You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.3 KiB
PHP
115 lines
3.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\Permission;
|
|
use App\Models\Role;
|
|
use App\Models\RolePermission;
|
|
use Illuminate\Http\RedirectResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Inertia\Response;
|
|
|
|
class RoleController extends Controller
|
|
{
|
|
public function index(Request $request): Response
|
|
{
|
|
$request->user()->allow('view-role', true);
|
|
|
|
$query = Role::query()->with(['users']);
|
|
|
|
if ($request->q) {
|
|
$query->where('name', 'ilike', "%{$request->q}%");
|
|
}
|
|
|
|
$query->orderBy('created_at', 'desc');
|
|
|
|
return inertia('Role/Index', [
|
|
'data' => $query->paginate(10),
|
|
]);
|
|
}
|
|
|
|
public function create(): Response
|
|
{
|
|
return inertia('Role/Form', [
|
|
'permissions' => Permission::all(),
|
|
]);
|
|
}
|
|
|
|
public function store(Request $request): RedirectResponse
|
|
{
|
|
$request->validate([
|
|
'name' => 'string|required|max:255',
|
|
'permissions' => 'array|required',
|
|
'permissions.*.id' => 'ulid|required|exists:permissions,id',
|
|
]);
|
|
|
|
DB::beginTransaction();
|
|
$role = Role::create(['name' => $request->name]);
|
|
foreach ($request->permissions as $permission) {
|
|
RolePermission::create([
|
|
'role_id' => $role->id,
|
|
'permission_id' => $permission['id'],
|
|
]);
|
|
}
|
|
DB::commit();
|
|
|
|
return redirect()->route('roles.index')
|
|
->with('message', ['type' => 'success', 'message' => 'Item has beed saved']);
|
|
}
|
|
|
|
public function edit(Role $role): Response
|
|
{
|
|
return inertia('Role/Form', [
|
|
'role' => $role->load(['permissions']),
|
|
'permissions' => Permission::all(),
|
|
]);
|
|
}
|
|
|
|
public function update(Request $request, Role $role): RedirectResponse
|
|
{
|
|
$request->validate([
|
|
'name' => 'string|required|max:255',
|
|
'permissions' => 'array|required',
|
|
'permissions.*.id' => 'ulid|required|exists:permissions,id',
|
|
]);
|
|
|
|
if ($role->flag == 1) {
|
|
return redirect()->route('roles.index')
|
|
->with('message', ['type' => 'error', 'message' => 'Item default can\'t updated']);
|
|
}
|
|
|
|
DB::beginTransaction();
|
|
$role->update([
|
|
'name' => $request->name,
|
|
]);
|
|
|
|
RolePermission::where('role_id', $role->id)->delete();
|
|
|
|
foreach ($request->permissions as $permission) {
|
|
RolePermission::create([
|
|
'role_id' => $role->id,
|
|
'permission_id' => $permission['id'],
|
|
]);
|
|
}
|
|
DB::commit();
|
|
|
|
return redirect()->route('roles.index')
|
|
->with('message', ['type' => 'success', 'message' => 'Item has beed updated']);
|
|
}
|
|
|
|
public function destroy(Role $role): RedirectResponse
|
|
{
|
|
$deleted = $role->delete();
|
|
|
|
if ($deleted) {
|
|
return redirect()->route('roles.index')
|
|
->with('message', ['type' => 'success', 'message' => 'Item has beed deleted']);
|
|
}
|
|
|
|
return redirect()->route('roles.index')
|
|
->with('message', ['type' => 'error', 'message' => 'Item default can\'t deleted']);
|
|
}
|
|
}
|