TRF Certest first commit
This commit is contained in:
@@ -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',
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -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',
|
||||
];
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user