megacommit

This commit is contained in:
Didier Slof 2023-02-02 08:17:38 +01:00
parent 2451ab45cb
commit 34ed81516b
Signed by: didier
GPG key ID: 01E71F18AA4398E5
51 changed files with 1200 additions and 251 deletions

View file

@ -14,6 +14,7 @@ use Illuminate\Support\Facades\Route;
|
*/
Route::middleware('auth:sanctum')->get('/user', function (Request $request) {
return $request->user();
});
@ -42,3 +43,72 @@ Route::get('/showings/{id}/seatMatrix', function ($id) {
$showing = (new App\Models\Showing)->find($id);
return $showing->seatMatrix();
});
// /api/showing/{id}/prices
Route::get('/showing/{id}/prices', function ($id) {
$showing = (new App\Models\Showing)->find($id);
return $showing->prices;
});
// /api/user/{id}/permissions
Route::get('/user/{id}/permissions', function ($id) {
$user = (new App\Models\User)->find($id);
return $user->permissions;
})->name('api.user.permissions');
Route::post('/user/{id}/permission', function ($id, Request $request) {
$user = (new App\Models\User)->find($id);
// check if request is valid
if (!isset($request->permission_name)) {
return response()->json(['error' => 'permission name not set'], 400);
}
// check if permission exists
// if it does not exist, create it
$permission = (new App\Models\Permission)->where('permission_name', $request->permission_name);
if ($permission->count() == 0) {
$permission = (new App\Models\Permission)->create(['permission_name' => $request->permission_name]);
} else {
$permission = $permission->first();
}
// check if user has permission
// if not, add it
$user->permissions()->attach($permission->permission_id);
$user->save();
return $user->permissions;
})->name('api.user.permission');
Route::delete('/user/{id}/permission', function ($id, Request $request) {
$user = (new App\Models\User)->find($id);
$perm = (new App\Models\Permission())->find(request('permission_id'));
$user->permissions->detach($perm);
$user->save();
return $user->permissions;
})->name('api.user.permission');
// /api/user/{id}/assignments
Route::get('/user/{id}/assignments', function ($id) {
$user = (new App\Models\User)->find($id);
return $user->cinemas;
})->name('api.user.assignments');
Route::post('/user/{id}/assignment', function ($id) {
$user = (new App\Models\User)->find($id);
$cinema = (new App\Models\Cinema())->find(request('cinema_id'));
$user->cinemas->attach($cinema);
$user->save();
return $user->cinemas;
})->name('api.user.assignment');
Route::delete('/user/{id}/assignment', function ($id) {
$user = (new App\Models\User)->find($id);
$cinema = (new App\Models\Cinema())->find(request('cinema_id'));
$user->cinemas->detach($cinema);
$user->save();
return $user->cinemas;
})->name('api.user.assignment');