diff --git a/app/Http/Controllers/UserController.php b/app/Http/Controllers/UserController.php
index a6fbeca..cbdc55d 100644
--- a/app/Http/Controllers/UserController.php
+++ b/app/Http/Controllers/UserController.php
@@ -2,6 +2,7 @@
namespace App\Http\Controllers;
+use App\Models\Role;
use App\Models\User;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
@@ -18,7 +19,9 @@ class UserController extends Controller
public function edit(User $user): View
{
- return view('users.edit', compact('user'));
+ $roles = Role::orderBy('name')->get();
+
+ return view('users.edit', compact('user', 'roles'));
}
public function update(Request $request, User $user): RedirectResponse
@@ -26,9 +29,12 @@ class UserController extends Controller
$validated = $request->validate([
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'email', 'max:255', 'unique:users,email,'.$user->id],
+ 'roles' => ['nullable', 'array'],
+ 'roles.*' => ['integer', 'exists:roles,id'],
]);
- $user->update($validated);
+ $user->update(['name' => $validated['name'], 'email' => $validated['email']]);
+ $user->roles()->sync($validated['roles'] ?? []);
return redirect()->route('users.index')->with('success', __('User updated successfully.'));
}
diff --git a/app/Models/Role.php b/app/Models/Role.php
index 01a4676..86b8213 100644
--- a/app/Models/Role.php
+++ b/app/Models/Role.php
@@ -5,6 +5,7 @@ namespace App\Models;
use Database\Factories\RoleFactory;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
+use Illuminate\Database\Eloquent\Relations\BelongsToMany;
class Role extends Model
{
@@ -12,4 +13,9 @@ class Role extends Model
use HasFactory;
protected $fillable = ['name'];
+
+ public function users(): BelongsToMany
+ {
+ return $this->belongsToMany(User::class);
+ }
}
diff --git a/app/Models/User.php b/app/Models/User.php
index f6ba1d2..ee6a6d4 100644
--- a/app/Models/User.php
+++ b/app/Models/User.php
@@ -7,6 +7,7 @@ use Database\Factories\UserFactory;
use Illuminate\Database\Eloquent\Attributes\Fillable;
use Illuminate\Database\Eloquent\Attributes\Hidden;
use Illuminate\Database\Eloquent\Factories\HasFactory;
+use Illuminate\Database\Eloquent\Relations\BelongsToMany;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
@@ -29,4 +30,9 @@ class User extends Authenticatable
'password' => 'hashed',
];
}
+
+ public function roles(): BelongsToMany
+ {
+ return $this->belongsToMany(Role::class);
+ }
}
diff --git a/database/migrations/2026_05_11_040641_create_role_user_table.php b/database/migrations/2026_05_11_040641_create_role_user_table.php
new file mode 100644
index 0000000..bc623bd
--- /dev/null
+++ b/database/migrations/2026_05_11_040641_create_role_user_table.php
@@ -0,0 +1,28 @@
+foreignId('user_id')->constrained()->cascadeOnDelete();
+ $table->foreignId('role_id')->constrained()->cascadeOnDelete();
+ $table->primary(['user_id', 'role_id']);
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ */
+ public function down(): void
+ {
+ Schema::dropIfExists('role_user');
+ }
+};
diff --git a/resources/views/users/edit.blade.php b/resources/views/users/edit.blade.php
index 2b56d48..910da9b 100644
--- a/resources/views/users/edit.blade.php
+++ b/resources/views/users/edit.blade.php
@@ -25,6 +25,25 @@