all(), [ 'name' => 'required|string|max:255', 'email' => 'required|string|email|max:255|unique:users', 'password' => 'required|string|min:8|confirmed', ], [ 'name.required' => 'El nombre es obligatorio', 'email.required' => 'El email es obligatorio', 'email.email' => 'El email debe ser válido', 'email.unique' => 'Este email ya está registrado', 'password.required' => 'La contraseña es obligatoria', 'password.min' => 'La contraseña debe tener al menos 8 caracteres', 'password.confirmed' => 'Las contraseñas no coinciden', ]); if ($validator->fails()) { return response()->json([ 'success' => false, 'message' => 'Error de validación', 'errors' => $validator->errors() ], 422); } $user = User::create([ 'name' => $request->name, 'email' => $request->email, 'password' => Hash::make($request->password), ]); // Criar categorias e dados padrão para o novo usuário $setupService = new UserSetupService(); $setupService->setupNewUser($user->id); $token = $user->createToken('auth-token')->plainTextToken; return response()->json([ 'success' => true, 'message' => 'Usuario registrado exitosamente', 'data' => [ 'user' => [ 'id' => $user->id, 'name' => $user->name, 'email' => $user->email, ], 'token' => $token, ] ], 201); } catch (\Exception $e) { return response()->json([ 'success' => false, 'message' => 'Error al registrar usuario', 'error' => $e->getMessage() ], 500); } } /** * Login user */ public function login(Request $request): JsonResponse { try { $validator = Validator::make($request->all(), [ 'email' => 'required|email', 'password' => 'required', ], [ 'email.required' => 'El email es obligatorio', 'email.email' => 'El email debe ser válido', 'password.required' => 'La contraseña es obligatoria', ]); if ($validator->fails()) { return response()->json([ 'success' => false, 'message' => 'Error de validación', 'errors' => $validator->errors() ], 422); } if (!Auth::attempt($request->only('email', 'password'))) { return response()->json([ 'success' => false, 'message' => 'Credenciales incorrectas' ], 401); } $user = User::where('email', $request->email)->first(); $token = $user->createToken('auth-token')->plainTextToken; return response()->json([ 'success' => true, 'message' => 'Inicio de sesión exitoso', 'data' => [ 'user' => [ 'id' => $user->id, 'name' => $user->name, 'email' => $user->email, ], 'token' => $token, ] ], 200); } catch (\Exception $e) { return response()->json([ 'success' => false, 'message' => 'Error al iniciar sesión', 'error' => $e->getMessage() ], 500); } } /** * Logout user (revoke token) */ public function logout(Request $request): JsonResponse { try { $request->user()->currentAccessToken()->delete(); return response()->json([ 'success' => true, 'message' => 'Sesión cerrada exitosamente' ], 200); } catch (\Exception $e) { return response()->json([ 'success' => false, 'message' => 'Error al cerrar sesión', 'error' => $e->getMessage() ], 500); } } /** * Get authenticated user */ public function me(Request $request): JsonResponse { try { $user = $request->user(); return response()->json([ 'success' => true, 'data' => [ 'user' => [ 'id' => $user->id, 'name' => $user->name, 'email' => $user->email, ] ] ], 200); } catch (\Exception $e) { return response()->json([ 'success' => false, 'message' => 'Error al obtener datos del usuario', 'error' => $e->getMessage() ], 500); } } }