Файл: library/Sabre/Sabre/HTTP/Response.php
Строк: 95
<?php
/**
* Sabre_HTTP_Response
*
* @package Sabre
* @subpackage HTTP
* @version $Id$
* @copyright Copyright (C) 2007-2010 Rooftop Solutions. All rights reserved.
* @author Evert Pot (http://www.rooftopsolutions.nl/)
* @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
*/
class Sabre_HTTP_Response {
/**
* Returns a full HTTP status message for an HTTP status code
*
* @param int $code
* @return string
*/
public function getStatusMessage($code) {
$msg = array(
100 => 'Continue',
101 => 'Switching Protocols',
200 => 'Ok',
201 => 'Created',
202 => 'Accepted',
203 => 'Non-Authorative Information',
204 => 'No Content',
205 => 'Reset Content',
206 => 'Partial Content',
207 => 'Multi-Status', // RFC 4918
300 => 'Multiple Choices',
301 => 'Moved Permanently',
302 => 'Found',
303 => 'See Other',
304 => 'Not Modified',
305 => 'Use Proxy',
307 => 'Temporary Redirect',
400 => 'Bad request',
401 => 'Unauthorized',
402 => 'Payment Required',
403 => 'Forbidden',
404 => 'Not Found',
405 => 'Method Not Allowed',
406 => 'Not Acceptable',
407 => 'Proxy Authentication Required',
408 => 'Request Timeout',
409 => 'Conflict',
410 => 'Gone',
411 => 'Length Required',
412 => 'Precondition failed',
413 => 'Request Entity Too Large',
414 => 'Request-URI Too Long',
415 => 'Unsupported Media Type',
416 => 'Requested Range Not Satisfiable',
417 => 'Expectation Failed',
418 => 'I'm a teapot', // RFC 2324
422 => 'Unprocessable Entity', // RFC 4918
423 => 'Locked', // RFC 4918
424 => 'Failed Dependency', // RFC 4918
500 => 'Internal Server Error',
501 => 'Not Implemented',
502 => 'Bad Gateway',
503 => 'Service Unavailable',
504 => 'Gateway Timeout',
505 => 'HTTP Version not supported',
507 => 'Unsufficient Storage', // RFC 4918
);
return 'HTTP/1.1 ' . $code . ' ' . $msg[$code];
}
/**
* Sends an HTTP status header to the client
*
* @param int $code HTTP status code
* @return void
*/
public function sendStatus($code) {
header($this->getStatusMessage($code));
}
/**
* Sets an HTTP header for the response
*
* @param string $name
* @param string $value
* @return void
*/
public function setHeader($name, $value, $replace = true) {
$value = str_replace(array("r","n"),array('r','n'),$value);
header($name . ': ' . $value, $replace);
}
/**
* Sends the entire response body
*
* This method can accept either an open filestream, or a string.
* Note that this method will first rewind the stream before output.
*
* @param mixed $body
* @return void
*/
public function sendBody($body) {
if (is_resource($body)) {
rewind($body);
fpassthru($body);
} else {
// We assume a string
echo $body;
}
}
}