AuthController.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\AuthRequest;
  4. use App\Http\Requests\RefreshTokenAppRequest;
  5. use App\Http\Requests\RefreshTokenRequest;
  6. use App\Http\Requests\UserAppsRequest;
  7. use App\Http\Requests\UserAppsValidateCodeRequest;
  8. use App\Http\Resources\AuthResource;
  9. use App\Services\AuthService;
  10. use Illuminate\Http\JsonResponse;
  11. class AuthController extends Controller
  12. {
  13. public function __construct(protected AuthService $authService) {}
  14. public function login(AuthRequest $request): JsonResponse
  15. {
  16. $validated = $request->validated();
  17. $result = $this->authService->login(
  18. email: $validated['email'],
  19. password: $validated['password'],
  20. );
  21. if (! $result) {
  22. return $this->errorResponse(message: __('auth.failed'), code: 401);
  23. }
  24. return $this->successResponse(
  25. payload: new AuthResource($result['payload']),
  26. message: __('auth.logged_in'),
  27. )->withCookie(
  28. cookie(
  29. 'refresh_token',
  30. $result['refreshToken'],
  31. config('sanctum.rt_expiration') * 60,
  32. '/',
  33. config('session.domain'),
  34. config('session.secure'),
  35. true,
  36. false,
  37. 'Lax',
  38. ),
  39. );
  40. }
  41. public function loginApp(AuthRequest $request): JsonResponse
  42. {
  43. $validated = $request->validated();
  44. $result = $this->authService->login(
  45. email: $validated['email'],
  46. password: $validated['password'],
  47. );
  48. if (! $result) {
  49. return $this->errorResponse(message: __('auth.failed'), code: 401);
  50. }
  51. return $this->successResponse(
  52. payload: new AuthResource([
  53. ...$result['payload'],
  54. 'refresh_token' => $result['refreshToken'],
  55. ]),
  56. message: __('auth.logged_in'),
  57. );
  58. }
  59. public function logout(): JsonResponse
  60. {
  61. $this->authService->logout();
  62. return $this->successResponse(
  63. message: __('auth.logout'),
  64. )->withoutCookie('refresh_token');
  65. }
  66. public function refresh(RefreshTokenRequest $request): JsonResponse
  67. {
  68. $refresh_token = $request->cookie('refresh_token');
  69. if (is_null($refresh_token)) {
  70. return $this->errorResponse(
  71. code: 403,
  72. )->withoutCookie('refresh_token');
  73. }
  74. $result = $this->authService->refresh(
  75. $refresh_token
  76. );
  77. if (is_null($result)) {
  78. return $this->errorResponse(
  79. message: __('auth.unauthorized'),
  80. code: 403,
  81. )->withoutCookie('refresh_token');
  82. }
  83. return $this->successResponse(
  84. payload: new AuthResource($result['payload']),
  85. )->withCookie(
  86. cookie(
  87. 'refresh_token',
  88. $result['refreshToken'],
  89. config('sanctum.rt_expiration') * 60,
  90. '/',
  91. config('session.domain'),
  92. config('session.secure'),
  93. true,
  94. true,
  95. 'Lax',
  96. ),
  97. );
  98. }
  99. public function refreshApp(RefreshTokenAppRequest $request): JsonResponse
  100. {
  101. $refresh_token = $request->validated('refresh_token');
  102. if (is_null($refresh_token)) {
  103. return $this->errorResponse(code: 403);
  104. }
  105. $result = $this->authService->refresh(
  106. $refresh_token
  107. );
  108. if (is_null($result)) {
  109. return $this->errorResponse(
  110. message: __('auth.unauthorized'),
  111. code: 403,
  112. );
  113. }
  114. return $this->successResponse(
  115. payload: new AuthResource([
  116. ...$result['payload'],
  117. 'refresh_token' => $result['refreshToken'],
  118. ]),
  119. );
  120. }
  121. public function clientSendCode(UserAppsRequest $request): JsonResponse
  122. {
  123. $result = $this->authService->clientSendCode($request->validated());
  124. if (is_array($result) && isset($result['error'])) {
  125. return $this->errorResponse(message: __("auth.{$result['error']}"), code: 403);
  126. }
  127. return $this->successResponse(
  128. message: __('messages.code_sent'),
  129. code: 201,
  130. payload: ['isLogin' => $result],
  131. );
  132. }
  133. public function providerSendCode(UserAppsRequest $request): JsonResponse
  134. {
  135. $result = $this->authService->providerSendCode($request->validated());
  136. if (is_array($result) && isset($result['error'])) {
  137. return $this->errorResponse(message: __("auth.{$result['error']}"), code: 403);
  138. }
  139. return $this->successResponse(
  140. message: __('messages.code_sent'),
  141. code: 201,
  142. payload: ['isLogin' => $result],
  143. );
  144. }
  145. public function validateCodeClient(UserAppsValidateCodeRequest $request): JsonResponse
  146. {
  147. $email = $request->input('email');
  148. $phone = $request->input('phone');
  149. $code = $request->input('code');
  150. $isLogin = (bool) $request->input('isLogin', false);
  151. $result = $this->authService->validateCodeClient($request->validated(), $isLogin);
  152. if ($result === false) {
  153. return $this->errorResponse(message: __('auth.invalid_code'), code: 400);
  154. }
  155. if (is_array($result) && isset($result['error'])) {
  156. return $this->errorResponse(message: __("auth.{$result['error']}"), code: 403);
  157. }
  158. if ($isLogin) {
  159. return $this->successResponse(
  160. payload: new AuthResource([...$result['payload'], 'refresh_token' => $result['refreshToken']]),
  161. message: __('auth.logged_in'),
  162. );
  163. }
  164. return $this->successResponse(
  165. payload: ['email' => $email, 'phone' => $phone, 'code' => $code],
  166. message: __('auth.valid_code'),
  167. );
  168. }
  169. public function validateCodeProvider(UserAppsValidateCodeRequest $request): JsonResponse
  170. {
  171. $email = $request->input('email');
  172. $phone = $request->input('phone');
  173. $code = $request->input('code');
  174. $isLogin = (bool) $request->input('isLogin', false);
  175. $result = $this->authService->validateCodeProvider($request->validated(), $isLogin);
  176. if ($result === false) {
  177. return $this->errorResponse(message: __('auth.invalid_code'), code: 400);
  178. }
  179. if (is_array($result) && isset($result['error'])) {
  180. return $this->errorResponse(message: __("auth.{$result['error']}"), code: 403);
  181. }
  182. if ($isLogin) {
  183. return $this->successResponse(
  184. payload: new AuthResource([...$result['payload'], 'refresh_token' => $result['refreshToken']]),
  185. message: __('auth.logged_in'),
  186. );
  187. }
  188. return $this->successResponse(
  189. payload: ['email' => $email, 'phone' => $phone, 'code' => $code],
  190. message: __('auth.valid_code'),
  191. );
  192. }
  193. public function validateCode(UserAppsValidateCodeRequest $request): JsonResponse
  194. {
  195. try {
  196. $email = $request->input('email');
  197. $phone = $request->input('phone');
  198. $code = $request->input('code');
  199. $isLogin = $request->input('isLogin');
  200. $result = $this->authService->validateCode($request->validated(), $isLogin);
  201. if (! $result) {
  202. return $this->errorResponse(
  203. message: __('auth.invalid_code'),
  204. code: 400,
  205. );
  206. }
  207. if ($isLogin) {
  208. return $this->successResponse(
  209. payload: new AuthResource([
  210. ...$result['payload'],
  211. 'refresh_token' => $result['refreshToken'],
  212. ]),
  213. message: __('auth.logged_in'),
  214. );
  215. } else {
  216. return $this->successResponse(
  217. payload: ['email' => $email, 'phone' => $phone, 'code' => $code],
  218. message: __('auth.valid_code'),
  219. code: 200,
  220. );
  221. }
  222. } catch (\Exception $e) {
  223. return $this->errorResponse(
  224. message: __('auth.validation_error'),
  225. code: 500,
  226. );
  227. }
  228. }
  229. }