hyperf-view/app/System/Service/Dependencies/UserAuthService.php

100 lines
3.7 KiB
PHP

<?php
declare(strict_types=1);
/**
* MineAdmin is committed to providing solutions for quickly building web applications
* Please view the LICENSE file that was distributed with this source code,
* For the full copyright and license information.
* Thank you very much for using MineAdmin.
*
* @Author X.Mo<root@imoi.cn>
* @Link https://gitee.com/xmo/MineAdmin
*/
namespace App\System\Service\Dependencies;
use App\System\Mapper\SystemUserMapper;
use App\System\Model\SystemUser;
use Hyperf\Database\Model\ModelNotFoundException;
use Builder\Event\UserLoginAfter;
use Builder\Event\UserLoginBefore;
use Builder\Event\UserLogout;
use Builder\Exception\NormalStatusException;
use Builder\Exception\UserBanException;
use Builder\Helper\BaseCode;
use Builder\Interfaces\UserServiceInterface;
use Builder\Vo\UserServiceVo;
/**
* 用户登录
*/
class UserAuthService implements UserServiceInterface
{
/**
* 登录
* @param UserServiceVo $userServiceVo
* @return string
* @throws \Psr\Container\ContainerExceptionInterface
* @throws \Psr\Container\NotFoundExceptionInterface
* @throws \Psr\SimpleCache\InvalidArgumentException
*/
public function login(UserServiceVo $userServiceVo): string
{
$mapper = container()->get(SystemUserMapper::class);
try {
event(new UserLoginBefore(['username' => $userServiceVo->getUsername(), 'password' => $userServiceVo->getPassword()]));
$userinfo = $mapper->checkUserByUsername($userServiceVo->getUsername())->toArray();
$password = $userinfo['password'];
unset($userinfo['password']);
$userLoginAfter = new UserLoginAfter($userinfo);
if ($mapper->checkPass($userServiceVo->getPassword(), $password)) {
if (
($userinfo['status'] == SystemUser::USER_NORMAL)
||
($userinfo['status'] == SystemUser::USER_BAN && $userinfo['id'] == env('SUPER_ADMIN'))
) {
$userLoginAfter->message = t('jwt.login_success');
$token = user()->getToken($userLoginAfter->userinfo);
$userLoginAfter->token = $token;
event($userLoginAfter);
return $token;
} else {
$userLoginAfter->loginStatus = false;
$userLoginAfter->message = t('jwt.user_ban');
event($userLoginAfter);
throw new UserBanException;
}
} else {
$userLoginAfter->loginStatus = false;
$userLoginAfter->message = t('jwt.password_error');
event($userLoginAfter);
throw new NormalStatusException;
}
} catch (\Exception $e) {
if ($e instanceof ModelNotFoundException) {
throw new NormalStatusException(t('jwt.username_error'), BaseCode::NO_DATA);
}
if ($e instanceof NormalStatusException) {
throw new NormalStatusException(t('jwt.password_error'), BaseCode::PASSWORD_ERROR);
}
if ($e instanceof UserBanException) {
throw new NormalStatusException(t('jwt.user_ban'), BaseCode::USER_BAN);
}
console()->error($e->getMessage());
throw new NormalStatusException(t('jwt.unknown_error'));
}
}
/**
* 用户退出
* @throws \Psr\Container\ContainerExceptionInterface
* @throws \Psr\Container\NotFoundExceptionInterface
* @throws \Psr\SimpleCache\InvalidArgumentException
*/
public function logout()
{
$user = user();
event(new UserLogout($user->getUserInfo()));
$user->getJwt()->logout();
}
}