From 8ef4572700b6e286e7dd03b0905364aff092005f Mon Sep 17 00:00:00 2001 From: csteipp Date: Wed, 26 Jun 2013 14:10:52 -0700 Subject: [PATCH] Add methods to get raw request in WebRequest Make it possible to get the raw parameters given to the request, with no escaping. This is needed for features like OAuth, where a signature is calculated over the parameters to verify their integrity and source. FauxRequest is extended so the original request doesn't pollute the fake one. This could be extended so "raw" values could be set and used, but there isn't a use case for that yet, so it's not done here. Change-Id: I8710844f21d21cbbf28517b0cc25b0713b506bee --- includes/WebRequest.php | 62 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) diff --git a/includes/WebRequest.php b/includes/WebRequest.php index dbd07403a6d..80881c977c0 100644 --- a/includes/WebRequest.php +++ b/includes/WebRequest.php @@ -569,6 +569,44 @@ class WebRequest { } /** + * Return the contents of the Query with no decoding. Use when you need to + * know exactly what was sent, e.g. for an OAuth signature over the elements. + * + * @return String + */ + public function getRawQueryString() { + return $_SERVER['QUERY_STRING']; + } + + /** + * Return the contents of the POST with no decoding. Use when you need to + * know exactly what was sent, e.g. for an OAuth signature over the elements. + * + * @return String + */ + public function getRawPostString() { + if ( !$this->wasPosted() ) { + return ''; + } + return $this->getRawInput(); + } + + /** + * Return the raw request body, with no processing. Cached since some methods + * disallow reading the stream more than once. As stated in the php docs, this + * does not work with enctype="multipart/form-data". + * + * @return String + */ + public function getRawInput() { + static $input = false; + if ( $input === false ) { + $input = file_get_contents( 'php://input' ); + } + return $input; + } + + /** * Get the HTTP method used for this request. * * @return String @@ -1392,6 +1430,30 @@ class FauxRequest extends WebRequest { } /** + * FauxRequests shouldn't depend on raw request data (but that could be implemented here) + * @return String + */ + public function getRawQueryString() { + return ''; + } + + /** + * FauxRequests shouldn't depend on raw request data (but that could be implemented here) + * @return String + */ + public function getRawPostString() { + return ''; + } + + /** + * FauxRequests shouldn't depend on raw request data (but that could be implemented here) + * @return String + */ + public function getRawInput() { + return ''; + } + + /** * @param array $extWhitelist * @return bool */ -- 2.11.4.GIT