Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

66 řádky
1.6KB

  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\Hash;
  9. class LoginCheckController extends WebController
  10. {
  11. public function name(): string
  12. {
  13. return "ログインチェック";
  14. }
  15. public function description(): string
  16. {
  17. return "ログインチェックを行う";
  18. }
  19. public function __construct(protected LoginCheckParam $param)
  20. {
  21. parent::__construct();
  22. }
  23. protected function run(Request $request): JsonResponse
  24. {
  25. $param = $this->param;
  26. // 取得したユーザ情報を登録しログインを行う
  27. // ログインパスワードチェック
  28. $users = User::whereEmail($param->email)
  29. ->get();
  30. foreach ($users as $user) {
  31. if (!Hash::check($param->password, $user->password)) {
  32. return $this->failedResponse();
  33. }
  34. }
  35. $access = Customer::getAccess();
  36. $query = Customer::getQuery()->where(Customer::FIELD_EMAIL, $param->email);
  37. $customers = $access->all($query);
  38. if ($customers->isEmpty()) {
  39. return $this->failedResponse();
  40. }
  41. $ret = [];
  42. foreach ($customers as $customer) {
  43. $ret[] = [
  44. 'customer_code' => $customer->customerCode,
  45. 'name' => $customer->customerName,
  46. ];
  47. }
  48. return $this->successResponse($ret);
  49. }
  50. }