mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
ENHANCEMENT Added SS_HTTPResponse->setStatusDescription() as equivalent to setStatusCode(). Added documentation.
BUGFIX Strip newlines and carriage returns from SS_HTTPResponse->getStatusDescription() (fixes #6222, thanks mattclegg) (from r114082) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.4@114083 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
b5e9b911d3
commit
43c85e3c9a
@ -6,6 +6,10 @@
|
|||||||
* @subpackage control
|
* @subpackage control
|
||||||
*/
|
*/
|
||||||
class SS_HTTPResponse {
|
class SS_HTTPResponse {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
protected static $status_codes = array(
|
protected static $status_codes = array(
|
||||||
100 => 'Continue',
|
100 => 'Continue',
|
||||||
101 => 'Switching Protocols',
|
101 => 'Switching Protocols',
|
||||||
@ -48,6 +52,9 @@ class SS_HTTPResponse {
|
|||||||
505 => 'HTTP Version Not Supported',
|
505 => 'HTTP Version Not Supported',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
protected static $redirect_codes = array(
|
protected static $redirect_codes = array(
|
||||||
301,
|
301,
|
||||||
302,
|
302,
|
||||||
@ -57,7 +64,14 @@ class SS_HTTPResponse {
|
|||||||
307
|
307
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var Int
|
||||||
|
*/
|
||||||
protected $statusCode = 200;
|
protected $statusCode = 200;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var String
|
||||||
|
*/
|
||||||
protected $statusDescription = "OK";
|
protected $statusDescription = "OK";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -77,15 +91,24 @@ class SS_HTTPResponse {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new HTTP response
|
* Create a new HTTP response
|
||||||
|
*
|
||||||
* @param $body The body of the response
|
* @param $body The body of the response
|
||||||
* @param $statusCode The numeric status code - 200, 404, etc
|
* @param $statusCode The numeric status code - 200, 404, etc
|
||||||
* @param $statusDescription The text to be given alongside the status code. This can be accessed by javascript
|
* @param $statusDescription The text to be given alongside the status code.
|
||||||
|
* See {@link setStatusCode()} for more information.
|
||||||
*/
|
*/
|
||||||
function __construct($body = null, $statusCode = null, $statusDescription = null) {
|
function __construct($body = null, $statusCode = null, $statusDescription = null) {
|
||||||
$this->body = $body;
|
$this->body = $body;
|
||||||
if($statusCode) $this->setStatusCode($statusCode, $statusDescription);
|
if($statusCode) $this->setStatusCode($statusCode, $statusDescription);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param String $code
|
||||||
|
* @param String $description Optional. See {@link setStatusDescription()}.
|
||||||
|
* No newlines are allowed in the description.
|
||||||
|
* If omitted, will default to the standard HTTP description
|
||||||
|
* for the given $code value (see {@link $status_codes}).
|
||||||
|
*/
|
||||||
function setStatusCode($code, $description = null) {
|
function setStatusCode($code, $description = null) {
|
||||||
if(isset(self::$status_codes[$code])) $this->statusCode = $code;
|
if(isset(self::$status_codes[$code])) $this->statusCode = $code;
|
||||||
else user_error("Unrecognised HTTP status code '$code'", E_USER_WARNING);
|
else user_error("Unrecognised HTTP status code '$code'", E_USER_WARNING);
|
||||||
@ -94,6 +117,19 @@ class SS_HTTPResponse {
|
|||||||
else $this->statusDescription = self::$status_codes[$code];
|
else $this->statusDescription = self::$status_codes[$code];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The text to be given alongside the status code ("reason phrase").
|
||||||
|
* Caution: Will be overwritten by {@link setStatusCode()}.
|
||||||
|
*
|
||||||
|
* @param String $description
|
||||||
|
*/
|
||||||
|
function setStatusDescription($description) {
|
||||||
|
$this->statusDescription = $description;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Int
|
||||||
|
*/
|
||||||
function getStatusCode() {
|
function getStatusCode() {
|
||||||
return $this->statusCode;
|
return $this->statusCode;
|
||||||
}
|
}
|
||||||
@ -102,7 +138,7 @@ class SS_HTTPResponse {
|
|||||||
* @return string Description for a HTTP status code
|
* @return string Description for a HTTP status code
|
||||||
*/
|
*/
|
||||||
function getStatusDescription() {
|
function getStatusDescription() {
|
||||||
return $this->statusDescription;
|
return str_replace(array("\r","\n"), '', $this->statusDescription);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
16
tests/control/HTTPResponseTest.php
Normal file
16
tests/control/HTTPResponseTest.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @package sapphire
|
||||||
|
* @subpackage tests
|
||||||
|
*/
|
||||||
|
class HTTPResponseTest extends SapphireTest {
|
||||||
|
|
||||||
|
function testStatusDescriptionStripsNewlines() {
|
||||||
|
$r = new SS_HTTPResponse('my body', 200, "my description \nwith newlines \rand carriage returns");
|
||||||
|
$this->assertEquals(
|
||||||
|
"my description with newlines and carriage returns",
|
||||||
|
$r->getStatusDescription()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user