PAPE.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?php
  2. require_once "PHPUnit.php";
  3. require_once "Auth/OpenID/PAPE.php";
  4. require_once "Auth/OpenID/Message.php";
  5. require_once "Auth/OpenID/Server.php";
  6. class PapeRequestTestCase extends PHPUnit_TestCase {
  7. function setUp()
  8. {
  9. $this->req = new Auth_OpenID_PAPE_Request();
  10. }
  11. function test_construct()
  12. {
  13. $this->assertEquals(array(), $this->req->preferred_auth_policies);
  14. $this->assertEquals(null, $this->req->max_auth_age);
  15. $this->assertEquals('pape', $this->req->ns_alias);
  16. $req2 = new Auth_OpenID_PAPE_Request(array(PAPE_AUTH_MULTI_FACTOR), 1000);
  17. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $req2->preferred_auth_policies);
  18. $this->assertEquals(1000, $req2->max_auth_age);
  19. }
  20. function test_add_policy_uri()
  21. {
  22. $this->assertEquals(array(), $this->req->preferred_auth_policies);
  23. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  24. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->preferred_auth_policies);
  25. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  26. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->preferred_auth_policies);
  27. $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT);
  28. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT),
  29. $this->req->preferred_auth_policies);
  30. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  31. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT),
  32. $this->req->preferred_auth_policies);
  33. }
  34. function test_getExtensionArgs() {
  35. $this->assertEquals(array('preferred_auth_policies' => ''), $this->req->getExtensionArgs());
  36. $this->req->addPolicyURI('http://uri');
  37. $this->assertEquals(array('preferred_auth_policies' => 'http://uri'), $this->req->getExtensionArgs());
  38. $this->req->addPolicyURI('http://zig');
  39. $this->assertEquals(array('preferred_auth_policies' => 'http://uri http://zig'), $this->req->getExtensionArgs());
  40. $this->req->max_auth_age = 789;
  41. $this->assertEquals(array('preferred_auth_policies' => 'http://uri http://zig', 'max_auth_age' => '789'), $this->req->getExtensionArgs());
  42. }
  43. function test_parseExtensionArgs() {
  44. $args = array('preferred_auth_policies' => 'http://foo http://bar',
  45. 'max_auth_age' => '9');
  46. $this->req->parseExtensionArgs($args);
  47. $this->assertEquals(9, $this->req->max_auth_age);
  48. $this->assertEquals(array('http://foo','http://bar'), $this->req->preferred_auth_policies);
  49. }
  50. function test_parseExtensionArgs_empty() {
  51. $this->req->parseExtensionArgs(array());
  52. $this->assertEquals(null, $this->req->max_auth_age);
  53. $this->assertEquals(array(), $this->req->preferred_auth_policies);
  54. }
  55. function test_fromOpenIDRequest() {
  56. $openid_req_msg = Auth_OpenID_Message::fromOpenIDArgs(array(
  57. 'mode' => 'checkid_setup',
  58. 'ns' => Auth_OpenID_OPENID2_NS,
  59. 'ns.pape' => Auth_OpenID_PAPE_NS_URI,
  60. 'pape.preferred_auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)),
  61. 'pape.max_auth_age' => '5476'
  62. ));
  63. $oid_req = new Auth_OpenID_Request();
  64. $oid_req->message = $openid_req_msg;
  65. $req = Auth_OpenID_PAPE_Request::fromOpenIDRequest($oid_req);
  66. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $req->preferred_auth_policies);
  67. $this->assertEquals(5476, $req->max_auth_age);
  68. }
  69. function test_fromOpenIDRequest_no_pape() {
  70. $message = new Auth_OpenID_Message();
  71. $openid_req = new Auth_OpenID_Request();
  72. $openid_req->message = $message;
  73. $pape_req = Auth_OpenID_PAPE_Request::fromOpenIDRequest($openid_req);
  74. $this->assertTrue($pape_req === null);
  75. }
  76. function test_preferred_types() {
  77. $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT);
  78. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  79. $pt = $this->req->preferredTypes(array(PAPE_AUTH_MULTI_FACTOR,
  80. PAPE_AUTH_MULTI_FACTOR_PHYSICAL));
  81. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $pt);
  82. }
  83. }
  84. class PAPE_DummySuccessResponse {
  85. function PAPE_DummySuccessResponse($message, $signed_stuff)
  86. {
  87. $this->message = $message;
  88. $this->signed_stuff = $signed_stuff;
  89. }
  90. function getSignedNS($ns_uri)
  91. {
  92. return $this->signed_stuff;
  93. }
  94. }
  95. class PapeResponseTestCase extends PHPUnit_TestCase {
  96. function setUp() {
  97. $this->req = new Auth_OpenID_PAPE_Response();
  98. }
  99. function test_construct() {
  100. $this->assertEquals(array(), $this->req->auth_policies);
  101. $this->assertEquals(null, $this->req->auth_time);
  102. $this->assertEquals('pape', $this->req->ns_alias);
  103. $this->assertEquals(null, $this->req->nist_auth_level);
  104. $req2 = new Auth_OpenID_PAPE_Response(array(PAPE_AUTH_MULTI_FACTOR),
  105. '2001-01-01T04:05:23Z',
  106. 3);
  107. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $req2->auth_policies);
  108. $this->assertEquals('2001-01-01T04:05:23Z', $req2->auth_time);
  109. $this->assertEquals(3, $req2->nist_auth_level);
  110. }
  111. function test_add_policy_uri() {
  112. $this->assertEquals(array(), $this->req->auth_policies);
  113. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  114. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->auth_policies);
  115. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  116. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->auth_policies);
  117. $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT);
  118. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $this->req->auth_policies);
  119. $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR);
  120. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $this->req->auth_policies);
  121. }
  122. function test_getExtensionArgs() {
  123. $this->assertEquals(array('auth_policies' => 'none'), $this->req->getExtensionArgs());
  124. $this->req->addPolicyURI('http://uri');
  125. $this->assertEquals(array('auth_policies' => 'http://uri'), $this->req->getExtensionArgs());
  126. $this->req->addPolicyURI('http://zig');
  127. $this->assertEquals(array('auth_policies' => 'http://uri http://zig'), $this->req->getExtensionArgs());
  128. $this->req->auth_time = '2008-03-02T12:34:56Z';
  129. $this->assertEquals(array('auth_policies' => 'http://uri http://zig', 'auth_time' => '2008-03-02T12:34:56Z'), $this->req->getExtensionArgs());
  130. $this->req->nist_auth_level = 3;
  131. $this->assertEquals(array('auth_policies' => 'http://uri http://zig', 'auth_time' => '2008-03-02T12:34:56Z', 'nist_auth_level' => '3'), $this->req->getExtensionArgs());
  132. }
  133. function test_getExtensionArgs_error_auth_age() {
  134. $this->req->auth_time = "foo2008-03-02T12:34:56Z";
  135. $this->assertEquals(false, $this->req->getExtensionArgs());
  136. $this->req->auth_time = "2008-03-02T12:34:56Zbar";
  137. $this->assertEquals(false, $this->req->getExtensionArgs());
  138. }
  139. function test_getExtensionArgs_error_nist_auth_level() {
  140. $this->req->nist_auth_level = "high as a kite";
  141. $this->assertEquals(false, $this->req->getExtensionArgs());
  142. $this->req->nist_auth_level = 5;
  143. $this->assertEquals(false, $this->req->getExtensionArgs());
  144. $this->req->nist_auth_level = -1;
  145. $this->assertEquals(false, $this->req->getExtensionArgs());
  146. }
  147. function test_parseExtensionArgs() {
  148. $args = array('auth_policies' => 'http://foo http://bar',
  149. 'auth_time' => '2008-03-02T12:34:56Z');
  150. $this->req->parseExtensionArgs($args);
  151. $this->assertEquals('2008-03-02T12:34:56Z', $this->req->auth_time);
  152. $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies);
  153. }
  154. function test_parseExtensionArgs_empty() {
  155. $this->req->parseExtensionArgs(array());
  156. $this->assertEquals(null, $this->req->auth_time);
  157. $this->assertEquals(array(), $this->req->auth_policies);
  158. }
  159. function test_parseExtensionArgs_strict_bogus1() {
  160. $args = array('auth_policies' => 'http://foo http://bar',
  161. 'auth_time' => 'yesterday');
  162. $this->assertEquals(false, $this->req->parseExtensionArgs($args, true));
  163. }
  164. function test_parseExtensionArgs_strict_bogus2() {
  165. $args = array('auth_policies' => 'http://foo http://bar',
  166. 'auth_time' => '63',
  167. 'nist_auth_level' => 'some');
  168. $this->assertEquals(false, $this->req->parseExtensionArgs($args, true));
  169. }
  170. function test_parseExtensionArgs_strict_good() {
  171. $args = array('auth_policies' => 'http://foo http://bar',
  172. 'auth_time' => '2008-03-02T12:34:56Z',
  173. 'nist_auth_level' => '0');
  174. $this->req->parseExtensionArgs($args, true);
  175. $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies);
  176. $this->assertEquals('2008-03-02T12:34:56Z', $this->req->auth_time);
  177. $this->assertEquals(0, $this->req->nist_auth_level);
  178. }
  179. function test_parseExtensionArgs_nostrict_bogus() {
  180. $args = array('auth_policies' => 'http://foo http://bar',
  181. 'auth_time' => 'the other day',
  182. 'nist_auth_level' => 'some');
  183. $this->req->parseExtensionArgs($args);
  184. $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies);
  185. $this->assertEquals(null, $this->req->auth_time);
  186. $this->assertEquals(null, $this->req->nist_auth_level);
  187. }
  188. function test_fromSuccessResponse() {
  189. $openid_req_msg = Auth_OpenID_Message::fromOpenIDArgs(array(
  190. 'mode' => 'id_res',
  191. 'ns' => Auth_OpenID_OPENID2_NS,
  192. 'ns.pape' => Auth_OpenID_PAPE_NS_URI,
  193. 'auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)),
  194. 'auth_time' => '2008-03-02T12:34:56Z'
  195. ));
  196. $signed_stuff = array(
  197. 'auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)),
  198. 'auth_time' => '2008-03-02T12:34:56Z'
  199. );
  200. $oid_req = new PAPE_DummySuccessResponse($openid_req_msg, $signed_stuff);
  201. $req = Auth_OpenID_PAPE_Response::fromSuccessResponse($oid_req);
  202. $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $req->auth_policies);
  203. $this->assertEquals('2008-03-02T12:34:56Z', $req->auth_time);
  204. }
  205. }
  206. class Tests_Auth_OpenID_PAPE extends PHPUnit_TestSuite {
  207. function getName() {
  208. return "Tests_Auth_OpenID_PAPE";
  209. }
  210. function Tests_Auth_OpenID_PAPE() {
  211. $this->addTestSuite('PapeRequestTestCase');
  212. $this->addTestSuite('PapeResponseTestCase');
  213. }
  214. }
  215. ?>