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