2016-02-14 20:50:10 +03:00
|
|
|
<?php
|
|
|
|
namespace common\models;
|
|
|
|
|
2016-11-27 17:41:39 +03:00
|
|
|
use common\components\Redis\Set;
|
2016-11-30 02:19:14 +03:00
|
|
|
use Yii;
|
2017-09-19 20:06:16 +03:00
|
|
|
use yii\base\NotSupportedException;
|
2018-02-28 01:27:35 +03:00
|
|
|
use yii\behaviors\TimestampBehavior;
|
2017-09-19 20:06:16 +03:00
|
|
|
use yii\db\ActiveQuery;
|
2016-02-14 20:50:10 +03:00
|
|
|
use yii\db\ActiveRecord;
|
|
|
|
|
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* Fields:
|
2016-11-30 12:19:10 +03:00
|
|
|
* @property integer $id
|
2019-07-15 01:59:56 +03:00
|
|
|
* @property string $owner_type contains one of the OauthOwnerType constants
|
2017-09-19 20:06:16 +03:00
|
|
|
* @property string|null $owner_id
|
2016-11-30 12:19:10 +03:00
|
|
|
* @property string $client_id
|
|
|
|
* @property string $client_redirect_uri
|
2018-02-28 01:27:35 +03:00
|
|
|
* @property integer $created_at
|
2016-02-14 20:50:10 +03:00
|
|
|
*
|
2019-07-15 01:59:56 +03:00
|
|
|
* Relations:
|
2016-11-30 12:19:10 +03:00
|
|
|
* @property OauthClient $client
|
|
|
|
* @property Account $account
|
|
|
|
* @property Set $scopes
|
2016-02-14 20:50:10 +03:00
|
|
|
*/
|
|
|
|
class OauthSession extends ActiveRecord {
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public static function tableName(): string {
|
2016-02-14 20:50:10 +03:00
|
|
|
return '{{%oauth_sessions}}';
|
|
|
|
}
|
|
|
|
|
2019-08-08 02:47:36 +03:00
|
|
|
public static function find(): OauthSessionQuery {
|
|
|
|
return new OauthSessionQuery(static::class);
|
|
|
|
}
|
|
|
|
|
2018-02-28 01:27:35 +03:00
|
|
|
public function behaviors() {
|
|
|
|
return [
|
|
|
|
[
|
|
|
|
'class' => TimestampBehavior::class,
|
|
|
|
'updatedAtAttribute' => false,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function getClient(): ActiveQuery {
|
2016-02-14 20:50:10 +03:00
|
|
|
return $this->hasOne(OauthClient::class, ['id' => 'client_id']);
|
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function getAccount(): ActiveQuery {
|
2016-02-14 20:50:10 +03:00
|
|
|
return $this->hasOne(Account::class, ['id' => 'owner_id']);
|
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function getScopes(): Set {
|
2016-11-01 19:36:39 +03:00
|
|
|
return new Set(static::getDb()->getSchema()->getRawTableName(static::tableName()), $this->id, 'scopes');
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function getAccessTokens() {
|
|
|
|
throw new NotSupportedException('This method is possible, but not implemented');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function beforeDelete(): bool {
|
2016-02-14 20:50:10 +03:00
|
|
|
if (!$result = parent::beforeDelete()) {
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
$this->clearScopes();
|
|
|
|
$this->removeRefreshToken();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function removeRefreshToken(): void {
|
2019-08-23 11:28:04 +03:00
|
|
|
/** @var \api\components\OAuth2\Repositories\RefreshTokenStorage $refreshTokensStorage */
|
|
|
|
// TODO: rework
|
2017-09-19 20:06:16 +03:00
|
|
|
$refreshTokensStorage = Yii::$app->oauth->getRefreshTokenStorage();
|
2016-11-30 02:19:14 +03:00
|
|
|
$refreshTokensSet = $refreshTokensStorage->sessionHash($this->id);
|
|
|
|
foreach ($refreshTokensSet->members() as $refreshTokenId) {
|
|
|
|
$refreshTokensStorage->delete($refreshTokensStorage->get($refreshTokenId));
|
|
|
|
}
|
|
|
|
|
|
|
|
$refreshTokensSet->delete();
|
2017-09-19 20:06:16 +03:00
|
|
|
}
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function clearScopes(): void {
|
|
|
|
$this->getScopes()->delete();
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|