2016-02-14 20:50:10 +03:00
|
|
|
<?php
|
2016-11-27 00:43:42 +03:00
|
|
|
namespace api\components\OAuth2;
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2017-06-17 21:05:36 +03:00
|
|
|
use api\components\OAuth2\Storage;
|
2016-02-14 20:50:10 +03:00
|
|
|
use League\OAuth2\Server\AuthorizationServer;
|
2017-09-19 20:06:16 +03:00
|
|
|
use League\OAuth2\Server\Storage\AccessTokenInterface;
|
|
|
|
use League\OAuth2\Server\Storage\RefreshTokenInterface;
|
|
|
|
use League\OAuth2\Server\Storage\SessionInterface;
|
2017-06-17 21:05:36 +03:00
|
|
|
use yii\base\Component as BaseComponent;
|
2016-02-14 20:50:10 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @property AuthorizationServer $authServer
|
|
|
|
*/
|
2017-06-17 21:05:36 +03:00
|
|
|
class Component extends BaseComponent {
|
2016-02-14 20:50:10 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var AuthorizationServer
|
|
|
|
*/
|
|
|
|
private $_authServer;
|
|
|
|
|
2017-06-17 21:05:36 +03:00
|
|
|
public function getAuthServer(): AuthorizationServer {
|
2016-02-14 20:50:10 +03:00
|
|
|
if ($this->_authServer === null) {
|
|
|
|
$authServer = new AuthorizationServer();
|
2017-06-17 21:05:36 +03:00
|
|
|
$authServer->setAccessTokenStorage(new Storage\AccessTokenStorage());
|
|
|
|
$authServer->setClientStorage(new Storage\ClientStorage());
|
|
|
|
$authServer->setScopeStorage(new Storage\ScopeStorage());
|
|
|
|
$authServer->setSessionStorage(new Storage\SessionStorage());
|
|
|
|
$authServer->setAuthCodeStorage(new Storage\AuthCodeStorage());
|
|
|
|
$authServer->setRefreshTokenStorage(new Storage\RefreshTokenStorage());
|
2017-03-07 19:09:41 +03:00
|
|
|
$authServer->setAccessTokenTTL(86400); // 1d
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2017-06-17 21:05:36 +03:00
|
|
|
$authServer->addGrantType(new Grants\AuthCodeGrant());
|
|
|
|
$authServer->addGrantType(new Grants\RefreshTokenGrant());
|
|
|
|
$authServer->addGrantType(new Grants\ClientCredentialsGrant());
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2017-06-17 21:05:36 +03:00
|
|
|
$this->_authServer = $authServer;
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return $this->_authServer;
|
|
|
|
}
|
|
|
|
|
2017-09-19 20:06:16 +03:00
|
|
|
public function getAccessTokenStorage(): AccessTokenInterface {
|
|
|
|
return $this->getAuthServer()->getAccessTokenStorage();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRefreshTokenStorage(): RefreshTokenInterface {
|
|
|
|
return $this->getAuthServer()->getRefreshTokenStorage();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSessionStorage(): SessionInterface {
|
|
|
|
return $this->getAuthServer()->getSessionStorage();
|
|
|
|
}
|
|
|
|
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|