Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@mybiogen/auth-openid

Package Overview
Dependencies
Maintainers
9
Versions
58
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@mybiogen/auth-openid - npm Package Compare versions

Comparing version 1.1.0 to 1.1.1

4

lib/JanrainJS.d.ts
import OpenIDClient from './OAuthClient';
import { OAuthUserInfo } from './types';
export declare type JanrainUserInfo = OAuthUserInfo;
export declare type JanrainUserInfo = OAuthUserInfo & {
picture: string;
};
export default class JanrainJS extends OpenIDClient<JanrainUserInfo> {

@@ -5,0 +7,0 @@ constructor(clientId: string, configUrl: string, redirectURI: string);

@@ -22,2 +22,2 @@ "use strict";

exports.default = JanrainJS;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFucmFpbkpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0phbnJhaW5KUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQUt6QyxNQUFxQixTQUFVLFNBQVEscUJBQTZCO0lBQ2xFLFlBQVksUUFBZ0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQ2xFLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBR1MsWUFBWSxDQUFDLFFBQWE7UUFDbEMsT0FBTztZQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsR0FBRztZQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7WUFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1lBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVztZQUM5QixPQUFPLEVBQUUsUUFBUSxDQUFDLE9BQU87U0FDMUIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWZELDRCQWVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE9wZW5JRENsaWVudCBmcm9tICcuL09BdXRoQ2xpZW50JztcbmltcG9ydCB7IE9BdXRoVXNlckluZm8gfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgSmFucmFpblVzZXJJbmZvID0gT0F1dGhVc2VySW5mb1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBKYW5yYWluSlMgZXh0ZW5kcyBPcGVuSURDbGllbnQ8SmFucmFpblVzZXJJbmZvPiB7XG4gIGNvbnN0cnVjdG9yKGNsaWVudElkOiBzdHJpbmcsIGNvbmZpZ1VybDogc3RyaW5nLCByZWRpcmVjdFVSSTogc3RyaW5nKSB7XG4gICAgc3VwZXIoY2xpZW50SWQsIGNvbmZpZ1VybCwgcmVkaXJlY3RVUkksICdqYW5yYWluX3Rva2VuJyk7XG4gIH1cblxuICAvLyBodHRwczovL2lkZW50aXR5ZG9jcy5ha2FtYWkuY29tL2hvbWUvamFucmFpbi1lbnRpdHktYXBpXG4gIHByb3RlY3RlZCBsb2FkVXNlckluZm8odXNlckpTT046IGFueSk6IEphbnJhaW5Vc2VySW5mbyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiB1c2VySlNPTi5zdWIsXG4gICAgICBlbWFpbDogdXNlckpTT04uZW1haWwsXG4gICAgICBuYW1lOiB1c2VySlNPTi5naXZlbl9uYW1lLFxuICAgICAgbGFzdE5hbWU6IHVzZXJKU09OLmZhbWlseV9uYW1lLFxuICAgICAgcGljdHVyZTogdXNlckpTT04ucGljdHVyZSxcbiAgICB9O1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFucmFpbkpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0phbnJhaW5KUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQU96QyxNQUFxQixTQUFVLFNBQVEscUJBQTZCO0lBQ2xFLFlBQVksUUFBZ0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQ2xFLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBR1MsWUFBWSxDQUFDLFFBQWE7UUFDbEMsT0FBTztZQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsR0FBRztZQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7WUFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1lBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVztZQUM5QixPQUFPLEVBQUUsUUFBUSxDQUFDLE9BQU87U0FDMUIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWZELDRCQWVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE9wZW5JRENsaWVudCBmcm9tICcuL09BdXRoQ2xpZW50JztcbmltcG9ydCB7IE9BdXRoVXNlckluZm8gfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgSmFucmFpblVzZXJJbmZvID0gT0F1dGhVc2VySW5mbyAmIHtcbiAgcGljdHVyZTogc3RyaW5nXG59XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEphbnJhaW5KUyBleHRlbmRzIE9wZW5JRENsaWVudDxKYW5yYWluVXNlckluZm8+IHtcbiAgY29uc3RydWN0b3IoY2xpZW50SWQ6IHN0cmluZywgY29uZmlnVXJsOiBzdHJpbmcsIHJlZGlyZWN0VVJJOiBzdHJpbmcpIHtcbiAgICBzdXBlcihjbGllbnRJZCwgY29uZmlnVXJsLCByZWRpcmVjdFVSSSwgJ2phbnJhaW5fdG9rZW4nKTtcbiAgfVxuXG4gIC8vIGh0dHBzOi8vaWRlbnRpdHlkb2NzLmFrYW1haS5jb20vaG9tZS9qYW5yYWluLWVudGl0eS1hcGlcbiAgcHJvdGVjdGVkIGxvYWRVc2VySW5mbyh1c2VySlNPTjogYW55KTogSmFucmFpblVzZXJJbmZvIHtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHVzZXJKU09OLnN1YixcbiAgICAgIGVtYWlsOiB1c2VySlNPTi5lbWFpbCxcbiAgICAgIG5hbWU6IHVzZXJKU09OLmdpdmVuX25hbWUsXG4gICAgICBsYXN0TmFtZTogdXNlckpTT04uZmFtaWx5X25hbWUsXG4gICAgICBwaWN0dXJlOiB1c2VySlNPTi5waWN0dXJlLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==

@@ -16,4 +16,7 @@ import { OAuthUserInfo, Token, WatchAuthCallback, Init } from './types';

comesFromLogin: boolean;
hasBeenInitialized: boolean;
constructor(clientId: string, configUrl: string, redirectURI: string, storageKey: string);
init(): Promise<Init | undefined>;
private getTokenOnInit;
private refreshTokenOnInit;
private callListeners;

@@ -30,4 +33,4 @@ private keepRefreshingToken;

private revokeToken;
logout: () => Promise<void>;
logout: (ignoreRevokationErrors?: boolean) => Promise<void>;
}
//# sourceMappingURL=OAuthClient.d.ts.map

@@ -13,2 +13,7 @@ "use strict";

this.keepRefreshingToken = () => {
var _a;
if (!((_a = this.token) === null || _a === void 0 ? void 0 : _a.refreshToken)) {
console.warn("missing refresh token.");
return;
}
if (this.user && this.token && !this.refreshTokenInterval) {

@@ -29,4 +34,4 @@ const SAFETY_GAP_REFRESH_TOKEN = 60000;

this.listeners.push(cb);
const token = await this.init();
if (token) {
await this.init();
if (this.token) {
await this.getUserInfo();

@@ -99,2 +104,5 @@ }

}
if (!this.token.refreshToken) {
throw new Error('Cannot refresh token without refresh token');
}
const body = {

@@ -186,16 +194,20 @@ grant_type: 'refresh_token',

};
this.logout = async () => {
this.logout = async (ignoreRevokationErrors = false) => {
if (!this.token) {
throw new Error('Cannot logout without token');
}
const [revokedAccessToken, revokedRefreshToken] = await Promise.all([
this.revokeToken(this.token.accessToken),
this.revokeToken(this.token.refreshToken),
]);
try {
await Promise.all([
this.revokeToken(this.token.accessToken),
this.revokeToken(this.token.refreshToken),
]);
}
catch (error) {
if (!ignoreRevokationErrors) {
throw error;
}
}
this.comesFromLogin = false;
this.token = undefined;
this.user = undefined;
if (!revokedAccessToken || !revokedRefreshToken) {
throw new Error('Token not revoked');
}
this.callListeners();

@@ -221,4 +233,8 @@ return utils_1.Storage.remove(this.storageKey);

this.comesFromLogin = false;
this.hasBeenInitialized = false;
}
async init() {
if (this.hasBeenInitialized) {
return;
}
const [callbackState, storageOauth] = await Promise.all([

@@ -232,28 +248,37 @@ utils_1.checkCallback(window.location.href),

}
this.hasBeenInitialized = true;
if (callbackState) {
const { code, pkceCodeVerifier, currentState, newUrl, } = callbackState;
this.token = await this.getToken(code, pkceCodeVerifier, currentState);
this.keepRefreshingToken();
window.history.replaceState(window.history.state, document.title, newUrl);
this.comesFromLogin = true;
return this.token
? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }
: undefined;
return await this.getTokenOnInit(callbackState);
}
if (storageOauth) {
this.token = storageOauth;
try {
await this.refreshToken();
this.keepRefreshingToken();
}
catch (err) {
this.token = undefined;
utils_1.Storage.remove(this.storageKey);
}
return this.token
? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }
: undefined;
return await this.refreshTokenOnInit(storageOauth);
}
return undefined;
}
async getTokenOnInit(callbackState) {
const { code, pkceCodeVerifier, currentState, newUrl, } = callbackState;
this.token = await this.getToken(code, pkceCodeVerifier, currentState);
this.keepRefreshingToken();
window.history.replaceState(window.history.state, document.title, newUrl);
this.comesFromLogin = true;
return this.token;
}
async refreshTokenOnInit(storageOauth) {
var _a;
this.token = storageOauth;
this.comesFromLogin = false;
if (!((_a = this.token) === null || _a === void 0 ? void 0 : _a.refreshToken)) {
console.warn("missing refresh token.");
return this.token;
}
try {
await this.refreshToken();
this.keepRefreshingToken();
}
catch (err) {
this.token = undefined;
utils_1.Storage.remove(this.storageKey);
}
return this.token;
}
callListeners() {

@@ -271,2 +296,2 @@ this.listeners.forEach((cb) => {

exports.default = OpenIDClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OAuthClient.js","sourceRoot":"","sources":["../src/OAuthClient.ts"],"names":[],"mappings":"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","sourcesContent":["import queryString from 'query-string';\nimport { v4 as uuidv4 } from 'uuid';\nimport { encodeBody, generateCodeVerifier, generatePkceChallenge, Storage, checkCallback } from './utils';\nimport {\n  OAuthUserInfo,\n  Token,\n  WatchAuthCallback,\n  Init,\n  ConfigEndpoint\n} from './types';\n\n\nexport default abstract class OpenIDClient<UserInfo extends OAuthUserInfo> {\n  clientId: string;\n\n  configUrl: string;\n\n  redirectURI: string;\n\n  authorizationEndpoint?: string;\n\n  tokenEndpoint?: string;\n\n  userInfoEndpoint?: string;\n\n  revocationEndpoint?: string;\n\n  token?: Token;\n\n  user?: UserInfo;\n\n  storageKey: string;\n\n  listeners: Array<WatchAuthCallback> = [];\n\n  refreshTokenInterval?: number;\n\n  comesFromLogin: boolean;\n\n  constructor(clientId: string, configUrl: string, redirectURI: string, storageKey: string) {\n    if (!clientId) {\n      throw new Error('clientId is not provided.')\n    }\n    this.clientId = clientId;\n\n    if (!configUrl) {\n      throw new Error('configUrl is not provided.')\n    }\n    this.configUrl = configUrl;\n\n    if (!redirectURI) {\n      throw new Error('redirectUri is not provided.')\n    }\n    this.redirectURI = redirectURI;\n\n    if (!storageKey) {\n      throw new Error('storageKey is not provided.')\n    }\n    this.storageKey = storageKey;\n\n    this.comesFromLogin = false;\n  }\n\n  async init(): Promise<Init | undefined> {\n    const [callbackState, storageOauth] = await Promise.all([\n      checkCallback(window.location.href),\n      Storage.get(this.storageKey),\n    ]);\n\n    // Wait until configuration has finished.\n    await this.setConfig();\n\n    // Return early\n    if (!callbackState && !storageOauth) {\n      return undefined;\n    }\n\n    if (callbackState) {\n      const {\n        code, pkceCodeVerifier, currentState, newUrl,\n      } = callbackState;\n      this.token = await this.getToken(code, pkceCodeVerifier, currentState);\n      this.keepRefreshingToken();\n      window.history.replaceState(window.history.state, document.title, newUrl);\n      this.comesFromLogin = true;\n      return this.token\n        ? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }\n        : undefined;\n    }\n\n    if (storageOauth) {\n      this.token = storageOauth;\n      try {\n        await this.refreshToken();\n        this.keepRefreshingToken();\n      } catch (err) {\n        this.token = undefined;\n        Storage.remove(this.storageKey);\n      }\n      return this.token\n        ? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }\n        : undefined;\n    }\n\n    return undefined;\n  }\n\n  private callListeners(): void {\n    this.listeners.forEach((cb) => {\n      if (this.token && this.user) {\n        cb({ ...this.user }, this.comesFromLogin);\n      } else {\n        cb(undefined, this.comesFromLogin);\n      }\n    });\n  }\n\n  private keepRefreshingToken = (): void => {\n    if (this.user && this.token && !this.refreshTokenInterval) {\n      const SAFETY_GAP_REFRESH_TOKEN = 60000; // 1 min\n      this.refreshTokenInterval = window.setInterval(async () => {\n        try {\n          await this.refreshToken();\n        } catch (error) {\n          clearInterval(this.refreshTokenInterval);\n          this.logout();\n        }\n      }, (this.token.expiresIn * 1000) - SAFETY_GAP_REFRESH_TOKEN);\n    }\n  };\n\n  watchAuth = async (cb: WatchAuthCallback): Promise<void> => {\n    this.listeners.push(cb);\n    const token = await this.init();\n\n    if (token) {\n      await this.getUserInfo();\n    }\n\n    this.callListeners();\n  };\n\n  private fetchConfig = async (): Promise<ConfigEndpoint | undefined> => {\n    try {\n      const response = await fetch(this.configUrl);\n      // TODO: Error, fetch only throws on connection error, else we get !fetch.ok\n      return response.json();\n    } catch (error) {\n      return undefined;\n    }\n  };\n\n  private setConfig = async (): Promise<void> => {\n    const config = await this.fetchConfig();\n    if (config) {\n      this.authorizationEndpoint = config.authorization_endpoint;\n      this.tokenEndpoint = config.token_endpoint;\n      this.userInfoEndpoint = config.userinfo_endpoint;\n      this.revocationEndpoint = config.revocation_endpoint;\n    }\n  };\n\n  private getToken = async (code: string, originalCodeVerifier: string, currentState: string): Promise<Token | undefined> => {\n    if (!this.tokenEndpoint) {\n      throw new Error('Not initialized. Token endpoint not present');\n    }\n\n    const body = {\n      grant_type: 'authorization_code',\n      code,\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      code_verifier: originalCodeVerifier,\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n      }),\n      body: encodeBody(body),\n    };\n\n    try {\n      const response = await fetch(this.tokenEndpoint, config);\n\n      if (!response.ok) {\n        // TODO: Error, deal with failure cases\n        return undefined;\n      }\n\n      const authToken = await response.json();\n\n      this.token = {\n        accessToken: authToken.access_token,\n        refreshToken: authToken.refresh_token,\n        expiresIn: authToken.expires_in,\n        tokenType: authToken.token_type,\n        scope: authToken.scope,\n        idToken: authToken.id_token,\n      };\n\n      Storage.set(this.storageKey, this.token);\n      // clean up local storage from PKCE details\n      Storage.remove(currentState);\n      // clean up query params from OAuth redirection\n      window.history.replaceState({}, document.title, window.location.pathname);\n\n      return this.token;\n    } catch (error) {\n      throw new Error('Error getting token');\n    }\n  };\n\n  refreshToken = async (): Promise<Init | undefined> => {\n    if (!this.token || !this.tokenEndpoint) {\n      throw new Error('Cannot refresh token without token or endpoint');\n    }\n\n    const body = {\n      grant_type: 'refresh_token',\n      refresh_token: this.token.refreshToken,\n      redirect_uri: this.redirectURI,\n      client_id: encodeURIComponent(this.clientId),\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n      }),\n      body: encodeBody(body),\n    };\n\n    const response = await fetch(this.tokenEndpoint, config);\n\n    if (!response.ok) {\n      throw new Error('Token not refreshed');\n    }\n\n    const token = await response.json();\n\n    this.token = {\n      accessToken: token.access_token,\n      refreshToken: token.refresh_token,\n      expiresIn: token.expires_in,\n      tokenType: token.token_type,\n      scope: token.scope,\n      idToken: token.id_token,\n    };\n\n    Storage.set(this.storageKey, this.token);\n\n    // (?) We don't return the token directly\n    return { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }\n  };\n\n  login = (): void => {\n    const originalCodeVerifier = generateCodeVerifier(96);\n    const codeVerifier = generatePkceChallenge(originalCodeVerifier);\n    const state = uuidv4();\n\n    const params = {\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      scope: 'openid email profile',\n      response_type: 'code',\n      response_mode: 'query',\n      state: encodeURIComponent(state),\n      code_challenge: encodeURI(codeVerifier),\n      code_challenge_method: 'S256',\n    };\n\n    Storage.set(state, {\n      codeVerifier,\n      originalCodeVerifier,\n    });\n\n    const loginQuery = queryString.stringify(params);\n    const url = `${this.authorizationEndpoint}?${loginQuery}`;\n    window.location.replace(url);\n  };\n\n  protected abstract loadUserInfo(userJSON: any): UserInfo;\n\n  getUserInfo = async (): Promise<UserInfo | undefined> => {\n    if (!this.userInfoEndpoint || !this.token) {\n      return undefined\n    }\n\n    const response = await fetch(this.userInfoEndpoint, {\n      headers: new Headers({\n        Authorization: `Bearer ${this.token.accessToken}`,\n      }),\n    });\n\n    const userInfo = await response.json();\n    this.user = this.loadUserInfo(userInfo)\n\n    return this.user;\n  };\n\n  private revokeToken = async (tokenKey: string): Promise<boolean> => {\n    if (!this.revocationEndpoint) {\n      throw new Error('Cannot revoke token without endpoint');\n    }\n\n    const body = {\n      token: tokenKey,\n      client_id: encodeURIComponent(this.clientId),\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n        Authorization: `Bearer ${tokenKey}`,\n      }),\n      body: encodeBody(body),\n    };\n    \n    const response = await fetch(this.revocationEndpoint, config);\n\n    if (!response.ok) {\n      throw new Error('Token not revoked');\n    }\n\n    return response.ok;\n  };\n\n  logout = async (): Promise<void> => {\n    if (!this.token) {\n      throw new Error('Cannot logout without token');\n    }\n\n    const [revokedAccessToken, revokedRefreshToken] = await Promise.all([\n      this.revokeToken(this.token.accessToken),\n      this.revokeToken(this.token.refreshToken),\n    ]);\n\n    this.comesFromLogin = false;\n    this.token = undefined;\n    this.user = undefined;\n\n    if (!revokedAccessToken || !revokedRefreshToken) {\n      throw new Error('Token not revoked');\n    }\n\n    this.callListeners();\n    return Storage.remove(this.storageKey);\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OAuthClient.js","sourceRoot":"","sources":["../src/OAuthClient.ts"],"names":[],"mappings":"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","sourcesContent":["import queryString from 'query-string';\nimport { v4 as uuidv4 } from 'uuid';\nimport { encodeBody, generateCodeVerifier, generatePkceChallenge, Storage, checkCallback } from './utils';\nimport {\n  OAuthUserInfo,\n  Token,\n  WatchAuthCallback,\n  Init,\n  ConfigEndpoint\n} from './types';\n\n\nexport default abstract class OpenIDClient<UserInfo extends OAuthUserInfo> {\n  clientId: string;\n\n  configUrl: string;\n\n  redirectURI: string;\n\n  authorizationEndpoint?: string;\n\n  tokenEndpoint?: string;\n\n  userInfoEndpoint?: string;\n\n  revocationEndpoint?: string;\n\n  token?: Token;\n\n  user?: UserInfo;\n\n  storageKey: string;\n\n  listeners: Array<WatchAuthCallback> = [];\n\n  refreshTokenInterval?: number;\n\n  comesFromLogin: boolean;\n\n  hasBeenInitialized: boolean;\n\n  constructor(clientId: string, configUrl: string, redirectURI: string, storageKey: string) {\n    if (!clientId) {\n      throw new Error('clientId is not provided.')\n    }\n    this.clientId = clientId;\n\n    if (!configUrl) {\n      throw new Error('configUrl is not provided.')\n    }\n    this.configUrl = configUrl;\n\n    if (!redirectURI) {\n      throw new Error('redirectUri is not provided.')\n    }\n    this.redirectURI = redirectURI;\n\n    if (!storageKey) {\n      throw new Error('storageKey is not provided.')\n    }\n    this.storageKey = storageKey;\n\n    this.comesFromLogin = false;\n    this.hasBeenInitialized = false;\n  }\n\n  async init(): Promise<Init | undefined> {\n    if (this.hasBeenInitialized) {\n      return\n    }\n\n    const [callbackState, storageOauth] = await Promise.all([\n      checkCallback(window.location.href),\n      Storage.get(this.storageKey),\n    ]);\n\n    // Wait until configuration has finished.\n    await this.setConfig();\n\n    // Return early\n    if (!callbackState && !storageOauth) {\n      return undefined;\n    }\n\n    this.hasBeenInitialized = true;\n\n    if (callbackState) {\n      return await this.getTokenOnInit(callbackState)\n    }\n\n    if (storageOauth) {\n      return await this.refreshTokenOnInit(storageOauth)\n    }\n\n    return undefined;\n  }\n\n  private async getTokenOnInit(callbackState): Promise<Token | undefined> {\n    const {\n      code, pkceCodeVerifier, currentState, newUrl,\n    } = callbackState;\n\n    this.token = await this.getToken(code, pkceCodeVerifier, currentState);\n    this.keepRefreshingToken();\n\n    window.history.replaceState(window.history.state, document.title, newUrl);\n    this.comesFromLogin = true;\n\n    return this.token\n  }\n\n  private async refreshTokenOnInit(storageOauth: any): Promise<Token | undefined> {\n    this.token = storageOauth;\n    this.comesFromLogin = false;\n\n    if (!this.token?.refreshToken) {\n      // TODO @all handle case without refresh token\n      // This should test if the current token is still valid\n      // or we should change the API calls to get the refresh token.\n      console.warn(\"missing refresh token.\")\n      return this.token\n    }\n\n    try {\n      await this.refreshToken();\n      this.keepRefreshingToken();\n    } catch (err) {\n      this.token = undefined;\n      Storage.remove(this.storageKey);\n    }\n\n    return this.token\n  }\n\n  private callListeners(): void {\n    this.listeners.forEach((cb) => {\n      if (this.token && this.user) {\n        cb({ ...this.user }, this.comesFromLogin);\n      } else {\n        cb(undefined, this.comesFromLogin);\n      }\n    });\n  }\n\n  private keepRefreshingToken = (): void => {\n    if (!this.token?.refreshToken) {\n      console.warn(\"missing refresh token.\")\n      return;\n    }\n\n    if (this.user && this.token && !this.refreshTokenInterval) {\n      const SAFETY_GAP_REFRESH_TOKEN = 60000; // 1 min\n      this.refreshTokenInterval = window.setInterval(async () => {\n        try {\n          await this.refreshToken();\n        } catch (error) {\n          clearInterval(this.refreshTokenInterval);\n          this.logout();\n        }\n      }, (this.token.expiresIn * 1000) - SAFETY_GAP_REFRESH_TOKEN);\n    }\n  };\n\n  watchAuth = async (cb: WatchAuthCallback): Promise<void> => {\n    this.listeners.push(cb);\n\n    await this.init();\n\n    if (this.token) {\n      await this.getUserInfo();\n    }\n\n    this.callListeners();\n  };\n\n  private fetchConfig = async (): Promise<ConfigEndpoint | undefined> => {\n    try {\n      const response = await fetch(this.configUrl);\n      // TODO: Error, fetch only throws on connection error, else we get !fetch.ok\n      return response.json();\n    } catch (error) {\n      return undefined;\n    }\n  };\n\n  private setConfig = async (): Promise<void> => {\n    const config = await this.fetchConfig();\n    if (config) {\n      this.authorizationEndpoint = config.authorization_endpoint;\n      this.tokenEndpoint = config.token_endpoint;\n      this.userInfoEndpoint = config.userinfo_endpoint;\n      this.revocationEndpoint = config.revocation_endpoint;\n    }\n  };\n\n  private getToken = async (code: string, originalCodeVerifier: string, currentState: string): Promise<Token | undefined> => {\n    if (!this.tokenEndpoint) {\n      throw new Error('Not initialized. Token endpoint not present');\n    }\n\n    const body = {\n      grant_type: 'authorization_code',\n      code,\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      code_verifier: originalCodeVerifier,\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n      }),\n      body: encodeBody(body),\n    };\n\n    try {\n      const response = await fetch(this.tokenEndpoint, config);\n\n      if (!response.ok) {\n        // TODO: Error, deal with failure cases\n        return undefined;\n      }\n\n      const authToken = await response.json();\n\n      this.token = {\n        accessToken: authToken.access_token,\n        refreshToken: authToken.refresh_token,\n        expiresIn: authToken.expires_in,\n        tokenType: authToken.token_type,\n        scope: authToken.scope,\n        idToken: authToken.id_token,\n      };\n\n      Storage.set(this.storageKey, this.token);\n      // clean up local storage from PKCE details\n      Storage.remove(currentState);\n      // clean up query params from OAuth redirection\n      window.history.replaceState({}, document.title, window.location.pathname);\n\n      return this.token;\n    } catch (error) {\n      throw new Error('Error getting token');\n    }\n  };\n\n  refreshToken = async (): Promise<Init | undefined> => {\n    if (!this.token || !this.tokenEndpoint) {\n      throw new Error('Cannot refresh token without token or endpoint');\n    }\n\n    if (!this.token.refreshToken) {\n      throw new Error('Cannot refresh token without refresh token');\n    }\n\n    const body = {\n      grant_type: 'refresh_token',\n      refresh_token: this.token.refreshToken,\n      redirect_uri: this.redirectURI,\n      client_id: encodeURIComponent(this.clientId),\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n      }),\n      body: encodeBody(body),\n    };\n\n    const response = await fetch(this.tokenEndpoint, config);\n\n    if (!response.ok) {\n      throw new Error('Token not refreshed');\n    }\n\n    const token = await response.json();\n\n    this.token = {\n      accessToken: token.access_token,\n      refreshToken: token.refresh_token,\n      expiresIn: token.expires_in,\n      tokenType: token.token_type,\n      scope: token.scope,\n      idToken: token.id_token,\n    };\n\n    Storage.set(this.storageKey, this.token);\n\n    // TODO @all call listeners if something changed\n\n    // (?) We don't return the token directly\n    return { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }\n  };\n\n  login = (): void => {\n    const originalCodeVerifier = generateCodeVerifier(96);\n    const codeVerifier = generatePkceChallenge(originalCodeVerifier);\n    const state = uuidv4();\n\n    const params = {\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      scope: 'openid email profile',\n      response_type: 'code',\n      response_mode: 'query',\n      state: encodeURIComponent(state),\n      code_challenge: encodeURI(codeVerifier),\n      code_challenge_method: 'S256',\n    };\n\n    Storage.set(state, {\n      codeVerifier,\n      originalCodeVerifier,\n    });\n\n    const loginQuery = queryString.stringify(params);\n    const url = `${this.authorizationEndpoint}?${loginQuery}`;\n    window.location.replace(url);\n  };\n\n  protected abstract loadUserInfo(userJSON: any): UserInfo;\n\n  getUserInfo = async (): Promise<UserInfo | undefined> => {\n    if (!this.userInfoEndpoint || !this.token) {\n      return undefined\n    }\n\n    const response = await fetch(this.userInfoEndpoint, {\n      headers: new Headers({\n        Authorization: `Bearer ${this.token.accessToken}`,\n      }),\n    });\n\n    const userInfo = await response.json();\n    this.user = this.loadUserInfo(userInfo)\n\n    return this.user;\n  };\n\n  private revokeToken = async (tokenKey: string): Promise<boolean> => {\n    if (!this.revocationEndpoint) {\n      throw new Error('Cannot revoke token without endpoint');\n    }\n\n    const body = {\n      token: tokenKey,\n      client_id: encodeURIComponent(this.clientId),\n    };\n\n    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n        Authorization: `Bearer ${tokenKey}`,\n      }),\n      body: encodeBody(body),\n    };\n\n    const response = await fetch(this.revocationEndpoint, config);\n\n    if (!response.ok) {\n      throw new Error('Token not revoked');\n    }\n\n    return response.ok;\n  };\n\n  logout = async (ignoreRevokationErrors: boolean = false): Promise<void> => {\n    if (!this.token) {\n      throw new Error('Cannot logout without token');\n    }\n\n    try {\n      await Promise.all([\n        this.revokeToken(this.token.accessToken),\n        this.revokeToken(this.token.refreshToken),\n      ]);\n    } catch (error) {\n      if (!ignoreRevokationErrors) {\n        throw error\n      }\n    }\n\n    this.comesFromLogin = false;\n\n    this.token = undefined;\n    this.user = undefined;\n\n    this.callListeners();\n\n    return Storage.remove(this.storageKey);\n  };\n}\n"]}

@@ -17,3 +17,2 @@ "use strict";

lastName: userJSON.family_name,
picture: userJSON.picture,
};

@@ -23,2 +22,2 @@ }

exports.default = OktaJS;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2t0YUpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL09rdGFKUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQUt6QyxNQUFxQixNQUFPLFNBQVEscUJBQTBCO0lBQzVELFlBQVksUUFBZ0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQ2xFLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBR1MsWUFBWSxDQUFDLFFBQWE7UUFDbEMsT0FBTztZQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsR0FBRztZQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7WUFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1lBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVztZQUM5QixPQUFPLEVBQUUsUUFBUSxDQUFDLE9BQU87U0FDMUIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWZELHlCQWVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE9wZW5JRENsaWVudCBmcm9tICcuL09BdXRoQ2xpZW50JztcbmltcG9ydCB7IE9BdXRoVXNlckluZm8gfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgT2t0YVVzZXJJbmZvID0gT0F1dGhVc2VySW5mb1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBPa3RhSlMgZXh0ZW5kcyBPcGVuSURDbGllbnQ8T2t0YVVzZXJJbmZvPiB7XG4gIGNvbnN0cnVjdG9yKGNsaWVudElkOiBzdHJpbmcsIGNvbmZpZ1VybDogc3RyaW5nLCByZWRpcmVjdFVSSTogc3RyaW5nKSB7XG4gICAgc3VwZXIoY2xpZW50SWQsIGNvbmZpZ1VybCwgcmVkaXJlY3RVUkksICdva3RhX3Rva2VuJyk7XG4gIH1cblxuICAvLyBodHRwczovL2RldmVsb3Blci5va3RhLmNvbS9kb2NzL3JlZmVyZW5jZS9hcGkvb2lkYy8jdXNlcmluZm9cbiAgcHJvdGVjdGVkIGxvYWRVc2VySW5mbyh1c2VySlNPTjogYW55KTogT2t0YVVzZXJJbmZvIHtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHVzZXJKU09OLnN1YixcbiAgICAgIGVtYWlsOiB1c2VySlNPTi5lbWFpbCxcbiAgICAgIG5hbWU6IHVzZXJKU09OLmdpdmVuX25hbWUsXG4gICAgICBsYXN0TmFtZTogdXNlckpTT04uZmFtaWx5X25hbWUsXG4gICAgICBwaWN0dXJlOiB1c2VySlNPTi5waWN0dXJlLCAvLyAoPykgcGljdHVyZSBpcyBub3QgZG9jdW1lbnRlZFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2t0YUpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL09rdGFKUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQUt6QyxNQUFxQixNQUFPLFNBQVEscUJBQTBCO0lBQzVELFlBQVksUUFBZ0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQ2xFLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBR1MsWUFBWSxDQUFDLFFBQWE7UUFDbEMsT0FBTztZQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsR0FBRztZQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7WUFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1lBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVztTQUMvQixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBZEQseUJBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgT3BlbklEQ2xpZW50IGZyb20gJy4vT0F1dGhDbGllbnQnO1xuaW1wb3J0IHsgT0F1dGhVc2VySW5mbyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgdHlwZSBPa3RhVXNlckluZm8gPSBPQXV0aFVzZXJJbmZvXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE9rdGFKUyBleHRlbmRzIE9wZW5JRENsaWVudDxPa3RhVXNlckluZm8+IHtcbiAgY29uc3RydWN0b3IoY2xpZW50SWQ6IHN0cmluZywgY29uZmlnVXJsOiBzdHJpbmcsIHJlZGlyZWN0VVJJOiBzdHJpbmcpIHtcbiAgICBzdXBlcihjbGllbnRJZCwgY29uZmlnVXJsLCByZWRpcmVjdFVSSSwgJ29rdGFfdG9rZW4nKTtcbiAgfVxuXG4gIC8vIGh0dHBzOi8vZGV2ZWxvcGVyLm9rdGEuY29tL2RvY3MvcmVmZXJlbmNlL2FwaS9vaWRjLyN1c2VyaW5mb1xuICBwcm90ZWN0ZWQgbG9hZFVzZXJJbmZvKHVzZXJKU09OOiBhbnkpOiBPa3RhVXNlckluZm8ge1xuICAgIHJldHVybiB7XG4gICAgICBpZDogdXNlckpTT04uc3ViLFxuICAgICAgZW1haWw6IHVzZXJKU09OLmVtYWlsLFxuICAgICAgbmFtZTogdXNlckpTT04uZ2l2ZW5fbmFtZSxcbiAgICAgIGxhc3ROYW1lOiB1c2VySlNPTi5mYW1pbHlfbmFtZSxcbiAgICB9O1xuICB9XG59XG4iXX0=

@@ -13,3 +13,2 @@ export declare type Token = {

readonly lastName: string;
readonly picture: string;
readonly id: string;

@@ -16,0 +15,0 @@ };

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgT0F1dGhVc2VySW5mbyA9IHtcbiAgcmVhZG9ubHkgZW1haWw6IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBsYXN0TmFtZTogc3RyaW5nO1xuICByZWFkb25seSBwaWN0dXJlOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBXYXRjaEF1dGhDYWxsYmFjayA9ICh1c2VyOiBPQXV0aFVzZXJJbmZvIHwgdW5kZWZpbmVkLCBjb21lc0Zyb21Mb2dpbjogYm9vbGVhbikgPT4gdm9pZDtcblxuZXhwb3J0IHR5cGUgSW5pdCA9IHtcbiAgYWNjZXNzVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG59O1xuXG5leHBvcnQgdHlwZSBDb25maWdFbmRwb2ludCA9IHtcbiAgYXV0aG9yaXphdGlvbl9lbmRwb2ludDogc3RyaW5nO1xuICB0b2tlbl9lbmRwb2ludDogc3RyaW5nO1xuICB1c2VyaW5mb19lbmRwb2ludDogc3RyaW5nO1xuICByZXZvY2F0aW9uX2VuZHBvaW50OiBzdHJpbmc7XG59OyJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgT0F1dGhVc2VySW5mbyA9IHtcbiAgcmVhZG9ubHkgZW1haWw6IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBsYXN0TmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpZDogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgV2F0Y2hBdXRoQ2FsbGJhY2sgPSAodXNlcjogT0F1dGhVc2VySW5mbyB8IHVuZGVmaW5lZCwgY29tZXNGcm9tTG9naW46IGJvb2xlYW4pID0+IHZvaWQ7XG5cbmV4cG9ydCB0eXBlIEluaXQgPSB7XG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIGV4cGlyZXNJbjogbnVtYmVyO1xufTtcblxuZXhwb3J0IHR5cGUgQ29uZmlnRW5kcG9pbnQgPSB7XG4gIGF1dGhvcml6YXRpb25fZW5kcG9pbnQ6IHN0cmluZztcbiAgdG9rZW5fZW5kcG9pbnQ6IHN0cmluZztcbiAgdXNlcmluZm9fZW5kcG9pbnQ6IHN0cmluZztcbiAgcmV2b2NhdGlvbl9lbmRwb2ludDogc3RyaW5nO1xufTsiXX0=

@@ -59,2 +59,2 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tDYWxsYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja0NhbGxiYWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHVDQUFvQztBQUNwQyxnRUFBdUM7QUFldkMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQVcsRUFBOEIsRUFBRTtJQUNuRSxNQUFNLFVBQVUsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3BDLElBQUksVUFBVSxLQUFLLENBQUMsQ0FBQyxFQUFFO1FBQ3JCLE1BQU0sVUFBVSxHQUE0QjtZQUMxQyxJQUFJLEVBQUUsU0FBUztZQUNmLE1BQU0sRUFBRSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUM7WUFDcEMsS0FBSyxFQUFFLFNBQVM7U0FDakIsQ0FBQztRQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsVUFBVSxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDeEQsTUFBTSxXQUFXLEdBQUcsc0JBQVcsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFN0MsTUFBTSxXQUFXLEdBQTRELEVBQUUsQ0FBQztRQUNoRixNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxFQUFFLEVBQUU7WUFDN0QsUUFBUSxRQUFRLEVBQUU7Z0JBQ2hCLEtBQUssTUFBTTtvQkFDVCxVQUFVLENBQUMsSUFBSSxHQUFHLFVBQW9CLENBQUM7b0JBQ3ZDLE1BQU07Z0JBQ1IsS0FBSyxPQUFPO29CQUNWLFVBQVUsQ0FBQyxLQUFLLEdBQUcsVUFBb0IsQ0FBQztvQkFDeEMsTUFBTTtnQkFDUjtvQkFDRSxXQUFXLENBQUMsUUFBUSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUNuQyxNQUFNO2FBQ1Q7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxNQUFNLEVBQUU7WUFDbkMsVUFBVSxDQUFDLE1BQU0sSUFBSSxJQUFJLHNCQUFXLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUM7U0FDL0Q7UUFDRCxJQUFJLFVBQVUsQ0FBQyxJQUFJLElBQUksVUFBVSxDQUFDLEtBQUssRUFBRTtZQUN2QyxPQUFPLFVBQTRCLENBQUM7U0FDckM7UUFDRCxPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVXLFFBQUEsYUFBYSxHQUFHLENBQUMsR0FBVyxFQUEyQixFQUFFO0lBQ3BFLE1BQU0sS0FBSyxHQUFHLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3BDLElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDVixPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUVELE1BQU0sV0FBVyxHQUFHLGlCQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUU3QyxJQUFJLFdBQVcsRUFBRTtRQUNmLE9BQU87WUFDTCxnQkFBZ0IsRUFBRSxXQUFXLENBQUMsb0JBQW9CO1lBQ2xELElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtZQUNoQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDcEIsWUFBWSxFQUFFLEtBQUssQ0FBQyxLQUFLO1NBQzFCLENBQUM7S0FDSDtJQUNELE1BQU0sS0FBSyxDQUFDLGtEQUFrRCxDQUFDLENBQUM7QUFDbEUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RvcmFnZSB9IGZyb20gJy4vU3RvcmFnZSc7XG5pbXBvcnQgcXVlcnlTdHJpbmcgZnJvbSAncXVlcnktc3RyaW5nJztcblxudHlwZSBPYXV0aFBhcmFtcyA9IHtcbiAgcGtjZUNvZGVWZXJpZmllcjogc3RyaW5nO1xuICBjb2RlOiBzdHJpbmc7XG4gIG5ld1VybDogc3RyaW5nO1xuICBjdXJyZW50U3RhdGU6IHN0cmluZztcbn07XG5cbnR5cGUgQ2FsbGJhY2tQYXJhbXMgPSB7XG4gIGNvZGU6IHN0cmluZztcbiAgc3RhdGU6IHN0cmluZztcbiAgbmV3VXJsOiBzdHJpbmc7XG59O1xuXG5jb25zdCBwYXJzZUNhbGxiYWNrVXJsID0gKHVybDogc3RyaW5nKTogQ2FsbGJhY2tQYXJhbXMgfCB1bmRlZmluZWQgPT4ge1xuICBjb25zdCBxdWVyeUluZGV4ID0gdXJsLmluZGV4T2YoJz8nKTtcbiAgaWYgKHF1ZXJ5SW5kZXggIT09IC0xKSB7XG4gICAgY29uc3Qgb2F0aFBhcmFtczogUGFydGlhbDxDYWxsYmFja1BhcmFtcz4gPSB7XG4gICAgICBjb2RlOiB1bmRlZmluZWQsXG4gICAgICBuZXdVcmw6IHVybC5zdWJzdHJpbmcoMCwgcXVlcnlJbmRleCksXG4gICAgICBzdGF0ZTogdW5kZWZpbmVkLFxuICAgIH07XG4gICAgY29uc3QgcXVlcnkgPSB1cmwuc3Vic3RyaW5nKHF1ZXJ5SW5kZXggKyAxLCB1cmwubGVuZ3RoKTtcbiAgICBjb25zdCBxdWVyeVBhcmFtcyA9IHF1ZXJ5U3RyaW5nLnBhcnNlKHF1ZXJ5KTtcbiAgICAvLyBxdWVyeSBwYXJhbSB0eXBlc1xuICAgIGNvbnN0IG90aGVyUGFyYW1zOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdIHwgbnVsbCB8IHVuZGVmaW5lZCB9ID0ge307XG4gICAgT2JqZWN0LmVudHJpZXMocXVlcnlQYXJhbXMpLmZvckVhY2goKFtxdWVyeUtleSwgcXVlcnlWYWx1ZV0pID0+IHtcbiAgICAgIHN3aXRjaCAocXVlcnlLZXkpIHtcbiAgICAgICAgY2FzZSAnY29kZSc6XG4gICAgICAgICAgb2F0aFBhcmFtcy5jb2RlID0gcXVlcnlWYWx1ZSBhcyBzdHJpbmc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ3N0YXRlJzpcbiAgICAgICAgICBvYXRoUGFyYW1zLnN0YXRlID0gcXVlcnlWYWx1ZSBhcyBzdHJpbmc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgb3RoZXJQYXJhbXNbcXVlcnlLZXldID0gcXVlcnlWYWx1ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9KTtcbiAgICBpZiAoT2JqZWN0LmtleXMob3RoZXJQYXJhbXMpLmxlbmd0aCkge1xuICAgICAgb2F0aFBhcmFtcy5uZXdVcmwgKz0gYD8ke3F1ZXJ5U3RyaW5nLnN0cmluZ2lmeShvdGhlclBhcmFtcyl9YDtcbiAgICB9XG4gICAgaWYgKG9hdGhQYXJhbXMuY29kZSAmJiBvYXRoUGFyYW1zLnN0YXRlKSB7XG4gICAgICByZXR1cm4gb2F0aFBhcmFtcyBhcyBDYWxsYmFja1BhcmFtcztcbiAgICB9XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuICByZXR1cm4gdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IGNoZWNrQ2FsbGJhY2sgPSAodXJsOiBzdHJpbmcpOiBPYXV0aFBhcmFtcyB8IHVuZGVmaW5lZCA9PiB7XG4gIGNvbnN0IG9hdXRoID0gcGFyc2VDYWxsYmFja1VybCh1cmwpO1xuICBpZiAoIW9hdXRoKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IHN0b3JlZFN0YXRlID0gU3RvcmFnZS5nZXQob2F1dGguc3RhdGUpO1xuXG4gIGlmIChzdG9yZWRTdGF0ZSkge1xuICAgIHJldHVybiB7XG4gICAgICBwa2NlQ29kZVZlcmlmaWVyOiBzdG9yZWRTdGF0ZS5vcmlnaW5hbENvZGVWZXJpZmllcixcbiAgICAgIGNvZGU6IG9hdXRoLmNvZGUsXG4gICAgICBuZXdVcmw6IG9hdXRoLm5ld1VybCxcbiAgICAgIGN1cnJlbnRTdGF0ZTogb2F1dGguc3RhdGUsXG4gICAgfTtcbiAgfVxuICB0aHJvdyBFcnJvcignU3RhdGUgaW4gdXJsIGRvZXMgbm90IG1hdGNoIGxvY2FsbHkgc3RvcmVkIHN0YXRlJyk7XG59OyJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tDYWxsYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja0NhbGxiYWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHVDQUFvQztBQUNwQyxnRUFBdUM7QUFldkMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQVcsRUFBOEIsRUFBRTtJQUNuRSxNQUFNLFVBQVUsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXBDLElBQUksVUFBVSxLQUFLLENBQUMsQ0FBQyxFQUFFO1FBQ3JCLE1BQU0sVUFBVSxHQUE0QjtZQUMxQyxJQUFJLEVBQUUsU0FBUztZQUNmLE1BQU0sRUFBRSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUM7WUFDcEMsS0FBSyxFQUFFLFNBQVM7U0FDakIsQ0FBQztRQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsVUFBVSxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDeEQsTUFBTSxXQUFXLEdBQUcsc0JBQVcsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFN0MsTUFBTSxXQUFXLEdBQTRELEVBQUUsQ0FBQztRQUNoRixNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxFQUFFLEVBQUU7WUFDN0QsUUFBUSxRQUFRLEVBQUU7Z0JBQ2hCLEtBQUssTUFBTTtvQkFDVCxVQUFVLENBQUMsSUFBSSxHQUFHLFVBQW9CLENBQUM7b0JBQ3ZDLE1BQU07Z0JBQ1IsS0FBSyxPQUFPO29CQUNWLFVBQVUsQ0FBQyxLQUFLLEdBQUcsVUFBb0IsQ0FBQztvQkFDeEMsTUFBTTtnQkFDUjtvQkFDRSxXQUFXLENBQUMsUUFBUSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUNuQyxNQUFNO2FBQ1Q7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxNQUFNLEVBQUU7WUFDbkMsVUFBVSxDQUFDLE1BQU0sSUFBSSxJQUFJLHNCQUFXLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUM7U0FDL0Q7UUFFRCxJQUFJLFVBQVUsQ0FBQyxJQUFJLElBQUksVUFBVSxDQUFDLEtBQUssRUFBRTtZQUN2QyxPQUFPLFVBQTRCLENBQUM7U0FDckM7UUFDRCxPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUVELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVXLFFBQUEsYUFBYSxHQUFHLENBQUMsR0FBVyxFQUEyQixFQUFFO0lBQ3BFLE1BQU0sS0FBSyxHQUFHLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXBDLElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDVixPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUVELE1BQU0sV0FBVyxHQUFHLGlCQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUU3QyxJQUFJLFdBQVcsRUFBRTtRQUNmLE9BQU87WUFDTCxnQkFBZ0IsRUFBRSxXQUFXLENBQUMsb0JBQW9CO1lBQ2xELElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtZQUNoQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDcEIsWUFBWSxFQUFFLEtBQUssQ0FBQyxLQUFLO1NBQzFCLENBQUM7S0FDSDtJQUNELE1BQU0sS0FBSyxDQUFDLGtEQUFrRCxDQUFDLENBQUM7QUFDbEUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RvcmFnZSB9IGZyb20gJy4vU3RvcmFnZSc7XG5pbXBvcnQgcXVlcnlTdHJpbmcgZnJvbSAncXVlcnktc3RyaW5nJztcblxudHlwZSBPYXV0aFBhcmFtcyA9IHtcbiAgcGtjZUNvZGVWZXJpZmllcjogc3RyaW5nO1xuICBjb2RlOiBzdHJpbmc7XG4gIG5ld1VybDogc3RyaW5nO1xuICBjdXJyZW50U3RhdGU6IHN0cmluZztcbn07XG5cbnR5cGUgQ2FsbGJhY2tQYXJhbXMgPSB7XG4gIGNvZGU6IHN0cmluZztcbiAgc3RhdGU6IHN0cmluZztcbiAgbmV3VXJsOiBzdHJpbmc7XG59O1xuXG5jb25zdCBwYXJzZUNhbGxiYWNrVXJsID0gKHVybDogc3RyaW5nKTogQ2FsbGJhY2tQYXJhbXMgfCB1bmRlZmluZWQgPT4ge1xuICBjb25zdCBxdWVyeUluZGV4ID0gdXJsLmluZGV4T2YoJz8nKTtcblxuICBpZiAocXVlcnlJbmRleCAhPT0gLTEpIHtcbiAgICBjb25zdCBvYXRoUGFyYW1zOiBQYXJ0aWFsPENhbGxiYWNrUGFyYW1zPiA9IHtcbiAgICAgIGNvZGU6IHVuZGVmaW5lZCxcbiAgICAgIG5ld1VybDogdXJsLnN1YnN0cmluZygwLCBxdWVyeUluZGV4KSxcbiAgICAgIHN0YXRlOiB1bmRlZmluZWQsXG4gICAgfTtcbiAgICBjb25zdCBxdWVyeSA9IHVybC5zdWJzdHJpbmcocXVlcnlJbmRleCArIDEsIHVybC5sZW5ndGgpO1xuICAgIGNvbnN0IHF1ZXJ5UGFyYW1zID0gcXVlcnlTdHJpbmcucGFyc2UocXVlcnkpO1xuICAgIC8vIHF1ZXJ5IHBhcmFtIHR5cGVzXG4gICAgY29uc3Qgb3RoZXJQYXJhbXM6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIHwgc3RyaW5nW10gfCBudWxsIHwgdW5kZWZpbmVkIH0gPSB7fTtcbiAgICBPYmplY3QuZW50cmllcyhxdWVyeVBhcmFtcykuZm9yRWFjaCgoW3F1ZXJ5S2V5LCBxdWVyeVZhbHVlXSkgPT4ge1xuICAgICAgc3dpdGNoIChxdWVyeUtleSkge1xuICAgICAgICBjYXNlICdjb2RlJzpcbiAgICAgICAgICBvYXRoUGFyYW1zLmNvZGUgPSBxdWVyeVZhbHVlIGFzIHN0cmluZztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnc3RhdGUnOlxuICAgICAgICAgIG9hdGhQYXJhbXMuc3RhdGUgPSBxdWVyeVZhbHVlIGFzIHN0cmluZztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICBvdGhlclBhcmFtc1txdWVyeUtleV0gPSBxdWVyeVZhbHVlO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgaWYgKE9iamVjdC5rZXlzKG90aGVyUGFyYW1zKS5sZW5ndGgpIHtcbiAgICAgIG9hdGhQYXJhbXMubmV3VXJsICs9IGA/JHtxdWVyeVN0cmluZy5zdHJpbmdpZnkob3RoZXJQYXJhbXMpfWA7XG4gICAgfVxuXG4gICAgaWYgKG9hdGhQYXJhbXMuY29kZSAmJiBvYXRoUGFyYW1zLnN0YXRlKSB7XG4gICAgICByZXR1cm4gb2F0aFBhcmFtcyBhcyBDYWxsYmFja1BhcmFtcztcbiAgICB9XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgY29uc3QgY2hlY2tDYWxsYmFjayA9ICh1cmw6IHN0cmluZyk6IE9hdXRoUGFyYW1zIHwgdW5kZWZpbmVkID0+IHtcbiAgY29uc3Qgb2F1dGggPSBwYXJzZUNhbGxiYWNrVXJsKHVybCk7XG5cbiAgaWYgKCFvYXV0aCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBzdG9yZWRTdGF0ZSA9IFN0b3JhZ2UuZ2V0KG9hdXRoLnN0YXRlKTtcblxuICBpZiAoc3RvcmVkU3RhdGUpIHtcbiAgICByZXR1cm4ge1xuICAgICAgcGtjZUNvZGVWZXJpZmllcjogc3RvcmVkU3RhdGUub3JpZ2luYWxDb2RlVmVyaWZpZXIsXG4gICAgICBjb2RlOiBvYXV0aC5jb2RlLFxuICAgICAgbmV3VXJsOiBvYXV0aC5uZXdVcmwsXG4gICAgICBjdXJyZW50U3RhdGU6IG9hdXRoLnN0YXRlLFxuICAgIH07XG4gIH1cbiAgdGhyb3cgRXJyb3IoJ1N0YXRlIGluIHVybCBkb2VzIG5vdCBtYXRjaCBsb2NhbGx5IHN0b3JlZCBzdGF0ZScpO1xufTsiXX0=
{
"name": "@mybiogen/auth-openid",
"version": "1.1.0",
"version": "1.1.1",
"description": "Authorization for OpenID",

@@ -35,3 +35,3 @@ "license": "MIT",

},
"gitHead": "399982b3b95d12078b00f64ebe45f4419108aa8c"
"gitHead": "abf713deb5b18b9d944e8c1f5bf820565dd381d4"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc