| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- <?php
- namespace app\controller\common;
- use app\extra\basic\Base;
- use app\extra\service\basic\SmsService;
- use app\middleware\AuthMiddleware;
- use app\model\saas\SaasAgent;
- use app\model\system\SystemUser;
- use Hzdad\Codecheck\Codecheck;
- use LinFly\Annotation\Route\Controller;
- use LinFly\Annotation\Route\Route;
- use Shopwwi\WebmanAuth\Auth;
- use support\Request;
- use support\Response;
- use think\facade\Db;
- use Tinywan\Captcha\Captcha;
- use Webman\Annotation\Middleware;
- #[Controller(prefix: "/api/login")]
- class Login extends Base
- {
- /**
- * 登陆
- * @param Request $request
- * @return Response
- */
- #[Route(path: "user",methods: "post")]
- public function setLogin(Request $request): Response
- {
- try {
- $param = $this->_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());
- }
- }
- }
|