kcal/app/Http/Controllers/UserController.php

82 lines
2.1 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Http\Requests\UpdateUserRequest;
use App\Models\User;
use Illuminate\Contracts\View\View;
use Illuminate\Http\RedirectResponse;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
class UserController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index(): View
{
return view('users.index')->with('users', User::all());
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Contracts\View\View
*/
public function create(): View
{
return $this->edit(new User());
}
/**
* Store a newly created resource in storage.
*/
public function store(UpdateUserRequest $request): RedirectResponse
{
return $this->update($request, new User());
}
/**
* Show the form for editing the specified resource.
*/
public function edit(User $user): View
{
return view('users.edit')->with('user', $user);
}
/**
* Update the specified resource in storage.
*/
public function update(UpdateUserRequest $request, User $user): RedirectResponse
{
$attributes = $request->validated();
$attributes['remember_token'] = Str::random(10);
$attributes['password'] = Hash::make($attributes['password']);
$attributes['admin'] = $attributes['admin'] ?? false;
$user->fill($attributes)->save();
session()->flash('message', "User {$user->name} updated!");
return redirect()->route('users.index');
}
/**
* Confirm removal of specified resource.
*/
public function delete(User $user): View
{
$this->authorize('delete', $user);
return view('users.delete')->with('user', $user);
}
/**
* Remove the specified resource from storage.
*/
public function destroy(User $user): RedirectResponse
{
$this->authorize('delete', $user);
$user->delete();
return redirect(route('users.index'))
->with('message', "User {$user->name} deleted!");
}
}