feat: add API for updating internship status

This commit is contained in:
Veronika Fehérvíziová
2025-11-01 20:51:07 +01:00
parent e972463da2
commit 0932584faa
2 changed files with 63 additions and 2 deletions

View File

@@ -74,9 +74,40 @@ class InternshipStatusController extends Controller
/**
* Update the specified resource in storage.
*/
public function update(Request $request, InternshipStatus $internshipStatus)
public function update(int $id, Request $request)
{
//
$user = auth()->user();
$internship = Internship::find($id);
if(!$internship) {
return response()->json([
'message' => 'No such internship exists.'
], 400);
}
$company_contact = User::find($internship->contact);
if ($user->role !== 'ADMIN' && $user->id !== $company_contact->id) {
abort(403, 'Unauthorized');
}
$internshipStatus = $this->currentInternshipStatus($internship);
$newStatusValidator = 'in:' . implode(',', $this->possibleNewStatuses($internshipStatus->status, $user->role));
$request->validate([
'status' => ['required', 'string', 'uppercase', $newStatusValidator],
'note' => ['required', 'string', 'min:1']
]);
InternshipStatus::create([
'internship_id' => $id,
'status' => $request->status,
'note' => $request->note,
'changed' => now(),
'modified_by' => $user->id
]);
return response()->noContent();
}
/**
@@ -86,4 +117,33 @@ class InternshipStatusController extends Controller
{
//
}
private function possibleNewStatuses(string $current_status, string $userRole) {
switch ($current_status) {
case 'SUBMITTED':
if ($userRole === 'EMPLOYER') {
return [];
}
return ['CONFIRMED', 'DENIED'];
case 'CONFIRMED':
if ($userRole === 'EMPLOYER') {
return ['DENIED'];
}
return ['SUBMITTED', 'DENIED', 'DEFENDED', 'NOT_DEFENDED'];
case 'DENIED':
if ($userRole === 'EMPLOYER') {
return ['CONFIRMED'];
}
return ['SUBMITTED', 'CONFIRMED'];
case 'DEFENDED':
case 'NOT_DEFENDED':
return [];
default:
throw new \InvalidArgumentException('Unknown status');
}
}
private function currentInternshipStatus(Internship $internship) {
return InternshipStatus::whereInternshipId($internship->id)->orderByDesc('changed')->firstOrFail();
}
}

View File

@@ -32,6 +32,7 @@ Route::prefix('/internships')->group(function () {
Route::middleware("auth:sanctum")->group(function () {
Route::prefix('/{id}')->group(function () {
Route::get("/", [InternshipController::class, 'get'])->name("api.internships.get");
Route::put("/status", [InternshipStatusController::class, 'update'])->name("api.internships.status.update");
Route::get("/statuses", [InternshipStatusController::class, 'get'])->name("api.internships.get");
Route::post("/basic", [InternshipController::class, 'update_basic'])->name("api.internships.update.basic");
});