first commit

This commit is contained in:
Noor E Ilahi
2026-01-09 12:54:53 +05:30
commit 7ccf44f7da
1070 changed files with 113036 additions and 0 deletions

View 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',
];
}
}

View 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',
];
}
}

View 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',
];
}
}

View 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();
}
}

View 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'
];
}
}

View 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',
];
}
}