| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 | <?php/** * HTTP response class * * Contains a response from Requests::request() * @package Requests *//** * HTTP response class * * Contains a response from Requests::request() * @package Requests */class Requests_Response {	/**	 * Constructor	 */	public function __construct() {		$this->headers = new Requests_Response_Headers();		$this->cookies = new Requests_Cookie_Jar();	}	/**	 * Response body	 *	 * @var string	 */	public $body = '';	/**	 * Raw HTTP data from the transport	 *	 * @var string	 */	public $raw = '';	/**	 * Headers, as an associative array	 *	 * @var Requests_Response_Headers Array-like object representing headers	 */	public $headers = array();	/**	 * Status code, false if non-blocking	 *	 * @var integer|boolean	 */	public $status_code = false;	/**	 * Protocol version, false if non-blocking	 * @var float|boolean	 */	public $protocol_version = false;	/**	 * Whether the request succeeded or not	 *	 * @var boolean	 */	public $success = false;	/**	 * Number of redirects the request used	 *	 * @var integer	 */	public $redirects = 0;	/**	 * URL requested	 *	 * @var string	 */	public $url = '';	/**	 * Previous requests (from redirects)	 *	 * @var array Array of Requests_Response objects	 */	public $history = array();	/**	 * Cookies from the request	 *	 * @var Requests_Cookie_Jar Array-like object representing a cookie jar	 */	public $cookies = array();	/**	 * Is the response a redirect?	 *	 * @return boolean True if redirect (3xx status), false if not.	 */	public function is_redirect() {		$code = $this->status_code;		return in_array($code, array(300, 301, 302, 303, 307)) || $code > 307 && $code < 400;	}	/**	 * Throws an exception if the request was not successful	 *	 * @throws Requests_Exception If `$allow_redirects` is false, and code is 3xx (`response.no_redirects`)	 * @throws Requests_Exception_HTTP On non-successful status code. Exception class corresponds to code (e.g. {@see Requests_Exception_HTTP_404})	 * @param boolean $allow_redirects Set to false to throw on a 3xx as well	 */	public function throw_for_status($allow_redirects = true) {		if ($this->is_redirect()) {			if (!$allow_redirects) {				throw new Requests_Exception('Redirection not allowed', 'response.no_redirects', $this);			}		}		elseif (!$this->success) {			$exception = Requests_Exception_HTTP::get_class($this->status_code);			throw new $exception(null, $this);		}	}}
 |