mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-07 12:33:53 +05:30
Added refresh token TTL
This commit is contained in:
parent
9f90cd2635
commit
c77484e97b
@ -282,7 +282,8 @@ class AuthCode implements GrantTypeInterface {
|
|||||||
// Associate a refresh token if set
|
// Associate a refresh token if set
|
||||||
if ($this->authServer->hasGrantType('refresh_token')) {
|
if ($this->authServer->hasGrantType('refresh_token')) {
|
||||||
$refreshToken = SecureKey::make();
|
$refreshToken = SecureKey::make();
|
||||||
$this->authServer->getStorage('session')->associateRefreshToken($accessTokenId, $refreshToken);
|
$refreshTokenTTL = time() + $this->authServer->getGrantType('refresh_token')->getRefreshTokenTTL();
|
||||||
|
$this->authServer->getStorage('session')->associateRefreshToken($accessTokenId, $refreshToken, $refreshTokenTTL);
|
||||||
$response['refresh_token'] = $refreshToken;
|
$response['refresh_token'] = $refreshToken;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,7 +212,8 @@ class Password implements GrantTypeInterface {
|
|||||||
// Associate a refresh token if set
|
// Associate a refresh token if set
|
||||||
if ($this->authServer->hasGrantType('refresh_token')) {
|
if ($this->authServer->hasGrantType('refresh_token')) {
|
||||||
$refreshToken = SecureKey::make();
|
$refreshToken = SecureKey::make();
|
||||||
$this->authServer->getStorage('session')->associateRefreshToken($accessTokenId, $refreshToken);
|
$refreshTokenTTL = time() + $this->authServer->getGrantType('refresh_token')->getRefreshTokenTTL();
|
||||||
|
$this->authServer->getStorage('session')->associateRefreshToken($accessTokenId, $refreshToken, $refreshTokenTTL);
|
||||||
$response['refresh_token'] = $refreshToken;
|
$response['refresh_token'] = $refreshToken;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,6 +48,12 @@ class RefreshToken implements GrantTypeInterface {
|
|||||||
*/
|
*/
|
||||||
protected $accessTokenTTL = null;
|
protected $accessTokenTTL = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Refresh token TTL
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
protected $refreshTokenTTL = 604800;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
* @param AuthServer $authServer AuthServer instance
|
* @param AuthServer $authServer AuthServer instance
|
||||||
@ -86,6 +92,25 @@ class RefreshToken implements GrantTypeInterface {
|
|||||||
$this->accessTokenTTL = $accessTokenTTL;
|
$this->accessTokenTTL = $accessTokenTTL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the TTL of the refresh token
|
||||||
|
* @param int $refreshTokenTTL
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setRefreshTokenTTL($refreshTokenTTL)
|
||||||
|
{
|
||||||
|
$this->refreshTokenTTL = $refreshTokenTTL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the TTL of the refresh token
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
public function getRefreshTokenTTL()
|
||||||
|
{
|
||||||
|
return $this->refreshTokenTTL;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Complete the refresh token grant
|
* Complete the refresh token grant
|
||||||
* @param null|array $inputParams
|
* @param null|array $inputParams
|
||||||
@ -135,6 +160,7 @@ class RefreshToken implements GrantTypeInterface {
|
|||||||
$accessTokenExpiresIn = ($this->accessTokenTTL !== null) ? $this->accessTokenTTL : $this->authServer->getExpiresIn();
|
$accessTokenExpiresIn = ($this->accessTokenTTL !== null) ? $this->accessTokenTTL : $this->authServer->getExpiresIn();
|
||||||
$accessTokenExpires = time() + $accessTokenExpiresIn;
|
$accessTokenExpires = time() + $accessTokenExpiresIn;
|
||||||
$refreshToken = SecureKey::make();
|
$refreshToken = SecureKey::make();
|
||||||
|
$refreshTokenExpires = time() + $this->getRefreshTokenTTL();
|
||||||
|
|
||||||
$newAccessTokenId = $this->authServer->getStorage('session')->associateAccessToken($accessTokenDetails['session_id'], $accessToken, $accessTokenExpires);
|
$newAccessTokenId = $this->authServer->getStorage('session')->associateAccessToken($accessTokenDetails['session_id'], $accessToken, $accessTokenExpires);
|
||||||
|
|
||||||
@ -142,7 +168,7 @@ class RefreshToken implements GrantTypeInterface {
|
|||||||
$this->authServer->getStorage('session')->associateScope($newAccessTokenId, $scope['id']);
|
$this->authServer->getStorage('session')->associateScope($newAccessTokenId, $scope['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->authServer->getStorage('session')->associateRefreshToken($newAccessTokenId, $refreshToken);
|
$this->authServer->getStorage('session')->associateRefreshToken($newAccessTokenId, $refreshToken, $refreshTokenExpires);
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'access_token' => $accessToken,
|
'access_token' => $accessToken,
|
||||||
|
@ -59,9 +59,10 @@ interface SessionInterface
|
|||||||
* Associate a refresh token with a session
|
* Associate a refresh token with a session
|
||||||
* @param int $accessTokenId The access token ID
|
* @param int $accessTokenId The access token ID
|
||||||
* @param string $refreshToken The refresh token
|
* @param string $refreshToken The refresh token
|
||||||
|
* @param int $expireTime Unix timestamp of the refresh token expiry time
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function associateRefreshToken($accessTokenId, $refreshToken);
|
public function associateRefreshToken($accessTokenId, $refreshToken, $expireTime);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Assocate an authorization code with a session
|
* Assocate an authorization code with a session
|
||||||
|
Loading…
Reference in New Issue
Block a user