Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

72 lignes
1.8KB

  1. <?php
  2. namespace App\Http\Controllers\Web\Auth;
  3. use App\Http\Controllers\Web\WebController;
  4. use App\Kintone\Models\Customer;
  5. use App\Models\User;
  6. use Illuminate\Http\JsonResponse;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\Auth;
  9. use Illuminate\Support\Facades\Hash;
  10. class LoginController extends WebController
  11. {
  12. public function name(): string
  13. {
  14. return "ログイン";
  15. }
  16. public function description(): string
  17. {
  18. return "ログインを行う";
  19. }
  20. public function __construct(protected LoginParam $param)
  21. {
  22. parent::__construct();
  23. }
  24. protected function run(Request $request): JsonResponse
  25. {
  26. // 取得したユーザ情報を登録しログインを行う
  27. $param = $this->param;
  28. $access = Customer::getAccess();
  29. $query = Customer::getQuery()->where(Customer::FIELD_EMAIL, $param->email)
  30. ->where(Customer::FIELD_CUSTOMER_CODE, $param->customerCode);
  31. $customer = $access->some($query);
  32. if ($customer->count() !== 1) {
  33. return $this->failedResponse();
  34. }
  35. $customer = $customer->first();
  36. $kintoneId = $customer->getRecordId();
  37. $user = User::whereKintoneId($kintoneId)
  38. ->first();
  39. if ($user instanceof User) {
  40. // パスワードチェック
  41. if (!Hash::check($param->password, $user->password)) {
  42. return $this->failedResponse();
  43. }
  44. //データ同期 Email
  45. if ($user->email !== $param->email) {
  46. $user->email = $param->email;
  47. $user->save();
  48. }
  49. Auth::login($user);
  50. return $this->successResponse($customer->toArray());
  51. }
  52. return $this->failedResponse();
  53. }
  54. }