@mybiogen/auth-openid
Advanced tools
Comparing version 1.5.2 to 1.5.3
"use strict"; | ||
var __extends = (this && this.__extends) || (function () { | ||
var extendStatics = function (d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
return function (d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
}; | ||
})(); | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
@@ -6,8 +19,11 @@ return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const OAuthClient_1 = __importDefault(require("./OAuthClient")); | ||
class JanrainJS extends OAuthClient_1.default { | ||
constructor(clientId, configUrl, redirectURI, logoutRedirectURI, scopes = ['openid', 'email', 'profile'], claims = []) { | ||
super(clientId, configUrl, redirectURI, 'janrain_token', logoutRedirectURI, scopes, claims); | ||
var OAuthClient_1 = __importDefault(require("./OAuthClient")); | ||
var JanrainJS = (function (_super) { | ||
__extends(JanrainJS, _super); | ||
function JanrainJS(clientId, configUrl, redirectURI, logoutRedirectURI, scopes, claims) { | ||
if (scopes === void 0) { scopes = ['openid', 'email', 'profile']; } | ||
if (claims === void 0) { claims = []; } | ||
return _super.call(this, clientId, configUrl, redirectURI, 'janrain_token', logoutRedirectURI, scopes, claims) || this; | ||
} | ||
loadUserInfo(userJSON, claims) { | ||
JanrainJS.prototype.loadUserInfo = function (userJSON, claims) { | ||
return { | ||
@@ -21,7 +37,8 @@ user: { | ||
}, | ||
claims, | ||
claims: claims, | ||
}; | ||
} | ||
} | ||
}; | ||
return JanrainJS; | ||
}(OAuthClient_1.default)); | ||
exports.default = JanrainJS; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFucmFpbkpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0phbnJhaW5KUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQU96QyxNQUFxQixTQUFpQyxTQUFRLHFCQUFxQztJQUNqRyxZQUFZLFFBQWdCLEVBQUUsU0FBaUIsRUFBRSxXQUFtQixFQUFFLGlCQUF5QixFQUFFLFNBQW1CLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsRUFBRSxTQUE4QixFQUFFO1FBQ2xMLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzlGLENBQUM7SUFHUyxZQUFZLENBQUMsUUFBYSxFQUFFLE1BQWU7UUFDbkQsT0FBTztZQUNMLElBQUksRUFBRTtnQkFDSixFQUFFLEVBQUUsUUFBUSxDQUFDLEdBQUc7Z0JBQ2hCLGFBQWEsRUFBRSxRQUFRLENBQUMsY0FBYztnQkFDdEMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxLQUFLO2dCQUNyQixJQUFJLEVBQUUsUUFBUSxDQUFDLFVBQVU7Z0JBQ3pCLFFBQVEsRUFBRSxRQUFRLENBQUMsV0FBVzthQUMvQjtZQUNELE1BQU07U0FDUCxDQUFDO0lBQ0osQ0FBQztDQUNGO0FBbEJELDRCQWtCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBPcGVuSURDbGllbnQgZnJvbSAnLi9PQXV0aENsaWVudCc7XG5pbXBvcnQgeyBPQXV0aFVzZXJJbmZvIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCB0eXBlIEphbnJhaW5Vc2VySW5mbyA9IE9BdXRoVXNlckluZm8gJiB7XG4gIGVtYWlsVmVyaWZpZWQ6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEphbnJhaW5KUzxDbGFpbXMgZXh0ZW5kcyBvYmplY3Q+IGV4dGVuZHMgT3BlbklEQ2xpZW50PENsYWltcywgSmFucmFpblVzZXJJbmZvPiB7XG4gIGNvbnN0cnVjdG9yKGNsaWVudElkOiBzdHJpbmcsIGNvbmZpZ1VybDogc3RyaW5nLCByZWRpcmVjdFVSSTogc3RyaW5nLCBsb2dvdXRSZWRpcmVjdFVSSTogc3RyaW5nLCBzY29wZXM6IHN0cmluZ1tdID0gWydvcGVuaWQnLCAnZW1haWwnLCAncHJvZmlsZSddLCBjbGFpbXM6IEFycmF5PGtleW9mIENsYWltcz4gPSBbXSkge1xuICAgIHN1cGVyKGNsaWVudElkLCBjb25maWdVcmwsIHJlZGlyZWN0VVJJLCAnamFucmFpbl90b2tlbicsIGxvZ291dFJlZGlyZWN0VVJJLCBzY29wZXMsIGNsYWltcyk7XG4gIH1cblxuICAvLyBodHRwczovL2lkZW50aXR5ZG9jcy5ha2FtYWkuY29tL2hvbWUvamFucmFpbi1lbnRpdHktYXBpXG4gIHByb3RlY3RlZCBsb2FkVXNlckluZm8odXNlckpTT046IGFueSwgY2xhaW1zPzogQ2xhaW1zKTogeyB1c2VyOiBKYW5yYWluVXNlckluZm8sIGNsYWltcz86IENsYWltcyB9IHtcbiAgICByZXR1cm4ge1xuICAgICAgdXNlcjoge1xuICAgICAgICBpZDogdXNlckpTT04uc3ViLFxuICAgICAgICBlbWFpbFZlcmlmaWVkOiB1c2VySlNPTi5lbWFpbF92ZXJpZmllZCxcbiAgICAgICAgZW1haWw6IHVzZXJKU09OLmVtYWlsLFxuICAgICAgICBuYW1lOiB1c2VySlNPTi5naXZlbl9uYW1lLFxuICAgICAgICBsYXN0TmFtZTogdXNlckpTT04uZmFtaWx5X25hbWUsXG4gICAgICB9LFxuICAgICAgY2xhaW1zLFxuICAgIH07XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFucmFpbkpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0phbnJhaW5KUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4REFBeUM7QUFPekM7SUFBOEQsNkJBQXFDO0lBQ2pHLG1CQUFZLFFBQWdCLEVBQUUsU0FBaUIsRUFBRSxXQUFtQixFQUFFLGlCQUF5QixFQUFFLE1BQWlELEVBQUUsTUFBZ0M7UUFBbkYsdUJBQUEsRUFBQSxVQUFvQixRQUFRLEVBQUUsT0FBTyxFQUFFLFNBQVMsQ0FBQztRQUFFLHVCQUFBLEVBQUEsV0FBZ0M7ZUFDbEwsa0JBQU0sUUFBUSxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDN0YsQ0FBQztJQUdTLGdDQUFZLEdBQXRCLFVBQXVCLFFBQWEsRUFBRSxNQUFlO1FBQ25ELE9BQU87WUFDTCxJQUFJLEVBQUU7Z0JBQ0osRUFBRSxFQUFFLFFBQVEsQ0FBQyxHQUFHO2dCQUNoQixhQUFhLEVBQUUsUUFBUSxDQUFDLGNBQWM7Z0JBQ3RDLEtBQUssRUFBRSxRQUFRLENBQUMsS0FBSztnQkFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO2dCQUN6QixRQUFRLEVBQUUsUUFBUSxDQUFDLFdBQVc7YUFDL0I7WUFDRCxNQUFNLFFBQUE7U0FDUCxDQUFDO0lBQ0osQ0FBQztJQUNILGdCQUFDO0FBQUQsQ0FBQyxBQWxCRCxDQUE4RCxxQkFBWSxHQWtCekUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgT3BlbklEQ2xpZW50IGZyb20gJy4vT0F1dGhDbGllbnQnO1xuaW1wb3J0IHsgT0F1dGhVc2VySW5mbyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgdHlwZSBKYW5yYWluVXNlckluZm8gPSBPQXV0aFVzZXJJbmZvICYge1xuICBlbWFpbFZlcmlmaWVkOiBib29sZWFuO1xufVxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBKYW5yYWluSlM8Q2xhaW1zIGV4dGVuZHMgb2JqZWN0PiBleHRlbmRzIE9wZW5JRENsaWVudDxDbGFpbXMsIEphbnJhaW5Vc2VySW5mbz4ge1xuICBjb25zdHJ1Y3RvcihjbGllbnRJZDogc3RyaW5nLCBjb25maWdVcmw6IHN0cmluZywgcmVkaXJlY3RVUkk6IHN0cmluZywgbG9nb3V0UmVkaXJlY3RVUkk6IHN0cmluZywgc2NvcGVzOiBzdHJpbmdbXSA9IFsnb3BlbmlkJywgJ2VtYWlsJywgJ3Byb2ZpbGUnXSwgY2xhaW1zOiBBcnJheTxrZXlvZiBDbGFpbXM+ID0gW10pIHtcbiAgICBzdXBlcihjbGllbnRJZCwgY29uZmlnVXJsLCByZWRpcmVjdFVSSSwgJ2phbnJhaW5fdG9rZW4nLCBsb2dvdXRSZWRpcmVjdFVSSSwgc2NvcGVzLCBjbGFpbXMpO1xuICB9XG5cbiAgLy8gaHR0cHM6Ly9pZGVudGl0eWRvY3MuYWthbWFpLmNvbS9ob21lL2phbnJhaW4tZW50aXR5LWFwaVxuICBwcm90ZWN0ZWQgbG9hZFVzZXJJbmZvKHVzZXJKU09OOiBhbnksIGNsYWltcz86IENsYWltcyk6IHsgdXNlcjogSmFucmFpblVzZXJJbmZvLCBjbGFpbXM/OiBDbGFpbXMgfSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHVzZXI6IHtcbiAgICAgICAgaWQ6IHVzZXJKU09OLnN1YixcbiAgICAgICAgZW1haWxWZXJpZmllZDogdXNlckpTT04uZW1haWxfdmVyaWZpZWQsXG4gICAgICAgIGVtYWlsOiB1c2VySlNPTi5lbWFpbCxcbiAgICAgICAgbmFtZTogdXNlckpTT04uZ2l2ZW5fbmFtZSxcbiAgICAgICAgbGFzdE5hbWU6IHVzZXJKU09OLmZhbWlseV9uYW1lLFxuICAgICAgfSxcbiAgICAgIGNsYWltcyxcbiAgICB9O1xuICB9XG59XG4iXX0= |
"use strict"; | ||
var __assign = (this && this.__assign) || function () { | ||
__assign = Object.assign || function(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) | ||
t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
}; | ||
var __generator = (this && this.__generator) || function (thisArg, body) { | ||
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) throw new TypeError("Generator is already executing."); | ||
while (_) try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; | ||
if (y = 0, t) op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: case 1: t = op; break; | ||
case 4: _.label++; return { value: op[1], done: false }; | ||
case 5: _.label++; y = op[1]; op = [0]; continue; | ||
case 7: op = _.ops.pop(); _.trys.pop(); continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } | ||
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } | ||
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } | ||
if (t[2]) _.ops.pop(); | ||
_.trys.pop(); continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } | ||
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
}; | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
@@ -6,143 +53,208 @@ return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
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 OpenIDClient { | ||
constructor(clientId, configUrl, redirectURI, storageKey, logoutRedirectURI, scopes = ['openid'], claims = []) { | ||
var query_string_1 = __importDefault(require("query-string")); | ||
var uuid_1 = require("uuid"); | ||
var utils_1 = require("./utils"); | ||
var OpenIDClient = (function () { | ||
function OpenIDClient(clientId, configUrl, redirectURI, storageKey, logoutRedirectURI, scopes, claims) { | ||
var _this = this; | ||
if (scopes === void 0) { scopes = ['openid']; } | ||
if (claims === void 0) { claims = []; } | ||
this.listeners = []; | ||
this.keepRefreshingToken = () => { | ||
this.keepRefreshingToken = function () { | ||
var _a; | ||
if (!((_a = this.token) === null || _a === void 0 ? void 0 : _a.refreshToken)) { | ||
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) { | ||
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); | ||
if (_this.user && _this.token && !_this.refreshTokenInterval) { | ||
var SAFETY_GAP_REFRESH_TOKEN = 60000; | ||
_this.refreshTokenInterval = window.setInterval(function () { return __awaiter(_this, void 0, void 0, function () { | ||
var error_1; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
_a.trys.push([0, 2, , 3]); | ||
return [4, this.refreshToken()]; | ||
case 1: | ||
_a.sent(); | ||
return [3, 3]; | ||
case 2: | ||
error_1 = _a.sent(); | ||
clearInterval(this.refreshTokenInterval); | ||
this.logout(); | ||
return [3, 3]; | ||
case 3: return [2]; | ||
} | ||
}); | ||
}); }, (_this.token.expiresIn * 1000) - SAFETY_GAP_REFRESH_TOKEN); | ||
} | ||
}; | ||
this.watchAuth = async (cb) => { | ||
this.listeners.push(cb); | ||
await this.init(); | ||
if (this.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.endSessionEndpoint = config.end_session_endpoint; | ||
} | ||
}; | ||
this.getToken = async (code, originalCodeVerifier, currentState) => { | ||
if (!this.tokenEndpoint) { | ||
throw new Error('Not initialized. Token endpoint not present'); | ||
} | ||
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), | ||
}; | ||
try { | ||
const response = await fetch(this.tokenEndpoint, config); | ||
if (!response.ok) { | ||
return undefined; | ||
this.watchAuth = function (cb) { return __awaiter(_this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
this.listeners.push(cb); | ||
return [4, this.init()]; | ||
case 1: | ||
_a.sent(); | ||
if (!this.token) return [3, 3]; | ||
return [4, this.getUserInfo()]; | ||
case 2: | ||
_a.sent(); | ||
_a.label = 3; | ||
case 3: | ||
this.callListeners(); | ||
return [2]; | ||
} | ||
const authToken = await response.json(); | ||
this.token = { | ||
accessToken: authToken.access_token, | ||
refreshToken: authToken.refresh_token, | ||
expiresIn: authToken.expires_in, | ||
tokenType: authToken.token_type, | ||
scope: authToken.scope, | ||
idToken: authToken.id_token, | ||
}; | ||
utils_1.Storage.set(`${this.storageKey}.token`, this.token); | ||
utils_1.Storage.remove(currentState); | ||
window.history.replaceState({}, document.title, window.location.pathname); | ||
return this.token; | ||
} | ||
catch (error) { | ||
throw new Error('Error getting token'); | ||
} | ||
}; | ||
this.refreshToken = async () => { | ||
if (!this.token || !this.tokenEndpoint) { | ||
throw new Error('Cannot refresh token without token or endpoint'); | ||
} | ||
if (!this.token.refreshToken) { | ||
throw new Error('Cannot refresh token without refresh token'); | ||
} | ||
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) { | ||
throw new Error('Token not refreshed'); | ||
} | ||
const token = await response.json(); | ||
this.token = { | ||
accessToken: token.access_token, | ||
refreshToken: token.refresh_token, | ||
expiresIn: token.expires_in, | ||
tokenType: token.token_type, | ||
scope: token.scope, | ||
idToken: token.id_token, | ||
}; | ||
utils_1.Storage.set(`${this.storageKey}.token`, this.token); | ||
return { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }; | ||
}; | ||
this.authenticate = (args) => { | ||
const { forcedRedirectTo, isSignup, extraParams } = args; | ||
const originalCodeVerifier = utils_1.generateCodeVerifier(96); | ||
const codeVerifier = utils_1.generatePkceChallenge(originalCodeVerifier); | ||
const { pathname, search } = window.location; | ||
const { origin } = query_string_1.default.parse(search); | ||
const redirectTo = forcedRedirectTo ? forcedRedirectTo : origin ? decodeURIComponent(origin + "") : pathname + search; | ||
const state = uuid_1.v4(); | ||
let claimParam; | ||
if (this.claims.length) { | ||
const claimMap = this.claims.reduce((curr, claim) => ({ ...curr, [claim]: null }), {}); | ||
claimParam = this.claims.length | ||
}); | ||
}); }; | ||
this.fetchConfig = function () { return __awaiter(_this, void 0, void 0, function () { | ||
var response, error_2; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
_a.trys.push([0, 2, , 3]); | ||
return [4, fetch(this.configUrl)]; | ||
case 1: | ||
response = _a.sent(); | ||
return [2, response.json()]; | ||
case 2: | ||
error_2 = _a.sent(); | ||
return [2, undefined]; | ||
case 3: return [2]; | ||
} | ||
}); | ||
}); }; | ||
this.setConfig = function () { return __awaiter(_this, void 0, void 0, function () { | ||
var config; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4, this.fetchConfig()]; | ||
case 1: | ||
config = _a.sent(); | ||
if (config) { | ||
this.authorizationEndpoint = config.authorization_endpoint; | ||
this.tokenEndpoint = config.token_endpoint; | ||
this.userInfoEndpoint = config.userinfo_endpoint; | ||
this.revocationEndpoint = config.revocation_endpoint; | ||
this.endSessionEndpoint = config.end_session_endpoint; | ||
} | ||
return [2]; | ||
} | ||
}); | ||
}); }; | ||
this.getToken = function (code, originalCodeVerifier, currentState) { return __awaiter(_this, void 0, void 0, function () { | ||
var body, config, response, authToken, error_3; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.tokenEndpoint) { | ||
throw new Error('Not initialized. Token endpoint not present'); | ||
} | ||
body = { | ||
grant_type: 'authorization_code', | ||
code: code, | ||
client_id: encodeURIComponent(this.clientId), | ||
redirect_uri: this.redirectURI, | ||
code_verifier: originalCodeVerifier, | ||
}; | ||
config = { | ||
method: 'POST', | ||
headers: new Headers({ | ||
'Content-Type': 'application/x-www-form-urlencoded', | ||
}), | ||
body: utils_1.encodeBody(body), | ||
}; | ||
_a.label = 1; | ||
case 1: | ||
_a.trys.push([1, 4, , 5]); | ||
return [4, fetch(this.tokenEndpoint, config)]; | ||
case 2: | ||
response = _a.sent(); | ||
if (!response.ok) { | ||
return [2, undefined]; | ||
} | ||
return [4, response.json()]; | ||
case 3: | ||
authToken = _a.sent(); | ||
this.token = { | ||
accessToken: authToken.access_token, | ||
refreshToken: authToken.refresh_token, | ||
expiresIn: authToken.expires_in, | ||
tokenType: authToken.token_type, | ||
scope: authToken.scope, | ||
idToken: authToken.id_token, | ||
}; | ||
utils_1.Storage.set(this.storageKey + ".token", this.token); | ||
utils_1.Storage.remove(currentState); | ||
window.history.replaceState({}, document.title, window.location.pathname); | ||
return [2, this.token]; | ||
case 4: | ||
error_3 = _a.sent(); | ||
throw new Error('Error getting token'); | ||
case 5: return [2]; | ||
} | ||
}); | ||
}); }; | ||
this.refreshToken = function () { return __awaiter(_this, void 0, void 0, function () { | ||
var body, config, response, token; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.token || !this.tokenEndpoint) { | ||
throw new Error('Cannot refresh token without token or endpoint'); | ||
} | ||
if (!this.token.refreshToken) { | ||
throw new Error('Cannot refresh token without refresh token'); | ||
} | ||
body = { | ||
grant_type: 'refresh_token', | ||
refresh_token: this.token.refreshToken, | ||
redirect_uri: this.redirectURI, | ||
client_id: encodeURIComponent(this.clientId), | ||
}; | ||
config = { | ||
method: 'POST', | ||
headers: new Headers({ | ||
'Content-Type': 'application/x-www-form-urlencoded', | ||
}), | ||
body: utils_1.encodeBody(body), | ||
}; | ||
return [4, fetch(this.tokenEndpoint, config)]; | ||
case 1: | ||
response = _a.sent(); | ||
if (!response.ok) { | ||
throw new Error('Token not refreshed'); | ||
} | ||
return [4, response.json()]; | ||
case 2: | ||
token = _a.sent(); | ||
this.token = { | ||
accessToken: token.access_token, | ||
refreshToken: token.refresh_token, | ||
expiresIn: token.expires_in, | ||
tokenType: token.token_type, | ||
scope: token.scope, | ||
idToken: token.id_token, | ||
}; | ||
utils_1.Storage.set(this.storageKey + ".token", this.token); | ||
return [2, { accessToken: this.token.accessToken, expiresIn: this.token.expiresIn }]; | ||
} | ||
}); | ||
}); }; | ||
this.authenticate = function (args) { | ||
var forcedRedirectTo = args.forcedRedirectTo, isSignup = args.isSignup, extraParams = args.extraParams; | ||
var originalCodeVerifier = utils_1.generateCodeVerifier(96); | ||
var codeVerifier = utils_1.generatePkceChallenge(originalCodeVerifier); | ||
var _a = window.location, pathname = _a.pathname, search = _a.search; | ||
var origin = query_string_1.default.parse(search).origin; | ||
var redirectTo = forcedRedirectTo ? forcedRedirectTo : origin ? decodeURIComponent(origin + "") : pathname + search; | ||
var state = uuid_1.v4(); | ||
var claimParam; | ||
if (_this.claims.length) { | ||
var claimMap = _this.claims.reduce(function (curr, claim) { | ||
var _a; | ||
return (__assign(__assign({}, curr), (_a = {}, _a[claim] = null, _a))); | ||
}, {}); | ||
claimParam = _this.claims.length | ||
? { | ||
@@ -154,76 +266,84 @@ userinfo: claimMap, | ||
} | ||
const params = { | ||
client_id: encodeURIComponent(this.clientId), | ||
redirect_uri: this.redirectURI, | ||
scope: this.scopes.join(' '), | ||
response_type: 'code', | ||
response_mode: 'query', | ||
state: encodeURIComponent(state), | ||
code_challenge: encodeURI(codeVerifier), | ||
code_challenge_method: 'S256', | ||
claims: claimParam && JSON.stringify(claimParam), | ||
...(extraParams || {}), | ||
...(isSignup && { | ||
prompt: 'create' | ||
}), | ||
}; | ||
var params = __assign(__assign({ client_id: encodeURIComponent(_this.clientId), redirect_uri: _this.redirectURI, scope: _this.scopes.join(' '), response_type: 'code', response_mode: 'query', state: encodeURIComponent(state), code_challenge: encodeURI(codeVerifier), code_challenge_method: 'S256', claims: claimParam && JSON.stringify(claimParam) }, (extraParams || {})), (isSignup && { | ||
prompt: 'create' | ||
})); | ||
utils_1.Storage.set(state, { | ||
codeVerifier, | ||
originalCodeVerifier, | ||
redirectTo, | ||
codeVerifier: codeVerifier, | ||
originalCodeVerifier: originalCodeVerifier, | ||
redirectTo: redirectTo, | ||
}); | ||
const loginQuery = query_string_1.default.stringify(params); | ||
const url = `${this.authorizationEndpoint}?${loginQuery}`; | ||
window.location.replace(url); | ||
var loginQuery = query_string_1.default.stringify(params); | ||
if (_this.authorizationEndpoint) { | ||
var url = _this.authorizationEndpoint + "?" + loginQuery; | ||
window.location.replace(url); | ||
} | ||
}; | ||
this.login = (forcedRedirectTo, extraParams) => { | ||
this.authenticate({ forcedRedirectTo, extraParams }); | ||
this.login = function (forcedRedirectTo, extraParams) { | ||
_this.authenticate({ forcedRedirectTo: forcedRedirectTo, extraParams: extraParams }); | ||
}; | ||
this.signup = (forcedRedirectTo, extraParams) => { | ||
this.authenticate({ forcedRedirectTo, extraParams, isSignup: true }); | ||
this.signup = function (forcedRedirectTo, extraParams) { | ||
_this.authenticate({ forcedRedirectTo: forcedRedirectTo, extraParams: extraParams, isSignup: true }); | ||
}; | ||
this.getUserInfo = async () => { | ||
if (!this.userInfoEndpoint || !this.token) { | ||
return undefined; | ||
} | ||
try { | ||
const response = await fetch(this.userInfoEndpoint, { | ||
headers: new Headers({ | ||
Authorization: `Bearer ${this.token.accessToken}`, | ||
}), | ||
}); | ||
const userInfo = await response.json(); | ||
const claims = this.claims.length | ||
? this.claims.reduce((curr, claim) => ({ | ||
...curr, | ||
[claim]: userInfo[claim], | ||
}), {}) | ||
: undefined; | ||
this.user = this.loadUserInfo(userInfo, claims); | ||
return this.user; | ||
} | ||
catch (error) { | ||
console.warn('Error getting user info, logging out...'); | ||
console.warn(error); | ||
await this.logout(); | ||
return undefined; | ||
} | ||
}; | ||
this.logout = async (endSessionURI) => { | ||
this.getUserInfo = function () { return __awaiter(_this, void 0, void 0, function () { | ||
var response, userInfo_1, claims, error_4; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.userInfoEndpoint || !this.token) { | ||
return [2, undefined]; | ||
} | ||
_a.label = 1; | ||
case 1: | ||
_a.trys.push([1, 4, , 6]); | ||
return [4, fetch(this.userInfoEndpoint, { | ||
headers: new Headers({ | ||
Authorization: "Bearer " + this.token.accessToken, | ||
}), | ||
})]; | ||
case 2: | ||
response = _a.sent(); | ||
return [4, response.json()]; | ||
case 3: | ||
userInfo_1 = _a.sent(); | ||
claims = this.claims.length | ||
? this.claims.reduce(function (curr, claim) { | ||
var _a; | ||
return (__assign(__assign({}, curr), (_a = {}, _a[claim] = userInfo_1[claim], _a))); | ||
}, {}) | ||
: undefined; | ||
this.user = this.loadUserInfo(userInfo_1, claims); | ||
return [2, this.user]; | ||
case 4: | ||
error_4 = _a.sent(); | ||
console.warn('Error getting user info, logging out...'); | ||
console.warn(error_4); | ||
return [4, this.logout()]; | ||
case 5: | ||
_a.sent(); | ||
return [2, undefined]; | ||
case 6: return [2]; | ||
} | ||
}); | ||
}); }; | ||
this.logout = function (endSessionURI) { return __awaiter(_this, void 0, void 0, function () { | ||
var params, url; | ||
var _a; | ||
utils_1.Storage.remove(`${this.storageKey}.token`); | ||
if (endSessionURI) { | ||
window.location.replace(endSessionURI); | ||
} | ||
else { | ||
const params = { | ||
'id_token_hint': (_a = this.token) === null || _a === void 0 ? void 0 : _a.idToken, | ||
'post_logout_redirect_uri': this.logoutRedirectURI, | ||
}; | ||
if (this.endSessionEndpoint) { | ||
const url = `${this.endSessionEndpoint}?${query_string_1.default.stringify(params)}`; | ||
window.location.replace(url); | ||
return __generator(this, function (_b) { | ||
utils_1.Storage.remove(this.storageKey + ".token"); | ||
if (endSessionURI) { | ||
window.location.replace(endSessionURI); | ||
} | ||
} | ||
}; | ||
else { | ||
params = { | ||
'id_token_hint': (_a = this.token) === null || _a === void 0 ? void 0 : _a.idToken, | ||
'post_logout_redirect_uri': this.logoutRedirectURI, | ||
}; | ||
if (this.endSessionEndpoint) { | ||
url = this.endSessionEndpoint + "?" + query_string_1.default.stringify(params); | ||
window.location.replace(url); | ||
} | ||
} | ||
return [2]; | ||
}); | ||
}); }; | ||
if (!clientId) { | ||
@@ -254,59 +374,98 @@ throw new Error('clientId is not provided.'); | ||
this.claims = claims; | ||
this.token = typeof window !== 'undefined' ? utils_1.Storage.get(`${storageKey}.token`) : null; | ||
this.token = typeof window !== 'undefined' ? utils_1.Storage.get(storageKey + ".token") : null; | ||
} | ||
async init() { | ||
if (this.hasBeenInitialized) { | ||
return; | ||
} | ||
const [callbackState, storageOauth] = await Promise.all([ | ||
utils_1.checkCallback(window.location.href), | ||
utils_1.Storage.get(`${this.storageKey}.token`), | ||
]); | ||
await this.setConfig(); | ||
if (!callbackState && !storageOauth) { | ||
return undefined; | ||
} | ||
this.hasBeenInitialized = true; | ||
if (callbackState) { | ||
return await this.getTokenOnInit(callbackState); | ||
} | ||
if (storageOauth && !storageOauth.logout) { | ||
return await this.refreshTokenOnInit(storageOauth); | ||
} | ||
return undefined; | ||
} | ||
async getTokenOnInit(callbackState) { | ||
const { code, pkceCodeVerifier, currentState, redirectTo, newUrl } = callbackState; | ||
this.token = await this.getToken(code, pkceCodeVerifier, currentState); | ||
this.keepRefreshingToken(); | ||
window.history.replaceState(window.history.state, document.title, newUrl); | ||
this.comesFromLogin = true; | ||
this.redirectTo = redirectTo; | ||
return this.token; | ||
} | ||
async refreshTokenOnInit(storageOauth) { | ||
OpenIDClient.prototype.init = function () { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var _a, callbackState, storageOauth; | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
if (this.hasBeenInitialized) { | ||
return [2]; | ||
} | ||
return [4, Promise.all([ | ||
utils_1.checkCallback(window.location.href), | ||
utils_1.Storage.get(this.storageKey + ".token"), | ||
])]; | ||
case 1: | ||
_a = _b.sent(), callbackState = _a[0], storageOauth = _a[1]; | ||
return [4, this.setConfig()]; | ||
case 2: | ||
_b.sent(); | ||
if (!callbackState && !storageOauth) { | ||
return [2, undefined]; | ||
} | ||
this.hasBeenInitialized = true; | ||
if (!callbackState) return [3, 4]; | ||
return [4, this.getTokenOnInit(callbackState)]; | ||
case 3: return [2, _b.sent()]; | ||
case 4: | ||
if (!(storageOauth && !storageOauth.logout)) return [3, 6]; | ||
return [4, this.refreshTokenOnInit(storageOauth)]; | ||
case 5: return [2, _b.sent()]; | ||
case 6: return [2, undefined]; | ||
} | ||
}); | ||
}); | ||
}; | ||
OpenIDClient.prototype.getTokenOnInit = function (callbackState) { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var code, pkceCodeVerifier, currentState, redirectTo, newUrl, _a; | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
code = callbackState.code, pkceCodeVerifier = callbackState.pkceCodeVerifier, currentState = callbackState.currentState, redirectTo = callbackState.redirectTo, newUrl = callbackState.newUrl; | ||
_a = this; | ||
return [4, this.getToken(code, pkceCodeVerifier, currentState)]; | ||
case 1: | ||
_a.token = _b.sent(); | ||
this.keepRefreshingToken(); | ||
window.history.replaceState(window.history.state, document.title, newUrl); | ||
this.comesFromLogin = true; | ||
this.redirectTo = redirectTo; | ||
return [2, this.token]; | ||
} | ||
}); | ||
}); | ||
}; | ||
OpenIDClient.prototype.refreshTokenOnInit = function (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}.token`); | ||
} | ||
return this.token; | ||
} | ||
callListeners() { | ||
this.listeners.forEach((cb) => { | ||
cb(this.token && this.user, this.comesFromLogin, this.redirectTo); | ||
return __awaiter(this, void 0, void 0, function () { | ||
var err_1; | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
this.token = storageOauth; | ||
this.comesFromLogin = false; | ||
if (!((_a = this.token) === null || _a === void 0 ? void 0 : _a.refreshToken)) { | ||
console.warn("missing refresh token."); | ||
return [2, this.token]; | ||
} | ||
_b.label = 1; | ||
case 1: | ||
_b.trys.push([1, 3, , 4]); | ||
return [4, this.refreshToken()]; | ||
case 2: | ||
_b.sent(); | ||
this.keepRefreshingToken(); | ||
return [3, 4]; | ||
case 3: | ||
err_1 = _b.sent(); | ||
this.token = undefined; | ||
utils_1.Storage.remove(this.storageKey + ".token"); | ||
return [3, 4]; | ||
case 4: return [2, this.token]; | ||
} | ||
}); | ||
}); | ||
} | ||
} | ||
}; | ||
OpenIDClient.prototype.callListeners = function () { | ||
var _this = this; | ||
this.listeners.forEach(function (cb) { | ||
cb(_this.token && _this.user, _this.comesFromLogin, _this.redirectTo); | ||
}); | ||
}; | ||
return OpenIDClient; | ||
}()); | ||
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  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"]} | ||
//# 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    if (this.authorizationEndpoint) {\n      const url = `${this.authorizationEndpoint}?${loginQuery}`;\n      window.location.replace(url);\n    }\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"]} |
"use strict"; | ||
var __extends = (this && this.__extends) || (function () { | ||
var extendStatics = function (d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
return function (d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
}; | ||
})(); | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
@@ -6,8 +19,11 @@ return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const OAuthClient_1 = __importDefault(require("./OAuthClient")); | ||
class OktaJS extends OAuthClient_1.default { | ||
constructor(clientId, configUrl, redirectURI, logoutRedirectURI, scopes = ['openid', 'email', 'profile'], claims = []) { | ||
super(clientId, configUrl, redirectURI, 'okta_token', logoutRedirectURI, scopes, claims); | ||
var OAuthClient_1 = __importDefault(require("./OAuthClient")); | ||
var OktaJS = (function (_super) { | ||
__extends(OktaJS, _super); | ||
function OktaJS(clientId, configUrl, redirectURI, logoutRedirectURI, scopes, claims) { | ||
if (scopes === void 0) { scopes = ['openid', 'email', 'profile']; } | ||
if (claims === void 0) { claims = []; } | ||
return _super.call(this, clientId, configUrl, redirectURI, 'okta_token', logoutRedirectURI, scopes, claims) || this; | ||
} | ||
loadUserInfo(userJSON, claims) { | ||
OktaJS.prototype.loadUserInfo = function (userJSON, claims) { | ||
return { | ||
@@ -20,7 +36,8 @@ user: { | ||
}, | ||
claims, | ||
claims: claims, | ||
}; | ||
} | ||
} | ||
}; | ||
return OktaJS; | ||
}(OAuthClient_1.default)); | ||
exports.default = OktaJS; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2t0YUpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL09rdGFKUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdFQUF5QztBQUt6QyxNQUFxQixNQUEwQixTQUFRLHFCQUFrQztJQUN2RixZQUFZLFFBQWdCLEVBQUUsU0FBaUIsRUFBRSxXQUFtQixFQUFFLGlCQUF5QixFQUFFLFNBQW1CLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsRUFBRSxTQUE4QixFQUFFO1FBQ2xMLEtBQUssQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzNGLENBQUM7SUFHUyxZQUFZLENBQUMsUUFBYSxFQUFFLE1BQWM7UUFDbEQsT0FBTztZQUNMLElBQUksRUFBRTtnQkFDSixFQUFFLEVBQUUsUUFBUSxDQUFDLEdBQUc7Z0JBQ2hCLEtBQUssRUFBRSxRQUFRLENBQUMsS0FBSztnQkFDckIsSUFBSSxFQUFFLFFBQVEsQ0FBQyxVQUFVO2dCQUN6QixRQUFRLEVBQUUsUUFBUSxDQUFDLFdBQVc7YUFDL0I7WUFDRCxNQUFNO1NBQ1AsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWpCRCx5QkFpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgT3BlbklEQ2xpZW50IGZyb20gJy4vT0F1dGhDbGllbnQnO1xuaW1wb3J0IHsgT0F1dGhVc2VySW5mbyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgdHlwZSBPa3RhVXNlckluZm8gPSBPQXV0aFVzZXJJbmZvXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE9rdGFKUzxDbGFpbXMgZXh0ZW5kcyB7fT4gZXh0ZW5kcyBPcGVuSURDbGllbnQ8Q2xhaW1zLCBPa3RhVXNlckluZm8+IHtcbiAgY29uc3RydWN0b3IoY2xpZW50SWQ6IHN0cmluZywgY29uZmlnVXJsOiBzdHJpbmcsIHJlZGlyZWN0VVJJOiBzdHJpbmcsIGxvZ291dFJlZGlyZWN0VVJJOiBzdHJpbmcsIHNjb3Blczogc3RyaW5nW10gPSBbJ29wZW5pZCcsICdlbWFpbCcsICdwcm9maWxlJ10sIGNsYWltczogQXJyYXk8a2V5b2YgQ2xhaW1zPiA9IFtdKSB7XG4gICAgc3VwZXIoY2xpZW50SWQsIGNvbmZpZ1VybCwgcmVkaXJlY3RVUkksICdva3RhX3Rva2VuJywgbG9nb3V0UmVkaXJlY3RVUkksIHNjb3BlcywgY2xhaW1zKTtcbiAgfVxuXG4gIC8vIGh0dHBzOi8vZGV2ZWxvcGVyLm9rdGEuY29tL2RvY3MvcmVmZXJlbmNlL2FwaS9vaWRjLyN1c2VyaW5mb1xuICBwcm90ZWN0ZWQgbG9hZFVzZXJJbmZvKHVzZXJKU09OOiBhbnksIGNsYWltczogQ2xhaW1zKTogeyB1c2VyOiBPQXV0aFVzZXJJbmZvLCBjbGFpbXM/OiBDbGFpbXMgfSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHVzZXI6IHtcbiAgICAgICAgaWQ6IHVzZXJKU09OLnN1YixcbiAgICAgICAgZW1haWw6IHVzZXJKU09OLmVtYWlsLFxuICAgICAgICBuYW1lOiB1c2VySlNPTi5naXZlbl9uYW1lLFxuICAgICAgICBsYXN0TmFtZTogdXNlckpTT04uZmFtaWx5X25hbWUsXG4gICAgICB9LFxuICAgICAgY2xhaW1zLFxuICAgIH07XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2t0YUpTLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL09rdGFKUy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4REFBeUM7QUFLekM7SUFBdUQsMEJBQWtDO0lBQ3ZGLGdCQUFZLFFBQWdCLEVBQUUsU0FBaUIsRUFBRSxXQUFtQixFQUFFLGlCQUF5QixFQUFFLE1BQWlELEVBQUUsTUFBZ0M7UUFBbkYsdUJBQUEsRUFBQSxVQUFvQixRQUFRLEVBQUUsT0FBTyxFQUFFLFNBQVMsQ0FBQztRQUFFLHVCQUFBLEVBQUEsV0FBZ0M7ZUFDbEwsa0JBQU0sUUFBUSxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDMUYsQ0FBQztJQUdTLDZCQUFZLEdBQXRCLFVBQXVCLFFBQWEsRUFBRSxNQUFjO1FBQ2xELE9BQU87WUFDTCxJQUFJLEVBQUU7Z0JBQ0osRUFBRSxFQUFFLFFBQVEsQ0FBQyxHQUFHO2dCQUNoQixLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7Z0JBQ3JCLElBQUksRUFBRSxRQUFRLENBQUMsVUFBVTtnQkFDekIsUUFBUSxFQUFFLFFBQVEsQ0FBQyxXQUFXO2FBQy9CO1lBQ0QsTUFBTSxRQUFBO1NBQ1AsQ0FBQztJQUNKLENBQUM7SUFDSCxhQUFDO0FBQUQsQ0FBQyxBQWpCRCxDQUF1RCxxQkFBWSxHQWlCbEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgT3BlbklEQ2xpZW50IGZyb20gJy4vT0F1dGhDbGllbnQnO1xuaW1wb3J0IHsgT0F1dGhVc2VySW5mbyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgdHlwZSBPa3RhVXNlckluZm8gPSBPQXV0aFVzZXJJbmZvXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE9rdGFKUzxDbGFpbXMgZXh0ZW5kcyB7fT4gZXh0ZW5kcyBPcGVuSURDbGllbnQ8Q2xhaW1zLCBPa3RhVXNlckluZm8+IHtcbiAgY29uc3RydWN0b3IoY2xpZW50SWQ6IHN0cmluZywgY29uZmlnVXJsOiBzdHJpbmcsIHJlZGlyZWN0VVJJOiBzdHJpbmcsIGxvZ291dFJlZGlyZWN0VVJJOiBzdHJpbmcsIHNjb3Blczogc3RyaW5nW10gPSBbJ29wZW5pZCcsICdlbWFpbCcsICdwcm9maWxlJ10sIGNsYWltczogQXJyYXk8a2V5b2YgQ2xhaW1zPiA9IFtdKSB7XG4gICAgc3VwZXIoY2xpZW50SWQsIGNvbmZpZ1VybCwgcmVkaXJlY3RVUkksICdva3RhX3Rva2VuJywgbG9nb3V0UmVkaXJlY3RVUkksIHNjb3BlcywgY2xhaW1zKTtcbiAgfVxuXG4gIC8vIGh0dHBzOi8vZGV2ZWxvcGVyLm9rdGEuY29tL2RvY3MvcmVmZXJlbmNlL2FwaS9vaWRjLyN1c2VyaW5mb1xuICBwcm90ZWN0ZWQgbG9hZFVzZXJJbmZvKHVzZXJKU09OOiBhbnksIGNsYWltczogQ2xhaW1zKTogeyB1c2VyOiBPQXV0aFVzZXJJbmZvLCBjbGFpbXM/OiBDbGFpbXMgfSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHVzZXI6IHtcbiAgICAgICAgaWQ6IHVzZXJKU09OLnN1YixcbiAgICAgICAgZW1haWw6IHVzZXJKU09OLmVtYWlsLFxuICAgICAgICBuYW1lOiB1c2VySlNPTi5naXZlbl9uYW1lLFxuICAgICAgICBsYXN0TmFtZTogdXNlckpTT04uZmFtaWx5X25hbWUsXG4gICAgICB9LFxuICAgICAgY2xhaW1zLFxuICAgIH07XG4gIH1cbn1cbiJdfQ== |
@@ -7,8 +7,8 @@ "use strict"; | ||
exports.checkCallback = void 0; | ||
const Storage_1 = require("./Storage"); | ||
const query_string_1 = __importDefault(require("query-string")); | ||
const parseCallbackUrl = (url) => { | ||
const queryIndex = url.indexOf('?'); | ||
var Storage_1 = require("./Storage"); | ||
var query_string_1 = __importDefault(require("query-string")); | ||
var parseCallbackUrl = function (url) { | ||
var queryIndex = url.indexOf('?'); | ||
if (queryIndex !== -1) { | ||
const oauthParams = { | ||
var oauthParams_1 = { | ||
code: undefined, | ||
@@ -18,23 +18,24 @@ newUrl: url.substring(0, queryIndex), | ||
}; | ||
const query = url.substring(queryIndex + 1, url.length); | ||
const queryParams = query_string_1.default.parse(query); | ||
const otherParams = {}; | ||
Object.entries(queryParams).forEach(([queryKey, queryValue]) => { | ||
var query = url.substring(queryIndex + 1, url.length); | ||
var queryParams = query_string_1.default.parse(query); | ||
var otherParams_1 = {}; | ||
Object.entries(queryParams).forEach(function (_a) { | ||
var queryKey = _a[0], queryValue = _a[1]; | ||
switch (queryKey) { | ||
case 'code': | ||
oauthParams.code = queryValue; | ||
oauthParams_1.code = queryValue; | ||
break; | ||
case 'state': | ||
oauthParams.state = queryValue; | ||
oauthParams_1.state = queryValue; | ||
break; | ||
default: | ||
otherParams[queryKey] = queryValue; | ||
otherParams_1[queryKey] = queryValue; | ||
break; | ||
} | ||
}); | ||
if (Object.keys(otherParams).length) { | ||
oauthParams.newUrl += `?${query_string_1.default.stringify(otherParams)}`; | ||
if (Object.keys(otherParams_1).length) { | ||
oauthParams_1.newUrl += "?" + query_string_1.default.stringify(otherParams_1); | ||
} | ||
if (oauthParams.code && oauthParams.state) { | ||
return oauthParams; | ||
if (oauthParams_1.code && oauthParams_1.state) { | ||
return oauthParams_1; | ||
} | ||
@@ -45,8 +46,8 @@ return undefined; | ||
}; | ||
exports.checkCallback = (url) => { | ||
const oauth = parseCallbackUrl(url); | ||
exports.checkCallback = function (url) { | ||
var oauth = parseCallbackUrl(url); | ||
if (!oauth) { | ||
return undefined; | ||
} | ||
const storedState = Storage_1.Storage.get(oauth.state); | ||
var storedState = Storage_1.Storage.get(oauth.state); | ||
if (storedState) { | ||
@@ -63,2 +64,2 @@ return { | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tDYWxsYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja0NhbGxiYWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHVDQUFvQztBQUNwQyxnRUFBdUM7QUFnQnZDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxHQUFXLEVBQThCLEVBQUU7SUFDbkUsTUFBTSxVQUFVLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVwQyxJQUFJLFVBQVUsS0FBSyxDQUFDLENBQUMsRUFBRTtRQUNyQixNQUFNLFdBQVcsR0FBNEI7WUFDM0MsSUFBSSxFQUFFLFNBQVM7WUFDZixNQUFNLEVBQUUsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDO1lBQ3BDLEtBQUssRUFBRSxTQUFTO1NBQ2pCLENBQUM7UUFDRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLFVBQVUsR0FBRyxDQUFDLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3hELE1BQU0sV0FBVyxHQUFHLHNCQUFXLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTdDLE1BQU0sV0FBVyxHQUE0RCxFQUFFLENBQUM7UUFDaEYsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsRUFBRSxFQUFFO1lBQzdELFFBQVEsUUFBUSxFQUFFO2dCQUNoQixLQUFLLE1BQU07b0JBQ1QsV0FBVyxDQUFDLElBQUksR0FBRyxVQUFvQixDQUFDO29CQUN4QyxNQUFNO2dCQUNSLEtBQUssT0FBTztvQkFDVixXQUFXLENBQUMsS0FBSyxHQUFHLFVBQW9CLENBQUM7b0JBQ3pDLE1BQU07Z0JBQ1I7b0JBQ0UsV0FBVyxDQUFDLFFBQVEsQ0FBQyxHQUFHLFVBQVUsQ0FBQztvQkFDbkMsTUFBTTthQUNUO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsTUFBTSxFQUFFO1lBQ25DLFdBQVcsQ0FBQyxNQUFNLElBQUksSUFBSSxzQkFBVyxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDO1NBQ2hFO1FBRUQsSUFBSSxXQUFXLENBQUMsSUFBSSxJQUFJLFdBQVcsQ0FBQyxLQUFLLEVBQUU7WUFDekMsT0FBTyxXQUE2QixDQUFDO1NBQ3RDO1FBQ0QsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDLENBQUM7QUFFVyxRQUFBLGFBQWEsR0FBRyxDQUFDLEdBQVcsRUFBMkIsRUFBRTtJQUNwRSxNQUFNLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVwQyxJQUFJLENBQUMsS0FBSyxFQUFFO1FBQ1YsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxNQUFNLFdBQVcsR0FBRyxpQkFBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFN0MsSUFBSSxXQUFXLEVBQUU7UUFDZixPQUFPO1lBQ0wsZ0JBQWdCLEVBQUUsV0FBVyxDQUFDLG9CQUFvQjtZQUNsRCxVQUFVLEVBQUUsV0FBVyxDQUFDLFVBQVU7WUFDbEMsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ2hCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTtZQUNwQixZQUFZLEVBQUUsS0FBSyxDQUFDLEtBQUs7U0FDMUIsQ0FBQztLQUNIO0lBQ0QsTUFBTSxLQUFLLENBQUMsa0RBQWtELENBQUMsQ0FBQztBQUNsRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdG9yYWdlIH0gZnJvbSAnLi9TdG9yYWdlJztcbmltcG9ydCBxdWVyeVN0cmluZyBmcm9tICdxdWVyeS1zdHJpbmcnO1xuXG50eXBlIE9hdXRoUGFyYW1zID0ge1xuICBwa2NlQ29kZVZlcmlmaWVyOiBzdHJpbmc7XG4gIHJlZGlyZWN0VG86IHN0cmluZztcbiAgY29kZTogc3RyaW5nO1xuICBuZXdVcmw6IHN0cmluZztcbiAgY3VycmVudFN0YXRlOiBzdHJpbmc7XG59O1xuXG50eXBlIENhbGxiYWNrUGFyYW1zID0ge1xuICBjb2RlOiBzdHJpbmc7XG4gIHN0YXRlOiBzdHJpbmc7XG4gIG5ld1VybDogc3RyaW5nO1xufTtcblxuY29uc3QgcGFyc2VDYWxsYmFja1VybCA9ICh1cmw6IHN0cmluZyk6IENhbGxiYWNrUGFyYW1zIHwgdW5kZWZpbmVkID0+IHtcbiAgY29uc3QgcXVlcnlJbmRleCA9IHVybC5pbmRleE9mKCc/Jyk7XG5cbiAgaWYgKHF1ZXJ5SW5kZXggIT09IC0xKSB7XG4gICAgY29uc3Qgb2F1dGhQYXJhbXM6IFBhcnRpYWw8Q2FsbGJhY2tQYXJhbXM+ID0ge1xuICAgICAgY29kZTogdW5kZWZpbmVkLFxuICAgICAgbmV3VXJsOiB1cmwuc3Vic3RyaW5nKDAsIHF1ZXJ5SW5kZXgpLFxuICAgICAgc3RhdGU6IHVuZGVmaW5lZCxcbiAgICB9O1xuICAgIGNvbnN0IHF1ZXJ5ID0gdXJsLnN1YnN0cmluZyhxdWVyeUluZGV4ICsgMSwgdXJsLmxlbmd0aCk7XG4gICAgY29uc3QgcXVlcnlQYXJhbXMgPSBxdWVyeVN0cmluZy5wYXJzZShxdWVyeSk7XG4gICAgLy8gcXVlcnkgcGFyYW0gdHlwZXNcbiAgICBjb25zdCBvdGhlclBhcmFtczogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB8IG51bGwgfCB1bmRlZmluZWQgfSA9IHt9O1xuICAgIE9iamVjdC5lbnRyaWVzKHF1ZXJ5UGFyYW1zKS5mb3JFYWNoKChbcXVlcnlLZXksIHF1ZXJ5VmFsdWVdKSA9PiB7XG4gICAgICBzd2l0Y2ggKHF1ZXJ5S2V5KSB7XG4gICAgICAgIGNhc2UgJ2NvZGUnOlxuICAgICAgICAgIG9hdXRoUGFyYW1zLmNvZGUgPSBxdWVyeVZhbHVlIGFzIHN0cmluZztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnc3RhdGUnOlxuICAgICAgICAgIG9hdXRoUGFyYW1zLnN0YXRlID0gcXVlcnlWYWx1ZSBhcyBzdHJpbmc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgb3RoZXJQYXJhbXNbcXVlcnlLZXldID0gcXVlcnlWYWx1ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGlmIChPYmplY3Qua2V5cyhvdGhlclBhcmFtcykubGVuZ3RoKSB7XG4gICAgICBvYXV0aFBhcmFtcy5uZXdVcmwgKz0gYD8ke3F1ZXJ5U3RyaW5nLnN0cmluZ2lmeShvdGhlclBhcmFtcyl9YDtcbiAgICB9XG5cbiAgICBpZiAob2F1dGhQYXJhbXMuY29kZSAmJiBvYXV0aFBhcmFtcy5zdGF0ZSkge1xuICAgICAgcmV0dXJuIG9hdXRoUGFyYW1zIGFzIENhbGxiYWNrUGFyYW1zO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGVja0NhbGxiYWNrID0gKHVybDogc3RyaW5nKTogT2F1dGhQYXJhbXMgfCB1bmRlZmluZWQgPT4ge1xuICBjb25zdCBvYXV0aCA9IHBhcnNlQ2FsbGJhY2tVcmwodXJsKTtcblxuICBpZiAoIW9hdXRoKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IHN0b3JlZFN0YXRlID0gU3RvcmFnZS5nZXQob2F1dGguc3RhdGUpO1xuXG4gIGlmIChzdG9yZWRTdGF0ZSkge1xuICAgIHJldHVybiB7XG4gICAgICBwa2NlQ29kZVZlcmlmaWVyOiBzdG9yZWRTdGF0ZS5vcmlnaW5hbENvZGVWZXJpZmllcixcbiAgICAgIHJlZGlyZWN0VG86IHN0b3JlZFN0YXRlLnJlZGlyZWN0VG8sXG4gICAgICBjb2RlOiBvYXV0aC5jb2RlLFxuICAgICAgbmV3VXJsOiBvYXV0aC5uZXdVcmwsXG4gICAgICBjdXJyZW50U3RhdGU6IG9hdXRoLnN0YXRlLFxuICAgIH07XG4gIH1cbiAgdGhyb3cgRXJyb3IoJ1N0YXRlIGluIHVybCBkb2VzIG5vdCBtYXRjaCBsb2NhbGx5IHN0b3JlZCBzdGF0ZScpO1xufTsiXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tDYWxsYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jaGVja0NhbGxiYWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHFDQUFvQztBQUNwQyw4REFBdUM7QUFnQnZDLElBQU0sZ0JBQWdCLEdBQUcsVUFBQyxHQUFXO0lBQ25DLElBQU0sVUFBVSxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFcEMsSUFBSSxVQUFVLEtBQUssQ0FBQyxDQUFDLEVBQUU7UUFDckIsSUFBTSxhQUFXLEdBQTRCO1lBQzNDLElBQUksRUFBRSxTQUFTO1lBQ2YsTUFBTSxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQztZQUNwQyxLQUFLLEVBQUUsU0FBUztTQUNqQixDQUFDO1FBQ0YsSUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxVQUFVLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4RCxJQUFNLFdBQVcsR0FBRyxzQkFBVyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUU3QyxJQUFNLGFBQVcsR0FBNEQsRUFBRSxDQUFDO1FBQ2hGLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsT0FBTyxDQUFDLFVBQUMsRUFBc0I7Z0JBQXJCLFFBQVEsUUFBQSxFQUFFLFVBQVUsUUFBQTtZQUN4RCxRQUFRLFFBQVEsRUFBRTtnQkFDaEIsS0FBSyxNQUFNO29CQUNULGFBQVcsQ0FBQyxJQUFJLEdBQUcsVUFBb0IsQ0FBQztvQkFDeEMsTUFBTTtnQkFDUixLQUFLLE9BQU87b0JBQ1YsYUFBVyxDQUFDLEtBQUssR0FBRyxVQUFvQixDQUFDO29CQUN6QyxNQUFNO2dCQUNSO29CQUNFLGFBQVcsQ0FBQyxRQUFRLENBQUMsR0FBRyxVQUFVLENBQUM7b0JBQ25DLE1BQU07YUFDVDtRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLGFBQVcsQ0FBQyxDQUFDLE1BQU0sRUFBRTtZQUNuQyxhQUFXLENBQUMsTUFBTSxJQUFJLE1BQUksc0JBQVcsQ0FBQyxTQUFTLENBQUMsYUFBVyxDQUFHLENBQUM7U0FDaEU7UUFFRCxJQUFJLGFBQVcsQ0FBQyxJQUFJLElBQUksYUFBVyxDQUFDLEtBQUssRUFBRTtZQUN6QyxPQUFPLGFBQTZCLENBQUM7U0FDdEM7UUFDRCxPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUVELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVXLFFBQUEsYUFBYSxHQUFHLFVBQUMsR0FBVztJQUN2QyxJQUFNLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVwQyxJQUFJLENBQUMsS0FBSyxFQUFFO1FBQ1YsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxJQUFNLFdBQVcsR0FBRyxpQkFBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFN0MsSUFBSSxXQUFXLEVBQUU7UUFDZixPQUFPO1lBQ0wsZ0JBQWdCLEVBQUUsV0FBVyxDQUFDLG9CQUFvQjtZQUNsRCxVQUFVLEVBQUUsV0FBVyxDQUFDLFVBQVU7WUFDbEMsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ2hCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTtZQUNwQixZQUFZLEVBQUUsS0FBSyxDQUFDLEtBQUs7U0FDMUIsQ0FBQztLQUNIO0lBQ0QsTUFBTSxLQUFLLENBQUMsa0RBQWtELENBQUMsQ0FBQztBQUNsRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdG9yYWdlIH0gZnJvbSAnLi9TdG9yYWdlJztcbmltcG9ydCBxdWVyeVN0cmluZyBmcm9tICdxdWVyeS1zdHJpbmcnO1xuXG50eXBlIE9hdXRoUGFyYW1zID0ge1xuICBwa2NlQ29kZVZlcmlmaWVyOiBzdHJpbmc7XG4gIHJlZGlyZWN0VG86IHN0cmluZztcbiAgY29kZTogc3RyaW5nO1xuICBuZXdVcmw6IHN0cmluZztcbiAgY3VycmVudFN0YXRlOiBzdHJpbmc7XG59O1xuXG50eXBlIENhbGxiYWNrUGFyYW1zID0ge1xuICBjb2RlOiBzdHJpbmc7XG4gIHN0YXRlOiBzdHJpbmc7XG4gIG5ld1VybDogc3RyaW5nO1xufTtcblxuY29uc3QgcGFyc2VDYWxsYmFja1VybCA9ICh1cmw6IHN0cmluZyk6IENhbGxiYWNrUGFyYW1zIHwgdW5kZWZpbmVkID0+IHtcbiAgY29uc3QgcXVlcnlJbmRleCA9IHVybC5pbmRleE9mKCc/Jyk7XG5cbiAgaWYgKHF1ZXJ5SW5kZXggIT09IC0xKSB7XG4gICAgY29uc3Qgb2F1dGhQYXJhbXM6IFBhcnRpYWw8Q2FsbGJhY2tQYXJhbXM+ID0ge1xuICAgICAgY29kZTogdW5kZWZpbmVkLFxuICAgICAgbmV3VXJsOiB1cmwuc3Vic3RyaW5nKDAsIHF1ZXJ5SW5kZXgpLFxuICAgICAgc3RhdGU6IHVuZGVmaW5lZCxcbiAgICB9O1xuICAgIGNvbnN0IHF1ZXJ5ID0gdXJsLnN1YnN0cmluZyhxdWVyeUluZGV4ICsgMSwgdXJsLmxlbmd0aCk7XG4gICAgY29uc3QgcXVlcnlQYXJhbXMgPSBxdWVyeVN0cmluZy5wYXJzZShxdWVyeSk7XG4gICAgLy8gcXVlcnkgcGFyYW0gdHlwZXNcbiAgICBjb25zdCBvdGhlclBhcmFtczogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB8IG51bGwgfCB1bmRlZmluZWQgfSA9IHt9O1xuICAgIE9iamVjdC5lbnRyaWVzKHF1ZXJ5UGFyYW1zKS5mb3JFYWNoKChbcXVlcnlLZXksIHF1ZXJ5VmFsdWVdKSA9PiB7XG4gICAgICBzd2l0Y2ggKHF1ZXJ5S2V5KSB7XG4gICAgICAgIGNhc2UgJ2NvZGUnOlxuICAgICAgICAgIG9hdXRoUGFyYW1zLmNvZGUgPSBxdWVyeVZhbHVlIGFzIHN0cmluZztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnc3RhdGUnOlxuICAgICAgICAgIG9hdXRoUGFyYW1zLnN0YXRlID0gcXVlcnlWYWx1ZSBhcyBzdHJpbmc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgb3RoZXJQYXJhbXNbcXVlcnlLZXldID0gcXVlcnlWYWx1ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGlmIChPYmplY3Qua2V5cyhvdGhlclBhcmFtcykubGVuZ3RoKSB7XG4gICAgICBvYXV0aFBhcmFtcy5uZXdVcmwgKz0gYD8ke3F1ZXJ5U3RyaW5nLnN0cmluZ2lmeShvdGhlclBhcmFtcyl9YDtcbiAgICB9XG5cbiAgICBpZiAob2F1dGhQYXJhbXMuY29kZSAmJiBvYXV0aFBhcmFtcy5zdGF0ZSkge1xuICAgICAgcmV0dXJuIG9hdXRoUGFyYW1zIGFzIENhbGxiYWNrUGFyYW1zO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGVja0NhbGxiYWNrID0gKHVybDogc3RyaW5nKTogT2F1dGhQYXJhbXMgfCB1bmRlZmluZWQgPT4ge1xuICBjb25zdCBvYXV0aCA9IHBhcnNlQ2FsbGJhY2tVcmwodXJsKTtcblxuICBpZiAoIW9hdXRoKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IHN0b3JlZFN0YXRlID0gU3RvcmFnZS5nZXQob2F1dGguc3RhdGUpO1xuXG4gIGlmIChzdG9yZWRTdGF0ZSkge1xuICAgIHJldHVybiB7XG4gICAgICBwa2NlQ29kZVZlcmlmaWVyOiBzdG9yZWRTdGF0ZS5vcmlnaW5hbENvZGVWZXJpZmllcixcbiAgICAgIHJlZGlyZWN0VG86IHN0b3JlZFN0YXRlLnJlZGlyZWN0VG8sXG4gICAgICBjb2RlOiBvYXV0aC5jb2RlLFxuICAgICAgbmV3VXJsOiBvYXV0aC5uZXdVcmwsXG4gICAgICBjdXJyZW50U3RhdGU6IG9hdXRoLnN0YXRlLFxuICAgIH07XG4gIH1cbiAgdGhyb3cgRXJyb3IoJ1N0YXRlIGluIHVybCBkb2VzIG5vdCBtYXRjaCBsb2NhbGx5IHN0b3JlZCBzdGF0ZScpO1xufTsiXX0= |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.encodeBody = void 0; | ||
exports.encodeBody = (body) => (Object.keys(body).reduce((acc, bodyKey) => { | ||
const encodedKey = encodeURIComponent(bodyKey); | ||
const encodedValue = encodeURIComponent(body[bodyKey]); | ||
acc.push(`${encodedKey}=${encodedValue}`); | ||
exports.encodeBody = function (body) { return (Object.keys(body).reduce(function (acc, bodyKey) { | ||
var encodedKey = encodeURIComponent(bodyKey); | ||
var encodedValue = encodeURIComponent(body[bodyKey]); | ||
acc.push(encodedKey + "=" + encodedValue); | ||
return acc; | ||
}, []).join('&')); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5jb2RlQm9keS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9lbmNvZGVCb2R5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFhLFFBQUEsVUFBVSxHQUFHLENBQUMsSUFBK0IsRUFBVSxFQUFFLENBQUMsQ0FDckUsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQVcsQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbEQsTUFBTSxVQUFVLEdBQUcsa0JBQWtCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDL0MsTUFBTSxZQUFZLEdBQUcsa0JBQWtCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDdkQsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLFVBQVUsSUFBSSxZQUFZLEVBQUUsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FDakIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBlbmNvZGVCb2R5ID0gKGJvZHk6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0pOiBzdHJpbmcgPT4gKFxuICBPYmplY3Qua2V5cyhib2R5KS5yZWR1Y2U8c3RyaW5nW10+KChhY2MsIGJvZHlLZXkpID0+IHtcbiAgICBjb25zdCBlbmNvZGVkS2V5ID0gZW5jb2RlVVJJQ29tcG9uZW50KGJvZHlLZXkpO1xuICAgIGNvbnN0IGVuY29kZWRWYWx1ZSA9IGVuY29kZVVSSUNvbXBvbmVudChib2R5W2JvZHlLZXldKTtcbiAgICBhY2MucHVzaChgJHtlbmNvZGVkS2V5fT0ke2VuY29kZWRWYWx1ZX1gKTtcbiAgICByZXR1cm4gYWNjO1xuICB9LCBbXSkuam9pbignJicpXG4pO1xuIl19 | ||
}, []).join('&')); }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5jb2RlQm9keS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9lbmNvZGVCb2R5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFhLFFBQUEsVUFBVSxHQUFHLFVBQUMsSUFBK0IsSUFBYSxPQUFBLENBQ3JFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFXLFVBQUMsR0FBRyxFQUFFLE9BQU87SUFDOUMsSUFBTSxVQUFVLEdBQUcsa0JBQWtCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDL0MsSUFBTSxZQUFZLEdBQUcsa0JBQWtCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDdkQsR0FBRyxDQUFDLElBQUksQ0FBSSxVQUFVLFNBQUksWUFBYyxDQUFDLENBQUM7SUFDMUMsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUNqQixFQVBzRSxDQU90RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVuY29kZUJvZHkgPSAoYm9keTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSk6IHN0cmluZyA9PiAoXG4gIE9iamVjdC5rZXlzKGJvZHkpLnJlZHVjZTxzdHJpbmdbXT4oKGFjYywgYm9keUtleSkgPT4ge1xuICAgIGNvbnN0IGVuY29kZWRLZXkgPSBlbmNvZGVVUklDb21wb25lbnQoYm9keUtleSk7XG4gICAgY29uc3QgZW5jb2RlZFZhbHVlID0gZW5jb2RlVVJJQ29tcG9uZW50KGJvZHlbYm9keUtleV0pO1xuICAgIGFjYy5wdXNoKGAke2VuY29kZWRLZXl9PSR7ZW5jb2RlZFZhbHVlfWApO1xuICAgIHJldHVybiBhY2M7XG4gIH0sIFtdKS5qb2luKCcmJylcbik7XG4iXX0= |
@@ -5,4 +5,4 @@ "use strict"; | ||
function generateRandomData(len) { | ||
let array = []; | ||
const { crypto } = window; | ||
var array = []; | ||
var crypto = window.crypto; | ||
if (crypto && crypto.getRandomValues && window.Uint8Array) { | ||
@@ -14,3 +14,3 @@ array = new Uint8Array(len); | ||
array = new Array(len); | ||
for (let j = 0; j < array.length; j += 1) { | ||
for (var j = 0; j < array.length; j += 1) { | ||
array[j] = Math.floor(256 * Math.random()); | ||
@@ -21,5 +21,5 @@ } | ||
function generateRandomString(len, alphabet) { | ||
const randomData = generateRandomData(len); | ||
const chars = new Array(len); | ||
for (let i = 0; i < len; i += 1) { | ||
var randomData = generateRandomData(len); | ||
var chars = new Array(len); | ||
for (var i = 0; i < len; i += 1) { | ||
chars[i] = alphabet.charCodeAt(randomData[i] % alphabet.length); | ||
@@ -33,2 +33,2 @@ } | ||
exports.generateCodeVerifier = generateCodeVerifier; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVDb2RlVmVyaWZpZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvZ2VuZXJhdGVDb2RlVmVyaWZpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsU0FBUyxrQkFBa0IsQ0FBQyxHQUFXO0lBRXJDLElBQUksS0FBSyxHQUF1QixFQUFFLENBQUM7SUFDbkMsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUMxQixJQUFJLE1BQU0sSUFBSSxNQUFNLENBQUMsZUFBZSxJQUFJLE1BQU0sQ0FBQyxVQUFVLEVBQUU7UUFDekQsS0FBSyxHQUFHLElBQUksVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzVCLE1BQU0sQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUdELEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN2QixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3hDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztLQUM1QztJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVELFNBQVMsb0JBQW9CLENBQUMsR0FBVyxFQUFFLFFBQWdCO0lBQ3pELE1BQU0sVUFBVSxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzNDLE1BQU0sS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUMvQixLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0tBQ2pFO0lBQ0QsT0FBTyxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFDaEQsQ0FBQztBQUVELFNBQWdCLG9CQUFvQixDQUFDLEdBQVc7SUFDOUMsT0FBTyxvQkFBb0IsQ0FBQyxHQUFHLEVBQUUsZ0VBQWdFLENBQUMsQ0FBQztBQUNyRyxDQUFDO0FBRkQsb0RBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gZ2VuZXJhdGVSYW5kb21EYXRhKGxlbjogbnVtYmVyKTogVWludDhBcnJheSB8IGFueVtdIHtcbiAgLy8gdXNlIHdlYiBjcnlwdG8gQVBJcyBpZiBwb3NzaWJsZVxuICBsZXQgYXJyYXk6IFVpbnQ4QXJyYXkgfCBhbnlbXSA9IFtdO1xuICBjb25zdCB7IGNyeXB0byB9ID0gd2luZG93OyAvLyB8fCB3aW5kb3cubXNDcnlwdG87XG4gIGlmIChjcnlwdG8gJiYgY3J5cHRvLmdldFJhbmRvbVZhbHVlcyAmJiB3aW5kb3cuVWludDhBcnJheSkge1xuICAgIGFycmF5ID0gbmV3IFVpbnQ4QXJyYXkobGVuKTtcbiAgICBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzKGFycmF5KTtcbiAgICByZXR1cm4gYXJyYXk7XG4gIH1cblxuICAvLyBmYWxsYmFjayB0byBNYXRoIHJhbmRvbVxuICBhcnJheSA9IG5ldyBBcnJheShsZW4pO1xuICBmb3IgKGxldCBqID0gMDsgaiA8IGFycmF5Lmxlbmd0aDsgaiArPSAxKSB7XG4gICAgYXJyYXlbal0gPSBNYXRoLmZsb29yKDI1NiAqIE1hdGgucmFuZG9tKCkpO1xuICB9XG4gIHJldHVybiBhcnJheTtcbn1cblxuZnVuY3Rpb24gZ2VuZXJhdGVSYW5kb21TdHJpbmcobGVuOiBudW1iZXIsIGFscGhhYmV0OiBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCByYW5kb21EYXRhID0gZ2VuZXJhdGVSYW5kb21EYXRhKGxlbik7XG4gIGNvbnN0IGNoYXJzID0gbmV3IEFycmF5KGxlbik7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuOyBpICs9IDEpIHtcbiAgICBjaGFyc1tpXSA9IGFscGhhYmV0LmNoYXJDb2RlQXQocmFuZG9tRGF0YVtpXSAlIGFscGhhYmV0Lmxlbmd0aCk7XG4gIH1cbiAgcmV0dXJuIFN0cmluZy5mcm9tQ2hhckNvZGUuYXBwbHkobnVsbCwgY2hhcnMpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVDb2RlVmVyaWZpZXIobGVuOiBudW1iZXIpOiBzdHJpbmcge1xuICByZXR1cm4gZ2VuZXJhdGVSYW5kb21TdHJpbmcobGVuLCAnQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODknKTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVDb2RlVmVyaWZpZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvZ2VuZXJhdGVDb2RlVmVyaWZpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsU0FBUyxrQkFBa0IsQ0FBQyxHQUFXO0lBRXJDLElBQUksS0FBSyxHQUF1QixFQUFFLENBQUM7SUFDM0IsSUFBQSxNQUFNLEdBQUssTUFBTSxPQUFYLENBQVk7SUFDMUIsSUFBSSxNQUFNLElBQUksTUFBTSxDQUFDLGVBQWUsSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFO1FBQ3pELEtBQUssR0FBRyxJQUFJLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QixNQUFNLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzlCLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFHRCxLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdkIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN4QyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7S0FDNUM7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUFFRCxTQUFTLG9CQUFvQixDQUFDLEdBQVcsRUFBRSxRQUFnQjtJQUN6RCxJQUFNLFVBQVUsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMzQyxJQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3QixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDL0IsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNqRTtJQUNELE9BQU8sTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQ2hELENBQUM7QUFFRCxTQUFnQixvQkFBb0IsQ0FBQyxHQUFXO0lBQzlDLE9BQU8sb0JBQW9CLENBQUMsR0FBRyxFQUFFLGdFQUFnRSxDQUFDLENBQUM7QUFDckcsQ0FBQztBQUZELG9EQUVDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmZ1bmN0aW9uIGdlbmVyYXRlUmFuZG9tRGF0YShsZW46IG51bWJlcik6IFVpbnQ4QXJyYXkgfCBhbnlbXSB7XG4gIC8vIHVzZSB3ZWIgY3J5cHRvIEFQSXMgaWYgcG9zc2libGVcbiAgbGV0IGFycmF5OiBVaW50OEFycmF5IHwgYW55W10gPSBbXTtcbiAgY29uc3QgeyBjcnlwdG8gfSA9IHdpbmRvdzsgLy8gfHwgd2luZG93Lm1zQ3J5cHRvO1xuICBpZiAoY3J5cHRvICYmIGNyeXB0by5nZXRSYW5kb21WYWx1ZXMgJiYgd2luZG93LlVpbnQ4QXJyYXkpIHtcbiAgICBhcnJheSA9IG5ldyBVaW50OEFycmF5KGxlbik7XG4gICAgY3J5cHRvLmdldFJhbmRvbVZhbHVlcyhhcnJheSk7XG4gICAgcmV0dXJuIGFycmF5O1xuICB9XG5cbiAgLy8gZmFsbGJhY2sgdG8gTWF0aCByYW5kb21cbiAgYXJyYXkgPSBuZXcgQXJyYXkobGVuKTtcbiAgZm9yIChsZXQgaiA9IDA7IGogPCBhcnJheS5sZW5ndGg7IGogKz0gMSkge1xuICAgIGFycmF5W2pdID0gTWF0aC5mbG9vcigyNTYgKiBNYXRoLnJhbmRvbSgpKTtcbiAgfVxuICByZXR1cm4gYXJyYXk7XG59XG5cbmZ1bmN0aW9uIGdlbmVyYXRlUmFuZG9tU3RyaW5nKGxlbjogbnVtYmVyLCBhbHBoYWJldDogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3QgcmFuZG9tRGF0YSA9IGdlbmVyYXRlUmFuZG9tRGF0YShsZW4pO1xuICBjb25zdCBjaGFycyA9IG5ldyBBcnJheShsZW4pO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGxlbjsgaSArPSAxKSB7XG4gICAgY2hhcnNbaV0gPSBhbHBoYWJldC5jaGFyQ29kZUF0KHJhbmRvbURhdGFbaV0gJSBhbHBoYWJldC5sZW5ndGgpO1xuICB9XG4gIHJldHVybiBTdHJpbmcuZnJvbUNoYXJDb2RlLmFwcGx5KG51bGwsIGNoYXJzKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdlbmVyYXRlQ29kZVZlcmlmaWVyKGxlbjogbnVtYmVyKTogc3RyaW5nIHtcbiAgcmV0dXJuIGdlbmVyYXRlUmFuZG9tU3RyaW5nKGxlbiwgJ0FCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Jyk7XG59XG4iXX0= |
@@ -7,7 +7,7 @@ "use strict"; | ||
exports.generatePkceChallenge = void 0; | ||
const base64_js_1 = __importDefault(require("base64-js")); | ||
const js_sha256_1 = require("js-sha256"); | ||
var base64_js_1 = __importDefault(require("base64-js")); | ||
var js_sha256_1 = require("js-sha256"); | ||
function generatePkceChallenge(codeVerifier) { | ||
const hashBytes = new Uint8Array(js_sha256_1.sha256.arrayBuffer(codeVerifier)); | ||
const encodedHash = base64_js_1.default.fromByteArray(hashBytes) | ||
var hashBytes = new Uint8Array(js_sha256_1.sha256.arrayBuffer(codeVerifier)); | ||
var encodedHash = base64_js_1.default.fromByteArray(hashBytes) | ||
.replace(/\+/g, '-') | ||
@@ -19,2 +19,2 @@ .replace(/\//g, '_') | ||
exports.generatePkceChallenge = generatePkceChallenge; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVQa2NlQ2hhbGxlbmdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2dlbmVyYXRlUGtjZUNoYWxsZW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFQSwwREFBaUM7QUFDakMseUNBQW1DO0FBRW5DLFNBQWdCLHFCQUFxQixDQUFDLFlBQW9CO0lBQ3hELE1BQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLGtCQUFNLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7SUFDbkUsTUFBTSxXQUFXLEdBQUcsbUJBQVEsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO1NBQ2xELE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDO1NBQ25CLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDO1NBR25CLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDdEIsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQVRELHNEQVNDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVXNlZCBieSBrZXljbG9hay1qc1xuLy8gaHR0cHM6Ly9naXRodWIuY29tL2tleWNsb2FrL2tleWNsb2FrL2Jsb2IvbWFzdGVyL2FkYXB0ZXJzL29pZGMvanMvc3JjL21haW4vcmVzb3VyY2VzL2tleWNsb2FrLmpzXG5pbXBvcnQgYmFzZTY0anMgZnJvbSAnYmFzZTY0LWpzJztcbmltcG9ydCB7IHNoYTI1NiB9IGZyb20gJ2pzLXNoYTI1Nic7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZVBrY2VDaGFsbGVuZ2UoY29kZVZlcmlmaWVyOiBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCBoYXNoQnl0ZXMgPSBuZXcgVWludDhBcnJheShzaGEyNTYuYXJyYXlCdWZmZXIoY29kZVZlcmlmaWVyKSk7XG4gIGNvbnN0IGVuY29kZWRIYXNoID0gYmFzZTY0anMuZnJvbUJ5dGVBcnJheShoYXNoQnl0ZXMpXG4gICAgLnJlcGxhY2UoL1xcKy9nLCAnLScpXG4gICAgLnJlcGxhY2UoL1xcLy9nLCAnXycpXG4gICAgLy8gSVQgSVMgTk9UIFVTRUxFU1NcbiAgICAvKiBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdXNlbGVzcy1lc2NhcGUgKi9cbiAgICAucmVwbGFjZSgvXFw9L2csICcnKTtcbiAgcmV0dXJuIGVuY29kZWRIYXNoO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVQa2NlQ2hhbGxlbmdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2dlbmVyYXRlUGtjZUNoYWxsZW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFQSx3REFBaUM7QUFDakMsdUNBQW1DO0FBRW5DLFNBQWdCLHFCQUFxQixDQUFDLFlBQW9CO0lBQ3hELElBQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLGtCQUFNLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7SUFDbkUsSUFBTSxXQUFXLEdBQUcsbUJBQVEsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO1NBQ2xELE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDO1NBQ25CLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDO1NBR25CLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDdEIsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQVRELHNEQVNDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVXNlZCBieSBrZXljbG9hay1qc1xuLy8gaHR0cHM6Ly9naXRodWIuY29tL2tleWNsb2FrL2tleWNsb2FrL2Jsb2IvbWFzdGVyL2FkYXB0ZXJzL29pZGMvanMvc3JjL21haW4vcmVzb3VyY2VzL2tleWNsb2FrLmpzXG5pbXBvcnQgYmFzZTY0anMgZnJvbSAnYmFzZTY0LWpzJztcbmltcG9ydCB7IHNoYTI1NiB9IGZyb20gJ2pzLXNoYTI1Nic7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZVBrY2VDaGFsbGVuZ2UoY29kZVZlcmlmaWVyOiBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCBoYXNoQnl0ZXMgPSBuZXcgVWludDhBcnJheShzaGEyNTYuYXJyYXlCdWZmZXIoY29kZVZlcmlmaWVyKSk7XG4gIGNvbnN0IGVuY29kZWRIYXNoID0gYmFzZTY0anMuZnJvbUJ5dGVBcnJheShoYXNoQnl0ZXMpXG4gICAgLnJlcGxhY2UoL1xcKy9nLCAnLScpXG4gICAgLnJlcGxhY2UoL1xcLy9nLCAnXycpXG4gICAgLy8gSVQgSVMgTk9UIFVTRUxFU1NcbiAgICAvKiBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdXNlbGVzcy1lc2NhcGUgKi9cbiAgICAucmVwbGFjZSgvXFw9L2csICcnKTtcbiAgcmV0dXJuIGVuY29kZWRIYXNoO1xufVxuIl19 |
@@ -5,4 +5,4 @@ "use strict"; | ||
exports.Storage = { | ||
get(key) { | ||
const storedStringified = localStorage.getItem(key); | ||
get: function (key) { | ||
var storedStringified = localStorage.getItem(key); | ||
return storedStringified | ||
@@ -12,9 +12,9 @@ ? JSON.parse(storedStringified) | ||
}, | ||
set(key, value) { | ||
set: function (key, value) { | ||
localStorage.setItem(key, JSON.stringify(value)); | ||
}, | ||
remove(key) { | ||
remove: function (key) { | ||
localStorage.removeItem(key); | ||
}, | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9TdG9yYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFhLFFBQUEsT0FBTyxHQUFHO0lBQ3JCLEdBQUcsQ0FBQyxHQUFXO1FBQ2IsTUFBTSxpQkFBaUIsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3BELE9BQU8saUJBQWlCO1lBQ3RCLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDO1lBQy9CLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDaEIsQ0FBQztJQUVELEdBQUcsQ0FBQyxHQUFXLEVBQUUsS0FBVTtRQUN6QixZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUNELE1BQU0sQ0FBQyxHQUFXO1FBQ2hCLFlBQVksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgU3RvcmFnZSA9IHtcbiAgZ2V0KGtleTogc3RyaW5nKSB7XG4gICAgY29uc3Qgc3RvcmVkU3RyaW5naWZpZWQgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xuICAgIHJldHVybiBzdG9yZWRTdHJpbmdpZmllZFxuICAgICAgPyBKU09OLnBhcnNlKHN0b3JlZFN0cmluZ2lmaWVkKVxuICAgICAgOiB1bmRlZmluZWQ7XG4gIH0sXG4gIC8qIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG4gIHNldChrZXk6IHN0cmluZywgdmFsdWU6IGFueSkge1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgSlNPTi5zdHJpbmdpZnkodmFsdWUpKTtcbiAgfSxcbiAgcmVtb3ZlKGtleTogc3RyaW5nKSB7XG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oa2V5KTtcbiAgfSxcbn07XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9TdG9yYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFhLFFBQUEsT0FBTyxHQUFHO0lBQ3JCLEdBQUcsRUFBSCxVQUFJLEdBQVc7UUFDYixJQUFNLGlCQUFpQixHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDcEQsT0FBTyxpQkFBaUI7WUFDdEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUM7WUFDL0IsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNoQixDQUFDO0lBRUQsR0FBRyxFQUFILFVBQUksR0FBVyxFQUFFLEtBQVU7UUFDekIsWUFBWSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFDRCxNQUFNLEVBQU4sVUFBTyxHQUFXO1FBQ2hCLFlBQVksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgU3RvcmFnZSA9IHtcbiAgZ2V0KGtleTogc3RyaW5nKSB7XG4gICAgY29uc3Qgc3RvcmVkU3RyaW5naWZpZWQgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xuICAgIHJldHVybiBzdG9yZWRTdHJpbmdpZmllZFxuICAgICAgPyBKU09OLnBhcnNlKHN0b3JlZFN0cmluZ2lmaWVkKVxuICAgICAgOiB1bmRlZmluZWQ7XG4gIH0sXG4gIC8qIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG4gIHNldChrZXk6IHN0cmluZywgdmFsdWU6IGFueSkge1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwgSlNPTi5zdHJpbmdpZnkodmFsdWUpKTtcbiAgfSxcbiAgcmVtb3ZlKGtleTogc3RyaW5nKSB7XG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oa2V5KTtcbiAgfSxcbn07XG4iXX0= |
{ | ||
"name": "@mybiogen/auth-openid", | ||
"version": "1.5.2", | ||
"version": "1.5.3", | ||
"description": "Authorization for OpenID", | ||
@@ -35,3 +35,3 @@ "license": "MIT", | ||
}, | ||
"gitHead": "c301d92c5328402ebd12daffb660c7a225c92f9e" | ||
"gitHead": "9159aaac127690dc1b19e92c423fefbd5c3eb85c" | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
97701
873
5