123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255 |
- <?php namespace League\OAuth1\Client\Tests;
- use InvalidArgumentException;
- use League\OAuth1\Client\Credentials\ClientCredentials;
- use League\OAuth1\Client\Server\Xing;
- use Mockery as m;
- use PHPUnit\Framework\TestCase;
- use Psr\Http\Message\ResponseInterface;
- class XingTest extends TestCase
- {
- protected function tearDown(): void
- {
- m::close();
- parent::tearDown();
- }
- public function testCreatingWithArray()
- {
- $server = new Xing($this->getMockClientCredentials());
- $credentials = $server->getClientCredentials();
- $this->assertInstanceOf('League\OAuth1\Client\Credentials\ClientCredentialsInterface', $credentials);
- $this->assertEquals($this->getApplicationKey(), $credentials->getIdentifier());
- $this->assertEquals('mysecret', $credentials->getSecret());
- $this->assertEquals('http://app.dev/', $credentials->getCallbackUri());
- }
- public function testCreatingWithObject()
- {
- $credentials = new ClientCredentials;
- $credentials->setIdentifier('myidentifier');
- $credentials->setSecret('mysecret');
- $credentials->setCallbackUri('http://app.dev/');
- $server = new Xing($credentials);
- $this->assertEquals($credentials, $server->getClientCredentials());
- }
- public function testGettingTemporaryCredentials()
- {
- $server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient]', [$this->getMockClientCredentials()]);
- $server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
- $me = $this;
- $client->shouldReceive('post')->with('https://api.xing.com/v1/request_token', m::on(function ($options) use ($me) {
- $headers = $options['headers'];
- $me->assertTrue(isset($headers['Authorization']));
- // OAuth protocol specifies a strict number of
- // headers should be sent, in the correct order.
- // We'll validate that here.
- $pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_callback="' . preg_quote('http%3A%2F%2Fapp.dev%2F', '/') . '", oauth_signature=".*?"/';
- $matches = preg_match($pattern, $headers['Authorization']);
- $me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
- return true;
- }))->once()->andReturn($response = m::mock(ResponseInterface::class));
- $response->shouldReceive('getBody')->andReturn('oauth_token=temporarycredentialsidentifier&oauth_token_secret=temporarycredentialssecret&oauth_callback_confirmed=true');
- $credentials = $server->getTemporaryCredentials();
- $this->assertInstanceOf('League\OAuth1\Client\Credentials\TemporaryCredentials', $credentials);
- $this->assertEquals('temporarycredentialsidentifier', $credentials->getIdentifier());
- $this->assertEquals('temporarycredentialssecret', $credentials->getSecret());
- }
- public function testGettingDefaultAuthorizationUrl()
- {
- $server = new Xing($this->getMockClientCredentials());
- $expected = 'https://api.xing.com/v1/authorize?oauth_token=foo';
- $this->assertEquals($expected, $server->getAuthorizationUrl('foo'));
- $credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
- $credentials->shouldReceive('getIdentifier')->andReturn('foo');
- $this->assertEquals($expected, $server->getAuthorizationUrl($credentials));
- }
- public function testGettingTokenCredentialsFailsWithManInTheMiddle()
- {
- $server = new Xing($this->getMockClientCredentials());
- $credentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
- $credentials->shouldReceive('getIdentifier')->andReturn('foo');
- $this->expectException(InvalidArgumentException::class);
- $server->getTokenCredentials($credentials, 'bar', 'verifier');
- }
- public function testGettingTokenCredentials()
- {
- $server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient]', [$this->getMockClientCredentials()]);
- $temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TemporaryCredentials');
- $temporaryCredentials->shouldReceive('getIdentifier')->andReturn('temporarycredentialsidentifier');
- $temporaryCredentials->shouldReceive('getSecret')->andReturn('temporarycredentialssecret');
- $server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
- $me = $this;
- $client->shouldReceive('post')->with('https://api.xing.com/v1/access_token', m::on(function ($options) use ($me) {
- $headers = $options['headers'];
- $body = $options['form_params'];
- $me->assertTrue(isset($headers['Authorization']));
- // OAuth protocol specifies a strict number of
- // headers should be sent, in the correct order.
- // We'll validate that here.
- $pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="temporarycredentialsidentifier", oauth_signature=".*?"/';
- $matches = preg_match($pattern, $headers['Authorization']);
- $me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
- $me->assertSame($body, ['oauth_verifier' => 'myverifiercode']);
- return true;
- }))->once()->andReturn($response = m::mock(ResponseInterface::class));
- $response->shouldReceive('getBody')->andReturn('oauth_token=tokencredentialsidentifier&oauth_token_secret=tokencredentialssecret');
- $credentials = $server->getTokenCredentials($temporaryCredentials, 'temporarycredentialsidentifier', 'myverifiercode');
- $this->assertInstanceOf('League\OAuth1\Client\Credentials\TokenCredentials', $credentials);
- $this->assertEquals('tokencredentialsidentifier', $credentials->getIdentifier());
- $this->assertEquals('tokencredentialssecret', $credentials->getSecret());
- }
- public function testGettingUserDetails()
- {
- $server = m::mock('League\OAuth1\Client\Server\Xing[createHttpClient,protocolHeader]', [$this->getMockClientCredentials()]);
- $temporaryCredentials = m::mock('League\OAuth1\Client\Credentials\TokenCredentials');
- $temporaryCredentials->shouldReceive('getIdentifier')->andReturn('tokencredentialsidentifier');
- $temporaryCredentials->shouldReceive('getSecret')->andReturn('tokencredentialssecret');
- $server->shouldReceive('createHttpClient')->andReturn($client = m::mock('stdClass'));
- $me = $this;
- $client->shouldReceive('get')->with('https://api.xing.com/v1/users/me', m::on(function ($options) use ($me) {
- $headers = $options['headers'];
- $me->assertTrue(isset($headers['Authorization']));
- // OAuth protocol specifies a strict number of
- // headers should be sent, in the correct order.
- // We'll validate that here.
- $pattern = '/OAuth oauth_consumer_key=".*?", oauth_nonce="[a-zA-Z0-9]+", oauth_signature_method="HMAC-SHA1", oauth_timestamp="\d{10}", oauth_version="1.0", oauth_token="tokencredentialsidentifier", oauth_signature=".*?"/';
- $matches = preg_match($pattern, $headers['Authorization']);
- $me->assertEquals(1, $matches, 'Asserting that the authorization header contains the correct expression.');
- return true;
- }))->once()->andReturn($response = m::mock(ResponseInterface::class));
- $response->shouldReceive('getBody')->once()->andReturn($this->getUserPayload());
- $user = $server->getUserDetails($temporaryCredentials);
- $this->assertInstanceOf('League\OAuth1\Client\Server\User', $user);
- $this->assertEquals('Roman Gelembjuk', $user->name);
- $this->assertEquals('17144430_0f9409', $server->getUserUid($temporaryCredentials));
- $this->assertEquals('XXXXXXXXXX@gmail.com', $server->getUserEmail($temporaryCredentials));
- $this->assertEquals('Roman Gelembjuk', $server->getUserScreenName($temporaryCredentials));
- }
- protected function getMockClientCredentials()
- {
- return [
- 'identifier' => $this->getApplicationKey(),
- 'secret' => 'mysecret',
- 'callback_uri' => 'http://app.dev/',
- ];
- }
- protected function getApplicationKey()
- {
- return 'abcdefghijk';
- }
- protected function getApplicationExpiration($days = 0)
- {
- return is_numeric($days) && $days > 0 ? $days . 'day' . ($days == 1 ? '' : 's') : 'never';
- }
- protected function getApplicationName()
- {
- return 'fizz buzz';
- }
- private function getUserPayload()
- {
- return '{
- "users":[
- {
- "id":"17144430_0f9409",
- "active_email":"XXXXXXXXXX@gmail.com",
- "time_zone":
- {
- "utc_offset":3.0,
- "name":"Europe/Kiev"
- },
- "display_name":"Roman Gelembjuk",
- "first_name":"Roman",
- "last_name":"Gelembjuk",
- "gender":"m",
- "page_name":"Roman_Gelembjuk",
- "birth_date":
- {"year":null,"month":null,"day":null},
- "wants":null,
- "haves":null,
- "interests":null,
- "web_profiles":{},
- "badges":[],
- "photo_urls":
- {
- "large":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.140x185.jpg",
- "maxi_thumb":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.70x93.jpg",
- "medium_thumb":"https://x1.xingassets.com/assets/frontend_minified/img/users/nobody_m.57x75.jpg"
- },
- "permalink":"https://www.xing.com/profile/Roman_Gelembjuk",
- "languages":{"en":null},
- "employment_status":"EMPLOYEE",
- "organisation_member":null,
- "instant_messaging_accounts":{},
- "educational_background":
- {"degree":null,"primary_school":null,"schools":[],"qualifications":[]},
- "private_address":{
- "street":null,
- "zip_code":null,
- "city":null,
- "province":null,
- "country":null,
- "email":"XXXXXXXX@gmail.com",
- "fax":null,
- "phone":null,
- "mobile_phone":null}
- ,"business_address":
- {
- "street":null,
- "zip_code":null,
- "city":"Ivano-Frankivsk",
- "province":null,
- "country":"UA",
- "email":null,
- "fax":null,"phone":null,"mobile_phone":null
- },
- "premium_services":[]
- }]}';
- }
- }
|