Ребята, использую
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}