_valid([ "username.require" => trans("empty.user"), "password.require" => trans("empty.passwd"), "code.require" => trans("empty.code"), "key.require" => trans("empty.data"), ],"post"); if (!is_array($param)) return error($param); if (Captcha::check($param['code'],$param['key']) === false) return errorTrans("error.captcha"); $map = ["is_deleted" => 0,"username" => $param['username']]; [$state,$msg,$user] = $this->checkLogin($map,2,$param); if (!$state) return error($msg); return successTrans("success.login",get_object_vars((new Auth)->guard("admin")->login($user))); } catch (\Throwable $throwable) { return error($throwable->getMessage()); } } /** * 手机号码登陆 * @param Request $request * @return Response */ #[Route(path: "mobile",methods: "post")] public function setLogin2Mobile(Request $request): Response { try { $param = $this->_valid([ "mobile.require" => trans("empty.mobile"), "code.require" => trans("empty.code"), "scene.require" => trans("empty.data"), ],"post"); if (!is_array($param)) return error($param); $code = (new Codecheck)->mobile($param['mobile'])->scene($param['scene'])->code($param['code'])->check(); if (!$code) return errorTrans("error.captcha"); $map = ["is_deleted" => 0,"mobile" => $param['mobile']]; [$state,$msg,$user] = $this->checkLogin($map); if (!$state) return error($msg); return successTrans("success.login",get_object_vars((new Auth)->guard("admin")->login($user))); } catch (\Throwable $throwable) { return error($throwable->getMessage()); } } /** * 登录验证处理 * @param array $map * @param int $type * @param array $param * @return array */ protected function checkLogin(array $map = [],int $type = 1,array $param = []): array { $user = (new SystemUser)->where($map)->findOrEmpty(); if ($user->isEmpty()) return [0,trans("error.user-empty"),[]]; if ($user['status'] <> 1) return [0,trans("error.user-status"),[]]; if ($user['type'] > 1) { $typeUser = $this->getTypeUser($user['agent_id']); if (empty($typeUser)) return [0,trans("empty.agent"),[]]; if ($typeUser['status'] <> 1) return [0,trans("error.agent"),[]]; if (time() > strtotime($typeUser['vip_at'])) return [0,trans("error.agent-out"),[]]; } if ($type == 2) { if (md5($param['password'].$user['salt']) <> $user['password']) return [0,trans("error.passwd"),[]]; } $user->login_at = getDateFull(); $user->login_ip = request()->getRealIp(); $user->login_num = Db::raw("login_num+1"); $user->save(); return [1,'success',$user->toArray()]; } /** * 获取代理信息 * @param int $agentId * @return array */ protected function getTypeUser(int $agentId = 0): array { return (new SaasAgent)->where("agent_id",$agentId)->findOrEmpty()->toArray(); } /** * @return Response */ #[Route(path: "profile",methods: "get"),Middleware(AuthMiddleware::class)] public function getLoginUser(): Response { try { $userData = (new Auth)->guard("admin")->user()->toArray(); if (isset($userData['password'])) unset($userData['password']); $agent = (new SaasAgent)->where("agent_id",$userData['agent_id'])->findOrEmpty(); if (empty($agent['vip_at'])) { $userData['vip_at'] = 0; } else { $userData['vip_at'] = strtotime($agent['vip_at']); } return successTrans("success.data",[ "username" => $userData['username'], "truename" => $userData['truename'], "vip_at" => $userData['vip_at'], "super" => $userData['is_super'], "type" => $userData['type'] ]); } catch (\Throwable $exception){ return error($exception->getMessage()); } } /** * 发送登录/注册验证码 * @param Request $request * @return Response */ #[Route(path: "sms",methods: "post")] public function getLoginSms(Request $request): Response { try { $param = $this->_valid([ "mobile.require" => trans("empty.mobile"), "mobile.mobile" => trans("error.mobile"), "code.require" => trans("empty.code"), "key.require" => trans("empty.data"), "scene.require" => trans("empty.data"), ],"post"); if (!is_array($param)) return error($param); if (Captcha::check($param['code'],$param['key']) === false) return errorTrans("error.captcha"); [$state,$msg] = (new SmsService)->sendSceneSms($param['mobile'],$param['scene']); if (!$state) return error($msg); return success($msg); } catch (\Throwable $throwable) { return error($throwable->getMessage()); } } }