mirror of
https://github.com/elyby/accounts.git
synced 2025-01-16 00:32:52 +05:30
Исправлена обработка ситуации, когда uuid selectedProfile при join операции передан без дефисов
This commit is contained in:
parent
da87d4bc86
commit
b8e445b99f
@ -126,7 +126,7 @@ class JoinForm extends Model {
|
|||||||
|
|
||||||
$selectedProfile = $this->selectedProfile;
|
$selectedProfile = $this->selectedProfile;
|
||||||
$isUuid = StringHelper::isUuid($selectedProfile);
|
$isUuid = StringHelper::isUuid($selectedProfile);
|
||||||
if ($isUuid && $account->uuid !== $selectedProfile) {
|
if ($isUuid && $account->uuid !== $this->normalizeUUID($selectedProfile)) {
|
||||||
Session::error(
|
Session::error(
|
||||||
"User with access_token = '{$accessToken}' trying to join with identity = '{$selectedProfile}'," .
|
"User with access_token = '{$accessToken}' trying to join with identity = '{$selectedProfile}'," .
|
||||||
" but access_token issued to account with id = '{$account->uuid}'."
|
" but access_token issued to account with id = '{$account->uuid}'."
|
||||||
@ -149,4 +149,8 @@ class JoinForm extends Model {
|
|||||||
return $this->account;
|
return $this->account;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function normalizeUUID(string $uuid): string {
|
||||||
|
return Uuid::fromString($uuid)->toString();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -52,6 +52,17 @@ class JoinCest {
|
|||||||
$this->expectSuccessResponse($I);
|
$this->expectSuccessResponse($I);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function joinByOauth2TokenWithNotDashedUUID(OauthSteps $I) {
|
||||||
|
$I->wantTo('join to server, using modern oAuth2 generated token and non dashed uuid');
|
||||||
|
$accessToken = $I->getAccessToken([P::MINECRAFT_SERVER_SESSION]);
|
||||||
|
$this->route->join([
|
||||||
|
'accessToken' => $accessToken,
|
||||||
|
'selectedProfile' => 'df936908b2e1544d96f82977ec213022',
|
||||||
|
'serverId' => Uuid::uuid(),
|
||||||
|
]);
|
||||||
|
$this->expectSuccessResponse($I);
|
||||||
|
}
|
||||||
|
|
||||||
public function joinByModernOauth2TokenWithoutPermission(OauthSteps $I) {
|
public function joinByModernOauth2TokenWithoutPermission(OauthSteps $I) {
|
||||||
$I->wantTo('join to server, using moder oAuth2 generated token, but without minecraft auth permission');
|
$I->wantTo('join to server, using moder oAuth2 generated token, but without minecraft auth permission');
|
||||||
$accessToken = $I->getAccessToken(['account_info', 'account_email']);
|
$accessToken = $I->getAccessToken(['account_info', 'account_email']);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user