You've already forked isop-mirror
feat: add API for updating internship status
This commit is contained in:
@@ -74,9 +74,40 @@ class InternshipStatusController extends Controller
|
|||||||
/**
|
/**
|
||||||
* Update the specified resource in storage.
|
* 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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ Route::prefix('/internships')->group(function () {
|
|||||||
Route::middleware("auth:sanctum")->group(function () {
|
Route::middleware("auth:sanctum")->group(function () {
|
||||||
Route::prefix('/{id}')->group(function () {
|
Route::prefix('/{id}')->group(function () {
|
||||||
Route::get("/", [InternshipController::class, 'get'])->name("api.internships.get");
|
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::get("/statuses", [InternshipStatusController::class, 'get'])->name("api.internships.get");
|
||||||
Route::post("/basic", [InternshipController::class, 'update_basic'])->name("api.internships.update.basic");
|
Route::post("/basic", [InternshipController::class, 'update_basic'])->name("api.internships.update.basic");
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user