2021-06-30 22:10:02 +01:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 17:56:55 +01:00
|
|
|
namespace BookStack\Access\Mfa;
|
2021-06-30 22:10:02 +01:00
|
|
|
|
|
|
|
use Illuminate\Contracts\Validation\Rule;
|
|
|
|
|
|
|
|
class TotpValidationRule implements Rule
|
|
|
|
{
|
|
|
|
protected $secret;
|
|
|
|
protected $totpService;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new rule instance.
|
|
|
|
* Takes the TOTP secret that must be system provided, not user provided.
|
|
|
|
*/
|
|
|
|
public function __construct(string $secret)
|
|
|
|
{
|
|
|
|
$this->secret = $secret;
|
|
|
|
$this->totpService = app()->make(TotpService::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if the validation rule passes.
|
|
|
|
*/
|
|
|
|
public function passes($attribute, $value)
|
|
|
|
{
|
|
|
|
return $this->totpService->verifyCode($value, $this->secret);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the validation error message.
|
|
|
|
*/
|
|
|
|
public function message()
|
|
|
|
{
|
|
|
|
return trans('validation.totp');
|
|
|
|
}
|
|
|
|
}
|