PageRenderTime 62ms CodeModel.GetById 25ms RepoModel.GetById 0ms app.codeStats 0ms

/concrete/vendor/lusitanian/oauth/src/OAuth/OAuth2/Service/Facebook.php

https://gitlab.com/koodersmiikka/operaatio-terveys
PHP | 193 lines | 150 code | 17 blank | 26 comment | 7 complexity | 03536252bdbdf73407403216d92f881d MD5 | raw file
  1. <?php
  2. namespace OAuth\OAuth2\Service;
  3. use OAuth\Common\Exception\Exception;
  4. use OAuth\OAuth2\Token\StdOAuth2Token;
  5. use OAuth\Common\Http\Exception\TokenResponseException;
  6. use OAuth\Common\Http\Uri\Uri;
  7. use OAuth\Common\Consumer\CredentialsInterface;
  8. use OAuth\Common\Http\Client\ClientInterface;
  9. use OAuth\Common\Storage\TokenStorageInterface;
  10. use OAuth\Common\Http\Uri\UriInterface;
  11. class Facebook extends AbstractService
  12. {
  13. /**
  14. * Facebook www url - used to build dialog urls
  15. */
  16. const WWW_URL = 'https://www.facebook.com/';
  17. /**
  18. * Defined scopes
  19. *
  20. * If you don't think this is scary you should not be allowed on the web at all
  21. *
  22. * @link https://developers.facebook.com/docs/reference/login/
  23. * @link https://developers.facebook.com/tools/explorer For a list of permissions use 'Get Access Token'
  24. */
  25. // email scopes
  26. const SCOPE_EMAIL = 'email';
  27. // extended permissions
  28. const SCOPE_READ_FRIENDLIST = 'read_friendlists';
  29. const SCOPE_READ_INSIGHTS = 'read_insights';
  30. const SCOPE_READ_MAILBOX = 'read_mailbox';
  31. const SCOPE_READ_PAGE_MAILBOXES = 'read_page_mailboxes';
  32. const SCOPE_READ_REQUESTS = 'read_requests';
  33. const SCOPE_READ_STREAM = 'read_stream';
  34. const SCOPE_VIDEO_UPLOAD = 'video_upload';
  35. const SCOPE_XMPP_LOGIN = 'xmpp_login';
  36. const SCOPE_USER_ONLINE_PRESENCE = 'user_online_presence';
  37. const SCOPE_FRIENDS_ONLINE_PRESENCE = 'friends_online_presence';
  38. const SCOPE_ADS_MANAGEMENT = 'ads_management';
  39. const SCOPE_ADS_READ = 'ads_read';
  40. const SCOPE_CREATE_EVENT = 'create_event';
  41. const SCOPE_CREATE_NOTE = 'create_note';
  42. const SCOPE_EXPORT_STREAM = 'export_stream';
  43. const SCOPE_MANAGE_FRIENDLIST = 'manage_friendlists';
  44. const SCOPE_MANAGE_NOTIFICATIONS = 'manage_notifications';
  45. const SCOPE_PHOTO_UPLOAD = 'photo_upload';
  46. const SCOPE_PUBLISH_ACTIONS = 'publish_actions';
  47. const SCOPE_PUBLISH_CHECKINS = 'publish_checkins';
  48. const SCOPE_PUBLISH_STREAM = 'publish_stream';
  49. const SCOPE_RSVP_EVENT = 'rsvp_event';
  50. const SCOPE_SHARE_ITEM = 'share_item';
  51. const SCOPE_SMS = 'sms';
  52. const SCOPE_STATUS_UPDATE = 'status_update';
  53. // Extended Profile Properties
  54. const SCOPE_USER_FRIENDS = 'user_friends';
  55. const SCOPE_USER_ABOUT = 'user_about_me';
  56. const SCOPE_FRIENDS_ABOUT = 'friends_about_me';
  57. const SCOPE_USER_ACTIVITIES = 'user_activities';
  58. const SCOPE_FRIENDS_ACTIVITIES = 'friends_activities';
  59. const SCOPE_USER_BIRTHDAY = 'user_birthday';
  60. const SCOPE_FRIENDS_BIRTHDAY = 'friends_birthday';
  61. const SCOPE_USER_CHECKINS = 'user_checkins';
  62. const SCOPE_FRIENDS_CHECKINS = 'friends_checkins';
  63. const SCOPE_USER_EDUCATION = 'user_education_history';
  64. const SCOPE_FRIENDS_EDUCATION = 'friends_education_history';
  65. const SCOPE_USER_EVENTS = 'user_events';
  66. const SCOPE_FRIENDS_EVENTS = 'friends_events';
  67. const SCOPE_USER_GROUPS = 'user_groups';
  68. const SCOPE_FRIENDS_GROUPS = 'friends_groups';
  69. const SCOPE_USER_HOMETOWN = 'user_hometown';
  70. const SCOPE_FRIENDS_HOMETOWN = 'friends_hometown';
  71. const SCOPE_USER_INTERESTS = 'user_interests';
  72. const SCOPE_FRIEND_INTERESTS = 'friends_interests';
  73. const SCOPE_USER_LIKES = 'user_likes';
  74. const SCOPE_FRIENDS_LIKES = 'friends_likes';
  75. const SCOPE_USER_LOCATION = 'user_location';
  76. const SCOPE_FRIENDS_LOCATION = 'friends_location';
  77. const SCOPE_USER_NOTES = 'user_notes';
  78. const SCOPE_FRIENDS_NOTES = 'friends_notes';
  79. const SCOPE_USER_PHOTOS = 'user_photos';
  80. const SCOPE_USER_PHOTO_VIDEO_TAGS = 'user_photo_video_tags';
  81. const SCOPE_FRIENDS_PHOTOS = 'friends_photos';
  82. const SCOPE_FRIENDS_PHOTO_VIDEO_TAGS = 'friends_photo_video_tags';
  83. const SCOPE_USER_QUESTIONS = 'user_questions';
  84. const SCOPE_FRIENDS_QUESTIONS = 'friends_questions';
  85. const SCOPE_USER_RELATIONSHIPS = 'user_relationships';
  86. const SCOPE_FRIENDS_RELATIONSHIPS = 'friends_relationships';
  87. const SCOPE_USER_RELATIONSHIPS_DETAILS = 'user_relationship_details';
  88. const SCOPE_FRIENDS_RELATIONSHIPS_DETAILS = 'friends_relationship_details';
  89. const SCOPE_USER_RELIGION = 'user_religion_politics';
  90. const SCOPE_FRIENDS_RELIGION = 'friends_religion_politics';
  91. const SCOPE_USER_STATUS = 'user_status';
  92. const SCOPE_FRIENDS_STATUS = 'friends_status';
  93. const SCOPE_USER_SUBSCRIPTIONS = 'user_subscriptions';
  94. const SCOPE_FRIENDS_SUBSCRIPTIONS = 'friends_subscriptions';
  95. const SCOPE_USER_VIDEOS = 'user_videos';
  96. const SCOPE_FRIENDS_VIDEOS = 'friends_videos';
  97. const SCOPE_USER_WEBSITE = 'user_website';
  98. const SCOPE_FRIENDS_WEBSITE = 'friends_website';
  99. const SCOPE_USER_WORK = 'user_work_history';
  100. const SCOPE_FRIENDS_WORK = 'friends_work_history';
  101. // Open Graph Permissions
  102. const SCOPE_USER_MUSIC = 'user_actions.music';
  103. const SCOPE_FRIENDS_MUSIC = 'friends_actions.music';
  104. const SCOPE_USER_NEWS = 'user_actions.news';
  105. const SCOPE_FRIENDS_NEWS = 'friends_actions.news';
  106. const SCOPE_USER_VIDEO = 'user_actions.video';
  107. const SCOPE_FRIENDS_VIDEO = 'friends_actions.video';
  108. const SCOPE_USER_APP = 'user_actions:APP_NAMESPACE';
  109. const SCOPE_FRIENDS_APP = 'friends_actions:APP_NAMESPACE';
  110. const SCOPE_USER_GAMES = 'user_games_activity';
  111. const SCOPE_FRIENDS_GAMES = 'friends_games_activity';
  112. //Page Permissions
  113. const SCOPE_PAGES = 'manage_pages';
  114. public function __construct(
  115. CredentialsInterface $credentials,
  116. ClientInterface $httpClient,
  117. TokenStorageInterface $storage,
  118. $scopes = array(),
  119. UriInterface $baseApiUri = null
  120. ) {
  121. parent::__construct($credentials, $httpClient, $storage, $scopes, $baseApiUri);
  122. if (null === $baseApiUri) {
  123. $this->baseApiUri = new Uri('https://graph.facebook.com/');
  124. }
  125. }
  126. /**
  127. * {@inheritdoc}
  128. */
  129. public function getAuthorizationEndpoint()
  130. {
  131. return new Uri('https://www.facebook.com/dialog/oauth');
  132. }
  133. /**
  134. * {@inheritdoc}
  135. */
  136. public function getAccessTokenEndpoint()
  137. {
  138. return new Uri('https://graph.facebook.com/oauth/access_token');
  139. }
  140. /**
  141. * {@inheritdoc}
  142. */
  143. protected function parseAccessTokenResponse($responseBody)
  144. {
  145. // Facebook gives us a query string ... Oh wait. JSON is too simple, understand ?
  146. parse_str($responseBody, $data);
  147. if (null === $data || !is_array($data)) {
  148. throw new TokenResponseException('Unable to parse response.');
  149. } elseif (isset($data['error'])) {
  150. throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"');
  151. }
  152. $token = new StdOAuth2Token();
  153. $token->setAccessToken($data['access_token']);
  154. if (isset($data['expires'])) {
  155. $token->setLifeTime($data['expires']);
  156. }
  157. if (isset($data['refresh_token'])) {
  158. $token->setRefreshToken($data['refresh_token']);
  159. unset($data['refresh_token']);
  160. }
  161. unset($data['access_token']);
  162. unset($data['expires']);
  163. $token->setExtraParams($data);
  164. return $token;
  165. }
  166. public function getDialogUri($dialogPath, array $parameters)
  167. {
  168. if (!isset($parameters['redirect_uri'])) {
  169. throw new Exception("Redirect uri is mandatory for this request");
  170. }
  171. $parameters['app_id'] = $this->credentials->getConsumerId();
  172. $baseUrl = self::WWW_URL . 'dialog/' . $dialogPath;
  173. $query = http_build_query($parameters);
  174. return new Uri($baseUrl . '?' . $query);
  175. }
  176. }