mirror of
https://github.com/Bubka/2FAuth.git
synced 2025-01-25 23:58:41 +01:00
Apply Laravel Pint fixes
This commit is contained in:
parent
6deb279c8d
commit
2d706e61b7
@ -16,11 +16,11 @@ class WebauthnCredentialBroker extends PasswordBroker
|
|||||||
* @param \Closure|null $callback
|
* @param \Closure|null $callback
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function sendResetLink(array $credentials, Closure $callback = null): string
|
public function sendResetLink(array $credentials, Closure $callback = null) : string
|
||||||
{
|
{
|
||||||
$user = $this->getUser($credentials);
|
$user = $this->getUser($credentials);
|
||||||
|
|
||||||
if (!$user instanceof WebAuthnAuthenticatable) {
|
if (! $user instanceof WebAuthnAuthenticatable) {
|
||||||
return static::INVALID_USER;
|
return static::INVALID_USER;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ public function reset(array $credentials, Closure $callback)
|
|||||||
{
|
{
|
||||||
$user = $this->validateReset($credentials);
|
$user = $this->validateReset($credentials);
|
||||||
|
|
||||||
if (!$user instanceof CanResetPasswordContract || !$user instanceof WebAuthnAuthenticatable) {
|
if (! $user instanceof CanResetPasswordContract || ! $user instanceof WebAuthnAuthenticatable) {
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,8 +2,6 @@
|
|||||||
|
|
||||||
namespace App\Helpers;
|
namespace App\Helpers;
|
||||||
|
|
||||||
use Illuminate\Support\Str;
|
|
||||||
|
|
||||||
class Helpers
|
class Helpers
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
@ -12,7 +10,7 @@ class Helpers
|
|||||||
* @param string|null $release
|
* @param string|null $release
|
||||||
* @return string|false
|
* @return string|false
|
||||||
*/
|
*/
|
||||||
public static function cleanVersionNumber(?string $release): string|false
|
public static function cleanVersionNumber(?string $release) : string|false
|
||||||
{
|
{
|
||||||
// We use the regex for semver detection (see https://semver.org/)
|
// We use the regex for semver detection (see https://semver.org/)
|
||||||
return preg_match('/(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?/', $release, $version) ? $version[0] : false;
|
return preg_match('/(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?/', $release, $version) ? $version[0] : false;
|
||||||
@ -24,7 +22,7 @@ public static function cleanVersionNumber(?string $release): string|false
|
|||||||
* @param string $str
|
* @param string $str
|
||||||
* @return string The filename
|
* @return string The filename
|
||||||
*/
|
*/
|
||||||
public static function PadToBase32Format(?string $str): string
|
public static function PadToBase32Format(?string $str) : string
|
||||||
{
|
{
|
||||||
return blank($str) ? '' : strtoupper(str_pad($str, (int) ceil(strlen($str) / 8) * 8, '='));
|
return blank($str) ? '' : strtoupper(str_pad($str, (int) ceil(strlen($str) / 8) * 8, '='));
|
||||||
}
|
}
|
||||||
|
@ -7,11 +7,11 @@
|
|||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use Illuminate\Contracts\Support\Responsable;
|
use Illuminate\Contracts\Support\Responsable;
|
||||||
use Illuminate\Http\JsonResponse;
|
use Illuminate\Http\JsonResponse;
|
||||||
|
use Illuminate\Support\Arr;
|
||||||
use Illuminate\Support\Facades\Log;
|
use Illuminate\Support\Facades\Log;
|
||||||
use Laragear\WebAuthn\Http\Requests\AssertedRequest;
|
use Laragear\WebAuthn\Http\Requests\AssertedRequest;
|
||||||
use Laragear\WebAuthn\Http\Requests\AssertionRequest;
|
use Laragear\WebAuthn\Http\Requests\AssertionRequest;
|
||||||
use Laragear\WebAuthn\WebAuthn;
|
use Laragear\WebAuthn\WebAuthn;
|
||||||
use Illuminate\Support\Arr;
|
|
||||||
|
|
||||||
class WebAuthnLoginController extends Controller
|
class WebAuthnLoginController extends Controller
|
||||||
{
|
{
|
||||||
@ -32,7 +32,7 @@ class WebAuthnLoginController extends Controller
|
|||||||
* @param \Laragear\WebAuthn\Http\Requests\AssertionRequest $request
|
* @param \Laragear\WebAuthn\Http\Requests\AssertionRequest $request
|
||||||
* @return \Illuminate\Contracts\Support\Responsable|\Illuminate\Http\JsonResponse
|
* @return \Illuminate\Contracts\Support\Responsable|\Illuminate\Http\JsonResponse
|
||||||
*/
|
*/
|
||||||
public function options(AssertionRequest $request): Responsable|JsonResponse
|
public function options(AssertionRequest $request) : Responsable|JsonResponse
|
||||||
{
|
{
|
||||||
switch (config('webauthn.user_verification')) {
|
switch (config('webauthn.user_verification')) {
|
||||||
case WebAuthn::USER_VERIFICATION_DISCOURAGED:
|
case WebAuthn::USER_VERIFICATION_DISCOURAGED:
|
||||||
@ -70,7 +70,7 @@ public function login(AssertedRequest $request)
|
|||||||
|
|
||||||
// Some authenticators do not send a userHandle so we hack the response to be compliant
|
// Some authenticators do not send a userHandle so we hack the response to be compliant
|
||||||
// with Larapass/webauthn-lib implementation that waits for a userHandle
|
// with Larapass/webauthn-lib implementation that waits for a userHandle
|
||||||
if (!Arr::exists($response, 'userHandle') || blank($response['userHandle'])) {
|
if (! Arr::exists($response, 'userHandle') || blank($response['userHandle'])) {
|
||||||
$response['userHandle'] = User::getFromCredentialId($request->id)?->userHandle();
|
$response['userHandle'] = User::getFromCredentialId($request->id)?->userHandle();
|
||||||
$request->merge(['response' => $response]);
|
$request->merge(['response' => $response]);
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ class WebAuthnRegisterController extends Controller
|
|||||||
* @param \Laragear\WebAuthn\Http\Requests\AttestationRequest $request
|
* @param \Laragear\WebAuthn\Http\Requests\AttestationRequest $request
|
||||||
* @return \Illuminate\Contracts\Support\Responsable
|
* @return \Illuminate\Contracts\Support\Responsable
|
||||||
*/
|
*/
|
||||||
public function options(AttestationRequest $request): Responsable
|
public function options(AttestationRequest $request) : Responsable
|
||||||
{
|
{
|
||||||
switch (config('webauthn.user_verification')) {
|
switch (config('webauthn.user_verification')) {
|
||||||
case WebAuthn::USER_VERIFICATION_DISCOURAGED:
|
case WebAuthn::USER_VERIFICATION_DISCOURAGED:
|
||||||
@ -40,7 +40,7 @@ public function options(AttestationRequest $request): Responsable
|
|||||||
* @param \Laragear\WebAuthn\Http\Requests\AttestedRequest $request
|
* @param \Laragear\WebAuthn\Http\Requests\AttestedRequest $request
|
||||||
* @return \Illuminate\Http\Response
|
* @return \Illuminate\Http\Response
|
||||||
*/
|
*/
|
||||||
public function register(AttestedRequest $request): Response
|
public function register(AttestedRequest $request) : Response
|
||||||
{
|
{
|
||||||
$request->save();
|
$request->save();
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
use Illuminate\Support\Facades\Log;
|
use Illuminate\Support\Facades\Log;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Illuminate\Support\Facades\Validator;
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use Illuminate\Support\Str;
|
||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
use OTPHP\Factory;
|
use OTPHP\Factory;
|
||||||
use OTPHP\HOTP;
|
use OTPHP\HOTP;
|
||||||
@ -30,7 +31,6 @@
|
|||||||
use Spatie\EloquentSortable\Sortable;
|
use Spatie\EloquentSortable\Sortable;
|
||||||
use Spatie\EloquentSortable\SortableTrait;
|
use Spatie\EloquentSortable\SortableTrait;
|
||||||
use SteamTotp\SteamTotp;
|
use SteamTotp\SteamTotp;
|
||||||
use Illuminate\Support\Str;
|
|
||||||
|
|
||||||
class TwoFAccount extends Model implements Sortable
|
class TwoFAccount extends Model implements Sortable
|
||||||
{
|
{
|
||||||
@ -144,13 +144,13 @@ protected static function boot()
|
|||||||
parent::boot();
|
parent::boot();
|
||||||
|
|
||||||
static::saving(function (TwoFAccount $twofaccount) {
|
static::saving(function (TwoFAccount $twofaccount) {
|
||||||
if (!$twofaccount->legacy_uri) {
|
if (! $twofaccount->legacy_uri) {
|
||||||
$twofaccount->legacy_uri = $twofaccount->getURI();
|
$twofaccount->legacy_uri = $twofaccount->getURI();
|
||||||
}
|
}
|
||||||
if ($twofaccount->otp_type == TwoFAccount::TOTP && !$twofaccount->period) {
|
if ($twofaccount->otp_type == TwoFAccount::TOTP && ! $twofaccount->period) {
|
||||||
$twofaccount->period = TwoFAccount::DEFAULT_PERIOD;
|
$twofaccount->period = TwoFAccount::DEFAULT_PERIOD;
|
||||||
}
|
}
|
||||||
if ($twofaccount->otp_type == TwoFAccount::HOTP && !$twofaccount->counter) {
|
if ($twofaccount->otp_type == TwoFAccount::HOTP && ! $twofaccount->counter) {
|
||||||
$twofaccount->counter = TwoFAccount::DEFAULT_COUNTER;
|
$twofaccount->counter = TwoFAccount::DEFAULT_COUNTER;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -255,7 +255,7 @@ public function setSecretAttribute($value)
|
|||||||
*/
|
*/
|
||||||
public function setDigitsAttribute($value)
|
public function setDigitsAttribute($value)
|
||||||
{
|
{
|
||||||
$this->attributes['digits'] = !$value ? 6 : $value;
|
$this->attributes['digits'] = ! $value ? 6 : $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -266,7 +266,7 @@ public function setDigitsAttribute($value)
|
|||||||
*/
|
*/
|
||||||
public function setAlgorithmAttribute($value)
|
public function setAlgorithmAttribute($value)
|
||||||
{
|
{
|
||||||
$this->attributes['algorithm'] = !$value ? self::SHA1 : strtolower($value);
|
$this->attributes['algorithm'] = ! $value ? self::SHA1 : strtolower($value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -277,7 +277,7 @@ public function setAlgorithmAttribute($value)
|
|||||||
*/
|
*/
|
||||||
public function setPeriodAttribute($value)
|
public function setPeriodAttribute($value)
|
||||||
{
|
{
|
||||||
$this->attributes['period'] = !$value && $this->otp_type === self::TOTP ? self::DEFAULT_PERIOD : $value;
|
$this->attributes['period'] = ! $value && $this->otp_type === self::TOTP ? self::DEFAULT_PERIOD : $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -376,7 +376,7 @@ public function fillWithOtpParameters(array $parameters, bool $skipIconFetching
|
|||||||
$this->enforceAsSteam();
|
$this->enforceAsSteam();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$this->icon && Settings::get('getOfficialIcons') && !$skipIconFetching) {
|
if (! $this->icon && Settings::get('getOfficialIcons') && ! $skipIconFetching) {
|
||||||
$this->icon = $this->getDefaultIcon();
|
$this->icon = $this->getDefaultIcon();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,7 +403,7 @@ public function fillWithURI(string $uri, bool $isSteamTotp = false, bool $skipIc
|
|||||||
|
|
||||||
// As loadFromProvisioningUri() accept URI without label (nor account nor service) we check
|
// As loadFromProvisioningUri() accept URI without label (nor account nor service) we check
|
||||||
// that the account is set
|
// that the account is set
|
||||||
if (!$this->generator->getLabel()) {
|
if (! $this->generator->getLabel()) {
|
||||||
Log::error('URI passed to fillWithURI() must contain a label');
|
Log::error('URI passed to fillWithURI() must contain a label');
|
||||||
|
|
||||||
throw ValidationException::withMessages([
|
throw ValidationException::withMessages([
|
||||||
@ -428,7 +428,7 @@ public function fillWithURI(string $uri, bool $isSteamTotp = false, bool $skipIc
|
|||||||
self::setIcon($this->generator->getParameter('image'));
|
self::setIcon($this->generator->getParameter('image'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$this->icon && Settings::get('getOfficialIcons') && !$skipIconFetching) {
|
if (! $this->icon && Settings::get('getOfficialIcons') && ! $skipIconFetching) {
|
||||||
$this->icon = $this->getDefaultIcon();
|
$this->icon = $this->getDefaultIcon();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -440,7 +440,7 @@ public function fillWithURI(string $uri, bool $isSteamTotp = false, bool $skipIc
|
|||||||
/**
|
/**
|
||||||
* Compare 2 TwoFAccounts
|
* Compare 2 TwoFAccounts
|
||||||
*/
|
*/
|
||||||
public function equals(self $other): bool
|
public function equals(self $other) : bool
|
||||||
{
|
{
|
||||||
return $this->service === $other->service &&
|
return $this->service === $other->service &&
|
||||||
$this->account === $other->account &&
|
$this->account === $other->account &&
|
||||||
@ -456,7 +456,7 @@ public function equals(self $other): bool
|
|||||||
/**
|
/**
|
||||||
* Sets model attributes to STEAM values
|
* Sets model attributes to STEAM values
|
||||||
*/
|
*/
|
||||||
private function enforceAsSteam(): void
|
private function enforceAsSteam() : void
|
||||||
{
|
{
|
||||||
$this->otp_type = self::STEAM_TOTP;
|
$this->otp_type = self::STEAM_TOTP;
|
||||||
$this->digits = 5;
|
$this->digits = 5;
|
||||||
@ -479,7 +479,7 @@ private function getGeneratorOtpType()
|
|||||||
/**
|
/**
|
||||||
* Returns an otpauth URI built with model attribute values
|
* Returns an otpauth URI built with model attribute values
|
||||||
*/
|
*/
|
||||||
public function getURI(): string
|
public function getURI() : string
|
||||||
{
|
{
|
||||||
$this->initGenerator();
|
$this->initGenerator();
|
||||||
|
|
||||||
@ -492,7 +492,7 @@ public function getURI(): string
|
|||||||
* @throws UnsupportedOtpTypeException The defined OTP type is not supported
|
* @throws UnsupportedOtpTypeException The defined OTP type is not supported
|
||||||
* @throws InvalidOtpParameterException One OTP parameter is invalid
|
* @throws InvalidOtpParameterException One OTP parameter is invalid
|
||||||
*/
|
*/
|
||||||
private function initGenerator(): void
|
private function initGenerator() : void
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
switch ($this->otp_type) {
|
switch ($this->otp_type) {
|
||||||
@ -542,7 +542,7 @@ private function initGenerator(): void
|
|||||||
* @param \Psr\Http\Message\StreamInterface|\Illuminate\Http\File|\Illuminate\Http\UploadedFile|string|resource $data
|
* @param \Psr\Http\Message\StreamInterface|\Illuminate\Http\File|\Illuminate\Http\UploadedFile|string|resource $data
|
||||||
* @param string|null $extension The resource extension, without the dot
|
* @param string|null $extension The resource extension, without the dot
|
||||||
*/
|
*/
|
||||||
public function setIcon($data, $extension = null): void
|
public function setIcon($data, $extension = null) : void
|
||||||
{
|
{
|
||||||
$isRemoteData = Str::startsWith($data, ['http://', 'https://']) && Validator::make(
|
$isRemoteData = Str::startsWith($data, ['http://', 'https://']) && Validator::make(
|
||||||
[$data],
|
[$data],
|
||||||
@ -565,7 +565,7 @@ public function setIcon($data, $extension = null): void
|
|||||||
* @param string $extension The file extension, without the dot
|
* @param string $extension The file extension, without the dot
|
||||||
* @return string|null The filename of the stored icon or null if the operation fails
|
* @return string|null The filename of the stored icon or null if the operation fails
|
||||||
*/
|
*/
|
||||||
private function storeFileDataAsIcon($content, $extension): string|null
|
private function storeFileDataAsIcon($content, $extension) : string|null
|
||||||
{
|
{
|
||||||
$filename = self::getUniqueFilename($extension);
|
$filename = self::getUniqueFilename($extension);
|
||||||
|
|
||||||
@ -582,14 +582,13 @@ private function storeFileDataAsIcon($content, $extension): string|null
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate a unique filename
|
* Generate a unique filename
|
||||||
*
|
*
|
||||||
* @param string $extension
|
* @param string $extension
|
||||||
* @return string The filename
|
* @return string The filename
|
||||||
*/
|
*/
|
||||||
private function getUniqueFilename(string $extension): string
|
private function getUniqueFilename(string $extension) : string
|
||||||
{
|
{
|
||||||
return Str::random(40) . '.' . $extension;
|
return Str::random(40) . '.' . $extension;
|
||||||
}
|
}
|
||||||
@ -601,7 +600,7 @@ private function getUniqueFilename(string $extension): string
|
|||||||
* @param string $disk
|
* @param string $disk
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
private function isValidIcon($filename, $disk): bool
|
private function isValidIcon($filename, $disk) : bool
|
||||||
{
|
{
|
||||||
return in_array(Storage::disk($disk)->mimeType($filename), [
|
return in_array(Storage::disk($disk)->mimeType($filename), [
|
||||||
'image/png',
|
'image/png',
|
||||||
@ -609,7 +608,7 @@ private function isValidIcon($filename, $disk): bool
|
|||||||
'image/webp',
|
'image/webp',
|
||||||
'image/bmp',
|
'image/bmp',
|
||||||
'image/x-ms-bmp',
|
'image/x-ms-bmp',
|
||||||
'image/svg+xml'
|
'image/svg+xml',
|
||||||
]) && (Storage::disk($disk)->mimeType($filename) !== 'image/svg+xml' ? getimagesize(Storage::disk($disk)->path($filename)) : true);
|
]) && (Storage::disk($disk)->mimeType($filename) !== 'image/svg+xml' ? getimagesize(Storage::disk($disk)->path($filename)) : true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -618,7 +617,7 @@ private function isValidIcon($filename, $disk): bool
|
|||||||
*
|
*
|
||||||
* @return string|null The filename of the stored icon or null if the operation fails
|
* @return string|null The filename of the stored icon or null if the operation fails
|
||||||
*/
|
*/
|
||||||
private function storeRemoteImageAsIcon(string $url): string|null
|
private function storeRemoteImageAsIcon(string $url) : string|null
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$path_parts = pathinfo($url);
|
$path_parts = pathinfo($url);
|
||||||
@ -672,7 +671,7 @@ private function getDefaultIcon()
|
|||||||
/**
|
/**
|
||||||
* Returns an acceptable value
|
* Returns an acceptable value
|
||||||
*/
|
*/
|
||||||
private function decryptOrReturn(mixed $value): mixed
|
private function decryptOrReturn(mixed $value) : mixed
|
||||||
{
|
{
|
||||||
// Decipher when needed
|
// Decipher when needed
|
||||||
if (Settings::get('useEncryption') && $value) {
|
if (Settings::get('useEncryption') && $value) {
|
||||||
@ -689,7 +688,7 @@ private function decryptOrReturn(mixed $value): mixed
|
|||||||
/**
|
/**
|
||||||
* Encrypt a value
|
* Encrypt a value
|
||||||
*/
|
*/
|
||||||
private function encryptOrReturn(mixed $value): mixed
|
private function encryptOrReturn(mixed $value) : mixed
|
||||||
{
|
{
|
||||||
// should be replaced by laravel 8 attribute encryption casting
|
// should be replaced by laravel 8 attribute encryption casting
|
||||||
return Settings::get('useEncryption') ? Crypt::encryptString($value) : $value;
|
return Settings::get('useEncryption') ? Crypt::encryptString($value) : $value;
|
||||||
|
@ -50,6 +50,7 @@ public function boot()
|
|||||||
* Get the services provided by the provider.
|
* Get the services provided by the provider.
|
||||||
*
|
*
|
||||||
* @codeCoverageIgnore
|
* @codeCoverageIgnore
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
public function provides()
|
public function provides()
|
||||||
|
@ -60,7 +60,7 @@ protected function getLogo($serviceName)
|
|||||||
$domain = $this->tfas->get($this->cleanDomain(strval($serviceName)));
|
$domain = $this->tfas->get($this->cleanDomain(strval($serviceName)));
|
||||||
$logoFilename = $domain . '.svg';
|
$logoFilename = $domain . '.svg';
|
||||||
|
|
||||||
if ($domain && !Storage::disk('logos')->exists($logoFilename)) {
|
if ($domain && ! Storage::disk('logos')->exists($logoFilename)) {
|
||||||
$this->fetchLogo($logoFilename);
|
$this->fetchLogo($logoFilename);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,7 +72,7 @@ protected function getLogo($serviceName)
|
|||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
protected function setTfaCollection(): void
|
protected function setTfaCollection() : void
|
||||||
{
|
{
|
||||||
// We fetch a fresh tfaDirectory if necessary to prevent too many API calls
|
// We fetch a fresh tfaDirectory if necessary to prevent too many API calls
|
||||||
if (Storage::disk('logos')->exists(self::TFA_JSON)) {
|
if (Storage::disk('logos')->exists(self::TFA_JSON)) {
|
||||||
@ -93,7 +93,7 @@ protected function setTfaCollection(): void
|
|||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
protected function cacheTfaDirectorySource(): void
|
protected function cacheTfaDirectorySource() : void
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$response = Http::retry(3, 100)->get(self::TFA_URL);
|
$response = Http::retry(3, 100)->get(self::TFA_URL);
|
||||||
@ -119,7 +119,7 @@ protected function cacheTfaDirectorySource(): void
|
|||||||
* @param string $logoFile Logo filename to fetch
|
* @param string $logoFile Logo filename to fetch
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
protected function fetchLogo(string $logoFile): void
|
protected function fetchLogo(string $logoFile) : void
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$response = Http::retry(3, 100)
|
$response = Http::retry(3, 100)
|
||||||
@ -141,7 +141,7 @@ protected function fetchLogo(string $logoFile): void
|
|||||||
* @param string $domain
|
* @param string $domain
|
||||||
* @return string Optimized domain name
|
* @return string Optimized domain name
|
||||||
*/
|
*/
|
||||||
protected function cleanDomain(string $domain): string
|
protected function cleanDomain(string $domain) : string
|
||||||
{
|
{
|
||||||
return strtolower(str_replace(['+'], ['plus'], $domain));
|
return strtolower(str_replace(['+'], ['plus'], $domain));
|
||||||
}
|
}
|
||||||
@ -153,7 +153,7 @@ protected function cleanDomain(string $domain): string
|
|||||||
* @param string $iconFilename
|
* @param string $iconFilename
|
||||||
* @return bool Weither the copy succed or not
|
* @return bool Weither the copy succed or not
|
||||||
*/
|
*/
|
||||||
protected function copyToIcons($logoFilename, $iconFilename): bool
|
protected function copyToIcons($logoFilename, $iconFilename) : bool
|
||||||
{
|
{
|
||||||
return Storage::disk('icons')->put($iconFilename, Storage::disk('logos')->get($logoFilename));
|
return Storage::disk('icons')->put($iconFilename, Storage::disk('logos')->get($logoFilename));
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,10 @@
|
|||||||
|
|
||||||
use App\Exceptions\InvalidMigrationDataException;
|
use App\Exceptions\InvalidMigrationDataException;
|
||||||
use App\Facades\TwoFAccounts;
|
use App\Facades\TwoFAccounts;
|
||||||
use App\Helpers\Helpers;
|
|
||||||
use App\Models\TwoFAccount;
|
use App\Models\TwoFAccount;
|
||||||
use Illuminate\Support\Arr;
|
use Illuminate\Support\Arr;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Illuminate\Support\Facades\Log;
|
use Illuminate\Support\Facades\Log;
|
||||||
use Illuminate\Support\Facades\Storage;
|
|
||||||
|
|
||||||
class AegisMigrator extends Migrator
|
class AegisMigrator extends Migrator
|
||||||
{
|
{
|
||||||
@ -38,7 +36,7 @@ class AegisMigrator extends Migrator
|
|||||||
* @param mixed $migrationPayload
|
* @param mixed $migrationPayload
|
||||||
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
||||||
*/
|
*/
|
||||||
public function migrate(mixed $migrationPayload): Collection
|
public function migrate(mixed $migrationPayload) : Collection
|
||||||
{
|
{
|
||||||
$json = json_decode(htmlspecialchars_decode($migrationPayload), true);
|
$json = json_decode(htmlspecialchars_decode($migrationPayload), true);
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ class GoogleAuthMigrator extends Migrator
|
|||||||
* @param mixed $migrationPayload migration uri provided by Google Authenticator export feature
|
* @param mixed $migrationPayload migration uri provided by Google Authenticator export feature
|
||||||
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
||||||
*/
|
*/
|
||||||
public function migrate(mixed $migrationPayload): Collection
|
public function migrate(mixed $migrationPayload) : Collection
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$migrationData = base64_decode(urldecode(Str::replace('otpauth-migration://offline?data=', '', $migrationPayload)));
|
$migrationData = base64_decode(urldecode(Str::replace('otpauth-migration://offline?data=', '', $migrationPayload)));
|
||||||
|
@ -17,7 +17,7 @@ class PlainTextMigrator extends Migrator
|
|||||||
* @param mixed $migrationPayload
|
* @param mixed $migrationPayload
|
||||||
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
* @return \Illuminate\Support\Collection<int|string, \App\Models\TwoFAccount> The converted accounts
|
||||||
*/
|
*/
|
||||||
public function migrate(mixed $migrationPayload): Collection
|
public function migrate(mixed $migrationPayload) : Collection
|
||||||
{
|
{
|
||||||
$otpauthURIs = preg_split('~\R~', $migrationPayload);
|
$otpauthURIs = preg_split('~\R~', $migrationPayload);
|
||||||
$otpauthURIs = Arr::where($otpauthURIs, function ($value, $key) {
|
$otpauthURIs = Arr::where($otpauthURIs, function ($value, $key) {
|
||||||
|
@ -92,7 +92,7 @@ public function migrate(mixed $migrationPayload) : Collection
|
|||||||
$parameters['counter'] = strtolower($parameters['otp_type']) === 'hotp' && $otp_parameters['otp']['counter'] > 0
|
$parameters['counter'] = strtolower($parameters['otp_type']) === 'hotp' && $otp_parameters['otp']['counter'] > 0
|
||||||
? $otp_parameters['otp']['counter']
|
? $otp_parameters['otp']['counter']
|
||||||
: null;
|
: null;
|
||||||
$parameters['period'] = strtolower($parameters['otp_type']) === 'totp' && $otp_parameters['otp']['period'] > 0
|
$parameters['period'] = strtolower($parameters['otp_type']) === 'totp' && $otp_parameters['otp']['period'] > 0
|
||||||
? $otp_parameters['otp']['period']
|
? $otp_parameters['otp']['period']
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ class ReleaseRadarService
|
|||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function scheduledScan(): void
|
public function scheduledScan() : void
|
||||||
{
|
{
|
||||||
if ((Settings::get('lastRadarScan') + (60 * 60 * 24 * 7)) < time()) {
|
if ((Settings::get('lastRadarScan') + (60 * 60 * 24 * 7)) < time()) {
|
||||||
$this->newRelease();
|
$this->newRelease();
|
||||||
@ -26,7 +26,7 @@ public function scheduledScan(): void
|
|||||||
*
|
*
|
||||||
* @return false|string False if no new release, the new release number otherwise
|
* @return false|string False if no new release, the new release number otherwise
|
||||||
*/
|
*/
|
||||||
public function manualScan(): false|string
|
public function manualScan() : false|string
|
||||||
{
|
{
|
||||||
return $this->newRelease();
|
return $this->newRelease();
|
||||||
}
|
}
|
||||||
@ -36,10 +36,9 @@ public function manualScan(): false|string
|
|||||||
*
|
*
|
||||||
* @return false|string False if no new release, the new release number otherwise
|
* @return false|string False if no new release, the new release number otherwise
|
||||||
*/
|
*/
|
||||||
protected function newRelease(): false|string
|
protected function newRelease() : false|string
|
||||||
{
|
{
|
||||||
if ($latestReleaseData = json_decode($this->getLatestReleaseData())) {
|
if ($latestReleaseData = json_decode($this->getLatestReleaseData())) {
|
||||||
|
|
||||||
$githubVersion = Helpers::cleanVersionNumber($latestReleaseData->tag_name);
|
$githubVersion = Helpers::cleanVersionNumber($latestReleaseData->tag_name);
|
||||||
$installedVersion = Helpers::cleanVersionNumber(config('2fauth.version'));
|
$installedVersion = Helpers::cleanVersionNumber(config('2fauth.version'));
|
||||||
|
|
||||||
@ -62,7 +61,7 @@ protected function newRelease(): false|string
|
|||||||
*
|
*
|
||||||
* @return string|null
|
* @return string|null
|
||||||
*/
|
*/
|
||||||
protected function getLatestReleaseData(): string|null
|
protected function getLatestReleaseData() : string|null
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$response = Http::retry(3, 100)
|
$response = Http::retry(3, 100)
|
||||||
|
@ -19,7 +19,7 @@ class UserControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ class GroupControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -9,9 +9,9 @@
|
|||||||
use Illuminate\Support\Facades\DB;
|
use Illuminate\Support\Facades\DB;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Tests\Classes\LocalFile;
|
use Tests\Classes\LocalFile;
|
||||||
|
use Tests\Data\MigrationTestData;
|
||||||
use Tests\Data\OtpTestData;
|
use Tests\Data\OtpTestData;
|
||||||
use Tests\FeatureTestCase;
|
use Tests\FeatureTestCase;
|
||||||
use Tests\Data\MigrationTestData;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Api\v1\Controllers\TwoFAccountController
|
* @covers \App\Api\v1\Controllers\TwoFAccountController
|
||||||
@ -125,7 +125,7 @@ class TwoFAccountControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new GroupAssignRequest();
|
$request = new GroupAssignRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -57,7 +57,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new GroupAssignRequest();
|
$request = new GroupAssignRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -68,7 +68,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -35,7 +35,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new GroupStoreRequest();
|
$request = new GroupStoreRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -46,7 +46,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -58,7 +58,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$group = new Group([
|
$group = new Group([
|
||||||
'name' => $this->uniqueGroupName,
|
'name' => $this->uniqueGroupName,
|
||||||
@ -75,7 +75,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -33,7 +33,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new QrCodeDecodeRequest();
|
$request = new QrCodeDecodeRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -44,7 +44,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
$file = LocalFile::fake()->validQrcode();
|
$file = LocalFile::fake()->validQrcode();
|
||||||
|
|
||||||
@ -58,7 +58,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new QrCodeDecodeRequest();
|
$request = new QrCodeDecodeRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -69,7 +69,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -35,7 +35,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new SettingStoreRequest();
|
$request = new SettingStoreRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -46,7 +46,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -67,7 +67,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
Settings::set($this->uniqueKey, 'uniqueValue');
|
Settings::set($this->uniqueKey, 'uniqueValue');
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new SettingUpdateRequest();
|
$request = new SettingUpdateRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -61,7 +61,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new SettingUpdateRequest();
|
$request = new SettingUpdateRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -72,7 +72,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountBatchRequest();
|
$request = new TwoFAccountBatchRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -58,7 +58,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountBatchRequest();
|
$request = new TwoFAccountBatchRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -69,7 +69,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountImportRequest();
|
$request = new TwoFAccountImportRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -55,7 +55,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountImportRequest();
|
$request = new TwoFAccountImportRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -66,7 +66,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountReorderRequest();
|
$request = new TwoFAccountReorderRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -58,7 +58,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountReorderRequest();
|
$request = new TwoFAccountReorderRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -69,7 +69,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -33,7 +33,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountStoreRequest();
|
$request = new TwoFAccountStoreRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -44,7 +44,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -108,7 +108,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountStoreRequest();
|
$request = new TwoFAccountStoreRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -119,7 +119,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -33,7 +33,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountUpdateRequest();
|
$request = new TwoFAccountUpdateRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -44,7 +44,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -84,7 +84,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountUpdateRequest();
|
$request = new TwoFAccountUpdateRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -95,7 +95,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -32,7 +32,7 @@ public function test_user_is_authorized()
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideValidData
|
* @dataProvider provideValidData
|
||||||
*/
|
*/
|
||||||
public function test_valid_data(array $data): void
|
public function test_valid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountUriRequest();
|
$request = new TwoFAccountUriRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -43,7 +43,7 @@ public function test_valid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideValidData(): array
|
public function provideValidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
@ -62,7 +62,7 @@ public function provideValidData(): array
|
|||||||
/**
|
/**
|
||||||
* @dataProvider provideInvalidData
|
* @dataProvider provideInvalidData
|
||||||
*/
|
*/
|
||||||
public function test_invalid_data(array $data): void
|
public function test_invalid_data(array $data) : void
|
||||||
{
|
{
|
||||||
$request = new TwoFAccountUriRequest();
|
$request = new TwoFAccountUriRequest();
|
||||||
$validator = Validator::make($data, $request->rules());
|
$validator = Validator::make($data, $request->rules());
|
||||||
@ -73,7 +73,7 @@ public function test_invalid_data(array $data): void
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideInvalidData(): array
|
public function provideInvalidData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
|
|
||||||
use App\Facades\Settings;
|
use App\Facades\Settings;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Tests\FeatureTestCase;
|
|
||||||
use Illuminate\Support\Carbon;
|
use Illuminate\Support\Carbon;
|
||||||
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Http\Controllers\Auth\LoginController
|
* @covers \App\Http\Controllers\Auth\LoginController
|
||||||
@ -28,7 +28,7 @@ class LoginTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ class PasswordControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ class RegisterControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,7 @@ class UserControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -3,10 +3,10 @@
|
|||||||
namespace Tests\Feature\Http\Auth;
|
namespace Tests\Feature\Http\Auth;
|
||||||
|
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Illuminate\Support\Facades\Notification;
|
|
||||||
use Tests\FeatureTestCase;
|
|
||||||
use App\Notifications\WebauthnRecoveryNotification;
|
use App\Notifications\WebauthnRecoveryNotification;
|
||||||
use Illuminate\Support\Facades\Lang;
|
use Illuminate\Support\Facades\Lang;
|
||||||
|
use Illuminate\Support\Facades\Notification;
|
||||||
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Http\Controllers\Auth\WebAuthnDeviceLostController
|
* @covers \App\Http\Controllers\Auth\WebAuthnDeviceLostController
|
||||||
@ -25,7 +25,7 @@ class WebAuthnDeviceLostControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -52,7 +52,7 @@ public function test_sendRecoveryEmail_sends_notification_on_success()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$this->assertDatabaseHas('webauthn_recoveries', [
|
$this->assertDatabaseHas('webauthn_recoveries', [
|
||||||
'email' => $this->user->email
|
'email' => $this->user->email,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,7 +113,7 @@ public function test_sendRecoveryEmail_does_not_send_anything_to_unknown_email()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$this->assertDatabaseMissing('webauthn_recoveries', [
|
$this->assertDatabaseMissing('webauthn_recoveries', [
|
||||||
'email' => 'bad@email.com'
|
'email' => 'bad@email.com',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ public function test_sendRecoveryEmail_does_not_send_anything_to_invalid_email()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$this->assertDatabaseMissing('webauthn_recoveries', [
|
$this->assertDatabaseMissing('webauthn_recoveries', [
|
||||||
'email' => 'bad@email.com'
|
'email' => 'bad@email.com',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -182,7 +182,7 @@ public function test_sendRecoveryEmail_is_throttled()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$this->assertDatabaseHas('webauthn_recoveries', [
|
$this->assertDatabaseHas('webauthn_recoveries', [
|
||||||
'email' => $this->user->email
|
'email' => $this->user->email,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$this->json('POST', '/webauthn/lost', [
|
$this->json('POST', '/webauthn/lost', [
|
||||||
@ -191,7 +191,7 @@ public function test_sendRecoveryEmail_is_throttled()
|
|||||||
->assertStatus(422)
|
->assertStatus(422)
|
||||||
->assertJsonValidationErrorfor('email')
|
->assertJsonValidationErrorfor('email')
|
||||||
->assertJsonFragment([
|
->assertJsonFragment([
|
||||||
'message' => __('passwords.throttled')
|
'message' => __('passwords.throttled'),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,7 +203,7 @@ public function test_error_if_no_broker_is_set()
|
|||||||
$this->app['config']->set('auth.passwords.webauthn', null);
|
$this->app['config']->set('auth.passwords.webauthn', null);
|
||||||
|
|
||||||
$this->json('POST', '/webauthn/lost', [
|
$this->json('POST', '/webauthn/lost', [
|
||||||
'email' => $this->user->email
|
'email' => $this->user->email,
|
||||||
])
|
])
|
||||||
->assertStatus(500);
|
->assertStatus(500);
|
||||||
}
|
}
|
||||||
|
@ -3,12 +3,12 @@
|
|||||||
namespace Tests\Feature\Http\Auth;
|
namespace Tests\Feature\Http\Auth;
|
||||||
|
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Illuminate\Support\Facades\DB;
|
|
||||||
use Laragear\WebAuthn\Http\Requests\AssertedRequest;
|
|
||||||
use Tests\FeatureTestCase;
|
|
||||||
use Laragear\WebAuthn\WebAuthn;
|
|
||||||
use Illuminate\Support\Facades\Config;
|
use Illuminate\Support\Facades\Config;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
use Laragear\WebAuthn\Assertion\Validator\AssertionValidator;
|
use Laragear\WebAuthn\Assertion\Validator\AssertionValidator;
|
||||||
|
use Laragear\WebAuthn\Http\Requests\AssertedRequest;
|
||||||
|
use Laragear\WebAuthn\WebAuthn;
|
||||||
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Http\Controllers\Auth\WebAuthnLoginController
|
* @covers \App\Http\Controllers\Auth\WebAuthnLoginController
|
||||||
@ -22,36 +22,39 @@ class WebAuthnLoginControllerTest extends FeatureTestCase
|
|||||||
protected $user;
|
protected $user;
|
||||||
|
|
||||||
const CREDENTIAL_ID = 's06aG41wsIYh5X1YUhB-SlH8y3F2RzdJZVse8iXRXOCd3oqQdEyCOsBawzxrYBtJRQA2azAMEN_q19TUp6iMgg';
|
const CREDENTIAL_ID = 's06aG41wsIYh5X1YUhB-SlH8y3F2RzdJZVse8iXRXOCd3oqQdEyCOsBawzxrYBtJRQA2azAMEN_q19TUp6iMgg';
|
||||||
|
|
||||||
const CREDENTIAL_ID_ALT = '-VOLFKPY-_FuMI_sJ7gMllK76L3VoRUINj6lL_Z3qDg';
|
const CREDENTIAL_ID_ALT = '-VOLFKPY-_FuMI_sJ7gMllK76L3VoRUINj6lL_Z3qDg';
|
||||||
|
|
||||||
const CREDENTIAL_ID_ALT_RAW = '+VOLFKPY+/FuMI/sJ7gMllK76L3VoRUINj6lL/Z3qDg=';
|
const CREDENTIAL_ID_ALT_RAW = '+VOLFKPY+/FuMI/sJ7gMllK76L3VoRUINj6lL/Z3qDg=';
|
||||||
|
|
||||||
const PUBLIC_KEY = 'eyJpdiI6ImYyUHlJOEJML0pwTXJ2UDkveTQwZFE9PSIsInZhbHVlIjoiQWFSYi9LVEszazlBRUZsWHp0cGNRNktGeEQ3aTBsbU9zZ1g5MEgrWFJJNmgraElsNU9hV0VsRVlWc3NoUVVHUjRRdlcxTS9pVklnOWtVYWY5TFJQTTFhR1Rxb1ZzTFkxTWE4VUVvK1lyU3pYQ1M3VlBMWWxZcDVaYWFnK25iaXVyWGR6ZFRmMFVoSmdPZ3UvSnptbVZER0FYdEEyYmNYcW43RkV5aTVqSjNwZEFsUjhUYSs0YjU2Z2V2bUJXa0E0aVB1VC8xSjdJZ2llRGlHY2RwOGk3MmNPTyt6eDFDWUs1dVBOSWp1ZUFSeUlkclgwRW16RE9sUUpDSWV6Sk50TSIsIm1hYyI6IjI3ODQ5NzcxZGY1MzMwYTNiZjAwZmEwMDJkZjYzMGU4N2UzZjZlOGM0ZWE3NDkyYWMxMThhNmE5NWZiMTVjNGEiLCJ0YWciOiIifQ==';
|
const PUBLIC_KEY = 'eyJpdiI6ImYyUHlJOEJML0pwTXJ2UDkveTQwZFE9PSIsInZhbHVlIjoiQWFSYi9LVEszazlBRUZsWHp0cGNRNktGeEQ3aTBsbU9zZ1g5MEgrWFJJNmgraElsNU9hV0VsRVlWc3NoUVVHUjRRdlcxTS9pVklnOWtVYWY5TFJQTTFhR1Rxb1ZzTFkxTWE4VUVvK1lyU3pYQ1M3VlBMWWxZcDVaYWFnK25iaXVyWGR6ZFRmMFVoSmdPZ3UvSnptbVZER0FYdEEyYmNYcW43RkV5aTVqSjNwZEFsUjhUYSs0YjU2Z2V2bUJXa0E0aVB1VC8xSjdJZ2llRGlHY2RwOGk3MmNPTyt6eDFDWUs1dVBOSWp1ZUFSeUlkclgwRW16RE9sUUpDSWV6Sk50TSIsIm1hYyI6IjI3ODQ5NzcxZGY1MzMwYTNiZjAwZmEwMDJkZjYzMGU4N2UzZjZlOGM0ZWE3NDkyYWMxMThhNmE5NWZiMTVjNGEiLCJ0YWciOiIifQ==';
|
||||||
|
|
||||||
const USER_ID = '3b758ac868b74307a7e96e69ae187339';
|
const USER_ID = '3b758ac868b74307a7e96e69ae187339';
|
||||||
|
|
||||||
const USER_ID_ALT = 'e8af6f703f8042aa91c30cf72289aa07';
|
const USER_ID_ALT = 'e8af6f703f8042aa91c30cf72289aa07';
|
||||||
|
|
||||||
const ASSERTION_RESPONSE = [
|
const ASSERTION_RESPONSE = [
|
||||||
'id' => self::CREDENTIAL_ID_ALT,
|
'id' => self::CREDENTIAL_ID_ALT,
|
||||||
'rawId' => self::CREDENTIAL_ID_ALT_RAW,
|
'rawId' => self::CREDENTIAL_ID_ALT_RAW,
|
||||||
'type' => 'public-key',
|
'type' => 'public-key',
|
||||||
'response' => [
|
'response' => [
|
||||||
'clientDataJSON' => 'eyJ0eXBlIjoid2ViYXV0aG4uZ2V0IiwiY2hhbGxlbmdlIjoiaVhvem15bktpLVlEMmlSdktOYlNQQSIsIm9yaWdpbiI6Imh0dHA6Ly9sb2NhbGhvc3QiLCJjcm9zc09yaWdpbiI6ZmFsc2V9',
|
'clientDataJSON' => 'eyJ0eXBlIjoid2ViYXV0aG4uZ2V0IiwiY2hhbGxlbmdlIjoiaVhvem15bktpLVlEMmlSdktOYlNQQSIsIm9yaWdpbiI6Imh0dHA6Ly9sb2NhbGhvc3QiLCJjcm9zc09yaWdpbiI6ZmFsc2V9',
|
||||||
'authenticatorData' => 'SZYN5YgOjGh0NBcPZHZgW4/krrmihjLHmVzzuoMdl2MFAAAAAQ==',
|
'authenticatorData' => 'SZYN5YgOjGh0NBcPZHZgW4/krrmihjLHmVzzuoMdl2MFAAAAAQ==',
|
||||||
'signature' => 'ca4IJ9h8bZnjMbEFuHX1zfX5LcbiPyDVz6sD1/ppR4t8++1DxKa5EdBIrfNlo8FSOv/JSzMrGGUCQvc/Ngj1KnZpO3s9OdTb54/gMDewH/K8EG4wSvxzHdL6sMbP7UUc5Wq1pcdu9MgXY8V+1gftXpzcoaae0X+mLEETgU7eB8jG0mZhVWvE4yQKuDnZA1i9r8oQhqsvG4nUw1BxvR8wAGiRR+R287LaL41k+xum5mS8zEojUmuLSH50miyVxZ4Y+/oyfxG7i+wSYGNSXlW5iNPB+2WupGS7ce4TuOgaFeMmP2a9rzP4m2IBSQoJ2FyrdzR7HwBEewqqrUVbGQw3Aw==',
|
'signature' => 'ca4IJ9h8bZnjMbEFuHX1zfX5LcbiPyDVz6sD1/ppR4t8++1DxKa5EdBIrfNlo8FSOv/JSzMrGGUCQvc/Ngj1KnZpO3s9OdTb54/gMDewH/K8EG4wSvxzHdL6sMbP7UUc5Wq1pcdu9MgXY8V+1gftXpzcoaae0X+mLEETgU7eB8jG0mZhVWvE4yQKuDnZA1i9r8oQhqsvG4nUw1BxvR8wAGiRR+R287LaL41k+xum5mS8zEojUmuLSH50miyVxZ4Y+/oyfxG7i+wSYGNSXlW5iNPB+2WupGS7ce4TuOgaFeMmP2a9rzP4m2IBSQoJ2FyrdzR7HwBEewqqrUVbGQw3Aw==',
|
||||||
'userHandle' => self::USER_ID_ALT,
|
'userHandle' => self::USER_ID_ALT,
|
||||||
]
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
const ASSERTION_RESPONSE_NO_HANDLE = [
|
const ASSERTION_RESPONSE_NO_HANDLE = [
|
||||||
'id' => self::CREDENTIAL_ID_ALT,
|
'id' => self::CREDENTIAL_ID_ALT,
|
||||||
'rawId' => self::CREDENTIAL_ID_ALT_RAW,
|
'rawId' => self::CREDENTIAL_ID_ALT_RAW,
|
||||||
'type' => 'public-key',
|
'type' => 'public-key',
|
||||||
'response' => [
|
'response' => [
|
||||||
'clientDataJSON' => 'eyJ0eXBlIjoid2ViYXV0aG4uZ2V0IiwiY2hhbGxlbmdlIjoiaVhvem15bktpLVlEMmlSdktOYlNQQSIsIm9yaWdpbiI6Imh0dHA6Ly9sb2NhbGhvc3QiLCJjcm9zc09yaWdpbiI6ZmFsc2V9',
|
'clientDataJSON' => 'eyJ0eXBlIjoid2ViYXV0aG4uZ2V0IiwiY2hhbGxlbmdlIjoiaVhvem15bktpLVlEMmlSdktOYlNQQSIsIm9yaWdpbiI6Imh0dHA6Ly9sb2NhbGhvc3QiLCJjcm9zc09yaWdpbiI6ZmFsc2V9',
|
||||||
'authenticatorData' => 'SZYN5YgOjGh0NBcPZHZgW4/krrmihjLHmVzzuoMdl2MFAAAAAQ==',
|
'authenticatorData' => 'SZYN5YgOjGh0NBcPZHZgW4/krrmihjLHmVzzuoMdl2MFAAAAAQ==',
|
||||||
'signature' => 'ca4IJ9h8bZnjMbEFuHX1zfX5LcbiPyDVz6sD1/ppR4t8++1DxKa5EdBIrfNlo8FSOv/JSzMrGGUCQvc/Ngj1KnZpO3s9OdTb54/gMDewH/K8EG4wSvxzHdL6sMbP7UUc5Wq1pcdu9MgXY8V+1gftXpzcoaae0X+mLEETgU7eB8jG0mZhVWvE4yQKuDnZA1i9r8oQhqsvG4nUw1BxvR8wAGiRR+R287LaL41k+xum5mS8zEojUmuLSH50miyVxZ4Y+/oyfxG7i+wSYGNSXlW5iNPB+2WupGS7ce4TuOgaFeMmP2a9rzP4m2IBSQoJ2FyrdzR7HwBEewqqrUVbGQw3Aw==',
|
'signature' => 'ca4IJ9h8bZnjMbEFuHX1zfX5LcbiPyDVz6sD1/ppR4t8++1DxKa5EdBIrfNlo8FSOv/JSzMrGGUCQvc/Ngj1KnZpO3s9OdTb54/gMDewH/K8EG4wSvxzHdL6sMbP7UUc5Wq1pcdu9MgXY8V+1gftXpzcoaae0X+mLEETgU7eB8jG0mZhVWvE4yQKuDnZA1i9r8oQhqsvG4nUw1BxvR8wAGiRR+R287LaL41k+xum5mS8zEojUmuLSH50miyVxZ4Y+/oyfxG7i+wSYGNSXlW5iNPB+2WupGS7ce4TuOgaFeMmP2a9rzP4m2IBSQoJ2FyrdzR7HwBEewqqrUVbGQw3Aw==',
|
||||||
'userHandle' => null,
|
'userHandle' => null,
|
||||||
]
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
const ASSERTION_CHALLENGE = 'iXozmynKi+YD2iRvKNbSPA==';
|
const ASSERTION_CHALLENGE = 'iXozmynKi+YD2iRvKNbSPA==';
|
||||||
@ -59,7 +62,7 @@ class WebAuthnLoginControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ class WebAuthnManageControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ class WebAuthnRecoveryControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -96,8 +96,8 @@ public function test_recover_with_expired_token_returns_validation_error()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$this->json('POST', '/webauthn/recover', [
|
$this->json('POST', '/webauthn/recover', [
|
||||||
'token' => self::ACTUAL_TOKEN_VALUE,
|
'token' => self::ACTUAL_TOKEN_VALUE,
|
||||||
'email' => $this->user->email,
|
'email' => $this->user->email,
|
||||||
'password' => UserFactory::USER_PASSWORD,
|
'password' => UserFactory::USER_PASSWORD,
|
||||||
])
|
])
|
||||||
->assertStatus(422)
|
->assertStatus(422)
|
||||||
|
@ -3,19 +3,18 @@
|
|||||||
namespace Tests\Feature\Http\Auth;
|
namespace Tests\Feature\Http\Auth;
|
||||||
|
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Tests\FeatureTestCase;
|
|
||||||
use Laragear\WebAuthn\Http\Requests\AttestedRequest;
|
|
||||||
use Laragear\WebAuthn\Http\Requests\AttestationRequest;
|
|
||||||
use Illuminate\Support\Facades\Config;
|
use Illuminate\Support\Facades\Config;
|
||||||
use Laragear\WebAuthn\WebAuthn;
|
use Laragear\WebAuthn\Http\Requests\AttestationRequest;
|
||||||
|
use Laragear\WebAuthn\Http\Requests\AttestedRequest;
|
||||||
use Laragear\WebAuthn\JsonTransport;
|
use Laragear\WebAuthn\JsonTransport;
|
||||||
|
use Laragear\WebAuthn\WebAuthn;
|
||||||
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Http\Controllers\Auth\WebAuthnRegisterController
|
* @covers \App\Http\Controllers\Auth\WebAuthnRegisterController
|
||||||
*/
|
*/
|
||||||
class WebAuthnRegisterControllerTest extends FeatureTestCase
|
class WebAuthnRegisterControllerTest extends FeatureTestCase
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var \App\Models\User
|
* @var \App\Models\User
|
||||||
*/
|
*/
|
||||||
@ -24,7 +23,7 @@ class WebAuthnRegisterControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -34,7 +33,7 @@ public function setUp(): void
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function test_uses_attestation_with_fastRegistration_request(): void
|
public function test_uses_attestation_with_fastRegistration_request() : void
|
||||||
{
|
{
|
||||||
Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_DISCOURAGED);
|
Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_DISCOURAGED);
|
||||||
|
|
||||||
@ -51,7 +50,7 @@ public function test_uses_attestation_with_fastRegistration_request(): void
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function test_uses_attestation_with_secureRegistration_request(): void
|
public function test_uses_attestation_with_secureRegistration_request() : void
|
||||||
{
|
{
|
||||||
Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_REQUIRED);
|
Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_REQUIRED);
|
||||||
|
|
||||||
@ -68,7 +67,7 @@ public function test_uses_attestation_with_secureRegistration_request(): void
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function test_register_uses_attested_request(): void
|
public function test_register_uses_attested_request() : void
|
||||||
{
|
{
|
||||||
$this->mock(AttestedRequest::class)->expects('save')->andReturn();
|
$this->mock(AttestedRequest::class)->expects('save')->andReturn();
|
||||||
|
|
||||||
|
@ -3,8 +3,8 @@
|
|||||||
namespace Tests\Feature\Http;
|
namespace Tests\Feature\Http;
|
||||||
|
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
|
||||||
use App\Services\ReleaseRadarService;
|
use App\Services\ReleaseRadarService;
|
||||||
|
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
||||||
use Tests\FeatureTestCase;
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -22,7 +22,7 @@ class SystemControllerTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -3,13 +3,12 @@
|
|||||||
namespace Tests\Feature\Models;
|
namespace Tests\Feature\Models;
|
||||||
|
|
||||||
use App\Models\TwoFAccount;
|
use App\Models\TwoFAccount;
|
||||||
|
use Illuminate\Http\Testing\FileFactory;
|
||||||
|
use Illuminate\Support\Facades\Http;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Tests\Data\HttpRequestTestData;
|
||||||
use Tests\Data\OtpTestData;
|
use Tests\Data\OtpTestData;
|
||||||
use Tests\FeatureTestCase;
|
use Tests\FeatureTestCase;
|
||||||
use Illuminate\Support\Facades\Storage;
|
|
||||||
use Illuminate\Http\Testing\FileFactory;
|
|
||||||
use Illuminate\Http\UploadedFile;
|
|
||||||
use Illuminate\Support\Facades\Http;
|
|
||||||
use Tests\Data\HttpRequestTestData;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Models\TwoFAccount
|
* @covers \App\Models\TwoFAccount
|
||||||
@ -28,14 +27,13 @@ class TwoFAccountModelTest extends FeatureTestCase
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Helpers $helpers;
|
* Helpers $helpers;
|
||||||
|
|
||||||
*/
|
*/
|
||||||
protected $helpers;
|
protected $helpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -461,7 +459,6 @@ public function test_getOTP_for_totp_returns_the_same_password()
|
|||||||
*/
|
*/
|
||||||
public function test_getOTP_for_hotp_returns_the_same_password()
|
public function test_getOTP_for_hotp_returns_the_same_password()
|
||||||
{
|
{
|
||||||
|
|
||||||
Http::preventStrayRequests();
|
Http::preventStrayRequests();
|
||||||
Http::fake([
|
Http::fake([
|
||||||
'https://en.opensuse.org/images/4/44/Button-filled-colour.png' => Http::response(HttpRequestTestData::ICON_PNG, 200),
|
'https://en.opensuse.org/images/4/44/Button-filled-colour.png' => Http::response(HttpRequestTestData::ICON_PNG, 200),
|
||||||
@ -567,7 +564,6 @@ public function test_getURI_for_custom_hotp_model_returns_uri()
|
|||||||
*/
|
*/
|
||||||
public function test_fill_succeed_when_image_fetching_fails()
|
public function test_fill_succeed_when_image_fetching_fails()
|
||||||
{
|
{
|
||||||
|
|
||||||
Http::preventStrayRequests();
|
Http::preventStrayRequests();
|
||||||
|
|
||||||
Storage::fake('imagesLink');
|
Storage::fake('imagesLink');
|
||||||
@ -585,11 +581,11 @@ public function test_fill_succeed_when_image_fetching_fails()
|
|||||||
*/
|
*/
|
||||||
public function test_saving_totp_without_period_set_default_one()
|
public function test_saving_totp_without_period_set_default_one()
|
||||||
{
|
{
|
||||||
$twofaccount = new TwoFAccount;
|
$twofaccount = new TwoFAccount;
|
||||||
$twofaccount->service = OtpTestData::SERVICE;
|
$twofaccount->service = OtpTestData::SERVICE;
|
||||||
$twofaccount->account = OtpTestData::ACCOUNT;
|
$twofaccount->account = OtpTestData::ACCOUNT;
|
||||||
$twofaccount->otp_type = TwoFAccount::TOTP;
|
$twofaccount->otp_type = TwoFAccount::TOTP;
|
||||||
$twofaccount->secret = OtpTestData::SECRET;
|
$twofaccount->secret = OtpTestData::SECRET;
|
||||||
|
|
||||||
$twofaccount->save();
|
$twofaccount->save();
|
||||||
|
|
||||||
@ -603,11 +599,11 @@ public function test_saving_totp_without_period_set_default_one()
|
|||||||
*/
|
*/
|
||||||
public function test_saving_hotp_without_counter_set_default_one()
|
public function test_saving_hotp_without_counter_set_default_one()
|
||||||
{
|
{
|
||||||
$twofaccount = new TwoFAccount;
|
$twofaccount = new TwoFAccount;
|
||||||
$twofaccount->service = OtpTestData::SERVICE;
|
$twofaccount->service = OtpTestData::SERVICE;
|
||||||
$twofaccount->account = OtpTestData::ACCOUNT;
|
$twofaccount->account = OtpTestData::ACCOUNT;
|
||||||
$twofaccount->otp_type = TwoFAccount::HOTP;
|
$twofaccount->otp_type = TwoFAccount::HOTP;
|
||||||
$twofaccount->secret = OtpTestData::SECRET;
|
$twofaccount->secret = OtpTestData::SECRET;
|
||||||
|
|
||||||
$twofaccount->save();
|
$twofaccount->save();
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ class GroupServiceTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -4,11 +4,10 @@
|
|||||||
|
|
||||||
use App\Services\LogoService;
|
use App\Services\LogoService;
|
||||||
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
||||||
use Mockery\MockInterface;
|
|
||||||
use Tests\TestCase;
|
|
||||||
use Illuminate\Support\Facades\Storage;
|
|
||||||
use Illuminate\Support\Facades\Http;
|
use Illuminate\Support\Facades\Http;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Tests\Data\HttpRequestTestData;
|
use Tests\Data\HttpRequestTestData;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Services\LogoService
|
* @covers \App\Services\LogoService
|
||||||
@ -20,7 +19,7 @@ class LogoServiceTest extends TestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
}
|
}
|
||||||
@ -30,20 +29,20 @@ public function setUp(): void
|
|||||||
*/
|
*/
|
||||||
public function test_getIcon_returns_stored_icon_file_when_logo_exists()
|
public function test_getIcon_returns_stored_icon_file_when_logo_exists()
|
||||||
{
|
{
|
||||||
$svgLogo = HttpRequestTestData::SVG_LOGO_BODY;
|
$svgLogo = HttpRequestTestData::SVG_LOGO_BODY;
|
||||||
$tfaJsonBody = HttpRequestTestData::TFA_JSON_BODY;
|
$tfaJsonBody = HttpRequestTestData::TFA_JSON_BODY;
|
||||||
|
|
||||||
Http::preventStrayRequests();
|
Http::preventStrayRequests();
|
||||||
Http::fake([
|
Http::fake([
|
||||||
'https://raw.githubusercontent.com/2factorauth/twofactorauth/master/img/*' => Http::response($svgLogo, 200),
|
'https://raw.githubusercontent.com/2factorauth/twofactorauth/master/img/*' => Http::response($svgLogo, 200),
|
||||||
'https://2fa.directory/api/v3/tfa.json' => Http::response($tfaJsonBody, 200),
|
'https://2fa.directory/api/v3/tfa.json' => Http::response($tfaJsonBody, 200),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Storage::fake('icons');
|
Storage::fake('icons');
|
||||||
Storage::fake('logos');
|
Storage::fake('logos');
|
||||||
|
|
||||||
$logoService = new LogoService();
|
$logoService = new LogoService();
|
||||||
$icon = $logoService->getIcon('twitter');
|
$icon = $logoService->getIcon('twitter');
|
||||||
|
|
||||||
$this->assertNotNull($icon);
|
$this->assertNotNull($icon);
|
||||||
Storage::disk('icons')->assertExists($icon);
|
Storage::disk('icons')->assertExists($icon);
|
||||||
@ -117,7 +116,7 @@ public function test_logoService_loads_empty_collection_when_tfajson_fetching_fa
|
|||||||
Storage::fake('logos');
|
Storage::fake('logos');
|
||||||
|
|
||||||
$logoService = new LogoService();
|
$logoService = new LogoService();
|
||||||
$icon = $logoService->getIcon('twitter');
|
$icon = $logoService->getIcon('twitter');
|
||||||
|
|
||||||
$this->assertNull($icon);
|
$this->assertNull($icon);
|
||||||
Storage::disk('logos')->assertMissing(LogoService::TFA_JSON);
|
Storage::disk('logos')->assertMissing(LogoService::TFA_JSON);
|
||||||
|
@ -21,7 +21,7 @@ class QrCodeServiceTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
}
|
}
|
||||||
|
@ -5,9 +5,9 @@
|
|||||||
use App\Facades\Settings;
|
use App\Facades\Settings;
|
||||||
use App\Services\ReleaseRadarService;
|
use App\Services\ReleaseRadarService;
|
||||||
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
||||||
use Tests\FeatureTestCase;
|
|
||||||
use Illuminate\Support\Facades\Http;
|
use Illuminate\Support\Facades\Http;
|
||||||
use Tests\Data\HttpRequestTestData;
|
use Tests\Data\HttpRequestTestData;
|
||||||
|
use Tests\FeatureTestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Services\ReleaseRadarService
|
* @covers \App\Services\ReleaseRadarService
|
||||||
@ -29,15 +29,15 @@ public function test_manualScan_returns_no_new_release()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$releaseRadarService = new ReleaseRadarService();
|
$releaseRadarService = new ReleaseRadarService();
|
||||||
$release = $releaseRadarService->manualScan();
|
$release = $releaseRadarService->manualScan();
|
||||||
|
|
||||||
$this->assertFalse($release);
|
$this->assertFalse($release);
|
||||||
$this->assertDatabaseHas('options', [
|
$this->assertDatabaseHas('options', [
|
||||||
'key' => 'lastRadarScan',
|
'key' => 'lastRadarScan',
|
||||||
]);
|
]);
|
||||||
$this->assertDatabaseMissing('options', [
|
$this->assertDatabaseMissing('options', [
|
||||||
'key' => 'latestRelease',
|
'key' => 'latestRelease',
|
||||||
'value' => HttpRequestTestData::TAG_NAME
|
'value' => HttpRequestTestData::TAG_NAME,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,15 +54,15 @@ public function test_manualScan_returns_new_release()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$releaseRadarService = new ReleaseRadarService();
|
$releaseRadarService = new ReleaseRadarService();
|
||||||
$release = $releaseRadarService->manualScan();
|
$release = $releaseRadarService->manualScan();
|
||||||
|
|
||||||
$this->assertEquals(HttpRequestTestData::NEW_TAG_NAME, $release);
|
$this->assertEquals(HttpRequestTestData::NEW_TAG_NAME, $release);
|
||||||
$this->assertDatabaseHas('options', [
|
$this->assertDatabaseHas('options', [
|
||||||
'key' => 'latestRelease',
|
'key' => 'latestRelease',
|
||||||
'value' => HttpRequestTestData::NEW_TAG_NAME
|
'value' => HttpRequestTestData::NEW_TAG_NAME,
|
||||||
]);
|
]);
|
||||||
$this->assertDatabaseHas('options', [
|
$this->assertDatabaseHas('options', [
|
||||||
'key' => 'lastRadarScan',
|
'key' => 'lastRadarScan',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,7 +77,7 @@ public function test_manualScan_succeed_when_something_fails()
|
|||||||
Http::preventStrayRequests();
|
Http::preventStrayRequests();
|
||||||
|
|
||||||
$releaseRadarService = new ReleaseRadarService();
|
$releaseRadarService = new ReleaseRadarService();
|
||||||
$release = $releaseRadarService->manualScan();
|
$release = $releaseRadarService->manualScan();
|
||||||
|
|
||||||
$this->assertFalse($release);
|
$this->assertFalse($release);
|
||||||
}
|
}
|
||||||
@ -95,7 +95,7 @@ public function test_manualScan_succeed_when_github_is_unreachable()
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$releaseRadarService = new ReleaseRadarService();
|
$releaseRadarService = new ReleaseRadarService();
|
||||||
$release = $releaseRadarService->manualScan();
|
$release = $releaseRadarService->manualScan();
|
||||||
|
|
||||||
$this->assertFalse($release);
|
$this->assertFalse($release);
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ class SettingServiceTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -239,7 +239,7 @@ public function test_set_useEncryption_off_returns_exception_when_data_are_undec
|
|||||||
/**
|
/**
|
||||||
* Provide invalid data for validation test
|
* Provide invalid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideUndecipherableData(): array
|
public function provideUndecipherableData() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[[
|
[[
|
||||||
|
@ -5,9 +5,9 @@
|
|||||||
use App\Facades\TwoFAccounts;
|
use App\Facades\TwoFAccounts;
|
||||||
use App\Models\Group;
|
use App\Models\Group;
|
||||||
use App\Models\TwoFAccount;
|
use App\Models\TwoFAccount;
|
||||||
|
use Tests\Data\MigrationTestData;
|
||||||
use Tests\Data\OtpTestData;
|
use Tests\Data\OtpTestData;
|
||||||
use Tests\FeatureTestCase;
|
use Tests\FeatureTestCase;
|
||||||
use Tests\Data\MigrationTestData;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Services\TwoFAccountService
|
* @covers \App\Services\TwoFAccountService
|
||||||
@ -33,7 +33,7 @@ class TwoFAccountServiceTest extends FeatureTestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -2,20 +2,20 @@
|
|||||||
|
|
||||||
namespace Tests\Unit\Exceptions;
|
namespace Tests\Unit\Exceptions;
|
||||||
|
|
||||||
|
use App\Exceptions\DbEncryptionException;
|
||||||
|
use App\Exceptions\EncryptedMigrationException;
|
||||||
use App\Exceptions\Handler;
|
use App\Exceptions\Handler;
|
||||||
|
use App\Exceptions\InvalidMigrationDataException;
|
||||||
|
use App\Exceptions\InvalidOtpParameterException;
|
||||||
|
use App\Exceptions\InvalidQrCodeException;
|
||||||
|
use App\Exceptions\InvalidSecretException;
|
||||||
|
use App\Exceptions\UndecipherableException;
|
||||||
|
use App\Exceptions\UnsupportedMigrationException;
|
||||||
|
use App\Exceptions\UnsupportedOtpTypeException;
|
||||||
use Illuminate\Contracts\Container\Container;
|
use Illuminate\Contracts\Container\Container;
|
||||||
use Illuminate\Http\JsonResponse;
|
use Illuminate\Http\JsonResponse;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use App\Exceptions\InvalidOtpParameterException;
|
|
||||||
use \App\Exceptions\InvalidQrCodeException;
|
|
||||||
use App\Exceptions\InvalidSecretException;
|
|
||||||
use App\Exceptions\DbEncryptionException;
|
|
||||||
use App\Exceptions\InvalidMigrationDataException;
|
|
||||||
use App\Exceptions\UndecipherableException;
|
|
||||||
use App\Exceptions\UnsupportedMigrationException;
|
|
||||||
use App\Exceptions\UnsupportedOtpTypeException;
|
|
||||||
use App\Exceptions\EncryptedMigrationException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Exceptions\Handler
|
* @covers \App\Exceptions\Handler
|
||||||
@ -50,7 +50,7 @@ public function test_exceptions_returns_badRequest_json_response($exception)
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideExceptionsforBadRequest(): array
|
public function provideExceptionsforBadRequest() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[
|
[
|
||||||
@ -111,7 +111,7 @@ public function test_exceptions_returns_notFound_json_response($exception)
|
|||||||
/**
|
/**
|
||||||
* Provide Valid data for validation test
|
* Provide Valid data for validation test
|
||||||
*/
|
*/
|
||||||
public function provideExceptionsforNotFound(): array
|
public function provideExceptionsforNotFound() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[
|
[
|
||||||
|
@ -7,8 +7,8 @@
|
|||||||
use App\Models\Group;
|
use App\Models\Group;
|
||||||
use App\Models\TwoFAccount;
|
use App\Models\TwoFAccount;
|
||||||
use Illuminate\Support\Facades\Event;
|
use Illuminate\Support\Facades\Event;
|
||||||
use Tests\TestCase;
|
|
||||||
use Mockery\MockInterface;
|
use Mockery\MockInterface;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Listeners\DissociateTwofaccountFromGroup
|
* @covers \App\Listeners\DissociateTwofaccountFromGroup
|
||||||
@ -23,15 +23,14 @@ class DissociateTwofaccountFromGroupTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function test_twofaccount_is_released_on_group_deletion()
|
public function test_twofaccount_is_released_on_group_deletion()
|
||||||
{
|
{
|
||||||
|
|
||||||
$this->mock('alias:' . TwoFAccount::class, function (MockInterface $twoFAccount) {
|
$this->mock('alias:' . TwoFAccount::class, function (MockInterface $twoFAccount) {
|
||||||
$twoFAccount->shouldReceive('where->update')
|
$twoFAccount->shouldReceive('where->update')
|
||||||
->once()
|
->once()
|
||||||
->andReturn(1);
|
->andReturn(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
$group = Group::factory()->make();
|
$group = Group::factory()->make();
|
||||||
$event = new GroupDeleting($group);
|
$event = new GroupDeleting($group);
|
||||||
$listener = new DissociateTwofaccountFromGroup();
|
$listener = new DissociateTwofaccountFromGroup();
|
||||||
|
|
||||||
$this->assertNull($listener->handle($event));
|
$this->assertNull($listener->handle($event));
|
||||||
|
@ -3,26 +3,23 @@
|
|||||||
namespace Tests\Unit;
|
namespace Tests\Unit;
|
||||||
|
|
||||||
use App\Exceptions\EncryptedMigrationException;
|
use App\Exceptions\EncryptedMigrationException;
|
||||||
use App\Factories\MigratorFactory;
|
|
||||||
use App\Exceptions\InvalidMigrationDataException;
|
use App\Exceptions\InvalidMigrationDataException;
|
||||||
|
use App\Exceptions\UnsupportedMigrationException;
|
||||||
|
use App\Factories\MigratorFactory;
|
||||||
use App\Models\TwoFAccount;
|
use App\Models\TwoFAccount;
|
||||||
use App\Services\Migrators\AegisMigrator;
|
use App\Services\Migrators\AegisMigrator;
|
||||||
use App\Services\Migrators\TwoFASMigrator;
|
use App\Services\Migrators\GoogleAuthMigrator;
|
||||||
use App\Services\Migrators\Migrator;
|
use App\Services\Migrators\Migrator;
|
||||||
use App\Services\Migrators\PlainTextMigrator;
|
use App\Services\Migrators\PlainTextMigrator;
|
||||||
use App\Services\Migrators\GoogleAuthMigrator;
|
use App\Services\Migrators\TwoFASMigrator;
|
||||||
use App\Services\SettingService;
|
use App\Services\SettingService;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use Mockery;
|
use Mockery;
|
||||||
use Mockery\Mock;
|
|
||||||
use Mockery\MockInterface;
|
use Mockery\MockInterface;
|
||||||
|
use ParagonIE\ConstantTime\Base32;
|
||||||
use Tests\Data\MigrationTestData;
|
use Tests\Data\MigrationTestData;
|
||||||
use Tests\Data\OtpTestData;
|
use Tests\Data\OtpTestData;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use ParagonIE\ConstantTime\Base32;
|
|
||||||
use App\Protobuf\GoogleAuth\Payload\Algorithm;
|
|
||||||
use App\Exceptions\UnsupportedMigrationException;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @covers \App\Providers\MigrationServiceProvider
|
* @covers \App\Providers\MigrationServiceProvider
|
||||||
@ -32,6 +29,7 @@
|
|||||||
* @covers \App\Services\Migrators\TwoFASMigrator
|
* @covers \App\Services\Migrators\TwoFASMigrator
|
||||||
* @covers \App\Services\Migrators\PlainTextMigrator
|
* @covers \App\Services\Migrators\PlainTextMigrator
|
||||||
* @covers \App\Services\Migrators\GoogleAuthMigrator
|
* @covers \App\Services\Migrators\GoogleAuthMigrator
|
||||||
|
*
|
||||||
* @uses \App\Models\TwoFAccount
|
* @uses \App\Models\TwoFAccount
|
||||||
*/
|
*/
|
||||||
class MigratorTest extends TestCase
|
class MigratorTest extends TestCase
|
||||||
@ -61,7 +59,7 @@ class MigratorTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
protected $GAuthTotpBisTwofaccount;
|
protected $GAuthTotpBisTwofaccount;
|
||||||
|
|
||||||
public function setUp(): void
|
public function setUp() : void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
@ -111,30 +109,30 @@ public function setUp(): void
|
|||||||
$this->steamTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
$this->steamTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
||||||
$this->steamTwofaccount->counter = null;
|
$this->steamTwofaccount->counter = null;
|
||||||
|
|
||||||
$this->GAuthTotpTwofaccount = new TwoFAccount;
|
$this->GAuthTotpTwofaccount = new TwoFAccount;
|
||||||
$this->GAuthTotpTwofaccount->service = OtpTestData::SERVICE;
|
$this->GAuthTotpTwofaccount->service = OtpTestData::SERVICE;
|
||||||
$this->GAuthTotpTwofaccount->account = OtpTestData::ACCOUNT;
|
$this->GAuthTotpTwofaccount->account = OtpTestData::ACCOUNT;
|
||||||
$this->GAuthTotpTwofaccount->icon = null;
|
$this->GAuthTotpTwofaccount->icon = null;
|
||||||
$this->GAuthTotpTwofaccount->otp_type = 'totp';
|
$this->GAuthTotpTwofaccount->otp_type = 'totp';
|
||||||
$this->GAuthTotpTwofaccount->secret = OtpTestData::SECRET;
|
$this->GAuthTotpTwofaccount->secret = OtpTestData::SECRET;
|
||||||
$this->GAuthTotpTwofaccount->digits = OtpTestData::DIGITS_DEFAULT;
|
$this->GAuthTotpTwofaccount->digits = OtpTestData::DIGITS_DEFAULT;
|
||||||
$this->GAuthTotpTwofaccount->algorithm = OtpTestData::ALGORITHM_DEFAULT;
|
$this->GAuthTotpTwofaccount->algorithm = OtpTestData::ALGORITHM_DEFAULT;
|
||||||
$this->GAuthTotpTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
$this->GAuthTotpTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
||||||
$this->GAuthTotpTwofaccount->counter = null;
|
$this->GAuthTotpTwofaccount->counter = null;
|
||||||
|
|
||||||
$this->GAuthTotpBisTwofaccount = new TwoFAccount;
|
$this->GAuthTotpBisTwofaccount = new TwoFAccount;
|
||||||
$this->GAuthTotpBisTwofaccount->service = OtpTestData::SERVICE . '_bis';
|
$this->GAuthTotpBisTwofaccount->service = OtpTestData::SERVICE . '_bis';
|
||||||
$this->GAuthTotpBisTwofaccount->account = OtpTestData::ACCOUNT . '_bis';
|
$this->GAuthTotpBisTwofaccount->account = OtpTestData::ACCOUNT . '_bis';
|
||||||
$this->GAuthTotpBisTwofaccount->icon = null;
|
$this->GAuthTotpBisTwofaccount->icon = null;
|
||||||
$this->GAuthTotpBisTwofaccount->otp_type = 'totp';
|
$this->GAuthTotpBisTwofaccount->otp_type = 'totp';
|
||||||
$this->GAuthTotpBisTwofaccount->secret = OtpTestData::SECRET;
|
$this->GAuthTotpBisTwofaccount->secret = OtpTestData::SECRET;
|
||||||
$this->GAuthTotpBisTwofaccount->digits = OtpTestData::DIGITS_DEFAULT;
|
$this->GAuthTotpBisTwofaccount->digits = OtpTestData::DIGITS_DEFAULT;
|
||||||
$this->GAuthTotpBisTwofaccount->algorithm = OtpTestData::ALGORITHM_DEFAULT;
|
$this->GAuthTotpBisTwofaccount->algorithm = OtpTestData::ALGORITHM_DEFAULT;
|
||||||
$this->GAuthTotpBisTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
$this->GAuthTotpBisTwofaccount->period = OtpTestData::PERIOD_DEFAULT;
|
||||||
$this->GAuthTotpBisTwofaccount->counter = null;
|
$this->GAuthTotpBisTwofaccount->counter = null;
|
||||||
|
|
||||||
$this->fakeTwofaccount = new TwoFAccount;
|
$this->fakeTwofaccount = new TwoFAccount;
|
||||||
$this->fakeTwofaccount->id = TwoFAccount::FAKE_ID;
|
$this->fakeTwofaccount->id = TwoFAccount::FAKE_ID;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -179,25 +177,25 @@ public function validMigrationsProvider()
|
|||||||
new PlainTextMigrator(),
|
new PlainTextMigrator(),
|
||||||
MigrationTestData::VALID_PLAIN_TEXT_PAYLOAD,
|
MigrationTestData::VALID_PLAIN_TEXT_PAYLOAD,
|
||||||
'custom',
|
'custom',
|
||||||
$hasSteam = true
|
$hasSteam = true,
|
||||||
],
|
],
|
||||||
'PLAIN_TEXT_PAYLOAD_WITH_INTRUDER' => [
|
'PLAIN_TEXT_PAYLOAD_WITH_INTRUDER' => [
|
||||||
new PlainTextMigrator(),
|
new PlainTextMigrator(),
|
||||||
MigrationTestData::VALID_PLAIN_TEXT_PAYLOAD_WITH_INTRUDER,
|
MigrationTestData::VALID_PLAIN_TEXT_PAYLOAD_WITH_INTRUDER,
|
||||||
'custom',
|
'custom',
|
||||||
$hasSteam = true
|
$hasSteam = true,
|
||||||
],
|
],
|
||||||
'AEGIS_JSON_MIGRATION_PAYLOAD' => [
|
'AEGIS_JSON_MIGRATION_PAYLOAD' => [
|
||||||
new AegisMigrator(),
|
new AegisMigrator(),
|
||||||
MigrationTestData::VALID_AEGIS_JSON_MIGRATION_PAYLOAD,
|
MigrationTestData::VALID_AEGIS_JSON_MIGRATION_PAYLOAD,
|
||||||
'custom',
|
'custom',
|
||||||
$hasSteam = true
|
$hasSteam = true,
|
||||||
],
|
],
|
||||||
'2FAS_MIGRATION_PAYLOAD' => [
|
'2FAS_MIGRATION_PAYLOAD' => [
|
||||||
new TwoFASMigrator(),
|
new TwoFASMigrator(),
|
||||||
MigrationTestData::VALID_2FAS_MIGRATION_PAYLOAD,
|
MigrationTestData::VALID_2FAS_MIGRATION_PAYLOAD,
|
||||||
'custom',
|
'custom',
|
||||||
$hasSteam = false
|
$hasSteam = false,
|
||||||
],
|
],
|
||||||
'GOOGLE_AUTH_MIGRATION_PAYLOAD' => [
|
'GOOGLE_AUTH_MIGRATION_PAYLOAD' => [
|
||||||
new GoogleAuthMigrator(),
|
new GoogleAuthMigrator(),
|
||||||
@ -466,18 +464,15 @@ public function encryptedMigrationDataProvider()
|
|||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'ENCRYPTED_AEGIS_JSON_MIGRATION_PAYLOAD' => [
|
'ENCRYPTED_AEGIS_JSON_MIGRATION_PAYLOAD' => [
|
||||||
MigrationTestData::ENCRYPTED_AEGIS_JSON_MIGRATION_PAYLOAD
|
MigrationTestData::ENCRYPTED_AEGIS_JSON_MIGRATION_PAYLOAD,
|
||||||
],
|
],
|
||||||
'ENCRYPTED_2FAS_MIGRATION_PAYLOAD' => [
|
'ENCRYPTED_2FAS_MIGRATION_PAYLOAD' => [
|
||||||
MigrationTestData::ENCRYPTED_2FAS_MIGRATION_PAYLOAD
|
MigrationTestData::ENCRYPTED_2FAS_MIGRATION_PAYLOAD,
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
protected function tearDown() : void
|
||||||
*
|
|
||||||
*/
|
|
||||||
protected function tearDown(): void
|
|
||||||
{
|
{
|
||||||
Mockery::close();
|
Mockery::close();
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ public function test_sensitive_attributes_are_stored_encrypted(string $attribute
|
|||||||
/**
|
/**
|
||||||
* Provide attributes to test for encryption
|
* Provide attributes to test for encryption
|
||||||
*/
|
*/
|
||||||
public function provideSensitiveAttributes(): array
|
public function provideSensitiveAttributes() : array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
[
|
[
|
||||||
|
Loading…
Reference in New Issue
Block a user