<?php namespace OAuth\OAuth2\Service; use OAuth\OAuth2\Token\StdOAuth2Token; use OAuth\Common\Http\Exception\TokenResponseException; use OAuth\Common\Http\Uri\Uri; use OAuth\Common\Consumer\CredentialsInterface; use OAuth\Common\Http\Client\ClientInterface; use OAuth\Common\Storage\TokenStorageInterface; use OAuth\Common\Http\Uri\UriInterface; class Microsoft extends AbstractService { const SCOPE_BASIC = 'wl.basic'; const SCOPE_OFFLINE = 'wl.offline_access'; const SCOPE_SIGNIN = 'wl.signin'; const SCOPE_BIRTHDAY = 'wl.birthday'; const SCOPE_CALENDARS = 'wl.calendars'; const SCOPE_CALENDARS_UPDATE = 'wl.calendars_update'; const SCOPE_CONTACTS_BIRTHDAY = 'wl.contacts_birthday'; const SCOPE_CONTACTS_CREATE = 'wl.contacts_create'; const SCOPE_CONTACTS_CALENDARS = 'wl.contacts_calendars'; const SCOPE_CONTACTS_PHOTOS = 'wl.contacts_photos'; const SCOPE_CONTACTS_SKYDRIVE = 'wl.contacts_skydrive'; const SCOPE_EMAILS = 'wl.emails'; const SCOPE_EVENTS_CREATE = 'wl.events_create'; const SCOPE_MESSENGER = 'wl.messenger'; const SCOPE_PHONE_NUMBERS = 'wl.phone_numbers'; const SCOPE_PHOTOS = 'wl.photos'; const SCOPE_POSTAL_ADDRESSES = 'wl.postal_addresses'; const SCOPE_SHARE = 'wl.share'; const SCOPE_SKYDRIVE = 'wl.skydrive'; const SCOPE_SKYDRIVE_UPDATE = 'wl.skydrive_update'; const SCOPE_WORK_PROFILE = 'wl.work_profile'; const SCOPE_APPLICATIONS = 'wl.applications'; const SCOPE_APPLICATIONS_CREATE = 'wl.applications_create'; /** * MS uses some magical not officialy supported scope to get even moar info like full emailaddresses. * They agree that giving 3rd party apps access to 3rd party emailaddresses is a pretty lame thing to do so in all * their wisdom they added this scope because fuck you that's why. * * https://github.com/Lusitanian/PHPoAuthLib/issues/214 * http://social.msdn.microsoft.com/Forums/live/en-US/c6dcb9ab-aed4-400a-99fb-5650c393a95d/how-retrieve-users- * contacts-email-address?forum=messengerconnect * * Considering this scope is not officially supported: use with care */ const SCOPE_CONTACTS_EMAILS = 'wl.contacts_emails'; public function __construct( CredentialsInterface $credentials, ClientInterface $httpClient, TokenStorageInterface $storage, $scopes = array(), UriInterface $baseApiUri = null ) { parent::__construct($credentials, $httpClient, $storage, $scopes, $baseApiUri); if (null === $baseApiUri) { $this->baseApiUri = new Uri('https://apis.live.net/v5.0/'); } } /** * {@inheritdoc} */ public function getAuthorizationEndpoint() { return new Uri('https://login.live.com/oauth20_authorize.srf'); } /** * {@inheritdoc} */ public function getAccessTokenEndpoint() { return new Uri('https://login.live.com/oauth20_token.srf'); } /** * {@inheritdoc} */ public function getAuthorizationMethod() { return static::AUTHORIZATION_METHOD_QUERY_STRING; } /** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { $data = json_decode($responseBody, true); if (null === $data || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); $token->setLifetime($data['expires_in']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires_in']); $token->setExtraParams($data); return $token; } }