Files
backend_vib360_laravel/app/Http/Controllers/APIS/CustomerApi/AuthController.php
2025-03-11 17:54:54 +05:30

72 lines
2.1 KiB
PHP

<?php
namespace App\Http\Controllers\APIS;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Tymon\JWTAuth\Facades\JWTAuth;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Validator;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Hash;
class AuthController extends Controller
{
public function login(Request $request)
{
$validator = Validator::make($request->all(), [
'email' => 'required|email',
'password' => 'required',
]);
if ($validator->fails()) {
$validationErrors = $validator->errors()->all();
Log::error("Login validation error: " . implode(", ", $validationErrors));
return jsonResponseWithErrorMessageApi($validationErrors, 403);
}
$credentials = [
'email_address' => $request->email_address,
'password' => $request->password,
];
$isDelete = User::where('email_address', $request->email_address)->onlyTrashed()->first();
if ($isDelete) {
return jsonResponseWithErrorMessageApi(__('auth.deleted_user_by_admin'), 403);
}
$isExistEmail = User::where('email_address', $request->email_address)->whereNull('deleted_at')->first();
if ($isExistEmail == null) {
return jsonResponseWithErrorMessageApi(__('auth.incorrect_email'), 403);
}
if ($isExistEmail && !(Hash::check($request->password, $isExistEmail->password))) {
Log::error('Entered Password is wrong.');
return jsonResponseWithErrorMessageApi(__('auth.incorrect_password'), 403);
}
if (Auth::attempt($credentials)) {
$user = Auth::user();
$token = JWTAuth::fromUser($user);
$response = [
'access_token' => $token,
'user' => $user,
];
return jsonResponseWithSuccessMessage(__('auth.data_fetched_successfully'), $response, 200);
}
// Authentication failed
return response()->json(['error' => 'Unauthorized'], 401);
}
}