New-Thanasoft/thanasoft-back/app/Http/Controllers/Api/PractitionerDocumentController.php
2025-11-05 17:09:12 +03:00

321 lines
12 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Http\Requests\StorePractitionerDocumentRequest;
use App\Http\Requests\UpdatePractitionerDocumentRequest;
use App\Http\Resources\Employee\PractitionerDocumentResource;
use App\Http\Resources\Employee\PractitionerDocumentCollection;
use App\Repositories\PractitionerDocumentRepositoryInterface;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Log;
class PractitionerDocumentController extends Controller
{
public function __construct(
private readonly PractitionerDocumentRepositoryInterface $practitionerDocumentRepository
) {
}
/**
* Display a listing of practitioner documents.
*/
public function index(Request $request): PractitionerDocumentCollection|JsonResponse
{
try {
$filters = [
'search' => $request->get('search'),
'practitioner_id' => $request->get('practitioner_id'),
'doc_type' => $request->get('doc_type'),
'valid_only' => $request->get('valid_only'),
'sort_by' => $request->get('sort_by', 'created_at'),
'sort_direction' => $request->get('sort_direction', 'desc'),
];
// Remove null filters
$filters = array_filter($filters, function ($value) {
return $value !== null && $value !== '';
});
$documents = $this->practitionerDocumentRepository->getAll($filters);
return new PractitionerDocumentCollection($documents);
} catch (\Exception $e) {
Log::error('Error fetching practitioner documents: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents des praticiens.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Display paginated practitioner documents.
*/
public function paginated(Request $request): JsonResponse
{
try {
$perPage = $request->get('per_page', 15);
$result = $this->practitionerDocumentRepository->getPaginated($perPage);
return response()->json([
'data' => new PractitionerDocumentCollection($result['documents']),
'pagination' => $result['pagination'],
'message' => 'Documents des praticiens récupérés avec succès.',
], 200);
} catch (\Exception $e) {
Log::error('Error fetching paginated practitioner documents: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents des praticiens.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Get documents by practitioner ID.
*/
public function byPractitioner(string $practitionerId): PractitionerDocumentCollection|JsonResponse
{
try {
$documents = $this->practitionerDocumentRepository->getByPractitionerId((int) $practitionerId);
return new PractitionerDocumentCollection($documents);
} catch (\Exception $e) {
Log::error('Error fetching documents by practitioner: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'practitioner_id' => $practitionerId,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents du praticien.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Get documents by type.
*/
public function byType(Request $request): PractitionerDocumentCollection|JsonResponse
{
try {
$docType = $request->get('doc_type');
if (!$docType) {
return response()->json([
'message' => 'Le paramètre doc_type est requis.',
], 400);
}
$documents = $this->practitionerDocumentRepository->getByDocumentType($docType);
return new PractitionerDocumentCollection($documents);
} catch (\Exception $e) {
Log::error('Error fetching documents by type: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'doc_type' => $docType,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents par type.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Get valid documents (not expired).
*/
public function valid(): PractitionerDocumentCollection|JsonResponse
{
try {
$documents = $this->practitionerDocumentRepository->getValid();
return new PractitionerDocumentCollection($documents);
} catch (\Exception $e) {
Log::error('Error fetching valid documents: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents valides.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Get expired documents.
*/
public function expired(): PractitionerDocumentCollection|JsonResponse
{
try {
$documents = $this->practitionerDocumentRepository->getExpired();
return new PractitionerDocumentCollection($documents);
} catch (\Exception $e) {
Log::error('Error fetching expired documents: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des documents expirés.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Get practitioner document statistics.
*/
public function statistics(): JsonResponse
{
try {
$statistics = $this->practitionerDocumentRepository->getStatistics();
return response()->json([
'data' => $statistics,
'message' => 'Statistiques des documents des praticiens récupérées avec succès.',
], 200);
} catch (\Exception $e) {
Log::error('Error fetching practitioner document statistics: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des statistiques.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Store a newly created practitioner document.
*/
public function store(StorePractitionerDocumentRequest $request): PractitionerDocumentResource|JsonResponse
{
try {
$document = $this->practitionerDocumentRepository->create($request->validated());
return new PractitionerDocumentResource($document);
} catch (\Exception $e) {
Log::error('Error creating practitioner document: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la création du document du praticien.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Display the specified practitioner document.
*/
public function show(string $id): PractitionerDocumentResource|JsonResponse
{
try {
$document = $this->practitionerDocumentRepository->find($id);
if (!$document) {
return response()->json([
'message' => 'Document du praticien non trouvé.',
], 404);
}
return new PractitionerDocumentResource($document);
} catch (\Exception $e) {
Log::error('Error fetching practitioner document: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'document_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération du document du praticien.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Update the specified practitioner document.
*/
public function update(UpdatePractitionerDocumentRequest $request, string $id): PractitionerDocumentResource|JsonResponse
{
try {
$updated = $this->practitionerDocumentRepository->update($id, $request->validated());
if (!$updated) {
return response()->json([
'message' => 'Document du praticien non trouvé ou échec de la mise à jour.',
], 404);
}
$document = $this->practitionerDocumentRepository->find($id);
return new PractitionerDocumentResource($document);
} catch (\Exception $e) {
Log::error('Error updating practitioner document: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'document_id' => $id,
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la mise à jour du document du praticien.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
/**
* Remove the specified practitioner document.
*/
public function destroy(string $id): JsonResponse
{
try {
$deleted = $this->practitionerDocumentRepository->delete($id);
if (!$deleted) {
return response()->json([
'message' => 'Document du praticien non trouvé ou échec de la suppression.',
], 404);
}
return response()->json([
'message' => 'Document du praticien supprimé avec succès.',
], 200);
} catch (\Exception $e) {
Log::error('Error deleting practitioner document: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'document_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la suppression du document du praticien.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
}