LoginController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace App\Http\Controllers\Api\v1;
  3. use App\Http\Controllers\Api\webApp;
  4. use App\Http\Validator\MemberValidator;
  5. use App\Services\Api\MemberService;
  6. use App\Services\ConfigService;
  7. use App\Services\MpService;
  8. use App\Services\RedisService;
  9. use App\Services\SmsService;
  10. use App\Services\WechatService;
  11. use Illuminate\Http\Request;
  12. /**
  13. * 授权登录控制器基类
  14. * Class LoginController
  15. * @package App\Http\Controllers
  16. */
  17. class LoginController extends webApp
  18. {
  19. /**
  20. * 账号登录
  21. * @return array
  22. */
  23. public function login(MemberValidator $validator)
  24. {
  25. $params = request()->all();
  26. $params = $validator->check($params, 'login');
  27. if (!is_array($params)) {
  28. return showJson($params, false);
  29. }
  30. if(!$result = MemberService::make()->login($params)){
  31. return showJson(MemberService::make()->getError(), false);
  32. }
  33. return showJson(MemberService::make()->getError(), true, $result);
  34. }
  35. /**
  36. * 小程序授权登录
  37. * @param MemberValidator $validator
  38. * @return array
  39. */
  40. public function mpAuth(MemberValidator $validator)
  41. {
  42. $params = request()->all();
  43. $params = $validator->check($params, 'mp');
  44. if (!is_array($params)) {
  45. return showJson($params, false);
  46. }
  47. $code = isset($params['code'])? $params['code'] : '';
  48. if($result = MemberService::make()->mpAuth($code, $params)){
  49. return showJson(MemberService::make()->getError(), true, $result);
  50. }
  51. return showJson(MemberService::make()->getError(), false);
  52. }
  53. /**
  54. * 重置密码
  55. * @param MemberValidator $validator
  56. * @return array
  57. */
  58. public function forget(MemberValidator $validator)
  59. {
  60. $params = request()->all();
  61. $params = $validator->check($params, 'reset_password');
  62. if (!is_array($params)) {
  63. return showJson($params, false);
  64. }
  65. if(!MemberService::make()->forget($params)){
  66. $error = MemberService::make()->getError();
  67. return showJson($error,false,'',$error==1040?405:0);
  68. }else{
  69. return showJson(MemberService::make()->getError(),true);
  70. }
  71. }
  72. /**
  73. * 发送短信验证码
  74. * @return array
  75. */
  76. public function smsSend(MemberValidator $validator)
  77. {
  78. $params = request()->all();
  79. $params = $validator->check($params, 'sms');
  80. if (!is_array($params)) {
  81. return showJson($params, false);
  82. }
  83. // 发送验证码处理
  84. $mobile = isset($params['mobile']) ? $params['mobile'] : '';
  85. $scene = isset($params['scene']) ? $params['scene'] : '';
  86. switch ($scene) {
  87. case 'register':
  88. if (MemberService::make()->checkExists('mobile', $mobile)) {
  89. return showJson(1040, false);
  90. }
  91. break;
  92. case 'deposit': // 退保
  93. case 'reset_password': // 忘记密码
  94. case 'login':
  95. if (!MemberService::make()->checkExists('mobile',$mobile)) {
  96. return showJson(2001, false);
  97. }
  98. break;
  99. }
  100. if (!SmsService::make()->send($mobile, $scene)) {
  101. return showJson(SmsService::make()->getError(), false);
  102. }
  103. return showJson(1011, true);
  104. }
  105. /**
  106. * 退出登录
  107. * @return array
  108. */
  109. public function logout()
  110. {
  111. RedisService::clear("auths:info:".$this->userId);
  112. return showJson(1003, true);
  113. }
  114. }