Added login controller and reset_user_password console script

This commit is contained in:
amikhaylov
2026-05-27 11:38:11 +03:00
parent ac47c7114d
commit d8d49f7bba
4 changed files with 133 additions and 1 deletions
@@ -0,0 +1,66 @@
<?php
declare(strict_types=1);
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
class LoginController extends Controller
{
public function login(Request $request)
{
// 1. Валидация JSON-данных
$validator = Validator::make($request->all(), [
'email' => ['required', 'string', 'email'],
'password' => ['required', 'string'],
]);
if ($validator->fails()) {
return response()->json([
'status' => 'error',
'message' => 'Validation failed',
'errors' => $validator->errors()
], 422);
}
// 2. Поиск пользователя
$user = User::where('email', $request->email)->first();
// 3. Проверка пароля
if (!$user || !Hash::check($request->password, $user->password)) {
return response()->json([
'status' => 'error',
'message' => 'Invalid credentials'
], 401);
}
// 4. Генерация нового токена Sanctum
$token = $user->createToken('auth_token')->plainTextToken;
return response()->json([
'status' => 'success',
'message' => 'Logged in successfully',
'data' => [
'user' => $user,
'token_type' => 'Bearer',
'access_token' => $token,
]
], 200);
}
public function logout(Request $request)
{
// Удаление текущего токена, с которым пришел пользователь
$request->user()->currentAccessToken()->delete();
return response()->json([
'status' => 'success',
'message' => 'Logged out successfully'
], 200);
}
}