mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
ENHANCEMENT Allow use of RestfulService->setQueryString() and test to support it. Patch from ticket #2973. Thanks to simon_w!
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@64596 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
a51d7184a3
commit
6195772779
@ -65,6 +65,14 @@ class RestfulService extends ViewableData {
|
|||||||
*/
|
*/
|
||||||
public function request($subURL = '', $method = "GET", $data = null, $headers = null) {
|
public function request($subURL = '', $method = "GET", $data = null, $headers = null) {
|
||||||
$url = $this->baseURL . $subURL; //url for the request
|
$url = $this->baseURL . $subURL; //url for the request
|
||||||
|
if($this->queryString) {
|
||||||
|
if(strpos($url, '?') !== false) {
|
||||||
|
$url .= '&' . $this->queryString;
|
||||||
|
} else {
|
||||||
|
$url .= '?' . $this->queryString;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$url = str_replace(' ', '%20', $url); // spaces should be encoded
|
||||||
$method = strtoupper($method);
|
$method = strtoupper($method);
|
||||||
|
|
||||||
assert(in_array($method, array('GET','POST','PUT','DELETE','HEAD','OPTIONS')));
|
assert(in_array($method, array('GET','POST','PUT','DELETE','HEAD','OPTIONS')));
|
||||||
@ -99,6 +107,11 @@ class RestfulService extends ViewableData {
|
|||||||
if($headers) curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
|
if($headers) curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
|
||||||
if($this->authUsername) curl_setopt($ch, CURLOPT_USERPWD, "$this->authUsername:$this->authPassword");
|
if($this->authUsername) curl_setopt($ch, CURLOPT_USERPWD, "$this->authUsername:$this->authPassword");
|
||||||
|
|
||||||
|
if($method == 'POST') {
|
||||||
|
curl_setopt($ch, CURLOPT_POST, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
|
||||||
|
}
|
||||||
|
|
||||||
$responseBody = curl_exec($ch);
|
$responseBody = curl_exec($ch);
|
||||||
|
|
||||||
if($responseBody === false) {
|
if($responseBody === false) {
|
||||||
|
91
tests/api/RestfulServiceTest.php
Normal file
91
tests/api/RestfulServiceTest.php
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class RestfulServiceTest extends SapphireTest {
|
||||||
|
function testGetData() {
|
||||||
|
$connection = new RestfulService(Director::absoluteBaseURL());
|
||||||
|
$test1params = array(
|
||||||
|
'test1a' => 4352655636.76543, // number test
|
||||||
|
'test1b' => '$&+,/:;=?@#"\'%', // special char test. These should all get encoded
|
||||||
|
'test1c' => 'And now for a string test' // string test
|
||||||
|
);
|
||||||
|
$connection->setQueryString($test1params);
|
||||||
|
$test1 = $connection->request('RestfulServiceTest_Controller')->getBody();
|
||||||
|
foreach ($test1params as $key => $value) {
|
||||||
|
$this->assertContains("<request_item name=\"$key\">$value</request_item>", $test1);
|
||||||
|
$this->assertContains("<get_item name=\"$key\">$value</get_item>", $test1);
|
||||||
|
}
|
||||||
|
$connection->setQueryString(array());
|
||||||
|
$test2params = array(
|
||||||
|
'test2a' => 767545678.76887, // number test
|
||||||
|
'test2b' => '%\'"@?=;:/,$', // special character checks
|
||||||
|
'test2c' => 'And now for a string test', // string test
|
||||||
|
);
|
||||||
|
$test2suburl = 'RestfulServiceTest_Controller/?';
|
||||||
|
foreach ($test2params as $key=>$value) {
|
||||||
|
$test2suburl .= "$key=$value&";
|
||||||
|
}
|
||||||
|
$test2suburl = substr($test2suburl, 0, -1);
|
||||||
|
$test2 = $connection->request($test2suburl)->getBody();
|
||||||
|
foreach ($test2params as $key => $value) {
|
||||||
|
$this->assertContains("<request_item name=\"$key\">$value</request_item>", $test2);
|
||||||
|
$this->assertContains("<get_item name=\"$key\">$value</get_item>", $test2);
|
||||||
|
}
|
||||||
|
$test3params = array_merge($test1params, $test2params); // We want to check using setQueryString() and hard coded
|
||||||
|
$connection->setQueryString($test1params);
|
||||||
|
$test3 = $connection->request($test2suburl)->getBody();
|
||||||
|
foreach ($test3params as $key => $value) {
|
||||||
|
$this->assertContains("<request_item name=\"$key\">$value</request_item>", $test3);
|
||||||
|
$this->assertContains("<get_item name=\"$key\">$value</get_item>", $test3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function testPostData() {
|
||||||
|
$connection = new RestfulService(Director::absoluteBaseURL());
|
||||||
|
$test1params = array(
|
||||||
|
'test1a' => mktime(),
|
||||||
|
'test1b' => mt_rand(),
|
||||||
|
'test1c' => 'And now for a string test'
|
||||||
|
);
|
||||||
|
$test1 = $connection->request('RestfulServiceTest_Controller', 'POST', $test1params)->getBody();
|
||||||
|
foreach ($test1params as $key => $value) {
|
||||||
|
$this->assertContains("<request_item name=\"$key\">$value</request_item>", $test1);
|
||||||
|
$this->assertContains("<post_item name=\"$key\">$value</post_item>", $test1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class RestfulServiceTest_Controller extends Controller {
|
||||||
|
public function index() {
|
||||||
|
ContentNegotiator::disable();
|
||||||
|
$request_count = count($_REQUEST);
|
||||||
|
$get_count = count($_GET);
|
||||||
|
$post_count = count($_POST);
|
||||||
|
$request = '';
|
||||||
|
foreach ($_REQUEST as $key=>$value) {
|
||||||
|
$request .= "\t\t<request_item name=\"$key\">$value</request_item>\n";
|
||||||
|
}
|
||||||
|
$get = '';
|
||||||
|
foreach ($_GET as $key => $value) {
|
||||||
|
$get .= "\t\t<get_item name=\"$key\">$value</get_item>\n";
|
||||||
|
}
|
||||||
|
$post = '';
|
||||||
|
foreach ($_POST as $key => $value) {
|
||||||
|
$post .= "\t\t<post_item name=\"$key\">$value</post_item>\n";
|
||||||
|
}
|
||||||
|
$out = <<<XML
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<test>
|
||||||
|
<request count="$request_count">
|
||||||
|
$request </request>
|
||||||
|
<get count="$get_count">
|
||||||
|
$get </get>
|
||||||
|
<post count="$post_count">
|
||||||
|
$post </post>
|
||||||
|
</test>
|
||||||
|
XML;
|
||||||
|
header('Content-type: text/xml');
|
||||||
|
echo $out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
Loading…
x
Reference in New Issue
Block a user