Задать вопрос
ponich
@ponich
php,mysql,js

Бесконечный token для Google Api Service?

Ребята, использую google/apiclient в проекте. Что бы работать с данным api нужно авторизироватся и получить токен, с которым библиотека будет работать. Выглядит это вот так:
protected function getClient()
    {
        $client = new Google_Client();
        $client->setApplicationName(APPLICATION_NAME);
        $client->setScopes(SCOPES);
        $client->setAuthConfig(CLIENT_SECRET_PATH);
        $client->setAccessType('offline');

        // Load previously authorized credentials from a file.
        $credentialsPath = CREDENTIALS_PATH;
        if (file_exists($credentialsPath)) {
            $accessToken = json_decode(file_get_contents($credentialsPath), true);
        } else {
            // Request authorization from the user.
            $authUrl = $client->createAuthUrl();
            printf("Open the following link in your browser:\n%s\n", $authUrl);
            print 'Enter verification code: ';
            $authCode = trim(fgets(STDIN));

            // Exchange authorization code for an access token.
            $accessToken = $client->fetchAccessTokenWithAuthCode($authCode);

            // Store the credentials to disk.
            if (!file_exists(dirname($credentialsPath))) {
                mkdir(dirname($credentialsPath), 0700, true);
            }
            file_put_contents($credentialsPath, json_encode($accessToken));
            printf("Credentials saved to %s\n", $credentialsPath);
        }
        $client->setAccessToken($accessToken);


        // Refresh the token if it's expired.
        if ($client->getRefreshToken()) {
            $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
            file_put_contents($credentialsPath, json_encode($client->getAccessToken()));

        }
        return $client;
    }

После данные авторизации будут записаны в $credentialsPath. Но! После истечения expires_in, клиент обновит свой токен, отправив на сервер refresh_token. После обновления токена, опять все работает до того момента как нужно обновить его ещё раз.
Так же заметил что после:
// Refresh the token if it's expired.
        if ($client->getRefreshToken()) {
            $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
            file_put_contents($credentialsPath, json_encode($client->getAccessToken()));
        }

В файл не записывается refresh_token. То есть когда нужно обновить, данного токена в файле нету.
Кто сталкивался с подобным?

Файл при первой авторизации:
{"access_token":"ya29.Ci9IA7H-*******-*********","token_type":"Bearer","expires_in":3600,"refresh_token":"1\/**********-*******","created":1471990656}

Файл после первого обновления токена:
{"access_token":"ya29.Ci9IA7H-*******-*********","token_type":"Bearer","expires_in":3600,"created":1471990987}
  • Вопрос задан
  • 1678 просмотров
Подписаться 3 Оценить Комментировать
Пригласить эксперта
Ответы на вопрос 1
Да, сталкивался. Для гугла это нормально. Он присылает refresh_token только один раз. Если refresh_token вам уже выдавался, то не ждите его больше. Просто не затирайте предыдущий и пользуйтесь им.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы