Login.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. namespace app\controller\exe;
  3. use app\extra\basic\Base;
  4. use app\middleware\ExeMiddleware;
  5. use app\model\saas\SaasAgent;
  6. use app\model\system\SystemUser;
  7. use LinFly\Annotation\Route\Controller;
  8. use LinFly\Annotation\Route\Route;
  9. use Shopwwi\WebmanAuth\Auth;
  10. use support\Request;
  11. use support\Response;
  12. use think\facade\Db;
  13. use Tinywan\Captcha\Captcha;
  14. use Webman\Annotation\Middleware;
  15. #[Controller(prefix: "/exe/login")]
  16. class Login extends Base
  17. {
  18. /**
  19. * 登陆
  20. * @param Request $request
  21. * @return Response
  22. */
  23. #[Route(path: "user",methods: "post")]
  24. public function setLogin(Request $request): Response
  25. {
  26. try {
  27. $param = $this->_valid([
  28. "username.require" => trans("empty.user"),
  29. "password.require" => trans("empty.passwd"),
  30. ],"post");
  31. if (!is_array($param)) return error($param);
  32. $map = ["is_deleted" => 0,"username" => $param['username']];
  33. [$state,$msg,$user] = $this->checkLogin($map,2,$param);
  34. if (!$state) return error($msg);
  35. return successTrans("success.login",$user);
  36. } catch (\Throwable $throwable) {
  37. return error($throwable->getMessage());
  38. }
  39. }
  40. /**
  41. * 登录验证处理
  42. * @param array $map
  43. * @param int $type
  44. * @param array $param
  45. * @return array
  46. */
  47. protected function checkLogin(array $map = [],int $type = 1,array $param = []): array
  48. {
  49. $user = (new SystemUser)->where($map)->findOrEmpty();
  50. if ($user->isEmpty()) return [0,trans("error.user-empty"),[]];
  51. if ($user['status'] <> 1) return [0,trans("error.user-status"),[]];
  52. if ($user['type'] > 1) {
  53. $typeUser = $this->getTypeUser($user['agent_id']);
  54. if (empty($typeUser)) return [0,trans("empty.agent"),[]];
  55. if ($typeUser['status'] <> 0) return [0,trans("error.agent"),[]];
  56. if (time() > strtotime($typeUser['vip_end'])) return [0,trans("error.agent-out"),[]];
  57. $user['shop_name'] = $typeUser['shop_name'];
  58. }
  59. if ($type == 2) {
  60. if (md5(md5($param['password']).$user['salt']) <> $user['password']) return [0,trans("error.passwd"),[]];
  61. }
  62. $user->login_at = getDateFull();
  63. $user->login_ip = request()->getRealIp();
  64. $user->login_num = Db::raw("login_num+1");
  65. $user->save();
  66. return [1,'success',$user->toArray()];
  67. }
  68. /**
  69. * 获取代理信息
  70. * @param int $agentId
  71. * @return array
  72. */
  73. protected function getTypeUser(int $agentId = 0): array
  74. {
  75. return (new SaasAgent)->where("agent_id",$agentId)->findOrEmpty()->toArray();
  76. }
  77. /**
  78. * @return Response
  79. */
  80. #[Route(path: "profile",methods: "get"),Middleware(ExeMiddleware::class)]
  81. public function getLoginUser(Request $request): Response
  82. {
  83. try {
  84. $agent = (new SaasAgent)->where("agent_id",$request->uuid)->findOrEmpty();
  85. return successTrans("success.data",[
  86. "vip_at" => empty($agent['vip_end'])?'无限期':date('Y-m-d',strtotime($agent['vip_end'])),
  87. "agent_id" => $agent['agent_id'],
  88. "shop" => $agent['shop_name']??'',
  89. "address" => $agent['shop_address']??'',
  90. "sys" => sConf("service.title"),
  91. "logo" => sConf("service.logo")
  92. ]);
  93. } catch (\Throwable $exception){
  94. return error($exception->getMessage());
  95. }
  96. }
  97. }