|  |  |  | <?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());
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 |