4 Commits

2 changed files with 35 additions and 42 deletions

View File

@@ -4,16 +4,16 @@ declare(strict_types=1);
namespace Sept\OAuth2\Client\Provider; namespace Sept\OAuth2\Client\Provider;
use League\OAuth2\Client\Provider\AbstractProvider; use League\OAuth2\Client\Provider\Exception\IdentityProviderException;
use League\OAuth2\Client\Provider\GenericProvider;
use League\OAuth2\Client\Token\AccessToken; use League\OAuth2\Client\Token\AccessToken;
use League\OAuth2\Client\Tool\BearerAuthorizationTrait; use League\OAuth2\Client\Tool\BearerAuthorizationTrait;
use League\OAuth2\Client\Provider\Exception\IdentityProviderException;
use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ResponseInterface;
/** /**
* Провайдер данных Первого сентября * Провайдер данных Первого сентября
*/ */
class SeptemberFirstProvider extends AbstractProvider class SeptemberFirstProvider extends GenericProvider
{ {
use BearerAuthorizationTrait; use BearerAuthorizationTrait;
@@ -28,48 +28,41 @@ class SeptemberFirstProvider extends AbstractProvider
const API_BASE = 'https://api.1sept.ru'; const API_BASE = 'https://api.1sept.ru';
/** /**
* @var string Версия API * @var array Разрешения (scopes) по умолчанию
*/ */
const API_VERSION = '2.0'; const SCOPES_DEFAULT = ['profile'];
/** /**
* @inheritDoc * @var string Разделитель перечня запрашиваемых разрешений
*/ */
public function getBaseAuthorizationUrl(): string const SCOPES_SEPARATOR = ' ';
{
return static::AUTH_BASE.'/oauth/authorize';
}
/** /**
* @inheritDoc * @var string Путь авторизации
*/ */
public function getBaseAccessTokenUrl(array $params): string const AUTHORIZE_PATH = '/oauth/authorize';
{
return static::API_BASE.'/oauth/access_token';
}
/** /**
* @inheritDoc * @var string Путь получения токена
*/ */
public function getResourceOwnerDetailsUrl(AccessToken $token): string const ACCESS_TOKEN_PATH = '/oauth/access_token';
{
return static::API_BASE.'/'.static::API_VERSION.'/userinfo';
}
/** /**
* @inheritDoc * @var string Путь получения данных пользователя
*/ */
public function getDefaultScopes(): array const USERINFO_PATH = '/2.0/userinfo';
{
return ['profile'];
}
/** public function __construct(array $options = [], array $collaborators = [])
* @inheritDoc
*/
protected function getScopeSeparator(): string
{ {
return ' '; $defaultOptions = [
'urlAuthorize' => static::AUTH_BASE.static::AUTHORIZE_PATH,
'urlAccessToken' => static::API_BASE.static::ACCESS_TOKEN_PATH,
'urlResourceOwnerDetails' => static::API_BASE.static::USERINFO_PATH,
'scopes' => static::SCOPES_DEFAULT,
'scopeSeparator' => static::SCOPES_SEPARATOR,
];
parent::__construct(array_merge($defaultOptions, $options), $collaborators);
} }
/** /**
@@ -78,7 +71,7 @@ class SeptemberFirstProvider extends AbstractProvider
protected function checkResponse(ResponseInterface $response, $data): void protected function checkResponse(ResponseInterface $response, $data): void
{ {
if (! empty($data['error'])) { if (! empty($data['error'])) {
throw new IdentityProviderException($data['error'].': '.$data['message'], null, $response); throw new IdentityProviderException($data['error'].': '.$data['message'], 0, $response);
} }
} }

View File

@@ -158,14 +158,14 @@ class SeptemberFirstUser implements ResourceOwnerInterface
/** /**
* URL аватарки (150x150) * URL аватарки (150x150)
* *
* @param bool $addVersion Использовать версию аватарки для улучшенного кэширования * @param bool $rejectDefaultAvatar
* @return string|null * @return string|null
* *
* @example https://avatar.1sept.ru/12121212-3456-7243-2134-432432144221.jpeg?v=12345 * @example https://avatar.1sept.ru/12121212-3456-7243-2134-432432144221.jpeg?v=12345
*/ */
public function getAvatarUrl(bool $addVersion = true): ?string public function getAvatarUrl(bool $rejectDefaultAvatar = false): ?string
{ {
return $this->getField('avatar') . ($addVersion ? $this->getAvatarVersionQuery() : ''); return ($rejectDefaultAvatar && $this->isDefaultAvatar()) ? null : $this->getField('avatar');
} }
/** /**
@@ -224,9 +224,9 @@ class SeptemberFirstUser implements ResourceOwnerInterface
/** /**
* Является ли аватарка заглушкой * Является ли аватарка заглушкой
* *
* @return boolean * @return bool|null
*/ */
public function isDefaultAvatar(): bool public function isDefaultAvatar(): ?bool
{ {
return (bool) $this->getField('avatar_default'); return (bool) $this->getField('avatar_default');
} }
@@ -279,7 +279,7 @@ class SeptemberFirstUser implements ResourceOwnerInterface
* СНИЛС * СНИЛС
* *
* @return string|null * @return string|null
* @example 123-123-123 56 * @example 123-456-789 01
*/ */
public function getSnils(): ?string public function getSnils(): ?string
{ {