123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- <?php
- namespace League\OAuth1\Client\Tests;
- use League\OAuth1\Client\Credentials\ClientCredentialsInterface;
- use League\OAuth1\Client\Credentials\RsaClientCredentials;
- use League\OAuth1\Client\Signature\RsaSha1Signature;
- use Mockery;
- use PHPUnit\Framework\TestCase;
- class RsaSha1SignatureTest extends TestCase
- {
- public function testMethod()
- {
- $signature = new RsaSha1Signature($this->getClientCredentials());
- $this->assertEquals('RSA-SHA1', $signature->method());
- }
- public function testSigningRequest()
- {
- $signature = new RsaSha1Signature($this->getClientCredentials());
- $uri = 'http://www.example.com/?qux=corge';
- $parameters = ['foo' => 'bar', 'baz' => null];
- $this->assertEquals('h8vpV4CYnLwss+rWicKE4sY6AiW2+DT6Fe7qB8jA7LSLhX5jvLEeX1D8E2ynSePSksAY48j+OSLu9vo5juS2duwNK8UA2Rtnnvuj6UFxpx70dpjHAsQg6EbycGptL/SChDkxfpG8LhuwX1FlFa+H0jLYXI5Dy8j90g51GRJbj48=', $signature->sign($uri, $parameters));
- }
- public function testQueryStringFromArray()
- {
- $array = ['a' => 'b'];
- $res = $this->invokeQueryStringFromData($array);
- $this->assertSame(
- 'a%3Db',
- $res
- );
- }
- public function testQueryStringFromIndexedArray()
- {
- $array = ['a', 'b'];
- $res = $this->invokeQueryStringFromData($array);
- $this->assertSame(
- '0%3Da%261%3Db',
- $res
- );
- }
- public function testQueryStringFromMultiDimensionalArray()
- {
- $array = [
- 'a' => [
- 'b' => [
- 'c' => 'd',
- ],
- 'e' => [
- 'f' => 'g',
- ],
- ],
- 'h' => 'i',
- 'empty' => '',
- 'null' => null,
- 'false' => false,
- ];
- // Convert to query string.
- $res = $this->invokeQueryStringFromData($array);
- $this->assertSame(
- 'a%5Bb%5D%5Bc%5D%3Dd%26a%5Be%5D%5Bf%5D%3Dg%26h%3Di%26empty%3D%26null%3D%26false%3D',
- $res
- );
- // Reverse engineer the string.
- $res = urldecode($res);
- $this->assertSame(
- 'a[b][c]=d&a[e][f]=g&h=i&empty=&null=&false=',
- $res
- );
- // Finally, parse the string back to an array.
- parse_str($res, $original_array);
- // And ensure it matches the orignal array (approximately).
- $this->assertSame(
- [
- 'a' => [
- 'b' => [
- 'c' => 'd',
- ],
- 'e' => [
- 'f' => 'g',
- ],
- ],
- 'h' => 'i',
- 'empty' => '',
- 'null' => '', // null value gets lost in string translation
- 'false' => '', // false value gets lost in string translation
- ],
- $original_array
- );
- }
- public function testSigningRequestWithMultiDimensionalParams()
- {
- $signature = new RsaSha1Signature($this->getClientCredentials());
- $uri = 'http://www.example.com/';
- $parameters = [
- 'a' => [
- 'b' => [
- 'c' => 'd',
- ],
- 'e' => [
- 'f' => 'g',
- ],
- ],
- 'h' => 'i',
- 'empty' => '',
- 'null' => null,
- 'false' => false,
- ];
- $this->assertEquals('X9EkmOEbA5CoF2Hicf3ciAumpp1zkKxnVZkh/mEwWyF2DDcrfou9XF11WvbBu3G4loJGeX4GY1FsIrQpsjEILbn0e7Alyii/x8VA9mBwdqMhQVl49jF0pdowocc03M04cAbAOMNObT7tMmDs+YTFgRxEGCiUkq9AizP1cW3+eBo=', $signature->sign($uri, $parameters));
- }
- protected function invokeQueryStringFromData(array $args)
- {
- $signature = new RsaSha1Signature(Mockery::mock(ClientCredentialsInterface::class));
- $refl = new \ReflectionObject($signature);
- $method = $refl->getMethod('queryStringFromData');
- $method->setAccessible(true);
- return $method->invokeArgs($signature, [$args]);
- }
- protected function getClientCredentials()
- {
- $credentials = new RsaClientCredentials();
- $credentials->setRsaPublicKey(__DIR__ . '/test_rsa_publickey.pem');
- $credentials->setRsaPrivateKey(__DIR__ . '/test_rsa_privatekey.pem');
- return $credentials;
- }
- }
|