AuthController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. /*
  3. * This file is part of the Jiannei/lumen-api-starter.
  4. *
  5. * (c) Jiannei <longjian.huang@foxmail.com>
  6. *
  7. * This source file is subject to the MIT license that is bundled
  8. * with this source code in the file LICENSE.
  9. */
  10. namespace App\Http\Controllers\Admin\Base;
  11. use App\Http\Controllers\Controller;
  12. use App\Repositories\Enums\ResponseCodeEnum;
  13. use App\Repositories\Models\Base\Admin;
  14. use App\Repositories\Transformers\Base\AdminTransformer;
  15. use Illuminate\Http\Request;
  16. use Illuminate\Support\Facades\App;
  17. use Illuminate\Support\Facades\Hash;
  18. use Illuminate\Support\Facades\Log;
  19. use Jiannei\Response\Laravel\Support\Facades\Response;
  20. class AuthController extends Controller
  21. {
  22. /**
  23. * Create a new controller instance.
  24. */
  25. public function __construct()
  26. {
  27. // $this->middleware('enum:false');
  28. $this->middleware('throttle:10,1', ['only' => ['login']]);
  29. }
  30. /**
  31. * 登录
  32. * Author: Mead
  33. */
  34. public function login(Request $request)
  35. {
  36. $this->validate($request, [
  37. 'username' => 'required',
  38. 'password' => 'required|min:6'
  39. ]);
  40. try {
  41. $credentials = request(['username', 'password']);
  42. $language = 'zh_CN';
  43. switch (App::getLocale()) {
  44. case 'zh_CN':
  45. default:
  46. $language = 'zh_CN';
  47. break;
  48. case 'en':
  49. $language = 'en';
  50. break;
  51. }
  52. $credentials['language'] = $language;
  53. if (!$token = auth()->guard('admins')->attempt($credentials)) {
  54. return Response::fail(T('The account or password is incorrect.'), ResponseCodeEnum::SERVICE_LOGIN_ERROR);
  55. }
  56. $user = auth('admins')->user();
  57. } catch (\Exception $exception) {
  58. Log::error($exception);
  59. $this->errorStore($exception);
  60. }
  61. return Response::success(compact('token', 'user'));
  62. }
  63. /**
  64. * 退出
  65. * @return mixed
  66. * Author: Mead
  67. */
  68. public function logout()
  69. {
  70. auth('admins')->logout();
  71. return Response::noContent();
  72. }
  73. /**
  74. * 用户
  75. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\JsonResource
  76. * Author: Mead
  77. */
  78. public function me()
  79. {
  80. Log::error(login_admin_id());
  81. $admin = Admin::query()->find(login_admin_id());
  82. Log::error(arr2str($admin->toArray()));
  83. $me = (new AdminTransformer())->transform($admin);
  84. return Response::success($me);
  85. }
  86. public function update(Request $request)
  87. {
  88. $this->validate($request, [
  89. 'username' => 'required|min:6',
  90. 'name' => 'required',
  91. 'password' => 'sometimes|confirmed',
  92. 'headimg' => 'sometimes',
  93. 'department_id' => 'required',
  94. 'status' => 'required',
  95. ]);
  96. try {
  97. $data = $request->only(['username', 'name', 'password', 'headimg', 'department_id', 'status']);
  98. if (isset($data['password']) && $data['password']) {
  99. $data['password'] = Hash::make($data['password']);
  100. } else {
  101. unset($data['password']);
  102. }
  103. $re = Admin::query()->where('id', login_admin_id())->update($data);
  104. if ($re) {
  105. return Response::success(null);
  106. }
  107. return $this->errorFail();
  108. } catch (\Exception $e) {
  109. $this->errorStore($e);
  110. }
  111. }
  112. }