validate([ 'name' => 'required|string|max:255', 'email' => 'required|string|email|max:255|unique:users', 'password' => 'required|string|min:8|confirmed', ]); $user = User::create([ 'name' => $validated['name'], 'email' => $validated['email'], 'password' => Hash::make($validated['password']), 'custom_field' => $request->custom_field ?? 'user', // ← ключевая строка ]); return response()->json([ 'message' => 'Пользователь зарегистрирован.', 'user' => $user, 'token' => $user->createToken('auth_token')->plainTextToken ], 201); } /** * Вход пользователя. */ public function login(Request $request) { $request->validate([ 'email' => 'required|email', 'password' => 'required', ]); $user = User::where('email', $request->email)->first(); if (!$user || !Hash::check($request->password, $user->password)) { throw ValidationException::withMessages([ 'email' => ['Неверные учётные данные.'], ]); } return response()->json([ 'message' => 'Успешный вход.', 'user' => $user, 'token' => $user->createToken('auth_token')->plainTextToken ]); } /** * Выход (инвалидация токена). */ public function logout(Request $request) { $request->user()->currentAccessToken()->delete(); return response()->json([ 'message' => 'Вы успешно вышли из системы.' ]); } }