2019-08-01 12:17:12 +03:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace api\components\User;
|
|
|
|
|
|
|
|
use yii\web\UnauthorizedHttpException;
|
|
|
|
|
|
|
|
class IdentityFactory {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @throws UnauthorizedHttpException
|
|
|
|
* @return IdentityInterface
|
|
|
|
*/
|
|
|
|
public static function findIdentityByAccessToken($token, $type = null): IdentityInterface {
|
|
|
|
if (empty($token)) {
|
|
|
|
throw new UnauthorizedHttpException('Incorrect token');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (substr_count($token, '.') === 2) {
|
|
|
|
return JwtIdentity::findIdentityByAccessToken($token, $type);
|
|
|
|
}
|
|
|
|
|
2019-08-02 18:32:08 +03:00
|
|
|
return OAuth2Identity::findIdentityByAccessToken($token, $type);
|
2019-08-01 12:17:12 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|