Я интегрировал свой диск Google, используя Oauth2 на стороне сервера, и сохранил учетные данные, такие как токен доступа и токен sh в базе данных.
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 Picker, оно должно быть открыто без экрана авторизации. Для этого я извлекаю токен доступа из моей базы данных (если срок его действия истек, я генерирую новый токен из refre sh токена) и передаю его в средство выбора 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);
}
Он отлично работает для определенного сессия. Однако для новых сеансов он снова запрашивает имя пользователя и пароль. Я не хочу, чтобы пользователь go через экран аутентификации, как только он интегрировал свой диск.