QR_code_generator/app/Http/Controllers/Api/Users/UsersController.php

78 lines
2.9 KiB
PHP

<?php
namespace App\Http\Controllers\Api\Users;
use App\Events\UserRegistered;
use App\Http\Controllers\Controller;
use App\Models\User;
use App\Transformers\Users\UserTransformer;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class UsersController extends Controller {
protected User $model;
public function __construct(User $model) {
$this->model = $model;
/*
$this->middleware('permission:List users')->only('index');
$this->middleware('permission:List users')->only('show');
$this->middleware('permission:Create users')->only('store');
$this->middleware('permission:Update users')->only('update');
$this->middleware('permission:Delete users')->only('destroy');
*/
}
public function checkEmail(Request $request): JsonResponse {
$this->validate($request, ['email' => 'required|email|unique:users,email']);
return response()->json(null);
}
public function index(Request $request): JsonResponse {
$paginator = $this->model->with('roles.permissions')->paginate($request->get('limit', config('app.pagination_limit', 20)));
//if ($request->has('limit')) $paginator->appends('limit', $request->get('limit'));
return fractal($paginator, new UserTransformer())->respond();
}
public function show($id): JsonResponse {
$user = $this->model->with('roles.permissions')->byUuid($id)->firstOrFail();
return fractal($user, new UserTransformer())->respond();
}
public function store(Request $request): JsonResponse {
$this->validate($request, [
'name' => 'required',
'email' => 'required|email|unique:users,email',
'password' => 'required|min:8|confirmed',
]);
$user = $this->model->create($request->all());
$user->assignRole('User');
event(new UserRegistered($user, $request->get('password')));
//if ($request->has('roles')) $user->syncRoles($request['roles']);
return fractal($user, new UserTransformer())->respond(201);
}
public function update(Request $request, $uuid): JsonResponse {
$user = $this->model->byUuid($uuid)->firstOrFail();
$rules = [
'name' => 'required',
'email' => 'required|email|unique:users,email,'.$user->id,
];
if ($request->method() == 'PATCH') $rules = [
'name' => 'sometimes|required',
'email' => 'sometimes|required|email|unique:users,email,'.$user->id,
];
$this->validate($request, $rules);
$user->update($request->except('_token', 'password'));
//if ($request->has('roles')) $user->syncRoles($request['roles']);
return fractal($user->fresh(), new UserTransformer())->respond();
}
public function destroy(Request $request, $uuid): JsonResponse {
$user = $this->model->byUuid($uuid)->firstOrFail();
$user->forceDelete();
return response()->json(null, 204);
}
}