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