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;
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								}
							 |