Для тех, кто хочет глубже изучить composer и подобные библиотеки, доступен следующий ресурс: учебный материал.
Использование библиотеки dicr/yii2-google позволяет легко настроить компонент для работы с Google API в Yii2. Вот как это можно сделать:
Настройка компонента
Для начала, необходимо настроить компонент в конфигурационном файле вашего приложения. Пример конфигурации выглядит следующим образом:
'components' => [ 'google' => [ 'class' => dicrgoogleGoogle::class, 'clientConfig' => [ 'client_id' => 'XXXXXXX.apps.googleusercontent.com', 'Access_type' => 'offline', 'prompt' => 'select_account consent', 'client_secret' => 'XXXXXXXX', // для простой авторизации 'credentials' => 'xxx', // см. Client::setAuthConfig 'scopes' => [ // см. Client::setScopes Google_Service_Sheets::SPREADSHEETS, Google_Service_Sheets::DRIVE, Google_Service_Sheets::DRIVE_FILE ], 'include_granted_scopes' => true ] ] ];
Этот код настраивает компонент google с необходимыми параметрами для работы с Google API. Важно правильно указать client_id, client_secret, а также необходимые scopes для доступа к нужным сервисам.
Проверка валидности текущего токена
После настройки компонента, важно убедиться, что токен доступа действителен. Вот пример кода, который проверяет валидность токена и при необходимости обновляет его или отправляет пользователя на страницу авторизации:
use GoogleClient; use yiihelpersUrl; /** @var dicrgoogleGoogle $google */ $google = Yii::$app->get('google'); /** @var Client $client */ $client = $google->client; // попробуем обновить токен через refresh_token, если имеется if ($client->isAccessTokenExpired() && !empty($client->getRefreshToken())) { $token = $client->fetchAccessTokenWithRefreshToken(); if (!empty($token)) { // сохраняем токен в сессии $this->module->api->sessionToken = $token; } } // если обновить не получилось, тогда переходим на страницу авторизации if ($client->isAccessTokenExpired()) { // сохраняем адрес возврата Yii::$app->user->returnUrl = Url::current(); // настраиваем адрес обработчика кода ответа $client->setRedirectUri(Url::to(['my-module/google-callback'], true)); // отправляем пользователя на страницу авторизации return $this->redirect($client->createAuthUrl(), 303); }
Этот код проверяет, истек ли срок действия текущего токена доступа, и если да, пытается обновить его с помощью refresh_token. Если обновление не удается, пользователь перенаправляется на страницу авторизации Google для получения нового токена.
Преимущества и практическое применение
Использование dicr/yii2-google значительно упрощает интеграцию с Google API в Yii2. Библиотека предоставляет удобный интерфейс для управления аутентификацией и доступом к различным сервисам Google, что экономит время и силы разработчика. В моем проекте это позволило быстро и эффективно реализовать функционал работы с Google Sheets и Google Drive, что было бы значительно сложнее без этой библиотеки.
В итоге, использование dicr/yii2-google оказалось отличным решением для интеграции с Google API, позволив мне сосредоточиться на других аспектах разработки, а не на тонкостях работы с API.