AuthController.php 7.4 KB

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