RsaSha1SignatureTest.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. namespace League\OAuth1\Client\Tests;
  3. use League\OAuth1\Client\Credentials\ClientCredentialsInterface;
  4. use League\OAuth1\Client\Credentials\RsaClientCredentials;
  5. use League\OAuth1\Client\Signature\RsaSha1Signature;
  6. use Mockery;
  7. use PHPUnit\Framework\TestCase;
  8. class RsaSha1SignatureTest extends TestCase
  9. {
  10. public function testMethod()
  11. {
  12. $signature = new RsaSha1Signature($this->getClientCredentials());
  13. $this->assertEquals('RSA-SHA1', $signature->method());
  14. }
  15. public function testSigningRequest()
  16. {
  17. $signature = new RsaSha1Signature($this->getClientCredentials());
  18. $uri = 'http://www.example.com/?qux=corge';
  19. $parameters = ['foo' => 'bar', 'baz' => null];
  20. $this->assertEquals('h8vpV4CYnLwss+rWicKE4sY6AiW2+DT6Fe7qB8jA7LSLhX5jvLEeX1D8E2ynSePSksAY48j+OSLu9vo5juS2duwNK8UA2Rtnnvuj6UFxpx70dpjHAsQg6EbycGptL/SChDkxfpG8LhuwX1FlFa+H0jLYXI5Dy8j90g51GRJbj48=', $signature->sign($uri, $parameters));
  21. }
  22. public function testQueryStringFromArray()
  23. {
  24. $array = ['a' => 'b'];
  25. $res = $this->invokeQueryStringFromData($array);
  26. $this->assertSame(
  27. 'a%3Db',
  28. $res
  29. );
  30. }
  31. public function testQueryStringFromIndexedArray()
  32. {
  33. $array = ['a', 'b'];
  34. $res = $this->invokeQueryStringFromData($array);
  35. $this->assertSame(
  36. '0%3Da%261%3Db',
  37. $res
  38. );
  39. }
  40. public function testQueryStringFromMultiDimensionalArray()
  41. {
  42. $array = [
  43. 'a' => [
  44. 'b' => [
  45. 'c' => 'd',
  46. ],
  47. 'e' => [
  48. 'f' => 'g',
  49. ],
  50. ],
  51. 'h' => 'i',
  52. 'empty' => '',
  53. 'null' => null,
  54. 'false' => false,
  55. ];
  56. // Convert to query string.
  57. $res = $this->invokeQueryStringFromData($array);
  58. $this->assertSame(
  59. 'a%5Bb%5D%5Bc%5D%3Dd%26a%5Be%5D%5Bf%5D%3Dg%26h%3Di%26empty%3D%26null%3D%26false%3D',
  60. $res
  61. );
  62. // Reverse engineer the string.
  63. $res = urldecode($res);
  64. $this->assertSame(
  65. 'a[b][c]=d&a[e][f]=g&h=i&empty=&null=&false=',
  66. $res
  67. );
  68. // Finally, parse the string back to an array.
  69. parse_str($res, $original_array);
  70. // And ensure it matches the orignal array (approximately).
  71. $this->assertSame(
  72. [
  73. 'a' => [
  74. 'b' => [
  75. 'c' => 'd',
  76. ],
  77. 'e' => [
  78. 'f' => 'g',
  79. ],
  80. ],
  81. 'h' => 'i',
  82. 'empty' => '',
  83. 'null' => '', // null value gets lost in string translation
  84. 'false' => '', // false value gets lost in string translation
  85. ],
  86. $original_array
  87. );
  88. }
  89. public function testSigningRequestWithMultiDimensionalParams()
  90. {
  91. $signature = new RsaSha1Signature($this->getClientCredentials());
  92. $uri = 'http://www.example.com/';
  93. $parameters = [
  94. 'a' => [
  95. 'b' => [
  96. 'c' => 'd',
  97. ],
  98. 'e' => [
  99. 'f' => 'g',
  100. ],
  101. ],
  102. 'h' => 'i',
  103. 'empty' => '',
  104. 'null' => null,
  105. 'false' => false,
  106. ];
  107. $this->assertEquals('X9EkmOEbA5CoF2Hicf3ciAumpp1zkKxnVZkh/mEwWyF2DDcrfou9XF11WvbBu3G4loJGeX4GY1FsIrQpsjEILbn0e7Alyii/x8VA9mBwdqMhQVl49jF0pdowocc03M04cAbAOMNObT7tMmDs+YTFgRxEGCiUkq9AizP1cW3+eBo=', $signature->sign($uri, $parameters));
  108. }
  109. protected function invokeQueryStringFromData(array $args)
  110. {
  111. $signature = new RsaSha1Signature(Mockery::mock(ClientCredentialsInterface::class));
  112. $refl = new \ReflectionObject($signature);
  113. $method = $refl->getMethod('queryStringFromData');
  114. $method->setAccessible(true);
  115. return $method->invokeArgs($signature, [$args]);
  116. }
  117. protected function getClientCredentials()
  118. {
  119. $credentials = new RsaClientCredentials();
  120. $credentials->setRsaPublicKey(__DIR__ . '/test_rsa_publickey.pem');
  121. $credentials->setRsaPrivateKey(__DIR__ . '/test_rsa_privatekey.pem');
  122. return $credentials;
  123. }
  124. }