2017-09-19 20:06:16 +03:00
|
|
|
<?php
|
2019-04-06 04:15:23 +02:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
namespace api\components\User;
|
|
|
|
|
|
|
|
use common\models\Account;
|
|
|
|
|
|
|
|
interface IdentityInterface extends \yii\web\IdentityInterface {
|
|
|
|
|
2017-12-02 21:04:48 +03:00
|
|
|
/**
|
|
|
|
* @param string $token
|
|
|
|
* @param string $type
|
|
|
|
*
|
|
|
|
* @throws \yii\web\UnauthorizedHttpException
|
|
|
|
* @return IdentityInterface
|
|
|
|
*/
|
2019-04-06 04:15:23 +02:00
|
|
|
public static function findIdentityByAccessToken($token, $type = null): IdentityInterface;
|
2017-09-19 20:06:16 +03:00
|
|
|
|
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* This method is used to obtain a token to which scopes are attached.
|
|
|
|
* Our permissions are attached to tokens itself, so we return its id.
|
2017-09-19 20:06:16 +03:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getId(): string;
|
|
|
|
|
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* The method returns an account that is attached to the current token.
|
|
|
|
* But it's possible that the token was issued without binding to the account,
|
|
|
|
* so you should handle it.
|
2017-09-19 20:06:16 +03:00
|
|
|
*
|
|
|
|
* @return Account|null
|
|
|
|
*/
|
|
|
|
public function getAccount(): ?Account;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string[]
|
|
|
|
*/
|
|
|
|
public function getAssignedPermissions(): array;
|
|
|
|
|
|
|
|
}
|