83 lines
2.0 KiB
PHP
83 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use Inertia\Inertia;
|
|
use Spatie\Permission\Models\Permission;
|
|
|
|
class PermissionController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
return Inertia::render('Permission/Index', [
|
|
'permissions' => Permission::all(),
|
|
]);
|
|
}
|
|
|
|
public function create()
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
return Inertia::render('Permission/Create');
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
$validated = $request->validate([
|
|
'name' => 'required|string|unique:permissions,name',
|
|
]);
|
|
|
|
Permission::create(['name' => $validated['name']]);
|
|
|
|
return redirect()->route('permissions.index')->with('success', 'Permission créée avec succès.');
|
|
}
|
|
|
|
public function edit(Permission $permission)
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
return Inertia::render('Permission/Edit', [
|
|
'permission' => $permission,
|
|
]);
|
|
}
|
|
|
|
public function update(Request $request, Permission $permission)
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
$validated = $request->validate([
|
|
'name' => 'required|string|unique:permissions,name,' . $permission->id,
|
|
]);
|
|
|
|
$permission->update(['name' => $validated['name']]);
|
|
|
|
return redirect()->route('permissions.index')->with('success', 'Permission mise à jour avec succès.');
|
|
}
|
|
|
|
public function destroy(Permission $permission)
|
|
{
|
|
if (!auth()->user()->hasRole('Admin')) {
|
|
abort(403);
|
|
}
|
|
|
|
$permission->delete();
|
|
|
|
return redirect()->route('permissions.index')->with('success', 'Permission supprimée avec succès.');
|
|
}
|
|
}
|