Description
Use the chrome.identity API to get OAuth2 access tokens.
Permissions
identityTypes
AccountInfo
Properties
- 
    idstring A unique identifier for the account. This ID will not change for the lifetime of the account. 
AccountStatus
Enum
"SYNC"  "ANY" 
 Specifies that Sync is enabled for the primary account.
 Specifies the existence of a primary account, if any.
GetAuthTokenResult
Properties
- 
    grantedScopesstring[] optional A list of OAuth2 scopes granted to the extension. 
- 
    tokenstring optional The specific token associated with the request. 
InvalidTokenDetails
Properties
- 
    tokenstring The specific token that should be removed from the cache. 
ProfileDetails
Properties
- 
    accountStatusAccountStatus optional A status of the primary account signed into a profile whose ProfileUserInfoshould be returned. Defaults toSYNCaccount status.
ProfileUserInfo
Properties
- 
    emailstring An email address for the user account signed into the current profile. Empty if the user is not signed in or the identity.emailmanifest permission is not specified.
- 
    idstring A unique identifier for the account. This ID will not change for the lifetime of the account. Empty if the user is not signed in or (in M41+) the identity.emailmanifest permission is not specified.
TokenDetails
Properties
- 
    accountAccountInfo optional The account ID whose token should be returned. If not specified, the function will use an account from the Chrome profile: the Sync account if there is one, or otherwise the first Google web account. 
- 
    enableGranularPermissionsboolean optional Chrome 87+The enableGranularPermissionsflag allows extensions to opt-in early to the granular permissions consent screen, in which requested permissions are granted or denied individually.
- 
    interactiveboolean optional Fetching a token may require the user to sign-in to Chrome, or approve the application's requested scopes. If the interactive flag is true,getAuthTokenwill prompt the user as necessary. When the flag isfalseor omitted,getAuthTokenwill return failure any time a prompt would be required.
- 
    scopesstring[] optional A list of OAuth2 scopes to request. When the scopesfield is present, it overrides the list of scopes specified in manifest.json.
WebAuthFlowDetails
Properties
- 
    abortOnLoadForNonInteractiveboolean optional Chrome 113+Whether to terminate launchWebAuthFlowfor non-interactive requests after the page loads. This parameter does not affect interactive flows.When set to true(default) the flow will terminate immediately after the page loads. When set tofalse, the flow will only terminate after thetimeoutMsForNonInteractivepasses. This is useful for identity providers that use JavaScript to perform redirections after the page loads.
- 
    interactiveboolean optional Whether to launch auth flow in interactive mode. Since some auth flows may immediately redirect to a result URL, launchWebAuthFlowhides its web view until the first navigation either redirects to the final URL, or finishes loading a page meant to be displayed.If the interactiveflag istrue, the window will be displayed when a page load completes. If the flag isfalseor omitted,launchWebAuthFlowwill return with an error if the initial navigation does not complete the flow.For flows that use JavaScript for redirection, abortOnLoadForNonInteractivecan be set tofalsein combination with settingtimeoutMsForNonInteractiveto give the page a chance to perform any redirects.
- 
    timeoutMsForNonInteractivenumber optional Chrome 113+The maximum amount of time, in miliseconds, launchWebAuthFlowis allowed to run in non-interactive mode in total. Only has an effect ifinteractiveisfalse.
- 
    urlstring The URL that initiates the auth flow. 
Methods
clearAllCachedAuthTokens()
chrome.identity.clearAllCachedAuthTokens(): Promise<void>
Resets the state of the Identity API:
- Removes all OAuth2 access tokens from the token cache
- Removes user's account preferences
- De-authorizes the user from all auth flows
Returns
- 
            Promise<void> Chrome 106+
getAccounts()
chrome.identity.getAccounts(): Promise<AccountInfo[]>
Retrieves a list of AccountInfo objects describing the accounts present on the profile.
getAccounts is only supported on dev channel.
Returns
- 
            Promise<AccountInfo[]> 
getAuthToken()
chrome.identity.getAuthToken(
details?: TokenDetails,
): Promise<GetAuthTokenResult>
Gets an OAuth2 access token using the client ID and scopes specified in the oauth2 section of manifest.json.
The Identity API caches access tokens in memory, so it's ok to call getAuthToken non-interactively any time a token is required. The token cache automatically handles expiration.
For a good user experience it is important interactive token requests are initiated by UI in your app explaining what the authorization is for. Failing to do this will cause your users to get authorization requests, or Chrome sign in screens if they are not signed in, with with no context. In particular, do not use getAuthToken interactively when your app is first launched.
Note: When called with a callback, instead of returning an object this function will return the two properties as separate arguments passed to the callback.
Parameters
- 
    detailsTokenDetails optional Token options. 
Returns
- 
            Promise<GetAuthTokenResult> Chrome 105+
getProfileUserInfo()
chrome.identity.getProfileUserInfo(
details?: ProfileDetails,
): Promise<ProfileUserInfo>
Retrieves email address and obfuscated gaia id of the user signed into a profile.
Requires the identity.email manifest permission. Otherwise, returns an empty result.
This API is different from identity.getAccounts in two ways. The information returned is available offline, and it only applies to the primary account for the profile.
Parameters
- 
    detailsProfileDetails optional Chrome 84+Profile options. 
Returns
- 
            Promise<ProfileUserInfo> Chrome 106+
getRedirectURL()
chrome.identity.getRedirectURL(
path?: string,
): string
Generates a redirect URL to be used in launchWebAuthFlow.
The generated URLs match the pattern https://<app-id>.chromiumapp.org/*.
Parameters
- 
    pathstring optional The path appended to the end of the generated URL. 
Returns
- 
            string 
launchWebAuthFlow()
chrome.identity.launchWebAuthFlow(
details: WebAuthFlowDetails,
): Promise<string | undefined>
Starts an auth flow at the specified URL.
This method enables auth flows with non-Google identity providers by launching a web view and navigating it to the first URL in the provider's auth flow. When the provider redirects to a URL matching the pattern https://<app-id>.chromiumapp.org/*, the window will close, and the final redirect URL will be passed to the callback function.
For a good user experience it is important interactive auth flows are initiated by UI in your app explaining what the authorization is for. Failing to do this will cause your users to get authorization requests with no context. In particular, do not launch an interactive auth flow when your app is first launched.
Parameters
- 
    detailsWebAuth flow options. 
Returns
- 
            Promise<string | undefined> Chrome 106+
removeCachedAuthToken()
chrome.identity.removeCachedAuthToken(
details: InvalidTokenDetails,
): Promise<void>
Removes an OAuth2 access token from the Identity API's token cache.
If an access token is discovered to be invalid, it should be passed to removeCachedAuthToken to remove it from the cache. The app may then retrieve a fresh token with getAuthToken.
Parameters
- 
    detailsToken information. 
Returns
- 
            Promise<void> Chrome 106+
Events
onSignInChanged
chrome.identity.onSignInChanged.addListener(
callback: function,
)
Fired when signin state changes for an account on the user's profile.
Parameters
- 
    callbackfunction The callbackparameter looks like:(account: AccountInfo, signedIn: boolean) => void - 
    account
- 
    signedInboolean 
 
-