Opis
Użyj interfejsu chrome.identity API, aby uzyskać tokeny dostępu OAuth2.
Uprawnienia
identityTypy
AccountInfo
Właściwości
- 
    idcią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
- 
    grantedScopesstring[] opcjonalne Lista zakresów OAuth 2.0 przyznanych rozszerzeniu. 
- 
    tokenstring opcjonalny Konkretny token powiązany z żądaniem. 
InvalidTokenDetails
Właściwości
- 
    tokenciąg znaków Konkretny token, który należy usunąć z pamięci podręcznej. 
ProfileDetails
Właściwości
- 
    accountStatusAccountStatus 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-mailcią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.
- 
    idcią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
- 
    kontoAccountInfo 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. 
- 
    enableGranularPermissionswartość 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.
- 
    interaktywnywartość 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.
- 
    zakresystring[] 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
- 
    abortOnLoadForNonInteractivewartość 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.
- 
    interaktywnywartość 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ń.
- 
    timeoutMsForNonInteractivenumber 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.
- 
    URLcią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
- 
    callbackfunkcja 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
- 
    callbackfunkcja 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ółyTokenDetails opcjonalny Opcje tokena. 
- 
    callbackfunkcja 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ółyProfileDetails opcjonalnie Chrome 84 lub nowszaOpcje profilu. 
- 
    callbackfunkcja 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żkastring 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ółyOpcje procedury WebAuth. 
- 
    callbackfunkcja opcjonalna Parametr callbackwygląda tak:(responseUrl?: string) => void - 
    responseUrlstring 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ółyInformacje o tokenie. 
- 
    callbackfunkcja 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
- 
    callbackfunkcja Parametr callbackwygląda tak:(account: AccountInfo, signedIn: boolean) => void - 
    konto
- 
    signedInWartość logiczna 
 
-