UNPKG

@auth0/auth0-spa-js

Version:

Auth0 SDK for Single Page Applications using Authorization Code Grant Flow with PKCE

53 lines (52 loc) 2.82 kB
import { CacheKeyManifest } from './key-manifest'; import { CacheEntry, ICache, CacheKey, DecodedToken, IdTokenEntry } from './shared'; export declare class CacheManager { private cache; private keyManifest?; private nowProvider; constructor(cache: ICache, keyManifest?: CacheKeyManifest | undefined, nowProvider?: () => number | Promise<number>); setIdToken(clientId: string, idToken: string, decodedToken: DecodedToken): Promise<void>; getIdToken(cacheKey: CacheKey): Promise<IdTokenEntry | undefined>; get(cacheKey: CacheKey, expiryAdjustmentSeconds?: number, useMrrt?: boolean, cacheMode?: string): Promise<Partial<CacheEntry> | undefined>; private modifiedCachedEntry; set(entry: CacheEntry): Promise<void>; remove(client_id: string, audience?: string, scope?: string): Promise<void>; clear(clientId?: string): Promise<void>; private wrapCacheEntry; private getCacheKeys; /** * Returns the cache key to be used to store the id token * @param clientId The client id used to link to the id token * @returns The constructed cache key, as a string, to store the id token */ private getIdTokenCacheKey; /** * Finds the corresponding key in the cache based on the provided cache key. * The keys inside the cache are in the format {prefix}::{clientId}::{audience}::{scope}. * The first key in the cache that satisfies the following conditions is returned * - `prefix` is strict equal to Auth0's internally configured `keyPrefix` * - `clientId` is strict equal to the `cacheKey.clientId` * - `audience` is strict equal to the `cacheKey.audience` * - `scope` contains at least all the `cacheKey.scope` values * * * @param keyToMatch The provided cache key * @param allKeys A list of existing cache keys */ private matchExistingCacheKey; /** * Returns the first entry that contains a refresh_token that satisfies the following conditions * The keys inside the cache are in the format {prefix}::{clientId}::{audience}::{scope}. * - `prefix` is strict equal to Auth0's internally configured `keyPrefix` * - `clientId` is strict equal to the `cacheKey.clientId` * @param keyToMatch The provided cache key * @param allKeys A list of existing cache keys */ private getEntryWithRefreshToken; /** * Updates in the cache all entries that has a match with previous refresh_token with the * new refresh_token obtained from the server * @param oldRefreshToken Old refresh_token used on refresh * @param newRefreshToken New refresh_token obtained from the server after refresh */ updateEntry(oldRefreshToken: string, newRefreshToken: string): Promise<void>; }