headers = new Requests_Response_Headers(); } /** * Response body * @var string */ public $body = ''; /** * Raw HTTP data from the transport * @var string */ public $raw = ''; /** * Headers, as an associative array * @var array */ public $headers = array(); /** * Status code, false if non-blocking * @var integer|boolean */ public $status_code = 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 */ public $cookies = array(); /** * 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->status_code >= 300 && $this->status_code < 400) { 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); } } }