[ Index ]

PHP Cross Reference of phpBB-3.3.14-deutsch

title

Body

[close]

/vendor/carlos-mg89/oauth/src/OAuth/OAuth2/Service/ -> Netatmo.php (source)

   1  <?php
   2  /**
   3   * Netatmo service.
   4   *
   5   * @author  Pedro Amorim <contact@pamorim.fr>
   6   * @license http://www.opensource.org/licenses/mit-license.html MIT License
   7   *
   8   * @see    https://dev.netatmo.com/doc/
   9   */
  10  
  11  namespace OAuth\OAuth2\Service;
  12  
  13  use OAuth\Common\Consumer\CredentialsInterface;
  14  use OAuth\Common\Http\Client\ClientInterface;
  15  use OAuth\Common\Http\Exception\TokenResponseException;
  16  use OAuth\Common\Http\Uri\Uri;
  17  use OAuth\Common\Http\Uri\UriInterface;
  18  use OAuth\Common\Storage\TokenStorageInterface;
  19  use OAuth\OAuth2\Token\StdOAuth2Token;
  20  
  21  /**
  22   * Netatmo service.
  23   *
  24   * @author  Pedro Amorim <contact@pamorim.fr>
  25   * @license http://www.opensource.org/licenses/mit-license.html MIT License
  26   *
  27   * @see    https://dev.netatmo.com/doc/
  28   */
  29  class Netatmo extends AbstractService
  30  {
  31      /**
  32       * SCOPES.
  33       *
  34       * @see https://dev.netatmo.com/doc/authentication/scopes
  35       */
  36  
  37      // Used to read weather station's data (devicelist, getmeasure)
  38      const SCOPE_STATION_READ = 'read_station';
  39      // Used to read thermostat's data (devicelist, getmeasure, getthermstate)
  40      const SCOPE_THERMOSTAT_READ = 'read_thermostat';
  41      // Used to configure the thermostat (syncschedule, setthermpoint)
  42      const SCOPE_THERMOSTAT_WRITE = 'write_thermostat';
  43  
  44      public function __construct(
  45          CredentialsInterface $credentials,
  46          ClientInterface $httpClient,
  47          TokenStorageInterface $storage,
  48          $scopes = [],
  49          ?UriInterface $baseApiUri = null
  50      ) {
  51          parent::__construct(
  52              $credentials,
  53              $httpClient,
  54              $storage,
  55              $scopes,
  56              $baseApiUri,
  57              true // use parameter state
  58          );
  59  
  60          if (null === $baseApiUri) {
  61              $this->baseApiUri = new Uri('https://api.netatmo.net/');
  62          }
  63      }
  64  
  65      /**
  66       * {@inheritdoc}
  67       */
  68      public function getAuthorizationEndpoint()
  69      {
  70          return new Uri($this->baseApiUri . 'oauth2/authorize');
  71      }
  72  
  73      /**
  74       * {@inheritdoc}
  75       */
  76      public function getAccessTokenEndpoint()
  77      {
  78          return new Uri($this->baseApiUri . 'oauth2/token');
  79      }
  80  
  81      /**
  82       * {@inheritdoc}
  83       */
  84      protected function getAuthorizationMethod()
  85      {
  86          return static::AUTHORIZATION_METHOD_QUERY_STRING;
  87      }
  88  
  89      /**
  90       * {@inheritdoc}
  91       */
  92      protected function parseAccessTokenResponse($responseBody)
  93      {
  94          $data = json_decode($responseBody, true);
  95  
  96          if (null === $data || !is_array($data)) {
  97              throw new TokenResponseException('Unable to parse response.');
  98          } elseif (isset($data['error'])) {
  99              throw new TokenResponseException(
 100                  'Error in retrieving token: "' . $data['error'] . '"'
 101              );
 102          }
 103  
 104          $token = new StdOAuth2Token();
 105          $token->setAccessToken($data['access_token']);
 106          $token->setLifetime($data['expires_in']);
 107  
 108          if (isset($data['refresh_token'])) {
 109              $token->setRefreshToken($data['refresh_token']);
 110              unset($data['refresh_token']);
 111          }
 112  
 113          unset($data['access_token'], $data['expires_in']);
 114  
 115          $token->setExtraParams($data);
 116  
 117          return $token;
 118      }
 119  }


Generated: Mon Nov 25 19:05:08 2024 Cross-referenced by PHPXref 0.7.1