mirror of
https://github.com/ConvoyPanel/panel.git
synced 2026-07-02 18:04:37 +08:00
Add basic application APIs
This commit is contained in:
63
app/Http/Controllers/Application/Users/UserController.php
Normal file
63
app/Http/Controllers/Application/Users/UserController.php
Normal file
@@ -0,0 +1,63 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Application\Users;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\Application\Users\StoreUserRequest;
|
||||
use App\Http\Requests\Application\Users\UpdateUserRequest;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Response;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
|
||||
class UserController extends Controller
|
||||
{
|
||||
public function index()
|
||||
{
|
||||
return User::all();
|
||||
}
|
||||
|
||||
public function show(User $user)
|
||||
{
|
||||
return new Response([
|
||||
'data' => $user
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
public function store(StoreUserRequest $request)
|
||||
{
|
||||
$user = User::create([
|
||||
'name' => $request->name,
|
||||
'email' => $request->email,
|
||||
'password' => Hash::make($request->password),
|
||||
'root_admin' => $request->root_admin
|
||||
]);
|
||||
|
||||
return new Response([
|
||||
'data' => $user,
|
||||
'message' => 'User created',
|
||||
]);
|
||||
}
|
||||
|
||||
public function update(User $user, UpdateUserRequest $request)
|
||||
{
|
||||
if (isset($request->password)) {
|
||||
$user->update([
|
||||
'name' => $request->name,
|
||||
'email' => $request->email,
|
||||
'password' => Hash::make($request->password),
|
||||
'root_admin' => $request->root_admin
|
||||
]);
|
||||
} else {
|
||||
$user->update($request->safe()->except(['password']));
|
||||
}
|
||||
|
||||
return new Response([
|
||||
'data' => $user,
|
||||
'message' => 'User updated',
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user