middleware('role:admin'); } /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index() { $users = User::all(); return view('admin.users.index', compact('users')); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { $roles = Role::all(); return view('admin.users.create', compact('roles')); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $validator = Validator::make($request->all(), [ 'name' => 'required', 'email' => 'required|email|unique:users', 'password' => 'required|min:8', 'role' => 'required', ]); if ($validator->fails()) { return redirect()->back()->withErrors($validator)->withInput(); } $user = User::create([ 'name' => $request->name, 'email' => $request->email, 'password' => Hash::make($request->password), ]); $role = Role::find($request->role); $user->assignRole($role); if ($user) { return redirect()->route('admin.users.index')->with('success', 'User created successfully.'); } else { return redirect()->back()->with('error', 'Failed to create user.'); } } /** * Display the specified resource. * * @param \App\Models\User $user * @return \Illuminate\Http\Response */ public function show(User $user) { $roles = Role::all(); return view('admin.users.detail', compact('user', 'roles')); } /** * Show the form for editing the specified resource. * * @param \App\Models\User $user * @return \Illuminate\Http\Response */ public function edit(User $user) { $roles = Role::all(); return view('admin.users.edit', compact('user', 'roles')); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param \App\Models\User $user * @return \Illuminate\Http\Response */ public function update(Request $request, User $user) { $validator = Validator::make($request->all(), [ 'name' => 'required', 'email' => 'required|email|unique:users,email,' . $user->id, 'role' => 'required', ]); if ($validator->fails()) { return redirect()->back()->withErrors($validator)->withInput(); } $user->update([ 'name' => $request->name, 'email' => $request->email, 'password' => $request->filled('password') ? Hash::make($request->password) : $user->password, ]); $role = Role::find($request->role); if ($role) { $user->syncRoles($role); } if ($user) { return redirect()->route('admin.users.index')->with('success', 'User updated successfully.'); } else { return redirect()->back()->with('error', 'Failed to update user.'); } } /** * Remove the specified resource from storage. * * @param \App\Models\User $user * @return \Illuminate\Http\Response */ public function destroy(User $user) { if (!$user->delete()) { return response()->json([ 'status' => false, 'message' => 'Data has been used on another page' ], 400); } return response()->json([ 'status' => true, 'message' => 'Success delete data' ], 200); } }