2021-09-18 00:00:39 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Rules;
|
|
|
|
|
2022-12-13 09:05:56 +01:00
|
|
|
use App\Helpers\Helpers;
|
2021-09-18 00:00:39 +02:00
|
|
|
use Illuminate\Contracts\Validation\Rule;
|
|
|
|
use ParagonIE\ConstantTime\Base32;
|
|
|
|
|
|
|
|
class IsBase32Encoded implements Rule
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Create a new rule instance.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
//
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if the validation rule passes.
|
|
|
|
*
|
|
|
|
* @param string $attribute
|
|
|
|
* @param mixed $value
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function passes($attribute, $value)
|
|
|
|
{
|
|
|
|
try {
|
2022-12-13 09:05:56 +01:00
|
|
|
$secret = Base32::decodeUpper(Helpers::PadToBase32Format($value));
|
2021-09-18 00:00:39 +02:00
|
|
|
} catch (\Exception $e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the validation error message.
|
|
|
|
*
|
2022-08-26 15:57:18 +02:00
|
|
|
* @return array|string
|
2021-09-18 00:00:39 +02:00
|
|
|
*/
|
|
|
|
public function message()
|
|
|
|
{
|
|
|
|
return trans('validation.custom.secret.isBase32Encoded');
|
|
|
|
}
|
|
|
|
}
|