mirror of
https://github.com/elyby/accounts.git
synced 2024-11-30 02:32:26 +05:30
Добавлена проверка, что если приходить nil uuid, то бросается IllegalArgumentException для sessionserver
This commit is contained in:
parent
67cbf2a502
commit
d3a2a37f11
@ -90,6 +90,7 @@ class JoinForm extends Model {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$validator = new UuidValidator();
|
$validator = new UuidValidator();
|
||||||
|
$validator->allowNil = false;
|
||||||
$validator->validateAttribute($this, $attribute);
|
$validator->validateAttribute($this, $attribute);
|
||||||
|
|
||||||
if ($this->hasErrors($attribute)) {
|
if ($this->hasErrors($attribute)) {
|
||||||
|
@ -7,6 +7,8 @@ use yii\validators\Validator;
|
|||||||
|
|
||||||
class UuidValidator extends Validator {
|
class UuidValidator extends Validator {
|
||||||
|
|
||||||
|
public $allowNil = true;
|
||||||
|
|
||||||
public $skipOnEmpty = false;
|
public $skipOnEmpty = false;
|
||||||
|
|
||||||
public $message = '{attribute} must be valid uuid';
|
public $message = '{attribute} must be valid uuid';
|
||||||
@ -18,6 +20,10 @@ class UuidValidator extends Validator {
|
|||||||
} catch (InvalidArgumentException $e) {
|
} catch (InvalidArgumentException $e) {
|
||||||
$this->addError($model, $attribute, $this->message, []);
|
$this->addError($model, $attribute, $this->message, []);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isset($uuid) && $this->allowNil === false && $uuid === Uuid::NIL) {
|
||||||
|
$this->addError($model, $attribute, $this->message, []);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -111,6 +111,21 @@ class JoinCest {
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function joinWithNilUuids(FunctionalTester $I) {
|
||||||
|
$I->wantTo('join to some server with nil accessToken and selectedProfile');
|
||||||
|
$this->route->join([
|
||||||
|
'accessToken' => '00000000-0000-0000-0000-000000000000',
|
||||||
|
'selectedProfile' => 'df936908-b2e1-544d-96f8-2977ec213022',
|
||||||
|
'serverId' => Uuid::uuid(),
|
||||||
|
]);
|
||||||
|
$I->canSeeResponseCodeIs(400);
|
||||||
|
$I->canSeeResponseIsJson();
|
||||||
|
$I->canSeeResponseContainsJson([
|
||||||
|
'error' => 'IllegalArgumentException',
|
||||||
|
'errorMessage' => 'credentials can not be null.',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
private function expectSuccessResponse(FunctionalTester $I) {
|
private function expectSuccessResponse(FunctionalTester $I) {
|
||||||
$I->seeResponseCodeIs(200);
|
$I->seeResponseCodeIs(200);
|
||||||
$I->seeResponseIsJson();
|
$I->seeResponseIsJson();
|
||||||
|
@ -84,6 +84,17 @@ class JoinLegacyCest {
|
|||||||
$I->canSeeResponseContains('Ely.by authorization required');
|
$I->canSeeResponseContains('Ely.by authorization required');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function joinWithNilUuids(FunctionalTester $I) {
|
||||||
|
$I->wantTo('join to some server by legacy protocol with nil accessToken and selectedProfile');
|
||||||
|
$this->route->joinLegacy([
|
||||||
|
'sessionId' => 'token:00000000-0000-0000-0000-000000000000:00000000-0000-0000-0000-000000000000',
|
||||||
|
'user' => 'SomeUser',
|
||||||
|
'serverId' => Uuid::uuid(),
|
||||||
|
]);
|
||||||
|
$I->canSeeResponseCodeIs(400);
|
||||||
|
$I->canSeeResponseContains('credentials can not be null.');
|
||||||
|
}
|
||||||
|
|
||||||
private function expectSuccessResponse(FunctionalTester $I) {
|
private function expectSuccessResponse(FunctionalTester $I) {
|
||||||
$I->seeResponseCodeIs(200);
|
$I->seeResponseCodeIs(200);
|
||||||
$I->canSeeResponseEquals('OK');
|
$I->canSeeResponseEquals('OK');
|
||||||
|
@ -12,42 +12,66 @@ class UuidValidatorTest extends TestCase {
|
|||||||
|
|
||||||
public function testValidateAttribute() {
|
public function testValidateAttribute() {
|
||||||
$this->specify('expected error if passed empty value', function() {
|
$this->specify('expected error if passed empty value', function() {
|
||||||
$model = new UuidTestModel();
|
$validator = new UuidValidator();
|
||||||
expect($model->validate())->false();
|
$model = $this->createModel();
|
||||||
expect($model->getErrors('attribute'))->equals(['Attribute must be valid uuid']);
|
$validator->validateAttribute($model, 'attribute');
|
||||||
|
$this->assertTrue($model->hasErrors());
|
||||||
|
$this->assertEquals(['Attribute must be valid uuid'], $model->getErrors('attribute'));
|
||||||
});
|
});
|
||||||
|
|
||||||
$this->specify('expected error if passed invalid string', function() {
|
$this->specify('expected error if passed invalid string', function() {
|
||||||
$model = new UuidTestModel();
|
$validator = new UuidValidator();
|
||||||
|
$model = $this->createModel();
|
||||||
$model->attribute = '123456789';
|
$model->attribute = '123456789';
|
||||||
expect($model->validate())->false();
|
$validator->validateAttribute($model, 'attribute');
|
||||||
expect($model->getErrors('attribute'))->equals(['Attribute must be valid uuid']);
|
$this->assertTrue($model->hasErrors());
|
||||||
|
$this->assertEquals(['Attribute must be valid uuid'], $model->getErrors('attribute'));
|
||||||
|
});
|
||||||
|
|
||||||
|
$this->specify('no errors if passed nil uuid and allowNil is set to true', function() {
|
||||||
|
$validator = new UuidValidator();
|
||||||
|
$model = $this->createModel();
|
||||||
|
$model->attribute = '00000000-0000-0000-0000-000000000000';
|
||||||
|
$validator->validateAttribute($model, 'attribute');
|
||||||
|
$this->assertFalse($model->hasErrors());
|
||||||
|
});
|
||||||
|
|
||||||
|
$this->specify('no errors if passed nil uuid and allowNil is set to false', function() {
|
||||||
|
$validator = new UuidValidator();
|
||||||
|
$validator->allowNil = false;
|
||||||
|
$model = $this->createModel();
|
||||||
|
$model->attribute = '00000000-0000-0000-0000-000000000000';
|
||||||
|
$validator->validateAttribute($model, 'attribute');
|
||||||
|
$this->assertTrue($model->hasErrors());
|
||||||
|
$this->assertEquals(['Attribute must be valid uuid'], $model->getErrors('attribute'));
|
||||||
});
|
});
|
||||||
|
|
||||||
$this->specify('no errors if passed valid uuid', function() {
|
$this->specify('no errors if passed valid uuid', function() {
|
||||||
$model = new UuidTestModel();
|
$validator = new UuidValidator();
|
||||||
|
$model = $this->createModel();
|
||||||
$model->attribute = Uuid::uuid();
|
$model->attribute = Uuid::uuid();
|
||||||
expect($model->validate())->true();
|
$validator->validateAttribute($model, 'attribute');
|
||||||
|
$this->assertFalse($model->hasErrors());
|
||||||
});
|
});
|
||||||
|
|
||||||
$this->specify('no errors if passed uuid string without dashes and converted to standart value', function() {
|
$this->specify('no errors if passed uuid string without dashes and converted to standart value', function() {
|
||||||
$model = new UuidTestModel();
|
$validator = new UuidValidator();
|
||||||
|
$model = $this->createModel();
|
||||||
$originalUuid = Uuid::uuid();
|
$originalUuid = Uuid::uuid();
|
||||||
$model->attribute = str_replace('-', '', $originalUuid);
|
$model->attribute = str_replace('-', '', $originalUuid);
|
||||||
expect($model->validate())->true();
|
$validator->validateAttribute($model, 'attribute');
|
||||||
expect($model->attribute)->equals($originalUuid);
|
$this->assertFalse($model->hasErrors());
|
||||||
|
$this->assertEquals($originalUuid, $model->attribute);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
/**
|
||||||
|
* @return Model
|
||||||
class UuidTestModel extends Model {
|
*/
|
||||||
public $attribute;
|
public function createModel() {
|
||||||
|
return new class extends Model {
|
||||||
public function rules() {
|
public $attribute;
|
||||||
return [
|
};
|
||||||
['attribute', UuidValidator::class],
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user