first commit
This commit is contained in:
37
app/Http/Requests/User/CreateUserRequest.php
Normal file
37
app/Http/Requests/User/CreateUserRequest.php
Normal file
@@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Enums\Role;
|
||||
use App\Enums\ScreenshotsState;
|
||||
use App\Models\User;
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
use Illuminate\Validation\Rules\Enum;
|
||||
|
||||
class CreateUserRequest extends CattrFormRequest
|
||||
{
|
||||
public function _authorize(): bool
|
||||
{
|
||||
return $this->user()->can('create', User::class);
|
||||
}
|
||||
|
||||
public function _rules(): array
|
||||
{
|
||||
return [
|
||||
'full_name' => 'required|string',
|
||||
'email' => 'required|email',
|
||||
'user_language' => 'required',
|
||||
'password' => 'sometimes|required|min:6',
|
||||
'important' => 'bool',
|
||||
'active' => 'required|bool',
|
||||
'screenshots_state' => ['required', new Enum(ScreenshotsState::class)],
|
||||
'manual_time' => 'sometimes|required|bool',
|
||||
'screenshots_interval' => 'required|int|min:1|max:15',
|
||||
'computer_time_popup' => 'required|int|min:1',
|
||||
'timezone' => 'required|string',
|
||||
'role_id' => ['required', new Enum(Role::class)],
|
||||
'type' => 'required|string',
|
||||
'web_and_app_monitoring' => 'sometimes|required|bool',
|
||||
];
|
||||
}
|
||||
}
|
||||
24
app/Http/Requests/User/DestroyUserRequest.php
Normal file
24
app/Http/Requests/User/DestroyUserRequest.php
Normal file
@@ -0,0 +1,24 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Http\Requests\AuthorizesAfterValidation;
|
||||
use App\Models\User;
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
|
||||
class DestroyUserRequest extends CattrFormRequest
|
||||
{
|
||||
use AuthorizesAfterValidation;
|
||||
|
||||
public function authorizeValidated(): bool
|
||||
{
|
||||
return $this->user()->can('destroy', User::find(request('id')));
|
||||
}
|
||||
|
||||
public function _rules(): array
|
||||
{
|
||||
return [
|
||||
'id' => 'required|int',
|
||||
];
|
||||
}
|
||||
}
|
||||
49
app/Http/Requests/User/EditUserRequest.php
Normal file
49
app/Http/Requests/User/EditUserRequest.php
Normal file
@@ -0,0 +1,49 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Enums\Role;
|
||||
use App\Enums\ScreenshotsState;
|
||||
use App\Models\User;
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Validation\Rule;
|
||||
use Illuminate\Validation\Rules\Enum;
|
||||
|
||||
class EditUserRequest extends CattrFormRequest
|
||||
{
|
||||
public function _authorize(): bool
|
||||
{
|
||||
return $this->user()->can('update', User::find(request('id')));
|
||||
}
|
||||
|
||||
public function _rules(): array
|
||||
{
|
||||
return [
|
||||
'id' => 'required|int',
|
||||
'full_name' => 'sometimes|required|string',
|
||||
'email' => [
|
||||
'sometimes',
|
||||
'required',
|
||||
'email',
|
||||
Rule::unique('users', 'email')->ignore(Request::input('id'))
|
||||
],
|
||||
'user_language' => 'sometimes|required',
|
||||
'password' => 'sometimes|required|min:6',
|
||||
'important' => 'sometimes|bool',
|
||||
'active' => 'sometimes|required|bool',
|
||||
'screenshots_state' => ['sometimes', 'required', new Enum(ScreenshotsState::class)],
|
||||
'manual_time' => 'sometimes|required|bool',
|
||||
'screenshots_interval' => 'sometimes|required|int|min:1|max:15',
|
||||
'computer_time_popup' => 'sometimes|required|int|min:1',
|
||||
'timezone' => 'sometimes|required|string',
|
||||
'role_id' => ['sometimes', 'required', new Enum(Role::class)],
|
||||
'project_roles' => 'sometimes|present|array',
|
||||
'project_roles.*.projects_ids.*' => 'required|array',
|
||||
'projects_roles.*.project_ids.*.id' => 'required|int|exists:projects,id',
|
||||
'project_roles.*.role_id' => ['required', new Enum(Role::class)],
|
||||
'type' => 'sometimes|required|string',
|
||||
'web_and_app_monitoring' => 'sometimes|required|bool',
|
||||
];
|
||||
}
|
||||
}
|
||||
20
app/Http/Requests/User/ListUsersRequest.php
Normal file
20
app/Http/Requests/User/ListUsersRequest.php
Normal file
@@ -0,0 +1,20 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Helpers\QueryHelper;
|
||||
use App\Models\User;
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
|
||||
class ListUsersRequest extends CattrFormRequest
|
||||
{
|
||||
public function _authorize(): bool
|
||||
{
|
||||
return $this->user()->can('viewAny', User::class);
|
||||
}
|
||||
|
||||
protected function _rules(): array
|
||||
{
|
||||
return QueryHelper::getValidationRules();
|
||||
}
|
||||
}
|
||||
21
app/Http/Requests/User/SendInviteUserRequest.php
Normal file
21
app/Http/Requests/User/SendInviteUserRequest.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
use App\Models\User;
|
||||
|
||||
class SendInviteUserRequest extends CattrFormRequest
|
||||
{
|
||||
public function _authorize(): bool
|
||||
{
|
||||
return $this->user()->can('create', User::class);
|
||||
}
|
||||
|
||||
public function _rules(): array
|
||||
{
|
||||
return [
|
||||
'id' => 'required|int|exists:users,id'
|
||||
];
|
||||
}
|
||||
}
|
||||
24
app/Http/Requests/User/ShowUserRequest.php
Normal file
24
app/Http/Requests/User/ShowUserRequest.php
Normal file
@@ -0,0 +1,24 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Requests\User;
|
||||
|
||||
use App\Http\Requests\AuthorizesAfterValidation;
|
||||
use App\Models\User;
|
||||
use App\Http\Requests\CattrFormRequest;
|
||||
|
||||
class ShowUserRequest extends CattrFormRequest
|
||||
{
|
||||
use AuthorizesAfterValidation;
|
||||
|
||||
public function authorizeValidated(): bool
|
||||
{
|
||||
return $this->user()->can('view', User::find(request('id')));
|
||||
}
|
||||
|
||||
protected function _rules(): array
|
||||
{
|
||||
return [
|
||||
'id' => 'required|int',
|
||||
];
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user