TRF Certest first commit

This commit is contained in:
2025-02-26 08:57:46 +01:00
commit 3ce064a108
2524 changed files with 475404 additions and 0 deletions
@@ -0,0 +1,22 @@
<?php
namespace Vanguard\Http\Requests\Auth;
class ApiLoginRequest extends LoginRequest
{
public function rules(): array
{
return array_merge(parent::rules(), [
'device_name' => 'required',
]);
}
public function getCredentials(): array
{
$credentials = parent::getCredentials();
unset($credentials['password']);
return $credentials;
}
}
@@ -0,0 +1,16 @@
<?php
namespace Vanguard\Http\Requests\Auth;
class ApiVerifyEmailRequest extends LoginRequest
{
public function rules(): array
{
return [
'id' => 'required',
'hash' => 'required',
'expires' => 'required',
'signature' => 'required',
];
}
}
+45
View File
@@ -0,0 +1,45 @@
<?php
namespace Vanguard\Http\Requests\Auth;
use Illuminate\Contracts\Validation\Factory as ValidationFactory;
use Vanguard\Http\Requests\Request;
class LoginRequest extends Request
{
public function rules(): array
{
return [
'username' => 'required',
'password' => 'required',
];
}
public function getCredentials(): array
{
// The form field for providing username or password
// have name of "username", however, in order to support
// logging users in with both (username and email)
// we have to check if user has entered one or another
$username = $this->get('username');
if ($this->isEmail($username)) {
return [
'email' => $username,
'password' => $this->get('password'),
];
}
return $this->only('username', 'password');
}
private function isEmail($param): bool
{
$factory = $this->container->make(ValidationFactory::class);
return ! $factory->make(
['username' => $param],
['username' => 'email']
)->fails();
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\Auth;
use Vanguard\Http\Requests\Request;
class PasswordRemindRequest extends Request
{
public function rules(): array
{
return [
'email' => 'required|email|exists:users,email',
];
}
}
@@ -0,0 +1,37 @@
<?php
namespace Vanguard\Http\Requests\Auth;
use Vanguard\Http\Requests\Request;
class PasswordResetRequest extends Request
{
public function rules(): array
{
return [
'token' => 'required',
'email' => 'required|email',
'password' => [
'required',
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
];
}
public function messages(): array
{
return [
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).'),
];
}
/**
* Get the password reset fields.
*/
public function credentials(): array
{
return $this->only('email', 'password', 'password_confirmation', 'token');
}
}
@@ -0,0 +1,55 @@
<?php
namespace Vanguard\Http\Requests\Auth;
use Vanguard\Http\Requests\Request;
use Vanguard\Support\Enum\UserStatus;
class RegisterRequest extends Request
{
public function rules(): array
{
$rules = [
'email' => 'required|email|unique:users,email',
'username' => 'required|unique:users,username',
'password' => [
'required',
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
];
if (setting('registration.captcha.enabled')) {
$rules['g-recaptcha-response'] = 'required|captcha';
}
if (setting('tos')) {
$rules['tos'] = 'accepted';
}
return $rules;
}
public function messages(): array
{
return [
'tos.accepted' => __('You have to accept Terms of Service.'),
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).'),
];
}
public function validFormData(): array
{
// Determine user status. User's status will be set to UNCONFIRMED
// if he has to confirm his email or to ACTIVE if email confirmation is not required
$status = setting('reg_email_confirmation')
? UserStatus::UNCONFIRMED
: UserStatus::ACTIVE;
return array_merge($this->only('email', 'username', 'password'), [
'status' => $status,
'email_verified_at' => setting('reg_email_confirmation') ? null : now(),
]);
}
}
@@ -0,0 +1,21 @@
<?php
namespace Vanguard\Http\Requests\Auth\Social;
use Illuminate\Validation\Rule;
use Vanguard\Http\Requests\Request;
class ApiAuthenticateRequest extends Request
{
public function rules(): array
{
return [
'network' => [
'required',
Rule::in(config('auth.social.providers')),
],
'social_token' => 'required',
'device_name' => 'required',
];
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\Auth\Social;
use Vanguard\Http\Requests\Request;
class SaveEmailRequest extends Request
{
public function rules(): array
{
return [
'email' => 'required|email|unique:users,email',
];
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\Permission;
use Illuminate\Foundation\Http\FormRequest;
class BasePermissionRequest extends FormRequest
{
public function messages(): array
{
return [
'name.unique' => __('Permission with this name already exists.'),
];
}
}
@@ -0,0 +1,20 @@
<?php
namespace Vanguard\Http\Requests\Permission;
use Illuminate\Validation\Rule;
use Vanguard\Rules\ValidPermissionName;
class CreatePermissionRequest extends BasePermissionRequest
{
public function rules(): array
{
return [
'name' => [
'required',
new ValidPermissionName,
Rule::unique('permissions', 'name'),
],
];
}
}
@@ -0,0 +1,21 @@
<?php
namespace Vanguard\Http\Requests\Permission;
use Vanguard\Http\Requests\Request;
class RemovePermissionRequest extends Request
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return $this->route('permission')->removable;
}
public function rules(): array
{
return [];
}
}
@@ -0,0 +1,20 @@
<?php
namespace Vanguard\Http\Requests\Permission;
use Illuminate\Validation\Rule;
use Vanguard\Rules\ValidPermissionName;
class UpdatePermissionRequest extends BasePermissionRequest
{
public function rules(): array
{
return [
'name' => [
'required',
new ValidPermissionName,
Rule::unique('permissions', 'name')->ignore($this->route('permission')->id),
],
];
}
}
+16
View File
@@ -0,0 +1,16 @@
<?php
namespace Vanguard\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
abstract class Request extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return true;
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\Role;
use Vanguard\Http\Requests\Request;
class CreateRoleRequest extends Request
{
public function rules(): array
{
return [
'name' => 'required|regex:/^[a-zA-Z0-9\-_\.]+$/|unique:roles,name',
];
}
}
@@ -0,0 +1,21 @@
<?php
namespace Vanguard\Http\Requests\Role;
use Vanguard\Http\Requests\Request;
class RemoveRoleRequest extends Request
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return $this->route('role')->removable;
}
public function rules(): array
{
return [];
}
}
@@ -0,0 +1,27 @@
<?php
namespace Vanguard\Http\Requests\Role;
use Illuminate\Validation\Rule;
use Vanguard\Http\Requests\Request;
use Vanguard\Permission;
class UpdateRolePermissionsRequest extends Request
{
public function rules(): array
{
$permissions = Permission::pluck('id')->toArray();
return [
'permissions' => 'required|array',
'permissions.*' => Rule::in($permissions),
];
}
public function messages(): array
{
return [
'permissions.*' => 'Provided permission does not exist.',
];
}
}
@@ -0,0 +1,17 @@
<?php
namespace Vanguard\Http\Requests\Role;
use Vanguard\Http\Requests\Request;
class UpdateRoleRequest extends Request
{
public function rules(): array
{
$role = $this->route('role');
return [
'name' => 'required|regex:/^[a-zA-Z0-9\-_\.]+$/|unique:roles,name,'.$role->id,
];
}
}
@@ -0,0 +1,7 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
class DisableTwoFactorRequest extends TwoFactorRequest
{
}
@@ -0,0 +1,11 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
class EnableTwoFactorRequest extends TwoFactorRequest
{
public function rules(): array
{
return [];
}
}
@@ -0,0 +1,7 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
class ReSendTwoFactorTokenRequest extends TwoFactorRequest
{
}
@@ -0,0 +1,64 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
use Laravel\Fortify\Contracts\TwoFactorAuthenticationProvider;
use Vanguard\Http\Requests\Request;
class TwoFactorLoginRequest extends Request
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize(): bool
{
if ($userId = $this->get('user')) {
// Only users with "users.manage" permission can enable 2FA for other users.
return $this->user()->hasPermission('users.manage') || $this->user()->id == $userId;
}
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules(): array
{
return [
'code' => 'nullable|string',
];
}
private function clear2FAUserId($result)
{
if ($result) {
$this->session()->forget('auth.2fa.id');
}
}
use PragmaRX\Google2FA\Google2FA;
public function hasValidCode($user): bool
{
try {
if (!$this->code) {
return false;
}
$google2fa = new Google2FA();
return tap(
$google2fa->verifyKey($user->google2fa_secret, $this->code),
fn($result) => $this->clear2FAUserId($result)
);
} catch (\Exception $e) {
\Log::info($e->getMessage());
return false;
}
}
}
@@ -0,0 +1,37 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
use Vanguard\Http\Requests\Request;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\User;
abstract class TwoFactorRequest extends Request
{
public function authorize(): bool
{
if ($userId = $this->get('user')) {
// Only users with "users.manage" permission can enable 2FA for other users.
return $this->user()->hasPermission('users.manage') || $this->user()->id == $userId;
}
return true;
}
public function rules(): array
{
return [];
}
/**
* Get the user for which we should enable the 2FA.
*/
public function theUser(): User
{
if ($userId = $this->get('user')) {
return app(UserRepository::class)->find($userId);
}
return $this->user();
}
}
@@ -0,0 +1,13 @@
<?php
namespace Vanguard\Http\Requests\TwoFactor;
class VerifyTwoFactorTokenRequest extends TwoFactorRequest
{
public function rules(): array
{
return [
'code' => 'required',
];
}
}
@@ -0,0 +1,38 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\Http\Requests\Request;
class CreateUserRequest extends Request
{
public function rules(): array
{
$rules = [
'email' => 'required|email|unique:users,email',
'username' => 'nullable|unique:users,username',
'password' => [
'required',
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
'birthday' => 'nullable|date',
'role_id' => 'required|exists:roles,id',
'verified' => 'boolean',
];
if ($this->get('country_id')) {
$rules['country_id'] = 'exists:countries,id';
}
return $rules;
}
public function messages(): array
{
return [
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).'),
];
}
}
@@ -0,0 +1,16 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\Http\Requests\Request;
class UpdateDetailsRequest extends Request
{
public function rules(): array
{
return [
'birthday' => 'nullable|date',
'role_id' => 'required|exists:roles,id',
];
}
}
@@ -0,0 +1,37 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\Http\Requests\Request;
use Vanguard\User;
class UpdateLoginDetailsRequest extends Request
{
public function rules(): array
{
$user = $this->getUserForUpdate();
return [
'email' => 'required|email|unique:users,email,' . $user->id,
'username' => 'nullable|unique:users,username,' . $user->id,
'password' => [
'nullable', // Permette di aggiornare i dati senza cambiare la password
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
];
}
public function messages(): array
{
return [
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).'),
];
}
protected function getUserForUpdate(): User
{
return $this->route('user');
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\Http\Requests\Request;
class UpdateProfileDetailsRequest extends Request
{
public function rules(): array
{
return [
'birthday' => 'nullable|date',
];
}
}
@@ -0,0 +1,13 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\User;
class UpdateProfileLoginDetailsRequest extends UpdateLoginDetailsRequest
{
protected function getUserForUpdate(): User
{
return \Auth::user();
}
}
@@ -0,0 +1,37 @@
<?php
namespace Vanguard\Http\Requests\User;
use Illuminate\Validation\Rule;
use Vanguard\Http\Requests\Request;
use Vanguard\Support\Enum\UserStatus;
class UpdateUserRequest extends Request
{
public function rules(): array
{
$user = $this->user();
return [
'email' => 'email|unique:users,email,' . $user->id,
'username' => 'nullable|unique:users,username,' . $user->id,
'password' => [
'nullable', // Permette di aggiornare i dati senza cambiare la password
'confirmed',
'min:8',
'regex:/^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/'
],
'birthday' => 'nullable|date',
'role_id' => 'exists:roles,id',
'country_id' => 'exists:countries,id',
'status' => Rule::in(array_keys(UserStatus::lists())),
];
}
public function messages(): array
{
return [
'password.regex' => __('The password must be at least 8 characters long and contain at least one number and one special character (@$!%*?&).'),
];
}
}
@@ -0,0 +1,15 @@
<?php
namespace Vanguard\Http\Requests\User;
use Vanguard\Http\Requests\Request;
class UploadAvatarRawRequest extends Request
{
public function rules(): array
{
return [
'file' => 'required|image',
];
}
}