Я интегрировал свой диск Google с помощью Oauth2 на стороне сервера и сохранил учетные данные, такие как токен доступа и токен обновления, в базе данных.
const clientId = `${process.env.GOOGLE_DRIVE_CLIENT_ID}`;
const clientSecret = `${process.env.GOOGLE_DRIVE_CLIENT_SECRET}`;
const redirectURI = `${process.env.SERVERHOST}/connect/gdrive`;
const oAuth2Client = new google.auth.OAuth2(
clientId,
clientSecret,
redirectURI,
);
const authUrl = oAuth2Client.generateAuthUrl({
access_type: "offline",
scope: SCOPE,
});
return res.send({ url: authUrl });
Как только пользователь авторизует приложение, в следующий раз, когда пользователь загрузит средство выбора Google, оно должно быть открыто напрямую без экрана аутентификации. Для этого я извлекаю токен доступа из своей базы данных (если срок его действия истек, я создаю новый токен из токена обновления) и передаю его в сборщик Google.
createPicker(accessToken) {
const { gdriveOAuth2Token } = this.props.userInfo;
const appId = '';
console.log('acc : ', accessToken);
const uploadView = new google.picker.DocsUploadView();
var picker = new google.picker.PickerBuilder().
addViewGroup(
new google.picker.ViewGroup(google.picker.ViewId.DOCS).
addView(google.picker.ViewId.DOCUMENTS).
addView(google.picker.ViewId.PRESENTATIONS)).
addView(uploadView).
setAppId(appId).
setOAuthToken(accessToken).
setDeveloperKey(developerKey).
setCallback(this.pickerCallback).
build();
picker.setVisible(true);
}
Он отлично работает для конкретной сессии. Однако для новых сеансов он снова запрашивает имя пользователя и пароль. Я не хочу, чтобы пользователь проходил через экран аутентификации после того, как он интегрировал свой диск.