You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
4.6 KiB
191 lines
4.6 KiB
<?php |
|
/** |
|
* @link http://www.yiiframework.com/ |
|
* @copyright Copyright (c) 2008 Yii Software LLC |
|
* @license http://www.yiiframework.com/license/ |
|
*/ |
|
|
|
namespace yii\authclient; |
|
|
|
use yii\base\Object; |
|
|
|
/** |
|
* Token represents OAuth token. |
|
* |
|
* @property integer $expireDuration Token expiration duration. Note that the type of this property differs in |
|
* getter and setter. See [[getExpireDuration()]] and [[setExpireDuration()]] for details. |
|
* @property string $expireDurationParamKey Expire duration param key. |
|
* @property boolean $isExpired Is token expired. This property is read-only. |
|
* @property boolean $isValid Is token valid. This property is read-only. |
|
* @property array $params This property is read-only. |
|
* @property string $token Token value. |
|
* @property string $tokenSecret Token secret value. |
|
* |
|
* @author Paul Klimov <klimov.paul@gmail.com> |
|
* @since 2.0 |
|
*/ |
|
class OAuthToken extends Object |
|
{ |
|
/** |
|
* @var string key in {@link _params} array, which stores token key. |
|
*/ |
|
public $tokenParamKey = 'oauth_token'; |
|
/** |
|
* @var string key in {@link _params} array, which stores token secret key. |
|
*/ |
|
public $tokenSecretParamKey = 'oauth_token_secret'; |
|
/** |
|
* @var string key in {@link _params} array, which stores token expiration duration. |
|
* If not set will attempt to fetch its value automatically. |
|
*/ |
|
private $_expireDurationParamKey; |
|
/** |
|
* @var array token parameters. |
|
*/ |
|
private $_params = []; |
|
/** |
|
* @var integer object creation timestamp. |
|
*/ |
|
public $createTimestamp; |
|
|
|
public function init() |
|
{ |
|
if ($this->createTimestamp === null) { |
|
$this->createTimestamp = time(); |
|
} |
|
} |
|
|
|
/** |
|
* @param string $expireDurationParamKey expire duration param key. |
|
*/ |
|
public function setExpireDurationParamKey($expireDurationParamKey) { |
|
$this->_expireDurationParamKey = $expireDurationParamKey; |
|
} |
|
|
|
/** |
|
* @return string expire duration param key. |
|
*/ |
|
public function getExpireDurationParamKey() { |
|
if ($this->_expireDurationParamKey === null) { |
|
$this->_expireDurationParamKey = $this->defaultExpireDurationParamKey(); |
|
} |
|
return $this->_expireDurationParamKey; |
|
} |
|
|
|
/** |
|
* @return array |
|
*/ |
|
public function getParams() { |
|
return $this->_params; |
|
} |
|
|
|
/** |
|
* @param array $params |
|
*/ |
|
public function setParams(array $params) { |
|
$this->_params = $params; |
|
} |
|
|
|
/** |
|
* Sets param by name. |
|
* @param string $name param name. |
|
* @param mixed $value param value, |
|
*/ |
|
public function setParam($name, $value) { |
|
$this->_params[$name] = $value; |
|
} |
|
|
|
/** |
|
* Returns param by name. |
|
* @param string $name param name. |
|
* @return mixed param value. |
|
*/ |
|
public function getParam($name) { |
|
return isset($this->_params[$name]) ? $this->_params[$name] : null; |
|
} |
|
|
|
/** |
|
* Sets token value. |
|
* @param string $token token value. |
|
* @return static self reference. |
|
*/ |
|
public function setToken($token) { |
|
$this->setParam($this->tokenParamKey, $token); |
|
} |
|
|
|
/** |
|
* Returns token value. |
|
* @return string token value. |
|
*/ |
|
public function getToken() { |
|
return $this->getParam($this->tokenParamKey); |
|
} |
|
|
|
/** |
|
* Sets the token secret value. |
|
* @param string $tokenSecret token secret. |
|
*/ |
|
public function setTokenSecret($tokenSecret) { |
|
$this->setParam($this->tokenSecretParamKey, $tokenSecret); |
|
} |
|
|
|
/** |
|
* Returns the token secret value. |
|
* @return string token secret value. |
|
*/ |
|
public function getTokenSecret() { |
|
return $this->getParam($this->tokenSecretParamKey); |
|
} |
|
|
|
/** |
|
* Sets token expire duration. |
|
* @param string $expireDuration token expiration duration. |
|
*/ |
|
public function setExpireDuration($expireDuration) { |
|
$this->setParam($this->getExpireDurationParamKey(), $expireDuration); |
|
} |
|
|
|
/** |
|
* Returns the token expiration duration. |
|
* @return integer token expiration duration. |
|
*/ |
|
public function getExpireDuration() { |
|
return $this->getParam($this->getExpireDurationParamKey()); |
|
} |
|
|
|
/** |
|
* Fetches default expire duration param key. |
|
* @return string expire duration param key. |
|
*/ |
|
protected function defaultExpireDurationParamKey() { |
|
$expireDurationParamKey = 'expires_in'; |
|
foreach ($this->getParams() as $name => $value) { |
|
if (strpos($name, 'expir') !== false) { |
|
$expireDurationParamKey = $name; |
|
break; |
|
} |
|
} |
|
return $expireDurationParamKey; |
|
} |
|
|
|
/** |
|
* Checks if token has expired. |
|
* @return boolean is token expired. |
|
*/ |
|
public function getIsExpired() { |
|
$expirationDuration = $this->getExpireDuration(); |
|
if (empty($expirationDuration)) { |
|
return false; |
|
} |
|
return (time() >= ($this->createTimestamp + $expirationDuration)); |
|
} |
|
|
|
/** |
|
* Checks if token is valid. |
|
* @return boolean is token valid. |
|
*/ |
|
public function getIsValid() { |
|
$token = $this->getToken(); |
|
return (!empty($token) && !$this->getIsExpired()); |
|
} |
|
} |