2016-08-21 02:21:39 +03:00
|
|
|
<?php
|
|
|
|
namespace api\modules\authserver\models;
|
|
|
|
|
2017-05-31 03:10:22 +03:00
|
|
|
use api\models\base\ApiForm;
|
2016-08-21 02:21:39 +03:00
|
|
|
use api\modules\authserver\exceptions\ForbiddenOperationException;
|
|
|
|
use api\modules\authserver\validators\RequiredValidator;
|
2016-09-01 10:31:43 +03:00
|
|
|
use common\models\Account;
|
2016-08-21 02:21:39 +03:00
|
|
|
use common\models\MinecraftAccessKey;
|
|
|
|
|
2017-05-31 03:10:22 +03:00
|
|
|
class RefreshTokenForm extends ApiForm {
|
2016-08-21 02:21:39 +03:00
|
|
|
|
|
|
|
public $accessToken;
|
|
|
|
public $clientToken;
|
|
|
|
|
|
|
|
public function rules() {
|
|
|
|
return [
|
2016-09-01 10:31:43 +03:00
|
|
|
[['accessToken', 'clientToken'], RequiredValidator::class],
|
2016-08-21 02:21:39 +03:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return AuthenticateData
|
|
|
|
* @throws \api\modules\authserver\exceptions\AuthserverException
|
|
|
|
*/
|
|
|
|
public function refresh() {
|
|
|
|
$this->validate();
|
|
|
|
|
|
|
|
/** @var MinecraftAccessKey|null $accessToken */
|
|
|
|
$accessToken = MinecraftAccessKey::findOne([
|
|
|
|
'access_token' => $this->accessToken,
|
|
|
|
'client_token' => $this->clientToken,
|
|
|
|
]);
|
|
|
|
if ($accessToken === null) {
|
|
|
|
throw new ForbiddenOperationException('Invalid token.');
|
|
|
|
}
|
|
|
|
|
2016-09-01 10:31:43 +03:00
|
|
|
if ($accessToken->account->status === Account::STATUS_BANNED) {
|
|
|
|
throw new ForbiddenOperationException('This account has been suspended.');
|
|
|
|
}
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
$accessToken->refreshPrimaryKeyValue();
|
|
|
|
$accessToken->update();
|
|
|
|
|
|
|
|
$dataModel = new AuthenticateData($accessToken);
|
|
|
|
|
|
|
|
return $dataModel;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|