2010-07-29 05:24:16 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* A class reposible for managing the response text, status and headers of a HTTP response
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* PHP 5
|
|
|
|
*
|
|
|
|
* CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
|
|
|
|
* Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
|
|
*
|
|
|
|
* Licensed under The MIT License
|
|
|
|
* Redistributions of files must retain the above copyright notice.
|
|
|
|
*
|
|
|
|
* @copyright Copyright 2005-2010, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
|
|
* @link http://cakephp.org CakePHP(tm) Project
|
|
|
|
* @package cake
|
|
|
|
* @subpackage cake.cake.libs
|
|
|
|
* @since CakePHP(tm) v 2.0
|
|
|
|
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
|
|
|
*/
|
|
|
|
|
|
|
|
class CakeResponse {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Holds HTTP response statuses
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $_statusCodes = array(
|
|
|
|
100 => 'Continue',
|
|
|
|
101 => 'Switching Protocols',
|
|
|
|
200 => 'OK',
|
|
|
|
201 => 'Created',
|
|
|
|
202 => 'Accepted',
|
|
|
|
203 => 'Non-Authoritative Information',
|
|
|
|
204 => 'No Content',
|
|
|
|
205 => 'Reset Content',
|
|
|
|
206 => 'Partial Content',
|
|
|
|
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 Time-out',
|
|
|
|
409 => 'Conflict',
|
|
|
|
410 => 'Gone',
|
|
|
|
411 => 'Length Required',
|
|
|
|
412 => 'Precondition Failed',
|
|
|
|
413 => 'Request Entity Too Large',
|
|
|
|
414 => 'Request-URI Too Large',
|
|
|
|
415 => 'Unsupported Media Type',
|
|
|
|
416 => 'Requested range not satisfiable',
|
|
|
|
417 => 'Expectation Failed',
|
|
|
|
500 => 'Internal Server Error',
|
|
|
|
501 => 'Not Implemented',
|
|
|
|
502 => 'Bad Gateway',
|
|
|
|
503 => 'Service Unavailable',
|
|
|
|
504 => 'Gateway Time-out'
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Holds known mime type mappings
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $_mimeTypes = array(
|
|
|
|
'ai' => 'application/postscript', 'bcpio' => 'application/x-bcpio', 'bin' => 'application/octet-stream',
|
|
|
|
'ccad' => 'application/clariscad', 'cdf' => 'application/x-netcdf', 'class' => 'application/octet-stream',
|
|
|
|
'cpio' => 'application/x-cpio', 'cpt' => 'application/mac-compactpro', 'csh' => 'application/x-csh',
|
|
|
|
'csv' => 'application/csv', 'dcr' => 'application/x-director', 'dir' => 'application/x-director',
|
|
|
|
'dms' => 'application/octet-stream', 'doc' => 'application/msword', 'drw' => 'application/drafting',
|
|
|
|
'dvi' => 'application/x-dvi', 'dwg' => 'application/acad', 'dxf' => 'application/dxf',
|
|
|
|
'dxr' => 'application/x-director', 'eot' => 'application/vnd.ms-fontobject', 'eps' => 'application/postscript',
|
|
|
|
'exe' => 'application/octet-stream', 'ez' => 'application/andrew-inset',
|
|
|
|
'flv' => 'video/x-flv', 'gtar' => 'application/x-gtar', 'gz' => 'application/x-gzip',
|
|
|
|
'bz2' => 'application/x-bzip', '7z' => 'application/x-7z-compressed', 'hdf' => 'application/x-hdf',
|
|
|
|
'hqx' => 'application/mac-binhex40', 'ico' => 'image/vnd.microsoft.icon', 'ips' => 'application/x-ipscript',
|
|
|
|
'ipx' => 'application/x-ipix', 'js' => 'application/x-javascript', 'latex' => 'application/x-latex',
|
|
|
|
'lha' => 'application/octet-stream', 'lsp' => 'application/x-lisp', 'lzh' => 'application/octet-stream',
|
|
|
|
'man' => 'application/x-troff-man', 'me' => 'application/x-troff-me', 'mif' => 'application/vnd.mif',
|
|
|
|
'ms' => 'application/x-troff-ms', 'nc' => 'application/x-netcdf', 'oda' => 'application/oda',
|
|
|
|
'otf' => 'font/otf', 'pdf' => 'application/pdf',
|
|
|
|
'pgn' => 'application/x-chess-pgn', 'pot' => 'application/mspowerpoint', 'pps' => 'application/mspowerpoint',
|
|
|
|
'ppt' => 'application/mspowerpoint', 'ppz' => 'application/mspowerpoint', 'pre' => 'application/x-freelance',
|
|
|
|
'prt' => 'application/pro_eng', 'ps' => 'application/postscript', 'roff' => 'application/x-troff',
|
|
|
|
'scm' => 'application/x-lotusscreencam', 'set' => 'application/set', 'sh' => 'application/x-sh',
|
|
|
|
'shar' => 'application/x-shar', 'sit' => 'application/x-stuffit', 'skd' => 'application/x-koan',
|
|
|
|
'skm' => 'application/x-koan', 'skp' => 'application/x-koan', 'skt' => 'application/x-koan',
|
|
|
|
'smi' => 'application/smil', 'smil' => 'application/smil', 'sol' => 'application/solids',
|
|
|
|
'spl' => 'application/x-futuresplash', 'src' => 'application/x-wais-source', 'step' => 'application/STEP',
|
|
|
|
'stl' => 'application/SLA', 'stp' => 'application/STEP', 'sv4cpio' => 'application/x-sv4cpio',
|
|
|
|
'sv4crc' => 'application/x-sv4crc', 'svg' => 'image/svg+xml', 'svgz' => 'image/svg+xml',
|
|
|
|
'swf' => 'application/x-shockwave-flash', 't' => 'application/x-troff',
|
|
|
|
'tar' => 'application/x-tar', 'tcl' => 'application/x-tcl', 'tex' => 'application/x-tex',
|
|
|
|
'texi' => 'application/x-texinfo', 'texinfo' => 'application/x-texinfo', 'tr' => 'application/x-troff',
|
|
|
|
'tsp' => 'application/dsptype', 'ttf' => 'font/ttf',
|
|
|
|
'unv' => 'application/i-deas', 'ustar' => 'application/x-ustar',
|
|
|
|
'vcd' => 'application/x-cdlink', 'vda' => 'application/vda', 'xlc' => 'application/vnd.ms-excel',
|
|
|
|
'xll' => 'application/vnd.ms-excel', 'xlm' => 'application/vnd.ms-excel', 'xls' => 'application/vnd.ms-excel',
|
|
|
|
'xlw' => 'application/vnd.ms-excel', 'zip' => 'application/zip', 'aif' => 'audio/x-aiff', 'aifc' => 'audio/x-aiff',
|
|
|
|
'aiff' => 'audio/x-aiff', 'au' => 'audio/basic', 'kar' => 'audio/midi', 'mid' => 'audio/midi',
|
|
|
|
'midi' => 'audio/midi', 'mp2' => 'audio/mpeg', 'mp3' => 'audio/mpeg', 'mpga' => 'audio/mpeg',
|
|
|
|
'ra' => 'audio/x-realaudio', 'ram' => 'audio/x-pn-realaudio', 'rm' => 'audio/x-pn-realaudio',
|
|
|
|
'rpm' => 'audio/x-pn-realaudio-plugin', 'snd' => 'audio/basic', 'tsi' => 'audio/TSP-audio', 'wav' => 'audio/x-wav',
|
|
|
|
'asc' => 'text/plain', 'c' => 'text/plain', 'cc' => 'text/plain', 'css' => 'text/css', 'etx' => 'text/x-setext',
|
|
|
|
'f' => 'text/plain', 'f90' => 'text/plain', 'h' => 'text/plain', 'hh' => 'text/plain', 'htm' => 'text/html',
|
|
|
|
'html' => 'text/html', 'm' => 'text/plain', 'rtf' => 'text/rtf', 'rtx' => 'text/richtext', 'sgm' => 'text/sgml',
|
|
|
|
'sgml' => 'text/sgml', 'tsv' => 'text/tab-separated-values', 'tpl' => 'text/template', 'txt' => 'text/plain',
|
|
|
|
'xml' => 'text/xml', 'avi' => 'video/x-msvideo', 'fli' => 'video/x-fli', 'mov' => 'video/quicktime',
|
|
|
|
'movie' => 'video/x-sgi-movie', 'mpe' => 'video/mpeg', 'mpeg' => 'video/mpeg', 'mpg' => 'video/mpeg',
|
|
|
|
'qt' => 'video/quicktime', 'viv' => 'video/vnd.vivo', 'vivo' => 'video/vnd.vivo', 'gif' => 'image/gif',
|
|
|
|
'ief' => 'image/ief', 'jpe' => 'image/jpeg', 'jpeg' => 'image/jpeg', 'jpg' => 'image/jpeg',
|
|
|
|
'pbm' => 'image/x-portable-bitmap', 'pgm' => 'image/x-portable-graymap', 'png' => 'image/png',
|
|
|
|
'pnm' => 'image/x-portable-anymap', 'ppm' => 'image/x-portable-pixmap', 'ras' => 'image/cmu-raster',
|
|
|
|
'rgb' => 'image/x-rgb', 'tif' => 'image/tiff', 'tiff' => 'image/tiff', 'xbm' => 'image/x-xbitmap',
|
|
|
|
'xpm' => 'image/x-xpixmap', 'xwd' => 'image/x-xwindowdump', 'ice' => 'x-conference/x-cooltalk',
|
|
|
|
'iges' => 'model/iges', 'igs' => 'model/iges', 'mesh' => 'model/mesh', 'msh' => 'model/mesh',
|
|
|
|
'silo' => 'model/mesh', 'vrml' => 'model/vrml', 'wrl' => 'model/vrml',
|
|
|
|
'mime' => 'www/mime', 'pdb' => 'chemical/x-pdb', 'xyz' => 'chemical/x-pdb'
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Protocol header to send to the client
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $_protocol = 'HTTP/1.1';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Status code to send to the client
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $_status = 200;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Content type to send. This can be an 'extension' that will be transformed using the $_mimetypes array
|
|
|
|
* or a complete mime-type
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $_contetType = 'html';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Buffer list of headers
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $_headers = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Buffer string for response message
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $_body = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encoding string to send
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $_encoding = 'UTF-8';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The object for the current request
|
|
|
|
*
|
|
|
|
* @var CakeRequest
|
|
|
|
*/
|
|
|
|
protected $_request = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class constructor
|
|
|
|
*
|
|
|
|
* @param array $options list of parameters to setup the response. Possible values are:
|
|
|
|
* - body: the rensonse text that should be sent to the client
|
|
|
|
* - status: the HTTP status code to respond with
|
|
|
|
* - type: a complete mime-type string or an extension mapepd in this class
|
|
|
|
* - encoding: the encoding for the response body
|
|
|
|
* @param CakeRequest $request the object representing the current request
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct(array $options = array(), CakeRequest $request = null) {
|
2010-07-31 17:03:02 +00:00
|
|
|
$this->_request = $request;
|
|
|
|
if (isset($options['body'])) {
|
|
|
|
$this->body($options['body']);
|
|
|
|
}
|
|
|
|
if (isset($options['status'])) {
|
|
|
|
$this->statusCode($options['status']);
|
|
|
|
}
|
|
|
|
if (isset($options['type'])) {
|
|
|
|
$this->type($options['type']);
|
|
|
|
}
|
|
|
|
if (isset($options['encoding'])) {
|
|
|
|
$this->encoding($options['encoding']);
|
|
|
|
}
|
2010-07-29 05:24:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends the complete response to the client including headers and message body
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function send() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends the complete headers list to the client
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function sendHeaders() {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Buffers a header string to be sent
|
|
|
|
*
|
|
|
|
* @param mixed $header. An array of header strings or a single header string
|
|
|
|
*/
|
|
|
|
public function header($header) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Buffers the response message to be sent
|
|
|
|
* if $content is null the current buffer is returned
|
|
|
|
*
|
|
|
|
* @param string $content the string message to be sent
|
|
|
|
* @return string current message buffer if $content param is passed as null
|
|
|
|
*/
|
|
|
|
public function body($content = null) {
|
2010-07-31 17:03:02 +00:00
|
|
|
if (is_null($content)) {
|
|
|
|
return $this->_body;
|
|
|
|
}
|
|
|
|
return $this->_body = $content;
|
2010-07-29 05:24:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the HTTP status code to be sent
|
|
|
|
* if $code is null the current code is returned
|
|
|
|
*
|
|
|
|
* @param integer $code
|
2010-07-31 17:03:02 +00:00
|
|
|
* @return integer current status code
|
2010-07-29 05:24:16 +00:00
|
|
|
*/
|
|
|
|
public function statusCode($code = null) {
|
2010-07-31 17:03:02 +00:00
|
|
|
if (is_null($code)) {
|
|
|
|
return $this->_status;
|
|
|
|
}
|
|
|
|
if (!isset($this->_statusCodes[$code])) {
|
|
|
|
throw new OutOfRangeException(__('Unknown status code'));
|
|
|
|
}
|
|
|
|
return $this->_status = $code;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the response content type. It can be either a file extension
|
|
|
|
* which will be mapped internally to a mime-type or a string representing a mime-type
|
|
|
|
* if $contentType is null the current content type is returned
|
|
|
|
*
|
|
|
|
* @param string $contentType
|
|
|
|
* @return string current content type
|
|
|
|
*/
|
|
|
|
public function type($contentType = null) {
|
|
|
|
if (is_null($contentType)) {
|
|
|
|
return $this->_contentType;
|
|
|
|
}
|
|
|
|
if (isset($this->_mimeTypes[$contentType])) {
|
|
|
|
$contentType = $this->_mimeTypes[$contentType];
|
|
|
|
}
|
|
|
|
return $this->_contentType = $contentType;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the response encoding or charset
|
|
|
|
* if $encoding is null the current encoding is returned
|
|
|
|
*
|
|
|
|
* @param string $encoding
|
|
|
|
* @return string current status code
|
|
|
|
*/
|
|
|
|
public function encoding($encoding = null) {
|
|
|
|
if (is_null($encoding)) {
|
|
|
|
return $this->_encoding;
|
|
|
|
}
|
|
|
|
return $this->_encoding = $encoding;
|
2010-07-29 05:24:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the correct headers to instruct the client to not cache te response
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function disableCache() {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the correct headers to instruct the client to cache the response
|
|
|
|
*
|
|
|
|
* @param string $since a valid time since the response text has not been modified
|
|
|
|
* @param string $time a valid time for cache expiry
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function cache($since, $time = '+1 day') {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the correct headers and output buffering handler to send a compressed response
|
|
|
|
*
|
|
|
|
* @return boolean false if client does not accept compressed responses or no handler is available, true otherwise
|
|
|
|
*/
|
|
|
|
public function compress() {
|
|
|
|
}
|
|
|
|
}
|