2010-11-18 13:46:34 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Zend Framework
|
|
|
|
*
|
|
|
|
* LICENSE
|
|
|
|
*
|
|
|
|
* This source file is subject to the new BSD license that is bundled
|
|
|
|
* with this package in the file LICENSE.txt.
|
|
|
|
* It is also available through the world-wide-web at this URL:
|
|
|
|
* http://framework.zend.com/license/new-bsd
|
|
|
|
* If you did not receive a copy of the license and are unable to
|
|
|
|
* obtain it through the world-wide-web, please send an email
|
|
|
|
* to license@zend.com so we can send you a copy immediately.
|
|
|
|
*
|
|
|
|
* @category Zend
|
|
|
|
* @package Zend_OpenId
|
|
|
|
* @subpackage Zend_OpenId_Consumer
|
2012-06-25 20:20:05 +00:00
|
|
|
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
|
2010-11-18 13:46:34 +00:00
|
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
2012-06-25 20:20:05 +00:00
|
|
|
* @version $Id: Storage.php 24594 2012-01-05 21:27:01Z matthew $
|
2010-11-18 13:46:34 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Abstract class to implement external storage for OpenID consumer
|
|
|
|
*
|
|
|
|
* @category Zend
|
|
|
|
* @package Zend_OpenId
|
|
|
|
* @subpackage Zend_OpenId_Consumer
|
2012-06-25 20:20:05 +00:00
|
|
|
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
|
2010-11-18 13:46:34 +00:00
|
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
|
|
*/
|
|
|
|
abstract class Zend_OpenId_Consumer_Storage
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores information about association identified by $url/$handle
|
|
|
|
*
|
|
|
|
* @param string $url OpenID server URL
|
|
|
|
* @param string $handle assiciation handle
|
|
|
|
* @param string $macFunc HMAC function (sha1 or sha256)
|
|
|
|
* @param string $secret shared secret
|
|
|
|
* @param long $expires expiration UNIX time
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
abstract public function addAssociation($url, $handle, $macFunc, $secret, $expires);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets information about association identified by $url
|
|
|
|
* Returns true if given association found and not expired and false
|
|
|
|
* otherwise
|
|
|
|
*
|
|
|
|
* @param string $url OpenID server URL
|
|
|
|
* @param string &$handle assiciation handle
|
|
|
|
* @param string &$macFunc HMAC function (sha1 or sha256)
|
|
|
|
* @param string &$secret shared secret
|
|
|
|
* @param long &$expires expiration UNIX time
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function getAssociation($url, &$handle, &$macFunc, &$secret, &$expires);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets information about association identified by $handle
|
|
|
|
* Returns true if given association found and not expired and false
|
|
|
|
* othverwise
|
|
|
|
*
|
|
|
|
* @param string $handle assiciation handle
|
|
|
|
* @param string &$url OpenID server URL
|
|
|
|
* @param string &$macFunc HMAC function (sha1 or sha256)
|
|
|
|
* @param string &$secret shared secret
|
|
|
|
* @param long &$expires expiration UNIX time
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function getAssociationByHandle($handle, &$url, &$macFunc, &$secret, &$expires);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deletes association identified by $url
|
|
|
|
*
|
|
|
|
* @param string $url OpenID server URL
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
abstract public function delAssociation($url);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores information discovered from identity $id
|
|
|
|
*
|
|
|
|
* @param string $id identity
|
|
|
|
* @param string $realId discovered real identity URL
|
|
|
|
* @param string $server discovered OpenID server URL
|
|
|
|
* @param float $version discovered OpenID protocol version
|
|
|
|
* @param long $expires expiration UNIX time
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
abstract public function addDiscoveryInfo($id, $realId, $server, $version, $expires);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets information discovered from identity $id
|
|
|
|
* Returns true if such information exists and false otherwise
|
|
|
|
*
|
|
|
|
* @param string $id identity
|
|
|
|
* @param string &$realId discovered real identity URL
|
|
|
|
* @param string &$server discovered OpenID server URL
|
|
|
|
* @param float &$version discovered OpenID protocol version
|
|
|
|
* @param long &$expires expiration UNIX time
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function getDiscoveryInfo($id, &$realId, &$server, &$version, &$expires);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes cached information discovered from identity $id
|
|
|
|
*
|
|
|
|
* @param string $id identity
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function delDiscoveryInfo($id);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The function checks the uniqueness of openid.response_nonce
|
|
|
|
*
|
|
|
|
* @param string $provider openid.openid_op_endpoint field from authentication response
|
|
|
|
* @param string $nonce openid.response_nonce field from authentication response
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function isUniqueNonce($provider, $nonce);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes data from the uniqueness database that is older then given date
|
|
|
|
*
|
|
|
|
* @param string $date Date of expired data
|
|
|
|
*/
|
|
|
|
abstract public function purgeNonces($date=null);
|
|
|
|
}
|