Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/ecommerce/app/Http/Controllers/Shop/ |
<?php
namespace App\Http\Controllers\Shop;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
class UsersController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
$users = User::orderBy('id', 'ASC')->paginate(10);
return view('backend.users.index')->with('users', $users);
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
return view('backend.users.create');
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
*
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
$this->validate(
$request,
[
'name' => 'string|required|max:30',
'email' => 'string|required|unique:users',
'password' => 'string|required',
'role' => 'required|in:admin,user',
'status' => 'required|in:active,inactive',
'photo' => 'nullable|string',
]
);
$data = $request->all();
$data['password'] = Hash::make($request->password);
$status = User::create($data);
if ($status) {
request()->session()->flash('success', 'Successfully added user');
} else {
request()->session()->flash('error', 'Error occurred while adding user');
}
return redirect()->route('users.index');
}
/**
* Display the specified resource.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function show($id)
{
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
$user = User::findOrFail($id);
return view('backend.users.edit')->with('user', $user);
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
$user = User::findOrFail($id);
$this->validate(
$request,
[
'name' => 'string|required|max:30',
'email' => 'string|required',
'role' => 'required|in:admin,user',
'status' => 'required|in:active,inactive',
'photo' => 'nullable|string',
]
);
$data = $request->all();
$status = $user->fill($data)->save();
if ($status) {
request()->session()->flash('success', 'Successfully updated');
} else {
request()->session()->flash('error', 'Error occured while updating');
}
return redirect()->route('users.index');
}
/**
* Remove the specified resource from storage.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
$delete = User::findorFail($id);
$status = $delete->delete();
if ($status) {
request()->session()->flash('success', 'User Successfully deleted');
} else {
request()->session()->flash('error', 'There is an error while deleting users');
}
return redirect()->route('users.index');
}
}