nyavokevin 56b0c50111 feat(auth): add employee user linking and password setup flow
Add user management endpoints and link employees to existing users
through `user_id`, including API resources, validation, repository
support, and database migrations.

Introduce a two-step login flow that checks email first and lets users
without a password create one before signing in.

Update the employee detail UI with a dedicated user tab and refresh the
employee and intervention side navigation to support the new account
management flow.
2026-04-08 13:31:57 +03:00

174 lines
5.4 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Http\Requests\StoreUserRequest;
use App\Http\Requests\UpdateUserRequest;
use App\Models\User;
use App\Repositories\UserRepositoryInterface;
use Illuminate\Http\JsonResponse;
use Illuminate\Support\Facades\Log;
class UserController extends Controller
{
public function __construct(
private readonly UserRepositoryInterface $userRepository
) {
}
public function index(): JsonResponse
{
try {
$email = request()->query('email');
if ($email) {
$user = User::query()->where('email', $email)->first();
return response()->json([
'data' => $user,
'message' => $user
? 'Utilisateur recupere avec succes.'
: 'Aucun utilisateur trouve pour cet email.',
]);
}
return response()->json([
'data' => $this->userRepository->all()->sortBy('name')->values(),
'message' => 'Utilisateurs recuperes avec succes.',
]);
} catch (\Exception $e) {
Log::error('Error fetching users: ' . $e->getMessage(), [
'exception' => $e,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la recuperation des utilisateurs.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function store(StoreUserRequest $request): JsonResponse
{
try {
$user = $this->userRepository->create($request->validated());
return response()->json([
'data' => $user,
'message' => 'Utilisateur cree avec succes.',
], 201);
} catch (\Exception $e) {
Log::error('Error creating user: ' . $e->getMessage(), [
'exception' => $e,
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la creation de l\'utilisateur.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function show(string $id): JsonResponse
{
try {
$user = $this->userRepository->find($id);
if (! $user) {
return response()->json([
'message' => 'Utilisateur non trouve.',
], 404);
}
return response()->json([
'data' => $user,
'message' => 'Utilisateur recupere avec succes.',
]);
} catch (\Exception $e) {
Log::error('Error fetching user: ' . $e->getMessage(), [
'exception' => $e,
'user_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la recuperation de l\'utilisateur.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function update(UpdateUserRequest $request, string $id): JsonResponse
{
try {
$user = $this->userRepository->find($id);
if (! $user) {
return response()->json([
'message' => 'Utilisateur non trouve ou echec de la mise a jour.',
], 404);
}
$validated = $request->validated();
if (empty($validated['password'])) {
unset($validated['password']);
}
$updated = $user->fill($validated)->save();
if (! $updated) {
return response()->json([
'message' => 'Utilisateur non trouve ou echec de la mise a jour.',
], 404);
}
return response()->json([
'data' => $user->fresh(),
'message' => 'Utilisateur mis a jour avec succes.',
]);
} catch (\Exception $e) {
Log::error('Error updating user: ' . $e->getMessage(), [
'exception' => $e,
'user_id' => $id,
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la mise a jour de l\'utilisateur.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function destroy(string $id): JsonResponse
{
try {
$deleted = $this->userRepository->delete($id);
if (! $deleted) {
return response()->json([
'message' => 'Utilisateur non trouve ou echec de la suppression.',
], 404);
}
return response()->json([
'message' => 'Utilisateur supprime avec succes.',
]);
} catch (\Exception $e) {
Log::error('Error deleting user: ' . $e->getMessage(), [
'exception' => $e,
'user_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la suppression de l\'utilisateur.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
}