2008-08-09 03:54:55 +00:00
|
|
|
<?php
|
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\Control\Tests;
|
|
|
|
|
2019-08-02 11:29:23 +12:00
|
|
|
use ReflectionMethod;
|
|
|
|
use SilverStripe\Control\HTTPRequest;
|
2017-06-25 15:12:29 +12:00
|
|
|
use SilverStripe\Control\Middleware\TrustedProxyMiddleware;
|
2019-08-02 11:29:23 +12:00
|
|
|
use SilverStripe\Control\Session;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
class HTTPRequestTest extends SapphireTest
|
|
|
|
{
|
|
|
|
protected static $fixture_file = null;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testMatch()
|
|
|
|
{
|
|
|
|
$request = new HTTPRequest("GET", "admin/crm/add");
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
/* When a rule matches, but has no variables, array("_matched" => true) is returned. */
|
|
|
|
$this->assertEquals(array("_matched" => true), $request->match('admin/crm', true));
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
/* Becasue we shifted admin/crm off the stack, just "add" should be remaining */
|
|
|
|
$this->assertEquals("add", $request->remaining());
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$this->assertEquals(array("_matched" => true), $request->match('add', true));
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testHttpMethodOverrides()
|
|
|
|
{
|
|
|
|
$request = new HTTPRequest(
|
|
|
|
'GET',
|
|
|
|
'admin/crm'
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isGET(),
|
|
|
|
'GET with no method override'
|
|
|
|
);
|
2008-10-06 14:58:01 +00:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm'
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isPOST(),
|
|
|
|
'POST with no method override'
|
|
|
|
);
|
2008-10-06 14:58:01 +00:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'GET',
|
|
|
|
'admin/crm',
|
|
|
|
array('_method' => 'DELETE')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isGET(),
|
|
|
|
'GET with invalid POST method override'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
array(),
|
|
|
|
array('_method' => 'DELETE')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isDELETE(),
|
|
|
|
'POST with valid method override to DELETE'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
array(),
|
|
|
|
array('_method' => 'put')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isPUT(),
|
|
|
|
'POST with valid method override to PUT'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
array(),
|
|
|
|
array('_method' => 'head')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isHEAD(),
|
|
|
|
'POST with valid method override to HEAD '
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
array(),
|
|
|
|
array('_method' => 'head')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isHEAD(),
|
|
|
|
'POST with valid method override to HEAD'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
array('_method' => 'head')
|
|
|
|
);
|
|
|
|
$this->assertTrue(
|
|
|
|
$request->isPOST(),
|
|
|
|
'POST with invalid method override by GET parameters to HEAD'
|
|
|
|
);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testRequestVars()
|
|
|
|
{
|
|
|
|
$getVars = array(
|
|
|
|
'first' => 'a',
|
|
|
|
'second' => 'b',
|
|
|
|
);
|
|
|
|
$postVars = array(
|
|
|
|
'third' => 'c',
|
|
|
|
'fourth' => 'd',
|
|
|
|
);
|
|
|
|
$requestVars = array(
|
|
|
|
'first' => 'a',
|
|
|
|
'second' => 'b',
|
|
|
|
'third' => 'c',
|
|
|
|
'fourth' => 'd',
|
|
|
|
);
|
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
$getVars,
|
|
|
|
$postVars
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$requestVars,
|
|
|
|
$request->requestVars(),
|
|
|
|
'GET parameters should supplement POST parameters'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$getVars = array(
|
|
|
|
'first' => 'a',
|
|
|
|
'second' => 'b',
|
|
|
|
);
|
|
|
|
$postVars = array(
|
|
|
|
'first' => 'c',
|
|
|
|
'third' => 'd',
|
|
|
|
);
|
|
|
|
$requestVars = array(
|
|
|
|
'first' => 'c',
|
|
|
|
'second' => 'b',
|
|
|
|
'third' => 'd',
|
|
|
|
);
|
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
$getVars,
|
|
|
|
$postVars
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$requestVars,
|
|
|
|
$request->requestVars(),
|
|
|
|
'POST parameters should override GET parameters'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$getVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'first' => 'a',
|
|
|
|
),
|
|
|
|
'second' => array(
|
|
|
|
'second' => 'b',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$postVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'first' => 'c',
|
|
|
|
),
|
|
|
|
'third' => array(
|
|
|
|
'third' => 'd',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$requestVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'first' => 'c',
|
|
|
|
),
|
|
|
|
'second' => array(
|
|
|
|
'second' => 'b',
|
|
|
|
),
|
|
|
|
'third' => array(
|
|
|
|
'third' => 'd',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
$getVars,
|
|
|
|
$postVars
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$requestVars,
|
|
|
|
$request->requestVars(),
|
|
|
|
'Nested POST parameters should override GET parameters'
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$getVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'first' => 'a',
|
|
|
|
),
|
|
|
|
'second' => array(
|
|
|
|
'second' => 'b',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$postVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'second' => 'c',
|
|
|
|
),
|
|
|
|
'third' => array(
|
|
|
|
'third' => 'd',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$requestVars = array(
|
|
|
|
'first' => array(
|
|
|
|
'first' => 'a',
|
|
|
|
'second' => 'c',
|
|
|
|
),
|
|
|
|
'second' => array(
|
|
|
|
'second' => 'b',
|
|
|
|
),
|
|
|
|
'third' => array(
|
|
|
|
'third' => 'd',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
$request = new HTTPRequest(
|
|
|
|
'POST',
|
|
|
|
'admin/crm',
|
|
|
|
$getVars,
|
|
|
|
$postVars
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$requestVars,
|
|
|
|
$request->requestVars(),
|
|
|
|
'Nested GET parameters should supplement POST parameters'
|
|
|
|
);
|
|
|
|
}
|
2012-04-05 14:44:42 +02:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testIsAjax()
|
|
|
|
{
|
|
|
|
$req = new HTTPRequest('GET', '/', array('ajax' => 0));
|
|
|
|
$this->assertFalse($req->isAjax());
|
2012-04-05 14:44:42 +02:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$req = new HTTPRequest('GET', '/', array('ajax' => 1));
|
|
|
|
$this->assertTrue($req->isAjax());
|
2012-04-05 14:44:42 +02:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$req = new HTTPRequest('GET', '/');
|
|
|
|
$req->addHeader('X-Requested-With', 'XMLHttpRequest');
|
|
|
|
$this->assertTrue($req->isAjax());
|
|
|
|
}
|
2012-06-29 22:02:30 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testGetURL()
|
|
|
|
{
|
|
|
|
$req = new HTTPRequest('GET', '/');
|
|
|
|
$this->assertEquals('', $req->getURL());
|
2012-06-29 22:02:30 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$req = new HTTPRequest('GET', '/assets/somefile.gif');
|
|
|
|
$this->assertEquals('assets/somefile.gif', $req->getURL());
|
2012-06-29 22:02:30 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$req = new HTTPRequest('GET', '/home?test=1');
|
|
|
|
$this->assertEquals('home?test=1', $req->getURL(true));
|
|
|
|
$this->assertEquals('home', $req->getURL());
|
|
|
|
}
|
2016-03-01 12:56:34 +00:00
|
|
|
|
2017-06-25 15:12:29 +12:00
|
|
|
public function testSetIPFromHeaderValue()
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
2017-06-25 15:12:29 +12:00
|
|
|
$req = new TrustedProxyMiddleware();
|
2016-12-16 17:34:21 +13:00
|
|
|
$reflectionMethod = new ReflectionMethod($req, 'getIPFromHeaderValue');
|
|
|
|
$reflectionMethod->setAccessible(true);
|
2016-03-01 12:56:34 +00:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$headers = array(
|
|
|
|
'80.79.208.21, 149.126.76.1, 10.51.0.68' => '80.79.208.21',
|
|
|
|
'52.19.19.103, 10.51.0.49' => '52.19.19.103',
|
|
|
|
'10.51.0.49, 52.19.19.103' => '52.19.19.103',
|
|
|
|
'10.51.0.49' => '10.51.0.49',
|
|
|
|
'127.0.0.1, 10.51.0.49' => '127.0.0.1',
|
|
|
|
);
|
2016-03-01 12:56:34 +00:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
foreach ($headers as $header => $ip) {
|
|
|
|
$this->assertEquals($ip, $reflectionMethod->invoke($req, $header));
|
|
|
|
}
|
|
|
|
}
|
2019-08-02 11:29:23 +12:00
|
|
|
|
|
|
|
public function testHasSession()
|
|
|
|
{
|
|
|
|
$request = new HTTPRequest('GET', '/');
|
|
|
|
$this->assertFalse($request->hasSession());
|
|
|
|
|
|
|
|
$request->setSession($this->createMock(Session::class));
|
|
|
|
$this->assertTrue($request->hasSession());
|
|
|
|
}
|
2011-12-23 11:04:44 +13:00
|
|
|
}
|