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:
Ingo Schommer 2010-11-23 19:39:17 +00:00 committed by Sam Minnee
parent b5e9b911d3
commit 43c85e3c9a
2 changed files with 54 additions and 2 deletions

View File

@ -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);
} }
/** /**

View 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()
);
}
}