OpenIdTest.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_Auth
  17. * @subpackage UnitTests
  18. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. * @version $Id$
  21. */
  22. /**
  23. * PHPUnit_Framework_TestCase
  24. */
  25. /**
  26. * Zend_OpenId_ResponseHelper
  27. */
  28. require_once 'Zend/OpenId/ResponseHelper.php';
  29. /**
  30. * Zend_OpenId_Consumer_Storage_File
  31. */
  32. require_once 'Zend/OpenId/Consumer/Storage/File.php';
  33. /**
  34. * Zend_OpenId_Extension_Sreg
  35. */
  36. require_once 'Zend/OpenId/Extension/Sreg.php';
  37. /**
  38. * @see Zend_Auth_Adapter_OpenId
  39. */
  40. require_once 'Zend/Auth/Adapter/OpenId.php';
  41. /**
  42. * @see Zend_OpenId_Consumer_Storage_File
  43. */
  44. require_once 'Zend/OpenId/Consumer/Storage/File.php';
  45. /**
  46. * Zend_Http_Client_Adapter_Test
  47. */
  48. require_once 'Zend/Http/Client/Adapter/Test.php';
  49. /**
  50. * @category Zend
  51. * @package Zend_Auth
  52. * @subpackage UnitTests
  53. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  54. * @license http://framework.zend.com/license/new-bsd New BSD License
  55. * @group Zend_Auth
  56. */
  57. class Zend_Auth_Adapter_OpenIdTest extends PHPUnit_Framework_TestCase
  58. {
  59. const ID = "http://id.myopenid.com/";
  60. const REAL_ID = "http://real_id.myopenid.com/";
  61. const SERVER = "http://www.myopenid.com/";
  62. const HANDLE = "d41d8cd98f00b204e9800998ecf8427e";
  63. const MAC_FUNC = "sha1";
  64. const SECRET = "\x83\x82\xae\xa9\x22\x56\x0e\xce\x83\x3b\xa5\x5f\xa5\x3b\x7a\x97\x5f\x59\x73\x70";
  65. public function testAuthenticateInvalid()
  66. {
  67. $adapter = new Zend_Auth_Adapter_OpenId(null, new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files"));
  68. $ret = $adapter->authenticate();
  69. $this->assertFalse($ret->isValid());
  70. $this->assertSame("", $ret->getIdentity());
  71. $this->assertSame(0, $ret->getCode());
  72. $msgs = $ret->getMessages();
  73. $this->assertTrue(is_array($msgs));
  74. $this->assertSame(2, count($msgs));
  75. $this->assertSame("Authentication failed", $msgs[0]);
  76. $this->assertSame("Missing openid.mode", $msgs[1]);
  77. }
  78. public function testAuthenticateLoginInvalid()
  79. {
  80. $adapter = new Zend_Auth_Adapter_OpenId("%sd", new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files"));
  81. $ret = $adapter->authenticate();
  82. $this->assertFalse($ret->isValid());
  83. $this->assertSame("%sd", $ret->getIdentity());
  84. $this->assertSame(0, $ret->getCode());
  85. $msgs = $ret->getMessages();
  86. $this->assertTrue(is_array($msgs));
  87. $this->assertSame(2, count($msgs));
  88. $this->assertSame("Authentication failed", $msgs[0]);
  89. $this->assertSame("Normalisation failed", $msgs[1]);
  90. }
  91. public function testAuthenticateLoginValid()
  92. {
  93. $expiresIn = time() + 600;
  94. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  95. $storage->delDiscoveryInfo(self::ID);
  96. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  97. $storage->delAssociation(self::SERVER);
  98. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  99. $response = new Zend_OpenId_ResponseHelper(true);
  100. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  101. $adapter = new Zend_Auth_Adapter_OpenId(self::ID, $storage);
  102. $this->assertSame($adapter, $adapter->setResponse($response));
  103. $ret = $adapter->authenticate();
  104. $this->assertTrue(is_null($ret));
  105. $headers = $response->getHeaders();
  106. $this->assertSame( '', $response->getBody() );
  107. $this->assertTrue( is_array($headers) );
  108. $this->assertSame( 1, count($headers) );
  109. $this->assertTrue( is_array($headers[0]) );
  110. $this->assertSame( 3, count($headers[0]) );
  111. $this->assertSame( 'Location', $headers[0]['name'] );
  112. $this->assertSame( true, $headers[0]['replace'] );
  113. $url = $headers[0]['value'];
  114. $url = parse_url($url);
  115. $this->assertSame( "http", $url['scheme'] );
  116. $this->assertSame( "www.myopenid.com", $url['host'] );
  117. $this->assertSame( "/", $url['path'] );
  118. $q = explode("&", $url['query']);
  119. $query = array();
  120. foreach($q as $var) {
  121. if (list($key, $val) = explode("=", $var, 2)) {
  122. $query[$key] = $val;
  123. }
  124. }
  125. $this->assertTrue( is_array($query) );
  126. $this->assertSame( 6, count($query) );
  127. $this->assertSame( 'checkid_setup', $query['openid.mode'] );
  128. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  129. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  130. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  131. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Ftest.php', $query['openid.return_to'] );
  132. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com', $query['openid.trust_root'] );
  133. }
  134. public function testSetIdentity()
  135. {
  136. $expiresIn = time() + 600;
  137. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  138. $storage->delDiscoveryInfo(self::ID);
  139. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  140. $storage->delAssociation(self::SERVER);
  141. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  142. $response = new Zend_OpenId_ResponseHelper(true);
  143. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  144. $adapter = new Zend_Auth_Adapter_OpenId(null, $storage);
  145. $this->assertSame($adapter, $adapter->setIdentity(self::ID));
  146. $adapter->setResponse($response);
  147. $ret = $adapter->authenticate();
  148. $this->assertTrue(is_null($ret));
  149. $headers = $response->getHeaders();
  150. $this->assertSame( '', $response->getBody() );
  151. $this->assertTrue( is_array($headers) );
  152. $this->assertSame( 1, count($headers) );
  153. $this->assertTrue( is_array($headers[0]) );
  154. $this->assertSame( 3, count($headers[0]) );
  155. $this->assertSame( 'Location', $headers[0]['name'] );
  156. $this->assertSame( true, $headers[0]['replace'] );
  157. $url = $headers[0]['value'];
  158. $url = parse_url($url);
  159. $this->assertSame( "http", $url['scheme'] );
  160. $this->assertSame( "www.myopenid.com", $url['host'] );
  161. $this->assertSame( "/", $url['path'] );
  162. $q = explode("&", $url['query']);
  163. $query = array();
  164. foreach($q as $var) {
  165. if (list($key, $val) = explode("=", $var, 2)) {
  166. $query[$key] = $val;
  167. }
  168. }
  169. $this->assertTrue( is_array($query) );
  170. $this->assertSame( 6, count($query) );
  171. $this->assertSame( 'checkid_setup', $query['openid.mode'] );
  172. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  173. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  174. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  175. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Ftest.php', $query['openid.return_to'] );
  176. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com', $query['openid.trust_root'] );
  177. }
  178. public function testSetStorage()
  179. {
  180. $expiresIn = time() + 600;
  181. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  182. $storage->delDiscoveryInfo(self::ID);
  183. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  184. $storage->delAssociation(self::SERVER);
  185. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  186. $response = new Zend_OpenId_ResponseHelper(true);
  187. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  188. $adapter = new Zend_Auth_Adapter_OpenId(self::ID);
  189. $this->assertSame($adapter, $adapter->setStorage($storage));
  190. $adapter->setResponse($response);
  191. $ret = $adapter->authenticate();
  192. $this->assertTrue(is_null($ret));
  193. $headers = $response->getHeaders();
  194. $this->assertSame( '', $response->getBody() );
  195. $this->assertTrue( is_array($headers) );
  196. $this->assertSame( 1, count($headers) );
  197. $this->assertTrue( is_array($headers[0]) );
  198. $this->assertSame( 3, count($headers[0]) );
  199. $this->assertSame( 'Location', $headers[0]['name'] );
  200. $this->assertSame( true, $headers[0]['replace'] );
  201. $url = $headers[0]['value'];
  202. $url = parse_url($url);
  203. $this->assertSame( "http", $url['scheme'] );
  204. $this->assertSame( "www.myopenid.com", $url['host'] );
  205. $this->assertSame( "/", $url['path'] );
  206. $q = explode("&", $url['query']);
  207. $query = array();
  208. foreach($q as $var) {
  209. if (list($key, $val) = explode("=", $var, 2)) {
  210. $query[$key] = $val;
  211. }
  212. }
  213. $this->assertTrue( is_array($query) );
  214. $this->assertSame( 6, count($query) );
  215. $this->assertSame( 'checkid_setup', $query['openid.mode'] );
  216. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  217. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  218. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  219. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Ftest.php', $query['openid.return_to'] );
  220. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com', $query['openid.trust_root'] );
  221. }
  222. public function testSetReturnTo()
  223. {
  224. $expiresIn = time() + 600;
  225. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  226. $storage->delDiscoveryInfo(self::ID);
  227. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  228. $storage->delAssociation(self::SERVER);
  229. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  230. $response = new Zend_OpenId_ResponseHelper(true);
  231. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  232. $adapter = new Zend_Auth_Adapter_OpenId(self::ID, $storage);
  233. $adapter->setResponse($response);
  234. $this->assertSame($adapter, $adapter->setReturnTo("http://www.zf-test.com/return.php"));
  235. $ret = $adapter->authenticate();
  236. $this->assertTrue(is_null($ret));
  237. $headers = $response->getHeaders();
  238. $this->assertSame( '', $response->getBody() );
  239. $this->assertTrue( is_array($headers) );
  240. $this->assertSame( 1, count($headers) );
  241. $this->assertTrue( is_array($headers[0]) );
  242. $this->assertSame( 3, count($headers[0]) );
  243. $this->assertSame( 'Location', $headers[0]['name'] );
  244. $this->assertSame( true, $headers[0]['replace'] );
  245. $url = $headers[0]['value'];
  246. $url = parse_url($url);
  247. $this->assertSame( "http", $url['scheme'] );
  248. $this->assertSame( "www.myopenid.com", $url['host'] );
  249. $this->assertSame( "/", $url['path'] );
  250. $q = explode("&", $url['query']);
  251. $query = array();
  252. foreach($q as $var) {
  253. if (list($key, $val) = explode("=", $var, 2)) {
  254. $query[$key] = $val;
  255. }
  256. }
  257. $this->assertTrue( is_array($query) );
  258. $this->assertSame( 6, count($query) );
  259. $this->assertSame( 'checkid_setup', $query['openid.mode'] );
  260. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  261. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  262. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  263. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Freturn.php', $query['openid.return_to'] );
  264. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com', $query['openid.trust_root'] );
  265. }
  266. public function testSetRoot()
  267. {
  268. $expiresIn = time() + 600;
  269. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  270. $storage->delDiscoveryInfo(self::ID);
  271. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  272. $storage->delAssociation(self::SERVER);
  273. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  274. $response = new Zend_OpenId_ResponseHelper(true);
  275. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  276. $adapter = new Zend_Auth_Adapter_OpenId(self::ID, $storage);
  277. $adapter->setResponse($response);
  278. $this->assertSame($adapter, $adapter->setRoot("http://www.zf-test.com/root.php"));
  279. $ret = $adapter->authenticate();
  280. $this->assertTrue(is_null($ret));
  281. $headers = $response->getHeaders();
  282. $this->assertSame( '', $response->getBody() );
  283. $this->assertTrue( is_array($headers) );
  284. $this->assertSame( 1, count($headers) );
  285. $this->assertTrue( is_array($headers[0]) );
  286. $this->assertSame( 3, count($headers[0]) );
  287. $this->assertSame( 'Location', $headers[0]['name'] );
  288. $this->assertSame( true, $headers[0]['replace'] );
  289. $url = $headers[0]['value'];
  290. $url = parse_url($url);
  291. $this->assertSame( "http", $url['scheme'] );
  292. $this->assertSame( "www.myopenid.com", $url['host'] );
  293. $this->assertSame( "/", $url['path'] );
  294. $q = explode("&", $url['query']);
  295. $query = array();
  296. foreach($q as $var) {
  297. if (list($key, $val) = explode("=", $var, 2)) {
  298. $query[$key] = $val;
  299. }
  300. }
  301. $this->assertTrue( is_array($query) );
  302. $this->assertSame( 6, count($query) );
  303. $this->assertSame( 'checkid_setup', $query['openid.mode'] );
  304. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  305. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  306. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  307. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Ftest.php', $query['openid.return_to'] );
  308. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Froot.php', $query['openid.trust_root'] );
  309. }
  310. public function testAuthenticateVerifyInvalid()
  311. {
  312. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  313. unset($_SERVER['REQUEST_METHOD']);
  314. $_GET = array('openid_mode'=>'id_res',
  315. "openid_return_to" => "http://www.zf-test.com/test.php",
  316. "openid_assoc_handle" => self::HANDLE,
  317. "openid_claimed_id" => self::ID,
  318. "openid_identity" => self::REAL_ID,
  319. "openid_op_endpoint" => self::SERVER,
  320. "openid_response_nonce" => "2007-08-14T12:52:33Z46c1a59124fff",
  321. "openid_signed" => "assoc_handle,return_to,claimed_id,identity,response_nonce,mode,signed,op_endpoint",
  322. "openid_sig" => "h/5AFD25NpzSok5tzHEGCVUkQSw="
  323. );
  324. $adapter = new Zend_Auth_Adapter_OpenId(null, new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files"));
  325. $ret = $adapter->authenticate();
  326. $this->assertFalse($ret->isValid());
  327. $this->assertSame(self::ID, $ret->getIdentity());
  328. $this->assertSame(0, $ret->getCode());
  329. $msgs = $ret->getMessages();
  330. $this->assertTrue(is_array($msgs));
  331. $this->assertSame(2, count($msgs));
  332. $this->assertSame("Authentication failed", $msgs[0]);
  333. $this->assertSame("Signature check failed", $msgs[1]);
  334. }
  335. public function testAuthenticateVerifyGetValid()
  336. {
  337. $expiresIn = time() + 600;
  338. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  339. $storage->delDiscoveryInfo(self::ID);
  340. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  341. $storage->delAssociation(self::SERVER);
  342. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  343. $storage->purgeNonces();
  344. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  345. unset($_SERVER['REQUEST_METHOD']);
  346. $_GET = array(
  347. "openid_return_to" => "http://www.zf-test.com/test.php",
  348. "openid_assoc_handle" => self::HANDLE,
  349. "openid_claimed_id" => self::ID,
  350. "openid_identity" => self::REAL_ID,
  351. "openid_response_nonce" => "2007-08-14T12:52:33Z46c1a59124ffe",
  352. "openid_mode" => "id_res",
  353. "openid_op_endpoint" => self::SERVER,
  354. "openid_signed" => "assoc_handle,return_to,claimed_id,identity,response_nonce,mode,signed,op_endpoint",
  355. "openid_sig" => '7DZUB+y05wJqpYSdFs5cX5FyNMY='
  356. );
  357. $adapter = new Zend_Auth_Adapter_OpenId(null, $storage);
  358. $ret = $adapter->authenticate();
  359. $this->assertTrue($ret->isValid());
  360. }
  361. public function testAuthenticateVerifyPostValid()
  362. {
  363. $expiresIn = time() + 600;
  364. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  365. $storage->delDiscoveryInfo(self::ID);
  366. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  367. $storage->delAssociation(self::SERVER);
  368. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  369. $storage->purgeNonces();
  370. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  371. $_SERVER['REQUEST_METHOD'] = 'POST';
  372. $_GET = array();
  373. $_POST = array(
  374. "openid_return_to" => "http://www.zf-test.com/test.php",
  375. "openid_assoc_handle" => self::HANDLE,
  376. "openid_claimed_id" => self::ID,
  377. "openid_identity" => self::REAL_ID,
  378. "openid_response_nonce" => "2007-08-14T12:52:33Z46c1a59124ffe",
  379. "openid_mode" => "id_res",
  380. "openid_op_endpoint" => self::SERVER,
  381. "openid_signed" => "assoc_handle,return_to,claimed_id,identity,response_nonce,mode,signed,op_endpoint",
  382. "openid_sig" => "7DZUB+y05wJqpYSdFs5cX5FyNMY="
  383. );
  384. $adapter = new Zend_Auth_Adapter_OpenId(null, $storage);
  385. $ret = $adapter->authenticate();
  386. $this->assertTrue($ret->isValid());
  387. }
  388. public function testSetExtensions()
  389. {
  390. $expiresIn = time() + 600;
  391. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  392. $this->assertTrue( $storage->delDiscoveryInfo(self::ID) );
  393. $this->assertTrue( $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 2.0, $expiresIn) );
  394. $storage->delAssociation(self::SERVER);
  395. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  396. $storage->purgeNonces();
  397. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  398. $_SERVER['REQUEST_METHOD'] = 'GET';
  399. $_GET = array(
  400. "openid_ns" => Zend_OpenId::NS_2_0,
  401. "openid_return_to" => "http://www.zf-test.com/test.php",
  402. "openid_assoc_handle" => self::HANDLE,
  403. "openid_claimed_id" => self::ID,
  404. "openid_identity" => self::REAL_ID,
  405. "openid_response_nonce" => "2007-08-14T12:52:33Z46c1a59124ffe",
  406. "openid_op_endpoint" => self::SERVER,
  407. "openid_mode" => "id_res",
  408. "openid_ns_sreg" => "http://openid.net/extensions/sreg/1.1",
  409. "openid_sreg_nickname" => "test",
  410. "openid_signed" => "ns,assoc_handle,return_to,claimed_id,identity,response_nonce,mode,ns.sreg,sreg.nickname,signed,op_endpoint",
  411. "openid_sig" => 'CIJabsMLZWjhJh+rHMnV+brQ7xE='
  412. );
  413. $_POST = array();
  414. $adapter = new Zend_Auth_Adapter_OpenId(null, $storage);
  415. $sreg= new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>false));
  416. $this->assertSame($adapter, $adapter->setExtensions($sreg));
  417. $ret = $adapter->authenticate();
  418. $this->assertTrue($ret->isValid());
  419. $sreg_data = $sreg->getProperties();
  420. $this->assertSame("test", $sreg_data['nickname']);
  421. }
  422. function testSetCheckImmediate() {
  423. $expiresIn = time() + 600;
  424. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  425. $storage->delDiscoveryInfo(self::ID);
  426. $storage->addDiscoveryInfo(self::ID, self::REAL_ID, self::SERVER, 1.1, $expiresIn);
  427. $storage->delAssociation(self::SERVER);
  428. $storage->addAssociation(self::SERVER, self::HANDLE, self::MAC_FUNC, self::SECRET, $expiresIn);
  429. $response = new Zend_OpenId_ResponseHelper(true);
  430. $_SERVER['SCRIPT_URI'] = "http://www.zf-test.com/test.php";
  431. $adapter = new Zend_Auth_Adapter_OpenId(self::ID, $storage);
  432. $adapter->setCheckImmediate(true);
  433. $this->assertSame($adapter, $adapter->setResponse($response));
  434. $ret = $adapter->authenticate();
  435. $this->assertTrue(is_null($ret));
  436. $headers = $response->getHeaders();
  437. $this->assertSame( '', $response->getBody() );
  438. $this->assertTrue( is_array($headers) );
  439. $this->assertSame( 1, count($headers) );
  440. $this->assertTrue( is_array($headers[0]) );
  441. $this->assertSame( 3, count($headers[0]) );
  442. $this->assertSame( 'Location', $headers[0]['name'] );
  443. $this->assertSame( true, $headers[0]['replace'] );
  444. $url = $headers[0]['value'];
  445. $url = parse_url($url);
  446. $this->assertSame( "http", $url['scheme'] );
  447. $this->assertSame( "www.myopenid.com", $url['host'] );
  448. $this->assertSame( "/", $url['path'] );
  449. $q = explode("&", $url['query']);
  450. $query = array();
  451. foreach($q as $var) {
  452. if (list($key, $val) = explode("=", $var, 2)) {
  453. $query[$key] = $val;
  454. }
  455. }
  456. $this->assertTrue( is_array($query) );
  457. $this->assertSame( 6, count($query) );
  458. $this->assertSame( 'checkid_immediate', $query['openid.mode'] );
  459. $this->assertSame( 'http%3A%2F%2Freal_id.myopenid.com%2F', $query['openid.identity'] );
  460. $this->assertSame( 'http%3A%2F%2Fid.myopenid.com%2F', $query['openid.claimed_id'] );
  461. $this->assertSame( self::HANDLE, $query['openid.assoc_handle'] );
  462. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com%2Ftest.php', $query['openid.return_to'] );
  463. $this->assertSame( 'http%3A%2F%2Fwww.zf-test.com', $query['openid.trust_root'] );
  464. }
  465. function testSetHttpClient() {
  466. $storage = new Zend_OpenId_Consumer_Storage_File(dirname(__FILE__)."/_files");
  467. $storage->delDiscoveryInfo(self::ID);
  468. $storage->delAssociation(self::SERVER);
  469. $adapter = new Zend_Auth_Adapter_OpenId(self::ID, $storage);
  470. $http = new Zend_Http_Client(null,
  471. array(
  472. 'maxredirects' => 4,
  473. 'timeout' => 15,
  474. 'useragent' => 'Zend_OpenId'
  475. ));
  476. $test = new Zend_Http_Client_Adapter_Test();
  477. $http->setAdapter($test);
  478. $adapter->SetHttpClient($http);
  479. $ret = $adapter->authenticate();
  480. $this->assertSame("GET / HTTP/1.1\r\n".
  481. "Host: id.myopenid.com\r\n".
  482. "Connection: close\r\n".
  483. "Accept-encoding: gzip, deflate\r\n".
  484. "User-Agent: Zend_OpenId\r\n\r\n",
  485. $http->getLastRequest());
  486. }
  487. }