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.0.2 to 1.1.0

lib/OAuthClient.d.ts

4

lib/index.d.ts

@@ -1,3 +0,5 @@

export { default } from './JanrainJS';
export { default as JanrainJS } from './JanrainJS';
export { default as OktaJS } from './OktaJS';
export { default } from './OAuthClient';
export * from './types';
//# sourceMappingURL=index.d.ts.map

@@ -14,4 +14,8 @@ "use strict";

var JanrainJS_1 = require("./JanrainJS");
Object.defineProperty(exports, "default", { enumerable: true, get: function () { return JanrainJS_1.default; } });
Object.defineProperty(exports, "JanrainJS", { enumerable: true, get: function () { return JanrainJS_1.default; } });
var OktaJS_1 = require("./OktaJS");
Object.defineProperty(exports, "OktaJS", { enumerable: true, get: function () { return OktaJS_1.default; } });
var OAuthClient_1 = require("./OAuthClient");
Object.defineProperty(exports, "default", { enumerable: true, get: function () { return OAuthClient_1.default; } });
__exportStar(require("./types"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXNDO0FBQTdCLG9HQUFBLE9BQU8sT0FBQTtBQUNoQiwwQ0FBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IH0gZnJvbSAnLi9KYW5yYWluSlMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW1EO0FBQTFDLHNHQUFBLE9BQU8sT0FBYTtBQUM3QixtQ0FBNkM7QUFBcEMsZ0dBQUEsT0FBTyxPQUFVO0FBQzFCLDZDQUF3QztBQUEvQixzR0FBQSxPQUFPLE9BQUE7QUFDaEIsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCBhcyBKYW5yYWluSlMgfSBmcm9tICcuL0phbnJhaW5KUyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIE9rdGFKUyB9IGZyb20gJy4vT2t0YUpTJztcbmV4cG9ydCB7IGRlZmF1bHQgfSBmcm9tICcuL09BdXRoQ2xpZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnOyJdfQ==

@@ -1,31 +0,8 @@

import { JanrainUserInfo, Token, WatchAuthCallback, Init } from './types';
declare class JanrainJS {
clientId: string;
configUrl: string;
redirectURI: string;
authorizationEndpoint?: string;
tokenEndpoint?: string;
userInfoEndpoint?: string;
revocationEndpoint?: string;
token?: Token;
user?: JanrainUserInfo;
storageKey: string;
listeners: Array<WatchAuthCallback>;
refreshTokenInterval?: number;
comesFromLogin: boolean;
import OpenIDClient from './OAuthClient';
import { OAuthUserInfo } from './types';
export declare type JanrainUserInfo = OAuthUserInfo;
export default class JanrainJS extends OpenIDClient<JanrainUserInfo> {
constructor(clientId: string, configUrl: string, redirectURI: string);
init(): Promise<Init | undefined>;
private callListeners;
private keepRefreshingToken;
watchAuth: (cb: WatchAuthCallback) => Promise<void>;
private fetchConfig;
private setConfig;
private getToken;
refreshToken: () => Promise<Init | undefined>;
login: () => void;
getUserInfo: () => Promise<JanrainUserInfo | undefined>;
private revokeToken;
logout: () => Promise<void>;
protected loadUserInfo(userJSON: any): JanrainUserInfo;
}
export default JanrainJS;
//# sourceMappingURL=JanrainJS.d.ts.map

@@ -6,284 +6,18 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
const query_string_1 = __importDefault(require("query-string"));
const uuid_1 = require("uuid");
const utils_1 = require("./utils");
class JanrainJS {
const OAuthClient_1 = __importDefault(require("./OAuthClient"));
class JanrainJS extends OAuthClient_1.default {
constructor(clientId, configUrl, redirectURI) {
this.storageKey = 'janrain_token';
this.listeners = [];
this.keepRefreshingToken = () => {
if (this.user && this.token && !this.refreshTokenInterval) {
const SAFETY_GAP_REFRESH_TOKEN = 60000;
this.refreshTokenInterval = window.setInterval(async () => {
try {
await this.refreshToken();
}
catch (error) {
clearInterval(this.refreshTokenInterval);
this.logout();
}
}, (this.token.expiresIn * 1000) - SAFETY_GAP_REFRESH_TOKEN);
}
super(clientId, configUrl, redirectURI, 'janrain_token');
}
loadUserInfo(userJSON) {
return {
id: userJSON.sub,
email: userJSON.email,
name: userJSON.given_name,
lastName: userJSON.family_name,
picture: userJSON.picture,
};
this.watchAuth = async (cb) => {
this.listeners.push(cb);
const token = await this.init();
if (token) {
await this.getUserInfo();
}
this.callListeners();
};
this.fetchConfig = async () => {
try {
const response = await fetch(this.configUrl);
return response.json();
}
catch (error) {
return undefined;
}
};
this.setConfig = async () => {
const config = await this.fetchConfig();
if (config) {
this.authorizationEndpoint = config.authorization_endpoint;
this.tokenEndpoint = config.token_endpoint;
this.userInfoEndpoint = config.userinfo_endpoint;
this.revocationEndpoint = config.revocation_endpoint;
}
};
this.getToken = async (code, originalCodeVerifier, currentState) => {
const body = {
grant_type: 'authorization_code',
code,
client_id: encodeURIComponent(this.clientId),
redirect_uri: this.redirectURI,
code_verifier: originalCodeVerifier,
};
const config = {
method: 'POST',
headers: new Headers({
'Content-Type': 'application/x-www-form-urlencoded',
}),
body: utils_1.encodeBody(body),
};
if (this.tokenEndpoint) {
try {
const response = await fetch(this.tokenEndpoint, config);
if (response.ok) {
const janrainToken = await response.json();
this.token = {
accessToken: janrainToken.access_token,
refreshToken: janrainToken.refresh_token,
expiresIn: janrainToken.expires_in,
tokenType: janrainToken.token_type,
scope: janrainToken.scope,
idToken: janrainToken.id_token,
};
utils_1.Storage.set(this.storageKey, this.token);
utils_1.Storage.remove(currentState);
window.history.replaceState({}, document.title, window.location.pathname);
return this.token;
}
return undefined;
}
catch (error) {
throw new Error('Error getting token');
}
}
else {
throw new Error('Not initialized. Token endpoint not present');
}
};
this.refreshToken = async () => {
try {
if (this.token && this.tokenEndpoint) {
const body = {
grant_type: 'refresh_token',
refresh_token: this.token.refreshToken,
redirect_uri: this.redirectURI,
client_id: encodeURIComponent(this.clientId),
};
const config = {
method: 'POST',
headers: new Headers({
'Content-Type': 'application/x-www-form-urlencoded',
}),
body: utils_1.encodeBody(body),
};
const response = await fetch(this.tokenEndpoint, config);
if (response.ok) {
const janrainToken = await response.json();
this.token = {
accessToken: janrainToken.access_token,
refreshToken: janrainToken.refresh_token,
expiresIn: janrainToken.expires_in,
tokenType: janrainToken.token_type,
scope: janrainToken.scope,
idToken: janrainToken.id_token,
};
utils_1.Storage.set(this.storageKey, this.token);
return this.token
? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }
: undefined;
}
throw new Error('Token not refreshed');
}
throw new Error('Cannot refresh token without token or endpoint');
}
catch (error) {
throw error;
}
};
this.login = () => {
const originalCodeVerifier = utils_1.generateCodeVerifier(96);
const codeVerifier = utils_1.generatePkceChallenge(originalCodeVerifier);
const state = uuid_1.v4();
const params = {
client_id: encodeURIComponent(this.clientId),
redirect_uri: this.redirectURI,
scope: 'openid email profile',
response_type: 'code',
response_mode: 'query',
state: encodeURIComponent(state),
code_challenge: encodeURI(codeVerifier),
code_challenge_method: 'S256',
};
utils_1.Storage.set(state, {
codeVerifier,
originalCodeVerifier,
});
const loginQuery = query_string_1.default.stringify(params);
const url = `${this.authorizationEndpoint}?${loginQuery}`;
window.location.replace(url);
};
this.getUserInfo = async () => {
if (this.userInfoEndpoint && this.token) {
const response = await fetch(this.userInfoEndpoint, {
headers: new Headers({
Authorization: `Bearer ${this.token.accessToken}`,
}),
});
const userInfo = await response.json();
this.user = {
id: userInfo.sub,
email: userInfo.email,
name: userInfo.given_name,
lastName: userInfo.family_name,
picture: userInfo.picture,
};
return this.user;
}
return undefined;
};
this.revokeToken = async (tokenKey) => {
try {
if (this.token && this.revocationEndpoint) {
const body = {
token: tokenKey,
client_id: encodeURIComponent(this.clientId),
};
const config = {
method: 'POST',
headers: new Headers({
'Content-Type': 'application/x-www-form-urlencoded',
Authorization: `Bearer ${tokenKey}`,
}),
body: utils_1.encodeBody(body),
};
const response = await fetch(this.revocationEndpoint, config);
if (response.ok) {
return response.ok;
}
throw new Error('Token not revoked');
}
throw new Error('Cannot revoke token without token or endpoint');
}
catch (error) {
throw error;
}
};
this.logout = async () => {
try {
if (this.token) {
const [revokedAccessToken, revokedRefreshToken] = await Promise.all([
this.revokeToken(this.token.accessToken),
this.revokeToken(this.token.refreshToken),
]);
this.comesFromLogin = false;
this.token = undefined;
this.user = undefined;
if (revokedAccessToken && revokedRefreshToken) {
this.callListeners();
return utils_1.Storage.remove(this.storageKey);
}
throw new Error('Token not removed from storage');
}
throw new Error('Cannot logout without token');
}
catch (error) {
throw error;
}
};
if (!clientId) {
throw new Error('clientId is not provided.');
}
this.clientId = clientId;
if (!configUrl) {
throw new Error('configUrl is not provided.');
}
this.configUrl = configUrl;
if (!redirectURI) {
throw new Error('redirectUri is not provided.');
}
this.redirectURI = redirectURI;
this.comesFromLogin = false;
}
async init() {
const [callbackState, storageOauth] = await Promise.all([
utils_1.checkCallback(window.location.href),
utils_1.Storage.get(this.storageKey),
]);
if (!callbackState && !storageOauth) {
this.setConfig();
return undefined;
}
await this.setConfig();
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;
}
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 undefined;
}
callListeners() {
this.listeners.forEach((cb) => {
if (this.token && this.user) {
cb({ ...this.user }, this.comesFromLogin);
}
else {
cb(undefined, this.comesFromLogin);
}
});
}
}
exports.default = JanrainJS;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"JanrainJS.js","sourceRoot":"","sources":["../src/JanrainJS.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  JanrainUserInfo,\n  Token,\n  WatchAuthCallback,\n  Init,\n  ConfigEndpoint\n} from './types';\n\nclass JanrainJS {\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?: JanrainUserInfo;\n\n  storageKey = 'janrain_token';\n\n  listeners: Array<WatchAuthCallback> = [];\n\n  refreshTokenInterval?: number;\n\n  comesFromLogin: boolean;\n\n  constructor(clientId: string, configUrl: string, redirectURI: 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    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    // Return early\n    if (!callbackState && !storageOauth) {\n      this.setConfig();\n      return undefined;\n    }\n    // Wait until configuration has finished.\n    await this.setConfig();\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    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    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    if (token) {\n      await this.getUserInfo();\n    }\n    this.callListeners();\n  };\n\n  private fetchConfig = async (): Promise<ConfigEndpoint | undefined> => {\n    try {\n      const response = await fetch(this.configUrl);\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    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    const config = {\n      method: 'POST',\n      headers: new Headers({\n        'Content-Type': 'application/x-www-form-urlencoded',\n      }),\n      body: encodeBody(body),\n    };\n    if (this.tokenEndpoint) {\n      try {\n        const response = await fetch(this.tokenEndpoint, config);\n        if (response.ok) {\n          const janrainToken = await response.json();\n          this.token = {\n            accessToken: janrainToken.access_token,\n            refreshToken: janrainToken.refresh_token,\n            expiresIn: janrainToken.expires_in,\n            tokenType: janrainToken.token_type,\n            scope: janrainToken.scope,\n            idToken: janrainToken.id_token,\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 Janrain redirection\n          window.history.replaceState({}, document.title, window.location.pathname);\n          return this.token;\n        }\n        return undefined;\n      } catch (error) {\n        throw new Error('Error getting token');\n      }\n    } else {\n      throw new Error('Not initialized. Token endpoint not present');\n    }\n  };\n\n  refreshToken = async (): Promise<Init | undefined> => {\n    try {\n      if (this.token && this.tokenEndpoint) {\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        const config = {\n          method: 'POST',\n          headers: new Headers({\n            'Content-Type': 'application/x-www-form-urlencoded',\n          }),\n          body: encodeBody(body),\n        };\n        const response = await fetch(this.tokenEndpoint, config);\n        if (response.ok) {\n          const janrainToken = await response.json();\n          this.token = {\n            accessToken: janrainToken.access_token,\n            refreshToken: janrainToken.refresh_token,\n            expiresIn: janrainToken.expires_in,\n            tokenType: janrainToken.token_type,\n            scope: janrainToken.scope,\n            idToken: janrainToken.id_token,\n          };\n          Storage.set(this.storageKey, this.token);\n          return this.token\n            ? { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }\n            : undefined;\n        }\n        throw new Error('Token not refreshed');\n      }\n      throw new Error('Cannot refresh token without token or endpoint');\n    } catch (error) {\n      throw error;\n    }\n  };\n\n  login = (): void => {\n    const originalCodeVerifier = generateCodeVerifier(96);\n    const codeVerifier = generatePkceChallenge(originalCodeVerifier);\n    const state = uuidv4();\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    Storage.set(state, {\n      codeVerifier,\n      originalCodeVerifier,\n    });\n    const loginQuery = queryString.stringify(params);\n    const url = `${this.authorizationEndpoint}?${loginQuery}`;\n    window.location.replace(url);\n  };\n\n  getUserInfo = async (): Promise<JanrainUserInfo | undefined> => {\n    if (this.userInfoEndpoint && this.token) {\n      const response = await fetch(this.userInfoEndpoint, {\n        headers: new Headers({\n          Authorization: `Bearer ${this.token.accessToken}`,\n        }),\n      });\n      const userInfo = await response.json();\n      this.user = {\n        id: userInfo.sub,\n        email: userInfo.email,\n        name: userInfo.given_name,\n        lastName: userInfo.family_name,\n        picture: userInfo.picture,\n      };\n      return this.user;\n    }\n    return undefined;\n  };\n\n  private revokeToken = async (tokenKey: string): Promise<boolean> => {\n    try {\n      if (this.token && this.revocationEndpoint) {\n        const body = {\n          token: tokenKey,\n          client_id: encodeURIComponent(this.clientId),\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        const response = await fetch(this.revocationEndpoint, config);\n        if (response.ok) {\n          return response.ok;\n        }\n        throw new Error('Token not revoked');\n      }\n      throw new Error('Cannot revoke token without token or endpoint');\n    } catch (error) {\n      throw error;\n    }\n  };\n\n  logout = async (): Promise<void> => {\n    try {\n      if (this.token) {\n        const [revokedAccessToken, revokedRefreshToken] = await Promise.all([\n          this.revokeToken(this.token.accessToken),\n          this.revokeToken(this.token.refreshToken),\n        ]);\n        this.comesFromLogin = false;\n        this.token = undefined;\n        this.user = undefined;\n        if (revokedAccessToken && revokedRefreshToken) {\n          this.callListeners();\n          return Storage.remove(this.storageKey);\n        }\n        throw new Error('Token not removed from storage');\n      }\n      throw new Error('Cannot logout without token');\n    } catch (error) {\n      throw error;\n    }\n  };\n}\n\nexport default JanrainJS;\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFucmFpbkpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0phbnJhaW5KUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQUt6QyxNQUFxQixTQUFVLFNBQVEscUJBQTZCO0lBQ2xFLFlBQVksUUFBZ0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQ2xFLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBR1MsWUFBWSxDQUFDLFFBQWE7UUFDbEMsT0FBTztZQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsR0FBRztZQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7WUFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1lBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVztZQUM5QixPQUFPLEVBQUUsUUFBUSxDQUFDLE9BQU87U0FDMUIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWZELDRCQWVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE9wZW5JRENsaWVudCBmcm9tICcuL09BdXRoQ2xpZW50JztcbmltcG9ydCB7IE9BdXRoVXNlckluZm8gfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgSmFucmFpblVzZXJJbmZvID0gT0F1dGhVc2VySW5mb1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBKYW5yYWluSlMgZXh0ZW5kcyBPcGVuSURDbGllbnQ8SmFucmFpblVzZXJJbmZvPiB7XG4gIGNvbnN0cnVjdG9yKGNsaWVudElkOiBzdHJpbmcsIGNvbmZpZ1VybDogc3RyaW5nLCByZWRpcmVjdFVSSTogc3RyaW5nKSB7XG4gICAgc3VwZXIoY2xpZW50SWQsIGNvbmZpZ1VybCwgcmVkaXJlY3RVUkksICdqYW5yYWluX3Rva2VuJyk7XG4gIH1cblxuICAvLyBodHRwczovL2lkZW50aXR5ZG9jcy5ha2FtYWkuY29tL2hvbWUvamFucmFpbi1lbnRpdHktYXBpXG4gIHByb3RlY3RlZCBsb2FkVXNlckluZm8odXNlckpTT046IGFueSk6IEphbnJhaW5Vc2VySW5mbyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiB1c2VySlNPTi5zdWIsXG4gICAgICBlbWFpbDogdXNlckpTT04uZW1haWwsXG4gICAgICBuYW1lOiB1c2VySlNPTi5naXZlbl9uYW1lLFxuICAgICAgbGFzdE5hbWU6IHVzZXJKU09OLmZhbWlseV9uYW1lLFxuICAgICAgcGljdHVyZTogdXNlckpTT04ucGljdHVyZSxcbiAgICB9O1xuICB9XG59XG4iXX0=

@@ -9,3 +9,3 @@ export declare type Token = {

};
export declare type JanrainUserInfo = {
export declare type OAuthUserInfo = {
readonly email: string;

@@ -17,3 +17,3 @@ readonly name: string;

};
export declare type WatchAuthCallback = (user: JanrainUserInfo | undefined, comesFromLogin: boolean) => void;
export declare type WatchAuthCallback = (user: OAuthUserInfo | undefined, comesFromLogin: boolean) => void;
export declare type Init = {

@@ -20,0 +20,0 @@ accessToken: string;

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgSmFucmFpblVzZXJJbmZvID0ge1xuICByZWFkb25seSBlbWFpbDogc3RyaW5nO1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGxhc3ROYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBpY3R1cmU6IHN0cmluZztcbiAgcmVhZG9ubHkgaWQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIFdhdGNoQXV0aENhbGxiYWNrID0gKHVzZXI6IEphbnJhaW5Vc2VySW5mbyB8IHVuZGVmaW5lZCwgY29tZXNGcm9tTG9naW46IGJvb2xlYW4pID0+IHZvaWQ7XG5cbmV4cG9ydCB0eXBlIEluaXQgPSB7XG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIGV4cGlyZXNJbjogbnVtYmVyO1xufTtcblxuZXhwb3J0IHR5cGUgQ29uZmlnRW5kcG9pbnQgPSB7XG4gIGF1dGhvcml6YXRpb25fZW5kcG9pbnQ6IHN0cmluZztcbiAgdG9rZW5fZW5kcG9pbnQ6IHN0cmluZztcbiAgdXNlcmluZm9fZW5kcG9pbnQ6IHN0cmluZztcbiAgcmV2b2NhdGlvbl9lbmRwb2ludDogc3RyaW5nO1xufTsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlZmVyZW5jZTogaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2F1dGhvcml6YXRpb24tY29kZS1wa2NlLWZvci1tb2JpbGUtYXBwc1xuZXhwb3J0IHR5cGUgVG9rZW4gPSB7XG4gIC8vIFRva2VuIHVzZWQgZm9yIGNhbGxzLCBzaG9ydCBleHBpcmF0aW9uXG4gIGFjY2Vzc1Rva2VuOiBzdHJpbmc7XG4gIC8vIFRva2VuIHVzZWQgdG8gcmV0cmlldmUgYSBuZXcgYWNjZXNzVG9rZW4sIGxvbmcgZXhwaXJhdGlvblxuICByZWZyZXNoVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG4gIHRva2VuVHlwZTogc3RyaW5nO1xuICAvLyBPSURDIHNjb3BlcyB0aGF0IHRoZSB0b2tlbiBoYXMgYWNjZXNzIHRvIHJldHJpZXZlXG4gIHNjb3BlOiBzdHJpbmc7XG4gIC8vIElkZW50aXR5IHRva2VuXG4gIGlkVG9rZW46IHN0cmluZ1xufTtcblxuZXhwb3J0IHR5cGUgT0F1dGhVc2VySW5mbyA9IHtcbiAgcmVhZG9ubHkgZW1haWw6IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBsYXN0TmFtZTogc3RyaW5nO1xuICByZWFkb25seSBwaWN0dXJlOiBzdHJpbmc7XG4gIHJlYWRvbmx5IGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBXYXRjaEF1dGhDYWxsYmFjayA9ICh1c2VyOiBPQXV0aFVzZXJJbmZvIHwgdW5kZWZpbmVkLCBjb21lc0Zyb21Mb2dpbjogYm9vbGVhbikgPT4gdm9pZDtcblxuZXhwb3J0IHR5cGUgSW5pdCA9IHtcbiAgYWNjZXNzVG9rZW46IHN0cmluZztcbiAgZXhwaXJlc0luOiBudW1iZXI7XG59O1xuXG5leHBvcnQgdHlwZSBDb25maWdFbmRwb2ludCA9IHtcbiAgYXV0aG9yaXphdGlvbl9lbmRwb2ludDogc3RyaW5nO1xuICB0b2tlbl9lbmRwb2ludDogc3RyaW5nO1xuICB1c2VyaW5mb19lbmRwb2ludDogc3RyaW5nO1xuICByZXZvY2F0aW9uX2VuZHBvaW50OiBzdHJpbmc7XG59OyJdfQ==
{
"name": "@mybiogen/auth-openid",
"version": "1.0.2",
"version": "1.1.0",
"description": "Authorization for OpenID",

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

},
"gitHead": "0134124240b8735dda29196b6d57a4c4db921f6c"
"gitHead": "399982b3b95d12078b00f64ebe45f4419108aa8c"
}

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