Files
MyBajet/app/Http/Controllers/Admin/RoleController.php
2026-05-14 09:08:09 +08:00

51 lines
1.6 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Spatie\Permission\Models\Permission;
use Spatie\Permission\Models\Role;
class RoleController extends Controller
{
public function index()
{
return view('admin.roles.index', ['roles' => Role::with('permissions')->paginate(10)]);
}
public function create()
{
return view('admin.roles.form', ['role' => new Role(), 'permissions' => Permission::orderBy('name')->get()]);
}
public function store(Request $request)
{
$validated = $request->validate(['name' => ['required', 'unique:roles,name'], 'permissions' => ['array']]);
$role = Role::create(['name' => $validated['name'], 'guard_name' => 'web']);
$role->syncPermissions($validated['permissions'] ?? []);
return redirect()->route('roles.index')->with('success', 'Role berjaya ditambah.');
}
public function edit(Role $role)
{
return view('admin.roles.form', ['role' => $role, 'permissions' => Permission::orderBy('name')->get()]);
}
public function update(Request $request, Role $role)
{
$validated = $request->validate(['name' => ['required', 'unique:roles,name,'.$role->id], 'permissions' => ['array']]);
$role->update(['name' => $validated['name']]);
$role->syncPermissions($validated['permissions'] ?? []);
return redirect()->route('roles.index')->with('success', 'Role berjaya dikemaskini.');
}
public function destroy(Role $role)
{
$role->delete();
return back()->with('success', 'Role berjaya dipadam.');
}
}