MIF_E31221264/app/Http/Controllers/UserController.php

91 lines
2.2 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
class UserController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index()
{
$users = User::all(); // Mengambil semua data user
return view('admin.pages.user.index', compact('users'));
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
//
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
//
}
/**
* Display the specified resource.
*/
public function show($id)
{
$user = User::findOrFail($id); // Ambil data user, jika tidak ada akan 404
return view('admin.pages.user.show', compact('user'));
}
/**
* Show the form for editing the specified resource.
*/
public function edit($id)
{
$user = User::findOrFail($id); // Ambil data user
return view('admin.pages.user.edit', compact('user'));
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, $id)
{
$user = User::findOrFail($id); // Ambil user berdasarkan ID
// Validasi input dari form
$request->validate([
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users,email,' . $id,
'username' => 'required|string|unique:users,username,' . $id,
'password' => 'nullable|string|min:6|confirmed', // validasi password + konfirmasi
]);
// Ambil data yang akan diperbarui
$data = $request->only(['name', 'email', 'username']);
// Jika password diisi, enkripsi dan tambahkan ke data
if ($request->filled('password')) {
$data['password'] = Hash::make($request->password);
}
// Update data user di database
$user->update($data);
return redirect()->route('admin.user.show', $user->id)->with('success', 'User berhasil diperbarui');
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
//
}
}