100 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			100 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|   | <?php | ||
|  | 
 | ||
|  | /** | ||
|  |  * This file supplies a dumb store backend for OpenID servers and | ||
|  |  * consumers. | ||
|  |  * | ||
|  |  * PHP versions 4 and 5 | ||
|  |  * | ||
|  |  * LICENSE: See the COPYING file included in this distribution. | ||
|  |  * | ||
|  |  * @package OpenID | ||
|  |  * @author JanRain, Inc. <openid@janrain.com> | ||
|  |  * @copyright 2005-2008 Janrain, Inc. | ||
|  |  * @license http://www.apache.org/licenses/LICENSE-2.0 Apache | ||
|  |  */ | ||
|  | 
 | ||
|  | /** | ||
|  |  * Import the interface for creating a new store class. | ||
|  |  */ | ||
|  | require_once 'Auth/OpenID/Interface.php'; | ||
|  | require_once 'Auth/OpenID/HMAC.php'; | ||
|  | 
 | ||
|  | /** | ||
|  |  * This is a store for use in the worst case, when you have no way of | ||
|  |  * saving state on the consumer site. Using this store makes the | ||
|  |  * consumer vulnerable to replay attacks, as it's unable to use | ||
|  |  * nonces. Avoid using this store if it is at all possible. | ||
|  |  * | ||
|  |  * Most of the methods of this class are implementation details. | ||
|  |  * Users of this class need to worry only about the constructor. | ||
|  |  * | ||
|  |  * @package OpenID | ||
|  |  */ | ||
|  | class Auth_OpenID_DumbStore extends Auth_OpenID_OpenIDStore { | ||
|  | 
 | ||
|  |     /** | ||
|  |      * Creates a new {@link Auth_OpenID_DumbStore} instance. For the security | ||
|  |      * of the tokens generated by the library, this class attempts to | ||
|  |      * at least have a secure implementation of getAuthKey. | ||
|  |      * | ||
|  |      * When you create an instance of this class, pass in a secret | ||
|  |      * phrase. The phrase is hashed with sha1 to make it the correct | ||
|  |      * length and form for an auth key. That allows you to use a long | ||
|  |      * string as the secret phrase, which means you can make it very | ||
|  |      * difficult to guess. | ||
|  |      * | ||
|  |      * Each {@link Auth_OpenID_DumbStore} instance that is created for use by | ||
|  |      * your consumer site needs to use the same $secret_phrase. | ||
|  |      * | ||
|  |      * @param string secret_phrase The phrase used to create the auth | ||
|  |      * key returned by getAuthKey | ||
|  |      */ | ||
|  |     function Auth_OpenID_DumbStore($secret_phrase) | ||
|  |     { | ||
|  |         $this->auth_key = Auth_OpenID_SHA1($secret_phrase); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * This implementation does nothing. | ||
|  |      */ | ||
|  |     function storeAssociation($server_url, $association) | ||
|  |     { | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * This implementation always returns null. | ||
|  |      */ | ||
|  |     function getAssociation($server_url, $handle = null) | ||
|  |     { | ||
|  |         return null; | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * This implementation always returns false. | ||
|  |      */ | ||
|  |     function removeAssociation($server_url, $handle) | ||
|  |     { | ||
|  |         return false; | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * In a system truly limited to dumb mode, nonces must all be | ||
|  |      * accepted. This therefore always returns true, which makes | ||
|  |      * replay attacks feasible. | ||
|  |      */ | ||
|  |     function useNonce($server_url, $timestamp, $salt) | ||
|  |     { | ||
|  |         return true; | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * This method returns the auth key generated by the constructor. | ||
|  |      */ | ||
|  |     function getAuthKey() | ||
|  |     { | ||
|  |         return $this->auth_key; | ||
|  |     } | ||
|  | } | ||
|  | 
 |