89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
/**
 | 
						|
 * Basic Authentication provider
 | 
						|
 *
 | 
						|
 * @package Requests
 | 
						|
 * @subpackage Authentication
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * Basic Authentication provider
 | 
						|
 *
 | 
						|
 * Provides a handler for Basic HTTP authentication via the Authorization
 | 
						|
 * header.
 | 
						|
 *
 | 
						|
 * @package Requests
 | 
						|
 * @subpackage Authentication
 | 
						|
 */
 | 
						|
class Requests_Auth_Basic implements Requests_Auth {
 | 
						|
	/**
 | 
						|
	 * Username
 | 
						|
	 *
 | 
						|
	 * @var string
 | 
						|
	 */
 | 
						|
	public $user;
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Password
 | 
						|
	 *
 | 
						|
	 * @var string
 | 
						|
	 */
 | 
						|
	public $pass;
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Constructor
 | 
						|
	 *
 | 
						|
	 * @throws Requests_Exception On incorrect number of arguments (`authbasicbadargs`)
 | 
						|
	 * @param array|null $args Array of user and password. Must have exactly two elements
 | 
						|
	 */
 | 
						|
	public function __construct($args = null) {
 | 
						|
		if (is_array($args)) {
 | 
						|
			if (count($args) !== 2) {
 | 
						|
				throw new Requests_Exception('Invalid number of arguments', 'authbasicbadargs');
 | 
						|
			}
 | 
						|
 | 
						|
			list($this->user, $this->pass) = $args;
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Register the necessary callbacks
 | 
						|
	 *
 | 
						|
	 * @see curl_before_send
 | 
						|
	 * @see fsockopen_header
 | 
						|
	 * @param Requests_Hooks $hooks Hook system
 | 
						|
	 */
 | 
						|
	public function register(Requests_Hooks $hooks) {
 | 
						|
		$hooks->register('curl.before_send', array($this, 'curl_before_send'));
 | 
						|
		$hooks->register('fsockopen.after_headers', array($this, 'fsockopen_header'));
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set cURL parameters before the data is sent
 | 
						|
	 *
 | 
						|
	 * @param resource $handle cURL resource
 | 
						|
	 */
 | 
						|
	public function curl_before_send(&$handle) {
 | 
						|
		curl_setopt($handle, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
 | 
						|
		curl_setopt($handle, CURLOPT_USERPWD, $this->getAuthString());
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Add extra headers to the request before sending
 | 
						|
	 *
 | 
						|
	 * @param string $out HTTP header string
 | 
						|
	 */
 | 
						|
	public function fsockopen_header(&$out) {
 | 
						|
		$out .= sprintf("Authorization: Basic %s\r\n", base64_encode($this->getAuthString()));
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Get the authentication string (user:pass)
 | 
						|
	 *
 | 
						|
	 * @return string
 | 
						|
	 */
 | 
						|
	public function getAuthString() {
 | 
						|
		return $this->user . ':' . $this->pass;
 | 
						|
	}
 | 
						|
}
 |