Можно ли открыть Google Picker с токеном доступа, полученным со стороны сервера Oauth2? - PullRequest
0 голосов
/ 06 января 2020

Я интегрировал свой диск 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 через экран аутентификации, как только он интегрировал свой диск.

...