Opis
Użyj interfejsu chrome.identity API, aby uzyskać tokeny dostępu OAuth2.
Uprawnienia
identityTypy
AccountInfo
Właściwości
-
id
ciąg znaków
Unikalny identyfikator konta. Ten identyfikator nie zmieni się przez cały okres istnienia konta.
AccountStatus
Typ wyliczeniowy
„SYNC”
Określa, że synchronizacja jest włączona na koncie głównym.
„ANY”
Określa, czy istnieje konto podstawowe.
GetAuthTokenResult
Właściwości
-
grantedScopes
string[] opcjonalne
Lista zakresów OAuth 2.0 przyznanych rozszerzeniu.
-
token
string opcjonalny
Konkretny token powiązany z żądaniem.
InvalidTokenDetails
Właściwości
-
token
ciąg znaków
Konkretny token, który należy usunąć z pamięci podręcznej.
ProfileDetails
Właściwości
-
accountStatus
AccountStatus opcjonalny
Stan konta głównego zalogowanego w profilu, którego
ProfileUserInfopowinien zostać zwrócony. Domyślna wartość to stan kontaSYNC.
ProfileUserInfo
Właściwości
-
e-mail
ciąg znaków
Adres e-mail konta użytkownika zalogowanego w bieżącym profilu. Puste, jeśli użytkownik nie jest zalogowany lub nie określono uprawnienia
identity.emailw pliku manifestu. -
id
ciąg znaków
Unikalny identyfikator konta. Ten identyfikator nie zmieni się przez cały okres istnienia konta. Puste, jeśli użytkownik nie jest zalogowany lub (w przypadku M41+) nie określono uprawnienia
identity.emailw pliku manifestu.
TokenDetails
Właściwości
-
konto
AccountInfo opcjonalnie
Identyfikator konta, dla którego ma zostać zwrócony token. Jeśli nie zostanie podane, funkcja użyje konta z profilu Chrome: konta synchronizacji, jeśli takie istnieje, lub pierwszego konta Google w internecie.
-
enableGranularPermissions
wartość logiczna opcjonalna
Chrome w wersji 87 lub nowszejFlaga
enableGranularPermissionsumożliwia rozszerzeniom wcześniejsze włączenie ekranu zgody na szczegółowe uprawnienia, na którym można przyznawać lub odrzucać poszczególne żądane uprawnienia. -
interaktywny
wartość logiczna opcjonalna
Pobranie tokena może wymagać zalogowania się użytkownika w Chrome lub zatwierdzenia przez niego zakresów żądanych przez aplikację. Jeśli flaga interaktywności ma wartość
true,getAuthTokenwyświetli użytkownikowi odpowiedni komunikat. Gdy flaga ma wartośćfalselub jest pominięta, funkcjagetAuthTokenzwraca błąd za każdym razem, gdy wymagany jest prompt. -
zakresy
string[] opcjonalne
Lista zakresów OAuth 2.0, o które należy poprosić.
Jeśli pole
scopesjest obecne, zastępuje listę zakresów podaną w pliku manifest.json.
WebAuthFlowDetails
Właściwości
-
abortOnLoadForNonInteractive
wartość logiczna opcjonalna
Chrome 113 lub nowszaOkreśla, czy w przypadku żądań nieinteraktywnych należy zakończyć
launchWebAuthFlowpo wczytaniu strony. Ten parametr nie ma wpływu na interaktywne procesy.Gdy ta opcja jest ustawiona na
true(domyślnie), przepływ kończy się natychmiast po załadowaniu strony. Jeśli ustawisz wartośćfalse, proces zakończy się dopiero po upłynięciu czasutimeoutMsForNonInteractive. Jest to przydatne w przypadku dostawców tożsamości, którzy używają JavaScriptu do przekierowywania po wczytaniu strony. -
interaktywny
wartość logiczna opcjonalna
Określa, czy proces autoryzacji ma być uruchamiany w trybie interaktywnym.
Niektóre procesy uwierzytelniania mogą od razu przekierowywać do adresu URL wyniku, dlatego
launchWebAuthFlowukrywa widok internetowy do momentu, gdy pierwsze przekierowanie nastąpi do końcowego adresu URL lub gdy zakończy się ładowanie strony, która ma być wyświetlana.Jeśli flaga
interactivema wartośćtrue, okno będzie wyświetlane po załadowaniu strony. Jeśli flaga ma wartośćfalselub jest pominięta, funkcjalaunchWebAuthFlowzwróci błąd, jeśli początkowa nawigacja nie zakończy przepływu.W przypadku przepływów, które używają JavaScriptu do przekierowania, wartość parametru
abortOnLoadForNonInteractivemożna ustawić nafalsew połączeniu z ustawieniem parametrutimeoutMsForNonInteractive, aby umożliwić stronie wykonanie przekierowań. -
timeoutMsForNonInteractive
number opcjonalny
Chrome 113 lub nowszaMaksymalny łączny czas (w milisekundach), przez jaki
launchWebAuthFlowmoże działać w trybie nieinteraktywnym. Działa tylko wtedy, gdy zasadainteractivema wartośćfalse. -
URL
ciąg znaków
Adres URL, który rozpoczyna proces autoryzacji.
Metody
clearAllCachedAuthTokens()
chrome.identity.clearAllCachedAuthTokens(
callback?: function,
): Promise<void>
Resetuje stan interfejsu Identity API:
- Usuwa z pamięci podręcznej tokenów wszystkie tokeny dostępu OAuth2.
- Usuwa ustawienia konta użytkownika
- Cofanie autoryzacji użytkownika we wszystkich procesach uwierzytelniania
Parametry
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:() => void
Zwroty
-
Promise<void>
Chrome 106 lub nowszaObietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
getAccounts()
chrome.identity.getAccounts(
callback?: function,
): Promise<AccountInfo[]>
Pobiera listę obiektów AccountInfo opisujących konta w profilu.
Atrybut getAccounts jest obsługiwany tylko w wersji deweloperskiej.
Parametry
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:(accounts: AccountInfo[]) => void
-
konta
-
Zwroty
-
Promise<AccountInfo[]>
Obietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
getAuthToken()
chrome.identity.getAuthToken(
details?: TokenDetails,
callback?: function,
): Promise<GetAuthTokenResult>
Pobiera token dostępu OAuth2, używając identyfikatora klienta i zakresów określonych w sekcji oauth2 pliku manifest.json.
Interfejs Identity API buforuje tokeny dostępu w pamięci, więc można wywoływać getAuthToken w sposób nieinteraktywny za każdym razem, gdy jest potrzebny token. Pamięć podręczna tokenów automatycznie obsługuje wygasanie.
Aby zapewnić użytkownikom wygodę, ważne jest, aby żądania interaktywnych tokenów były inicjowane przez interfejs w aplikacji, który wyjaśnia, do czego służy autoryzacja. Jeśli tego nie zrobisz, użytkownicy będą otrzymywać prośby o autoryzację lub ekrany logowania w Chrome (jeśli nie są zalogowani) bez kontekstu. W szczególności nie używaj funkcji getAuthToken interaktywnie przy pierwszym uruchomieniu aplikacji.
Uwaga: jeśli funkcja jest wywoływana z wywołaniem zwrotnym, zamiast zwracać obiekt, zwraca 2 właściwości jako osobne argumenty przekazywane do wywołania zwrotnego.
Parametry
-
szczegóły
TokenDetails opcjonalny
Opcje tokena.
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:(result: GetAuthTokenResult) => void
-
wynikChrome 105 lub nowsza
-
Zwroty
-
Promise<GetAuthTokenResult>
Chrome 105 lub nowszaObietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
getProfileUserInfo()
chrome.identity.getProfileUserInfo(
details?: ProfileDetails,
callback?: function,
): Promise<ProfileUserInfo>
Pobiera adres e-mail i zaciemniony identyfikator Gaia użytkownika zalogowanego w profilu.
Wymaga uprawnienia identity.email w pliku manifestu. W przeciwnym razie zwraca pusty wynik.
Ten interfejs API różni się od interfejsu identity.getAccounts na 2 sposoby. Zwrócone informacje są dostępne offline i dotyczą tylko konta głównego w profilu.
Parametry
-
szczegóły
ProfileDetails opcjonalnie
Chrome 84 lub nowszaOpcje profilu.
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:(userInfo: ProfileUserInfo) => void
-
userInfo
-
Zwroty
-
Promise<ProfileUserInfo>
Chrome 106 lub nowszaObietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
getRedirectURL()
chrome.identity.getRedirectURL(
path?: string,
): string
Generuje przekierowanie do użycia w zmiennej launchWebAuthFlow.
Wygenerowane adresy URL pasują do wzorca https://<app-id>.chromiumapp.org/*.
Parametry
-
ścieżka
string opcjonalny
Ścieżka dołączana na końcu wygenerowanego adresu URL.
Zwroty
-
ciąg znaków
launchWebAuthFlow()
chrome.identity.launchWebAuthFlow(
details: WebAuthFlowDetails,
callback?: function,
): Promise<string | undefined>
Rozpoczyna proces uwierzytelniania pod określonym adresem URL.
Ta metoda umożliwia przepływy uwierzytelniania z użyciem dostawców tożsamości innych niż Google. W tym celu uruchamia widok internetowy i przekierowuje go do pierwszego adresu URL w przepływie uwierzytelniania dostawcy. Gdy dostawca przekieruje użytkownika na adres URL pasujący do wzorca https://<app-id>.chromiumapp.org/*, okno zostanie zamknięte, a ostateczny adres URL przekierowania zostanie przekazany do funkcji callback.
Aby zapewnić użytkownikom wygodę, ważne jest, aby interaktywne procesy uwierzytelniania były inicjowane przez interfejs w aplikacji, który wyjaśnia, do czego służy autoryzacja. Jeśli tego nie zrobisz, użytkownicy będą otrzymywać prośby o autoryzację bez kontekstu. W szczególności nie uruchamiaj interaktywnego procesu uwierzytelniania przy pierwszym uruchomieniu aplikacji.
Parametry
-
szczegóły
Opcje procedury WebAuth.
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:(responseUrl?: string) => void
-
responseUrl
string opcjonalny
-
Zwroty
-
Promise<string | undefined>
Chrome 106 lub nowszaObietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
removeCachedAuthToken()
chrome.identity.removeCachedAuthToken(
details: InvalidTokenDetails,
callback?: function,
): Promise<void>
Usuwa token dostępu OAuth2 z pamięci podręcznej tokenów interfejsu API tożsamości.
Jeśli token dostępu okaże się nieprawidłowy, należy przekazać go do funkcji removeCachedAuthToken, aby usunąć go z pamięci podręcznej. Aplikacja może wtedy pobrać nowy token z parametrem getAuthToken.
Parametry
-
szczegóły
Informacje o tokenie.
-
callback
funkcja opcjonalna
Parametr
callbackwygląda tak:() => void
Zwroty
-
Promise<void>
Chrome 106 lub nowszaObietnice są obsługiwane tylko w przypadku platformy Manifest V3 i nowszych. Inne platformy muszą używać wywołań zwrotnych.
Wydarzenia
onSignInChanged
chrome.identity.onSignInChanged.addListener(
callback: function,
)
Wyzwalane, gdy stan logowania konta w profilu użytkownika ulegnie zmianie.
Parametry
-
callback
funkcja
Parametr
callbackwygląda tak:(account: AccountInfo, signedIn: boolean) => void
-
konto
-
signedIn
Wartość logiczna
-