12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- namespace app\admin\service\auth;
- use app\model\SysRole;
- use app\model\SysUser;
- use support\Db;
- use support\Request;
- use Tinywan\Jwt\JwtToken;
- class AuthService
- {
- public static function login($params)
- {
- DB::beginTransaction();
- try {
- $user = SysUser::findByLoginName($params['username']);
- if (!$user || $user->user_login_pass != md5(sha1($params['password']))) {
- throw new \Exception('账号 / 密码错误');
- }
- // 禁用用户
- if ($user->user_status == 'DISABLED') {
- throw new \Exception('当前账户已禁用,请联系管理员');
- }
- switch ($user->user_status) {
- case 'DISABLED':
- throw new \Exception('当前账户已禁用,请联系管理员');
- break;
- case 'PENDING':
- // 待激活用户登录后自动激活
- $user->user_status = 'ACTIVED';
- if (!$user->save()) {
- throw new \Exception('用户状态修改失败');
- }
- break;
- default:
- break;
- }
- $extend = [
- 'id' => $user->user_id,
- 'client' => 'admin',
- 'name'=> $user->user_name
- ];
- $token = JwtToken::generateToken($extend);
- $user->user_login_status = "ONLINE";
- $user->save();
- // 提交事务
- DB::commit();
- // 写操作日志
- _syslog("登录", "管理员【" . $params['username'] . "】登录系统; ID:" . $user->user_id, false, false, $user->user_id);
- return json_success('', $token);
- } catch (\Exception $e) {
- // 回滚事务
- DB::rollBack();
- return json_fail($e->getMessage());
- }
- }
- /**
- * @Desc 刷新token
- * @Author Gorden
- * @Date 2024/2/21 17:10
- *
- * @return \support\Response
- */
- public static function refreshToken()
- {
- $token = JwtToken::refreshToken();
- return json_success('Token已刷新', $token);
- }
- public static function userInfo(Request $request)
- {
- $user = SysUser::select('user_id', 'join_user_role_id', 'join_user_dept_id', 'user_status', 'user_category', 'user_name', 'user_login_name', 'user_mobile', 'user_remark', 'user_extend_json', 'user_addtimes')
- ->where('user_id', $request->adminId)
- ->first()
- ->toArray();
- $user['roleName'] = '';
- if (!empty($user['join_user_role_id'])) {
- $role = SysRole::where('role_id', $user['join_user_role_id'])->first();
- if (!empty($role->role_name)) {
- $user['roleName'] = $role->role_name;
- }
- }
- return json_success('', $user);
- }
- }
|