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

@mybiogen/auth-openid

Package Overview
Dependencies
Maintainers
13
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.4.5 to 1.5.0

6

lib/OAuthClient.d.ts

@@ -1,2 +0,2 @@

import { OAuthUserInfo, Token, WatchAuthCallback, Init } from './types';
import { OAuthUserInfo, Token, WatchAuthCallback, Init, AuthenticateExtraParams } from './types';
export default abstract class OpenIDClient<Claims extends {} = {}, UserInfo extends OAuthUserInfo = OAuthUserInfo, UserData extends {

@@ -40,4 +40,4 @@ user: UserInfo;

private authenticate;
login: (forcedRedirectTo?: string | undefined, uiLocales?: string | undefined) => void;
signup: (forcedRedirectTo?: string | undefined, uiLocales?: string | undefined) => void;
login: (forcedRedirectTo?: string | undefined, extraParams?: AuthenticateExtraParams | undefined) => void;
signup: (forcedRedirectTo?: string | undefined, extraParams?: AuthenticateExtraParams | undefined) => void;
protected abstract loadUserInfo(userJSON: any, claims?: Claims): UserData;

@@ -44,0 +44,0 @@ getUserInfo: () => Promise<{

@@ -136,3 +136,3 @@ "use strict";

this.authenticate = (args) => {
const { forcedRedirectTo, isSignup, uiLocales } = args;
const { forcedRedirectTo, isSignup, extraParams } = args;
const originalCodeVerifier = utils_1.generateCodeVerifier(96);

@@ -164,5 +164,3 @@ const codeVerifier = utils_1.generatePkceChallenge(originalCodeVerifier);

claims: claimParam && JSON.stringify(claimParam),
...(uiLocales && {
ui_locales: uiLocales
}),
...(extraParams || {}),
...(isSignup && {

@@ -181,7 +179,7 @@ prompt: 'create'

};
this.login = (forcedRedirectTo, uiLocales) => {
this.authenticate({ forcedRedirectTo, uiLocales });
this.login = (forcedRedirectTo, extraParams) => {
this.authenticate({ forcedRedirectTo, extraParams });
};
this.signup = (forcedRedirectTo, uiLocales) => {
this.authenticate({ forcedRedirectTo, uiLocales, isSignup: true });
this.signup = (forcedRedirectTo, extraParams) => {
this.authenticate({ forcedRedirectTo, extraParams, isSignup: true });
};

@@ -314,2 +312,2 @@ this.getUserInfo = async () => {

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  AuthenticateArgs,\n  ClaimParam,\n} from './types';\n\nexport default abstract class OpenIDClient<Claims extends {} = {}, UserInfo extends OAuthUserInfo = OAuthUserInfo, UserData extends { user: UserInfo, claims?: Claims } = { user: UserInfo, claims?: Claims }> {\n  clientId: string;\n\n  configUrl: string;\n\n  scopes: string[];\n\n  claims: Array<keyof Claims>;\n\n  redirectURI: string;\n\n  logoutRedirectURI: string;\n\n  authorizationEndpoint?: string;\n\n  tokenEndpoint?: string;\n\n  userInfoEndpoint?: string;\n\n  revocationEndpoint?: string;\n\n  endSessionEndpoint?: string;\n\n  token?: Token;\n\n  user?: UserData;\n\n  storageKey: string;\n\n  listeners: Array<WatchAuthCallback<UserInfo, Claims>> = [];\n\n  refreshTokenInterval?: number;\n\n  comesFromLogin: boolean;\n\n  redirectTo?: string;\n\n  hasBeenInitialized: boolean;\n\n  constructor(clientId: string, configUrl: string, redirectURI: string, storageKey: string, logoutRedirectURI: string, scopes: string[] = ['openid'], claims: Array<keyof Claims> = []) {\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 (!logoutRedirectURI) {\n      throw new Error('logoutRedirectURI is not provided.')\n    }\n    this.logoutRedirectURI = logoutRedirectURI;\n\n    if (!storageKey) {\n      throw new Error('storageKey is not provided.')\n    }\n    this.storageKey = storageKey;\n\n    this.comesFromLogin = false;\n    this.redirectTo = undefined;\n    this.hasBeenInitialized = false;\n    this.scopes = scopes;\n    this.claims = claims;\n    this.token = typeof window !== 'undefined' ? Storage.get(`${storageKey}.token`) : null;\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}.token`),\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 && !storageOauth.logout) {\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, \n      pkceCodeVerifier, \n      currentState, \n      redirectTo,\n      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\n    this.comesFromLogin = true;\n    this.redirectTo = redirectTo;\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}.token`);\n    }\n\n    return this.token\n  }\n\n  private callListeners(): void {\n    this.listeners.forEach((cb) => {\n      cb(this.token && this.user, this.comesFromLogin, this.redirectTo)\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<UserInfo, Claims>): 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      this.endSessionEndpoint = config.end_session_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}.token`, 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}.token`, 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  private authenticate = (args: AuthenticateArgs): void => {\n    const { forcedRedirectTo, isSignup, uiLocales } = args;\n    const originalCodeVerifier = generateCodeVerifier(96);\n    const codeVerifier = generatePkceChallenge(originalCodeVerifier);\n    const { pathname, search } = window.location;\n    const { origin } = queryString.parse(search);\n    const redirectTo = forcedRedirectTo ? forcedRedirectTo : origin ? decodeURIComponent(origin + \"\") : pathname + search;\n    const state = uuidv4();\n    let claimParam;\n  \n    if (this.claims.length) {\n      const claimMap = this.claims.reduce<ClaimParam>((curr, claim) => ({ ...curr, [claim]: null }), {});\n      claimParam = this.claims.length\n        ? {\n            userinfo: claimMap,\n            id_token: claimMap,\n          }\n        : undefined;\n    }\n\n    const params = {\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      scope: this.scopes.join(' '),\n      response_type: 'code',\n      response_mode: 'query',\n      state: encodeURIComponent(state),\n      code_challenge: encodeURI(codeVerifier),\n      code_challenge_method: 'S256',\n      claims: claimParam && JSON.stringify(claimParam),\n      ...(uiLocales && {\n        ui_locales: uiLocales\n      }),\n      ...(isSignup && {\n        prompt: 'create'\n      }),\n    };\n\n    Storage.set(state, {\n      codeVerifier,\n      originalCodeVerifier,\n      redirectTo,\n    });\n\n    const loginQuery = queryString.stringify(params);\n    const url = `${this.authorizationEndpoint}?${loginQuery}`;\n    window.location.replace(url);\n  }\n\n  login = (forcedRedirectTo?: string, uiLocales?: string): void => {\n    this.authenticate({ forcedRedirectTo, uiLocales });\n  };\n\n  signup = (forcedRedirectTo?: string, uiLocales?: string): void => {\n    this.authenticate({ forcedRedirectTo, uiLocales, isSignup: true });\n  };\n\n  protected abstract loadUserInfo(userJSON: any, claims?: Claims): UserData;\n\n  getUserInfo = async (): Promise<{ user: UserInfo, claims?: Claims } | undefined> => {\n    if (!this.userInfoEndpoint || !this.token) {\n      return undefined\n    }\n\n    try {\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      const claims = this.claims.length\n        ? this.claims.reduce<Claims>((curr, claim) => ({\n          ...curr,\n          [claim]: userInfo[claim],\n        }), {} as Claims)\n        : undefined;\n      this.user = this.loadUserInfo(userInfo, claims);\n\n      return this.user;\n    } catch (error) {\n      console.warn('Error getting user info, logging out...');\n      console.warn(error);\n      await this.logout();\n      return undefined;\n    }\n  };\n\n  logout = async (endSessionURI?: string): Promise<void> => {\n    Storage.remove(`${this.storageKey}.token`);\n\n    if (endSessionURI) {\n      // JanrainJS\n      window.location.replace(endSessionURI);\n    } else {\n      // OktaJS\n      const params = {\n        'id_token_hint': this.token?.idToken,\n        'post_logout_redirect_uri': this.logoutRedirectURI,\n      };\n      if (this.endSessionEndpoint) {\n        const url = `${this.endSessionEndpoint}?${queryString.stringify(params)}`;\n        window.location.replace(url);  \n      }\n    }\n\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  AuthenticateArgs,\n  ClaimParam,\n  AuthenticateExtraParams,\n} from './types';\n\nexport default abstract class OpenIDClient<Claims extends {} = {}, UserInfo extends OAuthUserInfo = OAuthUserInfo, UserData extends { user: UserInfo, claims?: Claims } = { user: UserInfo, claims?: Claims }> {\n  clientId: string;\n\n  configUrl: string;\n\n  scopes: string[];\n\n  claims: Array<keyof Claims>;\n\n  redirectURI: string;\n\n  logoutRedirectURI: string;\n\n  authorizationEndpoint?: string;\n\n  tokenEndpoint?: string;\n\n  userInfoEndpoint?: string;\n\n  revocationEndpoint?: string;\n\n  endSessionEndpoint?: string;\n\n  token?: Token;\n\n  user?: UserData;\n\n  storageKey: string;\n\n  listeners: Array<WatchAuthCallback<UserInfo, Claims>> = [];\n\n  refreshTokenInterval?: number;\n\n  comesFromLogin: boolean;\n\n  redirectTo?: string;\n\n  hasBeenInitialized: boolean;\n\n  constructor(clientId: string, configUrl: string, redirectURI: string, storageKey: string, logoutRedirectURI: string, scopes: string[] = ['openid'], claims: Array<keyof Claims> = []) {\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 (!logoutRedirectURI) {\n      throw new Error('logoutRedirectURI is not provided.')\n    }\n    this.logoutRedirectURI = logoutRedirectURI;\n\n    if (!storageKey) {\n      throw new Error('storageKey is not provided.')\n    }\n    this.storageKey = storageKey;\n\n    this.comesFromLogin = false;\n    this.redirectTo = undefined;\n    this.hasBeenInitialized = false;\n    this.scopes = scopes;\n    this.claims = claims;\n    this.token = typeof window !== 'undefined' ? Storage.get(`${storageKey}.token`) : null;\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}.token`),\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 && !storageOauth.logout) {\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, \n      pkceCodeVerifier, \n      currentState, \n      redirectTo,\n      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\n    this.comesFromLogin = true;\n    this.redirectTo = redirectTo;\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}.token`);\n    }\n\n    return this.token\n  }\n\n  private callListeners(): void {\n    this.listeners.forEach((cb) => {\n      cb(this.token && this.user, this.comesFromLogin, this.redirectTo)\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<UserInfo, Claims>): 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      this.endSessionEndpoint = config.end_session_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}.token`, 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}.token`, 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  private authenticate = (args: AuthenticateArgs): void => {\n    const { forcedRedirectTo, isSignup, extraParams } = args;\n    const originalCodeVerifier = generateCodeVerifier(96);\n    const codeVerifier = generatePkceChallenge(originalCodeVerifier);\n    const { pathname, search } = window.location;\n    const { origin } = queryString.parse(search);\n    const redirectTo = forcedRedirectTo ? forcedRedirectTo : origin ? decodeURIComponent(origin + \"\") : pathname + search;\n    const state = uuidv4();\n    let claimParam;\n  \n    if (this.claims.length) {\n      const claimMap = this.claims.reduce<ClaimParam>((curr, claim) => ({ ...curr, [claim]: null }), {});\n      claimParam = this.claims.length\n        ? {\n            userinfo: claimMap,\n            id_token: claimMap,\n          }\n        : undefined;\n    }\n\n    const params = {\n      client_id: encodeURIComponent(this.clientId),\n      redirect_uri: this.redirectURI,\n      scope: this.scopes.join(' '),\n      response_type: 'code',\n      response_mode: 'query',\n      state: encodeURIComponent(state),\n      code_challenge: encodeURI(codeVerifier),\n      code_challenge_method: 'S256',\n      claims: claimParam && JSON.stringify(claimParam),\n      ...(extraParams || {}),\n      ...(isSignup && {\n        prompt: 'create'\n      }),\n    };\n\n    Storage.set(state, {\n      codeVerifier,\n      originalCodeVerifier,\n      redirectTo,\n    });\n\n    const loginQuery = queryString.stringify(params);\n    const url = `${this.authorizationEndpoint}?${loginQuery}`;\n    window.location.replace(url);\n  }\n\n  login = (forcedRedirectTo?: string, extraParams?: AuthenticateExtraParams): void => {\n    this.authenticate({ forcedRedirectTo, extraParams });\n  };\n\n  signup = (forcedRedirectTo?: string, extraParams?: AuthenticateExtraParams): void => {\n    this.authenticate({ forcedRedirectTo, extraParams, isSignup: true });\n  };\n\n  protected abstract loadUserInfo(userJSON: any, claims?: Claims): UserData;\n\n  getUserInfo = async (): Promise<{ user: UserInfo, claims?: Claims } | undefined> => {\n    if (!this.userInfoEndpoint || !this.token) {\n      return undefined\n    }\n\n    try {\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      const claims = this.claims.length\n        ? this.claims.reduce<Claims>((curr, claim) => ({\n          ...curr,\n          [claim]: userInfo[claim],\n        }), {} as Claims)\n        : undefined;\n      this.user = this.loadUserInfo(userInfo, claims);\n\n      return this.user;\n    } catch (error) {\n      console.warn('Error getting user info, logging out...');\n      console.warn(error);\n      await this.logout();\n      return undefined;\n    }\n  };\n\n  logout = async (endSessionURI?: string): Promise<void> => {\n    Storage.remove(`${this.storageKey}.token`);\n\n    if (endSessionURI) {\n      // JanrainJS\n      window.location.replace(endSessionURI);\n    } else {\n      // OktaJS\n      const params = {\n        'id_token_hint': this.token?.idToken,\n        'post_logout_redirect_uri': this.logoutRedirectURI,\n      };\n      if (this.endSessionEndpoint) {\n        const url = `${this.endSessionEndpoint}?${queryString.stringify(params)}`;\n        window.location.replace(url);  \n      }\n    }\n\n  };\n}\n"]}

@@ -31,6 +31,22 @@ export declare type Token = {

};
declare type AuthenticateParams = {
client_id: string;
redirect_uri: string;
scope: string;
response_type: string;
response_mode: string;
state: string;
code_challenge: string;
code_challenge_method: string;
claims?: string;
prompt?: string;
};
declare type ExtraParams = {
[key: string]: string;
};
export declare type AuthenticateExtraParams = AuthenticateParams & ExtraParams;
export declare type AuthenticateArgs = {
forcedRedirectTo?: string;
isSignup?: boolean;
uiLocales?: string;
extraParams?: AuthenticateExtraParams;
};

@@ -40,2 +56,3 @@ export declare type ClaimParam = {

};
export {};
//# sourceMappingURL=index.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgT0F1dGhVc2VySW5mbyA9IHtcbiAgcmVhZG9ubHkgZW1haWw6IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBsYXN0TmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpZDogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgVXNlckRhdGE8VXNlckluZm8gZXh0ZW5kcyBPQXV0aFVzZXJJbmZvLCBDbGFpbXM+ID0ge1xuICB1c2VyOiBVc2VySW5mbztcbiAgY2xhaW1zPzogQ2xhaW1zO1xufVxuXG5leHBvcnQgdHlwZSBXYXRjaEF1dGhDYWxsYmFjazxVc2VySW5mbyBleHRlbmRzIE9BdXRoVXNlckluZm8sIENsYWltcz4gPSAodXNlcjogVXNlckRhdGE8VXNlckluZm8sIENsYWltcz4gfCB1bmRlZmluZWQsIGNvbWVzRnJvbUxvZ2luOiBib29sZWFuLCByZWRpcmVjdFRvPzogc3RyaW5nKSA9PiB2b2lkO1xuXG5leHBvcnQgdHlwZSBJbml0ID0ge1xuICBhY2Nlc3NUb2tlbjogc3RyaW5nO1xuICBleHBpcmVzSW46IG51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIENvbmZpZ0VuZHBvaW50ID0ge1xuICBhdXRob3JpemF0aW9uX2VuZHBvaW50OiBzdHJpbmc7XG4gIHRva2VuX2VuZHBvaW50OiBzdHJpbmc7XG4gIHVzZXJpbmZvX2VuZHBvaW50OiBzdHJpbmc7XG4gIHJldm9jYXRpb25fZW5kcG9pbnQ6IHN0cmluZztcbiAgZW5kX3Nlc3Npb25fZW5kcG9pbnQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEF1dGhlbnRpY2F0ZUFyZ3MgPSB7XG4gIGZvcmNlZFJlZGlyZWN0VG8/OiBzdHJpbmc7XG4gIGlzU2lnbnVwPzogYm9vbGVhbjtcbiAgdWlMb2NhbGVzPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBDbGFpbVBhcmFtID0ge1xuICBbY2xhaW06IHN0cmluZ106IG51bGwsXG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgT0F1dGhVc2VySW5mbyA9IHtcbiAgcmVhZG9ubHkgZW1haWw6IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBsYXN0TmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpZDogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgVXNlckRhdGE8VXNlckluZm8gZXh0ZW5kcyBPQXV0aFVzZXJJbmZvLCBDbGFpbXM+ID0ge1xuICB1c2VyOiBVc2VySW5mbztcbiAgY2xhaW1zPzogQ2xhaW1zO1xufVxuXG5leHBvcnQgdHlwZSBXYXRjaEF1dGhDYWxsYmFjazxVc2VySW5mbyBleHRlbmRzIE9BdXRoVXNlckluZm8sIENsYWltcz4gPSAodXNlcjogVXNlckRhdGE8VXNlckluZm8sIENsYWltcz4gfCB1bmRlZmluZWQsIGNvbWVzRnJvbUxvZ2luOiBib29sZWFuLCByZWRpcmVjdFRvPzogc3RyaW5nKSA9PiB2b2lkO1xuXG5leHBvcnQgdHlwZSBJbml0ID0ge1xuICBhY2Nlc3NUb2tlbjogc3RyaW5nO1xuICBleHBpcmVzSW46IG51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIENvbmZpZ0VuZHBvaW50ID0ge1xuICBhdXRob3JpemF0aW9uX2VuZHBvaW50OiBzdHJpbmc7XG4gIHRva2VuX2VuZHBvaW50OiBzdHJpbmc7XG4gIHVzZXJpbmZvX2VuZHBvaW50OiBzdHJpbmc7XG4gIHJldm9jYXRpb25fZW5kcG9pbnQ6IHN0cmluZztcbiAgZW5kX3Nlc3Npb25fZW5kcG9pbnQ6IHN0cmluZztcbn07XG5cbnR5cGUgQXV0aGVudGljYXRlUGFyYW1zID0ge1xuICBjbGllbnRfaWQ6IHN0cmluZztcbiAgcmVkaXJlY3RfdXJpOiBzdHJpbmc7XG4gIHNjb3BlOiBzdHJpbmc7XG4gIHJlc3BvbnNlX3R5cGU6IHN0cmluZztcbiAgcmVzcG9uc2VfbW9kZTogc3RyaW5nO1xuICBzdGF0ZTogc3RyaW5nO1xuICBjb2RlX2NoYWxsZW5nZTogc3RyaW5nO1xuICBjb2RlX2NoYWxsZW5nZV9tZXRob2Q6IHN0cmluZztcbiAgY2xhaW1zPzogc3RyaW5nO1xuICBwcm9tcHQ/OiBzdHJpbmc7XG59XG5cbnR5cGUgRXh0cmFQYXJhbXMgPSB7XG4gIFtrZXk6IHN0cmluZ106IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEF1dGhlbnRpY2F0ZUV4dHJhUGFyYW1zID0gQXV0aGVudGljYXRlUGFyYW1zICYgRXh0cmFQYXJhbXM7XG5cbmV4cG9ydCB0eXBlIEF1dGhlbnRpY2F0ZUFyZ3MgPSB7XG4gIGZvcmNlZFJlZGlyZWN0VG8/OiBzdHJpbmc7XG4gIGlzU2lnbnVwPzogYm9vbGVhbjtcbiAgZXh0cmFQYXJhbXM/OiBBdXRoZW50aWNhdGVFeHRyYVBhcmFtcztcbn1cblxuZXhwb3J0IHR5cGUgQ2xhaW1QYXJhbSA9IHtcbiAgW2NsYWltOiBzdHJpbmddOiBudWxsLFxufTtcbiJdfQ==
{
"name": "@mybiogen/auth-openid",
"version": "1.4.5",
"version": "1.5.0",
"description": "Authorization for OpenID",

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

},
"gitHead": "98dd7fe9e7f2236298dda72f371b378cd5e72d3f"
"gitHead": "d77cb14598fd3f2b003d270d505b0a1bc73a6136"
}

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