您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

98 行
2.7KB

  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 Exception;
  7. use Illuminate\Http\JsonResponse;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\Auth;
  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. $customer = $access->some($query);
  31. if ($customer->count() !== 1) {
  32. return $this->failedResponse();
  33. }
  34. /**
  35. * @var Customer
  36. */
  37. $customer = $customer->first();
  38. $kintoneId = $customer->getRecordId();
  39. $user = User::whereKintoneId($kintoneId)
  40. ->first();
  41. if ($user instanceof User) {
  42. // すでにユーザー登録されているケース
  43. //データ同期
  44. if ($user->email !== $param->email) {
  45. $user->email = $param->email;
  46. $user->save();
  47. }
  48. if ($user->kintone_customer_code !== $customer->getNumber(Customer::FIELD_CUSTOMER_CODE)) {
  49. $user->kintone_customer_code = $customer->getNumber(Customer::FIELD_CUSTOMER_CODE);
  50. $user->save();
  51. }
  52. if (Auth::attempt([
  53. 'email' => $param->email,
  54. 'password' => $param->password,
  55. ])) {
  56. return $this->successResponse($customer->toArray());
  57. } else {
  58. return $this->failedResponse();
  59. }
  60. } else {
  61. // 初回ログインのケース
  62. $password = "testtest";
  63. $user = new User();
  64. $user->email = $param->email;
  65. $user->kintone_id = $customer->getRecordId();
  66. $user->password = $password;
  67. $user->kintone_customer_code = $customer->getNumber(Customer::FIELD_CUSTOMER_CODE);
  68. $user->save();
  69. if (Auth::attempt([
  70. 'email' => $param->email,
  71. 'password' => $password,
  72. ])) {
  73. return $this->successResponse($customer->toArray());
  74. } else {
  75. return $this->failedResponse();
  76. }
  77. }
  78. }
  79. }