2010-11-13 20:51:09 -02:00
|
|
|
<?php
|
|
|
|
/**
|
2010-11-20 17:47:35 -02:00
|
|
|
* DigestAuthenticationTest file
|
2010-11-13 20:51:09 -02:00
|
|
|
*
|
|
|
|
* PHP 5
|
|
|
|
*
|
2012-04-26 19:49:18 -07:00
|
|
|
* CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
2012-03-12 22:46:07 -04:00
|
|
|
* Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2010-11-13 20:51:09 -02:00
|
|
|
*
|
|
|
|
* Licensed under The MIT License
|
|
|
|
* Redistributions of files must retain the above copyright notice
|
|
|
|
*
|
2012-03-12 22:46:07 -04:00
|
|
|
* @copyright Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2012-04-26 19:49:18 -07:00
|
|
|
* @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
2011-07-26 01:46:14 -04:30
|
|
|
* @package Cake.Test.Case.Network.Http
|
2010-11-13 20:51:09 -02:00
|
|
|
* @since CakePHP(tm) v 2.0.0
|
|
|
|
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
|
|
|
*/
|
|
|
|
|
2011-02-22 00:04:21 -04:30
|
|
|
App::uses('HttpSocket', 'Network/Http');
|
|
|
|
App::uses('DigestAuthentication', 'Network/Http');
|
2010-11-13 20:51:09 -02:00
|
|
|
|
|
|
|
class DigestHttpSocket extends HttpSocket {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* nextHeader attribute
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $nextHeader = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* request method
|
|
|
|
*
|
|
|
|
* @param mixed $request
|
|
|
|
* @return void
|
|
|
|
*/
|
2011-11-12 20:43:55 -05:00
|
|
|
public function request($request = array()) {
|
2010-11-24 21:14:52 -02:00
|
|
|
if ($request === false) {
|
|
|
|
if (isset($this->response['header']['WWW-Authenticate'])) {
|
|
|
|
unset($this->response['header']['WWW-Authenticate']);
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2010-11-13 21:47:25 -02:00
|
|
|
$this->response['header']['WWW-Authenticate'] = $this->nextHeader;
|
2010-11-13 20:51:09 -02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-11-20 17:47:35 -02:00
|
|
|
* DigestAuthenticationTest class
|
2010-11-13 20:51:09 -02:00
|
|
|
*
|
2011-07-26 01:46:14 -04:30
|
|
|
* @package Cake.Test.Case.Network.Http
|
2010-11-13 20:51:09 -02:00
|
|
|
*/
|
2010-11-20 17:47:35 -02:00
|
|
|
class DigestAuthenticationTest extends CakeTestCase {
|
2010-11-13 20:51:09 -02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Socket property
|
|
|
|
*
|
|
|
|
* @var mixed null
|
|
|
|
*/
|
|
|
|
public $HttpSocket = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function sets up a HttpSocket instance we are going to use for testing
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function setUp() {
|
|
|
|
$this->HttpSocket = new DigestHttpSocket();
|
|
|
|
$this->HttpSocket->request['method'] = 'GET';
|
|
|
|
$this->HttpSocket->request['uri']['path'] = '/';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* We use this function to clean up after the test case was executed
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2011-05-30 22:02:32 +02:00
|
|
|
public function tearDown() {
|
2010-11-13 20:51:09 -02:00
|
|
|
unset($this->HttpSocket);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testBasic method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testBasic() {
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51"';
|
|
|
|
$this->assertFalse(isset($this->HttpSocket->request['header']['Authorization']));
|
2010-12-03 21:57:15 -02:00
|
|
|
|
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertTrue(isset($this->HttpSocket->request['header']['Authorization']));
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertEquals('The batcave', $auth['realm']);
|
|
|
|
$this->assertEquals('4cded326c6c51', $auth['nonce']);
|
2010-11-13 20:51:09 -02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testQop method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testQop() {
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51"';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$expected = 'Digest username="admin", realm="The batcave", nonce="4cded326c6c51", uri="/", response="da7e2a46b471d77f70a9bb3698c8902b"';
|
2011-11-15 16:07:56 -08:00
|
|
|
$this->assertEquals($expected, $this->HttpSocket->request['header']['Authorization']);
|
2010-12-03 21:57:15 -02:00
|
|
|
$this->assertFalse(isset($auth['qop']));
|
|
|
|
$this->assertFalse(isset($auth['nc']));
|
2010-11-13 20:51:09 -02:00
|
|
|
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51",qop="auth"';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$expected = '@Digest username="admin", realm="The batcave", nonce="4cded326c6c51", uri="/", response="[a-z0-9]{32}", qop="auth", nc=00000001, cnonce="[a-z0-9]+"@';
|
2011-11-15 16:07:56 -08:00
|
|
|
$this->assertRegExp($expected, $this->HttpSocket->request['header']['Authorization']);
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertEquals('auth', $auth['qop']);
|
|
|
|
$this->assertEquals(2, $auth['nc']);
|
2010-11-13 20:51:09 -02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testOpaque method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testOpaque() {
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51"';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertFalse(strpos($this->HttpSocket->request['header']['Authorization'], 'opaque="d8ea7aa61a1693024c4cc3a516f49b3c"'));
|
|
|
|
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51",opaque="d8ea7aa61a1693024c4cc3a516f49b3c"';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertTrue(strpos($this->HttpSocket->request['header']['Authorization'], 'opaque="d8ea7aa61a1693024c4cc3a516f49b3c"') > 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testMultipleRequest method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testMultipleRequest() {
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51",qop="auth"';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertTrue(strpos($this->HttpSocket->request['header']['Authorization'], 'nc=00000001') > 0);
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertEquals(2, $auth['nc']);
|
2010-11-13 20:51:09 -02:00
|
|
|
|
2010-12-03 21:57:15 -02:00
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertTrue(strpos($this->HttpSocket->request['header']['Authorization'], 'nc=00000002') > 0);
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertEquals(3, $auth['nc']);
|
2010-11-13 20:51:09 -02:00
|
|
|
$responsePos = strpos($this->HttpSocket->request['header']['Authorization'], 'response=');
|
|
|
|
$response = substr($this->HttpSocket->request['header']['Authorization'], $responsePos + 10, 32);
|
|
|
|
|
|
|
|
$this->HttpSocket->nextHeader = '';
|
2010-12-03 21:57:15 -02:00
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$this->assertTrue(strpos($this->HttpSocket->request['header']['Authorization'], 'nc=00000003') > 0);
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertEquals(4, $auth['nc']);
|
2010-11-13 20:51:09 -02:00
|
|
|
$responsePos = strpos($this->HttpSocket->request['header']['Authorization'], 'response=');
|
2012-03-16 22:19:01 -04:00
|
|
|
$responseB = substr($this->HttpSocket->request['header']['Authorization'], $responsePos + 10, 32);
|
|
|
|
$this->assertNotEquals($response, $responseB);
|
2010-11-13 20:51:09 -02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* testPathChanged method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testPathChanged() {
|
|
|
|
$this->HttpSocket->nextHeader = 'Digest realm="The batcave",nonce="4cded326c6c51"';
|
|
|
|
$this->HttpSocket->request['uri']['path'] = '/admin';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-13 20:51:09 -02:00
|
|
|
$responsePos = strpos($this->HttpSocket->request['header']['Authorization'], 'response=');
|
|
|
|
$response = substr($this->HttpSocket->request['header']['Authorization'], $responsePos + 10, 32);
|
2012-03-22 23:37:12 -07:00
|
|
|
$this->assertNotEquals('da7e2a46b471d77f70a9bb3698c8902b', $response);
|
2010-11-13 20:51:09 -02:00
|
|
|
}
|
|
|
|
|
2010-11-24 21:14:52 -02:00
|
|
|
/**
|
|
|
|
* testNoDigestResponse method
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testNoDigestResponse() {
|
|
|
|
$this->HttpSocket->nextHeader = false;
|
|
|
|
$this->HttpSocket->request['uri']['path'] = '/admin';
|
2010-12-03 21:57:15 -02:00
|
|
|
$auth = array('user' => 'admin', 'pass' => '1234');
|
|
|
|
DigestAuthentication::authentication($this->HttpSocket, $auth);
|
2010-11-24 21:14:52 -02:00
|
|
|
$this->assertFalse(isset($this->HttpSocket->request['header']['Authorization']));
|
|
|
|
}
|
|
|
|
|
2011-11-12 20:43:55 -05:00
|
|
|
}
|