2018-01-02 20:22:56 +03:00
|
|
|
<?php
|
2019-12-04 21:10:15 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2018-01-02 20:22:56 +03:00
|
|
|
namespace api\modules\authserver\validators;
|
|
|
|
|
|
|
|
use api\modules\authserver\exceptions\IllegalArgumentException;
|
2019-12-04 21:10:15 +03:00
|
|
|
use yii\validators\Validator;
|
2018-01-02 20:22:56 +03:00
|
|
|
|
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* The maximum length of clientToken for our database is 255.
|
|
|
|
* If the token is longer, we do not accept the passed token at all.
|
2018-01-02 20:22:56 +03:00
|
|
|
*/
|
2019-12-04 21:10:15 +03:00
|
|
|
class ClientTokenValidator extends Validator {
|
2018-01-02 20:22:56 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $value
|
|
|
|
* @return null
|
|
|
|
* @throws \api\modules\authserver\exceptions\AuthserverException
|
|
|
|
*/
|
2019-12-04 21:10:15 +03:00
|
|
|
protected function validateValue($value): ?array {
|
2023-05-26 18:48:15 +02:00
|
|
|
if (mb_strlen((string)$value) > 255) {
|
2018-01-02 20:22:56 +03:00
|
|
|
throw new IllegalArgumentException('clientToken is too long.');
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|