Ich verwende Django mit python-social-auth
, um meine Benutzer mit Google OAuth2 zu authentifizieren und die Youtube-API zu verwenden.So aktualisieren Sie das Google OAuth2-Token programmgesteuert
Was Ich mag würde, ist, sie zu erreichen, bitten anmelden und genehmigen nur einmal und der Lage sein, ihre Anmeldeinformationen zu verwenden, solange ich will. Dies ist nicht möglich, da sie nach etwa einer Stunde ablaufen und der Benutzer meine Anwendung erneut autorisieren muss, um neue Anmeldeinformationen zu erhalten.
Ich nehme an, die Lösung besteht darin, die Berechtigungen regelmäßig zu aktualisieren, aber ich konnte keine zuverlässige Anleitung finden, wie dies zu tun ist.
Meine aktuelle Konfiguration ist:
SOCIAL_AUTH_GOOGLE_OAUTH2_KEY = 'the_key'
SOCIAL_AUTH_GOOGLE_OAUTH2_SECRET = 'the_secret'
SOCIAL_AUTH_GOOGLE_OAUTH2_SCOPE = ["https://www.googleapis.com/auth/youtube.readonly", "https://www.googleapis.com/auth/yt-analytics.readonly"]
SOCIAL_AUTH_GOOGLE_OAUTH2_AUTH_EXTRA_ARGUMENTS = {
'access_type': 'offline',
'approval_prompt': 'force'
}
Auch ein autorisierter Benutzer die folgenden Extras hat:
{
"access_token": "the_access_token",
"expires": 3600,
"refresh_token": "the_refresh_token",
"token_type": "Bearer"
}
Ich habe versucht, es mit dem folgenden Code erfrischend, aber da es abgelaufen ist immer noch ich denke, es ist nicht der richtige Weg:
Sie können den 'expires' Wert erhöhen –
setzen Sie Wert verfällt so lang wie Sie wollen –
Wo kann ich meinen Wert "abläuft" setzen? In Google API-Konsole oder ist es eine Konfiguration für PSA? – ihhcarus