From d9757db3a11f942b3f35e8ff8ffde69af12433c7 Mon Sep 17 00:00:00 2001 From: Jenkins Date: Tue, 26 Jan 2021 12:29:32 +0000 Subject: [PATCH] v9.14.3 --- .gitignore | 1 - build/auth0.js | 8176 +++++++++++++++++++++++++ build/auth0.min.esm.js | 9 + build/auth0.min.esm.js.map | 1 + build/auth0.min.js | 9 + build/auth0.min.js.map | 1 + build/cordova-auth0-plugin.js | 1426 +++++ build/cordova-auth0-plugin.min.js | 9 + build/cordova-auth0-plugin.min.js.map | 1 + dist/auth0.js | 8176 +++++++++++++++++++++++++ dist/auth0.min.esm.js | 9 + dist/auth0.min.esm.js.map | 1 + dist/auth0.min.js | 9 + dist/auth0.min.js.map | 1 + dist/cordova-auth0-plugin.js | 1426 +++++ dist/cordova-auth0-plugin.min.js | 9 + dist/cordova-auth0-plugin.min.js.map | 1 + package-lock.json | 2 +- 18 files changed, 19265 insertions(+), 2 deletions(-) create mode 100644 build/auth0.js create mode 100644 build/auth0.min.esm.js create mode 100644 build/auth0.min.esm.js.map create mode 100644 build/auth0.min.js create mode 100644 build/auth0.min.js.map create mode 100644 build/cordova-auth0-plugin.js create mode 100644 build/cordova-auth0-plugin.min.js create mode 100644 build/cordova-auth0-plugin.min.js.map create mode 100644 dist/auth0.js create mode 100644 dist/auth0.min.esm.js create mode 100644 dist/auth0.min.esm.js.map create mode 100644 dist/auth0.min.js create mode 100644 dist/auth0.min.js.map create mode 100644 dist/cordova-auth0-plugin.js create mode 100644 dist/cordova-auth0-plugin.min.js create mode 100644 dist/cordova-auth0-plugin.min.js.map diff --git a/.gitignore b/.gitignore index 69d7b701..27409cb3 100644 --- a/.gitignore +++ b/.gitignore @@ -23,7 +23,6 @@ release .DS_Store -build dist .gitignore diff --git a/build/auth0.js b/build/auth0.js new file mode 100644 index 00000000..064749b6 --- /dev/null +++ b/build/auth0.js @@ -0,0 +1,8176 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (global = global || self, factory(global.auth0 = {})); +}(this, (function (exports) { 'use strict'; + + var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var urlJoin = createCommonjsModule(function (module) { + (function (name, context, definition) { + if ( module.exports) module.exports = definition(); + else context[name] = definition(); + })('urljoin', commonjsGlobal, function () { + + function normalize (strArray) { + var resultArray = []; + if (strArray.length === 0) { return ''; } + + if (typeof strArray[0] !== 'string') { + throw new TypeError('Url must be a string. Received ' + strArray[0]); + } + + // If the first part is a plain protocol, we combine it with the next part. + if (strArray[0].match(/^[^/:]+:\/*$/) && strArray.length > 1) { + var first = strArray.shift(); + strArray[0] = first + strArray[0]; + } + + // There must be two or three slashes in the file protocol, two slashes in anything else. + if (strArray[0].match(/^file:\/\/\//)) { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1:///'); + } else { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1://'); + } + + for (var i = 0; i < strArray.length; i++) { + var component = strArray[i]; + + if (typeof component !== 'string') { + throw new TypeError('Url must be a string. Received ' + component); + } + + if (component === '') { continue; } + + if (i > 0) { + // Removing the starting slashes for each component but the first. + component = component.replace(/^[\/]+/, ''); + } + if (i < strArray.length - 1) { + // Removing the ending slashes for each component but the last. + component = component.replace(/[\/]+$/, ''); + } else { + // For the last component we will combine multiple slashes to a single one. + component = component.replace(/[\/]+$/, '/'); + } + + resultArray.push(component); + + } + + var str = resultArray.join('/'); + // Each input component is now separated by a single slash except the possible first plain protocol part. + + // remove trailing slash before parameters or hash + str = str.replace(/\/(\?|&|#[^!])/g, '$1'); + + // replace ? in parameters with & + var parts = str.split('?'); + str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&'); + + return str; + } + + return function () { + var input; + + if (typeof arguments[0] === 'object') { + input = arguments[0]; + } else { + input = [].slice.call(arguments); + } + + return normalize(input); + }; + + }); + }); + + var has = Object.prototype.hasOwnProperty; + var isArray = Array.isArray; + + var hexTable = (function () { + var array = []; + for (var i = 0; i < 256; ++i) { + array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase()); + } + + return array; + }()); + + var compactQueue = function compactQueue(queue) { + while (queue.length > 1) { + var item = queue.pop(); + var obj = item.obj[item.prop]; + + if (isArray(obj)) { + var compacted = []; + + for (var j = 0; j < obj.length; ++j) { + if (typeof obj[j] !== 'undefined') { + compacted.push(obj[j]); + } + } + + item.obj[item.prop] = compacted; + } + } + }; + + var arrayToObject = function arrayToObject(source, options) { + var obj = options && options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; + }; + + var merge = function merge(target, source, options) { + /* eslint no-param-reassign: 0 */ + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (isArray(target)) { + target.push(source); + } else if (target && typeof target === 'object') { + if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) { + target[source] = true; + } + } else { + return [target, source]; + } + + return target; + } + + if (!target || typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (isArray(target) && !isArray(source)) { + mergeTarget = arrayToObject(target, options); + } + + if (isArray(target) && isArray(source)) { + source.forEach(function (item, i) { + if (has.call(target, i)) { + var targetItem = target[i]; + if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') { + target[i] = merge(targetItem, item, options); + } else { + target.push(item); + } + } else { + target[i] = item; + } + }); + return target; + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (has.call(acc, key)) { + acc[key] = merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); + }; + + var assign = function assignSingleSource(target, source) { + return Object.keys(source).reduce(function (acc, key) { + acc[key] = source[key]; + return acc; + }, target); + }; + + var decode = function (str, decoder, charset) { + var strWithoutPlus = str.replace(/\+/g, ' '); + if (charset === 'iso-8859-1') { + // unescape never throws, no try...catch needed: + return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape); + } + // utf-8 + try { + return decodeURIComponent(strWithoutPlus); + } catch (e) { + return strWithoutPlus; + } + }; + + var encode = function encode(str, defaultEncoder, charset) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = str; + if (typeof str === 'symbol') { + string = Symbol.prototype.toString.call(str); + } else if (typeof str !== 'string') { + string = String(str); + } + + if (charset === 'iso-8859-1') { + return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) { + return '%26%23' + parseInt($0.slice(2), 16) + '%3B'; + }); + } + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D // - + || c === 0x2E // . + || c === 0x5F // _ + || c === 0x7E // ~ + || (c >= 0x30 && c <= 0x39) // 0-9 + || (c >= 0x41 && c <= 0x5A) // a-z + || (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + + hexTable[0x80 | ((c >> 12) & 0x3F)] + + hexTable[0x80 | ((c >> 6) & 0x3F)] + + hexTable[0x80 | (c & 0x3F)]; + } + + return out; + }; + + var compact = function compact(value) { + var queue = [{ obj: { o: value }, prop: 'o' }]; + var refs = []; + + for (var i = 0; i < queue.length; ++i) { + var item = queue[i]; + var obj = item.obj[item.prop]; + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + var val = obj[key]; + if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) { + queue.push({ obj: obj, prop: key }); + refs.push(val); + } + } + } + + compactQueue(queue); + + return value; + }; + + var isRegExp = function isRegExp(obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; + }; + + var isBuffer = function isBuffer(obj) { + if (!obj || typeof obj !== 'object') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); + }; + + var combine = function combine(a, b) { + return [].concat(a, b); + }; + + var maybeMap = function maybeMap(val, fn) { + if (isArray(val)) { + var mapped = []; + for (var i = 0; i < val.length; i += 1) { + mapped.push(fn(val[i])); + } + return mapped; + } + return fn(val); + }; + + var utils = { + arrayToObject: arrayToObject, + assign: assign, + combine: combine, + compact: compact, + decode: decode, + encode: encode, + isBuffer: isBuffer, + isRegExp: isRegExp, + maybeMap: maybeMap, + merge: merge + }; + + var replace = String.prototype.replace; + var percentTwenties = /%20/g; + + + + var Format = { + RFC1738: 'RFC1738', + RFC3986: 'RFC3986' + }; + + var formats = utils.assign( + { + 'default': Format.RFC3986, + formatters: { + RFC1738: function (value) { + return replace.call(value, percentTwenties, '+'); + }, + RFC3986: function (value) { + return String(value); + } + } + }, + Format + ); + + var has$1 = Object.prototype.hasOwnProperty; + + var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + comma: 'comma', + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } + }; + + var isArray$1 = Array.isArray; + var push = Array.prototype.push; + var pushToArray = function (arr, valueOrArray) { + push.apply(arr, isArray$1(valueOrArray) ? valueOrArray : [valueOrArray]); + }; + + var toISO = Date.prototype.toISOString; + + var defaultFormat = formats['default']; + var defaults = { + addQueryPrefix: false, + allowDots: false, + charset: 'utf-8', + charsetSentinel: false, + delimiter: '&', + encode: true, + encoder: utils.encode, + encodeValuesOnly: false, + format: defaultFormat, + formatter: formats.formatters[defaultFormat], + // deprecated + indices: false, + serializeDate: function serializeDate(date) { + return toISO.call(date); + }, + skipNulls: false, + strictNullHandling: false + }; + + var isNonNullishPrimitive = function isNonNullishPrimitive(v) { + return typeof v === 'string' + || typeof v === 'number' + || typeof v === 'boolean' + || typeof v === 'symbol' + || typeof v === 'bigint'; + }; + + var stringify = function stringify( + object, + prefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + ) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = serializeDate(obj); + } else if (generateArrayPrefix === 'comma' && isArray$1(obj)) { + obj = utils.maybeMap(obj, function (value) { + if (value instanceof Date) { + return serializeDate(value); + } + return value; + }).join(','); + } + + if (obj === null) { + if (strictNullHandling) { + return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix; + } + + obj = ''; + } + + if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) { + if (encoder) { + var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key'); + return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))]; + } + return [formatter(prefix) + '=' + formatter(String(obj))]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (isArray$1(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + var value = obj[key]; + + if (skipNulls && value === null) { + continue; + } + + var keyPrefix = isArray$1(obj) + ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix + : prefix + (allowDots ? '.' + key : '[' + key + ']'); + + pushToArray(values, stringify( + value, + keyPrefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + )); + } + + return values; + }; + + var normalizeStringifyOptions = function normalizeStringifyOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + var charset = opts.charset || defaults.charset; + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + + var format = formats['default']; + if (typeof opts.format !== 'undefined') { + if (!has$1.call(formats.formatters, opts.format)) { + throw new TypeError('Unknown format option provided.'); + } + format = opts.format; + } + var formatter = formats.formatters[format]; + + var filter = defaults.filter; + if (typeof opts.filter === 'function' || isArray$1(opts.filter)) { + filter = opts.filter; + } + + return { + addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix, + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter, + encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode, + encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder, + encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly, + filter: filter, + formatter: formatter, + serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate, + skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls, + sort: typeof opts.sort === 'function' ? opts.sort : null, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; + }; + + var stringify_1 = function (object, opts) { + var obj = object; + var options = normalizeStringifyOptions(opts); + + var objKeys; + var filter; + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (isArray$1(options.filter)) { + filter = options.filter; + objKeys = filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (opts && opts.arrayFormat in arrayPrefixGenerators) { + arrayFormat = opts.arrayFormat; + } else if (opts && 'indices' in opts) { + arrayFormat = opts.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (options.sort) { + objKeys.sort(options.sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (options.skipNulls && obj[key] === null) { + continue; + } + pushToArray(keys, stringify( + obj[key], + key, + generateArrayPrefix, + options.strictNullHandling, + options.skipNulls, + options.encode ? options.encoder : null, + options.filter, + options.sort, + options.allowDots, + options.serializeDate, + options.formatter, + options.encodeValuesOnly, + options.charset + )); + } + + var joined = keys.join(options.delimiter); + var prefix = options.addQueryPrefix === true ? '?' : ''; + + if (options.charsetSentinel) { + if (options.charset === 'iso-8859-1') { + // encodeURIComponent('✓'), the "numeric entity" representation of a checkmark + prefix += 'utf8=%26%2310003%3B&'; + } else { + // encodeURIComponent('✓') + prefix += 'utf8=%E2%9C%93&'; + } + } + + return joined.length > 0 ? prefix + joined : ''; + }; + + var has$2 = Object.prototype.hasOwnProperty; + var isArray$2 = Array.isArray; + + var defaults$1 = { + allowDots: false, + allowPrototypes: false, + arrayLimit: 20, + charset: 'utf-8', + charsetSentinel: false, + comma: false, + decoder: utils.decode, + delimiter: '&', + depth: 5, + ignoreQueryPrefix: false, + interpretNumericEntities: false, + parameterLimit: 1000, + parseArrays: true, + plainObjects: false, + strictNullHandling: false + }; + + var interpretNumericEntities = function (str) { + return str.replace(/&#(\d+);/g, function ($0, numberStr) { + return String.fromCharCode(parseInt(numberStr, 10)); + }); + }; + + var parseArrayValue = function (val, options) { + if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) { + return val.split(','); + } + + return val; + }; + + // This is what browsers will submit when the ✓ character occurs in an + // application/x-www-form-urlencoded body and the encoding of the page containing + // the form is iso-8859-1, or when the submitted form has an accept-charset + // attribute of iso-8859-1. Presumably also with other charsets that do not contain + // the ✓ character, such as us-ascii. + var isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓') + + // These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded. + var charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓') + + var parseValues = function parseQueryStringValues(str, options) { + var obj = {}; + var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\?/, '') : str; + var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit; + var parts = cleanStr.split(options.delimiter, limit); + var skipIndex = -1; // Keep track of where the utf8 sentinel was found + var i; + + var charset = options.charset; + if (options.charsetSentinel) { + for (i = 0; i < parts.length; ++i) { + if (parts[i].indexOf('utf8=') === 0) { + if (parts[i] === charsetSentinel) { + charset = 'utf-8'; + } else if (parts[i] === isoSentinel) { + charset = 'iso-8859-1'; + } + skipIndex = i; + i = parts.length; // The eslint settings do not allow break; + } + } + } + + for (i = 0; i < parts.length; ++i) { + if (i === skipIndex) { + continue; + } + var part = parts[i]; + + var bracketEqualsPos = part.indexOf(']='); + var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1; + + var key, val; + if (pos === -1) { + key = options.decoder(part, defaults$1.decoder, charset, 'key'); + val = options.strictNullHandling ? null : ''; + } else { + key = options.decoder(part.slice(0, pos), defaults$1.decoder, charset, 'key'); + val = utils.maybeMap( + parseArrayValue(part.slice(pos + 1), options), + function (encodedVal) { + return options.decoder(encodedVal, defaults$1.decoder, charset, 'value'); + } + ); + } + + if (val && options.interpretNumericEntities && charset === 'iso-8859-1') { + val = interpretNumericEntities(val); + } + + if (part.indexOf('[]=') > -1) { + val = isArray$2(val) ? [val] : val; + } + + if (has$2.call(obj, key)) { + obj[key] = utils.combine(obj[key], val); + } else { + obj[key] = val; + } + } + + return obj; + }; + + var parseObject = function (chain, val, options, valuesParsed) { + var leaf = valuesParsed ? val : parseArrayValue(val, options); + + for (var i = chain.length - 1; i >= 0; --i) { + var obj; + var root = chain[i]; + + if (root === '[]' && options.parseArrays) { + obj = [].concat(leaf); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root; + var index = parseInt(cleanRoot, 10); + if (!options.parseArrays && cleanRoot === '') { + obj = { 0: leaf }; + } else if ( + !isNaN(index) + && root !== cleanRoot + && String(index) === cleanRoot + && index >= 0 + && (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = leaf; + } else { + obj[cleanRoot] = leaf; + } + } + + leaf = obj; // eslint-disable-line no-param-reassign + } + + return leaf; + }; + + var parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^.[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var brackets = /(\[[^[\]]*])/; + var child = /(\[[^[\]]*])/g; + + // Get the parent + + var segment = options.depth > 0 && brackets.exec(key); + var parent = segment ? key.slice(0, segment.index) : key; + + // Stash the parent if it exists + + var keys = []; + if (parent) { + // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties + if (!options.plainObjects && has$2.call(Object.prototype, parent)) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(parent); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && has$2.call(Object.prototype, segment[1].slice(1, -1))) { + if (!options.allowPrototypes) { + return; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options, valuesParsed); + }; + + var normalizeParseOptions = function normalizeParseOptions(opts) { + if (!opts) { + return defaults$1; + } + + if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + var charset = typeof opts.charset === 'undefined' ? defaults$1.charset : opts.charset; + + return { + allowDots: typeof opts.allowDots === 'undefined' ? defaults$1.allowDots : !!opts.allowDots, + allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults$1.allowPrototypes, + arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults$1.arrayLimit, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults$1.charsetSentinel, + comma: typeof opts.comma === 'boolean' ? opts.comma : defaults$1.comma, + decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults$1.decoder, + delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults$1.delimiter, + // eslint-disable-next-line no-implicit-coercion, no-extra-parens + depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults$1.depth, + ignoreQueryPrefix: opts.ignoreQueryPrefix === true, + interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults$1.interpretNumericEntities, + parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults$1.parameterLimit, + parseArrays: opts.parseArrays !== false, + plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults$1.plainObjects, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults$1.strictNullHandling + }; + }; + + var parse = function (str, opts) { + var options = normalizeParseOptions(opts); + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string'); + obj = utils.merge(obj, newObj, options); + } + + return utils.compact(obj); + }; + + var lib = { + formats: formats, + parse: parse, + stringify: stringify_1 + }; + + var componentEmitter = createCommonjsModule(function (module) { + /** + * Expose `Emitter`. + */ + + { + module.exports = Emitter; + } + + /** + * Initialize a new `Emitter`. + * + * @api public + */ + + function Emitter(obj) { + if (obj) return mixin(obj); + } + /** + * Mixin the emitter properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + function mixin(obj) { + for (var key in Emitter.prototype) { + obj[key] = Emitter.prototype[key]; + } + return obj; + } + + /** + * Listen on the given `event` with `fn`. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.on = + Emitter.prototype.addEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + (this._callbacks['$' + event] = this._callbacks['$' + event] || []) + .push(fn); + return this; + }; + + /** + * Adds an `event` listener that will be invoked a single + * time then automatically removed. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.once = function(event, fn){ + function on() { + this.off(event, on); + fn.apply(this, arguments); + } + + on.fn = fn; + this.on(event, on); + return this; + }; + + /** + * Remove the given callback for `event` or all + * registered callbacks. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.off = + Emitter.prototype.removeListener = + Emitter.prototype.removeAllListeners = + Emitter.prototype.removeEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + + // all + if (0 == arguments.length) { + this._callbacks = {}; + return this; + } + + // specific event + var callbacks = this._callbacks['$' + event]; + if (!callbacks) return this; + + // remove all handlers + if (1 == arguments.length) { + delete this._callbacks['$' + event]; + return this; + } + + // remove specific handler + var cb; + for (var i = 0; i < callbacks.length; i++) { + cb = callbacks[i]; + if (cb === fn || cb.fn === fn) { + callbacks.splice(i, 1); + break; + } + } + + // Remove event specific arrays for event types that no + // one is subscribed for to avoid memory leak. + if (callbacks.length === 0) { + delete this._callbacks['$' + event]; + } + + return this; + }; + + /** + * Emit `event` with the given args. + * + * @param {String} event + * @param {Mixed} ... + * @return {Emitter} + */ + + Emitter.prototype.emit = function(event){ + this._callbacks = this._callbacks || {}; + + var args = new Array(arguments.length - 1) + , callbacks = this._callbacks['$' + event]; + + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + + if (callbacks) { + callbacks = callbacks.slice(0); + for (var i = 0, len = callbacks.length; i < len; ++i) { + callbacks[i].apply(this, args); + } + } + + return this; + }; + + /** + * Return array of callbacks for `event`. + * + * @param {String} event + * @return {Array} + * @api public + */ + + Emitter.prototype.listeners = function(event){ + this._callbacks = this._callbacks || {}; + return this._callbacks['$' + event] || []; + }; + + /** + * Check if this emitter has `event` handlers. + * + * @param {String} event + * @return {Boolean} + * @api public + */ + + Emitter.prototype.hasListeners = function(event){ + return !! this.listeners(event).length; + }; + }); + + var fastSafeStringify = stringify$1; + stringify$1.default = stringify$1; + stringify$1.stable = deterministicStringify; + stringify$1.stableStringify = deterministicStringify; + + var arr = []; + var replacerStack = []; + + // Regular stringify + function stringify$1 (obj, replacer, spacer) { + decirc(obj, '', [], undefined); + var res; + if (replacerStack.length === 0) { + res = JSON.stringify(obj, replacer, spacer); + } else { + res = JSON.stringify(obj, replaceGetterValues(replacer), spacer); + } + while (arr.length !== 0) { + var part = arr.pop(); + if (part.length === 4) { + Object.defineProperty(part[0], part[1], part[3]); + } else { + part[0][part[1]] = part[2]; + } + } + return res + } + function decirc (val, k, stack, parent) { + var i; + if (typeof val === 'object' && val !== null) { + for (i = 0; i < stack.length; i++) { + if (stack[i] === val) { + var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k); + if (propertyDescriptor.get !== undefined) { + if (propertyDescriptor.configurable) { + Object.defineProperty(parent, k, { value: '[Circular]' }); + arr.push([parent, k, val, propertyDescriptor]); + } else { + replacerStack.push([val, k]); + } + } else { + parent[k] = '[Circular]'; + arr.push([parent, k, val]); + } + return + } + } + stack.push(val); + // Optimize for Arrays. Big arrays could kill the performance otherwise! + if (Array.isArray(val)) { + for (i = 0; i < val.length; i++) { + decirc(val[i], i, stack, val); + } + } else { + var keys = Object.keys(val); + for (i = 0; i < keys.length; i++) { + var key = keys[i]; + decirc(val[key], key, stack, val); + } + } + stack.pop(); + } + } + + // Stable-stringify + function compareFunction (a, b) { + if (a < b) { + return -1 + } + if (a > b) { + return 1 + } + return 0 + } + + function deterministicStringify (obj, replacer, spacer) { + var tmp = deterministicDecirc(obj, '', [], undefined) || obj; + var res; + if (replacerStack.length === 0) { + res = JSON.stringify(tmp, replacer, spacer); + } else { + res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer); + } + while (arr.length !== 0) { + var part = arr.pop(); + if (part.length === 4) { + Object.defineProperty(part[0], part[1], part[3]); + } else { + part[0][part[1]] = part[2]; + } + } + return res + } + + function deterministicDecirc (val, k, stack, parent) { + var i; + if (typeof val === 'object' && val !== null) { + for (i = 0; i < stack.length; i++) { + if (stack[i] === val) { + var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k); + if (propertyDescriptor.get !== undefined) { + if (propertyDescriptor.configurable) { + Object.defineProperty(parent, k, { value: '[Circular]' }); + arr.push([parent, k, val, propertyDescriptor]); + } else { + replacerStack.push([val, k]); + } + } else { + parent[k] = '[Circular]'; + arr.push([parent, k, val]); + } + return + } + } + if (typeof val.toJSON === 'function') { + return + } + stack.push(val); + // Optimize for Arrays. Big arrays could kill the performance otherwise! + if (Array.isArray(val)) { + for (i = 0; i < val.length; i++) { + deterministicDecirc(val[i], i, stack, val); + } + } else { + // Create a temporary object in the required way + var tmp = {}; + var keys = Object.keys(val).sort(compareFunction); + for (i = 0; i < keys.length; i++) { + var key = keys[i]; + deterministicDecirc(val[key], key, stack, val); + tmp[key] = val[key]; + } + if (parent !== undefined) { + arr.push([parent, k, val]); + parent[k] = tmp; + } else { + return tmp + } + } + stack.pop(); + } + } + + // wraps replacer function to handle values we couldn't replace + // and mark them as [Circular] + function replaceGetterValues (replacer) { + replacer = replacer !== undefined ? replacer : function (k, v) { return v }; + return function (key, val) { + if (replacerStack.length > 0) { + for (var i = 0; i < replacerStack.length; i++) { + var part = replacerStack[i]; + if (part[1] === key && part[0] === val) { + val = '[Circular]'; + replacerStack.splice(i, 1); + break + } + } + } + return replacer.call(this, key, val) + } + } + + function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } + + /** + * Check if `obj` is an object. + * + * @param {Object} obj + * @return {Boolean} + * @api private + */ + function isObject(obj) { + return obj !== null && _typeof(obj) === 'object'; + } + + var isObject_1 = isObject; + + function _typeof$1(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof$1 = function _typeof(obj) { return typeof obj; }; } else { _typeof$1 = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof$1(obj); } + + /** + * Module of mixed-in functions shared between node and client code + */ + + /** + * Expose `RequestBase`. + */ + + + var requestBase = RequestBase; + /** + * Initialize a new `RequestBase`. + * + * @api public + */ + + function RequestBase(obj) { + if (obj) return mixin(obj); + } + /** + * Mixin the prototype properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + + function mixin(obj) { + for (var key in RequestBase.prototype) { + if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key]; + } + + return obj; + } + /** + * Clear previous timeout. + * + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.clearTimeout = function () { + clearTimeout(this._timer); + clearTimeout(this._responseTimeoutTimer); + clearTimeout(this._uploadTimeoutTimer); + delete this._timer; + delete this._responseTimeoutTimer; + delete this._uploadTimeoutTimer; + return this; + }; + /** + * Override default response body parser + * + * This function will be called to convert incoming data into request.body + * + * @param {Function} + * @api public + */ + + + RequestBase.prototype.parse = function (fn) { + this._parser = fn; + return this; + }; + /** + * Set format of binary response body. + * In browser valid formats are 'blob' and 'arraybuffer', + * which return Blob and ArrayBuffer, respectively. + * + * In Node all values result in Buffer. + * + * Examples: + * + * req.get('/') + * .responseType('blob') + * .end(callback); + * + * @param {String} val + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.responseType = function (val) { + this._responseType = val; + return this; + }; + /** + * Override default request body serializer + * + * This function will be called to convert data set via .send or .attach into payload to send + * + * @param {Function} + * @api public + */ + + + RequestBase.prototype.serialize = function (fn) { + this._serializer = fn; + return this; + }; + /** + * Set timeouts. + * + * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time. + * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections. + * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off + * + * Value of 0 or false means no timeout. + * + * @param {Number|Object} ms or {response, deadline} + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.timeout = function (options) { + if (!options || _typeof$1(options) !== 'object') { + this._timeout = options; + this._responseTimeout = 0; + this._uploadTimeout = 0; + return this; + } + + for (var option in options) { + if (Object.prototype.hasOwnProperty.call(options, option)) { + switch (option) { + case 'deadline': + this._timeout = options.deadline; + break; + + case 'response': + this._responseTimeout = options.response; + break; + + case 'upload': + this._uploadTimeout = options.upload; + break; + + default: + console.warn('Unknown timeout option', option); + } + } + } + + return this; + }; + /** + * Set number of retry attempts on error. + * + * Failed requests will be retried 'count' times if timeout or err.code >= 500. + * + * @param {Number} count + * @param {Function} [fn] + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.retry = function (count, fn) { + // Default to 1 if no count passed or true + if (arguments.length === 0 || count === true) count = 1; + if (count <= 0) count = 0; + this._maxRetries = count; + this._retries = 0; + this._retryCallback = fn; + return this; + }; + + var ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT']; + /** + * Determine if a request should be retried. + * (Borrowed from segmentio/superagent-retry) + * + * @param {Error} err an error + * @param {Response} [res] response + * @returns {Boolean} if segment should be retried + */ + + RequestBase.prototype._shouldRetry = function (err, res) { + if (!this._maxRetries || this._retries++ >= this._maxRetries) { + return false; + } + + if (this._retryCallback) { + try { + var override = this._retryCallback(err, res); + + if (override === true) return true; + if (override === false) return false; // undefined falls back to defaults + } catch (err_) { + console.error(err_); + } + } + + if (res && res.status && res.status >= 500 && res.status !== 501) return true; + + if (err) { + if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout + + if (err.timeout && err.code === 'ECONNABORTED') return true; + if (err.crossDomain) return true; + } + + return false; + }; + /** + * Retry request + * + * @return {Request} for chaining + * @api private + */ + + + RequestBase.prototype._retry = function () { + this.clearTimeout(); // node + + if (this.req) { + this.req = null; + this.req = this.request(); + } + + this._aborted = false; + this.timedout = false; + this.timedoutError = null; + return this._end(); + }; + /** + * Promise support + * + * @param {Function} resolve + * @param {Function} [reject] + * @return {Request} + */ + + + RequestBase.prototype.then = function (resolve, reject) { + var _this = this; + + if (!this._fullfilledPromise) { + var self = this; + + if (this._endCalled) { + console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises'); + } + + this._fullfilledPromise = new Promise(function (resolve, reject) { + self.on('abort', function () { + if (_this._maxRetries && _this._maxRetries > _this._retries) { + return; + } + + if (_this.timedout && _this.timedoutError) { + reject(_this.timedoutError); + return; + } + + var err = new Error('Aborted'); + err.code = 'ABORTED'; + err.status = _this.status; + err.method = _this.method; + err.url = _this.url; + reject(err); + }); + self.end(function (err, res) { + if (err) reject(err);else resolve(res); + }); + }); + } + + return this._fullfilledPromise.then(resolve, reject); + }; + + RequestBase.prototype.catch = function (cb) { + return this.then(undefined, cb); + }; + /** + * Allow for extension + */ + + + RequestBase.prototype.use = function (fn) { + fn(this); + return this; + }; + + RequestBase.prototype.ok = function (cb) { + if (typeof cb !== 'function') throw new Error('Callback required'); + this._okCallback = cb; + return this; + }; + + RequestBase.prototype._isResponseOK = function (res) { + if (!res) { + return false; + } + + if (this._okCallback) { + return this._okCallback(res); + } + + return res.status >= 200 && res.status < 300; + }; + /** + * Get request header `field`. + * Case-insensitive. + * + * @param {String} field + * @return {String} + * @api public + */ + + + RequestBase.prototype.get = function (field) { + return this._header[field.toLowerCase()]; + }; + /** + * Get case-insensitive header `field` value. + * This is a deprecated internal API. Use `.get(field)` instead. + * + * (getHeader is no longer used internally by the superagent code base) + * + * @param {String} field + * @return {String} + * @api private + * @deprecated + */ + + + RequestBase.prototype.getHeader = RequestBase.prototype.get; + /** + * Set header `field` to `val`, or multiple fields with one object. + * Case-insensitive. + * + * Examples: + * + * req.get('/') + * .set('Accept', 'application/json') + * .set('X-API-Key', 'foobar') + * .end(callback); + * + * req.get('/') + * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' }) + * .end(callback); + * + * @param {String|Object} field + * @param {String} val + * @return {Request} for chaining + * @api public + */ + + RequestBase.prototype.set = function (field, val) { + if (isObject_1(field)) { + for (var key in field) { + if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]); + } + + return this; + } + + this._header[field.toLowerCase()] = val; + this.header[field] = val; + return this; + }; + /** + * Remove header `field`. + * Case-insensitive. + * + * Example: + * + * req.get('/') + * .unset('User-Agent') + * .end(callback); + * + * @param {String} field field name + */ + + + RequestBase.prototype.unset = function (field) { + delete this._header[field.toLowerCase()]; + delete this.header[field]; + return this; + }; + /** + * Write the field `name` and `val`, or multiple fields with one object + * for "multipart/form-data" request bodies. + * + * ``` js + * request.post('/upload') + * .field('foo', 'bar') + * .end(callback); + * + * request.post('/upload') + * .field({ foo: 'bar', baz: 'qux' }) + * .end(callback); + * ``` + * + * @param {String|Object} name name of field + * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.field = function (name, val) { + // name should be either a string or an object. + if (name === null || undefined === name) { + throw new Error('.field(name, val) name can not be empty'); + } + + if (this._data) { + throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()"); + } + + if (isObject_1(name)) { + for (var key in name) { + if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]); + } + + return this; + } + + if (Array.isArray(val)) { + for (var i in val) { + if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]); + } + + return this; + } // val should be defined now + + + if (val === null || undefined === val) { + throw new Error('.field(name, val) val can not be empty'); + } + + if (typeof val === 'boolean') { + val = String(val); + } + + this._getFormData().append(name, val); + + return this; + }; + /** + * Abort the request, and clear potential timeout. + * + * @return {Request} request + * @api public + */ + + + RequestBase.prototype.abort = function () { + if (this._aborted) { + return this; + } + + this._aborted = true; + if (this.xhr) this.xhr.abort(); // browser + + if (this.req) this.req.abort(); // node + + this.clearTimeout(); + this.emit('abort'); + return this; + }; + + RequestBase.prototype._auth = function (user, pass, options, base64Encoder) { + switch (options.type) { + case 'basic': + this.set('Authorization', "Basic ".concat(base64Encoder("".concat(user, ":").concat(pass)))); + break; + + case 'auto': + this.username = user; + this.password = pass; + break; + + case 'bearer': + // usage would be .auth(accessToken, { type: 'bearer' }) + this.set('Authorization', "Bearer ".concat(user)); + break; + } + + return this; + }; + /** + * Enable transmission of cookies with x-domain requests. + * + * Note that for this to work the origin must not be + * using "Access-Control-Allow-Origin" with a wildcard, + * and also must set "Access-Control-Allow-Credentials" + * to "true". + * + * @api public + */ + + + RequestBase.prototype.withCredentials = function (on) { + // This is browser-only functionality. Node side is no-op. + if (on === undefined) on = true; + this._withCredentials = on; + return this; + }; + /** + * Set the max redirects to `n`. Does nothing in browser XHR implementation. + * + * @param {Number} n + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.redirects = function (n) { + this._maxRedirects = n; + return this; + }; + /** + * Maximum size of buffered response body, in bytes. Counts uncompressed size. + * Default 200MB. + * + * @param {Number} n number of bytes + * @return {Request} for chaining + */ + + + RequestBase.prototype.maxResponseSize = function (n) { + if (typeof n !== 'number') { + throw new TypeError('Invalid argument'); + } + + this._maxResponseSize = n; + return this; + }; + /** + * Convert to a plain javascript object (not JSON string) of scalar properties. + * Note as this method is designed to return a useful non-this value, + * it cannot be chained. + * + * @return {Object} describing method, url, and data of this request + * @api public + */ + + + RequestBase.prototype.toJSON = function () { + return { + method: this.method, + url: this.url, + data: this._data, + headers: this._header + }; + }; + /** + * Send `data` as the request body, defaulting the `.type()` to "json" when + * an object is given. + * + * Examples: + * + * // manual json + * request.post('/user') + * .type('json') + * .send('{"name":"tj"}') + * .end(callback) + * + * // auto json + * request.post('/user') + * .send({ name: 'tj' }) + * .end(callback) + * + * // manual x-www-form-urlencoded + * request.post('/user') + * .type('form') + * .send('name=tj') + * .end(callback) + * + * // auto x-www-form-urlencoded + * request.post('/user') + * .type('form') + * .send({ name: 'tj' }) + * .end(callback) + * + * // defaults to x-www-form-urlencoded + * request.post('/user') + * .send('name=tobi') + * .send('species=ferret') + * .end(callback) + * + * @param {String|Object} data + * @return {Request} for chaining + * @api public + */ + // eslint-disable-next-line complexity + + + RequestBase.prototype.send = function (data) { + var isObj = isObject_1(data); + var type = this._header['content-type']; + + if (this._formData) { + throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()"); + } + + if (isObj && !this._data) { + if (Array.isArray(data)) { + this._data = []; + } else if (!this._isHost(data)) { + this._data = {}; + } + } else if (data && this._data && this._isHost(this._data)) { + throw new Error("Can't merge these send calls"); + } // merge + + + if (isObj && isObject_1(this._data)) { + for (var key in data) { + if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key]; + } + } else if (typeof data === 'string') { + // default to x-www-form-urlencoded + if (!type) this.type('form'); + type = this._header['content-type']; + + if (type === 'application/x-www-form-urlencoded') { + this._data = this._data ? "".concat(this._data, "&").concat(data) : data; + } else { + this._data = (this._data || '') + data; + } + } else { + this._data = data; + } + + if (!isObj || this._isHost(data)) { + return this; + } // default to json + + + if (!type) this.type('json'); + return this; + }; + /** + * Sort `querystring` by the sort function + * + * + * Examples: + * + * // default order + * request.get('/user') + * .query('name=Nick') + * .query('search=Manny') + * .sortQuery() + * .end(callback) + * + * // customized sort function + * request.get('/user') + * .query('name=Nick') + * .query('search=Manny') + * .sortQuery(function(a, b){ + * return a.length - b.length; + * }) + * .end(callback) + * + * + * @param {Function} sort + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.sortQuery = function (sort) { + // _sort default to true but otherwise can be a function or boolean + this._sort = typeof sort === 'undefined' ? true : sort; + return this; + }; + /** + * Compose querystring to append to req.url + * + * @api private + */ + + + RequestBase.prototype._finalizeQueryString = function () { + var query = this._query.join('&'); + + if (query) { + this.url += (this.url.includes('?') ? '&' : '?') + query; + } + + this._query.length = 0; // Makes the call idempotent + + if (this._sort) { + var index = this.url.indexOf('?'); + + if (index >= 0) { + var queryArr = this.url.slice(index + 1).split('&'); + + if (typeof this._sort === 'function') { + queryArr.sort(this._sort); + } else { + queryArr.sort(); + } + + this.url = this.url.slice(0, index) + '?' + queryArr.join('&'); + } + } + }; // For backwards compat only + + + RequestBase.prototype._appendQueryString = function () { + console.warn('Unsupported'); + }; + /** + * Invoke callback with timeout error. + * + * @api private + */ + + + RequestBase.prototype._timeoutError = function (reason, timeout, errno) { + if (this._aborted) { + return; + } + + var err = new Error("".concat(reason + timeout, "ms exceeded")); + err.timeout = timeout; + err.code = 'ECONNABORTED'; + err.errno = errno; + this.timedout = true; + this.timedoutError = err; + this.abort(); + this.callback(err); + }; + + RequestBase.prototype._setTimeouts = function () { + var self = this; // deadline + + if (this._timeout && !this._timer) { + this._timer = setTimeout(function () { + self._timeoutError('Timeout of ', self._timeout, 'ETIME'); + }, this._timeout); + } // response timeout + + + if (this._responseTimeout && !this._responseTimeoutTimer) { + this._responseTimeoutTimer = setTimeout(function () { + self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT'); + }, this._responseTimeout); + } + }; + + /** + * Return the mime type for the given `str`. + * + * @param {String} str + * @return {String} + * @api private + */ + var type = function (str) { + return str.split(/ *; */).shift(); + }; + /** + * Return header field parameters. + * + * @param {String} str + * @return {Object} + * @api private + */ + + + var params = function (str) { + return str.split(/ *; */).reduce(function (obj, str) { + var parts = str.split(/ *= */); + var key = parts.shift(); + var val = parts.shift(); + if (key && val) obj[key] = val; + return obj; + }, {}); + }; + /** + * Parse Link header fields. + * + * @param {String} str + * @return {Object} + * @api private + */ + + + var parseLinks = function (str) { + return str.split(/ *, */).reduce(function (obj, str) { + var parts = str.split(/ *; */); + var url = parts[0].slice(1, -1); + var rel = parts[1].split(/ *= */)[1].slice(1, -1); + obj[rel] = url; + return obj; + }, {}); + }; + /** + * Strip content related fields from `header`. + * + * @param {Object} header + * @return {Object} header + * @api private + */ + + + var cleanHeader = function (header, changesOrigin) { + delete header['content-type']; + delete header['content-length']; + delete header['transfer-encoding']; + delete header.host; // secuirty + + if (changesOrigin) { + delete header.authorization; + delete header.cookie; + } + + return header; + }; + + + var utils$1 = { + type: type, + params: params, + parseLinks: parseLinks, + cleanHeader: cleanHeader + }; + + /** + * Module dependencies. + */ + + /** + * Expose `ResponseBase`. + */ + + + var responseBase = ResponseBase; + /** + * Initialize a new `ResponseBase`. + * + * @api public + */ + + function ResponseBase(obj) { + if (obj) return mixin$1(obj); + } + /** + * Mixin the prototype properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + + function mixin$1(obj) { + for (var key in ResponseBase.prototype) { + if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key]; + } + + return obj; + } + /** + * Get case-insensitive `field` value. + * + * @param {String} field + * @return {String} + * @api public + */ + + + ResponseBase.prototype.get = function (field) { + return this.header[field.toLowerCase()]; + }; + /** + * Set header related properties: + * + * - `.type` the content type without params + * + * A response of "Content-Type: text/plain; charset=utf-8" + * will provide you with a `.type` of "text/plain". + * + * @param {Object} header + * @api private + */ + + + ResponseBase.prototype._setHeaderProperties = function (header) { + // TODO: moar! + // TODO: make this a util + // content-type + var ct = header['content-type'] || ''; + this.type = utils$1.type(ct); // params + + var params = utils$1.params(ct); + + for (var key in params) { + if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key]; + } + + this.links = {}; // links + + try { + if (header.link) { + this.links = utils$1.parseLinks(header.link); + } + } catch (_unused) {// ignore + } + }; + /** + * Set flags such as `.ok` based on `status`. + * + * For example a 2xx response will give you a `.ok` of __true__ + * whereas 5xx will be __false__ and `.error` will be __true__. The + * `.clientError` and `.serverError` are also available to be more + * specific, and `.statusType` is the class of error ranging from 1..5 + * sometimes useful for mapping respond colors etc. + * + * "sugar" properties are also defined for common cases. Currently providing: + * + * - .noContent + * - .badRequest + * - .unauthorized + * - .notAcceptable + * - .notFound + * + * @param {Number} status + * @api private + */ + + + ResponseBase.prototype._setStatusProperties = function (status) { + var type = status / 100 | 0; // status / class + + this.statusCode = status; + this.status = this.statusCode; + this.statusType = type; // basics + + this.info = type === 1; + this.ok = type === 2; + this.redirect = type === 3; + this.clientError = type === 4; + this.serverError = type === 5; + this.error = type === 4 || type === 5 ? this.toError() : false; // sugar + + this.created = status === 201; + this.accepted = status === 202; + this.noContent = status === 204; + this.badRequest = status === 400; + this.unauthorized = status === 401; + this.notAcceptable = status === 406; + this.forbidden = status === 403; + this.notFound = status === 404; + this.unprocessableEntity = status === 422; + }; + + function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } + + function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } + + function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } + + function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } + + function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } + + function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } + + function Agent() { + this._defaults = []; + } + + ['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) { + // Default setting for all requests from this agent + Agent.prototype[fn] = function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + this._defaults.push({ + fn: fn, + args: args + }); + + return this; + }; + }); + + Agent.prototype._setDefaults = function (req) { + this._defaults.forEach(function (def) { + req[def.fn].apply(req, _toConsumableArray(def.args)); + }); + }; + + var agentBase = Agent; + + var client = createCommonjsModule(function (module, exports) { + + function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } + + /** + * Root reference for iframes. + */ + var root; + + if (typeof window !== 'undefined') { + // Browser window + root = window; + } else if (typeof self === 'undefined') { + // Other environments + console.warn('Using browser-only version of superagent in non-browser environment'); + root = void 0; + } else { + // Web Worker + root = self; + } + + + + + + + + + + + + + /** + * Noop. + */ + + + function noop() {} + /** + * Expose `request`. + */ + + + module.exports = function (method, url) { + // callback + if (typeof url === 'function') { + return new exports.Request('GET', method).end(url); + } // url first + + + if (arguments.length === 1) { + return new exports.Request('GET', method); + } + + return new exports.Request(method, url); + }; + + exports = module.exports; + var request = exports; + exports.Request = Request; + /** + * Determine XHR. + */ + + request.getXHR = function () { + if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) { + return new XMLHttpRequest(); + } + + try { + return new ActiveXObject('Microsoft.XMLHTTP'); + } catch (_unused) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP.6.0'); + } catch (_unused2) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP.3.0'); + } catch (_unused3) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP'); + } catch (_unused4) {} + + throw new Error('Browser-only version of superagent could not find XHR'); + }; + /** + * Removes leading and trailing whitespace, added to support IE. + * + * @param {String} s + * @return {String} + * @api private + */ + + + var trim = ''.trim ? function (s) { + return s.trim(); + } : function (s) { + return s.replace(/(^\s*|\s*$)/g, ''); + }; + /** + * Serialize the given `obj`. + * + * @param {Object} obj + * @return {String} + * @api private + */ + + function serialize(obj) { + if (!isObject_1(obj)) return obj; + var pairs = []; + + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]); + } + + return pairs.join('&'); + } + /** + * Helps 'serialize' with serializing arrays. + * Mutates the pairs array. + * + * @param {Array} pairs + * @param {String} key + * @param {Mixed} val + */ + + + function pushEncodedKeyValuePair(pairs, key, val) { + if (val === undefined) return; + + if (val === null) { + pairs.push(encodeURI(key)); + return; + } + + if (Array.isArray(val)) { + val.forEach(function (v) { + pushEncodedKeyValuePair(pairs, key, v); + }); + } else if (isObject_1(val)) { + for (var subkey in val) { + if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, "".concat(key, "[").concat(subkey, "]"), val[subkey]); + } + } else { + pairs.push(encodeURI(key) + '=' + encodeURIComponent(val)); + } + } + /** + * Expose serialization method. + */ + + + request.serializeObject = serialize; + /** + * Parse the given x-www-form-urlencoded `str`. + * + * @param {String} str + * @return {Object} + * @api private + */ + + function parseString(str) { + var obj = {}; + var pairs = str.split('&'); + var pair; + var pos; + + for (var i = 0, len = pairs.length; i < len; ++i) { + pair = pairs[i]; + pos = pair.indexOf('='); + + if (pos === -1) { + obj[decodeURIComponent(pair)] = ''; + } else { + obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1)); + } + } + + return obj; + } + /** + * Expose parser. + */ + + + request.parseString = parseString; + /** + * Default MIME type map. + * + * superagent.types.xml = 'application/xml'; + * + */ + + request.types = { + html: 'text/html', + json: 'application/json', + xml: 'text/xml', + urlencoded: 'application/x-www-form-urlencoded', + form: 'application/x-www-form-urlencoded', + 'form-data': 'application/x-www-form-urlencoded' + }; + /** + * Default serialization map. + * + * superagent.serialize['application/xml'] = function(obj){ + * return 'generated xml here'; + * }; + * + */ + + request.serialize = { + 'application/x-www-form-urlencoded': serialize, + 'application/json': fastSafeStringify + }; + /** + * Default parsers. + * + * superagent.parse['application/xml'] = function(str){ + * return { object parsed from str }; + * }; + * + */ + + request.parse = { + 'application/x-www-form-urlencoded': parseString, + 'application/json': JSON.parse + }; + /** + * Parse the given header `str` into + * an object containing the mapped fields. + * + * @param {String} str + * @return {Object} + * @api private + */ + + function parseHeader(str) { + var lines = str.split(/\r?\n/); + var fields = {}; + var index; + var line; + var field; + var val; + + for (var i = 0, len = lines.length; i < len; ++i) { + line = lines[i]; + index = line.indexOf(':'); + + if (index === -1) { + // could be empty line, just skip it + continue; + } + + field = line.slice(0, index).toLowerCase(); + val = trim(line.slice(index + 1)); + fields[field] = val; + } + + return fields; + } + /** + * Check if `mime` is json or has +json structured syntax suffix. + * + * @param {String} mime + * @return {Boolean} + * @api private + */ + + + function isJSON(mime) { + // should match /json or +json + // but not /json-seq + return /[/+]json($|[^-\w])/.test(mime); + } + /** + * Initialize a new `Response` with the given `xhr`. + * + * - set flags (.ok, .error, etc) + * - parse header + * + * Examples: + * + * Aliasing `superagent` as `request` is nice: + * + * request = superagent; + * + * We can use the promise-like API, or pass callbacks: + * + * request.get('/').end(function(res){}); + * request.get('/', function(res){}); + * + * Sending data can be chained: + * + * request + * .post('/user') + * .send({ name: 'tj' }) + * .end(function(res){}); + * + * Or passed to `.send()`: + * + * request + * .post('/user') + * .send({ name: 'tj' }, function(res){}); + * + * Or passed to `.post()`: + * + * request + * .post('/user', { name: 'tj' }) + * .end(function(res){}); + * + * Or further reduced to a single call for simple cases: + * + * request + * .post('/user', { name: 'tj' }, function(res){}); + * + * @param {XMLHTTPRequest} xhr + * @param {Object} options + * @api private + */ + + + function Response(req) { + this.req = req; + this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers + + this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null; + this.statusText = this.req.xhr.statusText; + var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request + + if (status === 1223) { + status = 204; + } + + this._setStatusProperties(status); + + this.headers = parseHeader(this.xhr.getAllResponseHeaders()); + this.header = this.headers; // getAllResponseHeaders sometimes falsely returns "" for CORS requests, but + // getResponseHeader still works. so we get content-type even if getting + // other headers fails. + + this.header['content-type'] = this.xhr.getResponseHeader('content-type'); + + this._setHeaderProperties(this.header); + + if (this.text === null && req._responseType) { + this.body = this.xhr.response; + } else { + this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response); + } + } // eslint-disable-next-line new-cap + + + responseBase(Response.prototype); + /** + * Parse the given body `str`. + * + * Used for auto-parsing of bodies. Parsers + * are defined on the `superagent.parse` object. + * + * @param {String} str + * @return {Mixed} + * @api private + */ + + Response.prototype._parseBody = function (str) { + var parse = request.parse[this.type]; + + if (this.req._parser) { + return this.req._parser(this, str); + } + + if (!parse && isJSON(this.type)) { + parse = request.parse['application/json']; + } + + return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null; + }; + /** + * Return an `Error` representative of this response. + * + * @return {Error} + * @api public + */ + + + Response.prototype.toError = function () { + var req = this.req; + var method = req.method; + var url = req.url; + var msg = "cannot ".concat(method, " ").concat(url, " (").concat(this.status, ")"); + var err = new Error(msg); + err.status = this.status; + err.method = method; + err.url = url; + return err; + }; + /** + * Expose `Response`. + */ + + + request.Response = Response; + /** + * Initialize a new `Request` with the given `method` and `url`. + * + * @param {String} method + * @param {String} url + * @api public + */ + + function Request(method, url) { + var self = this; + this._query = this._query || []; + this.method = method; + this.url = url; + this.header = {}; // preserves header name case + + this._header = {}; // coerces header names to lowercase + + this.on('end', function () { + var err = null; + var res = null; + + try { + res = new Response(self); + } catch (err_) { + err = new Error('Parser is unable to parse the response'); + err.parse = true; + err.original = err_; // issue #675: return the raw response if the response parsing fails + + if (self.xhr) { + // ie9 doesn't have 'response' property + err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails + + err.status = self.xhr.status ? self.xhr.status : null; + err.statusCode = err.status; // backwards-compat only + } else { + err.rawResponse = null; + err.status = null; + } + + return self.callback(err); + } + + self.emit('response', res); + var new_err; + + try { + if (!self._isResponseOK(res)) { + new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response'); + } + } catch (err_) { + new_err = err_; // ok() callback can throw + } // #1000 don't catch errors from the callback to avoid double calling it + + + if (new_err) { + new_err.original = err; + new_err.response = res; + new_err.status = res.status; + self.callback(new_err, res); + } else { + self.callback(null, res); + } + }); + } + /** + * Mixin `Emitter` and `RequestBase`. + */ + // eslint-disable-next-line new-cap + + + componentEmitter(Request.prototype); // eslint-disable-next-line new-cap + + requestBase(Request.prototype); + /** + * Set Content-Type to `type`, mapping values from `request.types`. + * + * Examples: + * + * superagent.types.xml = 'application/xml'; + * + * request.post('/') + * .type('xml') + * .send(xmlstring) + * .end(callback); + * + * request.post('/') + * .type('application/xml') + * .send(xmlstring) + * .end(callback); + * + * @param {String} type + * @return {Request} for chaining + * @api public + */ + + Request.prototype.type = function (type) { + this.set('Content-Type', request.types[type] || type); + return this; + }; + /** + * Set Accept to `type`, mapping values from `request.types`. + * + * Examples: + * + * superagent.types.json = 'application/json'; + * + * request.get('/agent') + * .accept('json') + * .end(callback); + * + * request.get('/agent') + * .accept('application/json') + * .end(callback); + * + * @param {String} accept + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.accept = function (type) { + this.set('Accept', request.types[type] || type); + return this; + }; + /** + * Set Authorization field value with `user` and `pass`. + * + * @param {String} user + * @param {String} [pass] optional in case of using 'bearer' as type + * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic') + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.auth = function (user, pass, options) { + if (arguments.length === 1) pass = ''; + + if (_typeof(pass) === 'object' && pass !== null) { + // pass is optional and can be replaced with options + options = pass; + pass = ''; + } + + if (!options) { + options = { + type: typeof btoa === 'function' ? 'basic' : 'auto' + }; + } + + var encoder = function encoder(string) { + if (typeof btoa === 'function') { + return btoa(string); + } + + throw new Error('Cannot use basic auth, btoa is not a function'); + }; + + return this._auth(user, pass, options, encoder); + }; + /** + * Add query-string `val`. + * + * Examples: + * + * request.get('/shoes') + * .query('size=10') + * .query({ color: 'blue' }) + * + * @param {Object|String} val + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.query = function (val) { + if (typeof val !== 'string') val = serialize(val); + if (val) this._query.push(val); + return this; + }; + /** + * Queue the given `file` as an attachment to the specified `field`, + * with optional `options` (or filename). + * + * ``` js + * request.post('/upload') + * .attach('content', new Blob(['hey!'], { type: "text/html"})) + * .end(callback); + * ``` + * + * @param {String} field + * @param {Blob|File} file + * @param {String|Object} options + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.attach = function (field, file, options) { + if (file) { + if (this._data) { + throw new Error("superagent can't mix .send() and .attach()"); + } + + this._getFormData().append(field, file, options || file.name); + } + + return this; + }; + + Request.prototype._getFormData = function () { + if (!this._formData) { + this._formData = new root.FormData(); + } + + return this._formData; + }; + /** + * Invoke the callback with `err` and `res` + * and handle arity check. + * + * @param {Error} err + * @param {Response} res + * @api private + */ + + + Request.prototype.callback = function (err, res) { + if (this._shouldRetry(err, res)) { + return this._retry(); + } + + var fn = this._callback; + this.clearTimeout(); + + if (err) { + if (this._maxRetries) err.retries = this._retries - 1; + this.emit('error', err); + } + + fn(err, res); + }; + /** + * Invoke callback with x-domain error. + * + * @api private + */ + + + Request.prototype.crossDomainError = function () { + var err = new Error('Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.'); + err.crossDomain = true; + err.status = this.status; + err.method = this.method; + err.url = this.url; + this.callback(err); + }; // This only warns, because the request is still likely to work + + + Request.prototype.agent = function () { + console.warn('This is not supported in browser version of superagent'); + return this; + }; + + Request.prototype.ca = Request.prototype.agent; + Request.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected + + Request.prototype.write = function () { + throw new Error('Streaming is not supported in browser version of superagent'); + }; + + Request.prototype.pipe = Request.prototype.write; + /** + * Check if `obj` is a host object, + * we don't want to serialize these :) + * + * @param {Object} obj host object + * @return {Boolean} is a host object + * @api private + */ + + Request.prototype._isHost = function (obj) { + // Native objects stringify to [object File], [object Blob], [object FormData], etc. + return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]'; + }; + /** + * Initiate request, invoking callback `fn(res)` + * with an instanceof `Response`. + * + * @param {Function} fn + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.end = function (fn) { + if (this._endCalled) { + console.warn('Warning: .end() was called twice. This is not supported in superagent'); + } + + this._endCalled = true; // store callback + + this._callback = fn || noop; // querystring + + this._finalizeQueryString(); + + this._end(); + }; + + Request.prototype._setUploadTimeout = function () { + var self = this; // upload timeout it's wokrs only if deadline timeout is off + + if (this._uploadTimeout && !this._uploadTimeoutTimer) { + this._uploadTimeoutTimer = setTimeout(function () { + self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT'); + }, this._uploadTimeout); + } + }; // eslint-disable-next-line complexity + + + Request.prototype._end = function () { + if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called')); + var self = this; + this.xhr = request.getXHR(); + var xhr = this.xhr; + var data = this._formData || this._data; + + this._setTimeouts(); // state change + + + xhr.onreadystatechange = function () { + var readyState = xhr.readyState; + + if (readyState >= 2 && self._responseTimeoutTimer) { + clearTimeout(self._responseTimeoutTimer); + } + + if (readyState !== 4) { + return; + } // In IE9, reads to any property (e.g. status) off of an aborted XHR will + // result in the error "Could not complete the operation due to error c00c023f" + + + var status; + + try { + status = xhr.status; + } catch (_unused5) { + status = 0; + } + + if (!status) { + if (self.timedout || self._aborted) return; + return self.crossDomainError(); + } + + self.emit('end'); + }; // progress + + + var handleProgress = function handleProgress(direction, e) { + if (e.total > 0) { + e.percent = e.loaded / e.total * 100; + + if (e.percent === 100) { + clearTimeout(self._uploadTimeoutTimer); + } + } + + e.direction = direction; + self.emit('progress', e); + }; + + if (this.hasListeners('progress')) { + try { + xhr.addEventListener('progress', handleProgress.bind(null, 'download')); + + if (xhr.upload) { + xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload')); + } + } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist. + // Reported here: + // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context + } + } + + if (xhr.upload) { + this._setUploadTimeout(); + } // initiate request + + + try { + if (this.username && this.password) { + xhr.open(this.method, this.url, true, this.username, this.password); + } else { + xhr.open(this.method, this.url, true); + } + } catch (err) { + // see #1149 + return this.callback(err); + } // CORS + + + if (this._withCredentials) xhr.withCredentials = true; // body + + if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) { + // serialize stuff + var contentType = this._header['content-type']; + + var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : '']; + + if (!_serialize && isJSON(contentType)) { + _serialize = request.serialize['application/json']; + } + + if (_serialize) data = _serialize(data); + } // set header fields + + + for (var field in this.header) { + if (this.header[field] === null) continue; + if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]); + } + + if (this._responseType) { + xhr.responseType = this._responseType; + } // send stuff + + + this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing) + // We need null here if data is undefined + + xhr.send(typeof data === 'undefined' ? null : data); + }; + + request.agent = function () { + return new agentBase(); + }; + + ['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) { + agentBase.prototype[method.toLowerCase()] = function (url, fn) { + var req = new request.Request(method, url); + + this._setDefaults(req); + + if (fn) { + req.end(fn); + } + + return req; + }; + }); + agentBase.prototype.del = agentBase.prototype.delete; + /** + * GET `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + request.get = function (url, data, fn) { + var req = request('GET', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.query(data); + if (fn) req.end(fn); + return req; + }; + /** + * HEAD `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.head = function (url, data, fn) { + var req = request('HEAD', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.query(data); + if (fn) req.end(fn); + return req; + }; + /** + * OPTIONS query to `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.options = function (url, data, fn) { + var req = request('OPTIONS', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * DELETE `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + function del(url, data, fn) { + var req = request('DELETE', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + } + + request.del = del; + request.delete = del; + /** + * PATCH `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + request.patch = function (url, data, fn) { + var req = request('PATCH', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * POST `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.post = function (url, data, fn) { + var req = request('POST', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * PUT `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.put = function (url, data, fn) { + var req = request('PUT', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + + }); + var client_1 = client.Request; + + var byteLength_1 = byteLength; + var toByteArray_1 = toByteArray; + var fromByteArray_1 = fromByteArray; + + var lookup = []; + var revLookup = []; + var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array; + + var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; + for (var i = 0, len = code.length; i < len; ++i) { + lookup[i] = code[i]; + revLookup[code.charCodeAt(i)] = i; + } + + // Support decoding URL-safe base64 strings, as Node.js does. + // See: https://en.wikipedia.org/wiki/Base64#URL_applications + revLookup['-'.charCodeAt(0)] = 62; + revLookup['_'.charCodeAt(0)] = 63; + + function getLens (b64) { + var len = b64.length; + + if (len % 4 > 0) { + throw new Error('Invalid string. Length must be a multiple of 4') + } + + // Trim off extra bytes after placeholder bytes are found + // See: https://github.com/beatgammit/base64-js/issues/42 + var validLen = b64.indexOf('='); + if (validLen === -1) validLen = len; + + var placeHoldersLen = validLen === len + ? 0 + : 4 - (validLen % 4); + + return [validLen, placeHoldersLen] + } + + // base64 is 4/3 + up to two characters of the original data + function byteLength (b64) { + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen + } + + function _byteLength (b64, validLen, placeHoldersLen) { + return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen + } + + function toByteArray (b64) { + var tmp; + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + + var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen)); + + var curByte = 0; + + // if there are placeholders, only get up to the last complete 4 chars + var len = placeHoldersLen > 0 + ? validLen - 4 + : validLen; + + var i; + for (i = 0; i < len; i += 4) { + tmp = + (revLookup[b64.charCodeAt(i)] << 18) | + (revLookup[b64.charCodeAt(i + 1)] << 12) | + (revLookup[b64.charCodeAt(i + 2)] << 6) | + revLookup[b64.charCodeAt(i + 3)]; + arr[curByte++] = (tmp >> 16) & 0xFF; + arr[curByte++] = (tmp >> 8) & 0xFF; + arr[curByte++] = tmp & 0xFF; + } + + if (placeHoldersLen === 2) { + tmp = + (revLookup[b64.charCodeAt(i)] << 2) | + (revLookup[b64.charCodeAt(i + 1)] >> 4); + arr[curByte++] = tmp & 0xFF; + } + + if (placeHoldersLen === 1) { + tmp = + (revLookup[b64.charCodeAt(i)] << 10) | + (revLookup[b64.charCodeAt(i + 1)] << 4) | + (revLookup[b64.charCodeAt(i + 2)] >> 2); + arr[curByte++] = (tmp >> 8) & 0xFF; + arr[curByte++] = tmp & 0xFF; + } + + return arr + } + + function tripletToBase64 (num) { + return lookup[num >> 18 & 0x3F] + + lookup[num >> 12 & 0x3F] + + lookup[num >> 6 & 0x3F] + + lookup[num & 0x3F] + } + + function encodeChunk (uint8, start, end) { + var tmp; + var output = []; + for (var i = start; i < end; i += 3) { + tmp = + ((uint8[i] << 16) & 0xFF0000) + + ((uint8[i + 1] << 8) & 0xFF00) + + (uint8[i + 2] & 0xFF); + output.push(tripletToBase64(tmp)); + } + return output.join('') + } + + function fromByteArray (uint8) { + var tmp; + var len = uint8.length; + var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes + var parts = []; + var maxChunkLength = 16383; // must be multiple of 3 + + // go through the array every three bytes, we'll deal with trailing stuff later + for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { + parts.push(encodeChunk( + uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength) + )); + } + + // pad the end with zeros, but make sure to not forget the extra bytes + if (extraBytes === 1) { + tmp = uint8[len - 1]; + parts.push( + lookup[tmp >> 2] + + lookup[(tmp << 4) & 0x3F] + + '==' + ); + } else if (extraBytes === 2) { + tmp = (uint8[len - 2] << 8) + uint8[len - 1]; + parts.push( + lookup[tmp >> 10] + + lookup[(tmp >> 4) & 0x3F] + + lookup[(tmp << 2) & 0x3F] + + '=' + ); + } + + return parts.join('') + } + + var base64Js = { + byteLength: byteLength_1, + toByteArray: toByteArray_1, + fromByteArray: fromByteArray_1 + }; + + function padding(str) { + var mod = str.length % 4; + var pad = 4 - mod; + + if (mod === 0) { + return str; + } + + return str + new Array(1 + pad).join('='); + } + + function stringToByteArray(str) { + var arr = new Array(str.length); + for (var a = 0; a < str.length; a++) { + arr[a] = str.charCodeAt(a); + } + return arr; + } + + function byteArrayToString(array) { + var result = ''; + for (var i = 0; i < array.length; i++) { + result += String.fromCharCode(array[i]); + } + return result; + } + + function encode$1(str) { + return base64Js + .fromByteArray(stringToByteArray(str)) + .replace(/\+/g, '-') // Convert '+' to '-' + .replace(/\//g, '_'); // Convert '/' to '_' + } + + function decode$1(str) { + str = padding(str) + .replace(/-/g, '+') // Convert '-' to '+' + .replace(/_/g, '/'); // Convert '_' to '/' + + return byteArrayToString(base64Js.toByteArray(str)); + } + + var base64Url = { + encode: encode$1, + decode: decode$1 + }; + + var version = { raw: '9.14.3' }; + + var toString = Object.prototype.toString; + + function attribute(o, attr, type, text) { + type = type === 'array' ? 'object' : type; + if (o && typeof o[attr] !== type) { + throw new Error(text); + } + } + + function variable(o, type, text) { + if (typeof o !== type) { + throw new Error(text); + } + } + + function value(o, values, text) { + if (values.indexOf(o) === -1) { + throw new Error(text); + } + } + + function check(o, config, attributes) { + if (!config.optional || o) { + variable(o, config.type, config.message); + } + if (config.type === 'object' && attributes) { + var keys = Object.keys(attributes); + + for (var index = 0; index < keys.length; index++) { + var a = keys[index]; + if (!attributes[a].optional || o[a]) { + if (!attributes[a].condition || attributes[a].condition(o)) { + attribute(o, a, attributes[a].type, attributes[a].message); + if (attributes[a].values) { + value(o[a], attributes[a].values, attributes[a].value_message); + } + } + } + } + } + } + + /** + * Wrap `Array.isArray` Polyfill for IE9 + * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray + * + * @param {Array} array + * @private + */ + function isArray$3(array) { + if (this.supportsIsArray()) { + return Array.isArray(array); + } + + return toString.call(array) === '[object Array]'; + } + + function supportsIsArray() { + return Array.isArray != null; + } + + var assert = { + check: check, + attribute: attribute, + variable: variable, + value: value, + isArray: isArray$3, + supportsIsArray: supportsIsArray + }; + + /* eslint-disable no-continue */ + + function get() { + if (!Object.assign) { + return objectAssignPolyfill; + } + + return Object.assign; + } + + function objectAssignPolyfill(target) { + if (target === undefined || target === null) { + throw new TypeError('Cannot convert first argument to object'); + } + + var to = Object(target); + for (var i = 1; i < arguments.length; i++) { + var nextSource = arguments[i]; + if (nextSource === undefined || nextSource === null) { + continue; + } + + var keysArray = Object.keys(Object(nextSource)); + for ( + var nextIndex = 0, len = keysArray.length; + nextIndex < len; + nextIndex++ + ) { + var nextKey = keysArray[nextIndex]; + var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); + if (desc !== undefined && desc.enumerable) { + to[nextKey] = nextSource[nextKey]; + } + } + } + return to; + } + + var objectAssign = { + get: get, + objectAssignPolyfill: objectAssignPolyfill + }; + + /* eslint-disable no-param-reassign */ + + function pick(object, keys) { + return keys.reduce(function(prev, key) { + if (object[key]) { + prev[key] = object[key]; + } + return prev; + }, {}); + } + + function getKeysNotIn(obj, allowedKeys) { + var notAllowed = []; + for (var key in obj) { + if (allowedKeys.indexOf(key) === -1) { + notAllowed.push(key); + } + } + return notAllowed; + } + + function objectValues(obj) { + var values = []; + for (var key in obj) { + values.push(obj[key]); + } + return values; + } + + function extend() { + var params = objectValues(arguments); + params.unshift({}); + return objectAssign.get().apply(undefined, params); + } + + function merge$1(object, keys) { + return { + base: keys ? pick(object, keys) : object, + with: function(object2, keys2) { + object2 = keys2 ? pick(object2, keys2) : object2; + return extend(this.base, object2); + } + }; + } + + function blacklist(object, blacklistedKeys) { + return Object.keys(object).reduce(function(p, key) { + if (blacklistedKeys.indexOf(key) === -1) { + p[key] = object[key]; + } + return p; + }, {}); + } + + function camelToSnake(str) { + var newKey = ''; + var index = 0; + var code; + var wasPrevNumber = true; + var wasPrevUppercase = true; + + while (index < str.length) { + code = str.charCodeAt(index); + if ( + (!wasPrevUppercase && code >= 65 && code <= 90) || + (!wasPrevNumber && code >= 48 && code <= 57) + ) { + newKey += '_'; + newKey += str[index].toLowerCase(); + } else { + newKey += str[index].toLowerCase(); + } + wasPrevNumber = code >= 48 && code <= 57; + wasPrevUppercase = code >= 65 && code <= 90; + index++; + } + + return newKey; + } + + function snakeToCamel(str) { + var parts = str.split('_'); + return parts.reduce(function(p, c) { + return p + c.charAt(0).toUpperCase() + c.slice(1); + }, parts.shift()); + } + + function toSnakeCase(object, exceptions) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + exceptions = exceptions || []; + + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key; + p[newKey] = toSnakeCase(object[key]); + return p; + }, {}); + } + + function toCamelCase(object, exceptions, options) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + + exceptions = exceptions || []; + options = options || {}; + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key; + + p[newKey] = toCamelCase(object[newKey] || object[key], [], options); + + if (options.keepOriginal) { + p[key] = toCamelCase(object[key], [], options); + } + return p; + }, {}); + } + + function getLocationFromUrl(href) { + var match = href.match( + /^(https?:|file:|chrome-extension:)\/\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\?[^#]*|)(#.*|)$/ + ); + return ( + match && { + href: href, + protocol: match[1], + host: match[2], + hostname: match[3], + port: match[4], + pathname: match[5], + search: match[6], + hash: match[7] + } + ); + } + + function getOriginFromUrl(url) { + if (!url) { + return undefined; + } + var parsed = getLocationFromUrl(url); + if (!parsed) { + return null; + } + var origin = parsed.protocol + '//' + parsed.hostname; + if (parsed.port) { + origin += ':' + parsed.port; + } + return origin; + } + + function trim(options, key) { + var trimmed = extend(options); + if (options[key]) { + trimmed[key] = options[key].trim(); + } + return trimmed; + } + + function trimMultiple(options, keys) { + return keys.reduce(trim, options); + } + + function trimUserDetails(options) { + return trimMultiple(options, ['username', 'email', 'phoneNumber']); + } + + /** + * Updates the value of a property on the given object, using a deep path selector. + * @param {object} obj The object to set the property value on + * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3'] + * @param {any} value The value to set + */ + function updatePropertyOn(obj, path, value) { + if (typeof path === 'string') { + path = path.split('.'); + } + + var next = path[0]; + + if (obj.hasOwnProperty(next)) { + if (path.length === 1) { + obj[next] = value; + } else { + updatePropertyOn(obj[next], path.slice(1), value); + } + } + } + + var objectHelper = { + toSnakeCase: toSnakeCase, + toCamelCase: toCamelCase, + blacklist: blacklist, + merge: merge$1, + pick: pick, + getKeysNotIn: getKeysNotIn, + extend: extend, + getOriginFromUrl: getOriginFromUrl, + getLocationFromUrl: getLocationFromUrl, + trimUserDetails: trimUserDetails, + updatePropertyOn: updatePropertyOn + }; + + /* eslint-disable no-param-reassign */ + + // ------------------------------------------------ RequestWrapper + + function RequestWrapper(req) { + this.request = req; + this.method = req.method; + this.url = req.url; + this.body = req._data; + this.headers = req._header; + } + + RequestWrapper.prototype.abort = function() { + this.request.abort(); + }; + + RequestWrapper.prototype.getMethod = function() { + return this.method; + }; + + RequestWrapper.prototype.getBody = function() { + return this.body; + }; + + RequestWrapper.prototype.getUrl = function() { + return this.url; + }; + + RequestWrapper.prototype.getHeaders = function() { + return this.headers; + }; + + // ------------------------------------------------ RequestObj + + function RequestObj(req) { + this.request = req; + } + + RequestObj.prototype.set = function(key, value) { + this.request = this.request.set(key, value); + return this; + }; + + RequestObj.prototype.send = function(body) { + this.request = this.request.send(objectHelper.trimUserDetails(body)); + return this; + }; + + RequestObj.prototype.withCredentials = function() { + this.request = this.request.withCredentials(); + return this; + }; + + RequestObj.prototype.end = function(cb) { + this.request.end(cb); + return new RequestWrapper(this.request); + }; + + // ------------------------------------------------ RequestBuilder + + function RequestBuilder(options) { + this._sendTelemetry = + options._sendTelemetry === false ? options._sendTelemetry : true; + this._telemetryInfo = options._telemetryInfo || null; + this._timesToRetryFailedRequests = options._timesToRetryFailedRequests; + this.headers = options.headers || {}; + this._universalLoginPage = options.universalLoginPage; + } + + RequestBuilder.prototype.setCommonConfiguration = function( + ongoingRequest, + options + ) { + options = options || {}; + + if (this._timesToRetryFailedRequests > 0) { + ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests); + } + + if (options.noHeaders) { + return ongoingRequest; + } + + var headers = this.headers; + ongoingRequest = ongoingRequest.set('Content-Type', 'application/json'); + + var keys = Object.keys(this.headers); + + for (var a = 0; a < keys.length; a++) { + ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]); + } + + if (this._sendTelemetry) { + ongoingRequest = ongoingRequest.set( + 'Auth0-Client', + this.getTelemetryData() + ); + } + + return ongoingRequest; + }; + + RequestBuilder.prototype.getTelemetryData = function() { + var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js'; + var clientInfo = { name: telemetryName, version: version.raw }; + if (this._telemetryInfo) { + clientInfo = objectHelper.extend({}, this._telemetryInfo); + clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env); + clientInfo.env[telemetryName] = version.raw; + } + var jsonClientInfo = JSON.stringify(clientInfo); + return base64Url.encode(jsonClientInfo); + }; + + RequestBuilder.prototype.get = function(url, options) { + return new RequestObj(this.setCommonConfiguration(client.get(url), options)); + }; + + RequestBuilder.prototype.post = function(url, options) { + return new RequestObj( + this.setCommonConfiguration(client.post(url), options) + ); + }; + + RequestBuilder.prototype.patch = function(url, options) { + return new RequestObj( + this.setCommonConfiguration(client.patch(url), options) + ); + }; + + function redirect(url) { + getWindow().location = url; + } + + function getDocument() { + return getWindow().document; + } + + function getWindow() { + return window; + } + + function getOrigin() { + var location = getWindow().location; + var origin = location.origin; + + if (!origin) { + origin = objectHelper.getOriginFromUrl(location.href); + } + + return origin; + } + + var windowHelper = { + redirect: redirect, + getDocument: getDocument, + getWindow: getWindow, + getOrigin: getOrigin + }; + + function DummyStorage() {} + + DummyStorage.prototype.getItem = function() { + return null; + }; + + DummyStorage.prototype.removeItem = function() {}; + + DummyStorage.prototype.setItem = function() {}; + + var js_cookie = createCommonjsModule(function (module, exports) { + (function (factory) { + var registeredInModuleLoader; + { + module.exports = factory(); + registeredInModuleLoader = true; + } + if (!registeredInModuleLoader) { + var OldCookies = window.Cookies; + var api = window.Cookies = factory(); + api.noConflict = function () { + window.Cookies = OldCookies; + return api; + }; + } + }(function () { + function extend () { + var i = 0; + var result = {}; + for (; i < arguments.length; i++) { + var attributes = arguments[ i ]; + for (var key in attributes) { + result[key] = attributes[key]; + } + } + return result; + } + + function decode (s) { + return s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent); + } + + function init (converter) { + function api() {} + + function set (key, value, attributes) { + if (typeof document === 'undefined') { + return; + } + + attributes = extend({ + path: '/' + }, api.defaults, attributes); + + if (typeof attributes.expires === 'number') { + attributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5); + } + + // We're using "expires" because "max-age" is not supported by IE + attributes.expires = attributes.expires ? attributes.expires.toUTCString() : ''; + + try { + var result = JSON.stringify(value); + if (/^[\{\[]/.test(result)) { + value = result; + } + } catch (e) {} + + value = converter.write ? + converter.write(value, key) : + encodeURIComponent(String(value)) + .replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent); + + key = encodeURIComponent(String(key)) + .replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent) + .replace(/[\(\)]/g, escape); + + var stringifiedAttributes = ''; + for (var attributeName in attributes) { + if (!attributes[attributeName]) { + continue; + } + stringifiedAttributes += '; ' + attributeName; + if (attributes[attributeName] === true) { + continue; + } + + // Considers RFC 6265 section 5.2: + // ... + // 3. If the remaining unparsed-attributes contains a %x3B (";") + // character: + // Consume the characters of the unparsed-attributes up to, + // not including, the first %x3B (";") character. + // ... + stringifiedAttributes += '=' + attributes[attributeName].split(';')[0]; + } + + return (document.cookie = key + '=' + value + stringifiedAttributes); + } + + function get (key, json) { + if (typeof document === 'undefined') { + return; + } + + var jar = {}; + // To prevent the for loop in the first place assign an empty array + // in case there are no cookies at all. + var cookies = document.cookie ? document.cookie.split('; ') : []; + var i = 0; + + for (; i < cookies.length; i++) { + var parts = cookies[i].split('='); + var cookie = parts.slice(1).join('='); + + if (!json && cookie.charAt(0) === '"') { + cookie = cookie.slice(1, -1); + } + + try { + var name = decode(parts[0]); + cookie = (converter.read || converter)(cookie, name) || + decode(cookie); + + if (json) { + try { + cookie = JSON.parse(cookie); + } catch (e) {} + } + + jar[name] = cookie; + + if (key === name) { + break; + } + } catch (e) {} + } + + return key ? jar[key] : jar; + } + + api.set = set; + api.get = function (key) { + return get(key, false /* read as raw */); + }; + api.getJSON = function (key) { + return get(key, true /* read as json */); + }; + api.remove = function (key, attributes) { + set(key, '', extend(attributes, { + expires: -1 + })); + }; + + api.defaults = {}; + + api.withConverter = init; + + return api; + } + + return init(function () {}); + })); + }); + + function CookieStorage() {} + + CookieStorage.prototype.getItem = function(key) { + return js_cookie.get(key); + }; + + CookieStorage.prototype.removeItem = function(key) { + js_cookie.remove(key); + }; + + CookieStorage.prototype.setItem = function(key, value, options) { + var params = objectHelper.extend( + { + expires: 1 // 1 day + }, + options + ); + js_cookie.set(key, value, params); + }; + + /* eslint-disable no-console */ + + function Warn(options) { + this.disableWarnings = options.disableWarnings; + } + + Warn.prototype.warning = function(message) { + if (this.disableWarnings) { + return; + } + + console.warn(message); + }; + + function StorageHandler(options) { + this.warn = new Warn({}); + this.storage = new CookieStorage(); + if (options.__tryLocalStorageFirst !== true) { + return; + } + try { + // some browsers throw an error when trying to access localStorage + // when localStorage is disabled. + var localStorage = windowHelper.getWindow().localStorage; + if (localStorage) { + this.storage = localStorage; + } + } catch (e) { + this.warn.warning(e); + this.warn.warning("Can't use localStorage. Using CookieStorage instead."); + } + } + + StorageHandler.prototype.failover = function() { + if (this.storage instanceof DummyStorage) { + this.warn.warning('DummyStorage: ignore failover'); + return; + } else if (this.storage instanceof CookieStorage) { + this.warn.warning('CookieStorage: failing over DummyStorage'); + this.storage = new DummyStorage(); + } else { + this.warn.warning('LocalStorage: failing over CookieStorage'); + this.storage = new CookieStorage(); + } + }; + + StorageHandler.prototype.getItem = function(key) { + try { + return this.storage.getItem(key); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.getItem(key); + } + }; + + StorageHandler.prototype.removeItem = function(key) { + try { + return this.storage.removeItem(key); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.removeItem(key); + } + }; + + StorageHandler.prototype.setItem = function(key, value, options) { + try { + return this.storage.setItem(key, value, options); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.setItem(key, value, options); + } + }; + + function Storage(options) { + this.handler = new StorageHandler(options); + } + + Storage.prototype.getItem = function(key) { + var value = this.handler.getItem(key); + try { + return JSON.parse(value); + } catch (_) { + return value; + } + }; + Storage.prototype.removeItem = function(key) { + return this.handler.removeItem(key); + }; + Storage.prototype.setItem = function(key, value, options) { + var json = JSON.stringify(value); + return this.handler.setItem(key, json, options); + }; + + function SSODataStorage(options) { + this.storage = new Storage(options); + } + + SSODataStorage.prototype.set = function(connection, sub) { + var ssodata = { + lastUsedConnection: connection, + lastUsedSub: sub + }; + this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata)); + }; + SSODataStorage.prototype.get = function() { + var ssodata = this.storage.getItem('auth0.ssodata'); + if (!ssodata) { + return; + } + return JSON.parse(ssodata); + }; + + function buildResponse(error, description) { + return { + error: error, + errorDescription: description + }; + } + + function invalidToken(description) { + return buildResponse('invalid_token', description); + } + + var error = { + buildResponse: buildResponse, + invalidToken: invalidToken + }; + + function wrapCallback(cb, options) { + options = options || {}; + options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false; + + return function(err, data) { + var errObj; + + if (!err && !data) { + return cb(error.buildResponse('generic_error', 'Something went wrong')); + } + + if (!err && data.err) { + err = data.err; + data = null; + } + + if (!err && data.error) { + err = data; + data = null; + } + + if (err) { + errObj = { + original: err + }; + + objectHelper.updatePropertyOn( + errObj, + 'original.response.req._data.password', + '*****' + ); + + if (err.response && err.response.statusCode) { + errObj.statusCode = err.response.statusCode; + } + + if (err.response && err.response.statusText) { + errObj.statusText = err.response.statusText; + } + + if (err.response && err.response.body) { + err = err.response.body; + } + + if (err.err) { + err = err.err; + } + + errObj.code = + err.code || err.error || err.error_code || err.status || null; + + errObj.description = + err.errorDescription || + err.error_description || + err.description || + err.error || + err.details || + err.err || + null; + + if (options.forceLegacyError) { + errObj.error = errObj.code; + errObj.error_description = errObj.description; + } + + if (err.error_codes && err.error_details) { + errObj.errorDetails = { + codes: err.error_codes, + details: err.error_details + }; + } + + if (err.name) { + errObj.name = err.name; + } + + if (err.policy) { + errObj.policy = err.policy; + } + + return cb(errObj); + } + + if ( + data.type && + (data.type === 'text/html' || data.type === 'text/plain') + ) { + return cb(null, data.text); + } + + if (options.ignoreCasing) { + return cb(null, data.body || data); + } + + return cb( + null, + objectHelper.toCamelCase(data.body || data, [], { + keepOriginal: options.keepOriginalCasing + }) + ); + }; + } + + // For future reference:, + + var tokenParams = [ + // auth0 + 'realm', + 'audience', + 'otp', + // oauth2 + 'client_id', + 'client_secret', + 'redirect_uri', + 'scope', + 'code', + 'grant_type', + 'username', + 'password', + 'refresh_token', + 'assertion', + 'client_assertion', + 'client_assertion_type', + 'code_verifier' + ]; + + var authorizeParams = [ + // auth0 + 'connection', + 'connection_scope', + 'auth0Client', + 'owp', + 'device', + 'realm', + + 'protocol', + '_csrf', + '_intstate', + 'login_ticket', + + // oauth2 + 'client_id', + 'response_type', + 'response_mode', + 'redirect_uri', + 'audience', + 'scope', + 'state', + 'nonce', + 'display', + 'prompt', + 'screen_hint', + 'max_age', + 'ui_locales', + 'claims_locales', + 'id_token_hint', + 'login_hint', + 'acr_values', + 'claims', + 'registration', + 'request', + 'request_uri', + 'code_challenge', + 'code_challenge_method', + + // ADDITIONAL_PARAMETERS: + // https://auth0.com/docs/api/authentication?javascript#social + 'access_type', + 'display' + ]; + + function oauthAuthorizeParams(warn, params) { + var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams); + + if (notAllowed.length > 0) { + warn.warning( + 'Following parameters are not allowed on the `/authorize` endpoint: [' + + notAllowed.join(',') + + ']' + ); + } + + return params; + } + + function oauthTokenParams(warn, params) { + return objectHelper.pick(params, tokenParams); + } + + var parametersWhitelist = { + oauthTokenParams: oauthTokenParams, + oauthAuthorizeParams: oauthAuthorizeParams + }; + + var t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return "function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return "[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w());},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4);},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16));}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0;},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes;},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16];}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0;}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0;},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f);}(Math),r.SHA256);}),o=e(function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++;}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64);}),s=e(function(t,e){t.exports=i$1.enc.Hex;}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e));}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a;}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s;}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a;}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t;}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t;}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t);},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++;}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t);},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s;},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0;},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else {if(4!=e)return void this.fromRadix(t,e);i=2;}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB));}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t;},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s;},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp();},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else {var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s;}else {for(i+=this.s;r>=this.DB;i-=t.s;}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp();},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1);}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp();},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n);}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return (e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else {var a=n;n=o,o=a;}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return "-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else {if(4!=t)return this.toRadix(t);e=2;}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r);},T.prototype.sqrTo=function(t,e){t.squareTo(e);},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t);},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O);}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return "0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0));}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this);},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else {var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s;}else {for(i+=this.s;r>=this.DB;i+=t.s;}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp();},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp();},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e];}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return !1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2;}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else {for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s);}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a));}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i;}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E();}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16);}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return {alg:e,hash:t.substring(i)}}return []}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return !1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return -1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0];}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i();});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return {ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r;}),r(a());},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null);})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||"";}function A(t){this.name="TokenValidationError",this.message=t||"";}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return "number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A("ID token is required but missing"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A("ID token could not be decoded"),!1);var n=i.encoded.header+"."+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of "'+s+'" is not supported. Expected the ID token to be signed with "RS256".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A("Invalid ID token signature."));if(!f||"string"!=typeof f)return r(new A("Issuer (iss) claim must be a string present in the ID token",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected "'+g.issuer+'", found "'+f+'"'),!1);if(!u||"string"!=typeof u)return r(new A("Subject (sub) claim must be a string present in the ID token"),!1);if(!a||"string"!=typeof a&&!Array.isArray(a))return r(new A("Audience (aud) claim must be a string or array of strings present in the ID token"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected "'+g.audience+'" but was not one of "'+a.join(", ")+'"'));if("string"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected "'+g.audience+'" but found "'+a+'"'),!1);if(e){if(!v||"string"!=typeof v)return r(new A("Nonce (nonce) claim must be a string present in the ID token"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected "'+e+'", found "'+v+'"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)});},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11 + else if (ua.indexOf("Trident") > -1) { + var re = new RegExp("rv:([0-9]{2,2}[\.0-9]{0,})"); + if (re.exec(ua) !== null) { + rv = parseFloat(RegExp.$1); + } + } + + return rv >= 8; + } + + // checking Mobile Firefox (Fennec) + function isFennec() { + try { + // We must check for both XUL and Java versions of Fennec. Both have + // distinct UA strings. + var userAgent = navigator.userAgent; + return (userAgent.indexOf('Fennec/') != -1) || // XUL + (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java + } catch(e) {} + return false; + } + + // feature checking to see if this platform is supported at all + function isSupported() { + return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify && + window.JSON.parse && window.postMessage); + } + + // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30 + function extractOrigin(url) { + if (!/^https?:\/\//.test(url)) url = window.location.href; + var m = /^(https?:\/\/[\-_a-zA-Z\.0-9:]+)/.exec(url); + if (m) return m[1]; + return url; + } + + // find the relay iframe in the opener + function findRelay() { + var frames = window.opener.frames; + for (var i = frames.length - 1; i >= 0; i--) { + try { + if (frames[i].location.protocol === window.location.protocol && + frames[i].location.host === window.location.host && + frames[i].name === RELAY_FRAME_NAME) + { + return frames[i]; + } + } catch(e) { } + } + return; + } + + var isIE = isInternetExplorer(); + + if (isSupported()) { + /* General flow: + * 0. user clicks + * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM + * 2. caller opens window (with content from trusted domain) + * 3. window on opening adds a listener to 'message' + * (IE SPECIFIC) 4. window on opening finds iframe + * 5. window checks if iframe is "loaded" - has a 'doPost' function yet + * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller + * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready + * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event + * 6. caller upon reciept of 'ready', sends args + */ + return { + open: function(opts, cb) { + if (!cb) throw "missing required callback argument"; + + // test required options + var err; + if (!opts.url) err = "missing required 'url' parameter"; + if (!opts.relay_url) err = "missing required 'relay_url' parameter"; + if (err) setTimeout(function() { cb(err); }, 0); + + // supply default options + if (!opts.window_name) opts.window_name = null; + if (!opts.window_features || isFennec()) opts.window_features = undefined; + + // opts.params may be undefined + + var iframe; + + // sanity check, are url and relay_url the same origin? + var origin = opts.origin || extractOrigin(opts.url); + if (origin !== extractOrigin(opts.relay_url)) { + return setTimeout(function() { + cb('invalid arguments: origin of url and relay_url must match'); + }, 0); + } + + var messageTarget; + + if (isIE) { + // first we need to add a "relay" iframe to the document that's served + // from the target domain. We can postmessage into a iframe, but not a + // window + iframe = document.createElement("iframe"); + // iframe.setAttribute('name', framename); + iframe.setAttribute('src', opts.relay_url); + iframe.style.display = "none"; + iframe.setAttribute('name', RELAY_FRAME_NAME); + document.body.appendChild(iframe); + messageTarget = iframe.contentWindow; + } + + var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features); + if (opts.popup) { + w.location.href = opts.url; + } + + if (!messageTarget) messageTarget = w; + + // lets listen in case the window blows up before telling us + var closeInterval = setInterval(function() { + if (w && w.closed) { + cleanup(); + if (cb) { + cb('User closed the popup window'); + cb = null; + } + } + }, 500); + + var req = JSON.stringify({a: 'request', d: opts.params}); + + // cleanup on unload + function cleanup() { + if (iframe) document.body.removeChild(iframe); + iframe = undefined; + if (closeInterval) closeInterval = clearInterval(closeInterval); + removeListener(window, 'message', onMessage); + removeListener(window, 'unload', cleanup); + if (w) { + try { + w.close(); + } catch (securityViolation) { + // This happens in Opera 12 sometimes + // see https://github.com/mozilla/browserid/issues/1844 + messageTarget.postMessage(CLOSE_CMD, origin); + } + } + w = messageTarget = undefined; + } + + addListener(window, 'unload', cleanup); + + function onMessage(e) { + if (e.origin !== origin) { return; } + try { + var d = JSON.parse(e.data); + } catch(err) { + if (cb) { + return cb(err); + } else { + throw err; + } + } + + if (d.a === 'ready') { + messageTarget.postMessage(req, origin); + } else if (d.a === 'error') { + cleanup(); + if (cb) { + cb(d.d); + cb = null; + } + } else if (d.a === 'response') { + cleanup(); + if (cb) { + cb(null, d.d); + cb = null; + } + } + } + + addListener(window, 'message', onMessage); + + return { + originalPopup: w, + close: cleanup, + focus: function() { + if (w) { + try { + w.focus(); + } catch (e) { + // IE7 blows up here, do nothing + } + } + } + }; + }, + onOpen: function(cb) { + var o = "*"; + var msgTarget = isIE ? findRelay() : window.opener; + if (!msgTarget) throw "can't find relay frame"; + function doPost(msg) { + msg = JSON.stringify(msg); + if (isIE) msgTarget.doPost(msg, o); + else msgTarget.postMessage(msg, o); + } + + function onMessage(e) { + // only one message gets through, but let's make sure it's actually + // the message we're looking for (other code may be using + // postmessage) - we do this by ensuring the payload can + // be parsed, and it's got an 'a' (action) value of 'request'. + var d; + try { + d = JSON.parse(e.data); + } catch(err) { } + if (!d || d.a !== 'request') return; + removeListener(window, 'message', onMessage); + o = e.origin; + if (cb) { + // this setTimeout is critically important for IE8 - + // in ie8 sometimes addListener for 'message' can synchronously + // cause your callback to be invoked. awesome. + setTimeout(function() { + cb(o, d.d, function(r) { + cb = undefined; + doPost({a: 'response', d: r}); + }); + }, 0); + } + } + + function onDie(e) { + if (e.data === CLOSE_CMD) { + try { window.close(); } catch (o_O) {} + } + } + addListener(isIE ? msgTarget : window, 'message', onMessage); + addListener(isIE ? msgTarget : window, 'message', onDie); + + // we cannot post to our parent that we're ready before the iframe + // is loaded. (IE specific possible failure) + try { + doPost({a: "ready"}); + } catch(e) { + // this code should never be exectued outside IE + addListener(msgTarget, 'load', function(e) { + doPost({a: "ready"}); + }); + } + + // if window is unloaded and the client hasn't called cb, it's an error + var onUnload = function() { + try { + // IE8 doesn't like this... + removeListener(isIE ? msgTarget : window, 'message', onDie); + } catch (ohWell) { } + if (cb) doPost({ a: 'error', d: 'client closed window' }); + cb = undefined; + // explicitly close the window, in case the client is trying to reload or nav + try { window.close(); } catch (e) { } + }; + addListener(window, 'unload', onUnload); + return { + detach: function() { + removeListener(window, 'unload', onUnload); + } + }; + } + }; + } else { + return { + open: function(url, winopts, arg, cb) { + setTimeout(function() { cb("unsupported browser"); }, 0); + }, + onOpen: function(cb) { + setTimeout(function() { cb("unsupported browser"); }, 0); + } + }; + } + })(); + + if ( module.exports) { + module.exports = WinChan; + } + }); + + // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30 + function extractOrigin(url) { + if (!/^https?:\/\//.test(url)) url = window.location.href; + var m = /^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url); + if (m) return m[1]; + return url; + } + + var urlHelper = { + extractOrigin: extractOrigin + }; + + /* eslint-disable no-restricted-syntax */ + + function PopupHandler() { + this._current_popup = null; + } + + PopupHandler.prototype.calculatePosition = function(options) { + var width = options.width || 500; + var height = options.height || 600; + var _window = windowHelper.getWindow(); + + var screenX = + typeof _window.screenX !== 'undefined' + ? _window.screenX + : _window.screenLeft; + var screenY = + typeof _window.screenY !== 'undefined' + ? _window.screenY + : _window.screenTop; + + var outerWidth = + typeof _window.outerWidth !== 'undefined' + ? _window.outerWidth + : _window.document.body.clientWidth; + + var outerHeight = + typeof _window.outerHeight !== 'undefined' + ? _window.outerHeight + : _window.document.body.clientHeight; + + var left = options.left || screenX + (outerWidth - width) / 2; + var top = options.top || screenY + (outerHeight - height) / 2; + + return { width: width, height: height, left: left, top: top }; + }; + + PopupHandler.prototype.preload = function(options) { + var _this = this; + var _window = windowHelper.getWindow(); + var popupPosition = this.calculatePosition(options.popupOptions || {}); + var popupOptions = objectHelper + .merge(popupPosition) + .with(options.popupOptions); + var url = options.url || 'about:blank'; + var windowFeatures = lib.stringify(popupOptions, { + encode: false, + delimiter: ',' + }); + + if (this._current_popup && !this._current_popup.closed) { + return this._current_popup; + } + + this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures); + + this._current_popup.kill = function() { + this.close(); + _this._current_popup = null; + }; + + return this._current_popup; + }; + + PopupHandler.prototype.load = function(url, relayUrl, options, cb) { + var _this = this; + var popupPosition = this.calculatePosition(options.popupOptions || {}); + var popupOptions = objectHelper + .merge(popupPosition) + .with(options.popupOptions); + + var winchanOptions = objectHelper + .merge({ + url: url, + relay_url: relayUrl, + window_features: lib.stringify(popupOptions, { + delimiter: ',', + encode: false + }), + popup: this._current_popup + }) + .with(options); + + var popup = winchan.open(winchanOptions, function(err, data) { + // Ignores messages sent by browser extensions. + if (err && err.name === 'SyntaxError') { + return; + } + _this._current_popup = null; + return cb(err, data); + }); + + popup.focus(); + + return popup; + }; + + function Popup(webAuth, options) { + this.baseOptions = options; + this.baseOptions.popupOrigin = options.popupOrigin; + this.client = webAuth.client; + this.webAuth = webAuth; + + this.transactionManager = new TransactionManager(this.baseOptions); + this.crossOriginAuthentication = new CrossOriginAuthentication( + webAuth, + this.baseOptions + ); + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + } + + /** + * Returns a new instance of the popup handler + * + * @method buildPopupHandler + * @private + */ + Popup.prototype.buildPopupHandler = function() { + var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler'); + + if (pluginHandler) { + return pluginHandler.getPopupHandler(); + } + + return new PopupHandler(); + }; + + /** + * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser. + * + * @method preload + * @param {Object} options receives the window height and width and any other window feature to be sent to window.open + */ + Popup.prototype.preload = function(options) { + options = options || {}; + + var popup = this.buildPopupHandler(); + + popup.preload(options); + return popup; + }; + + /** + * Internal use. + * + * @method getPopupHandler + * @private + */ + Popup.prototype.getPopupHandler = function(options, preload) { + if (options.popupHandler) { + return options.popupHandler; + } + + if (preload) { + return this.preload(options); + } + + return this.buildPopupHandler(); + }; + + /** + * Handles the popup logic for the callback page. + * + * @method callback + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @see {@link parseHash} + */ + Popup.prototype.callback = function(options) { + var _this = this; + var theWindow = windowHelper.getWindow(); + options = options || {}; + var originUrl = + options.popupOrigin || + this.baseOptions.popupOrigin || + windowHelper.getOrigin(); + + /* + in IE 11, there's a bug that makes window.opener return undefined. + The callback page will still call `popup.callback()` which will run this method + in the relay page. WinChan expects the relay page to have a global `doPost` function, + which will be called with the response. + + IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/ + */ + if (!theWindow.opener) { + theWindow.doPost = function(msg) { + if (theWindow.parent) { + theWindow.parent.postMessage(msg, originUrl); + } + }; + return; + } + + winchan.onOpen(function(popupOrigin, r, cb) { + if (popupOrigin !== originUrl) { + return cb({ + error: 'origin_mismatch', + error_description: + "The popup's origin (" + + popupOrigin + + ') should match the `popupOrigin` parameter (' + + originUrl + + ').' + }); + } + _this.webAuth.parseHash(options || {}, function(err, data) { + return cb(err || data); + }); + }); + }; + + /** + * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`. + * + * @method authorize + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response. + * @param {authorizeCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + Popup.prototype.authorize = function(options, cb) { + var popup; + var url; + var relayUrl; + var popOpts = {}; + + var pluginHandler = this.baseOptions.plugins.get('popup.authorize'); + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'scope', + 'domain', + 'audience', + 'tenant', + 'responseType', + 'redirectUri', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(objectHelper.blacklist(options, ['popupHandler'])); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + // the relay page should not be necessary as long it happens in the same domain + // (a redirectUri shoul be provided). It is necessary when using OWP + relayUrl = urlJoin(this.baseOptions.rootUrl, 'relay.html'); + + // if a owp is enabled, it should use the owp flag + if (options.owp) { + // used by server to render the relay page instead of sending the chunk in the + // url to the callback + params.owp = true; + } else { + popOpts.origin = urlHelper.extractOrigin(params.redirectUri); + relayUrl = params.redirectUri; + } + + if (options.popupOptions) { + popOpts.popupOptions = objectHelper.pick(options.popupOptions, [ + 'width', + 'height', + 'top', + 'left' + ]); + } + + if (pluginHandler) { + params = pluginHandler.processParams(params); + } + + params = this.transactionManager.process(params); + params.scope = params.scope || 'openid profile email'; + delete params.domain; + + url = this.client.buildAuthorizeUrl(params); + + popup = this.getPopupHandler(options); + + return popup.load( + url, + relayUrl, + popOpts, + wrapCallback(cb, { keepOriginalCasing: true }) + ); + }; + + /** + * Performs authentication with username/email and password with a database connection inside a new window + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link login}. + * + * @method loginWithCredentials + * @param {Object} options + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token` + * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`. + * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email` + * @param {credentialsCallback} cb + */ + Popup.prototype.loginWithCredentials = function(options, cb) { + options.realm = options.realm || options.connection; + options.popup = true; + options = objectHelper + .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce']) + .with(objectHelper.blacklist(options, ['popupHandler', 'connection'])); + options = this.transactionManager.process(options); + this.crossOriginAuthentication.login(options, cb); + }; + + /** + * Verifies the passwordless TOTP and redirects to finish the passwordless transaction + * + * @method passwordlessVerify + * @param {Object} options + * @param {String} options.type `sms` or `email` + * @param {String} options.phoneNumber only if type = sms + * @param {String} options.email only if type = email + * @param {String} options.connection the connection name + * @param {String} options.verificationCode the TOTP code + * @param {Function} cb + */ + Popup.prototype.passwordlessVerify = function(options, cb) { + var _this = this; + return this.client.passwordless.verify( + objectHelper.blacklist(options, ['popupHandler']), + function(err) { + if (err) { + return cb(err); + } + + options.username = options.phoneNumber || options.email; + options.password = options.verificationCode; + + delete options.email; + delete options.phoneNumber; + delete options.verificationCode; + delete options.type; + + _this.client.loginWithResourceOwner(options, cb); + } + ); + }; + + /** + * Signs up a new user and automatically logs the user in after the signup. + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link signupAndAuthorize}. + * + * @method signupAndLogin + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {credentialsCallback} cb + */ + Popup.prototype.signupAndLogin = function(options, cb) { + var _this = this; + + return this.client.dbConnection.signup(options, function(err) { + if (err) { + return cb(err); + } + _this.loginWithCredentials(options, cb); + }); + }; + + function SilentAuthenticationHandler(options) { + this.authenticationUrl = options.authenticationUrl; + this.timeout = options.timeout || 60 * 1000; + this.handler = null; + this.postMessageDataType = options.postMessageDataType || false; + + // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually + this.postMessageOrigin = + options.postMessageOrigin || + windowHelper.getWindow().location.origin || + windowHelper.getWindow().location.protocol + + '//' + + windowHelper.getWindow().location.hostname + + (windowHelper.getWindow().location.port + ? ':' + windowHelper.getWindow().location.port + : ''); + } + + SilentAuthenticationHandler.create = function(options) { + return new SilentAuthenticationHandler(options); + }; + + SilentAuthenticationHandler.prototype.login = function( + usePostMessage, + callback + ) { + this.handler = new IframeHandler({ + auth0: this.auth0, + url: this.authenticationUrl, + eventListenerType: usePostMessage ? 'message' : 'load', + callback: this.getCallbackHandler(callback, usePostMessage), + timeout: this.timeout, + eventValidator: this.getEventValidator(), + timeoutCallback: function() { + callback( + null, + '#error=timeout&error_description=Timeout+during+authentication+renew.' + ); + }, + usePostMessage: usePostMessage || false + }); + + this.handler.init(); + }; + + SilentAuthenticationHandler.prototype.getEventValidator = function() { + var _this = this; + return { + isValid: function(eventData) { + switch (eventData.event.type) { + case 'message': + // Message must come from the expected origin and iframe window. + if ( + eventData.event.origin !== _this.postMessageOrigin || + eventData.event.source !== _this.handler.iframe.contentWindow + ) { + return false; + } + + // Default behaviour, return all message events from the iframe. + if (_this.postMessageDataType === false) { + return true; + } + + return ( + eventData.event.data.type && + eventData.event.data.type === _this.postMessageDataType + ); + + case 'load': + if ( + eventData.sourceObject.contentWindow.location.protocol === 'about:' + ) { + // Chrome is automatically loading the about:blank page, we ignore this. + return false; + } + // Fall through to default + default: + return true; + } + } + }; + }; + + SilentAuthenticationHandler.prototype.getCallbackHandler = function( + callback, + usePostMessage + ) { + return function(eventData) { + var callbackValue; + if (!usePostMessage) { + callbackValue = eventData.sourceObject.contentWindow.location.hash; + } else if ( + typeof eventData.event.data === 'object' && + eventData.event.data.hash + ) { + callbackValue = eventData.event.data.hash; + } else { + callbackValue = eventData.event.data; + } + callback(null, callbackValue); + }; + }; + + function UsernamePassword(options) { + this.baseOptions = options; + this.request = new RequestBuilder(options); + this.transactionManager = new TransactionManager(this.baseOptions); + } + + UsernamePassword.prototype.login = function(options, cb) { + var url; + var body; + + url = urlJoin(this.baseOptions.rootUrl, 'usernamepassword', 'login'); + + options.username = options.username || options.email; // eslint-disable-line + + options = objectHelper.blacklist(options, ['email']); // eslint-disable-line + + body = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'tenant', + 'responseType', + 'responseMode', + 'scope', + 'audience' + ]) + .with(options); + body = this.transactionManager.process(body); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + UsernamePassword.prototype.callback = function(formHtml) { + var div; + var form; + var _document = windowHelper.getDocument(); + + div = _document.createElement('div'); + div.innerHTML = formHtml; + form = _document.body.appendChild(div).children[0]; + + form.submit(); + }; + + function HostedPages(client, options) { + this.baseOptions = options; + this.client = client; + this.baseOptions.universalLoginPage = true; + this.request = new RequestBuilder(this.baseOptions); + + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + } + + /** + * @callback credentialsCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the AuthN request + * @param {String} result.accessToken token that can be used with {@link userinfo} + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + */ + + /** + * Performs authentication with username/email and password with a database connection + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link login}. + * + * @method login + * @param {Object} options + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token` + * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment` + * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email` + * @param {credentialsCallback} cb + */ + HostedPages.prototype.login = function(options, cb) { + if (windowHelper.getWindow().location.host !== this.baseOptions.domain) { + throw new Error( + 'This method is meant to be used only inside the Universal Login Page.' + ); + } + var usernamePassword; + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'tenant', + 'responseType', + 'responseMode', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + usernamePassword = new UsernamePassword(this.baseOptions); + return usernamePassword.login(params, function(err, data) { + if (err) { + return cb(err); + } + return usernamePassword.callback(data); + }); + }; + + /** + * Signs up a new user and automatically logs the user in after the signup. + * + * @method signupAndLogin + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {credentialsCallback} cb + */ + HostedPages.prototype.signupAndLogin = function(options, cb) { + var _this = this; + return _this.client.client.dbConnection.signup(options, function(err) { + if (err) { + return cb(err); + } + return _this.login(options, cb); + }); + }; + + HostedPages.prototype.getSSOData = function(withActiveDirectories, cb) { + var url; + var params = ''; + + if (typeof withActiveDirectories === 'function') { + cb = withActiveDirectories; + withActiveDirectories = false; + } + + assert.check(withActiveDirectories, { + type: 'boolean', + message: 'withActiveDirectories parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + if (withActiveDirectories) { + params = + '?' + + lib.stringify({ + ldaps: 1, + client_id: this.baseOptions.clientID + }); + } + + url = urlJoin(this.baseOptions.rootUrl, 'user', 'ssodata', params); + + return this.request + .get(url, { noHeaders: true }) + .withCredentials() + .end(wrapCallback(cb)); + }; + + // eslint-disable-next-line no-unused-vars + + var noop = function () { }; + + var defaults$2 = { + lang: 'en', + templates: { + 'auth0': function (challenge) { + var message = challenge.type === 'code' ? + 'Enter the code shown above' : + 'Solve the formula shown above'; + return '
\n' + + ' \n' + + ' \n' + + '
\n' + + ''; + } + , + 'recaptcha_v2': function () { + return '
'; + } + , + 'error': function () { + return '
Error getting the bot detection challenge. Please contact the system administrator.
' + } + } + }; + + function handleAuth0Provider(element, options, challenge, load) { + element.innerHTML = options.templates[challenge.provider](challenge); + element.querySelector('.captcha-reload').addEventListener('click', function (e) { + e.preventDefault(); + load(); + }); + } + + function injectRecaptchaScript(element, lang, callback) { + var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001); + window[callbackName] = function () { + delete window[callbackName]; + callback(); + }; + var script = window.document.createElement('script'); + script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName; + script.async = true; + window.document.body.appendChild(script); + } + + function handleRecaptchaProvider(element, options, challenge) { + var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid'); + + function setValue(value) { + var input = element.querySelector('input[name="captcha"]'); + input.value = value || ''; + } + + if (widgetId) { + setValue(); + window.grecaptcha.reset(widgetId); + return; + } + + element.innerHTML = options.templates[challenge.provider](challenge); + + var recaptchaDiv = element.querySelector('.recaptcha'); + + injectRecaptchaScript(element, options.lang, function () { + widgetId = window.grecaptcha.render(recaptchaDiv, { + callback: setValue, + 'expired-callback': function () { setValue(); }, + 'error-callback': function () { setValue(); }, + sitekey: challenge.siteKey + }); + element.setAttribute('data-wid', widgetId); + }); + } + + + /** + * + * Renders the captcha challenge in the provided element. + * + * @param {Authentication} auth0Client The challenge response from the authentication server + * @param {HTMLElement} element The element where the captcha needs to be rendered + * @param {Object} options The configuration options for the captcha + * @param {Object} [options.templates] An object containaing templates for each captcha provider + * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string + * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string + * @param {String} [options.lang=en] the ISO code of the language for recaptcha* + * @param {Function} [callback] an optional callback function + */ + function render(auth0Client, element, options, callback) { + options = objectHelper.merge(defaults$2).with(options || {}); + + function load(done) { + done = done || noop; + auth0Client.getChallenge(function (err, challenge) { + if (err) { + element.innerHTML = options.templates.error(err); + return done(err); + } + if (!challenge.required) { + element.style.display = 'none'; + element.innerHTML = ''; + return; + } + element.style.display = ''; + if (challenge.provider === 'auth0') { + handleAuth0Provider(element, options, challenge, load); + } else if (challenge.provider === 'recaptcha_v2') { + handleRecaptchaProvider(element, options, challenge); + } + done(); + }); + } + + function getValue() { + var captchaInput = element.querySelector('input[name="captcha"]'); + if (!captchaInput) { return; } + return captchaInput.value; + } + + load(callback); + + return { + reload: load, + getValue: getValue + }; + } + + var captcha = { render: render }; + + function defaultClock() { + return new Date(); + } + + /** + * Handles all the browser's AuthN/AuthZ flows + * @constructor + * @param {Object} options + * @param {String} options.domain your Auth0 domain + * @param {String} options.clientID the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds. + * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server. + * @param {Array} [options.plugins] + * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js} + * @see {@link https://auth0.com/docs/api/authentication} + */ + function WebAuth(options) { + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + clientID: { type: 'string', message: 'clientID option is required' }, + responseType: { + optional: true, + type: 'string', + message: 'responseType is not valid' + }, + responseMode: { + optional: true, + type: 'string', + message: 'responseMode is not valid' + }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri is not valid' + }, + scope: { optional: true, type: 'string', message: 'scope is not valid' }, + audience: { + optional: true, + type: 'string', + message: 'audience is not valid' + }, + popupOrigin: { + optional: true, + type: 'string', + message: 'popupOrigin is not valid' + }, + leeway: { + optional: true, + type: 'number', + message: 'leeway is not valid' + }, + plugins: { + optional: true, + type: 'array', + message: 'plugins is not valid' + }, + maxAge: { + optional: true, + type: 'number', + message: 'maxAge is not valid' + }, + _disableDeprecationWarnings: { + optional: true, + type: 'boolean', + message: '_disableDeprecationWarnings option is not valid' + }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + }, + _timesToRetryFailedRequests: { + optional: true, + type: 'number', + message: '_timesToRetryFailedRequests option is not valid' + } + } + ); + + if (options.overrides) { + assert.check( + options.overrides, + { type: 'object', message: 'overrides option is not valid' }, + { + __tenant: { + optional: true, + type: 'string', + message: '__tenant option is required' + }, + __token_issuer: { + optional: true, + type: 'string', + message: '__token_issuer option is required' + }, + __jwks_uri: { + optional: true, + type: 'string', + message: '__jwks_uri is required' + } + } + ); + } + /* eslint-enable */ + + this.baseOptions = options; + this.baseOptions.plugins = new PluginHandler( + this, + this.baseOptions.plugins || [] + ); + + this.baseOptions._sendTelemetry = + this.baseOptions._sendTelemetry === false + ? this.baseOptions._sendTelemetry + : true; + + this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests + ? parseInt(options._timesToRetryFailedRequests, 0) + : 0; + + this.baseOptions.tenant = + (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) || + this.baseOptions.domain.split('.')[0]; + + this.baseOptions.token_issuer = + (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) || + 'https://' + this.baseOptions.domain + '/'; + + this.baseOptions.jwksURI = + this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri; + + this.transactionManager = new TransactionManager(this.baseOptions); + + this.client = new Authentication(this.baseOptions); + this.redirect = new Redirect(this, this.baseOptions); + this.popup = new Popup(this, this.baseOptions); + this.crossOriginAuthentication = new CrossOriginAuthentication( + this, + this.baseOptions + ); + this.webMessageHandler = new WebMessageHandler(this); + this._universalLogin = new HostedPages(this, this.baseOptions); + this.ssodataStorage = new SSODataStorage(this.baseOptions); + } + + /** + * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize} + * + * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed + * by the `/.well-known/jwks.json` endpoint of your account. + * Tokens signed with the HS256 algorithm cannot be properly validated. + * Instead, a call to {@link userInfo} will be made with the parsed `access_token`. + * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback. + * Tokens signed with other algorithms will not be accepted. + * + * @method parseHash + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType. + * @param {authorizeCallback} cb + */ + WebAuth.prototype.parseHash = function(options, cb) { + var parsedQs; + var err; + + if (!cb && typeof options === 'function') { + cb = options; + options = {}; + } else { + options = options || {}; + } + + var _window = windowHelper.getWindow(); + + var hashStr = + options.hash === undefined ? _window.location.hash : options.hash; + hashStr = hashStr.replace(/^#?\/?/, ''); + + parsedQs = lib.parse(hashStr); + + if (parsedQs.hasOwnProperty('error')) { + err = error.buildResponse(parsedQs.error, parsedQs.error_description); + + if (parsedQs.state) { + err.state = parsedQs.state; + } + + return cb(err); + } + + if ( + !parsedQs.hasOwnProperty('access_token') && + !parsedQs.hasOwnProperty('id_token') && + !parsedQs.hasOwnProperty('refresh_token') + ) { + return cb(null, null); + } + var responseTypes = ( + this.baseOptions.responseType || + options.responseType || + '' + ).split(' '); + if ( + responseTypes.length > 0 && + responseTypes.indexOf('token') !== -1 && + !parsedQs.hasOwnProperty('access_token') + ) { + return cb( + error.buildResponse( + 'invalid_hash', + 'response_type contains `token`, but the parsed hash does not contain an `access_token` property' + ) + ); + } + if ( + responseTypes.length > 0 && + responseTypes.indexOf('id_token') !== -1 && + !parsedQs.hasOwnProperty('id_token') + ) { + return cb( + error.buildResponse( + 'invalid_hash', + 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property' + ) + ); + } + return this.validateAuthenticationResponse(options, parsedQs, cb); + }; + + /** + * Validates an Auth response from a Auth flow started with {@link authorize} + * + * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed + * by the `/.well-known/jwks.json` endpoint of your account. + * Tokens signed with the HS256 algorithm cannot be properly validated. + * Instead, a call to {@link userInfo} will be made with the parsed `access_token`. + * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback. + * Tokens signed with other algorithms will not be accepted. + * + * @method validateAuthenticationResponse + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @param {Object} parsedHash an object that represents the parsed hash + * @param {authorizeCallback} cb + */ + WebAuth.prototype.validateAuthenticationResponse = function( + options, + parsedHash, + cb + ) { + var _this = this; + options.__enableIdPInitiatedLogin = + options.__enableIdPInitiatedLogin || options.__enableImpersonation; + var state = parsedHash.state; + var transaction = this.transactionManager.getStoredTransaction(state); + var transactionState = + options.state || (transaction && transaction.state) || null; + + var transactionStateMatchesState = transactionState === state; + var shouldBypassStateChecking = + !state && !transactionState && options.__enableIdPInitiatedLogin; + + if (!shouldBypassStateChecking && !transactionStateMatchesState) { + return cb({ + error: 'invalid_token', + errorDescription: '`state` does not match.' + }); + } + var transactionNonce = + options.nonce || (transaction && transaction.nonce) || null; + + var appState = options.state || (transaction && transaction.appState) || null; + + var callback = function(err, payload) { + if (err) { + return cb(err); + } + if (transaction && transaction.lastUsedConnection) { + var sub; + if (payload) { + sub = payload.sub; + } + _this.ssodataStorage.set(transaction.lastUsedConnection, sub); + } + return cb(null, buildParseHashResponse(parsedHash, appState, payload)); + }; + + if (!parsedHash.id_token) { + return callback(null, null); + } + return this.validateToken(parsedHash.id_token, transactionNonce, function( + validationError, + payload + ) { + if (!validationError) { + if (!parsedHash.access_token) { + return callback(null, payload); + } + // id_token's generated by non-oidc applications don't have at_hash + if (!payload.at_hash) { + return callback(null, payload); + } + // here we're absolutely sure that the id_token's alg is RS256 + // and that the id_token is valid, so we can check the access_token + return new k().validateAccessToken( + parsedHash.access_token, + 'RS256', + payload.at_hash, + function(err) { + if (err) { + return callback(error.invalidToken(err.message)); + } + return callback(null, payload); + } + ); + } + + if ( + validationError.error !== 'invalid_token' || + (validationError.errorDescription && + validationError.errorDescription.indexOf( + 'Nonce (nonce) claim value mismatch in the ID token' + ) > -1) + ) { + return callback(validationError); + } + + // if it's an invalid_token error, decode the token + var decodedToken = new k().decode(parsedHash.id_token); + + // if the alg is not HS256, return the raw error + if (decodedToken.header.alg !== 'HS256') { + return callback(validationError); + } + + if ((decodedToken.payload.nonce || null) !== transactionNonce) { + return callback({ + error: 'invalid_token', + errorDescription: + 'Nonce (nonce) claim value mismatch in the ID token; expected "' + + transactionNonce + + '", found "' + + decodedToken.payload.nonce + + '"' + }); + } + + if (!parsedHash.access_token) { + var noAccessTokenError = { + error: 'invalid_token', + description: + 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token' + }; + return callback(noAccessTokenError); + } + + // if the alg is HS256, use the /userinfo endpoint to build the payload + return _this.client.userInfo(parsedHash.access_token, function( + errUserInfo, + profile + ) { + // if the /userinfo request fails, use the validationError instead + if (errUserInfo) { + return callback(errUserInfo); + } + return callback(null, profile); + }); + }); + }; + + function buildParseHashResponse(qsParams, appState, token) { + return { + accessToken: qsParams.access_token || null, + idToken: qsParams.id_token || null, + idTokenPayload: token || null, + appState: appState || null, + refreshToken: qsParams.refresh_token || null, + state: qsParams.state || null, + expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null, + tokenType: qsParams.token_type || null, + scope: qsParams.scope || null + }; + } + + /** + * @callback validateTokenCallback + * @param {Error} [err] error returned by while validating the token + * @param {Object} [payload] claims stored in the token + */ + + /** + * Decodes the a JWT and verifies its nonce value + * + * @method validateToken + * @private + * @param {String} token + * @param {String} nonce + * @param {validateTokenCallback} cb + */ + WebAuth.prototype.validateToken = function(token, nonce, cb) { + var verifier = new k({ + issuer: this.baseOptions.token_issuer, + jwksURI: this.baseOptions.jwksURI, + audience: this.baseOptions.clientID, + leeway: this.baseOptions.leeway || 60, + maxAge: this.baseOptions.maxAge, + __clock: this.baseOptions.__clock || defaultClock + }); + + verifier.verify(token, nonce, function(err, payload) { + if (err) { + return cb(error.invalidToken(err.message)); + } + + cb(null, payload); + }); + }; + + /** + * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session. + * This method requires that all Auth is performed with {@link authorize} + * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method. + * + * @method renewAuth + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback. + * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy. + * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration. + * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed + * @param {authorizeCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + WebAuth.prototype.renewAuth = function(options, cb) { + var handler; + var usePostMessage = !!options.usePostMessage; + var postMessageDataType = options.postMessageDataType || false; + var postMessageOrigin = + options.postMessageOrigin || windowHelper.getWindow().origin; + var timeout = options.timeout; + var _this = this; + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'responseType', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + params.responseType = params.responseType || 'token'; + params.responseMode = params.responseMode || 'fragment'; + params = this.transactionManager.process(params); + + assert.check(params, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + params.prompt = 'none'; + + params = objectHelper.blacklist(params, [ + 'usePostMessage', + 'tenant', + 'postMessageDataType', + 'postMessageOrigin' + ]); + + handler = SilentAuthenticationHandler.create({ + authenticationUrl: this.client.buildAuthorizeUrl(params), + postMessageDataType: postMessageDataType, + postMessageOrigin: postMessageOrigin, + timeout: timeout + }); + + handler.login(usePostMessage, function(err, hash) { + if (typeof hash === 'object') { + // hash was already parsed, so we just return it. + // it's here to be backwards compatible and should be removed in the next major version. + return cb(err, hash); + } + _this.parseHash({ hash: hash }, cb); + }); + }; + + /** + * Renews an existing session on Auth0's servers using `response_mode=web_message` + * + * @method checkSession + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration. + * @param {checkSessionCallback} cb + * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens} + */ + WebAuth.prototype.checkSession = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + if (params.responseType === 'code') { + return cb({ + error: 'error', + error_description: "responseType can't be `code`" + }); + } + + if (!options.nonce) { + params = this.transactionManager.process(params); + } + + if (!params.redirectUri) { + return cb({ + error: 'error', + error_description: "redirectUri can't be empty" + }); + } + + assert.check(params, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + params = objectHelper.blacklist(params, [ + 'usePostMessage', + 'tenant', + 'postMessageDataType' + ]); + this.webMessageHandler.run( + params, + wrapCallback(cb, { forceLegacyError: true, ignoreCasing: true }) + ); + }; + + /** + * Request an email with instruction to change a user's password + * + * @method changePassword + * @param {Object} options + * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0 + * @param {String} options.connection name of the connection where the user was created + * @param {changePasswordCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#change-password} + */ + WebAuth.prototype.changePassword = function(options, cb) { + return this.client.dbConnection.changePassword(options, cb); + }; + + /** + * Starts a passwordless authentication transaction. + * + * @method passwordlessStart + * @param {Object} options + * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid + * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email` + * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber` + * @param {String} options.connection name of the passwordless connection + * @param {Object} [options.authParams] additional Auth parameters when using `link` + * @param {Function} cb + * @see {@link https://auth0.com/docs/api/authentication#passwordless} + */ + WebAuth.prototype.passwordlessStart = function(options, cb) { + var authParams = objectHelper + .merge(this.baseOptions, [ + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options.authParams); + + options.authParams = this.transactionManager.process(authParams); + return this.client.passwordless.start(options, cb); + }; + + /** + * Creates a new user in a Auth0 Database connection + * + * @method signup + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {signUpCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + */ + WebAuth.prototype.signup = function(options, cb) { + return this.client.dbConnection.signup(options, cb); + }; + + /** + * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction. + * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`. + * + * @method authorize + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Object} [options.appState] any values that you want back on the authentication response + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + WebAuth.prototype.authorize = function(options) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + params = this.transactionManager.process(params); + params.scope = params.scope || 'openid profile email'; + + windowHelper.redirect(this.client.buildAuthorizeUrl(params)); + }; + + /** + * Signs up a new user, automatically logs the user in after the signup and returns the user token. + * The login will be done using /oauth/token with password-realm grant type. + * + * @method signupAndAuthorize + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {tokenCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + * @see {@link https://auth0.com/docs/api-auth/grant/password} + */ + WebAuth.prototype.signupAndAuthorize = function(options, cb) { + var _this = this; + + return this.client.dbConnection.signup( + objectHelper.blacklist(options, ['popupHandler']), + function(err) { + if (err) { + return cb(err); + } + options.realm = options.connection; + if (!options.username) { + options.username = options.email; + } + _this.client.login(options, cb); + } + ); + }; + + /** + * @callback crossOriginLoginCallback + * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed + */ + + /** + * Logs the user in with username and password using the correct flow based on where it's called from: + * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint + * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow + * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`. + * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data. + * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.** + * + * @method login + * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired + * @param {String} [options.username] Username (mutually exclusive with email) + * @param {String} [options.email] Email (mutually exclusive with username) + * @param {String} options.password Password + * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name + * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`. + */ + WebAuth.prototype.login = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + params = this.transactionManager.process(params); + + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + params.connection = params.realm; + delete params.realm; + this._universalLogin.login(params, cb); + } else { + this.crossOriginAuthentication.login(params, cb); + } + }; + + /** + * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user. + * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor. + * + * @method passwordlessLogin + * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired + * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email) + * @param {String} [options.email] Email (mutually exclusive with username) + * @param {String} options.verificationCode Verification Code (OTP) + * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'. + * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`. + */ + WebAuth.prototype.passwordlessLogin = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + params = this.transactionManager.process(params); + + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + this.passwordlessVerify(params, cb); + } else { + var crossOriginOptions = objectHelper.extend( + { + credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp', + realm: params.connection, + username: params.email || params.phoneNumber, + otp: params.verificationCode + }, + objectHelper.blacklist(params, [ + 'connection', + 'email', + 'phoneNumber', + 'verificationCode' + ]) + ); + this.crossOriginAuthentication.login(crossOriginOptions, cb); + } + }; + + /** + * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url. + * + * @method crossOriginAuthenticationCallback + * @deprecated Use {@link crossOriginVerification} instead. + */ + WebAuth.prototype.crossOriginAuthenticationCallback = function() { + this.crossOriginVerification(); + }; + + /** + * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url. + * + * @method crossOriginVerification + */ + WebAuth.prototype.crossOriginVerification = function() { + this.crossOriginAuthentication.callback(); + }; + + /** + * Redirects to the auth0 logout endpoint + * + * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list: + * + * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level). + * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level). + * + * @method logout + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.returnTo] URL to be redirected after the logout + * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP. + * @see {@link https://auth0.com/docs/api/authentication#logout} + */ + WebAuth.prototype.logout = function(options) { + windowHelper.redirect(this.client.buildLogoutUrl(options)); + }; + + /** + * Verifies the passwordless TOTP and redirects to finish the passwordless transaction + * + * @method passwordlessVerify + * @param {Object} options + * @param {String} options.type `sms` or `email` + * @param {String} options.phoneNumber only if type = sms + * @param {String} options.email only if type = email + * @param {String} options.connection the connection name + * @param {String} options.verificationCode the TOTP code + * @param {Function} cb + */ + WebAuth.prototype.passwordlessVerify = function(options, cb) { + var _this = this; + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + params = this.transactionManager.process(params); + return this.client.passwordless.verify(params, function(err) { + if (err) { + return cb(err); + } + return windowHelper.redirect( + _this.client.passwordless.buildVerifyUrl(params) + ); + }); + }; + + /** + * + * Renders the captcha challenge in the provided element. + * This function can only be used in the context of a Classic Universal Login Page. + * + * @param {HTMLElement} element The element where the captcha needs to be rendered + * @param {Object} options The configuration options for the captcha + * @param {Object} [options.templates] An object containaing templates for each captcha provider + * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string + * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string + * @param {String} [options.lang=en] the ISO code of the language for recaptcha + * @param {Function} [callback] An optional completion callback + */ + WebAuth.prototype.renderCaptcha = function(element, options, callback) { + return captcha.render(this.client, element, options, callback); + }; + + function PasswordlessAuthentication(request, options) { + this.baseOptions = options; + this.request = request; + } + + PasswordlessAuthentication.prototype.buildVerifyUrl = function(options) { + var params; + var qString; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + verificationCode: { + type: 'string', + message: 'verificationCode option is required' + }, + phoneNumber: { + optional: false, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return !o.email; + } + }, + email: { + optional: false, + type: 'string', + message: 'email option is required', + condition: function(o) { + return !o.phoneNumber; + } + } + } + ); + /* eslint-enable */ + + params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'protocol', + 'nonce' + ]) + .with(options); + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + params = objectHelper.toSnakeCase(params, ['auth0Client']); + + qString = lib.stringify(params); + + return urlJoin( + this.baseOptions.rootUrl, + 'passwordless', + 'verify_redirect', + '?' + qString + ); + }; + + PasswordlessAuthentication.prototype.start = function(options, cb) { + var url; + var body; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + send: { + type: 'string', + message: 'send option is required', + values: ['link', 'code'], + value_message: 'send is not valid ([link, code])' + }, + phoneNumber: { + optional: true, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return o.send === 'code' || !o.email; + } + }, + email: { + optional: true, + type: 'string', + message: 'email option is required', + condition: function(o) { + return o.send === 'link' || !o.phoneNumber; + } + }, + authParams: { + optional: true, + type: 'object', + message: 'authParams option is required' + } + } + ); + /* eslint-enable */ + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'passwordless', 'start'); + + body = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope' + ]) + .with(options); + + if (body.scope) { + body.authParams = body.authParams || {}; + body.authParams.scope = body.authParams.scope || body.scope; + } + + if (body.redirectUri) { + body.authParams = body.authParams || {}; + body.authParams.redirect_uri = + body.authParams.redirectUri || body.redirectUri; + } + + if (body.responseType) { + body.authParams = body.authParams || {}; + body.authParams.response_type = + body.authParams.responseType || body.responseType; + } + + delete body.redirectUri; + delete body.responseType; + delete body.scope; + + body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + PasswordlessAuthentication.prototype.verify = function(options, cb) { + var url; + var cleanOption; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + verificationCode: { + type: 'string', + message: 'verificationCode option is required' + }, + phoneNumber: { + optional: false, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return !o.email; + } + }, + email: { + optional: false, + type: 'string', + message: 'email option is required', + condition: function(o) { + return !o.phoneNumber; + } + } + } + ); + /* eslint-enable */ + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + cleanOption = objectHelper.pick(options, [ + 'connection', + 'verificationCode', + 'phoneNumber', + 'email', + 'auth0Client' + ]); + cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']); + + url = urlJoin(this.baseOptions.rootUrl, 'passwordless', 'verify'); + + return this.request + .post(url) + .send(cleanOption) + .end(wrapCallback(cb)); + }; + + function DBConnection(request, options) { + this.baseOptions = options; + this.request = request; + } + + /** + * @callback signUpCallback + * @param {Error} [err] error returned by Auth0 with the reason why the signup failed + * @param {Object} [result] result of the signup request + * @param {Object} result.email user's email + * @param {Object} result.emailVerified if the user's email was verified + */ + + /** + * Creates a new user in a Auth0 Database connection + * + * @method signup + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username` + * @param {String} options.connection name of the connection where the user will be created + * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata` + * @param {signUpCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + */ + DBConnection.prototype.signup = function(options, cb) { + var url; + var body; + var metadata; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + email: { type: 'string', message: 'email option is required' }, + password: { type: 'string', message: 'password option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'dbconnections', 'signup'); + + body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options); + + metadata = body.user_metadata || body.userMetadata; + + body = objectHelper.blacklist(body, [ + 'scope', + 'userMetadata', + 'user_metadata' + ]); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + if (metadata) { + body.user_metadata = metadata; + } + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * @callback changePasswordCallback + * @param {Error} [err] error returned by Auth0 with the reason why the request failed + */ + + /** + * Request an email with instruction to change a user's password + * + * @method changePassword + * @param {Object} options + * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0 + * @param {String} options.connection name of the connection where the user was created + * @param {changePasswordCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#change-password} + */ + DBConnection.prototype.changePassword = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + email: { type: 'string', message: 'email option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password'); + + body = objectHelper + .merge(this.baseOptions, ['clientID']) + .with(options, ['email', 'connection']); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Creates a new Auth0 Authentication API client + * @constructor + * @param {Object} options + * @param {String} options.domain your Auth0 domain + * @param {String} options.clientID the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @see {@link https://auth0.com/docs/api/authentication} + */ + function Authentication(auth0, options) { + // If we have two arguments, the first one is a WebAuth instance, so we assign that + // if not, it's an options object and then we should use that as options instead + // this is here because we don't want to break people coming from v8 + if (arguments.length === 2) { + this.auth0 = auth0; + } else { + options = auth0; + } + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + clientID: { type: 'string', message: 'clientID option is required' }, + responseType: { + optional: true, + type: 'string', + message: 'responseType is not valid' + }, + responseMode: { + optional: true, + type: 'string', + message: 'responseMode is not valid' + }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri is not valid' + }, + scope: { optional: true, type: 'string', message: 'scope is not valid' }, + audience: { + optional: true, + type: 'string', + message: 'audience is not valid' + }, + _disableDeprecationWarnings: { + optional: true, + type: 'boolean', + message: '_disableDeprecationWarnings option is not valid' + }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + }, + } + ); + /* eslint-enable */ + + this.baseOptions = options; + this.baseOptions._sendTelemetry = + this.baseOptions._sendTelemetry === false + ? this.baseOptions._sendTelemetry + : true; + + this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0) + ? this.baseOptions.domain + : 'https://' + this.baseOptions.domain; + + this.request = new RequestBuilder(this.baseOptions); + + this.passwordless = new PasswordlessAuthentication( + this.request, + this.baseOptions + ); + this.dbConnection = new DBConnection(this.request, this.baseOptions); + + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + this.ssodataStorage = new SSODataStorage(this.baseOptions); + } + + /** + * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction + * + * @method buildAuthorizeUrl + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + * @see {@link https://auth0.com/docs/api/authentication#social} + */ + Authentication.prototype.buildAuthorizeUrl = function(options) { + var params; + var qString; + + assert.check(options, { + type: 'object', + message: 'options parameter is not valid' + }); + + params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience' + ]) + .with(options); + + /* eslint-disable */ + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + clientID: { type: 'string', message: 'clientID option is required' }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri option is required' + }, + responseType: { + type: 'string', + message: 'responseType option is required' + }, + nonce: { + type: 'string', + message: 'nonce option is required', + condition: function(o) { + return ( + o.responseType.indexOf('code') === -1 && + o.responseType.indexOf('id_token') !== -1 + ); + } + }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + /* eslint-enable */ + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + if (params.connection_scope && assert.isArray(params.connection_scope)) { + params.connection_scope = params.connection_scope.join(','); + } + + params = objectHelper.blacklist(params, [ + 'username', + 'popupOptions', + 'domain', + 'tenant', + 'timeout', + 'appState' + ]); + params = objectHelper.toSnakeCase(params, ['auth0Client']); + params = parametersWhitelist.oauthAuthorizeParams(this.warn, params); + + qString = lib.stringify(params); + + return urlJoin(this.baseOptions.rootUrl, 'authorize', '?' + qString); + }; + + /** + * Builds and returns the Logout url in order to initialize a new authN/authZ transaction + * + * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list: + * + * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level). + * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level). + * @method buildLogoutUrl + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.returnTo] URL to be redirected after the logout + * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP. + * @see {@link https://auth0.com/docs/api/authentication#logout} + */ + Authentication.prototype.buildLogoutUrl = function(options) { + var params; + var qString; + + assert.check(options, { + optional: true, + type: 'object', + message: 'options parameter is not valid' + }); + + params = objectHelper + .merge(this.baseOptions, ['clientID']) + .with(options || {}); + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']); + + qString = lib.stringify(objectHelper.blacklist(params, ['federated'])); + if ( + options && + options.federated !== undefined && + options.federated !== false && + options.federated !== 'false' + ) { + qString += '&federated'; + } + + return urlJoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString); + }; + + /** + * @callback authorizeCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null. + * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint) + * @param {Number} [result.expiresIn] number of seconds until the access token expires + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + * @param {Object} [result.appState] values that you receive back on the authentication response + */ + + /** + * @callback tokenCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the Auth request + * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint) + * @param {Number} result.expiresIn number of seconds until the access token expires + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + */ + + /** + * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory. + * + * @method loginWithDefaultDirectory + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {tokenCallback} cb function called with the result of the request + * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.loginWithDefaultDirectory = function(options, cb) { + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + options.grantType = 'password'; + + return this.oauthToken(options, cb); + }; + + /** + * Makes a call to the `oauth/token` endpoint with `password-realm` grant type + * + * @method login + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication` + * @param {tokenCallback} cb function called with the result of the request + * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.login = function(options, cb) { + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + realm: { type: 'string', message: 'realm option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + options.grantType = 'http://auth0.com/oauth/grant-type/password-realm'; + + return this.oauthToken(options, cb); + }; + + /** + * Makes a call to the `oauth/token` endpoint + * + * @method oauthToken + * @private + */ + Authentication.prototype.oauthToken = function(options, cb) { + var url; + var body; + + assert.check(options, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'oauth', 'token'); + + body = objectHelper + .merge(this.baseOptions, ['clientID', 'scope', 'audience']) + .with(options); + + assert.check( + body, + { type: 'object', message: 'options parameter is not valid' }, + { + clientID: { type: 'string', message: 'clientID option is required' }, + grantType: { type: 'string', message: 'grantType option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + body = parametersWhitelist.oauthTokenParams(this.warn, body); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Performs authentication calling `/oauth/ro` endpoint with username + * and password for a given connection name. + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link login} or {@link loginWithDefaultDirectory}. + * + * @method loginWithResourceOwner + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication` + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.device] name of the device/browser where the Auth was requested + * @param {tokenCallback} cb function called with the result of the request + */ + Authentication.prototype.loginWithResourceOwner = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + connection: { type: 'string', message: 'connection option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'oauth', 'ro'); + + body = objectHelper + .merge(this.baseOptions, ['clientID', 'scope']) + .with(options, ['username', 'password', 'scope', 'connection', 'device']); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + body.grant_type = body.grant_type || 'password'; + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Uses {@link checkSession} and localStorage to return data from the last successful authentication request. + * + * @method getSSOData + * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible + * @param {Function} cb + */ + Authentication.prototype.getSSOData = function(withActiveDirectories, cb) { + /* istanbul ignore if */ + if (!this.auth0) { + this.auth0 = new WebAuth(this.baseOptions); + } + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb); + } + if (typeof withActiveDirectories === 'function') { + cb = withActiveDirectories; + } + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + var clientId = this.baseOptions.clientID; + var ssodataInformation = this.ssodataStorage.get() || {}; + + this.auth0.checkSession( + { + responseType: 'token id_token', + scope: 'openid profile email', + connection: ssodataInformation.lastUsedConnection, + timeout: 5000 + }, + function(err, result) { + if (err) { + if (err.error === 'login_required') { + return cb(null, { sso: false }); + } + if (err.error === 'consent_required') { + err.error_description = + 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.'; + } + return cb(err, { sso: false }); + } + if ( + ssodataInformation.lastUsedSub && + ssodataInformation.lastUsedSub !== result.idTokenPayload.sub + ) { + return cb(err, { sso: false }); + } + return cb(null, { + lastUsedConnection: { + name: ssodataInformation.lastUsedConnection + }, + lastUsedUserID: result.idTokenPayload.sub, + lastUsedUsername: + result.idTokenPayload.email || result.idTokenPayload.name, + lastUsedClientID: clientId, + sessionClients: [clientId], + sso: true + }); + } + ); + }; + + /** + * @callback userInfoCallback + * @param {Error} [err] error returned by Auth0 + * @param {Object} [userInfo] user information + */ + + /** + * Makes a call to the `/userinfo` endpoint and returns the user profile + * + * @method userInfo + * @param {String} accessToken token issued to a user after Auth + * @param {userInfoCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#get-user-info} + */ + Authentication.prototype.userInfo = function(accessToken, cb) { + var url; + + assert.check(accessToken, { + type: 'string', + message: 'accessToken parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'userinfo'); + + return this.request + .get(url) + .set('Authorization', 'Bearer ' + accessToken) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Makes a call to the `/usernamepassword/challenge` endpoint + * and returns the challenge (captcha) if necessary. + * + * @method getChallenge + * @param {callback} cb + */ + Authentication.prototype.getChallenge = function(cb) { + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + if (!this.baseOptions.state) { + return cb(); + } + + var url = urlJoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge'); + + return this.request + .post(url) + .send({ state: this.baseOptions.state }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * @callback delegationCallback + * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed + * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used + */ + + /** + * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token` + * + * @method delegation + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer` + * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required + * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required + * @param {String} [options.target] the target ClientID of the delegation + * @param {String} [options.scope] either `openid` or `openid profile email` + * @param {String} [options.apiType] the api to be called + * @param {delegationCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#delegation} + * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.delegation = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + grant_type: { type: 'string', message: 'grant_type option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'delegation'); + + body = objectHelper.merge(this.baseOptions, ['clientID']).with(options); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Fetches the user country based on the ip. + * + * @method getUserCountry + * @private + * @param {Function} cb + */ + Authentication.prototype.getUserCountry = function(cb) { + var url; + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country'); + + return this.request.get(url).end(wrapCallback(cb)); + }; + + /** + * Auth0 Management API Client (methods allowed to be called from the browser only) + * @constructor + * @param {Object} options + * @param {Object} options.domain your Auth0 acount domain + * @param {Object} options.token a valid API token + */ + function Management(options) { + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + token: { type: 'string', message: 'token option is required' }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + } + } + ); + /* eslint-enable */ + + this.baseOptions = options; + + this.baseOptions.headers = { + Authorization: 'Bearer ' + this.baseOptions.token + }; + + this.request = new RequestBuilder(this.baseOptions); + this.baseOptions.rootUrl = urlJoin( + 'https://' + this.baseOptions.domain, + 'api', + 'v2' + ); + } + + /** + * @callback userCallback + * @param {Error} [err] failure reason for the failed request to Management API + * @param {Object} [result] user profile + */ + + /** + * Returns the user profile + * + * @method getUser + * @param {String} userId identifier of the user to retrieve + * @param {userCallback} cb + * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id + */ + Management.prototype.getUser = function(userId, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request.get(url).end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Updates the user metdata. It will patch the user metdata with the attributes sent. + * + * + * @method patchUserMetadata + * @param {String} userId + * @param {Object} userMetadata + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id} + */ + Management.prototype.patchUserMetadata = function(userId, userMetadata, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(userMetadata, { + type: 'object', + message: 'userMetadata parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request + .patch(url) + .send({ user_metadata: userMetadata }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Updates the user attributes. It will patch the user attributes that the server allows it. + * + * @method patchUserAttributes + * @param {String} userId + * @param {Object} user + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id} + */ + Management.prototype.patchUserAttributes = function(userId, user, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(user, { + type: 'object', + message: 'user parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request + .patch(url) + .send(user) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Link two users + * + * @method linkUser + * @param {String} userId + * @param {String} secondaryUserToken + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities} + */ + Management.prototype.linkUser = function(userId, secondaryUserToken, cb) { + var url; + /* eslint-disable */ + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(secondaryUserToken, { + type: 'string', + message: 'secondaryUserToken parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + /* eslint-enable */ + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId, 'identities'); + + return this.request + .post(url) + .send({ link_with: secondaryUserToken }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + var index = { + Authentication: Authentication, + Management: Management, + WebAuth: WebAuth, + version: version + }; + + exports.Authentication = Authentication; + exports.Management = Management; + exports.WebAuth = WebAuth; + exports.default = index; + exports.version = version; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); diff --git a/build/auth0.min.esm.js b/build/auth0.min.esm.js new file mode 100644 index 00000000..01ac74be --- /dev/null +++ b/build/auth0.min.esm.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +var commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function createCommonjsModule(fn,module){return fn(module={exports:{}},module.exports),module.exports}var urlJoin=createCommonjsModule((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray(val)){for(var mapped=[],i=0;i-1?val.split(","):val},parseKeys=function(givenKey,val,options,valuesParsed){if(givenKey){var key=options.allowDots?givenKey.replace(/\.([^.[]+)/g,"[$1]"):givenKey,child=/(\[[^[\]]*])/g,segment=options.depth>0&&/(\[[^[\]]*])/.exec(key),parent=segment?key.slice(0,segment.index):key,keys=[];if(parent){if(!options.plainObjects&&has$2.call(Object.prototype,parent)&&!options.allowPrototypes)return;keys.push(parent)}for(var i=0;options.depth>0&&null!==(segment=child.exec(key))&&i=0;--i){var obj,root=chain[i];if("[]"===root&&options.parseArrays)obj=[].concat(leaf);else{obj=options.plainObjects?Object.create(null):{};var cleanRoot="["===root.charAt(0)&&"]"===root.charAt(root.length-1)?root.slice(1,-1):root,index=parseInt(cleanRoot,10);options.parseArrays||""!==cleanRoot?!isNaN(index)&&root!==cleanRoot&&String(index)===cleanRoot&&index>=0&&options.parseArrays&&index<=options.arrayLimit?(obj=[])[index]=leaf:obj[cleanRoot]=leaf:obj={0:leaf}}leaf=obj}return leaf}(keys,val,options,valuesParsed)}},lib_parse=function(str,opts){var options=function(opts){if(!opts)return defaults$1;if(null!==opts.decoder&&void 0!==opts.decoder&&"function"!=typeof opts.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==opts.charset&&"utf-8"!==opts.charset&&"iso-8859-1"!==opts.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var charset=void 0===opts.charset?defaults$1.charset:opts.charset;return{allowDots:void 0===opts.allowDots?defaults$1.allowDots:!!opts.allowDots,allowPrototypes:"boolean"==typeof opts.allowPrototypes?opts.allowPrototypes:defaults$1.allowPrototypes,arrayLimit:"number"==typeof opts.arrayLimit?opts.arrayLimit:defaults$1.arrayLimit,charset:charset,charsetSentinel:"boolean"==typeof opts.charsetSentinel?opts.charsetSentinel:defaults$1.charsetSentinel,comma:"boolean"==typeof opts.comma?opts.comma:defaults$1.comma,decoder:"function"==typeof opts.decoder?opts.decoder:defaults$1.decoder,delimiter:"string"==typeof opts.delimiter||utils.isRegExp(opts.delimiter)?opts.delimiter:defaults$1.delimiter,depth:"number"==typeof opts.depth||!1===opts.depth?+opts.depth:defaults$1.depth,ignoreQueryPrefix:!0===opts.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof opts.interpretNumericEntities?opts.interpretNumericEntities:defaults$1.interpretNumericEntities,parameterLimit:"number"==typeof opts.parameterLimit?opts.parameterLimit:defaults$1.parameterLimit,parseArrays:!1!==opts.parseArrays,plainObjects:"boolean"==typeof opts.plainObjects?opts.plainObjects:defaults$1.plainObjects,strictNullHandling:"boolean"==typeof opts.strictNullHandling?opts.strictNullHandling:defaults$1.strictNullHandling}}(opts);if(""===str||null==str)return options.plainObjects?Object.create(null):{};for(var tempObj="string"==typeof str?function(str,options){var i,obj={},cleanStr=options.ignoreQueryPrefix?str.replace(/^\?/,""):str,limit=options.parameterLimit===1/0?void 0:options.parameterLimit,parts=cleanStr.split(options.delimiter,limit),skipIndex=-1,charset=options.charset;if(options.charsetSentinel)for(i=0;i-1&&(val=isArray$2(val)?[val]:val),has$2.call(obj,key)?obj[key]=utils.combine(obj[key],val):obj[key]=val}return obj}(str,options):str,obj=options.plainObjects?Object.create(null):{},keys=Object.keys(tempObj),i=0;i0?prefix+joined:""},componentEmitter=createCommonjsModule((function(module){function Emitter(obj){if(obj)return function(obj){for(var key in Emitter.prototype)obj[key]=Emitter.prototype[key];return obj}(obj)}module.exports=Emitter,Emitter.prototype.on=Emitter.prototype.addEventListener=function(event,fn){return this._callbacks=this._callbacks||{},(this._callbacks["$"+event]=this._callbacks["$"+event]||[]).push(fn),this},Emitter.prototype.once=function(event,fn){function on(){this.off(event,on),fn.apply(this,arguments)}return on.fn=fn,this.on(event,on),this},Emitter.prototype.off=Emitter.prototype.removeListener=Emitter.prototype.removeAllListeners=Emitter.prototype.removeEventListener=function(event,fn){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var cb,callbacks=this._callbacks["$"+event];if(!callbacks)return this;if(1==arguments.length)return delete this._callbacks["$"+event],this;for(var i=0;ib?1:0}function deterministicStringify(obj,replacer,spacer){var res,tmp=function deterministicDecirc(val,k,stack,parent){var i;if("object"==typeof val&&null!==val){for(i=0;i0)for(var i=0;i=this._maxRetries)return!1;if(this._retryCallback)try{var override=this._retryCallback(err,res);if(!0===override)return!0;if(!1===override)return!1}catch(err_){console.error(err_)}if(res&&res.status&&res.status>=500&&501!==res.status)return!0;if(err){if(err.code&&ERROR_CODES.includes(err.code))return!0;if(err.timeout&&"ECONNABORTED"===err.code)return!0;if(err.crossDomain)return!0}return!1},RequestBase.prototype._retry=function(){return this.clearTimeout(),this.req&&(this.req=null,this.req=this.request()),this._aborted=!1,this.timedout=!1,this.timedoutError=null,this._end()},RequestBase.prototype.then=function(resolve,reject){var _this=this;if(!this._fullfilledPromise){var self=this;this._endCalled&&console.warn("Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises"),this._fullfilledPromise=new Promise((function(resolve,reject){self.on("abort",(function(){if(!(_this._maxRetries&&_this._maxRetries>_this._retries))if(_this.timedout&&_this.timedoutError)reject(_this.timedoutError);else{var err=new Error("Aborted");err.code="ABORTED",err.status=_this.status,err.method=_this.method,err.url=_this.url,reject(err)}})),self.end((function(err,res){err?reject(err):resolve(res)}))}))}return this._fullfilledPromise.then(resolve,reject)},RequestBase.prototype.catch=function(cb){return this.then(void 0,cb)},RequestBase.prototype.use=function(fn){return fn(this),this},RequestBase.prototype.ok=function(cb){if("function"!=typeof cb)throw new Error("Callback required");return this._okCallback=cb,this},RequestBase.prototype._isResponseOK=function(res){return!!res&&(this._okCallback?this._okCallback(res):res.status>=200&&res.status<300)},RequestBase.prototype.get=function(field){return this._header[field.toLowerCase()]},RequestBase.prototype.getHeader=RequestBase.prototype.get,RequestBase.prototype.set=function(field,val){if(isObject_1(field)){for(var key in field)Object.prototype.hasOwnProperty.call(field,key)&&this.set(key,field[key]);return this}return this._header[field.toLowerCase()]=val,this.header[field]=val,this},RequestBase.prototype.unset=function(field){return delete this._header[field.toLowerCase()],delete this.header[field],this},RequestBase.prototype.field=function(name,val){if(null==name)throw new Error(".field(name, val) name can not be empty");if(this._data)throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()");if(isObject_1(name)){for(var key in name)Object.prototype.hasOwnProperty.call(name,key)&&this.field(key,name[key]);return this}if(Array.isArray(val)){for(var i in val)Object.prototype.hasOwnProperty.call(val,i)&&this.field(name,val[i]);return this}if(null==val)throw new Error(".field(name, val) val can not be empty");return"boolean"==typeof val&&(val=String(val)),this._getFormData().append(name,val),this},RequestBase.prototype.abort=function(){return this._aborted||(this._aborted=!0,this.xhr&&this.xhr.abort(),this.req&&this.req.abort(),this.clearTimeout(),this.emit("abort")),this},RequestBase.prototype._auth=function(user,pass,options,base64Encoder){switch(options.type){case"basic":this.set("Authorization","Basic ".concat(base64Encoder("".concat(user,":").concat(pass))));break;case"auto":this.username=user,this.password=pass;break;case"bearer":this.set("Authorization","Bearer ".concat(user))}return this},RequestBase.prototype.withCredentials=function(on){return void 0===on&&(on=!0),this._withCredentials=on,this},RequestBase.prototype.redirects=function(n){return this._maxRedirects=n,this},RequestBase.prototype.maxResponseSize=function(n){if("number"!=typeof n)throw new TypeError("Invalid argument");return this._maxResponseSize=n,this},RequestBase.prototype.toJSON=function(){return{method:this.method,url:this.url,data:this._data,headers:this._header}},RequestBase.prototype.send=function(data){var isObj=isObject_1(data),type=this._header["content-type"];if(this._formData)throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()");if(isObj&&!this._data)Array.isArray(data)?this._data=[]:this._isHost(data)||(this._data={});else if(data&&this._data&&this._isHost(this._data))throw new Error("Can't merge these send calls");if(isObj&&isObject_1(this._data))for(var key in data)Object.prototype.hasOwnProperty.call(data,key)&&(this._data[key]=data[key]);else"string"==typeof data?(type||this.type("form"),type=this._header["content-type"],this._data="application/x-www-form-urlencoded"===type?this._data?"".concat(this._data,"&").concat(data):data:(this._data||"")+data):this._data=data;return!isObj||this._isHost(data)||type||this.type("json"),this},RequestBase.prototype.sortQuery=function(sort){return this._sort=void 0===sort||sort,this},RequestBase.prototype._finalizeQueryString=function(){var query=this._query.join("&");if(query&&(this.url+=(this.url.includes("?")?"&":"?")+query),this._query.length=0,this._sort){var index=this.url.indexOf("?");if(index>=0){var queryArr=this.url.slice(index+1).split("&");"function"==typeof this._sort?queryArr.sort(this._sort):queryArr.sort(),this.url=this.url.slice(0,index)+"?"+queryArr.join("&")}}},RequestBase.prototype._appendQueryString=function(){console.warn("Unsupported")},RequestBase.prototype._timeoutError=function(reason,timeout,errno){if(!this._aborted){var err=new Error("".concat(reason+timeout,"ms exceeded"));err.timeout=timeout,err.code="ECONNABORTED",err.errno=errno,this.timedout=!0,this.timedoutError=err,this.abort(),this.callback(err)}},RequestBase.prototype._setTimeouts=function(){var self=this;this._timeout&&!this._timer&&(this._timer=setTimeout((function(){self._timeoutError("Timeout of ",self._timeout,"ETIME")}),this._timeout)),this._responseTimeout&&!this._responseTimeoutTimer&&(this._responseTimeoutTimer=setTimeout((function(){self._timeoutError("Response timeout of ",self._responseTimeout,"ETIMEDOUT")}),this._responseTimeout))};var utils$1_type=function(str){return str.split(/ *; */).shift()},utils$1_params=function(str){return str.split(/ *; */).reduce((function(obj,str){var parts=str.split(/ *= */),key=parts.shift(),val=parts.shift();return key&&val&&(obj[key]=val),obj}),{})},utils$1_parseLinks=function(str){return str.split(/ *, */).reduce((function(obj,str){var parts=str.split(/ *; */),url=parts[0].slice(1,-1);return obj[parts[1].split(/ *= */)[1].slice(1,-1)]=url,obj}),{})},responseBase=ResponseBase;function ResponseBase(obj){if(obj)return function(obj){for(var key in ResponseBase.prototype)Object.prototype.hasOwnProperty.call(ResponseBase.prototype,key)&&(obj[key]=ResponseBase.prototype[key]);return obj}(obj)}function _toConsumableArray(arr){return function(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}(arr)||function(iter){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(iter))return Array.from(iter)}(arr)||function(o,minLen){if(!o)return;if("string"==typeof o)return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);"Object"===n&&o.constructor&&(n=o.constructor.name);if("Map"===n||"Set"===n)return Array.from(o);if("Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}(arr)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _arrayLikeToArray(arr,len){(null==len||len>arr.length)&&(len=arr.length);for(var i=0,arr2=new Array(len);i0||str instanceof Object)?parse(str):null)},Response.prototype.toError=function(){var req=this.req,method=req.method,url=req.url,msg="cannot ".concat(method," ").concat(url," (").concat(this.status,")"),err=new Error(msg);return err.status=this.status,err.method=method,err.url=url,err},request.Response=Response,componentEmitter(Request.prototype),requestBase(Request.prototype),Request.prototype.type=function(type){return this.set("Content-Type",request.types[type]||type),this},Request.prototype.accept=function(type){return this.set("Accept",request.types[type]||type),this},Request.prototype.auth=function(user,pass,options){1===arguments.length&&(pass=""),"object"===_typeof(pass)&&null!==pass&&(options=pass,pass=""),options||(options={type:"function"==typeof btoa?"basic":"auto"});var encoder=function(string){if("function"==typeof btoa)return btoa(string);throw new Error("Cannot use basic auth, btoa is not a function")};return this._auth(user,pass,options,encoder)},Request.prototype.query=function(val){return"string"!=typeof val&&(val=serialize(val)),val&&this._query.push(val),this},Request.prototype.attach=function(field,file,options){if(file){if(this._data)throw new Error("superagent can't mix .send() and .attach()");this._getFormData().append(field,file,options||file.name)}return this},Request.prototype._getFormData=function(){return this._formData||(this._formData=new root.FormData),this._formData},Request.prototype.callback=function(err,res){if(this._shouldRetry(err,res))return this._retry();var fn=this._callback;this.clearTimeout(),err&&(this._maxRetries&&(err.retries=this._retries-1),this.emit("error",err)),fn(err,res)},Request.prototype.crossDomainError=function(){var err=new Error("Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.");err.crossDomain=!0,err.status=this.status,err.method=this.method,err.url=this.url,this.callback(err)},Request.prototype.agent=function(){return console.warn("This is not supported in browser version of superagent"),this},Request.prototype.ca=Request.prototype.agent,Request.prototype.buffer=Request.prototype.ca,Request.prototype.write=function(){throw new Error("Streaming is not supported in browser version of superagent")},Request.prototype.pipe=Request.prototype.write,Request.prototype._isHost=function(obj){return obj&&"object"===_typeof(obj)&&!Array.isArray(obj)&&"[object Object]"!==Object.prototype.toString.call(obj)},Request.prototype.end=function(fn){this._endCalled&&console.warn("Warning: .end() was called twice. This is not supported in superagent"),this._endCalled=!0,this._callback=fn||noop,this._finalizeQueryString(),this._end()},Request.prototype._setUploadTimeout=function(){var self=this;this._uploadTimeout&&!this._uploadTimeoutTimer&&(this._uploadTimeoutTimer=setTimeout((function(){self._timeoutError("Upload timeout of ",self._uploadTimeout,"ETIMEDOUT")}),this._uploadTimeout))},Request.prototype._end=function(){if(this._aborted)return this.callback(new Error("The request has been aborted even before .end() was called"));var self=this;this.xhr=request.getXHR();var xhr=this.xhr,data=this._formData||this._data;this._setTimeouts(),xhr.onreadystatechange=function(){var readyState=xhr.readyState;if(readyState>=2&&self._responseTimeoutTimer&&clearTimeout(self._responseTimeoutTimer),4===readyState){var status;try{status=xhr.status}catch(_unused5){status=0}if(!status){if(self.timedout||self._aborted)return;return self.crossDomainError()}self.emit("end")}};var handleProgress=function(direction,e){e.total>0&&(e.percent=e.loaded/e.total*100,100===e.percent&&clearTimeout(self._uploadTimeoutTimer)),e.direction=direction,self.emit("progress",e)};if(this.hasListeners("progress"))try{xhr.addEventListener("progress",handleProgress.bind(null,"download")),xhr.upload&&xhr.upload.addEventListener("progress",handleProgress.bind(null,"upload"))}catch(_unused6){}xhr.upload&&this._setUploadTimeout();try{this.username&&this.password?xhr.open(this.method,this.url,!0,this.username,this.password):xhr.open(this.method,this.url,!0)}catch(err){return this.callback(err)}if(this._withCredentials&&(xhr.withCredentials=!0),!this._formData&&"GET"!==this.method&&"HEAD"!==this.method&&"string"!=typeof data&&!this._isHost(data)){var contentType=this._header["content-type"],_serialize=this._serializer||request.serialize[contentType?contentType.split(";")[0]:""];!_serialize&&isJSON(contentType)&&(_serialize=request.serialize["application/json"]),_serialize&&(data=_serialize(data))}for(var field in this.header)null!==this.header[field]&&Object.prototype.hasOwnProperty.call(this.header,field)&&xhr.setRequestHeader(field,this.header[field]);this._responseType&&(xhr.responseType=this._responseType),this.emit("request",this),xhr.send(void 0===data?null:data)},request.agent=function(){return new agentBase},["GET","POST","OPTIONS","PATCH","PUT","DELETE"].forEach((function(method){agentBase.prototype[method.toLowerCase()]=function(url,fn){var req=new request.Request(method,url);return this._setDefaults(req),fn&&req.end(fn),req}})),agentBase.prototype.del=agentBase.prototype.delete,request.get=function(url,data,fn){var req=request("GET",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.head=function(url,data,fn){var req=request("HEAD",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.options=function(url,data,fn){var req=request("OPTIONS",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.del=del,request.delete=del,request.patch=function(url,data,fn){var req=request("PATCH",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.post=function(url,data,fn){var req=request("POST",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.put=function(url,data,fn){var req=request("PUT",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req}})),byteLength_1=(client.Request,function(b64){var lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1];return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}),toByteArray_1=function(b64){var tmp,i,lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1],arr=new Arr(function(b64,validLen,placeHoldersLen){return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}(0,validLen,placeHoldersLen)),curByte=0,len=placeHoldersLen>0?validLen-4:validLen;for(i=0;i>16&255,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp;2===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<2|revLookup[b64.charCodeAt(i+1)]>>4,arr[curByte++]=255&tmp);1===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<10|revLookup[b64.charCodeAt(i+1)]<<4|revLookup[b64.charCodeAt(i+2)]>>2,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp);return arr},fromByteArray_1=function(uint8){for(var tmp,len=uint8.length,extraBytes=len%3,parts=[],i=0,len2=len-extraBytes;ilen2?len2:i+16383));1===extraBytes?(tmp=uint8[len-1],parts.push(lookup[tmp>>2]+lookup[tmp<<4&63]+"==")):2===extraBytes&&(tmp=(uint8[len-2]<<8)+uint8[len-1],parts.push(lookup[tmp>>10]+lookup[tmp>>4&63]+lookup[tmp<<2&63]+"="));return parts.join("")},lookup=[],revLookup=[],Arr="undefined"!=typeof Uint8Array?Uint8Array:Array,code="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=0,len=code.length;i0)throw new Error("Invalid string. Length must be a multiple of 4");var validLen=b64.indexOf("=");return-1===validLen&&(validLen=len),[validLen,validLen===len?0:4-validLen%4]}function encodeChunk(uint8,start,end){for(var tmp,num,output=[],i=start;i>18&63]+lookup[num>>12&63]+lookup[num>>6&63]+lookup[63&num]);return output.join("")}revLookup["-".charCodeAt(0)]=62,revLookup["_".charCodeAt(0)]=63;var base64Js={byteLength:byteLength_1,toByteArray:toByteArray_1,fromByteArray:fromByteArray_1};var base64Url={encode:function(str){return base64Js.fromByteArray(function(str){for(var arr=new Array(str.length),a=0;a=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function RequestWrapper(req){this.request=req,this.method=req.method,this.url=req.url,this.body=req._data,this.headers=req._header}function RequestObj(req){this.request=req}function RequestBuilder(options){this._sendTelemetry=!1!==options._sendTelemetry||options._sendTelemetry,this._telemetryInfo=options._telemetryInfo||null,this._timesToRetryFailedRequests=options._timesToRetryFailedRequests,this.headers=options.headers||{},this._universalLoginPage=options.universalLoginPage}function getWindow(){return window}RequestWrapper.prototype.abort=function(){this.request.abort()},RequestWrapper.prototype.getMethod=function(){return this.method},RequestWrapper.prototype.getBody=function(){return this.body},RequestWrapper.prototype.getUrl=function(){return this.url},RequestWrapper.prototype.getHeaders=function(){return this.headers},RequestObj.prototype.set=function(key,value){return this.request=this.request.set(key,value),this},RequestObj.prototype.send=function(body){return this.request=this.request.send(objectHelper.trimUserDetails(body)),this},RequestObj.prototype.withCredentials=function(){return this.request=this.request.withCredentials(),this},RequestObj.prototype.end=function(cb){return this.request.end(cb),new RequestWrapper(this.request)},RequestBuilder.prototype.setCommonConfiguration=function(ongoingRequest,options){if(options=options||{},this._timesToRetryFailedRequests>0&&(ongoingRequest=ongoingRequest.retry(this._timesToRetryFailedRequests)),options.noHeaders)return ongoingRequest;var headers=this.headers;ongoingRequest=ongoingRequest.set("Content-Type","application/json");for(var keys=Object.keys(this.headers),a=0;a0&&warn.warning("Following parameters are not allowed on the `/authorize` endpoint: ["+notAllowed.join(",")+"]"),params}},t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e((function(e,r){e.exports=function(){function e(t){return"function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)})),o=e((function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64)})),s=e((function(t,e){t.exports=i$1.enc.Hex})),h=e((function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e))}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return"-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return"0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()}));function _(t,e){return e=e||{},new Promise((function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,(function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r})),r(a())},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)}))}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||""}function A(t){this.name="TokenValidationError",this.message=t||""}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return"number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}function PluginHandler(webAuth,plugins){this.plugins=plugins;for(var a=0;a1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)}))},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then((function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then((function(t){var e,r,i,n=null;for(e=0;e-1){null!==new RegExp("rv:([0-9]{2,2}[.0-9]{0,})").exec(ua)&&(rv=parseFloat(RegExp.$1))}return rv>=8}();return"undefined"!=typeof window&&window.JSON&&window.JSON.stringify&&window.JSON.parse&&window.postMessage?{open:function(opts,cb){if(!cb)throw"missing required callback argument";var err,iframe;opts.url||(err="missing required 'url' parameter"),opts.relay_url||(err="missing required 'relay_url' parameter"),err&&setTimeout((function(){cb(err)}),0),opts.window_name||(opts.window_name=null),opts.window_features&&!function(){try{var userAgent=navigator.userAgent;return-1!=userAgent.indexOf("Fennec/")||-1!=userAgent.indexOf("Firefox/")&&-1!=userAgent.indexOf("Android")}catch(e){}return!1}()||(opts.window_features=void 0);var messageTarget,origin=opts.origin||extractOrigin(opts.url);if(origin!==extractOrigin(opts.relay_url))return setTimeout((function(){cb("invalid arguments: origin of url and relay_url must match")}),0);isIE&&((iframe=document.createElement("iframe")).setAttribute("src",opts.relay_url),iframe.style.display="none",iframe.setAttribute("name","__winchan_relay_frame"),document.body.appendChild(iframe),messageTarget=iframe.contentWindow);var w=opts.popup||window.open(opts.url,opts.window_name,opts.window_features);opts.popup&&(w.location.href=opts.url),messageTarget||(messageTarget=w);var closeInterval=setInterval((function(){w&&w.closed&&(cleanup(),cb&&(cb("User closed the popup window"),cb=null))}),500),req=JSON.stringify({a:"request",d:opts.params});function cleanup(){if(iframe&&document.body.removeChild(iframe),iframe=void 0,closeInterval&&(closeInterval=clearInterval(closeInterval)),removeListener(window,"message",onMessage),removeListener(window,"unload",cleanup),w)try{w.close()}catch(securityViolation){messageTarget.postMessage("die",origin)}w=messageTarget=void 0}function onMessage(e){if(e.origin===origin){try{var d=JSON.parse(e.data)}catch(err){if(cb)return cb(err);throw err}"ready"===d.a?messageTarget.postMessage(req,origin):"error"===d.a?(cleanup(),cb&&(cb(d.d),cb=null)):"response"===d.a&&(cleanup(),cb&&(cb(null,d.d),cb=null))}}return addListener(window,"unload",cleanup),addListener(window,"message",onMessage),{originalPopup:w,close:cleanup,focus:function(){if(w)try{w.focus()}catch(e){}}}},onOpen:function(cb){var o="*",msgTarget=isIE?function(){for(var frames=window.opener.frames,i=frames.length-1;i>=0;i--)try{if(frames[i].location.protocol===window.location.protocol&&frames[i].location.host===window.location.host&&"__winchan_relay_frame"===frames[i].name)return frames[i]}catch(e){}}():window.opener;if(!msgTarget)throw"can't find relay frame";function doPost(msg){msg=JSON.stringify(msg),isIE?msgTarget.doPost(msg,o):msgTarget.postMessage(msg,o)}function onDie(e){if("die"===e.data)try{window.close()}catch(o_O){}}addListener(isIE?msgTarget:window,"message",(function onMessage(e){var d;try{d=JSON.parse(e.data)}catch(err){}d&&"request"===d.a&&(removeListener(window,"message",onMessage),o=e.origin,cb&&setTimeout((function(){cb(o,d.d,(function(r){cb=void 0,doPost({a:"response",d:r})}))}),0))})),addListener(isIE?msgTarget:window,"message",onDie);try{doPost({a:"ready"})}catch(e){addListener(msgTarget,"load",(function(e){doPost({a:"ready"})}))}var onUnload=function(){try{removeListener(isIE?msgTarget:window,"message",onDie)}catch(ohWell){}cb&&doPost({a:"error",d:"client closed window"}),cb=void 0;try{window.close()}catch(e){}};return addListener(window,"unload",onUnload),{detach:function(){removeListener(window,"unload",onUnload)}}}}:{open:function(url,winopts,arg,cb){setTimeout((function(){cb("unsupported browser")}),0)},onOpen:function(cb){setTimeout((function(){cb("unsupported browser")}),0)}}}();module.exports&&(module.exports=WinChan)}));var urlHelper={extractOrigin:function(url){/^https?:\/\//.test(url)||(url=window.location.href);var m=/^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url);return m?m[1]:url}};function PopupHandler(){this._current_popup=null}function Popup(webAuth,options){this.baseOptions=options,this.baseOptions.popupOrigin=options.popupOrigin,this.client=webAuth.client,this.webAuth=webAuth,this.transactionManager=new TransactionManager(this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(webAuth,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}function SilentAuthenticationHandler(options){this.authenticationUrl=options.authenticationUrl,this.timeout=options.timeout||6e4,this.handler=null,this.postMessageDataType=options.postMessageDataType||!1,this.postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().location.origin||windowHelper.getWindow().location.protocol+"//"+windowHelper.getWindow().location.hostname+(windowHelper.getWindow().location.port?":"+windowHelper.getWindow().location.port:"")}function UsernamePassword(options){this.baseOptions=options,this.request=new RequestBuilder(options),this.transactionManager=new TransactionManager(this.baseOptions)}function HostedPages(client,options){this.baseOptions=options,this.client=client,this.baseOptions.universalLoginPage=!0,this.request=new RequestBuilder(this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}PopupHandler.prototype.calculatePosition=function(options){var width=options.width||500,height=options.height||600,_window=windowHelper.getWindow(),screenX=void 0!==_window.screenX?_window.screenX:_window.screenLeft,screenY=void 0!==_window.screenY?_window.screenY:_window.screenTop,outerWidth=void 0!==_window.outerWidth?_window.outerWidth:_window.document.body.clientWidth,outerHeight=void 0!==_window.outerHeight?_window.outerHeight:_window.document.body.clientHeight;return{width:width,height:height,left:options.left||screenX+(outerWidth-width)/2,top:options.top||screenY+(outerHeight-height)/2}},PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHelper.getWindow(),popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),url=options.url||"about:blank",windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"auth0_signup_popup",windowFeatures),this._current_popup.kill=function(){this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,relayUrl,options,cb){var _this=this,popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),winchanOptions=objectHelper.merge({url:url,relay_url:relayUrl,window_features:lib_stringify(popupOptions,{delimiter:",",encode:!1}),popup:this._current_popup}).with(options),popup=winchan.open(winchanOptions,(function(err,data){if(!err||"SyntaxError"!==err.name)return _this._current_popup=null,cb(err,data)}));return popup.focus(),popup},Popup.prototype.buildPopupHandler=function(){var pluginHandler=this.baseOptions.plugins.get("popup.getPopupHandler");return pluginHandler?pluginHandler.getPopupHandler():new PopupHandler},Popup.prototype.preload=function(options){options=options||{};var popup=this.buildPopupHandler();return popup.preload(options),popup},Popup.prototype.getPopupHandler=function(options,preload){return options.popupHandler?options.popupHandler:preload?this.preload(options):this.buildPopupHandler()},Popup.prototype.callback=function(options){var _this=this,theWindow=windowHelper.getWindow(),originUrl=(options=options||{}).popupOrigin||this.baseOptions.popupOrigin||windowHelper.getOrigin();theWindow.opener?winchan.onOpen((function(popupOrigin,r,cb){if(popupOrigin!==originUrl)return cb({error:"origin_mismatch",error_description:"The popup's origin ("+popupOrigin+") should match the `popupOrigin` parameter ("+originUrl+")."});_this.webAuth.parseHash(options||{},(function(err,data){return cb(err||data)}))})):theWindow.doPost=function(msg){theWindow.parent&&theWindow.parent.postMessage(msg,originUrl)}},Popup.prototype.authorize=function(options,cb){var url,relayUrl,popOpts={},pluginHandler=this.baseOptions.plugins.get("popup.authorize"),params=objectHelper.merge(this.baseOptions,["clientID","scope","domain","audience","tenant","responseType","redirectUri","_csrf","state","_intstate","nonce"]).with(objectHelper.blacklist(options,["popupHandler"]));return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),relayUrl=urlJoin(this.baseOptions.rootUrl,"relay.html"),options.owp?params.owp=!0:(popOpts.origin=urlHelper.extractOrigin(params.redirectUri),relayUrl=params.redirectUri),options.popupOptions&&(popOpts.popupOptions=objectHelper.pick(options.popupOptions,["width","height","top","left"])),pluginHandler&&(params=pluginHandler.processParams(params)),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",delete params.domain,url=this.client.buildAuthorizeUrl(params),this.getPopupHandler(options).load(url,relayUrl,popOpts,wrapCallback(cb,{keepOriginalCasing:!0}))},Popup.prototype.loginWithCredentials=function(options,cb){options.realm=options.realm||options.connection,options.popup=!0,options=objectHelper.merge(this.baseOptions,["redirectUri","responseType","state","nonce"]).with(objectHelper.blacklist(options,["popupHandler","connection"])),options=this.transactionManager.process(options),this.crossOriginAuthentication.login(options,cb)},Popup.prototype.passwordlessVerify=function(options,cb){var _this=this;return this.client.passwordless.verify(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.username=options.phoneNumber||options.email,options.password=options.verificationCode,delete options.email,delete options.phoneNumber,delete options.verificationCode,delete options.type,_this.client.loginWithResourceOwner(options,cb)}))},Popup.prototype.signupAndLogin=function(options,cb){var _this=this;return this.client.dbConnection.signup(options,(function(err){if(err)return cb(err);_this.loginWithCredentials(options,cb)}))},SilentAuthenticationHandler.create=function(options){return new SilentAuthenticationHandler(options)},SilentAuthenticationHandler.prototype.login=function(usePostMessage,callback){this.handler=new IframeHandler({auth0:this.auth0,url:this.authenticationUrl,eventListenerType:usePostMessage?"message":"load",callback:this.getCallbackHandler(callback,usePostMessage),timeout:this.timeout,eventValidator:this.getEventValidator(),timeoutCallback:function(){callback(null,"#error=timeout&error_description=Timeout+during+authentication+renew.")},usePostMessage:usePostMessage||!1}),this.handler.init()},SilentAuthenticationHandler.prototype.getEventValidator=function(){var _this=this;return{isValid:function(eventData){switch(eventData.event.type){case"message":return eventData.event.origin===_this.postMessageOrigin&&eventData.event.source===_this.handler.iframe.contentWindow&&(!1===_this.postMessageDataType||eventData.event.data.type&&eventData.event.data.type===_this.postMessageDataType);case"load":if("about:"===eventData.sourceObject.contentWindow.location.protocol)return!1;default:return!0}}}},SilentAuthenticationHandler.prototype.getCallbackHandler=function(callback,usePostMessage){return function(eventData){var callbackValue;callbackValue=usePostMessage?"object"==typeof eventData.event.data&&eventData.event.data.hash?eventData.event.data.hash:eventData.event.data:eventData.sourceObject.contentWindow.location.hash,callback(null,callbackValue)}},UsernamePassword.prototype.login=function(options,cb){var url,body;return url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","login"),options.username=options.username||options.email,options=objectHelper.blacklist(options,["email"]),body=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience"]).with(options),body=this.transactionManager.process(body),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},UsernamePassword.prototype.callback=function(formHtml){var div,_document=windowHelper.getDocument();(div=_document.createElement("div")).innerHTML=formHtml,_document.body.appendChild(div).children[0].submit()},HostedPages.prototype.login=function(options,cb){if(windowHelper.getWindow().location.host!==this.baseOptions.domain)throw new Error("This method is meant to be used only inside the Universal Login Page.");var usernamePassword,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(usernamePassword=new UsernamePassword(this.baseOptions)).login(params,(function(err,data){return err?cb(err):usernamePassword.callback(data)}))},HostedPages.prototype.signupAndLogin=function(options,cb){var _this=this;return _this.client.client.dbConnection.signup(options,(function(err){return err?cb(err):_this.login(options,cb)}))},HostedPages.prototype.getSSOData=function(withActiveDirectories,cb){var url,params="";return"function"==typeof withActiveDirectories&&(cb=withActiveDirectories,withActiveDirectories=!1),assert.check(withActiveDirectories,{type:"boolean",message:"withActiveDirectories parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),withActiveDirectories&&(params="?"+lib_stringify({ldaps:1,client_id:this.baseOptions.clientID})),url=urlJoin(this.baseOptions.rootUrl,"user","ssodata",params),this.request.get(url,{noHeaders:!0}).withCredentials().end(wrapCallback(cb))};var noop=function(){},defaults$2={lang:"en",templates:{auth0:function(challenge){var message="code"===challenge.type?"Enter the code shown above":"Solve the formula shown above";return'
\n \n \n
\n'},recaptcha_v2:function(){return'
'},error:function(){return'
Error getting the bot detection challenge. Please contact the system administrator.
'}}};function handleRecaptchaProvider(element,options,challenge){var widgetId=element.hasAttribute("data-wid")&&element.getAttribute("data-wid");function setValue(value){element.querySelector('input[name="captcha"]').value=value||""}if(widgetId)return setValue(),void window.grecaptcha.reset(widgetId);element.innerHTML=options.templates[challenge.provider](challenge);var recaptchaDiv=element.querySelector(".recaptcha");!function(element,lang,callback){var callbackName="recaptchaCallback_"+Math.floor(1000001*Math.random());window[callbackName]=function(){delete window[callbackName],callback()};var script=window.document.createElement("script");script.src="https://www.google.com/recaptcha/api.js?hl="+lang+"&onload="+callbackName,script.async=!0,window.document.body.appendChild(script)}(0,options.lang,(function(){widgetId=window.grecaptcha.render(recaptchaDiv,{callback:setValue,"expired-callback":function(){setValue()},"error-callback":function(){setValue()},sitekey:challenge.siteKey}),element.setAttribute("data-wid",widgetId)}))}var captcha={render:function(auth0Client,element,options,callback){function load(done){done=done||noop,auth0Client.getChallenge((function(err,challenge){return err?(element.innerHTML=options.templates.error(err),done(err)):challenge.required?(element.style.display="","auth0"===challenge.provider?function(element,options,challenge,load){element.innerHTML=options.templates[challenge.provider](challenge),element.querySelector(".captcha-reload").addEventListener("click",(function(e){e.preventDefault(),load()}))}(element,options,challenge,load):"recaptcha_v2"===challenge.provider&&handleRecaptchaProvider(element,options,challenge),void done()):(element.style.display="none",void(element.innerHTML=""))}))}return options=objectHelper.merge(defaults$2).with(options||{}),load(callback),{reload:load,getValue:function(){var captchaInput=element.querySelector('input[name="captcha"]');if(captchaInput)return captchaInput.value}}}};function defaultClock(){return new Date}function WebAuth(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},popupOrigin:{optional:!0,type:"string",message:"popupOrigin is not valid"},leeway:{optional:!0,type:"number",message:"leeway is not valid"},plugins:{optional:!0,type:"array",message:"plugins is not valid"},maxAge:{optional:!0,type:"number",message:"maxAge is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"},_timesToRetryFailedRequests:{optional:!0,type:"number",message:"_timesToRetryFailedRequests option is not valid"}}),options.overrides&&assert.check(options.overrides,{type:"object",message:"overrides option is not valid"},{__tenant:{optional:!0,type:"string",message:"__tenant option is required"},__token_issuer:{optional:!0,type:"string",message:"__token_issuer option is required"},__jwks_uri:{optional:!0,type:"string",message:"__jwks_uri is required"}}),this.baseOptions=options,this.baseOptions.plugins=new PluginHandler(this,this.baseOptions.plugins||[]),this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions._timesToRetryFailedRequests=options._timesToRetryFailedRequests?parseInt(options._timesToRetryFailedRequests,0):0,this.baseOptions.tenant=this.baseOptions.overrides&&this.baseOptions.overrides.__tenant||this.baseOptions.domain.split(".")[0],this.baseOptions.token_issuer=this.baseOptions.overrides&&this.baseOptions.overrides.__token_issuer||"https://"+this.baseOptions.domain+"/",this.baseOptions.jwksURI=this.baseOptions.overrides&&this.baseOptions.overrides.__jwks_uri,this.transactionManager=new TransactionManager(this.baseOptions),this.client=new Authentication(this.baseOptions),this.redirect=new Redirect(this,this.baseOptions),this.popup=new Popup(this,this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(this,this.baseOptions),this.webMessageHandler=new WebMessageHandler(this),this._universalLogin=new HostedPages(this,this.baseOptions),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function PasswordlessAuthentication(request,options){this.baseOptions=options,this.request=request}function DBConnection(request,options){this.baseOptions=options,this.request=request}function Authentication(auth0,options){2===arguments.length?this.auth0=auth0:options=auth0,assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions.rootUrl=this.baseOptions.domain&&0===this.baseOptions.domain.toLowerCase().indexOf("http")?this.baseOptions.domain:"https://"+this.baseOptions.domain,this.request=new RequestBuilder(this.baseOptions),this.passwordless=new PasswordlessAuthentication(this.request,this.baseOptions),this.dbConnection=new DBConnection(this.request,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings}),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function Management(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},token:{type:"string",message:"token option is required"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions.headers={Authorization:"Bearer "+this.baseOptions.token},this.request=new RequestBuilder(this.baseOptions),this.baseOptions.rootUrl=urlJoin("https://"+this.baseOptions.domain,"api","v2")}WebAuth.prototype.parseHash=function(options,cb){var parsedQs,err;cb||"function"!=typeof options?options=options||{}:(cb=options,options={});var _window=windowHelper.getWindow(),hashStr=void 0===options.hash?_window.location.hash:options.hash;if(hashStr=hashStr.replace(/^#?\/?/,""),(parsedQs=lib_parse(hashStr)).hasOwnProperty("error"))return err=error.buildResponse(parsedQs.error,parsedQs.error_description),parsedQs.state&&(err.state=parsedQs.state),cb(err);if(!parsedQs.hasOwnProperty("access_token")&&!parsedQs.hasOwnProperty("id_token")&&!parsedQs.hasOwnProperty("refresh_token"))return cb(null,null);var responseTypes=(this.baseOptions.responseType||options.responseType||"").split(" ");return responseTypes.length>0&&-1!==responseTypes.indexOf("token")&&!parsedQs.hasOwnProperty("access_token")?cb(error.buildResponse("invalid_hash","response_type contains `token`, but the parsed hash does not contain an `access_token` property")):responseTypes.length>0&&-1!==responseTypes.indexOf("id_token")&&!parsedQs.hasOwnProperty("id_token")?cb(error.buildResponse("invalid_hash","response_type contains `id_token`, but the parsed hash does not contain an `id_token` property")):this.validateAuthenticationResponse(options,parsedQs,cb)},WebAuth.prototype.validateAuthenticationResponse=function(options,parsedHash,cb){var _this=this;options.__enableIdPInitiatedLogin=options.__enableIdPInitiatedLogin||options.__enableImpersonation;var state=parsedHash.state,transaction=this.transactionManager.getStoredTransaction(state),transactionState=options.state||transaction&&transaction.state||null,transactionStateMatchesState=transactionState===state;if(!(!state&&!transactionState&&options.__enableIdPInitiatedLogin)&&!transactionStateMatchesState)return cb({error:"invalid_token",errorDescription:"`state` does not match."});var transactionNonce=options.nonce||transaction&&transaction.nonce||null,appState=options.state||transaction&&transaction.appState||null,callback=function(err,payload){if(err)return cb(err);var sub;transaction&&transaction.lastUsedConnection&&(payload&&(sub=payload.sub),_this.ssodataStorage.set(transaction.lastUsedConnection,sub));return cb(null,function(qsParams,appState,token){return{accessToken:qsParams.access_token||null,idToken:qsParams.id_token||null,idTokenPayload:token||null,appState:appState||null,refreshToken:qsParams.refresh_token||null,state:qsParams.state||null,expiresIn:qsParams.expires_in?parseInt(qsParams.expires_in,10):null,tokenType:qsParams.token_type||null,scope:qsParams.scope||null}}(parsedHash,appState,payload))};return parsedHash.id_token?this.validateToken(parsedHash.id_token,transactionNonce,(function(validationError,payload){if(!validationError)return parsedHash.access_token&&payload.at_hash?(new k).validateAccessToken(parsedHash.access_token,"RS256",payload.at_hash,(function(err){return err?callback(error.invalidToken(err.message)):callback(null,payload)})):callback(null,payload);if("invalid_token"!==validationError.error||validationError.errorDescription&&validationError.errorDescription.indexOf("Nonce (nonce) claim value mismatch in the ID token")>-1)return callback(validationError);var decodedToken=(new k).decode(parsedHash.id_token);if("HS256"!==decodedToken.header.alg)return callback(validationError);if((decodedToken.payload.nonce||null)!==transactionNonce)return callback({error:"invalid_token",errorDescription:'Nonce (nonce) claim value mismatch in the ID token; expected "'+transactionNonce+'", found "'+decodedToken.payload.nonce+'"'});if(!parsedHash.access_token){return callback({error:"invalid_token",description:"The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token"})}return _this.client.userInfo(parsedHash.access_token,(function(errUserInfo,profile){return errUserInfo?callback(errUserInfo):callback(null,profile)}))})):callback(null,null)},WebAuth.prototype.validateToken=function(token,nonce,cb){new k({issuer:this.baseOptions.token_issuer,jwksURI:this.baseOptions.jwksURI,audience:this.baseOptions.clientID,leeway:this.baseOptions.leeway||60,maxAge:this.baseOptions.maxAge,__clock:this.baseOptions.__clock||defaultClock}).verify(token,nonce,(function(err,payload){if(err)return cb(error.invalidToken(err.message));cb(null,payload)}))},WebAuth.prototype.renewAuth=function(options,cb){var usePostMessage=!!options.usePostMessage,postMessageDataType=options.postMessageDataType||!1,postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().origin,timeout=options.timeout,_this=this,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","responseType","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params.responseType=params.responseType||"token",params.responseMode=params.responseMode||"fragment",params=this.transactionManager.process(params),assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params.prompt="none",params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType","postMessageOrigin"]),SilentAuthenticationHandler.create({authenticationUrl:this.client.buildAuthorizeUrl(params),postMessageDataType:postMessageDataType,postMessageOrigin:postMessageOrigin,timeout:timeout}).login(usePostMessage,(function(err,hash){if("object"==typeof hash)return cb(err,hash);_this.parseHash({hash:hash},cb)}))},WebAuth.prototype.checkSession=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return"code"===params.responseType?cb({error:"error",error_description:"responseType can't be `code`"}):(options.nonce||(params=this.transactionManager.process(params)),params.redirectUri?(assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType"]),void this.webMessageHandler.run(params,wrapCallback(cb,{forceLegacyError:!0,ignoreCasing:!0}))):cb({error:"error",error_description:"redirectUri can't be empty"}))},WebAuth.prototype.changePassword=function(options,cb){return this.client.dbConnection.changePassword(options,cb)},WebAuth.prototype.passwordlessStart=function(options,cb){var authParams=objectHelper.merge(this.baseOptions,["responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options.authParams);return options.authParams=this.transactionManager.process(authParams),this.client.passwordless.start(options,cb)},WebAuth.prototype.signup=function(options,cb){return this.client.dbConnection.signup(options,cb)},WebAuth.prototype.authorize=function(options){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",windowHelper.redirect(this.client.buildAuthorizeUrl(params))},WebAuth.prototype.signupAndAuthorize=function(options,cb){var _this=this;return this.client.dbConnection.signup(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.realm=options.connection,options.username||(options.username=options.email),_this.client.login(options,cb)}))},WebAuth.prototype.login=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain?(params.connection=params.realm,delete params.realm,this._universalLogin.login(params,cb)):this.crossOriginAuthentication.login(params,cb)},WebAuth.prototype.passwordlessLogin=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);if(params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain)this.passwordlessVerify(params,cb);else{var crossOriginOptions=objectHelper.extend({credentialType:"http://auth0.com/oauth/grant-type/passwordless/otp",realm:params.connection,username:params.email||params.phoneNumber,otp:params.verificationCode},objectHelper.blacklist(params,["connection","email","phoneNumber","verificationCode"]));this.crossOriginAuthentication.login(crossOriginOptions,cb)}},WebAuth.prototype.crossOriginAuthenticationCallback=function(){this.crossOriginVerification()},WebAuth.prototype.crossOriginVerification=function(){this.crossOriginAuthentication.callback()},WebAuth.prototype.logout=function(options){windowHelper.redirect(this.client.buildLogoutUrl(options))},WebAuth.prototype.passwordlessVerify=function(options,cb){var _this=this,params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),params=this.transactionManager.process(params),this.client.passwordless.verify(params,(function(err){return err?cb(err):windowHelper.redirect(_this.client.passwordless.buildVerifyUrl(params))}))},WebAuth.prototype.renderCaptcha=function(element,options,callback){return captcha.render(this.client,element,options,callback)},PasswordlessAuthentication.prototype.buildVerifyUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","protocol","nonce"]).with(options),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client"]),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"passwordless","verify_redirect","?"+qString)},PasswordlessAuthentication.prototype.start=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},send:{type:"string",message:"send option is required",values:["link","code"],value_message:"send is not valid ([link, code])"},phoneNumber:{optional:!0,type:"string",message:"phoneNumber option is required",condition:function(o){return"code"===o.send||!o.email}},email:{optional:!0,type:"string",message:"email option is required",condition:function(o){return"link"===o.send||!o.phoneNumber}},authParams:{optional:!0,type:"object",message:"authParams option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"passwordless","start"),(body=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope"]).with(options)).scope&&(body.authParams=body.authParams||{},body.authParams.scope=body.authParams.scope||body.scope),body.redirectUri&&(body.authParams=body.authParams||{},body.authParams.redirect_uri=body.authParams.redirectUri||body.redirectUri),body.responseType&&(body.authParams=body.authParams||{},body.authParams.response_type=body.authParams.responseType||body.responseType),delete body.redirectUri,delete body.responseType,delete body.scope,body=objectHelper.toSnakeCase(body,["auth0Client","authParams"]),this.request.post(url).send(body).end(wrapCallback(cb))},PasswordlessAuthentication.prototype.verify=function(options,cb){var url,cleanOption;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),cleanOption=objectHelper.pick(options,["connection","verificationCode","phoneNumber","email","auth0Client"]),cleanOption=objectHelper.toSnakeCase(cleanOption,["auth0Client"]),url=urlJoin(this.baseOptions.rootUrl,"passwordless","verify"),this.request.post(url).send(cleanOption).end(wrapCallback(cb))},DBConnection.prototype.signup=function(options,cb){var url,body,metadata;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"},password:{type:"string",message:"password option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","signup"),metadata=(body=objectHelper.merge(this.baseOptions,["clientID","state"]).with(options)).user_metadata||body.userMetadata,body=objectHelper.blacklist(body,["scope","userMetadata","user_metadata"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),metadata&&(body.user_metadata=metadata),this.request.post(url).send(body).end(wrapCallback(cb))},DBConnection.prototype.changePassword=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","change_password"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options,["email","connection"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.buildAuthorizeUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience"]).with(options),assert.check(params,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},redirectUri:{optional:!0,type:"string",message:"redirectUri option is required"},responseType:{type:"string",message:"responseType option is required"},nonce:{type:"string",message:"nonce option is required",condition:function(o){return-1===o.responseType.indexOf("code")&&-1!==o.responseType.indexOf("id_token")}},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params.connection_scope&&assert.isArray(params.connection_scope)&&(params.connection_scope=params.connection_scope.join(",")),params=objectHelper.blacklist(params,["username","popupOptions","domain","tenant","timeout","appState"]),params=objectHelper.toSnakeCase(params,["auth0Client"]),params=parametersWhitelist.oauthAuthorizeParams(this.warn,params),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"authorize","?"+qString)},Authentication.prototype.buildLogoutUrl=function(options){var params,qString;return assert.check(options,{optional:!0,type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID"]).with(options||{}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client","returnTo"]),qString=lib_stringify(objectHelper.blacklist(params,["federated"])),options&&void 0!==options.federated&&!1!==options.federated&&"false"!==options.federated&&(qString+="&federated"),urlJoin(this.baseOptions.rootUrl,"v2","logout","?"+qString)},Authentication.prototype.loginWithDefaultDirectory=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="password",this.oauthToken(options,cb)},Authentication.prototype.login=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},realm:{type:"string",message:"realm option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="http://auth0.com/oauth/grant-type/password-realm",this.oauthToken(options,cb)},Authentication.prototype.oauthToken=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","token"),body=objectHelper.merge(this.baseOptions,["clientID","scope","audience"]).with(options),assert.check(body,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},grantType:{type:"string",message:"grantType option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),body=objectHelper.toSnakeCase(body,["auth0Client"]),body=parametersWhitelist.oauthTokenParams(this.warn,body),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.loginWithResourceOwner=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},connection:{type:"string",message:"connection option is required"},scope:{optional:!0,type:"string",message:"scope option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","ro"),body=objectHelper.merge(this.baseOptions,["clientID","scope"]).with(options,["username","password","scope","connection","device"]),(body=objectHelper.toSnakeCase(body,["auth0Client"])).grant_type=body.grant_type||"password",this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getSSOData=function(withActiveDirectories,cb){if(this.auth0||(this.auth0=new WebAuth(this.baseOptions)),windowHelper.getWindow().location.host===this.baseOptions.domain)return this.auth0._universalLogin.getSSOData(withActiveDirectories,cb);"function"==typeof withActiveDirectories&&(cb=withActiveDirectories),assert.check(cb,{type:"function",message:"cb parameter is not valid"});var clientId=this.baseOptions.clientID,ssodataInformation=this.ssodataStorage.get()||{};this.auth0.checkSession({responseType:"token id_token",scope:"openid profile email",connection:ssodataInformation.lastUsedConnection,timeout:5e3},(function(err,result){return err?"login_required"===err.error?cb(null,{sso:!1}):("consent_required"===err.error&&(err.error_description="Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`."),cb(err,{sso:!1})):ssodataInformation.lastUsedSub&&ssodataInformation.lastUsedSub!==result.idTokenPayload.sub?cb(err,{sso:!1}):cb(null,{lastUsedConnection:{name:ssodataInformation.lastUsedConnection},lastUsedUserID:result.idTokenPayload.sub,lastUsedUsername:result.idTokenPayload.email||result.idTokenPayload.name,lastUsedClientID:clientId,sessionClients:[clientId],sso:!0})}))},Authentication.prototype.userInfo=function(accessToken,cb){var url;return assert.check(accessToken,{type:"string",message:"accessToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"userinfo"),this.request.get(url).set("Authorization","Bearer "+accessToken).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.getChallenge=function(cb){if(assert.check(cb,{type:"function",message:"cb parameter is not valid"}),!this.baseOptions.state)return cb();var url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","challenge");return this.request.post(url).send({state:this.baseOptions.state}).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.delegation=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{grant_type:{type:"string",message:"grant_type option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"delegation"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getUserCountry=function(cb){var url;return assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"user","geoloc","country"),this.request.get(url).end(wrapCallback(cb))},Management.prototype.getUser=function(userId,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.get(url).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserMetadata=function(userId,userMetadata,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(userMetadata,{type:"object",message:"userMetadata parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send({user_metadata:userMetadata}).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserAttributes=function(userId,user,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(user,{type:"object",message:"user parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send(user).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.linkUser=function(userId,secondaryUserToken,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(secondaryUserToken,{type:"string",message:"secondaryUserToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId,"identities"),this.request.post(url).send({link_with:secondaryUserToken}).end(wrapCallback(cb,{ignoreCasing:!0}))};var index={Authentication:Authentication,Management:Management,WebAuth:WebAuth,version:version};export default index;export{Authentication,Management,WebAuth,version}; +//# sourceMappingURL=auth0.min.esm.js.map diff --git a/build/auth0.min.esm.js.map b/build/auth0.min.esm.js.map new file mode 100644 index 00000000..1cc8fbfa --- /dev/null +++ b/build/auth0.min.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"auth0.min.esm.js","sources":["../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../node_modules/component-emitter/index.js","../node_modules/fast-safe-stringify/index.js","../node_modules/superagent/lib/is-object.js","../node_modules/superagent/lib/request-base.js","../node_modules/superagent/lib/utils.js","../node_modules/superagent/lib/response-base.js","../node_modules/superagent/lib/agent-base.js","../node_modules/base64-js/index.js","../node_modules/superagent/lib/client.js","../src/helper/base64_url.js","../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/request-builder.js","../src/helper/window.js","../src/helper/storage/dummy.js","../node_modules/js-cookie/src/js.cookie.js","../src/helper/storage/cookie.js","../src/helper/warn.js","../src/helper/storage/handler.js","../src/helper/storage.js","../src/helper/ssodata.js","../src/helper/error.js","../src/helper/response-handler.js","../src/helper/parameters-whitelist.js","../node_modules/idtoken-verifier/build/idtoken-verifier.esm.js","../src/helper/plugins.js","../src/helper/random.js","../src/web-auth/transaction-manager.js","../src/helper/iframe-handler.js","../src/web-auth/web-message-handler.js","../src/web-auth/cross-origin-authentication.js","../src/web-auth/redirect.js","../src/helper/times.js","../node_modules/winchan/winchan.js","../src/helper/url.js","../src/helper/popup-handler.js","../src/web-auth/popup.js","../src/web-auth/silent-authentication-handler.js","../src/web-auth/username-password.js","../src/web-auth/hosted-pages.js","../src/web-auth/captcha.js","../src/web-auth/index.js","../src/authentication/passwordless-authentication.js","../src/authentication/db-connection.js","../src/authentication/index.js","../src/management/index.js","../src/index.js"],"sourcesContent":["(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","\r\n/**\r\n * Expose `Emitter`.\r\n */\r\n\r\nif (typeof module !== 'undefined') {\r\n module.exports = Emitter;\r\n}\r\n\r\n/**\r\n * Initialize a new `Emitter`.\r\n *\r\n * @api public\r\n */\r\n\r\nfunction Emitter(obj) {\r\n if (obj) return mixin(obj);\r\n};\r\n\r\n/**\r\n * Mixin the emitter properties.\r\n *\r\n * @param {Object} obj\r\n * @return {Object}\r\n * @api private\r\n */\r\n\r\nfunction mixin(obj) {\r\n for (var key in Emitter.prototype) {\r\n obj[key] = Emitter.prototype[key];\r\n }\r\n return obj;\r\n}\r\n\r\n/**\r\n * Listen on the given `event` with `fn`.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.on =\r\nEmitter.prototype.addEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\r\n .push(fn);\r\n return this;\r\n};\r\n\r\n/**\r\n * Adds an `event` listener that will be invoked a single\r\n * time then automatically removed.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.once = function(event, fn){\r\n function on() {\r\n this.off(event, on);\r\n fn.apply(this, arguments);\r\n }\r\n\r\n on.fn = fn;\r\n this.on(event, on);\r\n return this;\r\n};\r\n\r\n/**\r\n * Remove the given callback for `event` or all\r\n * registered callbacks.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.off =\r\nEmitter.prototype.removeListener =\r\nEmitter.prototype.removeAllListeners =\r\nEmitter.prototype.removeEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n\r\n // all\r\n if (0 == arguments.length) {\r\n this._callbacks = {};\r\n return this;\r\n }\r\n\r\n // specific event\r\n var callbacks = this._callbacks['$' + event];\r\n if (!callbacks) return this;\r\n\r\n // remove all handlers\r\n if (1 == arguments.length) {\r\n delete this._callbacks['$' + event];\r\n return this;\r\n }\r\n\r\n // remove specific handler\r\n var cb;\r\n for (var i = 0; i < callbacks.length; i++) {\r\n cb = callbacks[i];\r\n if (cb === fn || cb.fn === fn) {\r\n callbacks.splice(i, 1);\r\n break;\r\n }\r\n }\r\n\r\n // Remove event specific arrays for event types that no\r\n // one is subscribed for to avoid memory leak.\r\n if (callbacks.length === 0) {\r\n delete this._callbacks['$' + event];\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Emit `event` with the given args.\r\n *\r\n * @param {String} event\r\n * @param {Mixed} ...\r\n * @return {Emitter}\r\n */\r\n\r\nEmitter.prototype.emit = function(event){\r\n this._callbacks = this._callbacks || {};\r\n\r\n var args = new Array(arguments.length - 1)\r\n , callbacks = this._callbacks['$' + event];\r\n\r\n for (var i = 1; i < arguments.length; i++) {\r\n args[i - 1] = arguments[i];\r\n }\r\n\r\n if (callbacks) {\r\n callbacks = callbacks.slice(0);\r\n for (var i = 0, len = callbacks.length; i < len; ++i) {\r\n callbacks[i].apply(this, args);\r\n }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Return array of callbacks for `event`.\r\n *\r\n * @param {String} event\r\n * @return {Array}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.listeners = function(event){\r\n this._callbacks = this._callbacks || {};\r\n return this._callbacks['$' + event] || [];\r\n};\r\n\r\n/**\r\n * Check if this emitter has `event` handlers.\r\n *\r\n * @param {String} event\r\n * @return {Boolean}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.hasListeners = function(event){\r\n return !! this.listeners(event).length;\r\n};\r\n","module.exports = stringify\nstringify.default = stringify\nstringify.stable = deterministicStringify\nstringify.stableStringify = deterministicStringify\n\nvar arr = []\nvar replacerStack = []\n\n// Regular stringify\nfunction stringify (obj, replacer, spacer) {\n decirc(obj, '', [], undefined)\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer)\n } else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\nfunction decirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, stack, val)\n }\n } else {\n var keys = Object.keys(val)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n decirc(val[key], key, stack, val)\n }\n }\n stack.pop()\n }\n}\n\n// Stable-stringify\nfunction compareFunction (a, b) {\n if (a < b) {\n return -1\n }\n if (a > b) {\n return 1\n }\n return 0\n}\n\nfunction deterministicStringify (obj, replacer, spacer) {\n var tmp = deterministicDecirc(obj, '', [], undefined) || obj\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer)\n } else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\n\nfunction deterministicDecirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n if (typeof val.toJSON === 'function') {\n return\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, stack, val)\n }\n } else {\n // Create a temporary object in the required way\n var tmp = {}\n var keys = Object.keys(val).sort(compareFunction)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n deterministicDecirc(val[key], key, stack, val)\n tmp[key] = val[key]\n }\n if (parent !== undefined) {\n arr.push([parent, k, val])\n parent[k] = tmp\n } else {\n return tmp\n }\n }\n stack.pop()\n }\n}\n\n// wraps replacer function to handle values we couldn't replace\n// and mark them as [Circular]\nfunction replaceGetterValues (replacer) {\n replacer = replacer !== undefined ? replacer : function (k, v) { return v }\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i]\n if (part[1] === key && part[0] === val) {\n val = '[Circular]'\n replacerStack.splice(i, 1)\n break\n }\n }\n }\n return replacer.call(this, key, val)\n }\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\nfunction isObject(obj) {\n return obj !== null && _typeof(obj) === 'object';\n}\n\nmodule.exports = isObject;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pcy1vYmplY3QuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJvYmoiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7Ozs7Ozs7QUFRQSxTQUFTQSxRQUFULENBQWtCQyxHQUFsQixFQUF1QjtBQUNyQixTQUFPQSxHQUFHLEtBQUssSUFBUixJQUFnQixRQUFPQSxHQUFQLE1BQWUsUUFBdEM7QUFDRDs7QUFFREMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCSCxRQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYW4gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge0Jvb2xlYW59XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBpc09iamVjdChvYmopIHtcbiAgcmV0dXJuIG9iaiAhPT0gbnVsbCAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0Jztcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBpc09iamVjdDtcbiJdfQ==","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Module of mixed-in functions shared between node and client code\n */\nvar isObject = require('./is-object');\n/**\n * Expose `RequestBase`.\n */\n\n\nmodule.exports = RequestBase;\n/**\n * Initialize a new `RequestBase`.\n *\n * @api public\n */\n\nfunction RequestBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in RequestBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.clearTimeout = function () {\n clearTimeout(this._timer);\n clearTimeout(this._responseTimeoutTimer);\n clearTimeout(this._uploadTimeoutTimer);\n delete this._timer;\n delete this._responseTimeoutTimer;\n delete this._uploadTimeoutTimer;\n return this;\n};\n/**\n * Override default response body parser\n *\n * This function will be called to convert incoming data into request.body\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.parse = function (fn) {\n this._parser = fn;\n return this;\n};\n/**\n * Set format of binary response body.\n * In browser valid formats are 'blob' and 'arraybuffer',\n * which return Blob and ArrayBuffer, respectively.\n *\n * In Node all values result in Buffer.\n *\n * Examples:\n *\n * req.get('/')\n * .responseType('blob')\n * .end(callback);\n *\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.responseType = function (val) {\n this._responseType = val;\n return this;\n};\n/**\n * Override default request body serializer\n *\n * This function will be called to convert data set via .send or .attach into payload to send\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.serialize = function (fn) {\n this._serializer = fn;\n return this;\n};\n/**\n * Set timeouts.\n *\n * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time.\n * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections.\n * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off\n *\n * Value of 0 or false means no timeout.\n *\n * @param {Number|Object} ms or {response, deadline}\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.timeout = function (options) {\n if (!options || _typeof(options) !== 'object') {\n this._timeout = options;\n this._responseTimeout = 0;\n this._uploadTimeout = 0;\n return this;\n }\n\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option)) {\n switch (option) {\n case 'deadline':\n this._timeout = options.deadline;\n break;\n\n case 'response':\n this._responseTimeout = options.response;\n break;\n\n case 'upload':\n this._uploadTimeout = options.upload;\n break;\n\n default:\n console.warn('Unknown timeout option', option);\n }\n }\n }\n\n return this;\n};\n/**\n * Set number of retry attempts on error.\n *\n * Failed requests will be retried 'count' times if timeout or err.code >= 500.\n *\n * @param {Number} count\n * @param {Function} [fn]\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.retry = function (count, fn) {\n // Default to 1 if no count passed or true\n if (arguments.length === 0 || count === true) count = 1;\n if (count <= 0) count = 0;\n this._maxRetries = count;\n this._retries = 0;\n this._retryCallback = fn;\n return this;\n};\n\nvar ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT'];\n/**\n * Determine if a request should be retried.\n * (Borrowed from segmentio/superagent-retry)\n *\n * @param {Error} err an error\n * @param {Response} [res] response\n * @returns {Boolean} if segment should be retried\n */\n\nRequestBase.prototype._shouldRetry = function (err, res) {\n if (!this._maxRetries || this._retries++ >= this._maxRetries) {\n return false;\n }\n\n if (this._retryCallback) {\n try {\n var override = this._retryCallback(err, res);\n\n if (override === true) return true;\n if (override === false) return false; // undefined falls back to defaults\n } catch (err_) {\n console.error(err_);\n }\n }\n\n if (res && res.status && res.status >= 500 && res.status !== 501) return true;\n\n if (err) {\n if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout\n\n if (err.timeout && err.code === 'ECONNABORTED') return true;\n if (err.crossDomain) return true;\n }\n\n return false;\n};\n/**\n * Retry request\n *\n * @return {Request} for chaining\n * @api private\n */\n\n\nRequestBase.prototype._retry = function () {\n this.clearTimeout(); // node\n\n if (this.req) {\n this.req = null;\n this.req = this.request();\n }\n\n this._aborted = false;\n this.timedout = false;\n this.timedoutError = null;\n return this._end();\n};\n/**\n * Promise support\n *\n * @param {Function} resolve\n * @param {Function} [reject]\n * @return {Request}\n */\n\n\nRequestBase.prototype.then = function (resolve, reject) {\n var _this = this;\n\n if (!this._fullfilledPromise) {\n var self = this;\n\n if (this._endCalled) {\n console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises');\n }\n\n this._fullfilledPromise = new Promise(function (resolve, reject) {\n self.on('abort', function () {\n if (_this._maxRetries && _this._maxRetries > _this._retries) {\n return;\n }\n\n if (_this.timedout && _this.timedoutError) {\n reject(_this.timedoutError);\n return;\n }\n\n var err = new Error('Aborted');\n err.code = 'ABORTED';\n err.status = _this.status;\n err.method = _this.method;\n err.url = _this.url;\n reject(err);\n });\n self.end(function (err, res) {\n if (err) reject(err);else resolve(res);\n });\n });\n }\n\n return this._fullfilledPromise.then(resolve, reject);\n};\n\nRequestBase.prototype.catch = function (cb) {\n return this.then(undefined, cb);\n};\n/**\n * Allow for extension\n */\n\n\nRequestBase.prototype.use = function (fn) {\n fn(this);\n return this;\n};\n\nRequestBase.prototype.ok = function (cb) {\n if (typeof cb !== 'function') throw new Error('Callback required');\n this._okCallback = cb;\n return this;\n};\n\nRequestBase.prototype._isResponseOK = function (res) {\n if (!res) {\n return false;\n }\n\n if (this._okCallback) {\n return this._okCallback(res);\n }\n\n return res.status >= 200 && res.status < 300;\n};\n/**\n * Get request header `field`.\n * Case-insensitive.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nRequestBase.prototype.get = function (field) {\n return this._header[field.toLowerCase()];\n};\n/**\n * Get case-insensitive header `field` value.\n * This is a deprecated internal API. Use `.get(field)` instead.\n *\n * (getHeader is no longer used internally by the superagent code base)\n *\n * @param {String} field\n * @return {String}\n * @api private\n * @deprecated\n */\n\n\nRequestBase.prototype.getHeader = RequestBase.prototype.get;\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n * Case-insensitive.\n *\n * Examples:\n *\n * req.get('/')\n * .set('Accept', 'application/json')\n * .set('X-API-Key', 'foobar')\n * .end(callback);\n *\n * req.get('/')\n * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n * .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequestBase.prototype.set = function (field, val) {\n if (isObject(field)) {\n for (var key in field) {\n if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]);\n }\n\n return this;\n }\n\n this._header[field.toLowerCase()] = val;\n this.header[field] = val;\n return this;\n};\n/**\n * Remove header `field`.\n * Case-insensitive.\n *\n * Example:\n *\n * req.get('/')\n * .unset('User-Agent')\n * .end(callback);\n *\n * @param {String} field field name\n */\n\n\nRequestBase.prototype.unset = function (field) {\n delete this._header[field.toLowerCase()];\n delete this.header[field];\n return this;\n};\n/**\n * Write the field `name` and `val`, or multiple fields with one object\n * for \"multipart/form-data\" request bodies.\n *\n * ``` js\n * request.post('/upload')\n * .field('foo', 'bar')\n * .end(callback);\n *\n * request.post('/upload')\n * .field({ foo: 'bar', baz: 'qux' })\n * .end(callback);\n * ```\n *\n * @param {String|Object} name name of field\n * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.field = function (name, val) {\n // name should be either a string or an object.\n if (name === null || undefined === name) {\n throw new Error('.field(name, val) name can not be empty');\n }\n\n if (this._data) {\n throw new Error(\".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObject(name)) {\n for (var key in name) {\n if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]);\n }\n\n return this;\n }\n\n if (Array.isArray(val)) {\n for (var i in val) {\n if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]);\n }\n\n return this;\n } // val should be defined now\n\n\n if (val === null || undefined === val) {\n throw new Error('.field(name, val) val can not be empty');\n }\n\n if (typeof val === 'boolean') {\n val = String(val);\n }\n\n this._getFormData().append(name, val);\n\n return this;\n};\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request} request\n * @api public\n */\n\n\nRequestBase.prototype.abort = function () {\n if (this._aborted) {\n return this;\n }\n\n this._aborted = true;\n if (this.xhr) this.xhr.abort(); // browser\n\n if (this.req) this.req.abort(); // node\n\n this.clearTimeout();\n this.emit('abort');\n return this;\n};\n\nRequestBase.prototype._auth = function (user, pass, options, base64Encoder) {\n switch (options.type) {\n case 'basic':\n this.set('Authorization', \"Basic \".concat(base64Encoder(\"\".concat(user, \":\").concat(pass))));\n break;\n\n case 'auto':\n this.username = user;\n this.password = pass;\n break;\n\n case 'bearer':\n // usage would be .auth(accessToken, { type: 'bearer' })\n this.set('Authorization', \"Bearer \".concat(user));\n break;\n\n default:\n break;\n }\n\n return this;\n};\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\n\nRequestBase.prototype.withCredentials = function (on) {\n // This is browser-only functionality. Node side is no-op.\n if (on === undefined) on = true;\n this._withCredentials = on;\n return this;\n};\n/**\n * Set the max redirects to `n`. Does nothing in browser XHR implementation.\n *\n * @param {Number} n\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.redirects = function (n) {\n this._maxRedirects = n;\n return this;\n};\n/**\n * Maximum size of buffered response body, in bytes. Counts uncompressed size.\n * Default 200MB.\n *\n * @param {Number} n number of bytes\n * @return {Request} for chaining\n */\n\n\nRequestBase.prototype.maxResponseSize = function (n) {\n if (typeof n !== 'number') {\n throw new TypeError('Invalid argument');\n }\n\n this._maxResponseSize = n;\n return this;\n};\n/**\n * Convert to a plain javascript object (not JSON string) of scalar properties.\n * Note as this method is designed to return a useful non-this value,\n * it cannot be chained.\n *\n * @return {Object} describing method, url, and data of this request\n * @api public\n */\n\n\nRequestBase.prototype.toJSON = function () {\n return {\n method: this.method,\n url: this.url,\n data: this._data,\n headers: this._header\n };\n};\n/**\n * Send `data` as the request body, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n * // manual json\n * request.post('/user')\n * .type('json')\n * .send('{\"name\":\"tj\"}')\n * .end(callback)\n *\n * // auto json\n * request.post('/user')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // manual x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send('name=tj')\n * .end(callback)\n *\n * // auto x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // defaults to x-www-form-urlencoded\n * request.post('/user')\n * .send('name=tobi')\n * .send('species=ferret')\n * .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n// eslint-disable-next-line complexity\n\n\nRequestBase.prototype.send = function (data) {\n var isObj = isObject(data);\n var type = this._header['content-type'];\n\n if (this._formData) {\n throw new Error(\".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObj && !this._data) {\n if (Array.isArray(data)) {\n this._data = [];\n } else if (!this._isHost(data)) {\n this._data = {};\n }\n } else if (data && this._data && this._isHost(this._data)) {\n throw new Error(\"Can't merge these send calls\");\n } // merge\n\n\n if (isObj && isObject(this._data)) {\n for (var key in data) {\n if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key];\n }\n } else if (typeof data === 'string') {\n // default to x-www-form-urlencoded\n if (!type) this.type('form');\n type = this._header['content-type'];\n\n if (type === 'application/x-www-form-urlencoded') {\n this._data = this._data ? \"\".concat(this._data, \"&\").concat(data) : data;\n } else {\n this._data = (this._data || '') + data;\n }\n } else {\n this._data = data;\n }\n\n if (!isObj || this._isHost(data)) {\n return this;\n } // default to json\n\n\n if (!type) this.type('json');\n return this;\n};\n/**\n * Sort `querystring` by the sort function\n *\n *\n * Examples:\n *\n * // default order\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery()\n * .end(callback)\n *\n * // customized sort function\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery(function(a, b){\n * return a.length - b.length;\n * })\n * .end(callback)\n *\n *\n * @param {Function} sort\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.sortQuery = function (sort) {\n // _sort default to true but otherwise can be a function or boolean\n this._sort = typeof sort === 'undefined' ? true : sort;\n return this;\n};\n/**\n * Compose querystring to append to req.url\n *\n * @api private\n */\n\n\nRequestBase.prototype._finalizeQueryString = function () {\n var query = this._query.join('&');\n\n if (query) {\n this.url += (this.url.includes('?') ? '&' : '?') + query;\n }\n\n this._query.length = 0; // Makes the call idempotent\n\n if (this._sort) {\n var index = this.url.indexOf('?');\n\n if (index >= 0) {\n var queryArr = this.url.slice(index + 1).split('&');\n\n if (typeof this._sort === 'function') {\n queryArr.sort(this._sort);\n } else {\n queryArr.sort();\n }\n\n this.url = this.url.slice(0, index) + '?' + queryArr.join('&');\n }\n }\n}; // For backwards compat only\n\n\nRequestBase.prototype._appendQueryString = function () {\n console.warn('Unsupported');\n};\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\n\nRequestBase.prototype._timeoutError = function (reason, timeout, errno) {\n if (this._aborted) {\n return;\n }\n\n var err = new Error(\"\".concat(reason + timeout, \"ms exceeded\"));\n err.timeout = timeout;\n err.code = 'ECONNABORTED';\n err.errno = errno;\n this.timedout = true;\n this.timedoutError = err;\n this.abort();\n this.callback(err);\n};\n\nRequestBase.prototype._setTimeouts = function () {\n var self = this; // deadline\n\n if (this._timeout && !this._timer) {\n this._timer = setTimeout(function () {\n self._timeoutError('Timeout of ', self._timeout, 'ETIME');\n }, this._timeout);\n } // response timeout\n\n\n if (this._responseTimeout && !this._responseTimeoutTimer) {\n this._responseTimeoutTimer = setTimeout(function () {\n self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT');\n }, this._responseTimeout);\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXF1ZXN0LWJhc2UuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJyZXF1aXJlIiwibW9kdWxlIiwiZXhwb3J0cyIsIlJlcXVlc3RCYXNlIiwib2JqIiwibWl4aW4iLCJrZXkiLCJwcm90b3R5cGUiLCJPYmplY3QiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJjbGVhclRpbWVvdXQiLCJfdGltZXIiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJfdXBsb2FkVGltZW91dFRpbWVyIiwicGFyc2UiLCJmbiIsIl9wYXJzZXIiLCJyZXNwb25zZVR5cGUiLCJ2YWwiLCJfcmVzcG9uc2VUeXBlIiwic2VyaWFsaXplIiwiX3NlcmlhbGl6ZXIiLCJ0aW1lb3V0Iiwib3B0aW9ucyIsIl90aW1lb3V0IiwiX3Jlc3BvbnNlVGltZW91dCIsIl91cGxvYWRUaW1lb3V0Iiwib3B0aW9uIiwiZGVhZGxpbmUiLCJyZXNwb25zZSIsInVwbG9hZCIsImNvbnNvbGUiLCJ3YXJuIiwicmV0cnkiLCJjb3VudCIsImFyZ3VtZW50cyIsImxlbmd0aCIsIl9tYXhSZXRyaWVzIiwiX3JldHJpZXMiLCJfcmV0cnlDYWxsYmFjayIsIkVSUk9SX0NPREVTIiwiX3Nob3VsZFJldHJ5IiwiZXJyIiwicmVzIiwib3ZlcnJpZGUiLCJlcnJfIiwiZXJyb3IiLCJzdGF0dXMiLCJjb2RlIiwiaW5jbHVkZXMiLCJjcm9zc0RvbWFpbiIsIl9yZXRyeSIsInJlcSIsInJlcXVlc3QiLCJfYWJvcnRlZCIsInRpbWVkb3V0IiwidGltZWRvdXRFcnJvciIsIl9lbmQiLCJ0aGVuIiwicmVzb2x2ZSIsInJlamVjdCIsIl9mdWxsZmlsbGVkUHJvbWlzZSIsInNlbGYiLCJfZW5kQ2FsbGVkIiwiUHJvbWlzZSIsIm9uIiwiRXJyb3IiLCJtZXRob2QiLCJ1cmwiLCJlbmQiLCJjYXRjaCIsImNiIiwidW5kZWZpbmVkIiwidXNlIiwib2siLCJfb2tDYWxsYmFjayIsIl9pc1Jlc3BvbnNlT0siLCJnZXQiLCJmaWVsZCIsIl9oZWFkZXIiLCJ0b0xvd2VyQ2FzZSIsImdldEhlYWRlciIsInNldCIsImhlYWRlciIsInVuc2V0IiwibmFtZSIsIl9kYXRhIiwiQXJyYXkiLCJpc0FycmF5IiwiaSIsIlN0cmluZyIsIl9nZXRGb3JtRGF0YSIsImFwcGVuZCIsImFib3J0IiwieGhyIiwiZW1pdCIsIl9hdXRoIiwidXNlciIsInBhc3MiLCJiYXNlNjRFbmNvZGVyIiwidHlwZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJ3aXRoQ3JlZGVudGlhbHMiLCJfd2l0aENyZWRlbnRpYWxzIiwicmVkaXJlY3RzIiwibiIsIl9tYXhSZWRpcmVjdHMiLCJtYXhSZXNwb25zZVNpemUiLCJUeXBlRXJyb3IiLCJfbWF4UmVzcG9uc2VTaXplIiwidG9KU09OIiwiZGF0YSIsImhlYWRlcnMiLCJzZW5kIiwiaXNPYmoiLCJfZm9ybURhdGEiLCJfaXNIb3N0Iiwic29ydFF1ZXJ5Iiwic29ydCIsIl9zb3J0IiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJxdWVyeSIsIl9xdWVyeSIsImpvaW4iLCJpbmRleCIsImluZGV4T2YiLCJxdWVyeUFyciIsInNsaWNlIiwic3BsaXQiLCJfYXBwZW5kUXVlcnlTdHJpbmciLCJfdGltZW91dEVycm9yIiwicmVhc29uIiwiZXJybm8iLCJjYWxsYmFjayIsIl9zZXRUaW1lb3V0cyIsInNldFRpbWVvdXQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7O0FBR0EsSUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsYUFBRCxDQUF4QjtBQUVBOzs7OztBQUlBQyxNQUFNLENBQUNDLE9BQVAsR0FBaUJDLFdBQWpCO0FBRUE7Ozs7OztBQU1BLFNBQVNBLFdBQVQsQ0FBcUJDLEdBQXJCLEVBQTBCO0FBQ3hCLE1BQUlBLEdBQUosRUFBUyxPQUFPQyxLQUFLLENBQUNELEdBQUQsQ0FBWjtBQUNWO0FBRUQ7Ozs7Ozs7OztBQVFBLFNBQVNDLEtBQVQsQ0FBZUQsR0FBZixFQUFvQjtBQUNsQixPQUFLLElBQU1FLEdBQVgsSUFBa0JI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LEVBRXJCLEtBQUtBLFFBRmdCLENBQXhCO0FBR0QsR0FSNkMsQ0FVOUM7OztBQUNBLE1BQUksS0FBS0MsZ0JBQUwsSUFBeUIsQ0FBQyxLQUFLYixxQkFBbkMsRUFBMEQ7QUFDeEQsU0FBS0EscUJBQUwsR0FBNkI0SCxVQUFVLENBQUMsWUFBTTtBQUM1QzFFLE1BQUFBLElBQUksQ0FBQ3FFLGFBQUwsQ0FDRSxzQkFERixFQUVFckUsSUFBSSxDQUFDckMsZ0JBRlAsRUFHRSxXQUhGO0FBS0QsS0FOc0MsRUFNcEMsS0FBS0EsZ0JBTitCLENBQXZDO0FBT0Q7QUFDRixDQXBCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTW9kdWxlIG9mIG1peGVkLWluIGZ1bmN0aW9ucyBzaGFyZWQgYmV0d2VlbiBub2RlIGFuZCBjbGllbnQgY29kZVxuICovXG5jb25zdCBpc09iamVjdCA9IHJlcXVpcmUoJy4vaXMtb2JqZWN0Jyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXF1ZXN0QmFzZWAuXG4gKi9cblxubW9kdWxlLmV4cG9ydHMgPSBSZXF1ZXN0QmFzZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0QmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0QmFzZShvYmopIHtcbiAgaWYgKG9iaikgcmV0dXJuIG1peGluKG9iaik7XG59XG5cbi8qKlxuICogTWl4aW4gdGhlIHByb3RvdHlwZSBwcm9wZXJ0aWVzLlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIG1peGluKG9iaikge1xuICBmb3IgKGNvbnN0IGtleSBpbiBSZXF1ZXN0QmFzZS5wcm90b3R5cGUpIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKFJlcXVlc3RCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVxdWVzdEJhc2UucHJvdG90eXBlW2tleV07XG4gIH1cblxuICByZXR1cm4gb2JqO1xufVxuXG4vKipcbiAqIENsZWFyIHByZXZpb3VzIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5jbGVhclRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3RpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3VwbG9hZFRpbWVvdXRUaW1lcik7XG4gIGRlbGV0ZSB0aGlzLl90aW1lcjtcbiAgZGVsZXRlIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyO1xuICBkZWxldGUgdGhpcy5fdXBsb2FkVGltZW91dFRpbWVyO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogT3ZlcnJpZGUgZGVmYXVsdCByZXNwb25zZSBib2R5IHBhcnNlclxuICpcbiAqIFRoaXMgZnVuY3Rpb24gd2lsbCBiZSBjYWxsZWQgdG8gY29udmVydCBpbmNvbWluZyBkYXRhIGludG8gcmVxdWVzdC5ib2R5XG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnBhcnNlID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fcGFyc2VyID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgZm9ybWF0IG9mIGJpbmFyeSByZXNwb25zZSBib2R5LlxuICogSW4gYnJvd3NlciB2YWxpZCBmb3JtYXRzIGFyZSAnYmxvYicgYW5kICdhcnJheWJ1ZmZlcicsXG4gKiB3aGljaCByZXR1cm4gQmxvYiBhbmQgQXJyYXlCdWZmZXIsIHJlc3BlY3RpdmVseS5cbiAqXG4gKiBJbiBOb2RlIGFsbCB2YWx1ZXMgcmVzdWx0IGluIEJ1ZmZlci5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5yZXNwb25zZVR5cGUoJ2Jsb2InKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB2YWxcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVzcG9uc2VUeXBlID0gZnVuY3Rpb24odmFsKSB7XG4gIHRoaXMuX3Jlc3BvbnNlVHlwZSA9IHZhbDtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIE92ZXJyaWRlIGRlZmF1bHQgcmVxdWVzdCBib2R5IHNlcmlhbGl6ZXJcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYmUgY2FsbGVkIHRvIGNvbnZlcnQgZGF0YSBzZXQgdmlhIC5zZW5kIG9yIC5hdHRhY2ggaW50byBwYXlsb2FkIHRvIHNlbmRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VyaWFsaXplID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fc2VyaWFsaXplciA9IGZuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IHRpbWVvdXRzLlxuICpcbiAqIC0gcmVzcG9uc2UgdGltZW91dCBpcyB0aW1lIGJldHdlZW4gc2VuZGluZyByZXF1ZXN0IGFuZCByZWNlaXZpbmcgdGhlIGZpcnN0IGJ5dGUgb2YgdGhlIHJlc3BvbnNlLiBJbmNsdWRlcyBETlMgYW5kIGNvbm5lY3Rpb24gdGltZS5cbiAqIC0gZGVhZGxpbmUgaXMgdGhlIHRpbWUgZnJvbSBzdGFydCBvZiB0aGUgcmVxdWVzdCB0byByZWNlaXZpbmcgcmVzcG9uc2UgYm9keSBpbiBmdWxsLiBJZiB0aGUgZGVhZGxpbmUgaXMgdG9vIHNob3J0IGxhcmdlIGZpbGVzIG1heSBub3QgbG9hZCBhdCBhbGwgb24gc2xvdyBjb25uZWN0aW9ucy5cbiAqIC0gdXBsb2FkIGlzIHRoZSB0aW1lICBzaW5jZSBsYXN0IGJpdCBvZiBkYXRhIHdhcyBzZW50IG9yIHJlY2VpdmVkLiBUaGlzIHRpbWVvdXQgd29ya3Mgb25seSBpZiBkZWFkbGluZSB0aW1lb3V0IGlzIG9mZlxuICpcbiAqIFZhbHVlIG9mIDAgb3IgZmFsc2UgbWVhbnMgbm8gdGltZW91dC5cbiAqXG4gKiBAcGFyYW0ge051bWJlcnxPYmplY3R9IG1zIG9yIHtyZXNwb25zZSwgZGVhZGxpbmV9XG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnRpbWVvdXQgPSBmdW5jdGlvbihvcHRpb25zKSB7XG4gIGlmICghb3B0aW9ucyB8fCB0eXBlb2Ygb3B0aW9ucyAhPT0gJ29iamVjdCcpIHtcbiAgICB0aGlzLl90aW1lb3V0ID0gb3B0aW9ucztcbiAgICB0aGlzLl9yZXNwb25zZVRpbWVvdXQgPSAwO1xuICAgIHRoaXMuX3VwbG9hZFRpbWVvdXQgPSAwO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZm9yIChjb25zdCBvcHRpb24gaW4gb3B0aW9ucykge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob3B0aW9ucywgb3B0aW9uKSkge1xuICAgICAgc3dpdGNoIChvcHRpb24pIHtcbiAgICAgICAgY2FzZSAnZGVhZGxpbmUnOlxuICAgICAgICAgIHRoaXMuX3RpbWVvdXQgPSBvcHRpb25zLmRlYWRsaW5lO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdyZXNwb25zZSc6XG4gICAgICAgICAgdGhpcy5fcmVzcG9uc2VUaW1lb3V0ID0gb3B0aW9ucy5yZXNwb25zZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAndXBsb2FkJzpcbiAgICAgICAgICB0aGlzLl91cGxvYWRUaW1lb3V0ID0gb3B0aW9ucy51cGxvYWQ7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgY29uc29sZS53YXJuKCdVbmtub3duIHRpbWVvdXQgb3B0aW9uJywgb3B0aW9uKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IG51bWJlciBvZiByZXRyeSBhdHRlbXB0cyBvbiBlcnJvci5cbiAqXG4gKiBGYWlsZWQgcmVxdWVzdHMgd2lsbCBiZSByZXRyaWVkICdjb3VudCcgdGltZXMgaWYgdGltZW91dCBvciBlcnIuY29kZSA+PSA1MDAuXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IGNvdW50XG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnJldHJ5ID0gZnVuY3Rpb24oY291bnQsIGZuKSB7XG4gIC8vIERlZmF1bHQgdG8gMSBpZiBubyBjb3VudCBwYXNzZWQgb3IgdHJ1ZVxuICBpZiAoYXJndW1lbnRzLmxlbmd0aCA9PT0gMCB8fCBjb3VudCA9PT0gdHJ1ZSkgY291bnQgPSAxO1xuICBpZiAoY291bnQgPD0gMCkgY291bnQgPSAwO1xuICB0aGlzLl9tYXhSZXRyaWVzID0gY291bnQ7XG4gIHRoaXMuX3JldHJpZXMgPSAwO1xuICB0aGlzLl9yZXRyeUNhbGxiYWNrID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuY29uc3QgRVJST1JfQ09ERVMgPSBbJ0VDT05OUkVTRVQnLCAnRVRJTUVET1VUJywgJ0VBRERSSU5GTycsICdFU09DS0VUVElNRURPVVQnXTtcblxuLyoqXG4gKiBEZXRlcm1pbmUgaWYgYSByZXF1ZXN0IHNob3VsZCBiZSByZXRyaWVkLlxuICogKEJvcnJvd2VkIGZyb20gc2VnbWVudGlvL3N1cGVyYWdlbnQtcmV0cnkpXG4gKlxuICogQHBhcmFtIHtFcnJvcn0gZXJyIGFuIGVycm9yXG4gKiBAcGFyYW0ge1Jlc3BvbnNlfSBbcmVzXSByZXNwb25zZVxuICogQHJldHVybnMge0Jvb2xlYW59IGlmIHNlZ21lbnQgc2hvdWxkIGJlIHJldHJpZWRcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zaG91bGRSZXRyeSA9IGZ1bmN0aW9uKGVyciwgcmVzKSB7XG4gIGlmICghdGhpcy5fbWF4UmV0cmllcyB8fCB0aGlzLl9yZXRyaWVzKysgPj0gdGhpcy5fbWF4UmV0cmllcykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICh0aGlzLl9yZXRyeUNhbGxiYWNrKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IG92ZXJyaWRlID0gdGhpcy5fcmV0cnlDYWxsYmFjayhlcnIsIHJlcyk7XG4gICAgICBpZiAob3ZlcnJpZGUgPT09IHRydWUpIHJldHVybiB0cnVlO1xuICAgICAgaWYgKG92ZXJyaWRlID09PSBmYWxzZSkgcmV0dXJuIGZhbHNlO1xuICAgICAgLy8gdW5kZWZpbmVkIGZhbGxzIGJhY2sgdG8gZGVmYXVsdHNcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycl8pO1xuICAgIH1cbiAgfVxuXG4gIGlmIChyZXMgJiYgcmVzLnN0YXR1cyAmJiByZXMuc3RhdHVzID49IDUwMCAmJiByZXMuc3RhdHVzICE9PSA1MDEpIHJldHVybiB0cnVlO1xuICBpZiAoZXJyKSB7XG4gICAgaWYgKGVyci5jb2RlICYmIEVSUk9SX0NPREVTLmluY2x1ZGVzKGVyci5jb2RlKSkgcmV0dXJuIHRydWU7XG4gICAgLy8gU3VwZXJhZ2VudCB0aW1lb3V0XG4gICAgaWYgKGVyci50aW1lb3V0ICYmIGVyci5jb2RlID09PSAnRUNPTk5BQk9SVEVEJykgcmV0dXJuIHRydWU7XG4gICAgaWYgKGVyci5jcm9zc0RvbWFpbikgcmV0dXJuIHRydWU7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59O1xuXG4vKipcbiAqIFJldHJ5IHJlcXVlc3RcbiAqXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fcmV0cnkgPSBmdW5jdGlvbigpIHtcbiAgdGhpcy5jbGVhclRpbWVvdXQoKTtcblxuICAvLyBub2RlXG4gIGlmICh0aGlzLnJlcSkge1xuICAgIHRoaXMucmVxID0gbnVsbDtcbiAgICB0aGlzLnJlcSA9IHRoaXMucmVxdWVzdCgpO1xuICB9XG5cbiAgdGhpcy5fYWJvcnRlZCA9IGZhbHNlO1xuICB0aGlzLnRpbWVkb3V0ID0gZmFsc2U7XG4gIHRoaXMudGltZWRvdXRFcnJvciA9IG51bGw7XG5cbiAgcmV0dXJuIHRoaXMuX2VuZCgpO1xufTtcblxuLyoqXG4gKiBQcm9taXNlIHN1cHBvcnRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSByZXNvbHZlXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbcmVqZWN0XVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudGhlbiA9IGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkge1xuICBpZiAoIXRoaXMuX2Z1bGxmaWxsZWRQcm9taXNlKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgaWYgKHRoaXMuX2VuZENhbGxlZCkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnV2FybmluZzogc3VwZXJhZ2VudCByZXF1ZXN0IHdhcyBzZW50IHR3aWNlLCBiZWNhdXNlIGJvdGggLmVuZCgpIGFuZCAudGhlbigpIHdlcmUgY2FsbGVkLiBOZXZlciBjYWxsIC5lbmQoKSBpZiB5b3UgdXNlIHByb21pc2VzJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHNlbGYub24oJ2Fib3J0JywgKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5fbWF4UmV0cmllcyAmJiB0aGlzLl9tYXhSZXRyaWVzID4gdGhpcy5fcmV0cmllcykge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLnRpbWVkb3V0ICYmIHRoaXMudGltZWRvdXRFcnJvcikge1xuICAgICAgICAgIHJlamVjdCh0aGlzLnRpbWVkb3V0RXJyb3IpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGVyciA9IG5ldyBFcnJvcignQWJvcnRlZCcpO1xuICAgICAgICBlcnIuY29kZSA9ICdBQk9SVEVEJztcbiAgICAgICAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICAgICAgICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gICAgICAgIGVyci51cmwgPSB0aGlzLnVybDtcbiAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICB9KTtcbiAgICAgIHNlbGYuZW5kKChlcnIsIHJlcykgPT4ge1xuICAgICAgICBpZiAoZXJyKSByZWplY3QoZXJyKTtcbiAgICAgICAgZWxzZSByZXNvbHZlKHJlcyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZS50aGVuKHJlc29sdmUsIHJlamVjdCk7XG59O1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuY2F0Y2ggPSBmdW5jdGlvbihjYikge1xuICByZXR1cm4gdGhpcy50aGVuKHVuZGVmaW5lZCwgY2IpO1xufTtcblxuLyoqXG4gKiBBbGxvdyBmb3IgZXh0ZW5zaW9uXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnVzZSA9IGZ1bmN0aW9uKGZuKSB7XG4gIGZuKHRoaXMpO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5vayA9IGZ1bmN0aW9uKGNiKSB7XG4gIGlmICh0eXBlb2YgY2IgIT09ICdmdW5jdGlvbicpIHRocm93IG5ldyBFcnJvcignQ2FsbGJhY2sgcmVxdWlyZWQnKTtcbiAgdGhpcy5fb2tDYWxsYmFjayA9IGNiO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5faXNSZXNwb25zZU9LID0gZnVuY3Rpb24ocmVzKSB7XG4gIGlmICghcmVzKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKHRoaXMuX29rQ2FsbGJhY2spIHtcbiAgICByZXR1cm4gdGhpcy5fb2tDYWxsYmFjayhyZXMpO1xuICB9XG5cbiAgcmV0dXJuIHJlcy5zdGF0dXMgPj0gMjAwICYmIHJlcy5zdGF0dXMgPCAzMDA7XG59O1xuXG4vKipcbiAqIEdldCByZXF1ZXN0IGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGRcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLl9oZWFkZXJbZmllbGQudG9Mb3dlckNhc2UoKV07XG59O1xuXG4vKipcbiAqIEdldCBjYXNlLWluc2Vuc2l0aXZlIGhlYWRlciBgZmllbGRgIHZhbHVlLlxuICogVGhpcyBpcyBhIGRlcHJlY2F0ZWQgaW50ZXJuYWwgQVBJLiBVc2UgYC5nZXQoZmllbGQpYCBpbnN0ZWFkLlxuICpcbiAqIChnZXRIZWFkZXIgaXMgbm8gbG9uZ2VyIHVzZWQgaW50ZXJuYWxseSBieSB0aGUgc3VwZXJhZ2VudCBjb2RlIGJhc2UpXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGZpZWxkXG4gKiBAcmV0dXJuIHtTdHJpbmd9XG4gKiBAYXBpIHByaXZhdGVcbiAqIEBkZXByZWNhdGVkXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldEhlYWRlciA9IFJlcXVlc3RCYXNlLnByb3RvdHlwZS5nZXQ7XG5cbi8qKlxuICogU2V0IGhlYWRlciBgZmllbGRgIHRvIGB2YWxgLCBvciBtdWx0aXBsZSBmaWVsZHMgd2l0aCBvbmUgb2JqZWN0LlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoJ0FjY2VwdCcsICdhcHBsaWNhdGlvbi9qc29uJylcbiAqICAgICAgICAuc2V0KCdYLUFQSS1LZXknLCAnZm9vYmFyJylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoeyBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJywgJ1gtQVBJLUtleSc6ICdmb29iYXInIH0pXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd8T2JqZWN0fSBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zZXQgPSBmdW5jdGlvbihmaWVsZCwgdmFsKSB7XG4gIGlmIChpc09iamVjdChmaWVsZCkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBmaWVsZCkge1xuICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChmaWVsZCwga2V5KSlcbiAgICAgICAgdGhpcy5zZXQoa2V5LCBmaWVsZFtrZXldKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRoaXMuX2hlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXSA9IHZhbDtcbiAgdGhpcy5oZWFkZXJbZmllbGRdID0gdmFsO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogUmVtb3ZlIGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlOlxuICpcbiAqICAgICAgcmVxLmdldCgnLycpXG4gKiAgICAgICAgLnVuc2V0KCdVc2VyLUFnZW50JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGQgZmllbGQgbmFtZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudW5zZXQgPSBmdW5jdGlvbihmaWVsZCkge1xuICBkZWxldGUgdGhpcy5faGVhZGVyW2ZpZWxkLnRvTG93ZXJDYXNlKCldO1xuICBkZWxldGUgdGhpcy5oZWFkZXJbZmllbGRdO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogV3JpdGUgdGhlIGZpZWxkIGBuYW1lYCBhbmQgYHZhbGAsIG9yIG11bHRpcGxlIGZpZWxkcyB3aXRoIG9uZSBvYmplY3RcbiAqIGZvciBcIm11bHRpcGFydC9mb3JtLWRhdGFcIiByZXF1ZXN0IGJvZGllcy5cbiAqXG4gKiBgYGAganNcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCgnZm9vJywgJ2JhcicpXG4gKiAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCh7IGZvbzogJ2JhcicsIGJhejogJ3F1eCcgfSlcbiAqICAgLmVuZChjYWxsYmFjayk7XG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ3xPYmplY3R9IG5hbWUgbmFtZSBvZiBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd8QmxvYnxGaWxlfEJ1ZmZlcnxmcy5SZWFkU3RyZWFtfSB2YWwgdmFsdWUgb2YgZmllbGRcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmZpZWxkID0gZnVuY3Rpb24obmFtZSwgdmFsKSB7XG4gIC8vIG5hbWUgc2hvdWxkIGJlIGVpdGhlciBhIHN0cmluZyBvciBhbiBvYmplY3QuXG4gIGlmIChuYW1lID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gbmFtZSkge1xuICAgIHRocm93IG5ldyBFcnJvcignLmZpZWxkKG5hbWUsIHZhbCkgbmFtZSBjYW4gbm90IGJlIGVtcHR5Jyk7XG4gIH1cblxuICBpZiAodGhpcy5fZGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLmZpZWxkKCkgY2FuJ3QgYmUgdXNlZCBpZiAuc2VuZCgpIGlzIHVzZWQuIFBsZWFzZSB1c2Ugb25seSAuc2VuZCgpIG9yIG9ubHkgLmZpZWxkKCkgJiAuYXR0YWNoKClcIlxuICAgICk7XG4gIH1cblxuICBpZiAoaXNPYmplY3QobmFtZSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBuYW1lKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG5hbWUsIGtleSkpXG4gICAgICAgIHRoaXMuZmllbGQoa2V5LCBuYW1lW2tleV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkodmFsKSkge1xuICAgIGZvciAoY29uc3QgaSBpbiB2YWwpIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmFsLCBpKSlcbiAgICAgICAgdGhpcy5maWVsZChuYW1lLCB2YWxbaV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLy8gdmFsIHNob3VsZCBiZSBkZWZpbmVkIG5vd1xuICBpZiAodmFsID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gdmFsKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCcuZmllbGQobmFtZSwgdmFsKSB2YWwgY2FuIG5vdCBiZSBlbXB0eScpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiB2YWwgPT09ICdib29sZWFuJykge1xuICAgIHZhbCA9IFN0cmluZyh2YWwpO1xuICB9XG5cbiAgdGhpcy5fZ2V0Rm9ybURhdGEoKS5hcHBlbmQobmFtZSwgdmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIEFib3J0IHRoZSByZXF1ZXN0LCBhbmQgY2xlYXIgcG90ZW50aWFsIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmFib3J0ID0gZnVuY3Rpb24oKSB7XG4gIGlmICh0aGlzLl9hYm9ydGVkKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICB0aGlzLl9hYm9ydGVkID0gdHJ1ZTtcbiAgaWYgKHRoaXMueGhyKSB0aGlzLnhoci5hYm9ydCgpOyAvLyBicm93c2VyXG4gIGlmICh0aGlzLnJlcSkgdGhpcy5yZXEuYWJvcnQoKTsgLy8gbm9kZVxuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuICB0aGlzLmVtaXQoJ2Fib3J0Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hdXRoID0gZnVuY3Rpb24odXNlciwgcGFzcywgb3B0aW9ucywgYmFzZTY0RW5jb2Rlcikge1xuICBzd2l0Y2ggKG9wdGlvbnMudHlwZSkge1xuICAgIGNhc2UgJ2Jhc2ljJzpcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJhc2ljICR7YmFzZTY0RW5jb2RlcihgJHt1c2VyfToke3Bhc3N9YCl9YCk7XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2F1dG8nOlxuICAgICAgdGhpcy51c2VybmFtZSA9IHVzZXI7XG4gICAgICB0aGlzLnBhc3N3b3JkID0gcGFzcztcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnYmVhcmVyJzogLy8gdXNhZ2Ugd291bGQgYmUgLmF1dGgoYWNjZXNzVG9rZW4sIHsgdHlwZTogJ2JlYXJlcicgfSlcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3VzZXJ9YCk7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgYnJlYWs7XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogRW5hYmxlIHRyYW5zbWlzc2lvbiBvZiBjb29raWVzIHdpdGggeC1kb21haW4gcmVxdWVzdHMuXG4gKlxuICogTm90ZSB0aGF0IGZvciB0aGlzIHRvIHdvcmsgdGhlIG9yaWdpbiBtdXN0IG5vdCBiZVxuICogdXNpbmcgXCJBY2Nlc3MtQ29udHJvbC1BbGxvdy1PcmlnaW5cIiB3aXRoIGEgd2lsZGNhcmQsXG4gKiBhbmQgYWxzbyBtdXN0IHNldCBcIkFjY2Vzcy1Db250cm9sLUFsbG93LUNyZWRlbnRpYWxzXCJcbiAqIHRvIFwidHJ1ZVwiLlxuICpcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLndpdGhDcmVkZW50aWFscyA9IGZ1bmN0aW9uKG9uKSB7XG4gIC8vIFRoaXMgaXMgYnJvd3Nlci1vbmx5IGZ1bmN0aW9uYWxpdHkuIE5vZGUgc2lkZSBpcyBuby1vcC5cbiAgaWYgKG9uID09PSB1bmRlZmluZWQpIG9uID0gdHJ1ZTtcbiAgdGhpcy5fd2l0aENyZWRlbnRpYWxzID0gb247XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgdGhlIG1heCByZWRpcmVjdHMgdG8gYG5gLiBEb2VzIG5vdGhpbmcgaW4gYnJvd3NlciBYSFIgaW1wbGVtZW50YXRpb24uXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IG5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVkaXJlY3RzID0gZnVuY3Rpb24obikge1xuICB0aGlzLl9tYXhSZWRpcmVjdHMgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogTWF4aW11bSBzaXplIG9mIGJ1ZmZlcmVkIHJlc3BvbnNlIGJvZHksIGluIGJ5dGVzLiBDb3VudHMgdW5jb21wcmVzc2VkIHNpemUuXG4gKiBEZWZhdWx0IDIwME1CLlxuICpcbiAqIEBwYXJhbSB7TnVtYmVyfSBuIG51bWJlciBvZiBieXRlc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKi9cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5tYXhSZXNwb25zZVNpemUgPSBmdW5jdGlvbihuKSB7XG4gIGlmICh0eXBlb2YgbiAhPT0gJ251bWJlcicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdJbnZhbGlkIGFyZ3VtZW50Jyk7XG4gIH1cblxuICB0aGlzLl9tYXhSZXNwb25zZVNpemUgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29udmVydCB0byBhIHBsYWluIGphdmFzY3JpcHQgb2JqZWN0IChub3QgSlNPTiBzdHJpbmcpIG9mIHNjYWxhciBwcm9wZXJ0aWVzLlxuICogTm90ZSBhcyB0aGlzIG1ldGhvZCBpcyBkZXNpZ25lZCB0byByZXR1cm4gYSB1c2VmdWwgbm9uLXRoaXMgdmFsdWUsXG4gKiBpdCBjYW5ub3QgYmUgY2hhaW5lZC5cbiAqXG4gKiBAcmV0dXJuIHtPYmplY3R9IGRlc2NyaWJpbmcgbWV0aG9kLCB1cmwsIGFuZCBkYXRhIG9mIHRoaXMgcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudG9KU09OID0gZnVuY3Rpb24oKSB7XG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiB0aGlzLm1ldGhvZCxcbiAgICB1cmw6IHRoaXMudXJsLFxuICAgIGRhdGE6IHRoaXMuX2RhdGEsXG4gICAgaGVhZGVyczogdGhpcy5faGVhZGVyXG4gIH07XG59O1xuXG4vKipcbiAqIFNlbmQgYGRhdGFgIGFzIHRoZSByZXF1ZXN0IGJvZHksIGRlZmF1bHRpbmcgdGhlIGAudHlwZSgpYCB0byBcImpzb25cIiB3aGVuXG4gKiBhbiBvYmplY3QgaXMgZ2l2ZW4uXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICAgICAgLy8gbWFudWFsIGpzb25cbiAqICAgICAgIHJlcXVlc3QucG9zdCgnL3VzZXInKVxuICogICAgICAgICAudHlwZSgnanNvbicpXG4gKiAgICAgICAgIC5zZW5kKCd7XCJuYW1lXCI6XCJ0alwifScpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gYXV0byBqc29uXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gbWFudWFsIHgtd3d3LWZvcm0tdXJsZW5jb2RlZFxuICogICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgIC50eXBlKCdmb3JtJylcbiAqICAgICAgICAgLnNlbmQoJ25hbWU9dGonKVxuICogICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqICAgICAgIC8vIGF1dG8geC13d3ctZm9ybS11cmxlbmNvZGVkXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnR5cGUoJ2Zvcm0nKVxuICogICAgICAgICAuc2VuZCh7IG5hbWU6ICd0aicgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0cyB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoJ25hbWU9dG9iaScpXG4gKiAgICAgICAgLnNlbmQoJ3NwZWNpZXM9ZmVycmV0JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gZGF0YVxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VuZCA9IGZ1bmN0aW9uKGRhdGEpIHtcbiAgY29uc3QgaXNPYmogPSBpc09iamVjdChkYXRhKTtcbiAgbGV0IHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuXG4gIGlmICh0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLnNlbmQoKSBjYW4ndCBiZSB1c2VkIGlmIC5hdHRhY2goKSBvciAuZmllbGQoKSBpcyB1c2VkLiBQbGVhc2UgdXNlIG9ubHkgLnNlbmQoKSBvciBvbmx5IC5maWVsZCgpICYgLmF0dGFjaCgpXCJcbiAgICApO1xuICB9XG5cbiAgaWYgKGlzT2JqICYmICF0aGlzLl9kYXRhKSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSBbXTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLl9pc0hvc3QoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSB7fTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoZGF0YSAmJiB0aGlzLl9kYXRhICYmIHRoaXMuX2lzSG9zdCh0aGlzLl9kYXRhKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIkNhbid0IG1lcmdlIHRoZXNlIHNlbmQgY2FsbHNcIik7XG4gIH1cblxuICAvLyBtZXJnZVxuICBpZiAoaXNPYmogJiYgaXNPYmplY3QodGhpcy5fZGF0YSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGRhdGEsIGtleSkpXG4gICAgICAgIHRoaXMuX2RhdGFba2V5XSA9IGRhdGFba2V5XTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodHlwZW9mIGRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgLy8gZGVmYXVsdCB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAgICBpZiAoIXR5cGUpIHRoaXMudHlwZSgnZm9ybScpO1xuICAgIHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGlmICh0eXBlID09PSAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJykge1xuICAgICAgdGhpcy5fZGF0YSA9IHRoaXMuX2RhdGEgPyBgJHt0aGlzLl9kYXRhfSYke2RhdGF9YCA6IGRhdGE7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2RhdGEgPSAodGhpcy5fZGF0YSB8fCAnJykgKyBkYXRhO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICB0aGlzLl9kYXRhID0gZGF0YTtcbiAgfVxuXG4gIGlmICghaXNPYmogfHwgdGhpcy5faXNIb3N0KGRhdGEpKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvLyBkZWZhdWx0IHRvIGpzb25cbiAgaWYgKCF0eXBlKSB0aGlzLnR5cGUoJ2pzb24nKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNvcnQgYHF1ZXJ5c3RyaW5nYCBieSB0aGUgc29ydCBmdW5jdGlvblxuICpcbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0IG9yZGVyXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeSgpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gY3VzdG9taXplZCBzb3J0IGZ1bmN0aW9uXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeShmdW5jdGlvbihhLCBiKXtcbiAqICAgICAgICAgICByZXR1cm4gYS5sZW5ndGggLSBiLmxlbmd0aDtcbiAqICAgICAgICAgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gc29ydFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zb3J0UXVlcnkgPSBmdW5jdGlvbihzb3J0KSB7XG4gIC8vIF9zb3J0IGRlZmF1bHQgdG8gdHJ1ZSBidXQgb3RoZXJ3aXNlIGNhbiBiZSBhIGZ1bmN0aW9uIG9yIGJvb2xlYW5cbiAgdGhpcy5fc29ydCA9IHR5cGVvZiBzb3J0ID09PSAndW5kZWZpbmVkJyA/IHRydWUgOiBzb3J0O1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29tcG9zZSBxdWVyeXN0cmluZyB0byBhcHBlbmQgdG8gcmVxLnVybFxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuX2ZpbmFsaXplUXVlcnlTdHJpbmcgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgcXVlcnkgPSB0aGlzLl9xdWVyeS5qb2luKCcmJyk7XG4gIGlmIChxdWVyeSkge1xuICAgIHRoaXMudXJsICs9ICh0aGlzLnVybC5pbmNsdWRlcygnPycpID8gJyYnIDogJz8nKSArIHF1ZXJ5O1xuICB9XG5cbiAgdGhpcy5fcXVlcnkubGVuZ3RoID0gMDsgLy8gTWFrZXMgdGhlIGNhbGwgaWRlbXBvdGVudFxuXG4gIGlmICh0aGlzLl9zb3J0KSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLnVybC5pbmRleE9mKCc/Jyk7XG4gICAgaWYgKGluZGV4ID49IDApIHtcbiAgICAgIGNvbnN0IHF1ZXJ5QXJyID0gdGhpcy51cmwuc2xpY2UoaW5kZXggKyAxKS5zcGxpdCgnJicpO1xuICAgICAgaWYgKHR5cGVvZiB0aGlzLl9zb3J0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHF1ZXJ5QXJyLnNvcnQodGhpcy5fc29ydCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBxdWVyeUFyci5zb3J0KCk7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudXJsID0gdGhpcy51cmwuc2xpY2UoMCwgaW5kZXgpICsgJz8nICsgcXVlcnlBcnIuam9pbignJicpO1xuICAgIH1cbiAgfVxufTtcblxuLy8gRm9yIGJhY2t3YXJkcyBjb21wYXQgb25seVxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hcHBlbmRRdWVyeVN0cmluZyA9ICgpID0+IHtcbiAgY29uc29sZS53YXJuKCdVbnN1cHBvcnRlZCcpO1xufTtcblxuLyoqXG4gKiBJbnZva2UgY2FsbGJhY2sgd2l0aCB0aW1lb3V0IGVycm9yLlxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fdGltZW91dEVycm9yID0gZnVuY3Rpb24ocmVhc29uLCB0aW1lb3V0LCBlcnJubykge1xuICBpZiAodGhpcy5fYWJvcnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGVyciA9IG5ldyBFcnJvcihgJHtyZWFzb24gKyB0aW1lb3V0fW1zIGV4Y2VlZGVkYCk7XG4gIGVyci50aW1lb3V0ID0gdGltZW91dDtcbiAgZXJyLmNvZGUgPSAnRUNPTk5BQk9SVEVEJztcbiAgZXJyLmVycm5vID0gZXJybm87XG4gIHRoaXMudGltZWRvdXQgPSB0cnVlO1xuICB0aGlzLnRpbWVkb3V0RXJyb3IgPSBlcnI7XG4gIHRoaXMuYWJvcnQoKTtcbiAgdGhpcy5jYWxsYmFjayhlcnIpO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zZXRUaW1lb3V0cyA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBzZWxmID0gdGhpcztcblxuICAvLyBkZWFkbGluZVxuICBpZiAodGhpcy5fdGltZW91dCAmJiAhdGhpcy5fdGltZXIpIHtcbiAgICB0aGlzLl90aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2VsZi5fdGltZW91dEVycm9yKCdUaW1lb3V0IG9mICcsIHNlbGYuX3RpbWVvdXQsICdFVElNRScpO1xuICAgIH0sIHRoaXMuX3RpbWVvdXQpO1xuICB9XG5cbiAgLy8gcmVzcG9uc2UgdGltZW91dFxuICBpZiAodGhpcy5fcmVzcG9uc2VUaW1lb3V0ICYmICF0aGlzLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZWxmLl90aW1lb3V0RXJyb3IoXG4gICAgICAgICdSZXNwb25zZSB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3Jlc3BvbnNlVGltZW91dCxcbiAgICAgICAgJ0VUSU1FRE9VVCdcbiAgICAgICk7XG4gICAgfSwgdGhpcy5fcmVzcG9uc2VUaW1lb3V0KTtcbiAgfVxufTtcbiJdfQ==","\"use strict\";\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\nexports.type = function (str) {\n return str.split(/ *; */).shift();\n};\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.params = function (str) {\n return str.split(/ *; */).reduce(function (obj, str) {\n var parts = str.split(/ *= */);\n var key = parts.shift();\n var val = parts.shift();\n if (key && val) obj[key] = val;\n return obj;\n }, {});\n};\n/**\n * Parse Link header fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.parseLinks = function (str) {\n return str.split(/ *, */).reduce(function (obj, str) {\n var parts = str.split(/ *; */);\n var url = parts[0].slice(1, -1);\n var rel = parts[1].split(/ *= */)[1].slice(1, -1);\n obj[rel] = url;\n return obj;\n }, {});\n};\n/**\n * Strip content related fields from `header`.\n *\n * @param {Object} header\n * @return {Object} header\n * @api private\n */\n\n\nexports.cleanHeader = function (header, changesOrigin) {\n delete header['content-type'];\n delete header['content-length'];\n delete header['transfer-encoding'];\n delete header.host; // secuirty\n\n if (changesOrigin) {\n delete header.authorization;\n delete header.cookie;\n }\n\n return header;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJleHBvcnRzIiwidHlwZSIsInN0ciIsInNwbGl0Iiwic2hpZnQiLCJwYXJhbXMiLCJyZWR1Y2UiLCJvYmoiLCJwYXJ0cyIsImtleSIsInZhbCIsInBhcnNlTGlua3MiLCJ1cmwiLCJzbGljZSIsInJlbCIsImNsZWFuSGVhZGVyIiwiaGVhZGVyIiwiY2hhbmdlc09yaWdpbiIsImhvc3QiLCJhdXRob3JpemF0aW9uIiwiY29va2llIl0sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7O0FBUUFBLE9BQU8sQ0FBQ0MsSUFBUixHQUFlLFVBQUFDLEdBQUc7QUFBQSxTQUFJQSxHQUFHLENBQUNDLEtBQUosQ0FBVSxPQUFWLEVBQW1CQyxLQUFuQixFQUFKO0FBQUEsQ0FBbEI7QUFFQTs7Ozs7Ozs7O0FBUUFKLE9BQU8sQ0FBQ0ssTUFBUixHQUFpQixVQUFBSCxHQUFHO0FBQUEsU0FDbEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTU0sR0FBRyxHQUFHRCxLQUFLLENBQUNKLEtBQU4sRUFBWjtBQUNBLFFBQU1NLEdBQUcsR0FBR0YsS0FBSyxDQUFDSixLQUFOLEVBQVo7QUFFQSxRQUFJSyxHQUFHLElBQUlDLEdBQVgsRUFBZ0JILEdBQUcsQ0FBQ0UsR0FBRCxDQUFILEdBQVdDLEdBQVg7QUFDaEIsV0FBT0gsR0FBUDtBQUNELEdBUEQsRUFPRyxFQVBILENBRGtCO0FBQUEsQ0FBcEI7QUFVQTs7Ozs7Ozs7O0FBUUFQLE9BQU8sQ0FBQ1csVUFBUixHQUFxQixVQUFBVCxHQUFHO0FBQUEsU0FDdEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTVMsR0FBRyxHQUFHSixLQUFLLENBQUMsQ0FBRCxDQUFMLENBQVNLLEtBQVQsQ0FBZSxDQUFmLEVBQWtCLENBQUMsQ0FBbkIsQ0FBWjtBQUNBLFFBQU1DLEdBQUcsR0FBR04sS0FBSyxDQUFDLENBQUQsQ0FBTCxDQUFTTCxLQUFULENBQWUsT0FBZixFQUF3QixDQUF4QixFQUEyQlUsS0FBM0IsQ0FBaUMsQ0FBakMsRUFBb0MsQ0FBQyxDQUFyQyxDQUFaO0FBQ0FOLElBQUFBLEdBQUcsQ0FBQ08sR0FBRCxDQUFILEdBQVdGLEdBQVg7QUFDQSxXQUFPTCxHQUFQO0FBQ0QsR0FORCxFQU1HLEVBTkgsQ0FEc0I7QUFBQSxDQUF4QjtBQVNBOzs7Ozs7Ozs7QUFRQVAsT0FBTyxDQUFDZSxXQUFSLEdBQXNCLFVBQUNDLE1BQUQsRUFBU0MsYUFBVCxFQUEyQjtBQUMvQyxTQUFPRCxNQUFNLENBQUMsY0FBRCxDQUFiO0FBQ0EsU0FBT0EsTUFBTSxDQUFDLGdCQUFELENBQWI7QUFDQSxTQUFPQSxNQUFNLENBQUMsbUJBQUQsQ0FBYjtBQUNBLFNBQU9BLE1BQU0sQ0FBQ0UsSUFBZCxDQUorQyxDQUsvQzs7QUFDQSxNQUFJRCxhQUFKLEVBQW1CO0FBQ2pCLFdBQU9ELE1BQU0sQ0FBQ0csYUFBZDtBQUNBLFdBQU9ILE1BQU0sQ0FBQ0ksTUFBZDtBQUNEOztBQUVELFNBQU9KLE1BQVA7QUFDRCxDQVpEIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXR1cm4gdGhlIG1pbWUgdHlwZSBmb3IgdGhlIGdpdmVuIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMudHlwZSA9IHN0ciA9PiBzdHIuc3BsaXQoLyAqOyAqLykuc2hpZnQoKTtcblxuLyoqXG4gKiBSZXR1cm4gaGVhZGVyIGZpZWxkIHBhcmFtZXRlcnMuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHN0clxuICogQHJldHVybiB7T2JqZWN0fVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZXhwb3J0cy5wYXJhbXMgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKjsgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo9ICovKTtcbiAgICBjb25zdCBrZXkgPSBwYXJ0cy5zaGlmdCgpO1xuICAgIGNvbnN0IHZhbCA9IHBhcnRzLnNoaWZ0KCk7XG5cbiAgICBpZiAoa2V5ICYmIHZhbCkgb2JqW2tleV0gPSB2YWw7XG4gICAgcmV0dXJuIG9iajtcbiAgfSwge30pO1xuXG4vKipcbiAqIFBhcnNlIExpbmsgaGVhZGVyIGZpZWxkcy5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5leHBvcnRzLnBhcnNlTGlua3MgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKiwgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo7ICovKTtcbiAgICBjb25zdCB1cmwgPSBwYXJ0c1swXS5zbGljZSgxLCAtMSk7XG4gICAgY29uc3QgcmVsID0gcGFydHNbMV0uc3BsaXQoLyAqPSAqLylbMV0uc2xpY2UoMSwgLTEpO1xuICAgIG9ialtyZWxdID0gdXJsO1xuICAgIHJldHVybiBvYmo7XG4gIH0sIHt9KTtcblxuLyoqXG4gKiBTdHJpcCBjb250ZW50IHJlbGF0ZWQgZmllbGRzIGZyb20gYGhlYWRlcmAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IGhlYWRlclxuICogQHJldHVybiB7T2JqZWN0fSBoZWFkZXJcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMuY2xlYW5IZWFkZXIgPSAoaGVhZGVyLCBjaGFuZ2VzT3JpZ2luKSA9PiB7XG4gIGRlbGV0ZSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICBkZWxldGUgaGVhZGVyWydjb250ZW50LWxlbmd0aCddO1xuICBkZWxldGUgaGVhZGVyWyd0cmFuc2Zlci1lbmNvZGluZyddO1xuICBkZWxldGUgaGVhZGVyLmhvc3Q7XG4gIC8vIHNlY3VpcnR5XG4gIGlmIChjaGFuZ2VzT3JpZ2luKSB7XG4gICAgZGVsZXRlIGhlYWRlci5hdXRob3JpemF0aW9uO1xuICAgIGRlbGV0ZSBoZWFkZXIuY29va2llO1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcjtcbn07XG4iXX0=","\"use strict\";\n\n/**\n * Module dependencies.\n */\nvar utils = require('./utils');\n/**\n * Expose `ResponseBase`.\n */\n\n\nmodule.exports = ResponseBase;\n/**\n * Initialize a new `ResponseBase`.\n *\n * @api public\n */\n\nfunction ResponseBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in ResponseBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nResponseBase.prototype.get = function (field) {\n return this.header[field.toLowerCase()];\n};\n/**\n * Set header related properties:\n *\n * - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\n\nResponseBase.prototype._setHeaderProperties = function (header) {\n // TODO: moar!\n // TODO: make this a util\n // content-type\n var ct = header['content-type'] || '';\n this.type = utils.type(ct); // params\n\n var params = utils.params(ct);\n\n for (var key in params) {\n if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key];\n }\n\n this.links = {}; // links\n\n try {\n if (header.link) {\n this.links = utils.parseLinks(header.link);\n }\n } catch (_unused) {// ignore\n }\n};\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n * - .noContent\n * - .badRequest\n * - .unauthorized\n * - .notAcceptable\n * - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\n\nResponseBase.prototype._setStatusProperties = function (status) {\n var type = status / 100 | 0; // status / class\n\n this.statusCode = status;\n this.status = this.statusCode;\n this.statusType = type; // basics\n\n this.info = type === 1;\n this.ok = type === 2;\n this.redirect = type === 3;\n this.clientError = type === 4;\n this.serverError = type === 5;\n this.error = type === 4 || type === 5 ? this.toError() : false; // sugar\n\n this.created = status === 201;\n this.accepted = status === 202;\n this.noContent = status === 204;\n this.badRequest = status === 400;\n this.unauthorized = status === 401;\n this.notAcceptable = status === 406;\n this.forbidden = status === 403;\n this.notFound = status === 404;\n this.unprocessableEntity = status === 422;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS1iYXNlLmpzIl0sIm5hbWVzIjpbInV0aWxzIiwicmVxdWlyZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJSZXNwb25zZUJhc2UiLCJvYmoiLCJtaXhpbiIsImtleSIsInByb3RvdHlwZSIsIk9iamVjdCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImdldCIsImZpZWxkIiwiaGVhZGVyIiwidG9Mb3dlckNhc2UiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsImN0IiwidHlwZSIsInBhcmFtcyIsImxpbmtzIiwibGluayIsInBhcnNlTGlua3MiLCJfc2V0U3RhdHVzUHJvcGVydGllcyIsInN0YXR1cyIsInN0YXR1c0NvZGUiLCJzdGF0dXNUeXBlIiwiaW5mbyIsIm9rIiwicmVkaXJlY3QiLCJjbGllbnRFcnJvciIsInNlcnZlckVycm9yIiwiZXJyb3IiLCJ0b0Vycm9yIiwiY3JlYXRlZCIsImFjY2VwdGVkIiwibm9Db250ZW50IiwiYmFkUmVxdWVzdCIsInVuYXV0aG9yaXplZCIsIm5vdEFjY2VwdGFibGUiLCJmb3JiaWRkZW4iLCJub3RGb3VuZCIsInVucHJvY2Vzc2FibGVFbnRpdHkiXSwibWFwcGluZ3MiOiI7O0FBQUE7OztBQUlBLElBQU1BLEtBQUssR0FBR0MsT0FBTyxDQUFDLFNBQUQsQ0FBckI7QUFFQTs7Ozs7QUFJQUMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCQyxZQUFqQjtBQUVBOzs7Ozs7QUFNQSxTQUFTQSxZQUFULENBQXNCQyxHQUF0QixFQUEyQjtBQUN6QixNQUFJQSxHQUFKLEVBQVMsT0FBT0MsS0FBSyxDQUFDRCxHQUFELENBQVo7QUFDVjtBQUVEOzs7Ozs7Ozs7QUFRQSxTQUFTQyxLQUFULENBQWVELEdBQWYsRUFBb0I7QUFDbEIsT0FBSyxJQUFNRSxHQUFYLElBQWtCSCxZQUFZLENBQUNJLFNBQS9CLEVBQTBDO0FBQ3hDLFFBQUlDLE1BQU0sQ0FBQ0QsU0FBUCxDQUFpQkUsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFD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LEdBQTJCbEIsTUFBTSxLQUFLLEdBQXRDO0FBQ0QsQ0ExQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1vZHVsZSBkZXBlbmRlbmNpZXMuXG4gKi9cblxuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzJyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXNwb25zZUJhc2VgLlxuICovXG5cbm1vZHVsZS5leHBvcnRzID0gUmVzcG9uc2VCYXNlO1xuXG4vKipcbiAqIEluaXRpYWxpemUgYSBuZXcgYFJlc3BvbnNlQmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXNwb25zZUJhc2Uob2JqKSB7XG4gIGlmIChvYmopIHJldHVybiBtaXhpbihvYmopO1xufVxuXG4vKipcbiAqIE1peGluIHRoZSBwcm90b3R5cGUgcHJvcGVydGllcy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBtaXhpbihvYmopIHtcbiAgZm9yIChjb25zdCBrZXkgaW4gUmVzcG9uc2VCYXNlLnByb3RvdHlwZSkge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoUmVzcG9uc2VCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVzcG9uc2VCYXNlLnByb3RvdHlwZVtrZXldO1xuICB9XG5cbiAgcmV0dXJuIG9iajtcbn1cblxuLyoqXG4gKiBHZXQgY2FzZS1pbnNlbnNpdGl2ZSBgZmllbGRgIHZhbHVlLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLmhlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXTtcbn07XG5cbi8qKlxuICogU2V0IGhlYWRlciByZWxhdGVkIHByb3BlcnRpZXM6XG4gKlxuICogICAtIGAudHlwZWAgdGhlIGNvbnRlbnQgdHlwZSB3aXRob3V0IHBhcmFtc1xuICpcbiAqIEEgcmVzcG9uc2Ugb2YgXCJDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9dXRmLThcIlxuICogd2lsbCBwcm92aWRlIHlvdSB3aXRoIGEgYC50eXBlYCBvZiBcInRleHQvcGxhaW5cIi5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gaGVhZGVyXG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLl9zZXRIZWFkZXJQcm9wZXJ0aWVzID0gZnVuY3Rpb24oaGVhZGVyKSB7XG4gIC8vIFRPRE86IG1vYXIhXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIHV0aWxcblxuICAvLyBjb250ZW50LXR5cGVcbiAgY29uc3QgY3QgPSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddIHx8ICcnO1xuICB0aGlzLnR5cGUgPSB1dGlscy50eXBlKGN0KTtcblxuICAvLyBwYXJhbXNcbiAgY29uc3QgcGFyYW1zID0gdXRpbHMucGFyYW1zKGN0KTtcbiAgZm9yIChjb25zdCBrZXkgaW4gcGFyYW1zKSB7XG4gICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChwYXJhbXMsIGtleSkpXG4gICAgICB0aGlzW2tleV0gPSBwYXJhbXNba2V5XTtcbiAgfVxuXG4gIHRoaXMubGlua3MgPSB7fTtcblxuICAvLyBsaW5rc1xuICB0cnkge1xuICAgIGlmIChoZWFkZXIubGluaykge1xuICAgICAgdGhpcy5saW5rcyA9IHV0aWxzLnBhcnNlTGlua3MoaGVhZGVyLmxpbmspO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlXG4gIH1cbn07XG5cbi8qKlxuICogU2V0IGZsYWdzIHN1Y2ggYXMgYC5va2AgYmFzZWQgb24gYHN0YXR1c2AuXG4gKlxuICogRm9yIGV4YW1wbGUgYSAyeHggcmVzcG9uc2Ugd2lsbCBnaXZlIHlvdSBhIGAub2tgIG9mIF9fdHJ1ZV9fXG4gKiB3aGVyZWFzIDV4eCB3aWxsIGJlIF9fZmFsc2VfXyBhbmQgYC5lcnJvcmAgd2lsbCBiZSBfX3RydWVfXy4gVGhlXG4gKiBgLmNsaWVudEVycm9yYCBhbmQgYC5zZXJ2ZXJFcnJvcmAgYXJlIGFsc28gYXZhaWxhYmxlIHRvIGJlIG1vcmVcbiAqIHNwZWNpZmljLCBhbmQgYC5zdGF0dXNUeXBlYCBpcyB0aGUgY2xhc3Mgb2YgZXJyb3IgcmFuZ2luZyBmcm9tIDEuLjVcbiAqIHNvbWV0aW1lcyB1c2VmdWwgZm9yIG1hcHBpbmcgcmVzcG9uZCBjb2xvcnMgZXRjLlxuICpcbiAqIFwic3VnYXJcIiBwcm9wZXJ0aWVzIGFyZSBhbHNvIGRlZmluZWQgZm9yIGNvbW1vbiBjYXNlcy4gQ3VycmVudGx5IHByb3ZpZGluZzpcbiAqXG4gKiAgIC0gLm5vQ29udGVudFxuICogICAtIC5iYWRSZXF1ZXN0XG4gKiAgIC0gLnVuYXV0aG9yaXplZFxuICogICAtIC5ub3RBY2NlcHRhYmxlXG4gKiAgIC0gLm5vdEZvdW5kXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IHN0YXR1c1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVzcG9uc2VCYXNlLnByb3RvdHlwZS5fc2V0U3RhdHVzUHJvcGVydGllcyA9IGZ1bmN0aW9uKHN0YXR1cykge1xuICBjb25zdCB0eXBlID0gKHN0YXR1cyAvIDEwMCkgfCAwO1xuXG4gIC8vIHN0YXR1cyAvIGNsYXNzXG4gIHRoaXMuc3RhdHVzQ29kZSA9IHN0YXR1cztcbiAgdGhpcy5zdGF0dXMgPSB0aGlzLnN0YXR1c0NvZGU7XG4gIHRoaXMuc3RhdHVzVHlwZSA9IHR5cGU7XG5cbiAgLy8gYmFzaWNzXG4gIHRoaXMuaW5mbyA9IHR5cGUgPT09IDE7XG4gIHRoaXMub2sgPSB0eXBlID09PSAyO1xuICB0aGlzLnJlZGlyZWN0ID0gdHlwZSA9PT0gMztcbiAgdGhpcy5jbGllbnRFcnJvciA9IHR5cGUgPT09IDQ7XG4gIHRoaXMuc2VydmVyRXJyb3IgPSB0eXBlID09PSA1O1xuICB0aGlzLmVycm9yID0gdHlwZSA9PT0gNCB8fCB0eXBlID09PSA1ID8gdGhpcy50b0Vycm9yKCkgOiBmYWxzZTtcblxuICAvLyBzdWdhclxuICB0aGlzLmNyZWF0ZWQgPSBzdGF0dXMgPT09IDIwMTtcbiAgdGhpcy5hY2NlcHRlZCA9IHN0YXR1cyA9PT0gMjAyO1xuICB0aGlzLm5vQ29udGVudCA9IHN0YXR1cyA9PT0gMjA0O1xuICB0aGlzLmJhZFJlcXVlc3QgPSBzdGF0dXMgPT09IDQwMDtcbiAgdGhpcy51bmF1dGhvcml6ZWQgPSBzdGF0dXMgPT09IDQwMTtcbiAgdGhpcy5ub3RBY2NlcHRhYmxlID0gc3RhdHVzID09PSA0MDY7XG4gIHRoaXMuZm9yYmlkZGVuID0gc3RhdHVzID09PSA0MDM7XG4gIHRoaXMubm90Rm91bmQgPSBzdGF0dXMgPT09IDQwNDtcbiAgdGhpcy51bnByb2Nlc3NhYmxlRW50aXR5ID0gc3RhdHVzID09PSA0MjI7XG59O1xuIl19","\"use strict\";\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction Agent() {\n this._defaults = [];\n}\n\n['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) {\n // Default setting for all requests from this agent\n Agent.prototype[fn] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this._defaults.push({\n fn: fn,\n args: args\n });\n\n return this;\n };\n});\n\nAgent.prototype._setDefaults = function (req) {\n this._defaults.forEach(function (def) {\n req[def.fn].apply(req, _toConsumableArray(def.args));\n });\n};\n\nmodule.exports = Agent;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hZ2VudC1iYXNlLmpzIl0sIm5hbWVzIjpbIkFnZW50IiwiX2RlZmF1bHRzIiwiZm9yRWFjaCIsImZuIiwicHJvdG90eXBlIiwiYXJncyIsInB1c2giLCJfc2V0RGVmYXVsdHMiLCJyZXEiLCJkZWYiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7OztBQUFBLFNBQVNBLEtBQVQsR0FBaUI7QUFDZixPQUFLQyxTQUFMLEdBQWlCLEVBQWpCO0FBQ0Q7O0FBRUQsQ0FDRSxLQURGLEVBRUUsSUFGRixFQUdFLE1BSEYsRUFJRSxLQUpGLEVBS0UsT0FMRixFQU1FLE1BTkYsRUFPRSxRQVBGLEVBUUUsTUFSRixFQVNFLGlCQVRGLEVBVUUsV0FWRixFQVdFLE9BWEYsRUFZRSxJQVpGLEVBYUUsV0FiRixFQWNFLFNBZEYsRUFlRSxRQWZGLEVBZ0JFLFdBaEJGLEVBaUJFLE9BakJGLEVBa0JFLElBbEJGLEVBbUJFLEtBbkJGLEVBb0JFLEtBcEJGLEVBcUJFLE1BckJGLEVBc0JFLGlCQXRCRixFQXVCRUMsT0F2QkYsQ0F1QlUsVUFBQUMsRUFBRSxFQUFJO0FBQ2Q7QUFDQUgsRUFBQUEsS0FBSyxDQUFDSSxTQUFOLENBQWdCRCxFQUFoQixJQUFzQixZQUFrQjtBQUFBLHNDQUFORSxJQUFNO0FBQU5BLE1BQUFBLElBQU07QUFBQTs7QUFDdEMsU0FBS0osU0FBTCxDQUFlSyxJQUFmLENBQW9CO0FBQUVILE1BQUFBLEVBQUUsRUFBRkEsRUFBRjtBQUFNRSxNQUFBQSxJQUFJLEVBQUpBO0FBQU4sS0FBcEI7O0FBQ0EsV0FBTyxJQUFQO0FBQ0QsR0FIRDtBQUlELENBN0JEOztBQStCQUwsS0FBSyxDQUFDSSxTQUFOLENBQWdCRyxZQUFoQixHQUErQixVQUFTQyxHQUFULEVBQWM7QUFDM0MsT0FBS1AsU0FBTCxDQUFlQyxPQUFmLENBQXVCLFVBQUFPLEdBQUcsRUFBSTtBQUM1QkQsSUFBQUEsR0FBRyxDQUFDQyxHQUFHLENBQUNOLEVBQUwsQ0FBSCxPQUFBSyxHQUFHLHFCQUFZQyxHQUFHLENBQUNKLElBQWhCLEVBQUg7QUFDRCxHQUZEO0FBR0QsQ0FKRDs7QUFNQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxLQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIEFnZW50KCkge1xuICB0aGlzLl9kZWZhdWx0cyA9IFtdO1xufVxuXG5bXG4gICd1c2UnLFxuICAnb24nLFxuICAnb25jZScsXG4gICdzZXQnLFxuICAncXVlcnknLFxuICAndHlwZScsXG4gICdhY2NlcHQnLFxuICAnYXV0aCcsXG4gICd3aXRoQ3JlZGVudGlhbHMnLFxuICAnc29ydFF1ZXJ5JyxcbiAgJ3JldHJ5JyxcbiAgJ29rJyxcbiAgJ3JlZGlyZWN0cycsXG4gICd0aW1lb3V0JyxcbiAgJ2J1ZmZlcicsXG4gICdzZXJpYWxpemUnLFxuICAncGFyc2UnLFxuICAnY2EnLFxuICAna2V5JyxcbiAgJ3BmeCcsXG4gICdjZXJ0JyxcbiAgJ2Rpc2FibGVUTFNDZXJ0cydcbl0uZm9yRWFjaChmbiA9PiB7XG4gIC8vIERlZmF1bHQgc2V0dGluZyBmb3IgYWxsIHJlcXVlc3RzIGZyb20gdGhpcyBhZ2VudFxuICBBZ2VudC5wcm90b3R5cGVbZm5dID0gZnVuY3Rpb24oLi4uYXJncykge1xuICAgIHRoaXMuX2RlZmF1bHRzLnB1c2goeyBmbiwgYXJncyB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbn0pO1xuXG5BZ2VudC5wcm90b3R5cGUuX3NldERlZmF1bHRzID0gZnVuY3Rpb24ocmVxKSB7XG4gIHRoaXMuX2RlZmF1bHRzLmZvckVhY2goZGVmID0+IHtcbiAgICByZXFbZGVmLmZuXSguLi5kZWYuYXJncyk7XG4gIH0pO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSBBZ2VudDtcbiJdfQ==","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Root reference for iframes.\n */\nvar root;\n\nif (typeof window !== 'undefined') {\n // Browser window\n root = window;\n} else if (typeof self === 'undefined') {\n // Other environments\n console.warn('Using browser-only version of superagent in non-browser environment');\n root = void 0;\n} else {\n // Web Worker\n root = self;\n}\n\nvar Emitter = require('component-emitter');\n\nvar safeStringify = require('fast-safe-stringify');\n\nvar RequestBase = require('./request-base');\n\nvar isObject = require('./is-object');\n\nvar ResponseBase = require('./response-base');\n\nvar Agent = require('./agent-base');\n/**\n * Noop.\n */\n\n\nfunction noop() {}\n/**\n * Expose `request`.\n */\n\n\nmodule.exports = function (method, url) {\n // callback\n if (typeof url === 'function') {\n return new exports.Request('GET', method).end(url);\n } // url first\n\n\n if (arguments.length === 1) {\n return new exports.Request('GET', method);\n }\n\n return new exports.Request(method, url);\n};\n\nexports = module.exports;\nvar request = exports;\nexports.Request = Request;\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) {\n return new XMLHttpRequest();\n }\n\n try {\n return new ActiveXObject('Microsoft.XMLHTTP');\n } catch (_unused) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.6.0');\n } catch (_unused2) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.3.0');\n } catch (_unused3) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP');\n } catch (_unused4) {}\n\n throw new Error('Browser-only version of superagent could not find XHR');\n};\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\n\nvar trim = ''.trim ? function (s) {\n return s.trim();\n} : function (s) {\n return s.replace(/(^\\s*|\\s*$)/g, '');\n};\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n if (!isObject(obj)) return obj;\n var pairs = [];\n\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]);\n }\n\n return pairs.join('&');\n}\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n if (val === undefined) return;\n\n if (val === null) {\n pairs.push(encodeURI(key));\n return;\n }\n\n if (Array.isArray(val)) {\n val.forEach(function (v) {\n pushEncodedKeyValuePair(pairs, key, v);\n });\n } else if (isObject(val)) {\n for (var subkey in val) {\n if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, \"\".concat(key, \"[\").concat(subkey, \"]\"), val[subkey]);\n }\n } else {\n pairs.push(encodeURI(key) + '=' + encodeURIComponent(val));\n }\n}\n/**\n * Expose serialization method.\n */\n\n\nrequest.serializeObject = serialize;\n/**\n * Parse the given x-www-form-urlencoded `str`.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseString(str) {\n var obj = {};\n var pairs = str.split('&');\n var pair;\n var pos;\n\n for (var i = 0, len = pairs.length; i < len; ++i) {\n pair = pairs[i];\n pos = pair.indexOf('=');\n\n if (pos === -1) {\n obj[decodeURIComponent(pair)] = '';\n } else {\n obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1));\n }\n }\n\n return obj;\n}\n/**\n * Expose parser.\n */\n\n\nrequest.parseString = parseString;\n/**\n * Default MIME type map.\n *\n * superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n html: 'text/html',\n json: 'application/json',\n xml: 'text/xml',\n urlencoded: 'application/x-www-form-urlencoded',\n form: 'application/x-www-form-urlencoded',\n 'form-data': 'application/x-www-form-urlencoded'\n};\n/**\n * Default serialization map.\n *\n * superagent.serialize['application/xml'] = function(obj){\n * return 'generated xml here';\n * };\n *\n */\n\nrequest.serialize = {\n 'application/x-www-form-urlencoded': serialize,\n 'application/json': safeStringify\n};\n/**\n * Default parsers.\n *\n * superagent.parse['application/xml'] = function(str){\n * return { object parsed from str };\n * };\n *\n */\n\nrequest.parse = {\n 'application/x-www-form-urlencoded': parseString,\n 'application/json': JSON.parse\n};\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n var lines = str.split(/\\r?\\n/);\n var fields = {};\n var index;\n var line;\n var field;\n var val;\n\n for (var i = 0, len = lines.length; i < len; ++i) {\n line = lines[i];\n index = line.indexOf(':');\n\n if (index === -1) {\n // could be empty line, just skip it\n continue;\n }\n\n field = line.slice(0, index).toLowerCase();\n val = trim(line.slice(index + 1));\n fields[field] = val;\n }\n\n return fields;\n}\n/**\n * Check if `mime` is json or has +json structured syntax suffix.\n *\n * @param {String} mime\n * @return {Boolean}\n * @api private\n */\n\n\nfunction isJSON(mime) {\n // should match /json or +json\n // but not /json-seq\n return /[/+]json($|[^-\\w])/.test(mime);\n}\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n * - set flags (.ok, .error, etc)\n * - parse header\n *\n * Examples:\n *\n * Aliasing `superagent` as `request` is nice:\n *\n * request = superagent;\n *\n * We can use the promise-like API, or pass callbacks:\n *\n * request.get('/').end(function(res){});\n * request.get('/', function(res){});\n *\n * Sending data can be chained:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' })\n * .end(function(res){});\n *\n * Or passed to `.send()`:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' }, function(res){});\n *\n * Or passed to `.post()`:\n *\n * request\n * .post('/user', { name: 'tj' })\n * .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n * request\n * .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\n\nfunction Response(req) {\n this.req = req;\n this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers\n\n this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null;\n this.statusText = this.req.xhr.statusText;\n var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n\n if (status === 1223) {\n status = 204;\n }\n\n this._setStatusProperties(status);\n\n this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n this.header = this.headers; // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n // getResponseHeader still works. so we get content-type even if getting\n // other headers fails.\n\n this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n\n this._setHeaderProperties(this.header);\n\n if (this.text === null && req._responseType) {\n this.body = this.xhr.response;\n } else {\n this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response);\n }\n} // eslint-disable-next-line new-cap\n\n\nResponseBase(Response.prototype);\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype._parseBody = function (str) {\n var parse = request.parse[this.type];\n\n if (this.req._parser) {\n return this.req._parser(this, str);\n }\n\n if (!parse && isJSON(this.type)) {\n parse = request.parse['application/json'];\n }\n\n return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null;\n};\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\n\nResponse.prototype.toError = function () {\n var req = this.req;\n var method = req.method;\n var url = req.url;\n var msg = \"cannot \".concat(method, \" \").concat(url, \" (\").concat(this.status, \")\");\n var err = new Error(msg);\n err.status = this.status;\n err.method = method;\n err.url = url;\n return err;\n};\n/**\n * Expose `Response`.\n */\n\n\nrequest.Response = Response;\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n var self = this;\n this._query = this._query || [];\n this.method = method;\n this.url = url;\n this.header = {}; // preserves header name case\n\n this._header = {}; // coerces header names to lowercase\n\n this.on('end', function () {\n var err = null;\n var res = null;\n\n try {\n res = new Response(self);\n } catch (err_) {\n err = new Error('Parser is unable to parse the response');\n err.parse = true;\n err.original = err_; // issue #675: return the raw response if the response parsing fails\n\n if (self.xhr) {\n // ie9 doesn't have 'response' property\n err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails\n\n err.status = self.xhr.status ? self.xhr.status : null;\n err.statusCode = err.status; // backwards-compat only\n } else {\n err.rawResponse = null;\n err.status = null;\n }\n\n return self.callback(err);\n }\n\n self.emit('response', res);\n var new_err;\n\n try {\n if (!self._isResponseOK(res)) {\n new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response');\n }\n } catch (err_) {\n new_err = err_; // ok() callback can throw\n } // #1000 don't catch errors from the callback to avoid double calling it\n\n\n if (new_err) {\n new_err.original = err;\n new_err.response = res;\n new_err.status = res.status;\n self.callback(new_err, res);\n } else {\n self.callback(null, res);\n }\n });\n}\n/**\n * Mixin `Emitter` and `RequestBase`.\n */\n// eslint-disable-next-line new-cap\n\n\nEmitter(Request.prototype); // eslint-disable-next-line new-cap\n\nRequestBase(Request.prototype);\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.xml = 'application/xml';\n *\n * request.post('/')\n * .type('xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * request.post('/')\n * .type('application/xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function (type) {\n this.set('Content-Type', request.types[type] || type);\n return this;\n};\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.json = 'application/json';\n *\n * request.get('/agent')\n * .accept('json')\n * .end(callback);\n *\n * request.get('/agent')\n * .accept('application/json')\n * .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.accept = function (type) {\n this.set('Accept', request.types[type] || type);\n return this;\n};\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} [pass] optional in case of using 'bearer' as type\n * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic')\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.auth = function (user, pass, options) {\n if (arguments.length === 1) pass = '';\n\n if (_typeof(pass) === 'object' && pass !== null) {\n // pass is optional and can be replaced with options\n options = pass;\n pass = '';\n }\n\n if (!options) {\n options = {\n type: typeof btoa === 'function' ? 'basic' : 'auto'\n };\n }\n\n var encoder = function encoder(string) {\n if (typeof btoa === 'function') {\n return btoa(string);\n }\n\n throw new Error('Cannot use basic auth, btoa is not a function');\n };\n\n return this._auth(user, pass, options, encoder);\n};\n/**\n * Add query-string `val`.\n *\n * Examples:\n *\n * request.get('/shoes')\n * .query('size=10')\n * .query({ color: 'blue' })\n *\n * @param {Object|String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.query = function (val) {\n if (typeof val !== 'string') val = serialize(val);\n if (val) this._query.push(val);\n return this;\n};\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `options` (or filename).\n *\n * ``` js\n * request.post('/upload')\n * .attach('content', new Blob(['hey!'], { type: \"text/html\"}))\n * .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String|Object} options\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.attach = function (field, file, options) {\n if (file) {\n if (this._data) {\n throw new Error(\"superagent can't mix .send() and .attach()\");\n }\n\n this._getFormData().append(field, file, options || file.name);\n }\n\n return this;\n};\n\nRequest.prototype._getFormData = function () {\n if (!this._formData) {\n this._formData = new root.FormData();\n }\n\n return this._formData;\n};\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\n\nRequest.prototype.callback = function (err, res) {\n if (this._shouldRetry(err, res)) {\n return this._retry();\n }\n\n var fn = this._callback;\n this.clearTimeout();\n\n if (err) {\n if (this._maxRetries) err.retries = this._retries - 1;\n this.emit('error', err);\n }\n\n fn(err, res);\n};\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\n\nRequest.prototype.crossDomainError = function () {\n var err = new Error('Request has been terminated\\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.');\n err.crossDomain = true;\n err.status = this.status;\n err.method = this.method;\n err.url = this.url;\n this.callback(err);\n}; // This only warns, because the request is still likely to work\n\n\nRequest.prototype.agent = function () {\n console.warn('This is not supported in browser version of superagent');\n return this;\n};\n\nRequest.prototype.ca = Request.prototype.agent;\nRequest.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected\n\nRequest.prototype.write = function () {\n throw new Error('Streaming is not supported in browser version of superagent');\n};\n\nRequest.prototype.pipe = Request.prototype.write;\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * @param {Object} obj host object\n * @return {Boolean} is a host object\n * @api private\n */\n\nRequest.prototype._isHost = function (obj) {\n // Native objects stringify to [object File], [object Blob], [object FormData], etc.\n return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]';\n};\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.end = function (fn) {\n if (this._endCalled) {\n console.warn('Warning: .end() was called twice. This is not supported in superagent');\n }\n\n this._endCalled = true; // store callback\n\n this._callback = fn || noop; // querystring\n\n this._finalizeQueryString();\n\n this._end();\n};\n\nRequest.prototype._setUploadTimeout = function () {\n var self = this; // upload timeout it's wokrs only if deadline timeout is off\n\n if (this._uploadTimeout && !this._uploadTimeoutTimer) {\n this._uploadTimeoutTimer = setTimeout(function () {\n self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT');\n }, this._uploadTimeout);\n }\n}; // eslint-disable-next-line complexity\n\n\nRequest.prototype._end = function () {\n if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called'));\n var self = this;\n this.xhr = request.getXHR();\n var xhr = this.xhr;\n var data = this._formData || this._data;\n\n this._setTimeouts(); // state change\n\n\n xhr.onreadystatechange = function () {\n var readyState = xhr.readyState;\n\n if (readyState >= 2 && self._responseTimeoutTimer) {\n clearTimeout(self._responseTimeoutTimer);\n }\n\n if (readyState !== 4) {\n return;\n } // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n // result in the error \"Could not complete the operation due to error c00c023f\"\n\n\n var status;\n\n try {\n status = xhr.status;\n } catch (_unused5) {\n status = 0;\n }\n\n if (!status) {\n if (self.timedout || self._aborted) return;\n return self.crossDomainError();\n }\n\n self.emit('end');\n }; // progress\n\n\n var handleProgress = function handleProgress(direction, e) {\n if (e.total > 0) {\n e.percent = e.loaded / e.total * 100;\n\n if (e.percent === 100) {\n clearTimeout(self._uploadTimeoutTimer);\n }\n }\n\n e.direction = direction;\n self.emit('progress', e);\n };\n\n if (this.hasListeners('progress')) {\n try {\n xhr.addEventListener('progress', handleProgress.bind(null, 'download'));\n\n if (xhr.upload) {\n xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload'));\n }\n } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n // Reported here:\n // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n }\n }\n\n if (xhr.upload) {\n this._setUploadTimeout();\n } // initiate request\n\n\n try {\n if (this.username && this.password) {\n xhr.open(this.method, this.url, true, this.username, this.password);\n } else {\n xhr.open(this.method, this.url, true);\n }\n } catch (err) {\n // see #1149\n return this.callback(err);\n } // CORS\n\n\n if (this._withCredentials) xhr.withCredentials = true; // body\n\n if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) {\n // serialize stuff\n var contentType = this._header['content-type'];\n\n var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : ''];\n\n if (!_serialize && isJSON(contentType)) {\n _serialize = request.serialize['application/json'];\n }\n\n if (_serialize) data = _serialize(data);\n } // set header fields\n\n\n for (var field in this.header) {\n if (this.header[field] === null) continue;\n if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]);\n }\n\n if (this._responseType) {\n xhr.responseType = this._responseType;\n } // send stuff\n\n\n this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n // We need null here if data is undefined\n\n xhr.send(typeof data === 'undefined' ? null : data);\n};\n\nrequest.agent = function () {\n return new Agent();\n};\n\n['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) {\n Agent.prototype[method.toLowerCase()] = function (url, fn) {\n var req = new request.Request(method, url);\n\n this._setDefaults(req);\n\n if (fn) {\n req.end(fn);\n }\n\n return req;\n };\n});\nAgent.prototype.del = Agent.prototype.delete;\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.get = function (url, data, fn) {\n var req = request('GET', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.head = function (url, data, fn) {\n var req = request('HEAD', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * OPTIONS query to `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.options = function (url, data, fn) {\n var req = request('OPTIONS', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * DELETE `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nfunction del(url, data, fn) {\n var req = request('DELETE', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n}\n\nrequest.del = del;\nrequest.delete = del;\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function (url, data, fn) {\n var req = request('PATCH', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.post = function (url, data, fn) {\n var req = request('POST', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.put = function (url, data, fn) {\n var req = request('PUT', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jbGllbnQuanMiXSwibmFtZXMiOlsicm9vdCIsIndpbmRvdyIsInNlbGYiLCJjb25zb2xlIiwid2FybiIsIkVtaXR0ZXIiLCJyZXF1aXJlIiwic2FmZVN0cmluZ2lmeSIsIlJlcXVlc3RCYXNlIiwiaXNPYmplY3QiLCJSZXNwb25zZUJhc2UiLCJBZ2VudCIsIm5vb3AiLCJtb2R1bGUiLCJleHBvcnRzIiwibWV0aG9kIiwidXJsIiwiUmVxdWVzdCIsImVuZCIsImFyZ3VtZW50cyIsImxlbmd0aCIsInJlcXVlc3QiLCJnZXRYSFIiLCJYTUxIdHRwUmVxdWVzdCIsImxvY2F0aW9uIiwicHJvdG9jb2wiLCJBY3RpdmVYT2JqZWN0IiwiRXJyb3IiLCJ0cmltIiwicyIsInJlcGxhY2UiLCJzZXJpYWxpemUiLCJvYmoiLCJwYWlycyIsImtleSIsIk9iamVjdCIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsInB1c2hFbmNvZGVkS2V5VmFsdWVQYWlyIiwiam9pbiIsInZhbCIsInVuZGVmaW5lZCIsInB1c2giLCJlbmNvZGVVUkkiLCJBcnJheSIsImlzQXJyYXkiLCJmb3JFYWNoIiwidiIsInN1YmtleSIsImVuY29kZVVSSUNvbXBvbmVudCIsInNlcmlhbGl6ZU9iamVjdCIsInBhcnNlU3RyaW5nIiwic3RyIiwic3BsaXQiLCJwYWlyIiwicG9zIiwiaSIsImxlbiIsImluZGV4T2YiLCJkZWNvZGVVUklDb21wb25lbnQiLCJzbGljZSIsInR5cGVzIiwiaHRtbCIsImpzb24iLCJ4bWwiLCJ1cmxlbmNvZGVkIiwiZm9ybSIsInBhcnNlIiwiSlNPTiIsInBhcnNlSGVhZGVyIiwibGluZXMiLCJmaWVsZHMiLCJpbmRleCIsImxpbmUiLCJmaWVsZCIsInRvTG93ZXJDYXNlIiwiaXNKU09OIiwibWltZSIsInRlc3QiLCJSZXNwb25zZSIsInJlcSIsInhociIsInRleHQiLCJyZXNwb25zZVR5cGUiLCJyZXNwb25zZVRleHQiLCJzdGF0dXNUZXh0Iiwic3RhdHVzIiwiX3NldFN0YXR1c1Byb3BlcnRpZXMiLCJoZWFkZXJzIiwiZ2V0QWxsUmVzcG9uc2VIZWFkZXJzIiwiaGVhZGVyIiwiZ2V0UmVzcG9uc2VIZWFkZXIiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsIl9yZXNwb25zZVR5cGUiLCJib2R5IiwicmVzcG9uc2UiLCJfcGFyc2VCb2R5IiwidHlwZSIsIl9wYXJzZXIiLCJ0b0Vycm9yIiwibXNnIiwiZXJyIiwiX3F1ZXJ5IiwiX2hlYWRlciIsIm9uIiwicmVzIiwiZXJyXyIsIm9yaWdpbmFsIiwicmF3UmVzcG9uc2UiLCJzdGF0dXNDb2RlIiwiY2FsbGJhY2siLCJlbWl0IiwibmV3X2VyciIsIl9pc1Jlc3BvbnNlT0siLCJzZXQiLCJhY2NlcHQiLCJhdXRoIiwidXNlciIsInBhc3MiLCJvcHRpb25zIiwiYnRvYSIsImVuY29kZXIiLCJzdHJpbmciLCJfYXV0aCIsInF1ZXJ5IiwiYXR0YWNoIiwiZmlsZSIsIl9kYXRhIiwiX2dldEZvcm1EYXRhIiwiYXBwZW5kIiwibmFtZSIsIl9mb3JtRGF0YSIsIkZvcm1EYXRhIiwiX3Nob3VsZFJldHJ5IiwiX3JldHJ5IiwiZm4iLCJfY2FsbGJhY2siLCJjbGVhclRpbWVvdXQiLCJfbWF4UmV0cmllcyIsInJldHJpZXMiLCJfcmV0cmllcyIsImNyb3NzRG9tYWluRXJyb3IiLCJjcm9zc0RvbWFpbiIsImFnZW50IiwiY2EiLCJidWZmZXIiLCJ3cml0ZSIsInBpcGUiLCJfaXNIb3N0IiwidG9TdHJpbmciLCJfZW5kQ2FsbGVkIiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJfZW5kIiwiX3NldFVwbG9hZFRpbWVvdXQiLCJfdXBsb2FkVGltZW91dCIsIl91cGxvYWRUaW1lb3V0VGltZXIiLCJzZXRUaW1lb3V0IiwiX3RpbWVvdXRFcnJvciIsIl9hYm9ydGVkIiwiZGF0YSIsIl9zZXRUaW1lb3V0cyIsIm9ucmVhZHlzdGF0ZWNoYW5nZSIsInJlYWR5U3RhdGUiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJ0aW1lZG91dCIsImhhbmRsZVByb2dyZXNzIiwiZGlyZWN0aW9uIiwiZSIsInRvdGFsIiwicGVyY2VudCIsImxvYWRlZCIsImhhc0xpc3RlbmVycyIsImFkZEV2ZW50TGlzdGVuZXIiLCJiaW5kIiwidXBsb2FkIiwidXNlcm5hbWUiLCJwYXNzd29yZCIsIm9wZW4iLCJfd2l0aENyZWRlbnRpYWxzIiwid2l0aENyZWRlbnRpYWxzIiwiY29udGVudFR5cGUiLCJfc2VyaWFsaXplciIsInNldFJlcXVlc3RIZWFkZXIiLCJzZW5kIiwiX3NldERlZmF1bHRzIiwiZGVsIiwiZGVsZXRlIiwiZ2V0IiwiaGVhZCIsInBhdGNoIiwicG9zdCIsInB1dCJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7QUFJQSxJQUFJQSxJQUFKOztBQUNBLElBQUksT0FBT0MsTUFBUCxLQUFrQixXQUF0QixFQUFtQztBQUNqQztBQUNBRCxFQUFBQSxJQUFJLEdBQUdDLE1BQVA7QUFDRCxDQUhELE1BR08sSUFBSSxPQUFPQyxJQUFQLEtBQWdCLFdBQXBCLEVBQWlDO0FBQ3RDO0FBQ0FDLEVBQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUNFLHFFQURGO0FBR0FKLEVBQUFBLElBQUksU0FBSjtBQUNELENBTk0sTUFNQTtBQUNMO0FBQ0FBLEVBQUFBLElBQUksR0FBR0UsSUFBUDtBQUNEOztBQUVELElBQU1HLE9BQU8sR0FBR0MsT0FBTyxDQUFDLG1CQUFELENBQXZCOztBQUNBLElBQU1DLGFBQWEsR0FBR0QsT0FBTyxDQUFDLHFCQUFELENBQTdCOztBQUNBLElBQU1FLFdBQVcsR0FBR0YsT0FBTyxDQUFDLGdCQUFELENBQTNCOztBQUNBLElBQU1HLFFBQVEsR0FBR0gsT0FBTyxDQUFDLGFBQUQsQ0FBeEI7O0FBQ0EsSUFBTUksWUFBWSxHQUFHSixPQUFPLENBQUMsaUJBQUQsQ0FBNUI7O0FBQ0EsSUFBTUssS0FBSyxHQUFHTCxPQUFPLENBQUMsY0FBRCxDQUFyQjtBQUVBOzs7OztBQUlBLFNBQVNNLElBQVQsR0FBZ0IsQ0FBRTtBQUVsQjs7Ozs7QUFJ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cmVuY2UgZm9yIGlmcmFtZXMuXG4gKi9cblxubGV0IHJvb3Q7XG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgLy8gQnJvd3NlciB3aW5kb3dcbiAgcm9vdCA9IHdpbmRvdztcbn0gZWxzZSBpZiAodHlwZW9mIHNlbGYgPT09ICd1bmRlZmluZWQnKSB7XG4gIC8vIE90aGVyIGVudmlyb25tZW50c1xuICBjb25zb2xlLndhcm4oXG4gICAgJ1VzaW5nIGJyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgaW4gbm9uLWJyb3dzZXIgZW52aXJvbm1lbnQnXG4gICk7XG4gIHJvb3QgPSB0aGlzO1xufSBlbHNlIHtcbiAgLy8gV2ViIFdvcmtlclxuICByb290ID0gc2VsZjtcbn1cblxuY29uc3QgRW1pdHRlciA9IHJlcXVpcmUoJ2NvbXBvbmVudC1lbWl0dGVyJyk7XG5jb25zdCBzYWZlU3RyaW5naWZ5ID0gcmVxdWlyZSgnZmFzdC1zYWZlLXN0cmluZ2lmeScpO1xuY29uc3QgUmVxdWVzdEJhc2UgPSByZXF1aXJlKCcuL3JlcXVlc3QtYmFzZScpO1xuY29uc3QgaXNPYmplY3QgPSByZXF1aXJlKCcuL2lzLW9iamVjdCcpO1xuY29uc3QgUmVzcG9uc2VCYXNlID0gcmVxdWlyZSgnLi9yZXNwb25zZS1iYXNlJyk7XG5jb25zdCBBZ2VudCA9IHJlcXVpcmUoJy4vYWdlbnQtYmFzZScpO1xuXG4vKipcbiAqIE5vb3AuXG4gKi9cblxuZnVuY3Rpb24gbm9vcCgpIHt9XG5cbi8qKlxuICogRXhwb3NlIGByZXF1ZXN0YC5cbiAqL1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKG1ldGhvZCwgdXJsKSB7XG4gIC8vIGNhbGxiYWNrXG4gIGlmICh0eXBlb2YgdXJsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIG5ldyBleHBvcnRzLlJlcXVlc3QoJ0dFVCcsIG1ldGhvZCkuZW5kKHVybCk7XG4gIH1cblxuICAvLyB1cmwgZmlyc3RcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHtcbiAgICByZXR1cm4gbmV3IGV4cG9ydHMuUmVxdWVzdCgnR0VUJywgbWV0aG9kKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgZXhwb3J0cy5SZXF1ZXN0KG1ldGhvZCwgdXJsKTtcbn07XG5cbmV4cG9ydHMgPSBtb2R1bGUuZXhwb3J0cztcblxuY29uc3QgcmVxdWVzdCA9IGV4cG9ydHM7XG5cbmV4cG9ydHMuUmVxdWVzdCA9IFJlcXVlc3Q7XG5cbi8qKlxuICogRGV0ZXJtaW5lIFhIUi5cbiAqL1xuXG5yZXF1ZXN0LmdldFhIUiA9ICgpID0+IHtcbiAgaWYgKFxuICAgIHJvb3QuWE1MSHR0cFJlcXVlc3QgJiZcbiAgICAoIXJvb3QubG9jYXRpb24gfHxcbiAgICAgIHJvb3QubG9jYXRpb24ucHJvdG9jb2wgIT09ICdmaWxlOicgfHxcbiAgICAgICFyb290LkFjdGl2ZVhPYmplY3QpXG4gICkge1xuICAgIHJldHVybiBuZXcgWE1MSHR0cFJlcXVlc3QoKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgcmV0dXJuIG5ldyBBY3RpdmVYT2JqZWN0KCdNaWNyb3NvZnQuWE1MSFRUUCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjYuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjMuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQJyk7XG4gIH0gY2F0Y2gge31cblxuICB0aHJvdyBuZXcgRXJyb3IoJ0Jyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgY291bGQgbm90IGZpbmQgWEhSJyk7XG59O1xuXG4vKipcbiAqIFJlbW92ZXMgbGVhZGluZyBhbmQgdHJhaWxpbmcgd2hpdGVzcGFjZSwgYWRkZWQgdG8gc3VwcG9ydCBJRS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc1xuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuY29uc3QgdHJpbSA9ICcnLnRyaW0gPyBzID0+IHMudHJpbSgpIDogcyA9PiBzLnJlcGxhY2UoLyheXFxzKnxcXHMqJCkvZywgJycpO1xuXG4vKipcbiAqIFNlcmlhbGl6ZSB0aGUgZ2l2ZW4gYG9iamAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9ialxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gc2VyaWFsaXplKG9iaikge1xuICBpZiAoIWlzT2JqZWN0KG9iaikpIHJldHVybiBvYmo7XG4gIGNvbnN0IHBhaXJzID0gW107XG4gIGZvciAoY29uc3Qga2V5IGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBrZXkpKVxuICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGtleSwgb2JqW2tleV0pO1xuICB9XG5cbiAgcmV0dXJuIHBhaXJzLmpvaW4oJyYnKTtcbn1cblxuLyoqXG4gKiBIZWxwcyAnc2VyaWFsaXplJyB3aXRoIHNlcmlhbGl6aW5nIGFycmF5cy5cbiAqIE11dGF0ZXMgdGhlIHBhaXJzIGFycmF5LlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IHBhaXJzXG4gKiBAcGFyYW0ge1N0cmluZ30ga2V5XG4gKiBAcGFyYW0ge01peGVkfSB2YWxcbiAqL1xuXG5mdW5jdGlvbiBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2YWwpIHtcbiAgaWYgKHZhbCA9PT0gdW5kZWZpbmVkKSByZXR1cm47XG4gIGlmICh2YWwgPT09IG51bGwpIHtcbiAgICBwYWlycy5wdXNoKGVuY29kZVVSSShrZXkpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheSh2YWwpKSB7XG4gICAgdmFsLmZvckVhY2godiA9PiB7XG4gICAgICBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2KTtcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc09iamVjdCh2YWwpKSB7XG4gICAgZm9yIChjb25zdCBzdWJrZXkgaW4gdmFsKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHZhbCwgc3Via2V5KSlcbiAgICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGAke2tleX1bJHtzdWJrZXl9XWAsIHZhbFtzdWJrZXldKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcGFpcnMucHVzaChlbmNvZGVVUkkoa2V5KSArICc9JyArIGVuY29kZVVSSUNvbXBvbmVudCh2YWwpKTtcbiAgfVxufVxuXG4vKipcbiAqIEV4cG9zZSBzZXJpYWxpemF0aW9uIG1ldGhvZC5cbiAqL1xuXG5yZXF1ZXN0LnNlcmlhbGl6ZU9iamVjdCA9IHNlcmlhbGl6ZTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4geC13d3ctZm9ybS11cmxlbmNvZGVkIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgY29uc3QgcGFpcnMgPSBzdHIuc3BsaXQoJyYnKTtcbiAgbGV0IHBhaXI7XG4gIGxldCBwb3M7XG5cbiAgZm9yIChsZXQgaSA9IDAsIGxlbiA9IHBhaXJzLmxlbmd0aDsgaSA8IGxlbjsgKytpKSB7XG4gICAgcGFpciA9IHBhaXJzW2ldO1xuICAgIHBvcyA9IHBhaXIuaW5kZXhPZignPScpO1xuICAgIGlmIChwb3MgPT09IC0xKSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIpXSA9ICcnO1xuICAgIH0gZWxzZSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIuc2xpY2UoMCwgcG9zKSldID0gZGVjb2RlVVJJQ29tcG9uZW50KFxuICAgICAgICBwYWlyLnNsaWNlKHBvcyArIDEpXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbi8qKlxuICogRXhwb3NlIHBhcnNlci5cbiAqL1xuXG5yZXF1ZXN0LnBhcnNlU3RyaW5nID0gcGFyc2VTdHJpbmc7XG5cbi8qKlxuICogRGVmYXVsdCBNSU1FIHR5cGUgbWFwLlxuICpcbiAqICAgICBzdXBlcmFnZW50LnR5cGVzLnhtbCA9ICdhcHBsaWNhdGlvbi94bWwnO1xuICpcbiAqL1xuXG5yZXF1ZXN0LnR5cGVzID0ge1xuICBodG1sOiAndGV4dC9odG1sJyxcbiAganNvbjogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICB4bWw6ICd0ZXh0L3htbCcsXG4gIHVybGVuY29kZWQ6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnLFxuICBmb3JtOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyxcbiAgJ2Zvcm0tZGF0YSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG59O1xuXG4vKipcbiAqIERlZmF1bHQgc2VyaWFsaXphdGlvbiBtYXAuXG4gKlxuICogICAgIHN1cGVyYWdlbnQuc2VyaWFsaXplWydhcHBsaWNhdGlvbi94bWwnXSA9IGZ1bmN0aW9uKG9iail7XG4gKiAgICAgICByZXR1cm4gJ2dlbmVyYXRlZCB4bWwgaGVyZSc7XG4gKiAgICAgfTtcbiAqXG4gKi9cblxucmVxdWVzdC5zZXJpYWxpemUgPSB7XG4gICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnOiBzZXJpYWxpemUsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogc2FmZVN0cmluZ2lmeVxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcnNlcnMuXG4gKlxuICogICAgIHN1cGVyYWdlbnQucGFyc2VbJ2FwcGxpY2F0aW9uL3htbCddID0gZnVuY3Rpb24oc3RyKXtcbiAqICAgICAgIHJldHVybiB7IG9iamVjdCBwYXJzZWQgZnJvbSBzdHIgfTtcbiAqICAgICB9O1xuICpcbiAqL1xuXG5yZXF1ZXN0LnBhcnNlID0ge1xuICAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJzogcGFyc2VTdHJpbmcsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogSlNPTi5wYXJzZVxufTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gaGVhZGVyIGBzdHJgIGludG9cbiAqIGFuIG9iamVjdCBjb250YWluaW5nIHRoZSBtYXBwZWQgZmllbGRzLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlSGVhZGVyKHN0cikge1xuICBjb25zdCBsaW5lcyA9IHN0ci5zcGxpdCgvXFxyP1xcbi8pO1xuICBjb25zdCBmaWVsZHMgPSB7fTtcbiAgbGV0IGluZGV4O1xuICBsZXQgbGluZTtcbiAgbGV0IGZpZWxkO1xuICBsZXQgdmFsO1xuXG4gIGZvciAobGV0IGkgPSAwLCBsZW4gPSBsaW5lcy5sZW5ndGg7IGkgPCBsZW47ICsraSkge1xuICAgIGxpbmUgPSBsaW5lc1tpXTtcbiAgICBpbmRleCA9IGxpbmUuaW5kZXhPZignOicpO1xuICAgIGlmIChpbmRleCA9PT0gLTEpIHtcbiAgICAgIC8vIGNvdWxkIGJlIGVtcHR5IGxpbmUsIGp1c3Qgc2tpcCBpdFxuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgZmllbGQgPSBsaW5lLnNsaWNlKDAsIGluZGV4KS50b0xvd2VyQ2FzZSgpO1xuICAgIHZhbCA9IHRyaW0obGluZS5zbGljZShpbmRleCArIDEpKTtcbiAgICBmaWVsZHNbZmllbGRdID0gdmFsO1xuICB9XG5cbiAgcmV0dXJuIGZpZWxkcztcbn1cblxuLyoqXG4gKiBDaGVjayBpZiBgbWltZWAgaXMganNvbiBvciBoYXMgK2pzb24gc3RydWN0dXJlZCBzeW50YXggc3VmZml4LlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBtaW1lXG4gKiBAcmV0dXJuIHtCb29sZWFufVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gaXNKU09OKG1pbWUpIHtcbiAgLy8gc2hvdWxkIG1hdGNoIC9qc29uIG9yICtqc29uXG4gIC8vIGJ1dCBub3QgL2pzb24tc2VxXG4gIHJldHVybiAvWy8rXWpzb24oJHxbXi1cXHddKS8udGVzdChtaW1lKTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXNwb25zZWAgd2l0aCB0aGUgZ2l2ZW4gYHhocmAuXG4gKlxuICogIC0gc2V0IGZsYWdzICgub2ssIC5lcnJvciwgZXRjKVxuICogIC0gcGFyc2UgaGVhZGVyXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogIEFsaWFzaW5nIGBzdXBlcmFnZW50YCBhcyBgcmVxdWVzdGAgaXMgbmljZTpcbiAqXG4gKiAgICAgIHJlcXVlc3QgPSBzdXBlcmFnZW50O1xuICpcbiAqICBXZSBjYW4gdXNlIHRoZSBwcm9taXNlLWxpa2UgQVBJLCBvciBwYXNzIGNhbGxiYWNrczpcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJykuZW5kKGZ1bmN0aW9uKHJlcyl7fSk7XG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJywgZnVuY3Rpb24ocmVzKXt9KTtcbiAqXG4gKiAgU2VuZGluZyBkYXRhIGNhbiBiZSBjaGFpbmVkOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqICBPciBwYXNzZWQgdG8gYC5zZW5kKClgOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogIE9yIHBhc3NlZCB0byBgLnBvc3QoKWA6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqIE9yIGZ1cnRoZXIgcmVkdWNlZCB0byBhIHNpbmdsZSBjYWxsIGZvciBzaW1wbGUgY2FzZXM6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogQHBhcmFtIHtYTUxIVFRQUmVxdWVzdH0geGhyXG4gKiBAcGFyYW0ge09iamVjdH0gb3B0aW9uc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gUmVzcG9uc2UocmVxKSB7XG4gIHRoaXMucmVxID0gcmVxO1xuICB0aGlzLnhociA9IHRoaXMucmVxLnhocjtcbiAgLy8gcmVzcG9uc2VUZXh0IGlzIGFjY2Vzc2libGUgb25seSBpZiByZXNwb25zZVR5cGUgaXMgJycgb3IgJ3RleHQnIGFuZCBvbiBvbGRlciBicm93c2Vyc1xuICB0aGlzLnRleHQgPVxuICAgICh0aGlzLnJlcS5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgICAgKHRoaXMueGhyLnJlc3BvbnNlVHlwZSA9PT0gJycgfHwgdGhpcy54aHIucmVzcG9uc2VUeXBlID09PSAndGV4dCcpKSB8fFxuICAgIHR5cGVvZiB0aGlzLnhoci5yZXNwb25zZVR5cGUgPT09ICd1bmRlZmluZWQnXG4gICAgICA/IHRoaXMueGhyLnJlc3BvbnNlVGV4dFxuICAgICAgOiBudWxsO1xuICB0aGlzLnN0YXR1c1RleHQgPSB0aGlzLnJlcS54aHIuc3RhdHVzVGV4dDtcbiAgbGV0IHsgc3RhdHVzIH0gPSB0aGlzLnhocjtcbiAgLy8gaGFuZGxlIElFOSBidWc6IGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTAwNDY5NzIvbXNpZS1yZXR1cm5zLXN0YXR1cy1jb2RlLW9mLTEyMjMtZm9yLWFqYXgtcmVxdWVzdFxuICBpZiAoc3RhdHVzID09PSAxMjIzKSB7XG4gICAgc3RhdHVzID0gMjA0O1xuICB9XG5cbiAgdGhpcy5fc2V0U3RhdHVzUHJvcGVydGllcyhzdGF0dXMpO1xuICB0aGlzLmhlYWRlcnMgPSBwYXJzZUhlYWRlcih0aGlzLnhoci5nZXRBbGxSZXNwb25zZUhlYWRlcnMoKSk7XG4gIHRoaXMuaGVhZGVyID0gdGhpcy5oZWFkZXJzO1xuICAvLyBnZXRBbGxSZXNwb25zZUhlYWRlcnMgc29tZXRpbWVzIGZhbHNlbHkgcmV0dXJucyBcIlwiIGZvciBDT1JTIHJlcXVlc3RzLCBidXRcbiAgLy8gZ2V0UmVzcG9uc2VIZWFkZXIgc3RpbGwgd29ya3MuIHNvIHdlIGdldCBjb250ZW50LXR5cGUgZXZlbiBpZiBnZXR0aW5nXG4gIC8vIG90aGVyIGhlYWRlcnMgZmFpbHMuXG4gIHRoaXMuaGVhZGVyWydjb250ZW50LXR5cGUnXSA9IHRoaXMueGhyLmdldFJlc3BvbnNlSGVhZGVyKCdjb250ZW50LXR5cGUnKTtcbiAgdGhpcy5fc2V0SGVhZGVyUHJvcGVydGllcyh0aGlzLmhlYWRlcik7XG5cbiAgaWYgKHRoaXMudGV4dCA9PT0gbnVsbCAmJiByZXEuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHRoaXMuYm9keSA9IHRoaXMueGhyLnJlc3BvbnNlO1xuICB9IGVsc2Uge1xuICAgIHRoaXMuYm9keSA9XG4gICAgICB0aGlzLnJlcS5tZXRob2QgPT09ICdIRUFEJ1xuICAgICAgICA/IG51bGxcbiAgICAgICAgOiB0aGlzLl9wYXJzZUJvZHkodGhpcy50ZXh0ID8gdGhpcy50ZXh0IDogdGhpcy54aHIucmVzcG9uc2UpO1xuICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXNwb25zZUJhc2UoUmVzcG9uc2UucHJvdG90eXBlKTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gYm9keSBgc3RyYC5cbiAqXG4gKiBVc2VkIGZvciBhdXRvLXBhcnNpbmcgb2YgYm9kaWVzLiBQYXJzZXJzXG4gKiBhcmUgZGVmaW5lZCBvbiB0aGUgYHN1cGVyYWdlbnQucGFyc2VgIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtNaXhlZH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlc3BvbnNlLnByb3RvdHlwZS5fcGFyc2VCb2R5ID0gZnVuY3Rpb24oc3RyKSB7XG4gIGxldCBwYXJzZSA9IHJlcXVlc3QucGFyc2VbdGhpcy50eXBlXTtcbiAgaWYgKHRoaXMucmVxLl9wYXJzZXIpIHtcbiAgICByZXR1cm4gdGhpcy5yZXEuX3BhcnNlcih0aGlzLCBzdHIpO1xuICB9XG5cbiAgaWYgKCFwYXJzZSAmJiBpc0pTT04odGhpcy50eXBlKSkge1xuICAgIHBhcnNlID0gcmVxdWVzdC5wYXJzZVsnYXBwbGljYXRpb24vanNvbiddO1xuICB9XG5cbiAgcmV0dXJuIHBhcnNlICYmIHN0ciAmJiAoc3RyLmxlbmd0aCA+IDAgfHwgc3RyIGluc3RhbmNlb2YgT2JqZWN0KVxuICAgID8gcGFyc2Uoc3RyKVxuICAgIDogbnVsbDtcbn07XG5cbi8qKlxuICogUmV0dXJuIGFuIGBFcnJvcmAgcmVwcmVzZW50YXRpdmUgb2YgdGhpcyByZXNwb25zZS5cbiAqXG4gKiBAcmV0dXJuIHtFcnJvcn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVzcG9uc2UucHJvdG90eXBlLnRvRXJyb3IgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgeyByZXEgfSA9IHRoaXM7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSByZXE7XG4gIGNvbnN0IHsgdXJsIH0gPSByZXE7XG5cbiAgY29uc3QgbXNnID0gYGNhbm5vdCAke21ldGhvZH0gJHt1cmx9ICgke3RoaXMuc3RhdHVzfSlgO1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IobXNnKTtcbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gbWV0aG9kO1xuICBlcnIudXJsID0gdXJsO1xuXG4gIHJldHVybiBlcnI7XG59O1xuXG4vKipcbiAqIEV4cG9zZSBgUmVzcG9uc2VgLlxuICovXG5cbnJlcXVlc3QuUmVzcG9uc2UgPSBSZXNwb25zZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0YCB3aXRoIHRoZSBnaXZlbiBgbWV0aG9kYCBhbmQgYHVybGAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IG1ldGhvZFxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0KG1ldGhvZCwgdXJsKSB7XG4gIGNvbnN0IHNlbGYgPSB0aGlzO1xuICB0aGlzLl9xdWVyeSA9IHRoaXMuX3F1ZXJ5IHx8IFtdO1xuICB0aGlzLm1ldGhvZCA9IG1ldGhvZDtcbiAgdGhpcy51cmwgPSB1cmw7XG4gIHRoaXMuaGVhZGVyID0ge307IC8vIHByZXNlcnZlcyBoZWFkZXIgbmFtZSBjYXNlXG4gIHRoaXMuX2hlYWRlciA9IHt9OyAvLyBjb2VyY2VzIGhlYWRlciBuYW1lcyB0byBsb3dlcmNhc2VcbiAgdGhpcy5vbignZW5kJywgKCkgPT4ge1xuICAgIGxldCBlcnIgPSBudWxsO1xuICAgIGxldCByZXMgPSBudWxsO1xuXG4gICAgdHJ5IHtcbiAgICAgIHJlcyA9IG5ldyBSZXNwb25zZShzZWxmKTtcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBlcnIgPSBuZXcgRXJyb3IoJ1BhcnNlciBpcyB1bmFibGUgdG8gcGFyc2UgdGhlIHJlc3BvbnNlJyk7XG4gICAgICBlcnIucGFyc2UgPSB0cnVlO1xuICAgICAgZXJyLm9yaWdpbmFsID0gZXJyXztcbiAgICAgIC8vIGlzc3VlICM2NzU6IHJldHVybiB0aGUgcmF3IHJlc3BvbnNlIGlmIHRoZSByZXNwb25zZSBwYXJzaW5nIGZhaWxzXG4gICAgICBpZiAoc2VsZi54aHIpIHtcbiAgICAgICAgLy8gaWU5IGRvZXNuJ3QgaGF2ZSAncmVzcG9uc2UnIHByb3BlcnR5XG4gICAgICAgIGVyci5yYXdSZXNwb25zZSA9XG4gICAgICAgICAgdHlwZW9mIHNlbGYueGhyLnJlc3BvbnNlVHlwZSA9PT0gJ3VuZGVmaW5lZCdcbiAgICAgICAgICAgID8gc2VsZi54aHIucmVzcG9uc2VUZXh0XG4gICAgICAgICAgICA6IHNlbGYueGhyLnJlc3BvbnNlO1xuICAgICAgICAvLyBpc3N1ZSAjODc2OiByZXR1cm4gdGhlIGh0dHAgc3RhdHVzIGNvZGUgaWYgdGhlIHJlc3BvbnNlIHBhcnNpbmcgZmFpbHNcbiAgICAgICAgZXJyLnN0YXR1cyA9IHNlbGYueGhyLnN0YXR1cyA/IHNlbGYueGhyLnN0YXR1cyA6IG51bGw7XG4gICAgICAgIGVyci5zdGF0dXNDb2RlID0gZXJyLnN0YXR1czsgLy8gYmFja3dhcmRzLWNvbXBhdCBvbmx5XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBlcnIucmF3UmVzcG9uc2UgPSBudWxsO1xuICAgICAgICBlcnIuc3RhdHVzID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNlbGYuY2FsbGJhY2soZXJyKTtcbiAgICB9XG5cbiAgICBzZWxmLmVtaXQoJ3Jlc3BvbnNlJywgcmVzKTtcblxuICAgIGxldCBuZXdfZXJyO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXNlbGYuX2lzUmVzcG9uc2VPSyhyZXMpKSB7XG4gICAgICAgIG5ld19lcnIgPSBuZXcgRXJyb3IoXG4gICAgICAgICAgcmVzLnN0YXR1c1RleHQgfHwgcmVzLnRleHQgfHwgJ1Vuc3VjY2Vzc2Z1bCBIVFRQIHJlc3BvbnNlJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycl8pIHtcbiAgICAgIG5ld19lcnIgPSBlcnJfOyAvLyBvaygpIGNhbGxiYWNrIGNhbiB0aHJvd1xuICAgIH1cblxuICAgIC8vICMxMDAwIGRvbid0IGNhdGNoIGVycm9ycyBmcm9tIHRoZSBjYWxsYmFjayB0byBhdm9pZCBkb3VibGUgY2FsbGluZyBpdFxuICAgIGlmIChuZXdfZXJyKSB7XG4gICAgICBuZXdfZXJyLm9yaWdpbmFsID0gZXJyO1xuICAgICAgbmV3X2Vyci5yZXNwb25zZSA9IHJlcztcbiAgICAgIG5ld19lcnIuc3RhdHVzID0gcmVzLnN0YXR1cztcbiAgICAgIHNlbGYuY2FsbGJhY2sobmV3X2VyciwgcmVzKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2VsZi5jYWxsYmFjayhudWxsLCByZXMpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogTWl4aW4gYEVtaXR0ZXJgIGFuZCBgUmVxdWVzdEJhc2VgLlxuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5FbWl0dGVyKFJlcXVlc3QucHJvdG90eXBlKTtcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXF1ZXN0QmFzZShSZXF1ZXN0LnByb3RvdHlwZSk7XG5cbi8qKlxuICogU2V0IENvbnRlbnQtVHlwZSB0byBgdHlwZWAsIG1hcHBpbmcgdmFsdWVzIGZyb20gYHJlcXVlc3QudHlwZXNgLlxuICpcbiAqIEV4YW1wbGVzOlxuICpcbiAqICAgICAgc3VwZXJhZ2VudC50eXBlcy54bWwgPSAnYXBwbGljYXRpb24veG1sJztcbiAqXG4gKiAgICAgIHJlcXVlc3QucG9zdCgnLycpXG4gKiAgICAgICAgLnR5cGUoJ3htbCcpXG4gKiAgICAgICAgLnNlbmQoeG1sc3RyaW5nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvJylcbiAqICAgICAgICAudHlwZSgnYXBwbGljYXRpb24veG1sJylcbiAqICAgICAgICAuc2VuZCh4bWxzdHJpbmcpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHR5cGVcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS50eXBlID0gZnVuY3Rpb24odHlwZSkge1xuICB0aGlzLnNldCgnQ29udGVudC1UeXBlJywgcmVxdWVzdC50eXBlc1t0eXBlXSB8fCB0eXBlKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNldCBBY2NlcHQgdG8gYHR5cGVgLCBtYXBwaW5nIHZhbHVlcyBmcm9tIGByZXF1ZXN0LnR5cGVzYC5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHN1cGVyYWdlbnQudHlwZXMuanNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJztcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvYWdlbnQnKVxuICogICAgICAgIC5hY2NlcHQoJ2pzb24nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5nZXQoJy9hZ2VudCcpXG4gKiAgICAgICAgLmFjY2VwdCgnYXBwbGljYXRpb24vanNvbicpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGFjY2VwdFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmFjY2VwdCA9IGZ1bmN0aW9uKHR5cGUpIHtcbiAgdGhpcy5zZXQoJ0FjY2VwdCcsIHJlcXVlc3QudHlwZXNbdHlwZV0gfHwgdHlwZSk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgQXV0aG9yaXphdGlvbiBmaWVsZCB2YWx1ZSB3aXRoIGB1c2VyYCBhbmQgYHBhc3NgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1c2VyXG4gKiBAcGFyYW0ge1N0cmluZ30gW3Bhc3NdIG9wdGlvbmFsIGluIGNhc2Ugb2YgdXNpbmcgJ2JlYXJlcicgYXMgdHlwZVxuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMgd2l0aCAndHlwZScgcHJvcGVydHkgJ2F1dG8nLCAnYmFzaWMnIG9yICdiZWFyZXInIChkZWZhdWx0ICdiYXNpYycpXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuYXV0aCA9IGZ1bmN0aW9uKHVzZXIsIHBhc3MsIG9wdGlvbnMpIHtcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHBhc3MgPSAnJztcbiAgaWYgKHR5cGVvZiBwYXNzID09PSAnb2JqZWN0JyAmJiBwYXNzICE9PSBudWxsKSB7XG4gICAgLy8gcGFzcyBpcyBvcHRpb25hbCBhbmQgY2FuIGJlIHJlcGxhY2VkIHdpdGggb3B0aW9uc1xuICAgIG9wdGlvbnMgPSBwYXNzO1xuICAgIHBhc3MgPSAnJztcbiAgfVxuXG4gIGlmICghb3B0aW9ucykge1xuICAgIG9wdGlvbnMgPSB7XG4gICAgICB0eXBlOiB0eXBlb2YgYnRvYSA9PT0gJ2Z1bmN0aW9uJyA/ICdiYXNpYycgOiAnYXV0bydcbiAgICB9O1xuICB9XG5cbiAgY29uc3QgZW5jb2RlciA9IHN0cmluZyA9PiB7XG4gICAgaWYgKHR5cGVvZiBidG9hID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYnRvYShzdHJpbmcpO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IHVzZSBiYXNpYyBhdXRoLCBidG9hIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gIH07XG5cbiAgcmV0dXJuIHRoaXMuX2F1dGgodXNlciwgcGFzcywgb3B0aW9ucywgZW5jb2Rlcik7XG59O1xuXG4vKipcbiAqIEFkZCBxdWVyeS1zdHJpbmcgYHZhbGAuXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICByZXF1ZXN0LmdldCgnL3Nob2VzJylcbiAqICAgICAucXVlcnkoJ3NpemU9MTAnKVxuICogICAgIC5xdWVyeSh7IGNvbG9yOiAnYmx1ZScgfSlcbiAqXG4gKiBAcGFyYW0ge09iamVjdHxTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLnF1ZXJ5ID0gZnVuY3Rpb24odmFsKSB7XG4gIGlmICh0eXBlb2YgdmFsICE9PSAnc3RyaW5nJykgdmFsID0gc2VyaWFsaXplKHZhbCk7XG4gIGlmICh2YWwpIHRoaXMuX3F1ZXJ5LnB1c2godmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFF1ZXVlIHRoZSBnaXZlbiBgZmlsZWAgYXMgYW4gYXR0YWNobWVudCB0byB0aGUgc3BlY2lmaWVkIGBmaWVsZGAsXG4gKiB3aXRoIG9wdGlvbmFsIGBvcHRpb25zYCAob3IgZmlsZW5hbWUpLlxuICpcbiAqIGBgYCBqc1xuICogcmVxdWVzdC5wb3N0KCcvdXBsb2FkJylcbiAqICAgLmF0dGFjaCgnY29udGVudCcsIG5ldyBCbG9iKFsnPGEgaWQ9XCJhXCI+PGIgaWQ9XCJiXCI+aGV5ITwvYj48L2E+J10sIHsgdHlwZTogXCJ0ZXh0L2h0bWxcIn0pKVxuICogICAuZW5kKGNhbGxiYWNrKTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHBhcmFtIHtCbG9ifEZpbGV9IGZpbGVcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gb3B0aW9uc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmF0dGFjaCA9IGZ1bmN0aW9uKGZpZWxkLCBmaWxlLCBvcHRpb25zKSB7XG4gIGlmIChmaWxlKSB7XG4gICAgaWYgKHRoaXMuX2RhdGEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInN1cGVyYWdlbnQgY2FuJ3QgbWl4IC5zZW5kKCkgYW5kIC5hdHRhY2goKVwiKTtcbiAgICB9XG5cbiAgICB0aGlzLl9nZXRGb3JtRGF0YSgpLmFwcGVuZChmaWVsZCwgZmlsZSwgb3B0aW9ucyB8fCBmaWxlLm5hbWUpO1xuICB9XG5cbiAgcmV0dXJuIHRoaXM7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5fZ2V0Rm9ybURhdGEgPSBmdW5jdGlvbigpIHtcbiAgaWYgKCF0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRoaXMuX2Zvcm1EYXRhID0gbmV3IHJvb3QuRm9ybURhdGEoKTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mb3JtRGF0YTtcbn07XG5cbi8qKlxuICogSW52b2tlIHRoZSBjYWxsYmFjayB3aXRoIGBlcnJgIGFuZCBgcmVzYFxuICogYW5kIGhhbmRsZSBhcml0eSBjaGVjay5cbiAqXG4gKiBAcGFyYW0ge0Vycm9yfSBlcnJcbiAqIEBwYXJhbSB7UmVzcG9uc2V9IHJlc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY2FsbGJhY2sgPSBmdW5jdGlvbihlcnIsIHJlcykge1xuICBpZiAodGhpcy5fc2hvdWxkUmV0cnkoZXJyLCByZXMpKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JldHJ5KCk7XG4gIH1cblxuICBjb25zdCBmbiA9IHRoaXMuX2NhbGxiYWNrO1xuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuXG4gIGlmIChlcnIpIHtcbiAgICBpZiAodGhpcy5fbWF4UmV0cmllcykgZXJyLnJldHJpZXMgPSB0aGlzLl9yZXRyaWVzIC0gMTtcbiAgICB0aGlzLmVtaXQoJ2Vycm9yJywgZXJyKTtcbiAgfVxuXG4gIGZuKGVyciwgcmVzKTtcbn07XG5cbi8qKlxuICogSW52b2tlIGNhbGxiYWNrIHdpdGggeC1kb21haW4gZXJyb3IuXG4gKlxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY3Jvc3NEb21haW5FcnJvciA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IoXG4gICAgJ1JlcXVlc3QgaGFzIGJlZW4gdGVybWluYXRlZFxcblBvc3NpYmxlIGNhdXNlczogdGhlIG5ldHdvcmsgaXMgb2ZmbGluZSwgT3JpZ2luIGlzIG5vdCBhbGxvd2VkIGJ5IEFjY2Vzcy1Db250cm9sLUFsbG93LU9yaWdpbiwgdGhlIHBhZ2UgaXMgYmVpbmcgdW5sb2FkZWQsIGV0Yy4nXG4gICk7XG4gIGVyci5jcm9zc0RvbWFpbiA9IHRydWU7XG5cbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gIGVyci51cmwgPSB0aGlzLnVybDtcblxuICB0aGlzLmNhbGxiYWNrKGVycik7XG59O1xuXG4vLyBUaGlzIG9ubHkgd2FybnMsIGJlY2F1c2UgdGhlIHJlcXVlc3QgaXMgc3RpbGwgbGlrZWx5IHRvIHdvcmtcblJlcXVlc3QucHJvdG90eXBlLmFnZW50ID0gZnVuY3Rpb24oKSB7XG4gIGNvbnNvbGUud2FybignVGhpcyBpcyBub3Qgc3VwcG9ydGVkIGluIGJyb3dzZXIgdmVyc2lvbiBvZiBzdXBlcmFnZW50Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuY2EgPSBSZXF1ZXN0LnByb3RvdHlwZS5hZ2VudDtcblJlcXVlc3QucHJvdG90eXBlLmJ1ZmZlciA9IFJlcXVlc3QucHJvdG90eXBlLmNhO1xuXG4vLyBUaGlzIHRocm93cywgYmVjYXVzZSBpdCBjYW4ndCBzZW5kL3JlY2VpdmUgZGF0YSBhcyBleHBlY3RlZFxuUmVxdWVzdC5wcm90b3R5cGUud3JpdGUgPSAoKSA9PiB7XG4gIHRocm93IG5ldyBFcnJvcihcbiAgICAnU3RyZWFtaW5nIGlzIG5vdCBzdXBwb3J0ZWQgaW4gYnJvd3NlciB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQnXG4gICk7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5waXBlID0gUmVxdWVzdC5wcm90b3R5cGUud3JpdGU7XG5cbi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYSBob3N0IG9iamVjdCxcbiAqIHdlIGRvbid0IHdhbnQgdG8gc2VyaWFsaXplIHRoZXNlIDopXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9iaiBob3N0IG9iamVjdFxuICogQHJldHVybiB7Qm9vbGVhbn0gaXMgYSBob3N0IG9iamVjdFxuICogQGFwaSBwcml2YXRlXG4gKi9cblJlcXVlc3QucHJvdG90eXBlLl9pc0hvc3QgPSBmdW5jdGlvbihvYmopIHtcbiAgLy8gTmF0aXZlIG9iamVjdHMgc3RyaW5naWZ5IHRvIFtvYmplY3QgRmlsZV0sIFtvYmplY3QgQmxvYl0sIFtvYmplY3QgRm9ybURhdGFdLCBldGMuXG4gIHJldHVybiAoXG4gICAgb2JqICYmXG4gICAgdHlwZW9mIG9iaiA9PT0gJ29iamVjdCcgJiZcbiAgICAhQXJyYXkuaXNBcnJheShvYmopICYmXG4gICAgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKG9iaikgIT09ICdbb2JqZWN0IE9iamVjdF0nXG4gICk7XG59O1xuXG4vKipcbiAqIEluaXRpYXRlIHJlcXVlc3QsIGludm9raW5nIGNhbGxiYWNrIGBmbihyZXMpYFxuICogd2l0aCBhbiBpbnN0YW5jZW9mIGBSZXNwb25zZWAuXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gZm5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5lbmQgPSBmdW5jdGlvbihmbikge1xuICBpZiAodGhpcy5fZW5kQ2FsbGVkKSB7XG4gICAgY29uc29sZS53YXJuKFxuICAgICAgJ1dhcm5pbmc6IC5lbmQoKSB3YXMgY2FsbGVkIHR3aWNlLiBUaGlzIGlzIG5vdCBzdXBwb3J0ZWQgaW4gc3VwZXJhZ2VudCdcbiAgICApO1xuICB9XG5cbiAgdGhpcy5fZW5kQ2FsbGVkID0gdHJ1ZTtcblxuICAvLyBzdG9yZSBjYWxsYmFja1xuICB0aGlzLl9jYWxsYmFjayA9IGZuIHx8IG5vb3A7XG5cbiAgLy8gcXVlcnlzdHJpbmdcbiAgdGhpcy5fZmluYWxpemVRdWVyeVN0cmluZygpO1xuXG4gIHRoaXMuX2VuZCgpO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuX3NldFVwbG9hZFRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY29uc3Qgc2VsZiA9IHRoaXM7XG5cbiAgLy8gdXBsb2FkIHRpbWVvdXQgaXQncyB3b2tycyBvbmx5IGlmIGRlYWRsaW5lIHRpbWVvdXQgaXMgb2ZmXG4gIGlmICh0aGlzLl91cGxvYWRUaW1lb3V0ICYmICF0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIpIHtcbiAgICB0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlbGYuX3RpbWVvdXRFcnJvcihcbiAgICAgICAgJ1VwbG9hZCB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3VwbG9hZFRpbWVvdXQsXG4gICAgICAgICdFVElNRURPVVQnXG4gICAgICApO1xuICAgIH0sIHRoaXMuX3VwbG9hZFRpbWVvdXQpO1xuICB9XG59O1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29tcGxleGl0eVxuUmVxdWVzdC5wcm90b3R5cGUuX2VuZCA9IGZ1bmN0aW9uKCkge1xuICBpZiAodGhpcy5fYWJvcnRlZClcbiAgICByZXR1cm4gdGhpcy5jYWxsYmFjayhcbiAgICAgIG5ldyBFcnJvcignVGhlIHJlcXVlc3QgaGFzIGJlZW4gYWJvcnRlZCBldmVuIGJlZm9yZSAuZW5kKCkgd2FzIGNhbGxlZCcpXG4gICAgKTtcblxuICBjb25zdCBzZWxmID0gdGhpcztcbiAgdGhpcy54aHIgPSByZXF1ZXN0LmdldFhIUigpO1xuICBjb25zdCB7IHhociB9ID0gdGhpcztcbiAgbGV0IGRhdGEgPSB0aGlzLl9mb3JtRGF0YSB8fCB0aGlzLl9kYXRhO1xuXG4gIHRoaXMuX3NldFRpbWVvdXRzKCk7XG5cbiAgLy8gc3RhdGUgY2hhbmdlXG4gIHhoci5vbnJlYWR5c3RhdGVjaGFuZ2UgPSAoKSA9PiB7XG4gICAgY29uc3QgeyByZWFkeVN0YXRlIH0gPSB4aHI7XG4gICAgaWYgKHJlYWR5U3RhdGUgPj0gMiAmJiBzZWxmLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgICAgY2xlYXJUaW1lb3V0KHNlbGYuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgICB9XG5cbiAgICBpZiAocmVhZHlTdGF0ZSAhPT0gNCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIEluIElFOSwgcmVhZHMgdG8gYW55IHByb3BlcnR5IChlLmcuIHN0YXR1cykgb2ZmIG9mIGFuIGFib3J0ZWQgWEhSIHdpbGxcbiAgICAvLyByZXN1bHQgaW4gdGhlIGVycm9yIFwiQ291bGQgbm90IGNvbXBsZXRlIHRoZSBvcGVyYXRpb24gZHVlIHRvIGVycm9yIGMwMGMwMjNmXCJcbiAgICBsZXQgc3RhdHVzO1xuICAgIHRyeSB7XG4gICAgICBzdGF0dXMgPSB4aHIuc3RhdHVzO1xuICAgIH0gY2F0Y2gge1xuICAgICAgc3RhdHVzID0gMDtcbiAgICB9XG5cbiAgICBpZiAoIXN0YXR1cykge1xuICAgICAgaWYgKHNlbGYudGltZWRvdXQgfHwgc2VsZi5fYWJvcnRlZCkgcmV0dXJuO1xuICAgICAgcmV0dXJuIHNlbGYuY3Jvc3NEb21haW5FcnJvcigpO1xuICAgIH1cblxuICAgIHNlbGYuZW1pdCgnZW5kJyk7XG4gIH07XG5cbiAgLy8gcHJvZ3Jlc3NcbiAgY29uc3QgaGFuZGxlUHJvZ3Jlc3MgPSAoZGlyZWN0aW9uLCBlKSA9PiB7XG4gICAgaWYgKGUudG90YWwgPiAwKSB7XG4gICAgICBlLnBlcmNlbnQgPSAoZS5sb2FkZWQgLyBlLnRvdGFsKSAqIDEwMDtcblxuICAgICAgaWYgKGUucGVyY2VudCA9PT0gMTAwKSB7XG4gICAgICAgIGNsZWFyVGltZW91dChzZWxmLl91cGxvYWRUaW1lb3V0VGltZXIpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGUuZGlyZWN0aW9uID0gZGlyZWN0aW9uO1xuICAgIHNlbGYuZW1pdCgncHJvZ3Jlc3MnLCBlKTtcbiAgfTtcblxuICBpZiAodGhpcy5oYXNMaXN0ZW5lcnMoJ3Byb2dyZXNzJykpIHtcbiAgICB0cnkge1xuICAgICAgeGhyLmFkZEV2ZW50TGlzdGVuZXIoJ3Byb2dyZXNzJywgaGFuZGxlUHJvZ3Jlc3MuYmluZChudWxsLCAnZG93bmxvYWQnKSk7XG4gICAgICBpZiAoeGhyLnVwbG9hZCkge1xuICAgICAgICB4aHIudXBsb2FkLmFkZEV2ZW50TGlzdGVuZXIoXG4gICAgICAgICAgJ3Byb2dyZXNzJyxcbiAgICAgICAgICBoYW5kbGVQcm9ncmVzcy5iaW5kKG51bGwsICd1cGxvYWQnKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gQWNjZXNzaW5nIHhoci51cGxvYWQgZmFpbHMgaW4gSUUgZnJvbSBhIHdlYiB3b3JrZXIsIHNvIGp1c3QgcHJldGVuZCBpdCBkb2Vzbid0IGV4aXN0LlxuICAgICAgLy8gUmVwb3J0ZWQgaGVyZTpcbiAgICAgIC8vIGh0dHBzOi8vY29ubmVjdC5taWNyb3NvZnQuY29tL0lFL2ZlZWRiYWNrL2RldGFpbHMvODM3MjQ1L3htbGh0dHByZXF1ZXN0LXVwbG9hZC10aHJvd3MtaW52YWxpZC1hcmd1bWVudC13aGVuLXVzZWQtZnJvbS13ZWItd29ya2VyLWNvbnRleHRcbiAgICB9XG4gIH1cblxuICBpZiAoeGhyLnVwbG9hZCkge1xuICAgIHRoaXMuX3NldFVwbG9hZFRpbWVvdXQoKTtcbiAgfVxuXG4gIC8vIGluaXRpYXRlIHJlcXVlc3RcbiAgdHJ5IHtcbiAgICBpZiAodGhpcy51c2VybmFtZSAmJiB0aGlzLnBhc3N3b3JkKSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUsIHRoaXMudXNlcm5hbWUsIHRoaXMucGFzc3dvcmQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUpO1xuICAgIH1cbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgLy8gc2VlICMxMTQ5XG4gICAgcmV0dXJuIHRoaXMuY2FsbGJhY2soZXJyKTtcbiAgfVxuXG4gIC8vIENPUlNcbiAgaWYgKHRoaXMuX3dpdGhDcmVkZW50aWFscykgeGhyLndpdGhDcmVkZW50aWFscyA9IHRydWU7XG5cbiAgLy8gYm9keVxuICBpZiAoXG4gICAgIXRoaXMuX2Zvcm1EYXRhICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdHRVQnICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgIHR5cGVvZiBkYXRhICE9PSAnc3RyaW5nJyAmJlxuICAgICF0aGlzLl9pc0hvc3QoZGF0YSlcbiAgKSB7XG4gICAgLy8gc2VyaWFsaXplIHN0dWZmXG4gICAgY29uc3QgY29udGVudFR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGxldCBzZXJpYWxpemUgPVxuICAgICAgdGhpcy5fc2VyaWFsaXplciB8fFxuICAgICAgcmVxdWVzdC5zZXJpYWxpemVbY29udGVudFR5cGUgPyBjb250ZW50VHlwZS5zcGxpdCgnOycpWzBdIDogJyddO1xuICAgIGlmICghc2VyaWFsaXplICYmIGlzSlNPTihjb250ZW50VHlwZSkpIHtcbiAgICAgIHNlcmlhbGl6ZSA9IHJlcXVlc3Quc2VyaWFsaXplWydhcHBsaWNhdGlvbi9qc29uJ107XG4gICAgfVxuXG4gICAgaWYgKHNlcmlhbGl6ZSkgZGF0YSA9IHNlcmlhbGl6ZShkYXRhKTtcbiAgfVxuXG4gIC8vIHNldCBoZWFkZXIgZmllbGRzXG4gIGZvciAoY29uc3QgZmllbGQgaW4gdGhpcy5oZWFkZXIpIHtcbiAgICBpZiAodGhpcy5oZWFkZXJbZmllbGRdID09PSBudWxsKSBjb250aW51ZTtcblxuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodGhpcy5oZWFkZXIsIGZpZWxkKSlcbiAgICAgIHhoci5zZXRSZXF1ZXN0SGVhZGVyKGZpZWxkLCB0aGlzLmhlYWRlcltmaWVsZF0pO1xuICB9XG5cbiAgaWYgKHRoaXMuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHhoci5yZXNwb25zZVR5cGUgPSB0aGlzLl9yZXNwb25zZVR5cGU7XG4gIH1cblxuICAvLyBzZW5kIHN0dWZmXG4gIHRoaXMuZW1pdCgncmVxdWVzdCcsIHRoaXMpO1xuXG4gIC8vIElFMTEgeGhyLnNlbmQodW5kZWZpbmVkKSBzZW5kcyAndW5kZWZpbmVkJyBzdHJpbmcgYXMgUE9TVCBwYXlsb2FkIChpbnN0ZWFkIG9mIG5vdGhpbmcpXG4gIC8vIFdlIG5lZWQgbnVsbCBoZXJlIGlmIGRhdGEgaXMgdW5kZWZpbmVkXG4gIHhoci5zZW5kKHR5cGVvZiBkYXRhID09PSAndW5kZWZpbmVkJyA/IG51bGwgOiBkYXRhKTtcbn07XG5cbnJlcXVlc3QuYWdlbnQgPSAoKSA9PiBuZXcgQWdlbnQoKTtcblxuWydHRVQnLCAnUE9TVCcsICdPUFRJT05TJywgJ1BBVENIJywgJ1BVVCcsICdERUxFVEUnXS5mb3JFYWNoKG1ldGhvZCA9PiB7XG4gIEFnZW50LnByb3RvdHlwZVttZXRob2QudG9Mb3dlckNhc2UoKV0gPSBmdW5jdGlvbih1cmwsIGZuKSB7XG4gICAgY29uc3QgcmVxID0gbmV3IHJlcXVlc3QuUmVxdWVzdChtZXRob2QsIHVybCk7XG4gICAgdGhpcy5fc2V0RGVmYXVsdHMocmVxKTtcbiAgICBpZiAoZm4pIHtcbiAgICAgIHJlcS5lbmQoZm4pO1xuICAgIH1cblxuICAgIHJldHVybiByZXE7XG4gIH07XG59KTtcblxuQWdlbnQucHJvdG90eXBlLmRlbCA9IEFnZW50LnByb3RvdHlwZS5kZWxldGU7XG5cbi8qKlxuICogR0VUIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5nZXQgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdHRVQnLCB1cmwpO1xuICBpZiAodHlwZW9mIGRhdGEgPT09ICdmdW5jdGlvbicpIHtcbiAgICBmbiA9IGRhdGE7XG4gICAgZGF0YSA9IG51bGw7XG4gIH1cblxuICBpZiAoZGF0YSkgcmVxLnF1ZXJ5KGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBIRUFEIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5oZWFkID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnSEVBRCcsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEucXVlcnkoZGF0YSk7XG4gIGlmIChmbikgcmVxLmVuZChmbik7XG4gIHJldHVybiByZXE7XG59O1xuXG4vKipcbiAqIE9QVElPTlMgcXVlcnkgdG8gYHVybGAgd2l0aCBvcHRpb25hbCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZHxGdW5jdGlvbn0gW2RhdGFdIG9yIGZuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0Lm9wdGlvbnMgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdPUFRJT05TJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBERUxFVEUgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfSBbZGF0YV1cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbmZ1bmN0aW9uIGRlbCh1cmwsIGRhdGEsIGZuKSB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ0RFTEVURScsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEuc2VuZChkYXRhKTtcbiAgaWYgKGZuKSByZXEuZW5kKGZuKTtcbiAgcmV0dXJuIHJlcTtcbn1cblxucmVxdWVzdC5kZWwgPSBkZWw7XG5yZXF1ZXN0LmRlbGV0ZSA9IGRlbDtcblxuLyoqXG4gKiBQQVRDSCBgdXJsYCB3aXRoIG9wdGlvbmFsIGBkYXRhYCBhbmQgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR9IFtkYXRhXVxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5wYXRjaCA9ICh1cmwsIGRhdGEsIGZuKSA9PiB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ1BBVENIJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQT1NUIGB1cmxgIHdpdGggb3B0aW9uYWwgYGRhdGFgIGFuZCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZH0gW2RhdGFdXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0LnBvc3QgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdQT1NUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQVVQgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfEZ1bmN0aW9ufSBbZGF0YV0gb3IgZm5cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbnJlcXVlc3QucHV0ID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnUFVUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcbiJdfQ==","import base64 from 'base64-js';\n\nfunction padding(str) {\n var mod = str.length % 4;\n var pad = 4 - mod;\n\n if (mod === 0) {\n return str;\n }\n\n return str + new Array(1 + pad).join('=');\n}\n\nfunction stringToByteArray(str) {\n var arr = new Array(str.length);\n for (var a = 0; a < str.length; a++) {\n arr[a] = str.charCodeAt(a);\n }\n return arr;\n}\n\nfunction byteArrayToString(array) {\n var result = '';\n for (var i = 0; i < array.length; i++) {\n result += String.fromCharCode(array[i]);\n }\n return result;\n}\n\nfunction encode(str) {\n return base64\n .fromByteArray(stringToByteArray(str))\n .replace(/\\+/g, '-') // Convert '+' to '-'\n .replace(/\\//g, '_'); // Convert '/' to '_'\n}\n\nfunction decode(str) {\n str = padding(str)\n .replace(/-/g, '+') // Convert '-' to '+'\n .replace(/_/g, '/'); // Convert '_' to '/'\n\n return byteArrayToString(base64.toByteArray(str));\n}\n\nexport default {\n encode: encode,\n decode: decode\n};\n","module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","/* eslint-disable no-param-reassign */\nimport request from 'superagent';\nimport base64Url from './base64_url';\nimport version from '../version';\nimport objectHelper from './object';\n\n// ------------------------------------------------ RequestWrapper\n\nfunction RequestWrapper(req) {\n this.request = req;\n this.method = req.method;\n this.url = req.url;\n this.body = req._data;\n this.headers = req._header;\n}\n\nRequestWrapper.prototype.abort = function() {\n this.request.abort();\n};\n\nRequestWrapper.prototype.getMethod = function() {\n return this.method;\n};\n\nRequestWrapper.prototype.getBody = function() {\n return this.body;\n};\n\nRequestWrapper.prototype.getUrl = function() {\n return this.url;\n};\n\nRequestWrapper.prototype.getHeaders = function() {\n return this.headers;\n};\n\n// ------------------------------------------------ RequestObj\n\nfunction RequestObj(req) {\n this.request = req;\n}\n\nRequestObj.prototype.set = function(key, value) {\n this.request = this.request.set(key, value);\n return this;\n};\n\nRequestObj.prototype.send = function(body) {\n this.request = this.request.send(objectHelper.trimUserDetails(body));\n return this;\n};\n\nRequestObj.prototype.withCredentials = function() {\n this.request = this.request.withCredentials();\n return this;\n};\n\nRequestObj.prototype.end = function(cb) {\n this.request.end(cb);\n return new RequestWrapper(this.request);\n};\n\n// ------------------------------------------------ RequestBuilder\n\nfunction RequestBuilder(options) {\n this._sendTelemetry =\n options._sendTelemetry === false ? options._sendTelemetry : true;\n this._telemetryInfo = options._telemetryInfo || null;\n this._timesToRetryFailedRequests = options._timesToRetryFailedRequests;\n this.headers = options.headers || {};\n this._universalLoginPage = options.universalLoginPage;\n}\n\nRequestBuilder.prototype.setCommonConfiguration = function(\n ongoingRequest,\n options\n) {\n options = options || {};\n\n if (this._timesToRetryFailedRequests > 0) {\n ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests);\n }\n\n if (options.noHeaders) {\n return ongoingRequest;\n }\n\n var headers = this.headers;\n ongoingRequest = ongoingRequest.set('Content-Type', 'application/json');\n\n var keys = Object.keys(this.headers);\n\n for (var a = 0; a < keys.length; a++) {\n ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]);\n }\n\n if (this._sendTelemetry) {\n ongoingRequest = ongoingRequest.set(\n 'Auth0-Client',\n this.getTelemetryData()\n );\n }\n\n return ongoingRequest;\n};\n\nRequestBuilder.prototype.getTelemetryData = function() {\n var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js';\n var clientInfo = { name: telemetryName, version: version.raw };\n if (this._telemetryInfo) {\n clientInfo = objectHelper.extend({}, this._telemetryInfo);\n clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env);\n clientInfo.env[telemetryName] = version.raw;\n }\n var jsonClientInfo = JSON.stringify(clientInfo);\n return base64Url.encode(jsonClientInfo);\n};\n\nRequestBuilder.prototype.get = function(url, options) {\n return new RequestObj(this.setCommonConfiguration(request.get(url), options));\n};\n\nRequestBuilder.prototype.post = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.post(url), options)\n );\n};\n\nRequestBuilder.prototype.patch = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.patch(url), options)\n );\n};\n\nexport default RequestBuilder;\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","function DummyStorage() {}\n\nDummyStorage.prototype.getItem = function() {\n return null;\n};\n\nDummyStorage.prototype.removeItem = function() {};\n\nDummyStorage.prototype.setItem = function() {};\n\nexport default DummyStorage;\n","/*!\n * JavaScript Cookie v2.2.1\n * https://github.com/js-cookie/js-cookie\n *\n * Copyright 2006, 2015 Klaus Hartl & Fagner Brack\n * Released under the MIT license\n */\n;(function (factory) {\n\tvar registeredInModuleLoader;\n\tif (typeof define === 'function' && define.amd) {\n\t\tdefine(factory);\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (typeof exports === 'object') {\n\t\tmodule.exports = factory();\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (!registeredInModuleLoader) {\n\t\tvar OldCookies = window.Cookies;\n\t\tvar api = window.Cookies = factory();\n\t\tapi.noConflict = function () {\n\t\t\twindow.Cookies = OldCookies;\n\t\t\treturn api;\n\t\t};\n\t}\n}(function () {\n\tfunction extend () {\n\t\tvar i = 0;\n\t\tvar result = {};\n\t\tfor (; i < arguments.length; i++) {\n\t\t\tvar attributes = arguments[ i ];\n\t\t\tfor (var key in attributes) {\n\t\t\t\tresult[key] = attributes[key];\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction decode (s) {\n\t\treturn s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent);\n\t}\n\n\tfunction init (converter) {\n\t\tfunction api() {}\n\n\t\tfunction set (key, value, attributes) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tattributes = extend({\n\t\t\t\tpath: '/'\n\t\t\t}, api.defaults, attributes);\n\n\t\t\tif (typeof attributes.expires === 'number') {\n\t\t\t\tattributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5);\n\t\t\t}\n\n\t\t\t// We're using \"expires\" because \"max-age\" is not supported by IE\n\t\t\tattributes.expires = attributes.expires ? attributes.expires.toUTCString() : '';\n\n\t\t\ttry {\n\t\t\t\tvar result = JSON.stringify(value);\n\t\t\t\tif (/^[\\{\\[]/.test(result)) {\n\t\t\t\t\tvalue = result;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\n\t\t\tvalue = converter.write ?\n\t\t\t\tconverter.write(value, key) :\n\t\t\t\tencodeURIComponent(String(value))\n\t\t\t\t\t.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n\t\t\tkey = encodeURIComponent(String(key))\n\t\t\t\t.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n\t\t\t\t.replace(/[\\(\\)]/g, escape);\n\n\t\t\tvar stringifiedAttributes = '';\n\t\t\tfor (var attributeName in attributes) {\n\t\t\t\tif (!attributes[attributeName]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tstringifiedAttributes += '; ' + attributeName;\n\t\t\t\tif (attributes[attributeName] === true) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Considers RFC 6265 section 5.2:\n\t\t\t\t// ...\n\t\t\t\t// 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n\t\t\t\t// character:\n\t\t\t\t// Consume the characters of the unparsed-attributes up to,\n\t\t\t\t// not including, the first %x3B (\";\") character.\n\t\t\t\t// ...\n\t\t\t\tstringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n\t\t\t}\n\n\t\t\treturn (document.cookie = key + '=' + value + stringifiedAttributes);\n\t\t}\n\n\t\tfunction get (key, json) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar jar = {};\n\t\t\t// To prevent the for loop in the first place assign an empty array\n\t\t\t// in case there are no cookies at all.\n\t\t\tvar cookies = document.cookie ? document.cookie.split('; ') : [];\n\t\t\tvar i = 0;\n\n\t\t\tfor (; i < cookies.length; i++) {\n\t\t\t\tvar parts = cookies[i].split('=');\n\t\t\t\tvar cookie = parts.slice(1).join('=');\n\n\t\t\t\tif (!json && cookie.charAt(0) === '\"') {\n\t\t\t\t\tcookie = cookie.slice(1, -1);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tvar name = decode(parts[0]);\n\t\t\t\t\tcookie = (converter.read || converter)(cookie, name) ||\n\t\t\t\t\t\tdecode(cookie);\n\n\t\t\t\t\tif (json) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tcookie = JSON.parse(cookie);\n\t\t\t\t\t\t} catch (e) {}\n\t\t\t\t\t}\n\n\t\t\t\t\tjar[name] = cookie;\n\n\t\t\t\t\tif (key === name) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\t\t\t}\n\n\t\t\treturn key ? jar[key] : jar;\n\t\t}\n\n\t\tapi.set = set;\n\t\tapi.get = function (key) {\n\t\t\treturn get(key, false /* read as raw */);\n\t\t};\n\t\tapi.getJSON = function (key) {\n\t\t\treturn get(key, true /* read as json */);\n\t\t};\n\t\tapi.remove = function (key, attributes) {\n\t\t\tset(key, '', extend(attributes, {\n\t\t\t\texpires: -1\n\t\t\t}));\n\t\t};\n\n\t\tapi.defaults = {};\n\n\t\tapi.withConverter = init;\n\n\t\treturn api;\n\t}\n\n\treturn init(function () {});\n}));\n","import Cookie from 'js-cookie';\nimport objectHelper from '../object';\nfunction CookieStorage() {}\n\nCookieStorage.prototype.getItem = function(key) {\n return Cookie.get(key);\n};\n\nCookieStorage.prototype.removeItem = function(key) {\n Cookie.remove(key);\n};\n\nCookieStorage.prototype.setItem = function(key, value, options) {\n var params = objectHelper.extend(\n {\n expires: 1 // 1 day\n },\n options\n );\n Cookie.set(key, value, params);\n};\n\nexport default CookieStorage;\n","/* eslint-disable no-console */\n\nfunction Warn(options) {\n this.disableWarnings = options.disableWarnings;\n}\n\nWarn.prototype.warning = function(message) {\n if (this.disableWarnings) {\n return;\n }\n\n console.warn(message);\n};\n\nexport default Warn;\n","import windowHandler from '../window';\nimport DummyStorage from './dummy';\nimport CookieStorage from './cookie';\nimport Warn from '../warn';\n\nfunction StorageHandler(options) {\n this.warn = new Warn({});\n this.storage = new CookieStorage();\n if (options.__tryLocalStorageFirst !== true) {\n return;\n }\n try {\n // some browsers throw an error when trying to access localStorage\n // when localStorage is disabled.\n var localStorage = windowHandler.getWindow().localStorage;\n if (localStorage) {\n this.storage = localStorage;\n }\n } catch (e) {\n this.warn.warning(e);\n this.warn.warning(\"Can't use localStorage. Using CookieStorage instead.\");\n }\n}\n\nStorageHandler.prototype.failover = function() {\n if (this.storage instanceof DummyStorage) {\n this.warn.warning('DummyStorage: ignore failover');\n return;\n } else if (this.storage instanceof CookieStorage) {\n this.warn.warning('CookieStorage: failing over DummyStorage');\n this.storage = new DummyStorage();\n } else {\n this.warn.warning('LocalStorage: failing over CookieStorage');\n this.storage = new CookieStorage();\n }\n};\n\nStorageHandler.prototype.getItem = function(key) {\n try {\n return this.storage.getItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.getItem(key);\n }\n};\n\nStorageHandler.prototype.removeItem = function(key) {\n try {\n return this.storage.removeItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.removeItem(key);\n }\n};\n\nStorageHandler.prototype.setItem = function(key, value, options) {\n try {\n return this.storage.setItem(key, value, options);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.setItem(key, value, options);\n }\n};\n\nexport default StorageHandler;\n","import StorageHandler from './storage/handler';\n\nfunction Storage(options) {\n this.handler = new StorageHandler(options);\n}\n\nStorage.prototype.getItem = function(key) {\n var value = this.handler.getItem(key);\n try {\n return JSON.parse(value);\n } catch (_) {\n return value;\n }\n};\nStorage.prototype.removeItem = function(key) {\n return this.handler.removeItem(key);\n};\nStorage.prototype.setItem = function(key, value, options) {\n var json = JSON.stringify(value);\n return this.handler.setItem(key, json, options);\n};\n\nexport default Storage;\n","import Storage from './storage';\n\nfunction SSODataStorage(options) {\n this.storage = new Storage(options);\n}\n\nSSODataStorage.prototype.set = function(connection, sub) {\n var ssodata = {\n lastUsedConnection: connection,\n lastUsedSub: sub\n };\n this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata));\n};\nSSODataStorage.prototype.get = function() {\n var ssodata = this.storage.getItem('auth0.ssodata');\n if (!ssodata) {\n return;\n }\n return JSON.parse(ssodata);\n};\n\nexport default SSODataStorage;\n","function buildResponse(error, description) {\n return {\n error: error,\n errorDescription: description\n };\n}\n\nfunction invalidToken(description) {\n return buildResponse('invalid_token', description);\n}\n\nexport default {\n buildResponse: buildResponse,\n invalidToken: invalidToken\n};\n","import error from './error';\nimport objectHelper from './object';\n\nfunction wrapCallback(cb, options) {\n options = options || {};\n options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false;\n\n return function(err, data) {\n var errObj;\n\n if (!err && !data) {\n return cb(error.buildResponse('generic_error', 'Something went wrong'));\n }\n\n if (!err && data.err) {\n err = data.err;\n data = null;\n }\n\n if (!err && data.error) {\n err = data;\n data = null;\n }\n\n if (err) {\n errObj = {\n original: err\n };\n\n objectHelper.updatePropertyOn(\n errObj,\n 'original.response.req._data.password',\n '*****'\n );\n\n if (err.response && err.response.statusCode) {\n errObj.statusCode = err.response.statusCode;\n }\n\n if (err.response && err.response.statusText) {\n errObj.statusText = err.response.statusText;\n }\n\n if (err.response && err.response.body) {\n err = err.response.body;\n }\n\n if (err.err) {\n err = err.err;\n }\n\n errObj.code =\n err.code || err.error || err.error_code || err.status || null;\n\n errObj.description =\n err.errorDescription ||\n err.error_description ||\n err.description ||\n err.error ||\n err.details ||\n err.err ||\n null;\n\n if (options.forceLegacyError) {\n errObj.error = errObj.code;\n errObj.error_description = errObj.description;\n }\n\n if (err.error_codes && err.error_details) {\n errObj.errorDetails = {\n codes: err.error_codes,\n details: err.error_details\n };\n }\n\n if (err.name) {\n errObj.name = err.name;\n }\n\n if (err.policy) {\n errObj.policy = err.policy;\n }\n\n return cb(errObj);\n }\n\n if (\n data.type &&\n (data.type === 'text/html' || data.type === 'text/plain')\n ) {\n return cb(null, data.text);\n }\n\n if (options.ignoreCasing) {\n return cb(null, data.body || data);\n }\n\n return cb(\n null,\n objectHelper.toCamelCase(data.body || data, [], {\n keepOriginal: options.keepOriginalCasing\n })\n );\n };\n}\n\nexport default wrapCallback;\n","// For future reference:,\n// The only parameters that should be allowed are parameters\n// defined by the specification, or existing parameters that we\n// need for compatibility\n\nimport objectHelper from './object';\n\nvar tokenParams = [\n // auth0\n 'realm',\n 'audience',\n 'otp',\n // oauth2\n 'client_id',\n 'client_secret',\n 'redirect_uri',\n 'scope',\n 'code',\n 'grant_type',\n 'username',\n 'password',\n 'refresh_token',\n 'assertion',\n 'client_assertion',\n 'client_assertion_type',\n 'code_verifier'\n];\n\nvar authorizeParams = [\n // auth0\n 'connection',\n 'connection_scope',\n 'auth0Client',\n 'owp',\n 'device',\n 'realm',\n\n 'protocol',\n '_csrf',\n '_intstate',\n 'login_ticket',\n\n // oauth2\n 'client_id',\n 'response_type',\n 'response_mode',\n 'redirect_uri',\n 'audience',\n 'scope',\n 'state',\n 'nonce',\n 'display',\n 'prompt',\n 'screen_hint',\n 'max_age',\n 'ui_locales',\n 'claims_locales',\n 'id_token_hint',\n 'login_hint',\n 'acr_values',\n 'claims',\n 'registration',\n 'request',\n 'request_uri',\n 'code_challenge',\n 'code_challenge_method',\n\n // ADDITIONAL_PARAMETERS:\n // https://auth0.com/docs/api/authentication?javascript#social\n 'access_type',\n 'display'\n];\n\nfunction oauthAuthorizeParams(warn, params) {\n var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams);\n\n if (notAllowed.length > 0) {\n warn.warning(\n 'Following parameters are not allowed on the `/authorize` endpoint: [' +\n notAllowed.join(',') +\n ']'\n );\n }\n\n return params;\n}\n\nfunction oauthTokenParams(warn, params) {\n return objectHelper.pick(params, tokenParams);\n}\n\nexport default {\n oauthTokenParams: oauthTokenParams,\n oauthAuthorizeParams: oauthAuthorizeParams\n};\n","var t=\"undefined\"!=typeof globalThis?globalThis:\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error(\"Dynamic requires are not currently supported by @rollup/plugin-commonjs\")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return\"function\"==typeof t}var r=Array.isArray?Array.isArray:function(t){return\"[object Array]\"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h=\"undefined\"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f=\"undefined\"==typeof self&&\"undefined\"!=typeof process&&\"[object process]\"==={}.toString.call(process),c=\"undefined\"!=typeof Uint8ClampedArray&&\"undefined\"!=typeof importScripts&&\"undefined\"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error(\"Malformed UTF-8 data\")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){\"string\"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)}),o=e(function(t,e){var r,n;t.exports=(r=(n=i).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join(\"\")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\"},n.enc.Base64)}),s=e(function(t,e){t.exports=i.enc.Hex}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&(\"number\"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&\"string\"!=typeof t?256:e))}function i(){return new r(null)}var n=\"undefined\"!=typeof navigator;n&&\"Microsoft Internet Explorer\"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&\"Netscape\"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?\"-\"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return\"-\"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:\"0\"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return\"0\";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h=\"\";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if(\"number\"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error(\"Invalid key data\");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\\s\\n]]/gi,\"\");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error(\"Signature does not match with the key modulus.\");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,\"\"));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error(\"Hashing algorithm is not supported.\");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,d=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",m=0,v=d.length;m0)throw new Error(\"Invalid string. Length must be a multiple of 4\");var r=t.indexOf(\"=\");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join(\"=\")}function w(t){return t=g(t).replace(/\\-/g,\"+\").replace(/_/g,\"/\"),decodeURIComponent(function(t){for(var e=\"\",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\\/\\/\\//)?t[0].replace(/^([^/:]+):\\/*/,\"$1:///\"):t[0].replace(/^([^/:]+):\\/*/,\"$1://\");for(var i=0;i0&&(n=n.replace(/^[\\/]+/,\"\")),n=n.replace(/[\\/]+$/,i0?\"?\":\"\")+s.join(\"&\")}return function(){return t(\"object\"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||\"get\",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\\S\\n]*([\\s\\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+\",\"+r:r}),r(a())},n.onerror=i,n.withCredentials=\"include\"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name=\"ConfigurationError\",this.message=t||\"\"}function A(t){this.name=\"TokenValidationError\",this.message=t||\"\"}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return\"number\"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||\"RS256\",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock=\"function\"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D(\"The leeway should be positive and lower than five minutes.\");if(\"RS256\"!==this.expectedAlg)throw new D('Signature algorithm of \"'+this.expectedAlg+'\" is not supported. Expected the ID token to be signed with \"RS256\".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A(\"ID token is required but missing\"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A(\"ID token could not be decoded\"),!1);var n=i.encoded.header+\".\"+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of \"'+s+'\" is not supported. Expected the ID token to be signed with \"RS256\".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A(\"Invalid ID token signature.\"));if(!f||\"string\"!=typeof f)return r(new A(\"Issuer (iss) claim must be a string present in the ID token\",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected \"'+g.issuer+'\", found \"'+f+'\"'),!1);if(!u||\"string\"!=typeof u)return r(new A(\"Subject (sub) claim must be a string present in the ID token\"),!1);if(!a||\"string\"!=typeof a&&!Array.isArray(a))return r(new A(\"Audience (aud) claim must be a string or array of strings present in the ID token\"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but was not one of \"'+a.join(\", \")+'\"'));if(\"string\"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but found \"'+a+'\"'),!1);if(e){if(!v||\"string\"!=typeof v)return r(new A(\"Nonce (nonce) claim must be a string present in the ID token\"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected \"'+e+'\", found \"'+v+'\"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||\"string\"!=typeof d)return r(new A(\"Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values\",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected \"'+g.audience+'\", found \"'+d+'\"',!1))}if(!c||!x(c))return r(new A(\"Expiration Time (exp) claim must be a number present in the ID token\",!1));if(!l||!x(l))return r(new A(\"Issued At (iat) claim must be a number present in the ID token\"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time \"'+y+'\" is after expiration time \"'+w+'\"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time \"'+y+'\" is after last auth time at \"'+S+'\"'))}return r(null,i.payload)})},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},(\"undefined\"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,\".well-known\",\"jwks.json\")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11\n else if (ua.indexOf(\"Trident\") > -1) {\n var re = new RegExp(\"rv:([0-9]{2,2}[\\.0-9]{0,})\");\n if (re.exec(ua) !== null) {\n rv = parseFloat(RegExp.$1);\n }\n }\n\n return rv >= 8;\n }\n\n // checking Mobile Firefox (Fennec)\n function isFennec() {\n try {\n // We must check for both XUL and Java versions of Fennec. Both have\n // distinct UA strings.\n var userAgent = navigator.userAgent;\n return (userAgent.indexOf('Fennec/') != -1) || // XUL\n (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java\n } catch(e) {}\n return false;\n }\n\n // feature checking to see if this platform is supported at all\n function isSupported() {\n return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify &&\n window.JSON.parse && window.postMessage);\n }\n\n // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\n function extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[\\-_a-zA-Z\\.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n }\n\n // find the relay iframe in the opener\n function findRelay() {\n var loc = window.location;\n var frames = window.opener.frames;\n for (var i = frames.length - 1; i >= 0; i--) {\n try {\n if (frames[i].location.protocol === window.location.protocol &&\n frames[i].location.host === window.location.host &&\n frames[i].name === RELAY_FRAME_NAME)\n {\n return frames[i];\n }\n } catch(e) { }\n }\n return;\n }\n\n var isIE = isInternetExplorer();\n\n if (isSupported()) {\n /* General flow:\n * 0. user clicks\n * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM\n * 2. caller opens window (with content from trusted domain)\n * 3. window on opening adds a listener to 'message'\n * (IE SPECIFIC) 4. window on opening finds iframe\n * 5. window checks if iframe is \"loaded\" - has a 'doPost' function yet\n * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller\n * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready\n * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event\n * 6. caller upon reciept of 'ready', sends args\n */\n return {\n open: function(opts, cb) {\n if (!cb) throw \"missing required callback argument\";\n\n // test required options\n var err;\n if (!opts.url) err = \"missing required 'url' parameter\";\n if (!opts.relay_url) err = \"missing required 'relay_url' parameter\";\n if (err) setTimeout(function() { cb(err); }, 0);\n\n // supply default options\n if (!opts.window_name) opts.window_name = null;\n if (!opts.window_features || isFennec()) opts.window_features = undefined;\n\n // opts.params may be undefined\n\n var iframe;\n\n // sanity check, are url and relay_url the same origin?\n var origin = opts.origin || extractOrigin(opts.url);\n if (origin !== extractOrigin(opts.relay_url)) {\n return setTimeout(function() {\n cb('invalid arguments: origin of url and relay_url must match');\n }, 0);\n }\n\n var messageTarget;\n\n if (isIE) {\n // first we need to add a \"relay\" iframe to the document that's served\n // from the target domain. We can postmessage into a iframe, but not a\n // window\n iframe = document.createElement(\"iframe\");\n // iframe.setAttribute('name', framename);\n iframe.setAttribute('src', opts.relay_url);\n iframe.style.display = \"none\";\n iframe.setAttribute('name', RELAY_FRAME_NAME);\n document.body.appendChild(iframe);\n messageTarget = iframe.contentWindow;\n }\n\n var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features);\n if (opts.popup) {\n w.location.href = opts.url;\n }\n\n if (!messageTarget) messageTarget = w;\n\n // lets listen in case the window blows up before telling us\n var closeInterval = setInterval(function() {\n if (w && w.closed) {\n cleanup();\n if (cb) {\n cb('User closed the popup window');\n cb = null;\n }\n }\n }, 500);\n\n var req = JSON.stringify({a: 'request', d: opts.params});\n\n // cleanup on unload\n function cleanup() {\n if (iframe) document.body.removeChild(iframe);\n iframe = undefined;\n if (closeInterval) closeInterval = clearInterval(closeInterval);\n removeListener(window, 'message', onMessage);\n removeListener(window, 'unload', cleanup);\n if (w) {\n try {\n w.close();\n } catch (securityViolation) {\n // This happens in Opera 12 sometimes\n // see https://github.com/mozilla/browserid/issues/1844\n messageTarget.postMessage(CLOSE_CMD, origin);\n }\n }\n w = messageTarget = undefined;\n }\n\n addListener(window, 'unload', cleanup);\n\n function onMessage(e) {\n if (e.origin !== origin) { return; }\n try {\n var d = JSON.parse(e.data);\n } catch(err) {\n if (cb) {\n return cb(err);\n } else {\n throw err;\n }\n }\n\n if (d.a === 'ready') {\n messageTarget.postMessage(req, origin);\n } else if (d.a === 'error') {\n cleanup();\n if (cb) {\n cb(d.d);\n cb = null;\n }\n } else if (d.a === 'response') {\n cleanup();\n if (cb) {\n cb(null, d.d);\n cb = null;\n }\n }\n }\n\n addListener(window, 'message', onMessage);\n\n return {\n originalPopup: w,\n close: cleanup,\n focus: function() {\n if (w) {\n try {\n w.focus();\n } catch (e) {\n // IE7 blows up here, do nothing\n }\n }\n }\n };\n },\n onOpen: function(cb) {\n var o = \"*\";\n var msgTarget = isIE ? findRelay() : window.opener;\n if (!msgTarget) throw \"can't find relay frame\";\n function doPost(msg) {\n msg = JSON.stringify(msg);\n if (isIE) msgTarget.doPost(msg, o);\n else msgTarget.postMessage(msg, o);\n }\n\n function onMessage(e) {\n // only one message gets through, but let's make sure it's actually\n // the message we're looking for (other code may be using\n // postmessage) - we do this by ensuring the payload can\n // be parsed, and it's got an 'a' (action) value of 'request'.\n var d;\n try {\n d = JSON.parse(e.data);\n } catch(err) { }\n if (!d || d.a !== 'request') return;\n removeListener(window, 'message', onMessage);\n o = e.origin;\n if (cb) {\n // this setTimeout is critically important for IE8 -\n // in ie8 sometimes addListener for 'message' can synchronously\n // cause your callback to be invoked. awesome.\n setTimeout(function() {\n cb(o, d.d, function(r) {\n cb = undefined;\n doPost({a: 'response', d: r});\n });\n }, 0);\n }\n }\n\n function onDie(e) {\n if (e.data === CLOSE_CMD) {\n try { window.close(); } catch (o_O) {}\n }\n }\n addListener(isIE ? msgTarget : window, 'message', onMessage);\n addListener(isIE ? msgTarget : window, 'message', onDie);\n\n // we cannot post to our parent that we're ready before the iframe\n // is loaded. (IE specific possible failure)\n try {\n doPost({a: \"ready\"});\n } catch(e) {\n // this code should never be exectued outside IE\n addListener(msgTarget, 'load', function(e) {\n doPost({a: \"ready\"});\n });\n }\n\n // if window is unloaded and the client hasn't called cb, it's an error\n var onUnload = function() {\n try {\n // IE8 doesn't like this...\n removeListener(isIE ? msgTarget : window, 'message', onDie);\n } catch (ohWell) { }\n if (cb) doPost({ a: 'error', d: 'client closed window' });\n cb = undefined;\n // explicitly close the window, in case the client is trying to reload or nav\n try { window.close(); } catch (e) { }\n };\n addListener(window, 'unload', onUnload);\n return {\n detach: function() {\n removeListener(window, 'unload', onUnload);\n }\n };\n }\n };\n } else {\n return {\n open: function(url, winopts, arg, cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n },\n onOpen: function(cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n }\n };\n }\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n module.exports = WinChan;\n}\n","// given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\nfunction extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[-_a-zA-Z.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n}\n\nexport default {\n extractOrigin: extractOrigin\n};\n","/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\nimport WinChan from 'winchan';\n\nimport windowHandler from './window';\nimport objectHelper from './object';\nimport qs from 'qs';\n\nfunction PopupHandler() {\n this._current_popup = null;\n}\n\nPopupHandler.prototype.calculatePosition = function(options) {\n var width = options.width || 500;\n var height = options.height || 600;\n var _window = windowHandler.getWindow();\n\n var screenX =\n typeof _window.screenX !== 'undefined'\n ? _window.screenX\n : _window.screenLeft;\n var screenY =\n typeof _window.screenY !== 'undefined'\n ? _window.screenY\n : _window.screenTop;\n\n var outerWidth =\n typeof _window.outerWidth !== 'undefined'\n ? _window.outerWidth\n : _window.document.body.clientWidth;\n\n var outerHeight =\n typeof _window.outerHeight !== 'undefined'\n ? _window.outerHeight\n : _window.document.body.clientHeight;\n\n var left = options.left || screenX + (outerWidth - width) / 2;\n var top = options.top || screenY + (outerHeight - height) / 2;\n\n return { width: width, height: height, left: left, top: top };\n};\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n var url = options.url || 'about:blank';\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures);\n\n this._current_popup.kill = function() {\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, relayUrl, options, cb) {\n var _this = this;\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n\n var winchanOptions = objectHelper\n .merge({\n url: url,\n relay_url: relayUrl,\n window_features: qs.stringify(popupOptions, {\n delimiter: ',',\n encode: false\n }),\n popup: this._current_popup\n })\n .with(options);\n\n var popup = WinChan.open(winchanOptions, function(err, data) {\n // Ignores messages sent by browser extensions.\n if (err && err.name === 'SyntaxError') {\n return;\n }\n _this._current_popup = null;\n return cb(err, data);\n });\n\n popup.focus();\n\n return popup;\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport WinChan from 'winchan';\n\nimport urlHelper from '../helper/url';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\nimport PopupHandler from '../helper/popup-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport TransactionManager from './transaction-manager';\nimport CrossOriginAuthentication from './cross-origin-authentication';\n\nfunction Popup(webAuth, options) {\n this.baseOptions = options;\n this.baseOptions.popupOrigin = options.popupOrigin;\n this.client = webAuth.client;\n this.webAuth = webAuth;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n webAuth,\n this.baseOptions\n );\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * Returns a new instance of the popup handler\n *\n * @method buildPopupHandler\n * @private\n */\nPopup.prototype.buildPopupHandler = function() {\n var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler');\n\n if (pluginHandler) {\n return pluginHandler.getPopupHandler();\n }\n\n return new PopupHandler();\n};\n\n/**\n * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser.\n *\n * @method preload\n * @param {Object} options receives the window height and width and any other window feature to be sent to window.open\n */\nPopup.prototype.preload = function(options) {\n options = options || {};\n\n var popup = this.buildPopupHandler();\n\n popup.preload(options);\n return popup;\n};\n\n/**\n * Internal use.\n *\n * @method getPopupHandler\n * @private\n */\nPopup.prototype.getPopupHandler = function(options, preload) {\n if (options.popupHandler) {\n return options.popupHandler;\n }\n\n if (preload) {\n return this.preload(options);\n }\n\n return this.buildPopupHandler();\n};\n\n/**\n * Handles the popup logic for the callback page.\n *\n * @method callback\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @see {@link parseHash}\n */\nPopup.prototype.callback = function(options) {\n var _this = this;\n var theWindow = windowHelper.getWindow();\n options = options || {};\n var originUrl =\n options.popupOrigin ||\n this.baseOptions.popupOrigin ||\n windowHelper.getOrigin();\n\n /*\n in IE 11, there's a bug that makes window.opener return undefined.\n The callback page will still call `popup.callback()` which will run this method\n in the relay page. WinChan expects the relay page to have a global `doPost` function,\n which will be called with the response.\n\n IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/\n */\n if (!theWindow.opener) {\n theWindow.doPost = function(msg) {\n if (theWindow.parent) {\n theWindow.parent.postMessage(msg, originUrl);\n }\n };\n return;\n }\n\n WinChan.onOpen(function(popupOrigin, r, cb) {\n if (popupOrigin !== originUrl) {\n return cb({\n error: 'origin_mismatch',\n error_description:\n \"The popup's origin (\" +\n popupOrigin +\n ') should match the `popupOrigin` parameter (' +\n originUrl +\n ').'\n });\n }\n _this.webAuth.parseHash(options || {}, function(err, data) {\n return cb(err || data);\n });\n });\n};\n\n/**\n * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`.\n *\n * @method authorize\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response.\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nPopup.prototype.authorize = function(options, cb) {\n var popup;\n var url;\n var relayUrl;\n var popOpts = {};\n\n var pluginHandler = this.baseOptions.plugins.get('popup.authorize');\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'scope',\n 'domain',\n 'audience',\n 'tenant',\n 'responseType',\n 'redirectUri',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(objectHelper.blacklist(options, ['popupHandler']));\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n // the relay page should not be necessary as long it happens in the same domain\n // (a redirectUri shoul be provided). It is necessary when using OWP\n relayUrl = urljoin(this.baseOptions.rootUrl, 'relay.html');\n\n // if a owp is enabled, it should use the owp flag\n if (options.owp) {\n // used by server to render the relay page instead of sending the chunk in the\n // url to the callback\n params.owp = true;\n } else {\n popOpts.origin = urlHelper.extractOrigin(params.redirectUri);\n relayUrl = params.redirectUri;\n }\n\n if (options.popupOptions) {\n popOpts.popupOptions = objectHelper.pick(options.popupOptions, [\n 'width',\n 'height',\n 'top',\n 'left'\n ]);\n }\n\n if (pluginHandler) {\n params = pluginHandler.processParams(params);\n }\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n delete params.domain;\n\n url = this.client.buildAuthorizeUrl(params);\n\n popup = this.getPopupHandler(options);\n\n return popup.load(\n url,\n relayUrl,\n popOpts,\n responseHandler(cb, { keepOriginalCasing: true })\n );\n};\n\n/**\n * Performs authentication with username/email and password with a database connection inside a new window\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method loginWithCredentials\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`.\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nPopup.prototype.loginWithCredentials = function(options, cb) {\n options.realm = options.realm || options.connection;\n options.popup = true;\n options = objectHelper\n .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce'])\n .with(objectHelper.blacklist(options, ['popupHandler', 'connection']));\n options = this.transactionManager.process(options);\n this.crossOriginAuthentication.login(options, cb);\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nPopup.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n return this.client.passwordless.verify(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n\n options.username = options.phoneNumber || options.email;\n options.password = options.verificationCode;\n\n delete options.email;\n delete options.phoneNumber;\n delete options.verificationCode;\n delete options.type;\n\n _this.client.loginWithResourceOwner(options, cb);\n }\n );\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link signupAndAuthorize}.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nPopup.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n _this.loginWithCredentials(options, cb);\n });\n};\n\nexport default Popup;\n","import IframeHandler from '../helper/iframe-handler';\nimport windowHelper from '../helper/window';\n\nfunction SilentAuthenticationHandler(options) {\n this.authenticationUrl = options.authenticationUrl;\n this.timeout = options.timeout || 60 * 1000;\n this.handler = null;\n this.postMessageDataType = options.postMessageDataType || false;\n\n // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually\n this.postMessageOrigin =\n options.postMessageOrigin ||\n windowHelper.getWindow().location.origin ||\n windowHelper.getWindow().location.protocol +\n '//' +\n windowHelper.getWindow().location.hostname +\n (windowHelper.getWindow().location.port\n ? ':' + windowHelper.getWindow().location.port\n : '');\n}\n\nSilentAuthenticationHandler.create = function(options) {\n return new SilentAuthenticationHandler(options);\n};\n\nSilentAuthenticationHandler.prototype.login = function(\n usePostMessage,\n callback\n) {\n this.handler = new IframeHandler({\n auth0: this.auth0,\n url: this.authenticationUrl,\n eventListenerType: usePostMessage ? 'message' : 'load',\n callback: this.getCallbackHandler(callback, usePostMessage),\n timeout: this.timeout,\n eventValidator: this.getEventValidator(),\n timeoutCallback: function() {\n callback(\n null,\n '#error=timeout&error_description=Timeout+during+authentication+renew.'\n );\n },\n usePostMessage: usePostMessage || false\n });\n\n this.handler.init();\n};\n\nSilentAuthenticationHandler.prototype.getEventValidator = function() {\n var _this = this;\n return {\n isValid: function(eventData) {\n switch (eventData.event.type) {\n case 'message':\n // Message must come from the expected origin and iframe window.\n if (\n eventData.event.origin !== _this.postMessageOrigin ||\n eventData.event.source !== _this.handler.iframe.contentWindow\n ) {\n return false;\n }\n\n // Default behaviour, return all message events from the iframe.\n if (_this.postMessageDataType === false) {\n return true;\n }\n\n return (\n eventData.event.data.type &&\n eventData.event.data.type === _this.postMessageDataType\n );\n\n case 'load':\n if (\n eventData.sourceObject.contentWindow.location.protocol === 'about:'\n ) {\n // Chrome is automatically loading the about:blank page, we ignore this.\n return false;\n }\n // Fall through to default\n default:\n return true;\n }\n }\n };\n};\n\nSilentAuthenticationHandler.prototype.getCallbackHandler = function(\n callback,\n usePostMessage\n) {\n return function(eventData) {\n var callbackValue;\n if (!usePostMessage) {\n callbackValue = eventData.sourceObject.contentWindow.location.hash;\n } else if (\n typeof eventData.event.data === 'object' &&\n eventData.event.data.hash\n ) {\n callbackValue = eventData.event.data.hash;\n } else {\n callbackValue = eventData.event.data;\n }\n callback(null, callbackValue);\n };\n};\n\nexport default SilentAuthenticationHandler;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport windowHelper from '../helper/window';\nimport TransactionManager from './transaction-manager';\n\nfunction UsernamePassword(options) {\n this.baseOptions = options;\n this.request = new RequestBuilder(options);\n this.transactionManager = new TransactionManager(this.baseOptions);\n}\n\nUsernamePassword.prototype.login = function(options, cb) {\n var url;\n var body;\n\n url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'login');\n\n options.username = options.username || options.email; // eslint-disable-line\n\n options = objectHelper.blacklist(options, ['email']); // eslint-disable-line\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience'\n ])\n .with(options);\n body = this.transactionManager.process(body);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nUsernamePassword.prototype.callback = function(formHtml) {\n var div;\n var form;\n var _document = windowHelper.getDocument();\n\n div = _document.createElement('div');\n div.innerHTML = formHtml;\n form = _document.body.appendChild(div).children[0];\n\n form.submit();\n};\n\nexport default UsernamePassword;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport UsernamePassword from './username-password';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport assert from '../helper/assert';\n\nfunction HostedPages(client, options) {\n this.baseOptions = options;\n this.client = client;\n this.baseOptions.universalLoginPage = true;\n this.request = new RequestBuilder(this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * @callback credentialsCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the AuthN request\n * @param {String} result.accessToken token that can be used with {@link userinfo}\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Performs authentication with username/email and password with a database connection\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method login\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.login = function(options, cb) {\n if (windowHelper.getWindow().location.host !== this.baseOptions.domain) {\n throw new Error(\n 'This method is meant to be used only inside the Universal Login Page.'\n );\n }\n var usernamePassword;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n usernamePassword = new UsernamePassword(this.baseOptions);\n return usernamePassword.login(params, function(err, data) {\n if (err) {\n return cb(err);\n }\n return usernamePassword.callback(data);\n });\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n return _this.client.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n return _this.login(options, cb);\n });\n};\n\nHostedPages.prototype.getSSOData = function(withActiveDirectories, cb) {\n var url;\n var params = '';\n\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n withActiveDirectories = false;\n }\n\n assert.check(withActiveDirectories, {\n type: 'boolean',\n message: 'withActiveDirectories parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (withActiveDirectories) {\n params =\n '?' +\n qs.stringify({\n ldaps: 1,\n client_id: this.baseOptions.clientID\n });\n }\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'ssodata', params);\n\n return this.request\n .get(url, { noHeaders: true })\n .withCredentials()\n .end(responseHandler(cb));\n};\n\nexport default HostedPages;\n","// eslint-disable-next-line no-unused-vars\nimport Authentication from '../authentication';\nimport object from '../helper/object';\n\nvar noop = function () { };\n\nvar defaults = {\n lang: 'en',\n templates: {\n 'auth0': function (challenge) {\n var message = challenge.type === 'code' ?\n 'Enter the code shown above' :\n 'Solve the formula shown above';\n return '
\\n' +\n ' \\n' +\n ' \\n' +\n '
\\n' +\n '';\n }\n ,\n 'recaptcha_v2': function () {\n return '
';\n }\n ,\n 'error': function () {\n return '
Error getting the bot detection challenge. Please contact the system administrator.
'\n }\n }\n};\n\nfunction handleAuth0Provider(element, options, challenge, load) {\n element.innerHTML = options.templates[challenge.provider](challenge);\n element.querySelector('.captcha-reload').addEventListener('click', function (e) {\n e.preventDefault();\n load();\n });\n}\n\nfunction injectRecaptchaScript(element, lang, callback) {\n var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001);\n window[callbackName] = function () {\n delete window[callbackName];\n callback();\n };\n var script = window.document.createElement('script');\n script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName;\n script.async = true;\n window.document.body.appendChild(script);\n}\n\nfunction handleRecaptchaProvider(element, options, challenge) {\n var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid');\n\n function setValue(value) {\n var input = element.querySelector('input[name=\"captcha\"]');\n input.value = value || '';\n }\n\n if (widgetId) {\n setValue();\n window.grecaptcha.reset(widgetId);\n return;\n }\n\n element.innerHTML = options.templates[challenge.provider](challenge);\n\n var recaptchaDiv = element.querySelector('.recaptcha');\n\n injectRecaptchaScript(element, options.lang, function () {\n widgetId = window.grecaptcha.render(recaptchaDiv, {\n callback: setValue,\n 'expired-callback': function () { setValue(); },\n 'error-callback': function () { setValue(); },\n sitekey: challenge.siteKey\n });\n element.setAttribute('data-wid', widgetId)\n });\n}\n\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n *\n * @param {Authentication} auth0Client The challenge response from the authentication server\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha*\n * @param {Function} [callback] an optional callback function\n */\nfunction render(auth0Client, element, options, callback) {\n options = object.merge(defaults).with(options || {});\n\n function load(done) {\n done = done || noop;\n auth0Client.getChallenge(function (err, challenge) {\n if (err) {\n element.innerHTML = options.templates.error(err);\n return done(err);\n }\n if (!challenge.required) {\n element.style.display = 'none';\n element.innerHTML = '';\n return;\n }\n element.style.display = '';\n if (challenge.provider === 'auth0') {\n handleAuth0Provider(element, options, challenge, load);\n } else if (challenge.provider === 'recaptcha_v2') {\n handleRecaptchaProvider(element, options, challenge);\n }\n done();\n });\n }\n\n function getValue() {\n var captchaInput = element.querySelector('input[name=\"captcha\"]');\n if (!captchaInput) { return; }\n return captchaInput.value;\n }\n\n load(callback);\n\n return {\n reload: load,\n getValue: getValue\n };\n}\n\nexport default { render: render };\n","import IdTokenVerifier from 'idtoken-verifier';\nimport qs from 'qs';\n\nimport assert from '../helper/assert';\nimport error from '../helper/error';\nimport PluginHandler from '../helper/plugins';\nimport windowHelper from '../helper/window';\nimport objectHelper from '../helper/object';\nimport SSODataStorage from '../helper/ssodata';\nimport responseHandler from '../helper/response-handler';\nimport TransactionManager from './transaction-manager';\nimport Authentication from '../authentication';\nimport Redirect from './redirect';\nimport Popup from './popup';\nimport SilentAuthenticationHandler from './silent-authentication-handler';\nimport CrossOriginAuthentication from './cross-origin-authentication';\nimport WebMessageHandler from './web-message-handler';\nimport HostedPages from './hosted-pages';\nimport captcha from './captcha';\n\nfunction defaultClock() {\n return new Date();\n}\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds.\n * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server.\n * @param {Array} [options.plugins]\n * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js}\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction WebAuth(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n popupOrigin: {\n optional: true,\n type: 'string',\n message: 'popupOrigin is not valid'\n },\n leeway: {\n optional: true,\n type: 'number',\n message: 'leeway is not valid'\n },\n plugins: {\n optional: true,\n type: 'array',\n message: 'plugins is not valid'\n },\n maxAge: {\n optional: true,\n type: 'number',\n message: 'maxAge is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n _timesToRetryFailedRequests: {\n optional: true,\n type: 'number',\n message: '_timesToRetryFailedRequests option is not valid'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(\n options.overrides,\n { type: 'object', message: 'overrides option is not valid' },\n {\n __tenant: {\n optional: true,\n type: 'string',\n message: '__tenant option is required'\n },\n __token_issuer: {\n optional: true,\n type: 'string',\n message: '__token_issuer option is required'\n },\n __jwks_uri: {\n optional: true,\n type: 'string',\n message: '__jwks_uri is required'\n }\n }\n );\n }\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions.plugins = new PluginHandler(\n this,\n this.baseOptions.plugins || []\n );\n\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n\n this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests\n ? parseInt(options._timesToRetryFailedRequests, 0)\n : 0;\n\n this.baseOptions.tenant =\n (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) ||\n this.baseOptions.domain.split('.')[0];\n\n this.baseOptions.token_issuer =\n (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) ||\n 'https://' + this.baseOptions.domain + '/';\n\n this.baseOptions.jwksURI =\n this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n\n this.client = new Authentication(this.baseOptions);\n this.redirect = new Redirect(this, this.baseOptions);\n this.popup = new Popup(this, this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n this,\n this.baseOptions\n );\n this.webMessageHandler = new WebMessageHandler(this);\n this._universalLogin = new HostedPages(this, this.baseOptions);\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method parseHash\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType.\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.parseHash = function(options, cb) {\n var parsedQs;\n var err;\n\n if (!cb && typeof options === 'function') {\n cb = options;\n options = {};\n } else {\n options = options || {};\n }\n\n var _window = windowHelper.getWindow();\n\n var hashStr =\n options.hash === undefined ? _window.location.hash : options.hash;\n hashStr = hashStr.replace(/^#?\\/?/, '');\n\n parsedQs = qs.parse(hashStr);\n\n if (parsedQs.hasOwnProperty('error')) {\n err = error.buildResponse(parsedQs.error, parsedQs.error_description);\n\n if (parsedQs.state) {\n err.state = parsedQs.state;\n }\n\n return cb(err);\n }\n\n if (\n !parsedQs.hasOwnProperty('access_token') &&\n !parsedQs.hasOwnProperty('id_token') &&\n !parsedQs.hasOwnProperty('refresh_token')\n ) {\n return cb(null, null);\n }\n var responseTypes = (\n this.baseOptions.responseType ||\n options.responseType ||\n ''\n ).split(' ');\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('token') !== -1 &&\n !parsedQs.hasOwnProperty('access_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `token`, but the parsed hash does not contain an `access_token` property'\n )\n );\n }\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('id_token') !== -1 &&\n !parsedQs.hasOwnProperty('id_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property'\n )\n );\n }\n return this.validateAuthenticationResponse(options, parsedQs, cb);\n};\n\n/**\n * Validates an Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method validateAuthenticationResponse\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {Object} parsedHash an object that represents the parsed hash\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.validateAuthenticationResponse = function(\n options,\n parsedHash,\n cb\n) {\n var _this = this;\n options.__enableIdPInitiatedLogin =\n options.__enableIdPInitiatedLogin || options.__enableImpersonation;\n var state = parsedHash.state;\n var transaction = this.transactionManager.getStoredTransaction(state);\n var transactionState =\n options.state || (transaction && transaction.state) || null;\n\n var transactionStateMatchesState = transactionState === state;\n var shouldBypassStateChecking =\n !state && !transactionState && options.__enableIdPInitiatedLogin;\n\n if (!shouldBypassStateChecking && !transactionStateMatchesState) {\n return cb({\n error: 'invalid_token',\n errorDescription: '`state` does not match.'\n });\n }\n var transactionNonce =\n options.nonce || (transaction && transaction.nonce) || null;\n\n var appState = options.state || (transaction && transaction.appState) || null;\n\n var callback = function(err, payload) {\n if (err) {\n return cb(err);\n }\n if (transaction && transaction.lastUsedConnection) {\n var sub;\n if (payload) {\n sub = payload.sub;\n }\n _this.ssodataStorage.set(transaction.lastUsedConnection, sub);\n }\n return cb(null, buildParseHashResponse(parsedHash, appState, payload));\n };\n\n if (!parsedHash.id_token) {\n return callback(null, null);\n }\n return this.validateToken(parsedHash.id_token, transactionNonce, function(\n validationError,\n payload\n ) {\n if (!validationError) {\n if (!parsedHash.access_token) {\n return callback(null, payload);\n }\n // id_token's generated by non-oidc applications don't have at_hash\n if (!payload.at_hash) {\n return callback(null, payload);\n }\n // here we're absolutely sure that the id_token's alg is RS256\n // and that the id_token is valid, so we can check the access_token\n return new IdTokenVerifier().validateAccessToken(\n parsedHash.access_token,\n 'RS256',\n payload.at_hash,\n function(err) {\n if (err) {\n return callback(error.invalidToken(err.message));\n }\n return callback(null, payload);\n }\n );\n }\n\n if (\n validationError.error !== 'invalid_token' ||\n (validationError.errorDescription &&\n validationError.errorDescription.indexOf(\n 'Nonce (nonce) claim value mismatch in the ID token'\n ) > -1)\n ) {\n return callback(validationError);\n }\n\n // if it's an invalid_token error, decode the token\n var decodedToken = new IdTokenVerifier().decode(parsedHash.id_token);\n\n // if the alg is not HS256, return the raw error\n if (decodedToken.header.alg !== 'HS256') {\n return callback(validationError);\n }\n\n if ((decodedToken.payload.nonce || null) !== transactionNonce) {\n return callback({\n error: 'invalid_token',\n errorDescription:\n 'Nonce (nonce) claim value mismatch in the ID token; expected \"' +\n transactionNonce +\n '\", found \"' +\n decodedToken.payload.nonce +\n '\"'\n });\n }\n\n if (!parsedHash.access_token) {\n var noAccessTokenError = {\n error: 'invalid_token',\n description:\n 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token'\n };\n return callback(noAccessTokenError);\n }\n\n // if the alg is HS256, use the /userinfo endpoint to build the payload\n return _this.client.userInfo(parsedHash.access_token, function(\n errUserInfo,\n profile\n ) {\n // if the /userinfo request fails, use the validationError instead\n if (errUserInfo) {\n return callback(errUserInfo);\n }\n return callback(null, profile);\n });\n });\n};\n\nfunction buildParseHashResponse(qsParams, appState, token) {\n return {\n accessToken: qsParams.access_token || null,\n idToken: qsParams.id_token || null,\n idTokenPayload: token || null,\n appState: appState || null,\n refreshToken: qsParams.refresh_token || null,\n state: qsParams.state || null,\n expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null,\n tokenType: qsParams.token_type || null,\n scope: qsParams.scope || null\n };\n}\n\n/**\n * @callback validateTokenCallback\n * @param {Error} [err] error returned by while validating the token\n * @param {Object} [payload] claims stored in the token\n */\n\n/**\n * Decodes the a JWT and verifies its nonce value\n *\n * @method validateToken\n * @private\n * @param {String} token\n * @param {String} nonce\n * @param {validateTokenCallback} cb\n */\nWebAuth.prototype.validateToken = function(token, nonce, cb) {\n var verifier = new IdTokenVerifier({\n issuer: this.baseOptions.token_issuer,\n jwksURI: this.baseOptions.jwksURI,\n audience: this.baseOptions.clientID,\n leeway: this.baseOptions.leeway || 60,\n maxAge: this.baseOptions.maxAge,\n __clock: this.baseOptions.__clock || defaultClock\n });\n\n verifier.verify(token, nonce, function(err, payload) {\n if (err) {\n return cb(error.invalidToken(err.message));\n }\n\n cb(null, payload);\n });\n};\n\n/**\n * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session.\n * This method requires that all Auth is performed with {@link authorize}\n * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method.\n *\n * @method renewAuth\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback.\n * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy.\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.renewAuth = function(options, cb) {\n var handler;\n var usePostMessage = !!options.usePostMessage;\n var postMessageDataType = options.postMessageDataType || false;\n var postMessageOrigin =\n options.postMessageOrigin || windowHelper.getWindow().origin;\n var timeout = options.timeout;\n var _this = this;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'responseType',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n params.responseType = params.responseType || 'token';\n params.responseMode = params.responseMode || 'fragment';\n params = this.transactionManager.process(params);\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params.prompt = 'none';\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType',\n 'postMessageOrigin'\n ]);\n\n handler = SilentAuthenticationHandler.create({\n authenticationUrl: this.client.buildAuthorizeUrl(params),\n postMessageDataType: postMessageDataType,\n postMessageOrigin: postMessageOrigin,\n timeout: timeout\n });\n\n handler.login(usePostMessage, function(err, hash) {\n if (typeof hash === 'object') {\n // hash was already parsed, so we just return it.\n // it's here to be backwards compatible and should be removed in the next major version.\n return cb(err, hash);\n }\n _this.parseHash({ hash: hash }, cb);\n });\n};\n\n/**\n * Renews an existing session on Auth0's servers using `response_mode=web_message`\n *\n * @method checkSession\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {checkSessionCallback} cb\n * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens}\n */\nWebAuth.prototype.checkSession = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n if (params.responseType === 'code') {\n return cb({\n error: 'error',\n error_description: \"responseType can't be `code`\"\n });\n }\n\n if (!options.nonce) {\n params = this.transactionManager.process(params);\n }\n\n if (!params.redirectUri) {\n return cb({\n error: 'error',\n error_description: \"redirectUri can't be empty\"\n });\n }\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType'\n ]);\n this.webMessageHandler.run(\n params,\n responseHandler(cb, { forceLegacyError: true, ignoreCasing: true })\n );\n};\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nWebAuth.prototype.changePassword = function(options, cb) {\n return this.client.dbConnection.changePassword(options, cb);\n};\n\n/**\n * Starts a passwordless authentication transaction.\n *\n * @method passwordlessStart\n * @param {Object} options\n * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid\n * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email`\n * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber`\n * @param {String} options.connection name of the passwordless connection\n * @param {Object} [options.authParams] additional Auth parameters when using `link`\n * @param {Function} cb\n * @see {@link https://auth0.com/docs/api/authentication#passwordless}\n */\nWebAuth.prototype.passwordlessStart = function(options, cb) {\n var authParams = objectHelper\n .merge(this.baseOptions, [\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options.authParams);\n\n options.authParams = this.transactionManager.process(authParams);\n return this.client.passwordless.start(options, cb);\n};\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nWebAuth.prototype.signup = function(options, cb) {\n return this.client.dbConnection.signup(options, cb);\n};\n\n/**\n * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction.\n * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`.\n *\n * @method authorize\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} [options.appState] any values that you want back on the authentication response\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.authorize = function(options) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n\n windowHelper.redirect(this.client.buildAuthorizeUrl(params));\n};\n\n/**\n * Signs up a new user, automatically logs the user in after the signup and returns the user token.\n * The login will be done using /oauth/token with password-realm grant type.\n *\n * @method signupAndAuthorize\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {tokenCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n * @see {@link https://auth0.com/docs/api-auth/grant/password}\n */\nWebAuth.prototype.signupAndAuthorize = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n options.realm = options.connection;\n if (!options.username) {\n options.username = options.email;\n }\n _this.client.login(options, cb);\n }\n );\n};\n\n/**\n * @callback crossOriginLoginCallback\n * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Logs the user in with username and password using the correct flow based on where it's called from:\n * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint\n * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow\n * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`.\n * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data.\n * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.**\n *\n * @method login\n * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.username] Username (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.password Password\n * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.login = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n params.connection = params.realm;\n delete params.realm;\n this._universalLogin.login(params, cb);\n } else {\n this.crossOriginAuthentication.login(params, cb);\n }\n};\n\n/**\n * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user.\n * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor.\n *\n * @method passwordlessLogin\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.verificationCode Verification Code (OTP)\n * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'.\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.passwordlessLogin = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n this.passwordlessVerify(params, cb);\n } else {\n var crossOriginOptions = objectHelper.extend(\n {\n credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp',\n realm: params.connection,\n username: params.email || params.phoneNumber,\n otp: params.verificationCode\n },\n objectHelper.blacklist(params, [\n 'connection',\n 'email',\n 'phoneNumber',\n 'verificationCode'\n ])\n );\n this.crossOriginAuthentication.login(crossOriginOptions, cb);\n }\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginAuthenticationCallback\n * @deprecated Use {@link crossOriginVerification} instead.\n */\nWebAuth.prototype.crossOriginAuthenticationCallback = function() {\n this.crossOriginVerification();\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginVerification\n */\nWebAuth.prototype.crossOriginVerification = function() {\n this.crossOriginAuthentication.callback();\n};\n\n/**\n * Redirects to the auth0 logout endpoint\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n *\n * @method logout\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nWebAuth.prototype.logout = function(options) {\n windowHelper.redirect(this.client.buildLogoutUrl(options));\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nWebAuth.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n return this.client.passwordless.verify(params, function(err) {\n if (err) {\n return cb(err);\n }\n return windowHelper.redirect(\n _this.client.passwordless.buildVerifyUrl(params)\n );\n });\n};\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n * This function can only be used in the context of a Classic Universal Login Page.\n *\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha\n * @param {Function} [callback] An optional completion callback\n */\nWebAuth.prototype.renderCaptcha = function(element, options, callback) {\n return captcha.render(this.client, element, options, callback);\n};\n\nexport default WebAuth;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport qs from 'qs';\nimport responseHandler from '../helper/response-handler';\n\nfunction PasswordlessAuthentication(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\nPasswordlessAuthentication.prototype.buildVerifyUrl = function(options) {\n var params;\n var qString;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'protocol',\n 'nonce'\n ])\n .with(options);\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n\n qString = qs.stringify(params);\n\n return urljoin(\n this.baseOptions.rootUrl,\n 'passwordless',\n 'verify_redirect',\n '?' + qString\n );\n};\n\nPasswordlessAuthentication.prototype.start = function(options, cb) {\n var url;\n var body;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n send: {\n type: 'string',\n message: 'send option is required',\n values: ['link', 'code'],\n value_message: 'send is not valid ([link, code])'\n },\n phoneNumber: {\n optional: true,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return o.send === 'code' || !o.email;\n }\n },\n email: {\n optional: true,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return o.send === 'link' || !o.phoneNumber;\n }\n },\n authParams: {\n optional: true,\n type: 'object',\n message: 'authParams option is required'\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'start');\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope'\n ])\n .with(options);\n\n if (body.scope) {\n body.authParams = body.authParams || {};\n body.authParams.scope = body.authParams.scope || body.scope;\n }\n\n if (body.redirectUri) {\n body.authParams = body.authParams || {};\n body.authParams.redirect_uri =\n body.authParams.redirectUri || body.redirectUri;\n }\n\n if (body.responseType) {\n body.authParams = body.authParams || {};\n body.authParams.response_type =\n body.authParams.responseType || body.responseType;\n }\n\n delete body.redirectUri;\n delete body.responseType;\n delete body.scope;\n\n body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nPasswordlessAuthentication.prototype.verify = function(options, cb) {\n var url;\n var cleanOption;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n cleanOption = objectHelper.pick(options, [\n 'connection',\n 'verificationCode',\n 'phoneNumber',\n 'email',\n 'auth0Client'\n ]);\n cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']);\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'verify');\n\n return this.request\n .post(url)\n .send(cleanOption)\n .end(responseHandler(cb));\n};\n\nexport default PasswordlessAuthentication;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\nfunction DBConnection(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\n/**\n * @callback signUpCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the signup failed\n * @param {Object} [result] result of the signup request\n * @param {Object} result.email user's email\n * @param {Object} result.emailVerified if the user's email was verified\n */\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username`\n * @param {String} options.connection name of the connection where the user will be created\n * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata`\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nDBConnection.prototype.signup = function(options, cb) {\n var url;\n var body;\n var metadata;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' },\n password: { type: 'string', message: 'password option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'signup');\n\n body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options);\n\n metadata = body.user_metadata || body.userMetadata;\n\n body = objectHelper.blacklist(body, [\n 'scope',\n 'userMetadata',\n 'user_metadata'\n ]);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n if (metadata) {\n body.user_metadata = metadata;\n }\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * @callback changePasswordCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nDBConnection.prototype.changePassword = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options, ['email', 'connection']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nexport default DBConnection;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport RequestBuilder from '../helper/request-builder';\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport SSODataStorage from '../helper/ssodata';\nimport windowHelper from '../helper/window';\nimport responseHandler from '../helper/response-handler';\nimport parametersWhitelist from '../helper/parameters-whitelist';\nimport Warn from '../helper/warn';\nimport WebAuth from '../web-auth/index';\nimport PasswordlessAuthentication from './passwordless-authentication';\nimport DBConnection from './db-connection';\n\n/**\n * Creates a new Auth0 Authentication API client\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction Authentication(auth0, options) {\n // If we have two arguments, the first one is a WebAuth instance, so we assign that\n // if not, it's an options object and then we should use that as options instead\n // this is here because we don't want to break people coming from v8\n if (arguments.length === 2) {\n this.auth0 = auth0;\n } else {\n options = auth0;\n }\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n \n this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0)\n ? this.baseOptions.domain\n : 'https://' + this.baseOptions.domain;\n \n this.request = new RequestBuilder(this.baseOptions);\n\n this.passwordless = new PasswordlessAuthentication(\n this.request,\n this.baseOptions\n );\n this.dbConnection = new DBConnection(this.request, this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction\n *\n * @method buildAuthorizeUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n * @see {@link https://auth0.com/docs/api/authentication#social}\n */\nAuthentication.prototype.buildAuthorizeUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience'\n ])\n .with(options);\n\n /* eslint-disable */\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri option is required'\n },\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n },\n nonce: {\n type: 'string',\n message: 'nonce option is required',\n condition: function(o) {\n return (\n o.responseType.indexOf('code') === -1 &&\n o.responseType.indexOf('id_token') !== -1\n );\n }\n },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n /* eslint-enable */\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n if (params.connection_scope && assert.isArray(params.connection_scope)) {\n params.connection_scope = params.connection_scope.join(',');\n }\n\n params = objectHelper.blacklist(params, [\n 'username',\n 'popupOptions',\n 'domain',\n 'tenant',\n 'timeout',\n 'appState'\n ]);\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n params = parametersWhitelist.oauthAuthorizeParams(this.warn, params);\n\n qString = qs.stringify(params);\n\n return urljoin(this.baseOptions.rootUrl, 'authorize', '?' + qString);\n};\n\n/**\n * Builds and returns the Logout url in order to initialize a new authN/authZ transaction\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n * @method buildLogoutUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nAuthentication.prototype.buildLogoutUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n optional: true,\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options || {});\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']);\n\n qString = qs.stringify(objectHelper.blacklist(params, ['federated']));\n if (\n options &&\n options.federated !== undefined &&\n options.federated !== false &&\n options.federated !== 'false'\n ) {\n qString += '&federated';\n }\n\n return urljoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString);\n};\n\n/**\n * @callback authorizeCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null.\n * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} [result.expiresIn] number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n * @param {Object} [result.appState] values that you receive back on the authentication response\n */\n\n/**\n * @callback tokenCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request\n * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} result.expiresIn number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory.\n *\n * @method loginWithDefaultDirectory\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.loginWithDefaultDirectory = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'password';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password-realm` grant type\n *\n * @method login\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.login = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n realm: { type: 'string', message: 'realm option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'http://auth0.com/oauth/grant-type/password-realm';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint\n *\n * @method oauthToken\n * @private\n */\nAuthentication.prototype.oauthToken = function(options, cb) {\n var url;\n var body;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'token');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope', 'audience'])\n .with(options);\n\n assert.check(\n body,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n grantType: { type: 'string', message: 'grantType option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n body = parametersWhitelist.oauthTokenParams(this.warn, body);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Performs authentication calling `/oauth/ro` endpoint with username\n * and password for a given connection name.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link login} or {@link loginWithDefaultDirectory}.\n *\n * @method loginWithResourceOwner\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.device] name of the device/browser where the Auth was requested\n * @param {tokenCallback} cb function called with the result of the request\n */\nAuthentication.prototype.loginWithResourceOwner = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n connection: { type: 'string', message: 'connection option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'ro');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope'])\n .with(options, ['username', 'password', 'scope', 'connection', 'device']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n body.grant_type = body.grant_type || 'password';\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Uses {@link checkSession} and localStorage to return data from the last successful authentication request.\n *\n * @method getSSOData\n * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible\n * @param {Function} cb\n */\nAuthentication.prototype.getSSOData = function(withActiveDirectories, cb) {\n /* istanbul ignore if */\n if (!this.auth0) {\n this.auth0 = new WebAuth(this.baseOptions);\n }\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb);\n }\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n }\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n var clientId = this.baseOptions.clientID;\n var ssodataInformation = this.ssodataStorage.get() || {};\n\n this.auth0.checkSession(\n {\n responseType: 'token id_token',\n scope: 'openid profile email',\n connection: ssodataInformation.lastUsedConnection,\n timeout: 5000\n },\n function(err, result) {\n if (err) {\n if (err.error === 'login_required') {\n return cb(null, { sso: false });\n }\n if (err.error === 'consent_required') {\n err.error_description =\n 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.';\n }\n return cb(err, { sso: false });\n }\n if (\n ssodataInformation.lastUsedSub &&\n ssodataInformation.lastUsedSub !== result.idTokenPayload.sub\n ) {\n return cb(err, { sso: false });\n }\n return cb(null, {\n lastUsedConnection: {\n name: ssodataInformation.lastUsedConnection\n },\n lastUsedUserID: result.idTokenPayload.sub,\n lastUsedUsername:\n result.idTokenPayload.email || result.idTokenPayload.name,\n lastUsedClientID: clientId,\n sessionClients: [clientId],\n sso: true\n });\n }\n );\n};\n\n/**\n * @callback userInfoCallback\n * @param {Error} [err] error returned by Auth0\n * @param {Object} [userInfo] user information\n */\n\n/**\n * Makes a call to the `/userinfo` endpoint and returns the user profile\n *\n * @method userInfo\n * @param {String} accessToken token issued to a user after Auth\n * @param {userInfoCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#get-user-info}\n */\nAuthentication.prototype.userInfo = function(accessToken, cb) {\n var url;\n\n assert.check(accessToken, {\n type: 'string',\n message: 'accessToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'userinfo');\n\n return this.request\n .get(url)\n .set('Authorization', 'Bearer ' + accessToken)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Makes a call to the `/usernamepassword/challenge` endpoint\n * and returns the challenge (captcha) if necessary.\n *\n * @method getChallenge\n * @param {callback} cb\n */\nAuthentication.prototype.getChallenge = function(cb) {\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (!this.baseOptions.state) {\n return cb();\n }\n\n var url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge');\n\n return this.request\n .post(url)\n .send({ state: this.baseOptions.state })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * @callback delegationCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed\n * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used\n */\n\n/**\n * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token`\n *\n * @method delegation\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer`\n * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required\n * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required\n * @param {String} [options.target] the target ClientID of the delegation\n * @param {String} [options.scope] either `openid` or `openid profile email`\n * @param {String} [options.apiType] the api to be called\n * @param {delegationCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#delegation}\n * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.delegation = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n grant_type: { type: 'string', message: 'grant_type option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'delegation');\n\n body = objectHelper.merge(this.baseOptions, ['clientID']).with(options);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Fetches the user country based on the ip.\n *\n * @method getUserCountry\n * @private\n * @param {Function} cb\n */\nAuthentication.prototype.getUserCountry = function(cb) {\n var url;\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country');\n\n return this.request.get(url).end(responseHandler(cb));\n};\n\nexport default Authentication;\n","import urljoin from 'url-join';\n\nimport RequestBuilder from '../helper/request-builder';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\n/**\n * Auth0 Management API Client (methods allowed to be called from the browser only)\n * @constructor\n * @param {Object} options\n * @param {Object} options.domain your Auth0 acount domain\n * @param {Object} options.token a valid API token\n */\nfunction Management(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n token: { type: 'string', message: 'token option is required' },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n }\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n\n this.baseOptions.headers = {\n Authorization: 'Bearer ' + this.baseOptions.token\n };\n\n this.request = new RequestBuilder(this.baseOptions);\n this.baseOptions.rootUrl = urljoin(\n 'https://' + this.baseOptions.domain,\n 'api',\n 'v2'\n );\n}\n\n/**\n * @callback userCallback\n * @param {Error} [err] failure reason for the failed request to Management API\n * @param {Object} [result] user profile\n */\n\n/**\n * Returns the user profile\n *\n * @method getUser\n * @param {String} userId identifier of the user to retrieve\n * @param {userCallback} cb\n * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id\n */\nManagement.prototype.getUser = function(userId, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request.get(url).end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user metdata. It will patch the user metdata with the attributes sent.\n *\n *\n * @method patchUserMetadata\n * @param {String} userId\n * @param {Object} userMetadata\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserMetadata = function(userId, userMetadata, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(userMetadata, {\n type: 'object',\n message: 'userMetadata parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send({ user_metadata: userMetadata })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user attributes. It will patch the user attributes that the server allows it.\n *\n * @method patchUserAttributes\n * @param {String} userId\n * @param {Object} user\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserAttributes = function(userId, user, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(user, {\n type: 'object',\n message: 'user parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send(user)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Link two users\n *\n * @method linkUser\n * @param {String} userId\n * @param {String} secondaryUserToken\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities}\n */\nManagement.prototype.linkUser = function(userId, secondaryUserToken, cb) {\n var url;\n /* eslint-disable */\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(secondaryUserToken, {\n type: 'string',\n message: 'secondaryUserToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n /* eslint-enable */\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId, 'identities');\n\n return this.request\n .post(url)\n .send({ link_with: secondaryUserToken })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\nexport default Management;\n","import Authentication from './authentication';\nimport Management from './management';\nimport WebAuth from './web-auth';\nimport version from './version';\n\nexport { Authentication, Management, WebAuth, version };\n\nexport default {\n Authentication: Authentication,\n Management: Management,\n WebAuth: WebAuth,\n version: version\n};\n"],"names":["context","definition","this","normalize","strArray","resultArray","length","TypeError","match","first","shift","replace","i","component","push","str","join","parts","split","arguments","slice","call","module","exports","has","Object","prototype","hasOwnProperty","isArray","Array","hexTable","array","toString","toUpperCase","arrayToObject","source","options","obj","plainObjects","create","assign","target","keys","reduce","acc","key","combine","a","b","concat","compact","value","queue","o","prop","refs","item","j","val","indexOf","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","c","charCodeAt","charAt","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","merge","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","apply","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","object","generateArrayPrefix","filter","sort","v","isNonNullishPrimitive","objKeys","values","keyPrefix","arrayLimit","depth","ignoreQueryPrefix","interpretNumericEntities","parameterLimit","parseArrays","numberStr","fromCharCode","parseArrayValue","parseKeys","givenKey","valuesParsed","child","segment","exec","parent","index","chain","leaf","root","cleanRoot","isNaN","0","parseObject","opts","undefined","normalizeParseOptions","tempObj","cleanStr","limit","Infinity","skipIndex","part","bracketEqualsPos","pos","encodedVal","parseValues","newObj","normalizeStringifyOptions","arrayFormat","joined","Emitter","mixin","on","addEventListener","event","_callbacks","once","off","removeListener","removeAllListeners","removeEventListener","cb","callbacks","splice","emit","args","len","listeners","hasListeners","stable","deterministicStringify","stableStringify","replacerStack","replacer","spacer","res","decirc","k","stack","propertyDescriptor","getOwnPropertyDescriptor","get","configurable","defineProperty","JSON","replaceGetterValues","compareFunction","tmp","deterministicDecirc","toJSON","_typeof","iterator","RequestBase","clearTimeout","_timer","_responseTimeoutTimer","_uploadTimeoutTimer","parse","_parser","responseType","_responseType","serialize","_serializer","timeout","_timeout","_responseTimeout","_uploadTimeout","option","deadline","response","upload","console","warn","retry","count","_maxRetries","_retries","_retryCallback","ERROR_CODES","_shouldRetry","err","override","err_","error","status","code","includes","crossDomain","_retry","req","request","_aborted","timedout","timedoutError","_end","then","resolve","reject","_this","_fullfilledPromise","self","_endCalled","Promise","Error","method","url","end","catch","use","ok","_okCallback","_isResponseOK","field","_header","toLowerCase","getHeader","set","isObject","header","unset","name","_data","_getFormData","append","abort","xhr","_auth","user","pass","base64Encoder","type","username","password","withCredentials","_withCredentials","redirects","n","_maxRedirects","maxResponseSize","_maxResponseSize","data","headers","send","isObj","_formData","_isHost","sortQuery","_sort","_finalizeQueryString","query","_query","queryArr","_appendQueryString","_timeoutError","reason","errno","callback","_setTimeouts","setTimeout","ResponseBase","_toConsumableArray","_arrayLikeToArray","_arrayWithoutHoles","iter","from","_iterableToArray","minLen","test","_unsupportedIterableToArray","_nonIterableSpread","arr2","Agent","_defaults","_setHeaderProperties","ct","params","links","link","_unused","_setStatusProperties","statusCode","statusType","info","redirect","clientError","serverError","toError","created","accepted","noContent","badRequest","unauthorized","notAcceptable","forbidden","notFound","unprocessableEntity","_len","_key","_setDefaults","def","noop","window","Request","getXHR","XMLHttpRequest","location","protocol","ActiveXObject","_unused2","_unused3","_unused4","trim","s","pairs","pushEncodedKeyValuePair","subkey","encodeURI","encodeURIComponent","parseString","pair","isJSON","mime","Response","text","responseText","statusText","line","lines","fields","parseHeader","getAllResponseHeaders","getResponseHeader","body","_parseBody","new_err","original","rawResponse","del","serializeObject","types","html","json","xml","urlencoded","form","form-data","application/x-www-form-urlencoded","application/json","safeStringify","msg","accept","auth","btoa","attach","file","FormData","_callback","retries","crossDomainError","agent","ca","buffer","write","pipe","_setUploadTimeout","onreadystatechange","readyState","_unused5","handleProgress","direction","total","percent","loaded","bind","_unused6","open","contentType","_serialize","setRequestHeader","delete","head","patch","post","put","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","lookup","Uint8Array","start","num","output","base64","fromByteArray","stringToByteArray","mod","padding","result","byteArrayToString","toByteArray","raw","attribute","attr","variable","check","config","attributes","optional","message","condition","value_message","supportsIsArray","objectAssignPolyfill","to","nextSource","keysArray","nextIndex","nextKey","desc","enumerable","pick","prev","objectValues","extend","unshift","objectAssign","getLocationFromUrl","href","host","hostname","port","pathname","search","hash","trimmed","toSnakeCase","exceptions","assert","p","newKey","wasPrevNumber","wasPrevUppercase","camelToSnake","toCamelCase","keepOriginal","blacklist","blacklistedKeys","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","RequestWrapper","RequestObj","RequestBuilder","_sendTelemetry","_telemetryInfo","_timesToRetryFailedRequests","_universalLoginPage","universalLoginPage","getWindow","getMethod","getBody","getUrl","getHeaders","objectHelper","setCommonConfiguration","ongoingRequest","noHeaders","getTelemetryData","telemetryName","clientInfo","version","env","jsonClientInfo","base64Url","getDocument","document","getOrigin","DummyStorage","getItem","removeItem","setItem","factory","init","converter","api","expires","toUTCString","stringifiedAttributes","attributeName","cookie","jar","cookies","read","getJSON","remove","withConverter","CookieStorage","Warn","disableWarnings","StorageHandler","storage","__tryLocalStorageFirst","localStorage","windowHandler","warning","Storage","handler","SSODataStorage","buildResponse","description","errorDescription","Cookie","failover","_","connection","sub","ssodata","lastUsedConnection","lastUsedSub","invalidToken","wrapCallback","ignoreCasing","errObj","error_code","error_description","details","forceLegacyError","error_codes","error_details","errorDetails","codes","policy","keepOriginalCasing","tokenParams","authorizeParams","oauthTokenParams","oauthAuthorizeParams","t","globalThis","global","r","require","l","d","w","h","u","MutationObserver","WebKitMutationObserver","f","process","Uint8ClampedArray","importScripts","MessageChannel","m","y","g","T","S","C","_state","I","_result","A","nextTick","createTextNode","observe","characterData","port1","onmessage","port2","postMessage","Function","runOnLoop","runOnContext","Math","random","substring","D","x","E","B","_onerror","M","_subscribers","R","_instanceConstructor","promise","_remaining","_enumerate","_eachEntry","_settledAt","O","_willSettleAt","finally","all","race","_setScheduler","_setAsap","_asap","polyfill","cast","lib","Base","mixIn","$super","clone","WordArray","words","sigBytes","clamp","ceil","enc","Hex","substr","Latin1","Utf8","BufferedBlockAlgorithm","reset","_nDataBytes","_append","_process","blockSize","max","_minBufferSize","min","_doProcessBlock","Hasher","cfg","_doReset","update","finalize","_doFinalize","_createHelper","_createHmacHelper","HMAC","algo","sqrt","pow","SHA256","_hash","floor","HmacSHA256","Base64","_map","_reverseMap","fromNumber","fromString","navigator","appName","am","DB","DM","DV","FV","F1","F2","fromInt","mp","invDigit","mpl","mph","um","mt2","r2","q3","ONE","dlShiftTo","mu","divide","convert","compareTo","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","abs","ZERO","subTo","copyTo","drShiftTo","fromRadix","lShiftTo","rShiftTo","isEven","exp","negate","toRadix","bitLength","modPowInt","multiplyUpperTo","multiplyLowerTo","dAddOffset","getTime","chunkSize","LN2","log","signum","intValue","dMultiply","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","changeBit","addTo","modInt","millerRabin","subtract","getLowestSetBit","shiftRight","modPow","byteValue","shortValue","equals","and","or","xor","andNot","not","bitCount","setBit","clearBit","flipBit","add","multiply","remainder","divideAndRemainder","modInverse","gcd","square","Barrett","crypto","getRandomValues","appVersion","BigInteger","SecureRandom","sha1","sha224","sha256","sha384","sha512","md2","md5","ripemd160","verify","alg","map","urljoin","responseURL","blob","Blob","entries","onload","onerror","credentials","jwksCache","expectedAlg","issuer","audience","leeway","jwksURI","maxAge","__clock","PluginHandler","webAuth","plugins","pluginName","setWebAuth","encoded","payload","signature","kid","aud","iss","nbf","iat","azp","auth_time","nonce","getRsaVerifier","setUTCSeconds","fetch","modulus","validateAccessToken","+","/","=","extensibilityPoint","supports","randomString","bytes","cryptoObj","windowHelper","msCrypto","TransactionManager","transaction","namespace","keyLength","IframeHandler","timeoutCallback","eventListenerType","iframe","timeoutHandle","_destroyTimeout","transientMessageEventListener","proxyEventListener","eventValidator","isValid","WebMessageHandler","baseOptions","CrossOriginAuthentication","webMessageHandler","createKey","coId","Redirect","auth0","crossOriginAuthentication","_disableDeprecationWarnings","realm","responseTypeIncludesIdToken","generateTransaction","appState","state","generateNonce","domain","getStoredTransaction","transactionData","clearTransaction","_window","createElement","style","display","eventListener","eventSourceObject","appendChild","src","timeoutHandler","eventData","sourceObject","destroy","parentNode","removeChild","run","responseMode","prompt","currentOrigin","redirectUriOrigin","redirectUri","authorizeUrl","runWebMessageFlow","client","buildAuthorizeUrl","parsedHash","validateAuthenticationResponse","transactionManager","login","rootUrl","email","authenticateBody","client_id","clientID","otp","credentialType","credential_type","errorObject","responseHandler","popupMode","popup","authorizeOptions","loginTicket","login_ticket","co_id","co_verifier","authorize","targetOrigin","getFragment","theWindow","evt","id","verifier","tryGetVerifier","loginWithCredentials","signupAndLogin","dbConnection","signup","WinChan","addListener","attachEvent","detachEvent","extractOrigin","isIE","rv","ua","userAgent","RegExp","parseFloat","$1","isInternetExplorer","relay_url","window_name","window_features","isFennec","messageTarget","setAttribute","contentWindow","closeInterval","setInterval","closed","cleanup","clearInterval","onMessage","close","securityViolation","originalPopup","focus","onOpen","msgTarget","frames","opener","findRelay","doPost","onDie","o_O","onUnload","ohWell","detach","winopts","arg","PopupHandler","_current_popup","Popup","popupOrigin","SilentAuthenticationHandler","authenticationUrl","postMessageDataType","postMessageOrigin","UsernamePassword","HostedPages","calculatePosition","width","height","screenX","screenLeft","screenY","screenTop","outerWidth","clientWidth","outerHeight","clientHeight","left","top","preload","popupPosition","popupOptions","windowFeatures","qs","kill","load","relayUrl","winchanOptions","buildPopupHandler","pluginHandler","getPopupHandler","popupHandler","originUrl","parseHash","popOpts","owp","urlHelper","processParams","scope","passwordlessVerify","passwordless","phoneNumber","verificationCode","loginWithResourceOwner","usePostMessage","getCallbackHandler","getEventValidator","callbackValue","formHtml","div","_document","innerHTML","children","submit","usernamePassword","getSSOData","withActiveDirectories","ldaps","lang","templates","challenge","image","recaptcha_v2","handleRecaptchaProvider","element","widgetId","hasAttribute","getAttribute","setValue","querySelector","grecaptcha","provider","recaptchaDiv","callbackName","script","async","injectRecaptchaScript","render","expired-callback","error-callback","sitekey","siteKey","auth0Client","done","getChallenge","required","preventDefault","handleAuth0Provider","reload","getValue","captchaInput","defaultClock","WebAuth","overrides","__tenant","__token_issuer","__jwks_uri","tenant","token_issuer","Authentication","_universalLogin","ssodataStorage","PasswordlessAuthentication","DBConnection","Management","token","Authorization","parsedQs","hashStr","responseTypes","__enableIdPInitiatedLogin","__enableImpersonation","transactionState","transactionStateMatchesState","transactionNonce","qsParams","accessToken","access_token","idToken","id_token","idTokenPayload","refreshToken","refresh_token","expiresIn","expires_in","tokenType","token_type","buildParseHashResponse","validateToken","validationError","at_hash","IdTokenVerifier","decodedToken","userInfo","errUserInfo","profile","renewAuth","checkSession","changePassword","passwordlessStart","authParams","signupAndAuthorize","passwordlessLogin","crossOriginOptions","crossOriginAuthenticationCallback","crossOriginVerification","logout","buildLogoutUrl","buildVerifyUrl","renderCaptcha","captcha","qString","redirect_uri","response_type","cleanOption","metadata","user_metadata","userMetadata","connection_scope","parametersWhitelist","federated","loginWithDefaultDirectory","grantType","oauthToken","grant_type","clientId","ssodataInformation","sso","lastUsedUserID","lastUsedUsername","lastUsedClientID","sessionClients","delegation","getUserCountry","getUser","userId","patchUserMetadata","patchUserAttributes","linkUser","secondaryUserToken","link_with"],"mappings":";;;;;;;2TAAA,IAAiBA,QAASC,WAATD,QAIHE,eAJYD,WAIN,WAElB,SAASE,UAAWC,UAClB,IAAIC,YAAc,GAClB,GAAwB,IAApBD,SAASE,OAAgB,MAAO,GAEpC,GAA2B,iBAAhBF,SAAS,GAClB,MAAM,IAAIG,UAAU,kCAAoCH,SAAS,IAInE,GAAIA,SAAS,GAAGI,MAAM,iBAAmBJ,SAASE,OAAS,EAAG,CAC5D,IAAIG,MAAQL,SAASM,QACrBN,SAAS,GAAKK,MAAQL,SAAS,GAI7BA,SAAS,GAAGI,MAAM,gBACpBJ,SAAS,GAAKA,SAAS,GAAGO,QAAQ,gBAAiB,UAEnDP,SAAS,GAAKA,SAAS,GAAGO,QAAQ,gBAAiB,SAGrD,IAAK,IAAIC,EAAI,EAAGA,EAAIR,SAASE,OAAQM,IAAK,CACxC,IAAIC,UAAYT,SAASQ,GAEzB,GAAyB,iBAAdC,UACT,MAAM,IAAIN,UAAU,kCAAoCM,WAGxC,KAAdA,YAEAD,EAAI,IAENC,UAAYA,UAAUF,QAAQ,SAAU,KAIxCE,UAFED,EAAIR,SAASE,OAAS,EAEZO,UAAUF,QAAQ,SAAU,IAG5BE,UAAUF,QAAQ,SAAU,KAG1CN,YAAYS,KAAKD,YAInB,IAAIE,IAAMV,YAAYW,KAAK,KAOvBC,OAHJF,IAAMA,IAAIJ,QAAQ,kBAAmB,OAGrBO,MAAM,KAGtB,OAFAH,IAAME,MAAMP,SAAWO,MAAMX,OAAS,EAAI,IAAK,IAAMW,MAAMD,KAAK,KAKlE,OAAO,WASL,OAAOb,UANqB,iBAAjBgB,UAAU,GACXA,UAAU,GAEV,GAAGC,MAAMC,KAAKF,cAtEWG,OAAOC,QAASD,eAAiBrB,aAEjED,QAAY,QAAIC,gBCDnBuB,IAAMC,OAAOC,UAAUC,eACvBC,QAAUC,MAAMD,QAEhBE,SAAY,WAEZ,IADA,IAAIC,MAAQ,GACHnB,EAAI,EAAGA,EAAI,MAAOA,EACvBmB,MAAMjB,KAAK,MAAQF,EAAI,GAAK,IAAM,IAAMA,EAAEoB,SAAS,KAAKC,eAG5D,OAAOF,SAsBPG,cAAgB,SAAuBC,OAAQC,SAE/C,IADA,IAAIC,IAAMD,SAAWA,QAAQE,aAAeb,OAAOc,OAAO,MAAQ,GACzD3B,EAAI,EAAGA,EAAIuB,OAAO7B,SAAUM,OACR,IAAduB,OAAOvB,KACdyB,IAAIzB,GAAKuB,OAAOvB,IAIxB,OAAOyB,WAmMM,CACbH,cAAeA,cACfM,OAzIS,SAA4BC,OAAQN,QAC7C,OAAOV,OAAOiB,KAAKP,QAAQQ,QAAO,SAAUC,IAAKC,KAE7C,OADAD,IAAIC,KAAOV,OAAOU,KACXD,MACRH,SAsIHK,QAlBU,SAAiBC,EAAGC,GAC9B,MAAO,GAAGC,OAAOF,EAAGC,IAkBpBE,QAvDU,SAAiBC,OAI3B,IAHA,IAAIC,MAAQ,CAAC,CAAEf,IAAK,CAAEgB,EAAGF,OAASG,KAAM,MACpCC,KAAO,GAEF3C,EAAI,EAAGA,EAAIwC,MAAM9C,SAAUM,EAKhC,IAJA,IAAI4C,KAAOJ,MAAMxC,GACbyB,IAAMmB,KAAKnB,IAAImB,KAAKF,MAEpBZ,KAAOjB,OAAOiB,KAAKL,KACdoB,EAAI,EAAGA,EAAIf,KAAKpC,SAAUmD,EAAG,CAClC,IAAIZ,IAAMH,KAAKe,GACXC,IAAMrB,IAAIQ,KACK,iBAARa,KAA4B,OAARA,MAAuC,IAAvBH,KAAKI,QAAQD,OACxDN,MAAMtC,KAAK,CAAEuB,IAAKA,IAAKiB,KAAMT,MAC7BU,KAAKzC,KAAK4C,MAOtB,OAhMe,SAAsBN,OACrC,KAAOA,MAAM9C,OAAS,GAAG,CACrB,IAAIkD,KAAOJ,MAAMQ,MACbvB,IAAMmB,KAAKnB,IAAImB,KAAKF,MAExB,GAAI1B,QAAQS,KAAM,CAGd,IAFA,IAAIwB,UAAY,GAEPJ,EAAI,EAAGA,EAAIpB,IAAI/B,SAAUmD,OACR,IAAXpB,IAAIoB,IACXI,UAAU/C,KAAKuB,IAAIoB,IAI3BD,KAAKnB,IAAImB,KAAKF,MAAQO,YAgL9BC,CAAaV,OAEND,OAmCPY,OArIS,SAAUhD,IAAKiD,QAASC,SACjC,IAAIC,eAAiBnD,IAAIJ,QAAQ,MAAO,KACxC,GAAgB,eAAZsD,QAEA,OAAOC,eAAevD,QAAQ,iBAAkBwD,UAGpD,IACI,OAAOC,mBAAmBF,gBAC5B,MAAOG,GACL,OAAOH,iBA4HXI,OAxHS,SAAgBvD,IAAKwD,eAAgBN,SAG9C,GAAmB,IAAflD,IAAIT,OACJ,OAAOS,IAGX,IAAIyD,OAASzD,IAOb,GANmB,iBAARA,IACPyD,OAASC,OAAO/C,UAAUM,SAASX,KAAKN,KAClB,iBAARA,MACdyD,OAASE,OAAO3D,MAGJ,eAAZkD,QACA,OAAOU,OAAOH,QAAQ7D,QAAQ,mBAAmB,SAAUiE,IACvD,MAAO,SAAWC,SAASD,GAAGxD,MAAM,GAAI,IAAM,SAKtD,IADA,IAAI0D,IAAM,GACDlE,EAAI,EAAGA,EAAI4D,OAAOlE,SAAUM,EAAG,CACpC,IAAImE,EAAIP,OAAOQ,WAAWpE,GAGhB,KAANmE,GACS,KAANA,GACM,KAANA,GACM,MAANA,GACCA,GAAK,IAAQA,GAAK,IAClBA,GAAK,IAAQA,GAAK,IAClBA,GAAK,IAAQA,GAAK,IAEtBD,KAAON,OAAOS,OAAOrE,GAIrBmE,EAAI,IACJD,KAAYhD,SAASiD,GAIrBA,EAAI,KACJD,KAAahD,SAAS,IAAQiD,GAAK,GAAMjD,SAAS,IAAY,GAAJiD,GAI1DA,EAAI,OAAUA,GAAK,MACnBD,KAAahD,SAAS,IAAQiD,GAAK,IAAOjD,SAAS,IAASiD,GAAK,EAAK,IAASjD,SAAS,IAAY,GAAJiD,IAIpGnE,GAAK,EACLmE,EAAI,QAAiB,KAAJA,IAAc,GAA8B,KAAvBP,OAAOQ,WAAWpE,IACxDkE,KAAOhD,SAAS,IAAQiD,GAAK,IACvBjD,SAAS,IAASiD,GAAK,GAAM,IAC7BjD,SAAS,IAASiD,GAAK,EAAK,IAC5BjD,SAAS,IAAY,GAAJiD,IAG3B,OAAOD,KA6DPI,SA9BW,SAAkB7C,KAC7B,SAAKA,KAAsB,iBAARA,SAITA,IAAI8C,aAAe9C,IAAI8C,YAAYD,UAAY7C,IAAI8C,YAAYD,SAAS7C,OA0BlF+C,SAnCW,SAAkB/C,KAC7B,MAA+C,oBAAxCZ,OAAOC,UAAUM,SAASX,KAAKgB,MAmCtCgD,SApBW,SAAkB3B,IAAK4B,IAClC,GAAI1D,QAAQ8B,KAAM,CAEd,IADA,IAAI6B,OAAS,GACJ3E,EAAI,EAAGA,EAAI8C,IAAIpD,OAAQM,GAAK,EACjC2E,OAAOzE,KAAKwE,GAAG5B,IAAI9C,KAEvB,OAAO2E,OAEX,OAAOD,GAAG5B,MAaV8B,MA1MQ,SAASA,MAAM/C,OAAQN,OAAQC,SAEvC,IAAKD,OACD,OAAOM,OAGX,GAAsB,iBAAXN,OAAqB,CAC5B,GAAIP,QAAQa,QACRA,OAAO3B,KAAKqB,YACT,CAAA,IAAIM,QAA4B,iBAAXA,OAKxB,MAAO,CAACA,OAAQN,SAJXC,UAAYA,QAAQE,cAAgBF,QAAQqD,mBAAsBjE,IAAIH,KAAKI,OAAOC,UAAWS,WAC9FM,OAAON,SAAU,GAMzB,OAAOM,OAGX,IAAKA,QAA4B,iBAAXA,OAClB,MAAO,CAACA,QAAQQ,OAAOd,QAG3B,IAAIuD,YAAcjD,OAKlB,OAJIb,QAAQa,UAAYb,QAAQO,UAC5BuD,YAAcxD,cAAcO,OAAQL,UAGpCR,QAAQa,SAAWb,QAAQO,SAC3BA,OAAOwD,SAAQ,SAAUnC,KAAM5C,GAC3B,GAAIY,IAAIH,KAAKoB,OAAQ7B,GAAI,CACrB,IAAIgF,WAAanD,OAAO7B,GACpBgF,YAAoC,iBAAfA,YAA2BpC,MAAwB,iBAATA,KAC/Df,OAAO7B,GAAK4E,MAAMI,WAAYpC,KAAMpB,SAEpCK,OAAO3B,KAAK0C,WAGhBf,OAAO7B,GAAK4C,QAGbf,QAGJhB,OAAOiB,KAAKP,QAAQQ,QAAO,SAAUC,IAAKC,KAC7C,IAAIM,MAAQhB,OAAOU,KAOnB,OALIrB,IAAIH,KAAKuB,IAAKC,KACdD,IAAIC,KAAO2C,MAAM5C,IAAIC,KAAMM,MAAOf,SAElCQ,IAAIC,KAAOM,MAERP,MACR8C,eChGH/E,QAAU+D,OAAOhD,UAAUf,QAC3BkF,gBAAkB,OAIlBC,OAAS,CACTC,QAAS,UACTC,QAAS,mBAGIC,MAAKzD,OAClB,CACI0D,QAAWJ,OAAOE,QAClBG,WAAY,CACRJ,QAAS,SAAU5C,OACf,OAAOxC,QAAQU,KAAK8B,MAAO0C,gBAAiB,MAEhDG,QAAS,SAAU7C,OACf,OAAOuB,OAAOvB,UAI1B2C,QCpBAtE,MAAMC,OAAOC,UAAUC,eAEvByE,sBAAwB,CACxBC,SAAU,SAAkBC,QACxB,OAAOA,OAAS,MAEpBC,MAAO,QACPC,QAAS,SAAiBF,OAAQzD,KAC9B,OAAOyD,OAAS,IAAMzD,IAAM,KAEhC4D,OAAQ,SAAgBH,QACpB,OAAOA,SAIX1E,UAAUC,MAAMD,QAChBd,KAAOe,MAAMH,UAAUZ,KACvB4F,YAAc,SAAUC,IAAKC,cAC7B9F,KAAK+F,MAAMF,IAAK/E,UAAQgF,cAAgBA,aAAe,CAACA,gBAGxDE,MAAQC,KAAKrF,UAAUsF,YAEvBC,cAAgBC,QAAiB,QACjCC,SAAW,CACXC,gBAAgB,EAChBC,WAAW,EACXpD,QAAS,QACTqD,iBAAiB,EACjBC,UAAW,IACXjD,QAAQ,EACRkD,QAASC,MAAMnD,OACfoD,kBAAkB,EAClBC,OAAQV,cACRW,UAAWV,QAAQf,WAAWc,eAE9BT,SAAS,EACTqB,cAAe,SAAuBC,MAClC,OAAOhB,MAAMzF,KAAKyG,OAEtBC,WAAW,EACXC,oBAAoB,GAWpBC,UAAY,SAASA,UACrBC,OACA5B,OACA6B,oBACAH,mBACAD,UACAP,QACAY,OACAC,KACAhB,UACAQ,cACAD,UACAF,iBACAzD,SAEA,IAAI5B,IAAM6F,OAcV,GAbsB,mBAAXE,OACP/F,IAAM+F,OAAO9B,OAAQjE,KACdA,eAAe0E,KACtB1E,IAAMwF,cAAcxF,KACW,UAAxB8F,qBAAmCvG,UAAQS,OAClDA,IAAMoF,MAAMpC,SAAShD,KAAK,SAAUc,OAChC,OAAIA,iBAAiB4D,KACVc,cAAc1E,OAElBA,SACRnC,KAAK,MAGA,OAARqB,IAAc,CACd,GAAI2F,mBACA,OAAOR,UAAYE,iBAAmBF,QAAQlB,OAAQa,SAASK,QAASvD,QAAS,OAASqC,OAG9FjE,IAAM,GAGV,GA7CwB,SAA+BiG,GACvD,MAAoB,iBAANA,GACM,iBAANA,GACM,kBAANA,GACM,iBAANA,GACM,iBAANA,EAwCVC,CAAsBlG,MAAQoF,MAAMvC,SAAS7C,KAC7C,OAAImF,QAEO,CAACI,UADOF,iBAAmBpB,OAASkB,QAAQlB,OAAQa,SAASK,QAASvD,QAAS,QACxD,IAAM2D,UAAUJ,QAAQnF,IAAK8E,SAASK,QAASvD,QAAS,WAEnF,CAAC2D,UAAUtB,QAAU,IAAMsB,UAAUlD,OAAOrC,OAGvD,IAMImG,QANAC,OAAS,GAEb,QAAmB,IAARpG,IACP,OAAOoG,OAIX,GAAI7G,UAAQwG,QACRI,QAAUJ,WACP,CACH,IAAI1F,KAAOjB,OAAOiB,KAAKL,KACvBmG,QAAUH,KAAO3F,KAAK2F,KAAKA,MAAQ3F,KAGvC,IAAK,IAAI9B,EAAI,EAAGA,EAAI4H,QAAQlI,SAAUM,EAAG,CACrC,IAAIiC,IAAM2F,QAAQ5H,GACduC,MAAQd,IAAIQ,KAEhB,IAAIkF,WAAuB,OAAV5E,MAAjB,CAIA,IAAIuF,UAAY9G,UAAQS,KACa,mBAAxB8F,oBAAqCA,oBAAoB7B,OAAQzD,KAAOyD,OAC/EA,QAAUe,UAAY,IAAMxE,IAAM,IAAMA,IAAM,KAEpD6D,YAAY+B,OAAQR,UAChB9E,MACAuF,UACAP,oBACAH,mBACAD,UACAP,QACAY,OACAC,KACAhB,UACAQ,cACAD,UACAF,iBACAzD,WAIR,OAAOwE,QC5IPjH,MAAMC,OAAOC,UAAUC,eACvBC,UAAUC,MAAMD,QAEhBuF,WAAW,CACXE,WAAW,EACX5B,iBAAiB,EACjBkD,WAAY,GACZ1E,QAAS,QACTqD,iBAAiB,EACjBf,OAAO,EACPvC,QAASyD,MAAM1D,OACfwD,UAAW,IACXqB,MAAO,EACPC,mBAAmB,EACnBC,0BAA0B,EAC1BC,eAAgB,IAChBC,aAAa,EACb1G,cAAc,EACd0F,oBAAoB,GAGpBc,yBAA2B,SAAU/H,KACrC,OAAOA,IAAIJ,QAAQ,aAAa,SAAUiE,GAAIqE,WAC1C,OAAOvE,OAAOwE,aAAarE,SAASoE,UAAW,SAInDE,gBAAkB,SAAUzF,IAAKtB,SACjC,OAAIsB,KAAsB,iBAARA,KAAoBtB,QAAQmE,OAAS7C,IAAIC,QAAQ,MAAQ,EAChED,IAAIxC,MAAM,KAGdwC,KAgHP0F,UAAY,SAA8BC,SAAU3F,IAAKtB,QAASkH,cAClE,GAAKD,SAAL,CAKA,IAAIxG,IAAMT,QAAQiF,UAAYgC,SAAS1I,QAAQ,cAAe,QAAU0I,SAKpEE,MAAQ,gBAIRC,QAAUpH,QAAQwG,MAAQ,GALf,eAK6Ba,KAAK5G,KAC7C6G,OAASF,QAAU3G,IAAIzB,MAAM,EAAGoI,QAAQG,OAAS9G,IAIjDH,KAAO,GACX,GAAIgH,OAAQ,CAER,IAAKtH,QAAQE,cAAgBd,MAAIH,KAAKI,OAAOC,UAAWgI,UAC/CtH,QAAQqD,gBACT,OAIR/C,KAAK5B,KAAK4I,QAMd,IADA,IAAI9I,EAAI,EACDwB,QAAQwG,MAAQ,GAAqC,QAA/BY,QAAUD,MAAME,KAAK5G,OAAkBjC,EAAIwB,QAAQwG,OAAO,CAEnF,GADAhI,GAAK,GACAwB,QAAQE,cAAgBd,MAAIH,KAAKI,OAAOC,UAAW8H,QAAQ,GAAGpI,MAAM,GAAI,MACpEgB,QAAQqD,gBACT,OAGR/C,KAAK5B,KAAK0I,QAAQ,IAStB,OAJIA,SACA9G,KAAK5B,KAAK,IAAM+B,IAAIzB,MAAMoI,QAAQG,OAAS,KAnFjC,SAAUC,MAAOlG,IAAKtB,QAASkH,cAG7C,IAFA,IAAIO,KAAOP,aAAe5F,IAAMyF,gBAAgBzF,IAAKtB,SAE5CxB,EAAIgJ,MAAMtJ,OAAS,EAAGM,GAAK,IAAKA,EAAG,CACxC,IAAIyB,IACAyH,KAAOF,MAAMhJ,GAEjB,GAAa,OAATkJ,MAAiB1H,QAAQ4G,YACzB3G,IAAM,GAAGY,OAAO4G,UACb,CACHxH,IAAMD,QAAQE,aAAeb,OAAOc,OAAO,MAAQ,GACnD,IAAIwH,UAA+B,MAAnBD,KAAK7E,OAAO,IAA+C,MAAjC6E,KAAK7E,OAAO6E,KAAKxJ,OAAS,GAAawJ,KAAK1I,MAAM,GAAI,GAAK0I,KACjGH,MAAQ9E,SAASkF,UAAW,IAC3B3H,QAAQ4G,aAA6B,KAAde,WAGvBC,MAAML,QACJG,OAASC,WACTrF,OAAOiF,SAAWI,WAClBJ,OAAS,GACRvH,QAAQ4G,aAAeW,OAASvH,QAAQuG,YAE5CtG,IAAM,IACFsH,OAASE,KAEbxH,IAAI0H,WAAaF,KAXjBxH,IAAM,CAAE4H,EAAGJ,MAenBA,KAAOxH,IAGX,OAAOwH,KAsDAK,CAAYxH,KAAMgB,IAAKtB,QAASkH,0BAqC1B,SAAUvI,IAAKoJ,MAC5B,IAAI/H,QAnCoB,SAA+B+H,MACvD,IAAKA,KACD,OAAOhD,WAGX,GAAqB,OAAjBgD,KAAKnG,cAAqCoG,IAAjBD,KAAKnG,SAAiD,mBAAjBmG,KAAKnG,QACnE,MAAM,IAAIzD,UAAU,iCAGxB,QAA4B,IAAjB4J,KAAKlG,SAA4C,UAAjBkG,KAAKlG,SAAwC,eAAjBkG,KAAKlG,QACxE,MAAM,IAAI1D,UAAU,qEAExB,IAAI0D,aAAkC,IAAjBkG,KAAKlG,QAA0BkD,WAASlD,QAAUkG,KAAKlG,QAE5E,MAAO,CACHoD,eAAqC,IAAnB8C,KAAK9C,UAA4BF,WAASE,YAAc8C,KAAK9C,UAC/E5B,gBAAiD,kBAAzB0E,KAAK1E,gBAAgC0E,KAAK1E,gBAAkB0B,WAAS1B,gBAC7FkD,WAAuC,iBAApBwB,KAAKxB,WAA0BwB,KAAKxB,WAAaxB,WAASwB,WAC7E1E,QAASA,QACTqD,gBAAiD,kBAAzB6C,KAAK7C,gBAAgC6C,KAAK7C,gBAAkBH,WAASG,gBAC7Ff,MAA6B,kBAAf4D,KAAK5D,MAAsB4D,KAAK5D,MAAQY,WAASZ,MAC/DvC,QAAiC,mBAAjBmG,KAAKnG,QAAyBmG,KAAKnG,QAAUmD,WAASnD,QACtEuD,UAAqC,iBAAnB4C,KAAK5C,WAA0BE,MAAMrC,SAAS+E,KAAK5C,WAAa4C,KAAK5C,UAAYJ,WAASI,UAE5GqB,MAA8B,iBAAfuB,KAAKvB,QAAqC,IAAfuB,KAAKvB,OAAoBuB,KAAKvB,MAAQzB,WAASyB,MACzFC,mBAA8C,IAA3BsB,KAAKtB,kBACxBC,yBAAmE,kBAAlCqB,KAAKrB,yBAAyCqB,KAAKrB,yBAA2B3B,WAAS2B,yBACxHC,eAA+C,iBAAxBoB,KAAKpB,eAA8BoB,KAAKpB,eAAiB5B,WAAS4B,eACzFC,aAAkC,IAArBmB,KAAKnB,YAClB1G,aAA2C,kBAAtB6H,KAAK7H,aAA6B6H,KAAK7H,aAAe6E,WAAS7E,aACpF0F,mBAAuD,kBAA5BmC,KAAKnC,mBAAmCmC,KAAKnC,mBAAqBb,WAASa,oBAK5FqC,CAAsBF,MAEpC,GAAY,KAARpJ,KAAAA,MAAcA,IACd,OAAOqB,QAAQE,aAAeb,OAAOc,OAAO,MAAQ,GASxD,IANA,IAAI+H,QAAyB,iBAARvJ,IAlMP,SAAgCA,IAAKqB,SACnD,IAKIxB,EALAyB,IAAM,GACNkI,SAAWnI,QAAQyG,kBAAoB9H,IAAIJ,QAAQ,MAAO,IAAMI,IAChEyJ,MAAQpI,QAAQ2G,iBAAmB0B,EAAAA,OAAWL,EAAYhI,QAAQ2G,eAClE9H,MAAQsJ,SAASrJ,MAAMkB,QAAQmF,UAAWiD,OAC1CE,WAAa,EAGbzG,QAAU7B,QAAQ6B,QACtB,GAAI7B,QAAQkF,gBACR,IAAK1G,EAAI,EAAGA,EAAIK,MAAMX,SAAUM,EACM,IAA9BK,MAAML,GAAG+C,QAAQ,WAbX,mBAcF1C,MAAML,GACNqD,QAAU,QAlBZ,wBAmBShD,MAAML,KACbqD,QAAU,cAEdyG,UAAY9J,EACZA,EAAIK,MAAMX,QAKtB,IAAKM,EAAI,EAAGA,EAAIK,MAAMX,SAAUM,EAC5B,GAAIA,IAAM8J,UAAV,CAGA,IAKI7H,IAAKa,IALLiH,KAAO1J,MAAML,GAEbgK,iBAAmBD,KAAKhH,QAAQ,MAChCkH,KAA4B,IAAtBD,iBAA0BD,KAAKhH,QAAQ,KAAOiH,iBAAmB,GAG9D,IAATC,KACAhI,IAAMT,QAAQ4B,QAAQ2G,KAAMxD,WAASnD,QAASC,QAAS,OACvDP,IAAMtB,QAAQ4F,mBAAqB,KAAO,KAE1CnF,IAAMT,QAAQ4B,QAAQ2G,KAAKvJ,MAAM,EAAGyJ,KAAM1D,WAASnD,QAASC,QAAS,OACrEP,IAAM+D,MAAMpC,SACR8D,gBAAgBwB,KAAKvJ,MAAMyJ,IAAM,GAAIzI,UACrC,SAAU0I,YACN,OAAO1I,QAAQ4B,QAAQ8G,WAAY3D,WAASnD,QAASC,QAAS,aAKtEP,KAAOtB,QAAQ0G,0BAAwC,eAAZ7E,UAC3CP,IAAMoF,yBAAyBpF,MAG/BiH,KAAKhH,QAAQ,QAAU,IACvBD,IAAM9B,UAAQ8B,KAAO,CAACA,KAAOA,KAG7BlC,MAAIH,KAAKgB,IAAKQ,KACdR,IAAIQ,KAAO4E,MAAM3E,QAAQT,IAAIQ,KAAMa,KAEnCrB,IAAIQ,KAAOa,IAInB,OAAOrB,IAqIiC0I,CAAYhK,IAAKqB,SAAWrB,IAChEsB,IAAMD,QAAQE,aAAeb,OAAOc,OAAO,MAAQ,GAInDG,KAAOjB,OAAOiB,KAAK4H,SACd1J,EAAI,EAAGA,EAAI8B,KAAKpC,SAAUM,EAAG,CAClC,IAAIiC,IAAMH,KAAK9B,GACXoK,OAAS5B,UAAUvG,IAAKyH,QAAQzH,KAAMT,QAAwB,iBAARrB,KAC1DsB,IAAMoF,MAAMjC,MAAMnD,IAAK2I,OAAQ5I,SAGnC,OAAOqF,MAAMvE,QAAQb,oBD9DR,SAAU6F,OAAQiC,MAC/B,IAGI3B,QAHAnG,IAAM6F,OACN9F,QAhDwB,SAAmC+H,MAC/D,IAAKA,KACD,OAAOhD,SAGX,GAAqB,OAAjBgD,KAAK3C,cAAqC4C,IAAjBD,KAAK3C,SAAiD,mBAAjB2C,KAAK3C,QACnE,MAAM,IAAIjH,UAAU,iCAGxB,IAAI0D,QAAUkG,KAAKlG,SAAWkD,SAASlD,QACvC,QAA4B,IAAjBkG,KAAKlG,SAA4C,UAAjBkG,KAAKlG,SAAwC,eAAjBkG,KAAKlG,QACxE,MAAM,IAAI1D,UAAU,qEAGxB,IAAIoH,OAAST,QAAiB,QAC9B,QAA2B,IAAhBiD,KAAKxC,OAAwB,CACpC,IAAKnG,MAAIH,KAAK6F,QAAQf,WAAYgE,KAAKxC,QACnC,MAAM,IAAIpH,UAAU,mCAExBoH,OAASwC,KAAKxC,OAElB,IAAIC,UAAYV,QAAQf,WAAWwB,QAE/BS,OAASjB,SAASiB,OAKtB,OAJ2B,mBAAhB+B,KAAK/B,QAAyBxG,UAAQuI,KAAK/B,WAClDA,OAAS+B,KAAK/B,QAGX,CACHhB,eAA+C,kBAAxB+C,KAAK/C,eAA+B+C,KAAK/C,eAAiBD,SAASC,eAC1FC,eAAqC,IAAnB8C,KAAK9C,UAA4BF,SAASE,YAAc8C,KAAK9C,UAC/EpD,QAASA,QACTqD,gBAAiD,kBAAzB6C,KAAK7C,gBAAgC6C,KAAK7C,gBAAkBH,SAASG,gBAC7FC,eAAqC,IAAnB4C,KAAK5C,UAA4BJ,SAASI,UAAY4C,KAAK5C,UAC7EjD,OAA+B,kBAAhB6F,KAAK7F,OAAuB6F,KAAK7F,OAAS6C,SAAS7C,OAClEkD,QAAiC,mBAAjB2C,KAAK3C,QAAyB2C,KAAK3C,QAAUL,SAASK,QACtEE,iBAAmD,kBAA1ByC,KAAKzC,iBAAiCyC,KAAKzC,iBAAmBP,SAASO,iBAChGU,OAAQA,OACRR,UAAWA,UACXC,cAA6C,mBAAvBsC,KAAKtC,cAA+BsC,KAAKtC,cAAgBV,SAASU,cACxFE,UAAqC,kBAAnBoC,KAAKpC,UAA0BoC,KAAKpC,UAAYZ,SAASY,UAC3EM,KAA2B,mBAAd8B,KAAK9B,KAAsB8B,KAAK9B,KAAO,KACpDL,mBAAuD,kBAA5BmC,KAAKnC,mBAAmCmC,KAAKnC,mBAAqBb,SAASa,oBAM5FiD,CAA0Bd,MAKV,mBAAnB/H,QAAQgG,OAEf/F,KADA+F,EAAShG,QAAQgG,QACJ,GAAI/F,KACVT,UAAQQ,QAAQgG,UAEvBI,QADSpG,QAAQgG,QAIrB,IAMI8C,YANAxI,KAAO,GAEX,GAAmB,iBAARL,KAA4B,OAARA,IAC3B,MAAO,GAKP6I,YADAf,MAAQA,KAAKe,eAAe9E,sBACd+D,KAAKe,YACZf,MAAQ,YAAaA,KACdA,KAAK3D,QAAU,UAAY,SAE3B,UAGlB,IAAI2B,oBAAsB/B,sBAAsB8E,aAE3C1C,UACDA,QAAU/G,OAAOiB,KAAKL,MAGtBD,QAAQiG,MACRG,QAAQH,KAAKjG,QAAQiG,MAGzB,IAAK,IAAIzH,EAAI,EAAGA,EAAI4H,QAAQlI,SAAUM,EAAG,CACrC,IAAIiC,IAAM2F,QAAQ5H,GAEdwB,QAAQ2F,WAA0B,OAAb1F,IAAIQ,MAG7B6D,YAAYhE,KAAMuF,UACd5F,IAAIQ,KACJA,IACAsF,oBACA/F,QAAQ4F,mBACR5F,QAAQ2F,UACR3F,QAAQkC,OAASlC,QAAQoF,QAAU,KACnCpF,QAAQgG,OACRhG,QAAQiG,KACRjG,QAAQiF,UACRjF,QAAQyF,cACRzF,QAAQwF,UACRxF,QAAQsF,iBACRtF,QAAQ6B,UAIhB,IAAIkH,OAASzI,KAAK1B,KAAKoB,QAAQmF,WAC3BjB,QAAoC,IAA3BlE,QAAQgF,eAA0B,IAAM,GAYrD,OAVIhF,QAAQkF,kBACgB,eAApBlF,QAAQ6B,QAERqC,QAAU,uBAGVA,QAAU,mBAIX6E,OAAO7K,OAAS,EAAIgG,OAAS6E,OAAS,4DE9PjD,SAASC,QAAQ/I,KACf,GAAIA,IAAK,OAWX,SAAeA,KACb,IAAK,IAAIQ,OAAOuI,QAAQ1J,UACtBW,IAAIQ,KAAOuI,QAAQ1J,UAAUmB,KAE/B,OAAOR,IAfSgJ,CAAMhJ,KAVtBf,eAAiB8J,QAqCnBA,QAAQ1J,UAAU4J,GAClBF,QAAQ1J,UAAU6J,iBAAmB,SAASC,MAAOlG,IAInD,OAHApF,KAAKuL,WAAavL,KAAKuL,YAAc,IACpCvL,KAAKuL,WAAW,IAAMD,OAAStL,KAAKuL,WAAW,IAAMD,QAAU,IAC7D1K,KAAKwE,IACDpF,MAaTkL,QAAQ1J,UAAUgK,KAAO,SAASF,MAAOlG,IACvC,SAASgG,KACPpL,KAAKyL,IAAIH,MAAOF,IAChBhG,GAAGuB,MAAM3G,KAAMiB,WAKjB,OAFAmK,GAAGhG,GAAKA,GACRpF,KAAKoL,GAAGE,MAAOF,IACRpL,MAaTkL,QAAQ1J,UAAUiK,IAClBP,QAAQ1J,UAAUkK,eAClBR,QAAQ1J,UAAUmK,mBAClBT,QAAQ1J,UAAUoK,oBAAsB,SAASN,MAAOlG,IAItD,GAHApF,KAAKuL,WAAavL,KAAKuL,YAAc,GAGjC,GAAKtK,UAAUb,OAEjB,OADAJ,KAAKuL,WAAa,GACXvL,KAIT,IAUI6L,GAVAC,UAAY9L,KAAKuL,WAAW,IAAMD,OACtC,IAAKQ,UAAW,OAAO9L,KAGvB,GAAI,GAAKiB,UAAUb,OAEjB,cADOJ,KAAKuL,WAAW,IAAMD,OACtBtL,KAKT,IAAK,IAAIU,EAAI,EAAGA,EAAIoL,UAAU1L,OAAQM,IAEpC,IADAmL,GAAKC,UAAUpL,MACJ0E,IAAMyG,GAAGzG,KAAOA,GAAI,CAC7B0G,UAAUC,OAAOrL,EAAG,GACpB,MAUJ,OAJyB,IAArBoL,UAAU1L,eACLJ,KAAKuL,WAAW,IAAMD,OAGxBtL,MAWTkL,QAAQ1J,UAAUwK,KAAO,SAASV,OAChCtL,KAAKuL,WAAavL,KAAKuL,YAAc,GAKrC,IAHA,IAAIU,KAAO,IAAItK,MAAMV,UAAUb,OAAS,GACpC0L,UAAY9L,KAAKuL,WAAW,IAAMD,OAE7B5K,EAAI,EAAGA,EAAIO,UAAUb,OAAQM,IACpCuL,KAAKvL,EAAI,GAAKO,UAAUP,GAG1B,GAAIoL,UAEG,CAAIpL,EAAI,EAAb,IAAK,IAAWwL,KADhBJ,UAAYA,UAAU5K,MAAM,IACId,OAAQM,EAAIwL,MAAOxL,EACjDoL,UAAUpL,GAAGiG,MAAM3G,KAAMiM,MAI7B,OAAOjM,MAWTkL,QAAQ1J,UAAU2K,UAAY,SAASb,OAErC,OADAtL,KAAKuL,WAAavL,KAAKuL,YAAc,GAC9BvL,KAAKuL,WAAW,IAAMD,QAAU,IAWzCJ,QAAQ1J,UAAU4K,aAAe,SAASd,OACxC,QAAUtL,KAAKmM,UAAUb,OAAOlL,6BC7KjB2H,YACjBA,YAAU/B,QAAU+B,YACpBA,YAAUsE,OAASC,uBACnBvE,YAAUwE,gBAAkBD,uBAE5B,IAAI7F,IAAM,GACN+F,cAAgB,GAGpB,SAASzE,YAAW5F,IAAKsK,SAAUC,QAEjC,IAAIC,IAMJ,KAUF,SAASC,OAAQpJ,IAAKqJ,EAAGC,MAAOtD,QAC9B,IAAI9I,EACJ,GAAmB,iBAAR8C,KAA4B,OAARA,IAAc,CAC3C,IAAK9C,EAAI,EAAGA,EAAIoM,MAAM1M,OAAQM,IAC5B,GAAIoM,MAAMpM,KAAO8C,IAAK,CACpB,IAAIuJ,mBAAqBxL,OAAOyL,yBAAyBxD,OAAQqD,GAYjE,iBAX+B3C,IAA3B6C,mBAAmBE,IACjBF,mBAAmBG,cACrB3L,OAAO4L,eAAe3D,OAAQqD,EAAG,CAAE5J,MAAO,eAC1CwD,IAAI7F,KAAK,CAAC4I,OAAQqD,EAAGrJ,IAAKuJ,sBAE1BP,cAAc5L,KAAK,CAAC4C,IAAKqJ,KAG3BrD,OAAOqD,GAAK,aACZpG,IAAI7F,KAAK,CAAC4I,OAAQqD,EAAGrJ,QAO3B,GAFAsJ,MAAMlM,KAAK4C,KAEP7B,MAAMD,QAAQ8B,KAChB,IAAK9C,EAAI,EAAGA,EAAI8C,IAAIpD,OAAQM,IAC1BkM,OAAOpJ,IAAI9C,GAAIA,EAAGoM,MAAOtJ,SAEtB,CACL,IAAIhB,KAAOjB,OAAOiB,KAAKgB,KACvB,IAAK9C,EAAI,EAAGA,EAAI8B,KAAKpC,OAAQM,IAAK,CAChC,IAAIiC,IAAMH,KAAK9B,GACfkM,OAAOpJ,IAAIb,KAAMA,IAAKmK,MAAOtJ,MAGjCsJ,MAAMpJ,OAlDRkJ,CAAOzK,IAAK,GAAI,QAAI+H,GAGlByC,IAD2B,IAAzBH,cAAcpM,OACVgN,KAAKrF,UAAU5F,IAAKsK,SAAUC,QAE9BU,KAAKrF,UAAU5F,IAAKkL,oBAAoBZ,UAAWC,QAErC,IAAfjG,IAAIrG,QAAc,CACvB,IAAIqK,KAAOhE,IAAI/C,MACK,IAAhB+G,KAAKrK,OACPmB,OAAO4L,eAAe1C,KAAK,GAAIA,KAAK,GAAIA,KAAK,IAE7CA,KAAK,GAAGA,KAAK,IAAMA,KAAK,GAG5B,OAAOkC,IAwCT,SAASW,gBAAiBzK,EAAGC,GAC3B,OAAID,EAAIC,GACE,EAEND,EAAIC,EACC,EAEF,EAGT,SAASwJ,uBAAwBnK,IAAKsK,SAAUC,QAC9C,IACIC,IADAY,IAkBN,SAASC,oBAAqBhK,IAAKqJ,EAAGC,MAAOtD,QAC3C,IAAI9I,EACJ,GAAmB,iBAAR8C,KAA4B,OAARA,IAAc,CAC3C,IAAK9C,EAAI,EAAGA,EAAIoM,MAAM1M,OAAQM,IAC5B,GAAIoM,MAAMpM,KAAO8C,IAAK,CACpB,IAAIuJ,mBAAqBxL,OAAOyL,yBAAyBxD,OAAQqD,GAYjE,iBAX+B3C,IAA3B6C,mBAAmBE,IACjBF,mBAAmBG,cACrB3L,OAAO4L,eAAe3D,OAAQqD,EAAG,CAAE5J,MAAO,eAC1CwD,IAAI7F,KAAK,CAAC4I,OAAQqD,EAAGrJ,IAAKuJ,sBAE1BP,cAAc5L,KAAK,CAAC4C,IAAKqJ,KAG3BrD,OAAOqD,GAAK,aACZpG,IAAI7F,KAAK,CAAC4I,OAAQqD,EAAGrJ,QAK3B,GAA0B,mBAAfA,IAAIiK,OACb,OAIF,GAFAX,MAAMlM,KAAK4C,KAEP7B,MAAMD,QAAQ8B,KAChB,IAAK9C,EAAI,EAAGA,EAAI8C,IAAIpD,OAAQM,IAC1B8M,oBAAoBhK,IAAI9C,GAAIA,EAAGoM,MAAOtJ,SAEnC,CAEL,IAAI+J,IAAM,GACN/K,KAAOjB,OAAOiB,KAAKgB,KAAK2E,KAAKmF,iBACjC,IAAK5M,EAAI,EAAGA,EAAI8B,KAAKpC,OAAQM,IAAK,CAChC,IAAIiC,IAAMH,KAAK9B,GACf8M,oBAAoBhK,IAAIb,KAAMA,IAAKmK,MAAOtJ,KAC1C+J,IAAI5K,KAAOa,IAAIb,KAEjB,QAAeuH,IAAXV,OAIF,OAAO+D,IAHP9G,IAAI7F,KAAK,CAAC4I,OAAQqD,EAAGrJ,MACrBgG,OAAOqD,GAAKU,IAKhBT,MAAMpJ,OA/DE8J,CAAoBrL,IAAK,GAAI,QAAI+H,IAAc/H,IAOzD,IAJEwK,IAD2B,IAAzBH,cAAcpM,OACVgN,KAAKrF,UAAUwF,IAAKd,SAAUC,QAE9BU,KAAKrF,UAAUwF,IAAKF,oBAAoBZ,UAAWC,QAErC,IAAfjG,IAAIrG,QAAc,CACvB,IAAIqK,KAAOhE,IAAI/C,MACK,IAAhB+G,KAAKrK,OACPmB,OAAO4L,eAAe1C,KAAK,GAAIA,KAAK,GAAIA,KAAK,IAE7CA,KAAK,GAAGA,KAAK,IAAMA,KAAK,GAG5B,OAAOkC,IAsDT,SAASU,oBAAqBZ,UAE5B,OADAA,cAAwBvC,IAAbuC,SAAyBA,SAAW,SAAUI,EAAGzE,GAAK,OAAOA,GACjE,SAAUzF,IAAKa,KACpB,GAAIgJ,cAAcpM,OAAS,EACzB,IAAK,IAAIM,EAAI,EAAGA,EAAI8L,cAAcpM,OAAQM,IAAK,CAC7C,IAAI+J,KAAO+B,cAAc9L,GACzB,GAAI+J,KAAK,KAAO9H,KAAO8H,KAAK,KAAOjH,IAAK,CACtCA,IAAM,aACNgJ,cAAcT,OAAOrL,EAAG,GACxB,OAIN,OAAO+L,SAAStL,KAAKnB,KAAM2C,IAAKa,MC5JpC,SAASkK,QAAQvL,KAAmV,OAAtOuL,QAArD,mBAAXnJ,QAAoD,iBAApBA,OAAOoJ,SAAmC,SAAiBxL,KAAO,cAAcA,KAA2B,SAAiBA,KAAO,OAAOA,KAAyB,mBAAXoC,QAAyBpC,IAAI8C,cAAgBV,QAAUpC,MAAQoC,OAAO/C,UAAY,gBAAkBW,MAAyBA,KAanX,eAJA,SAAkBA,KAChB,OAAe,OAARA,KAAiC,WAAjBuL,QAAQvL,MCVjC,SAASuL,UAAQvL,KAAmV,OAAtOuL,UAArD,mBAAXnJ,QAAoD,iBAApBA,OAAOoJ,SAAmC,SAAiBxL,KAAO,cAAcA,KAA2B,SAAiBA,KAAO,OAAOA,KAAyB,mBAAXoC,QAAyBpC,IAAI8C,cAAgBV,QAAUpC,MAAQoC,OAAO/C,UAAY,gBAAkBW,MAAyBA,KAWnX,gBAAiByL,YAOjB,SAASA,YAAYzL,KACnB,GAAIA,IAAK,OAWX,SAAeA,KACb,IAAK,IAAIQ,OAAOiL,YAAYpM,UACtBD,OAAOC,UAAUC,eAAeN,KAAKyM,YAAYpM,UAAWmB,OAAMR,IAAIQ,KAAOiL,YAAYpM,UAAUmB,MAGzG,OAAOR,IAhBSgJ,CAAMhJ,KA0BxByL,YAAYpM,UAAUqM,aAAe,WAOnC,OANAA,aAAa7N,KAAK8N,QAClBD,aAAa7N,KAAK+N,uBAClBF,aAAa7N,KAAKgO,4BACXhO,KAAK8N,cACL9N,KAAK+N,6BACL/N,KAAKgO,oBACLhO,MAYT4N,YAAYpM,UAAUyM,MAAQ,SAAU7I,IAEtC,OADApF,KAAKkO,QAAU9I,GACRpF,MAqBT4N,YAAYpM,UAAU2M,aAAe,SAAU3K,KAE7C,OADAxD,KAAKoO,cAAgB5K,IACdxD,MAYT4N,YAAYpM,UAAU6M,UAAY,SAAUjJ,IAE1C,OADApF,KAAKsO,YAAclJ,GACZpF,MAiBT4N,YAAYpM,UAAU+M,QAAU,SAAUrM,SACxC,IAAKA,SAAgC,WAArBwL,UAAQxL,SAItB,OAHAlC,KAAKwO,SAAWtM,QAChBlC,KAAKyO,iBAAmB,EACxBzO,KAAK0O,eAAiB,EACf1O,KAGT,IAAK,IAAI2O,UAAUzM,QACjB,GAAIX,OAAOC,UAAUC,eAAeN,KAAKe,QAASyM,QAChD,OAAQA,QACN,IAAK,WACH3O,KAAKwO,SAAWtM,QAAQ0M,SACxB,MAEF,IAAK,WACH5O,KAAKyO,iBAAmBvM,QAAQ2M,SAChC,MAEF,IAAK,SACH7O,KAAK0O,eAAiBxM,QAAQ4M,OAC9B,MAEF,QACEC,QAAQC,KAAK,yBAA0BL,QAK/C,OAAO3O,MAcT4N,YAAYpM,UAAUyN,MAAQ,SAAUC,MAAO9J,IAO7C,OALyB,IAArBnE,UAAUb,SAA0B,IAAV8O,QAAgBA,MAAQ,GAClDA,OAAS,IAAGA,MAAQ,GACxBlP,KAAKmP,YAAcD,MACnBlP,KAAKoP,SAAW,EAChBpP,KAAKqP,eAAiBjK,GACfpF,MAGT,IAAIsP,YAAc,CAAC,aAAc,YAAa,YAAa,mBAU3D1B,YAAYpM,UAAU+N,aAAe,SAAUC,IAAK7C,KAClD,IAAK3M,KAAKmP,aAAenP,KAAKoP,YAAcpP,KAAKmP,YAC/C,OAAO,EAGT,GAAInP,KAAKqP,eACP,IACE,IAAII,SAAWzP,KAAKqP,eAAeG,IAAK7C,KAExC,IAAiB,IAAb8C,SAAmB,OAAO,EAC9B,IAAiB,IAAbA,SAAoB,OAAO,EAC/B,MAAOC,MACPX,QAAQY,MAAMD,MAIlB,GAAI/C,KAAOA,IAAIiD,QAAUjD,IAAIiD,QAAU,KAAsB,MAAfjD,IAAIiD,OAAgB,OAAO,EAEzE,GAAIJ,IAAK,CACP,GAAIA,IAAIK,MAAQP,YAAYQ,SAASN,IAAIK,MAAO,OAAO,EAEvD,GAAIL,IAAIjB,SAAwB,iBAAbiB,IAAIK,KAAyB,OAAO,EACvD,GAAIL,IAAIO,YAAa,OAAO,EAG9B,OAAO,GAUTnC,YAAYpM,UAAUwO,OAAS,WAW7B,OAVAhQ,KAAK6N,eAED7N,KAAKiQ,MACPjQ,KAAKiQ,IAAM,KACXjQ,KAAKiQ,IAAMjQ,KAAKkQ,WAGlBlQ,KAAKmQ,UAAW,EAChBnQ,KAAKoQ,UAAW,EAChBpQ,KAAKqQ,cAAgB,KACdrQ,KAAKsQ,QAWd1C,YAAYpM,UAAU+O,KAAO,SAAUC,QAASC,QAC9C,IAAIC,MAAQ1Q,KAEZ,IAAKA,KAAK2Q,mBAAoB,CAC5B,IAAIC,KAAO5Q,KAEPA,KAAK6Q,YACP9B,QAAQC,KAAK,kIAGfhP,KAAK2Q,mBAAqB,IAAIG,SAAQ,SAAUN,QAASC,QACvDG,KAAKxF,GAAG,SAAS,WACf,KAAIsF,MAAMvB,aAAeuB,MAAMvB,YAAcuB,MAAMtB,UAInD,GAAIsB,MAAMN,UAAYM,MAAML,cAC1BI,OAAOC,MAAML,mBADf,CAKA,IAAIb,IAAM,IAAIuB,MAAM,WACpBvB,IAAIK,KAAO,UACXL,IAAII,OAASc,MAAMd,OACnBJ,IAAIwB,OAASN,MAAMM,OACnBxB,IAAIyB,IAAMP,MAAMO,IAChBR,OAAOjB,SAEToB,KAAKM,KAAI,SAAU1B,IAAK7C,KAClB6C,IAAKiB,OAAOjB,KAAUgB,QAAQ7D,WAKxC,OAAO3M,KAAK2Q,mBAAmBJ,KAAKC,QAASC,SAG/C7C,YAAYpM,UAAU2P,MAAQ,SAAUtF,IACtC,OAAO7L,KAAKuQ,UAAKrG,EAAW2B,KAO9B+B,YAAYpM,UAAU4P,IAAM,SAAUhM,IAEpC,OADAA,GAAGpF,MACIA,MAGT4N,YAAYpM,UAAU6P,GAAK,SAAUxF,IACnC,GAAkB,mBAAPA,GAAmB,MAAM,IAAIkF,MAAM,qBAE9C,OADA/Q,KAAKsR,YAAczF,GACZ7L,MAGT4N,YAAYpM,UAAU+P,cAAgB,SAAU5E,KAC9C,QAAKA,MAID3M,KAAKsR,YACAtR,KAAKsR,YAAY3E,KAGnBA,IAAIiD,QAAU,KAAOjD,IAAIiD,OAAS,MAY3ChC,YAAYpM,UAAUyL,IAAM,SAAUuE,OACpC,OAAOxR,KAAKyR,QAAQD,MAAME,gBAe5B9D,YAAYpM,UAAUmQ,UAAY/D,YAAYpM,UAAUyL,IAsBxDW,YAAYpM,UAAUoQ,IAAM,SAAUJ,MAAOhO,KAC3C,GAAIqO,WAASL,OAAQ,CACnB,IAAK,IAAI7O,OAAO6O,MACVjQ,OAAOC,UAAUC,eAAeN,KAAKqQ,MAAO7O,MAAM3C,KAAK4R,IAAIjP,IAAK6O,MAAM7O,MAG5E,OAAO3C,KAKT,OAFAA,KAAKyR,QAAQD,MAAME,eAAiBlO,IACpCxD,KAAK8R,OAAON,OAAShO,IACdxD,MAgBT4N,YAAYpM,UAAUuQ,MAAQ,SAAUP,OAGtC,cAFOxR,KAAKyR,QAAQD,MAAME,sBACnB1R,KAAK8R,OAAON,OACZxR,MAuBT4N,YAAYpM,UAAUgQ,MAAQ,SAAUQ,KAAMxO,KAE5C,GAAIwO,MAAAA,KACF,MAAM,IAAIjB,MAAM,2CAGlB,GAAI/Q,KAAKiS,MACP,MAAM,IAAIlB,MAAM,mGAGlB,GAAIc,WAASG,MAAO,CAClB,IAAK,IAAIrP,OAAOqP,KACVzQ,OAAOC,UAAUC,eAAeN,KAAK6Q,KAAMrP,MAAM3C,KAAKwR,MAAM7O,IAAKqP,KAAKrP,MAG5E,OAAO3C,KAGT,GAAI2B,MAAMD,QAAQ8B,KAAM,CACtB,IAAK,IAAI9C,KAAK8C,IACRjC,OAAOC,UAAUC,eAAeN,KAAKqC,IAAK9C,IAAIV,KAAKwR,MAAMQ,KAAMxO,IAAI9C,IAGzE,OAAOV,KAIT,GAAIwD,MAAAA,IACF,MAAM,IAAIuN,MAAM,0CASlB,MANmB,kBAARvN,MACTA,IAAMgB,OAAOhB,MAGfxD,KAAKkS,eAAeC,OAAOH,KAAMxO,KAE1BxD,MAUT4N,YAAYpM,UAAU4Q,MAAQ,WAC5B,OAAIpS,KAAKmQ,WAITnQ,KAAKmQ,UAAW,EACZnQ,KAAKqS,KAAKrS,KAAKqS,IAAID,QAEnBpS,KAAKiQ,KAAKjQ,KAAKiQ,IAAImC,QAEvBpS,KAAK6N,eACL7N,KAAKgM,KAAK,UATDhM,MAaX4N,YAAYpM,UAAU8Q,MAAQ,SAAUC,KAAMC,KAAMtQ,QAASuQ,eAC3D,OAAQvQ,QAAQwQ,MACd,IAAK,QACH1S,KAAK4R,IAAI,gBAAiB,SAAS7O,OAAO0P,cAAc,GAAG1P,OAAOwP,KAAM,KAAKxP,OAAOyP,SACpF,MAEF,IAAK,OACHxS,KAAK2S,SAAWJ,KAChBvS,KAAK4S,SAAWJ,KAChB,MAEF,IAAK,SAEHxS,KAAK4R,IAAI,gBAAiB,UAAU7O,OAAOwP,OAO/C,OAAOvS,MAcT4N,YAAYpM,UAAUqR,gBAAkB,SAAUzH,IAIhD,YAFWlB,IAAPkB,KAAkBA,IAAK,GAC3BpL,KAAK8S,iBAAmB1H,GACjBpL,MAWT4N,YAAYpM,UAAUuR,UAAY,SAAUC,GAE1C,OADAhT,KAAKiT,cAAgBD,EACdhT,MAWT4N,YAAYpM,UAAU0R,gBAAkB,SAAUF,GAChD,GAAiB,iBAANA,EACT,MAAM,IAAI3S,UAAU,oBAItB,OADAL,KAAKmT,iBAAmBH,EACjBhT,MAYT4N,YAAYpM,UAAUiM,OAAS,WAC7B,MAAO,CACLuD,OAAQhR,KAAKgR,OACbC,IAAKjR,KAAKiR,IACVmC,KAAMpT,KAAKiS,MACXoB,QAASrT,KAAKyR,UA6ClB7D,YAAYpM,UAAU8R,KAAO,SAAUF,MACrC,IAAIG,MAAQ1B,WAASuB,MACjBV,KAAO1S,KAAKyR,QAAQ,gBAExB,GAAIzR,KAAKwT,UACP,MAAM,IAAIzC,MAAM,gHAGlB,GAAIwC,QAAUvT,KAAKiS,MACbtQ,MAAMD,QAAQ0R,MAChBpT,KAAKiS,MAAQ,GACHjS,KAAKyT,QAAQL,QACvBpT,KAAKiS,MAAQ,SAEV,GAAImB,MAAQpT,KAAKiS,OAASjS,KAAKyT,QAAQzT,KAAKiS,OACjD,MAAM,IAAIlB,MAAM,gCAIlB,GAAIwC,OAAS1B,WAAS7R,KAAKiS,OACzB,IAAK,IAAItP,OAAOyQ,KACV7R,OAAOC,UAAUC,eAAeN,KAAKiS,KAAMzQ,OAAM3C,KAAKiS,MAAMtP,KAAOyQ,KAAKzQ,UAErD,iBAATyQ,MAEXV,MAAM1S,KAAK0S,KAAK,QACrBA,KAAO1S,KAAKyR,QAAQ,gBAGlBzR,KAAKiS,MADM,sCAATS,KACW1S,KAAKiS,MAAQ,GAAGlP,OAAO/C,KAAKiS,MAAO,KAAKlP,OAAOqQ,MAAQA,MAEtDpT,KAAKiS,OAAS,IAAMmB,MAGpCpT,KAAKiS,MAAQmB,KAGf,OAAKG,OAASvT,KAAKyT,QAAQL,OAKtBV,MAAM1S,KAAK0S,KAAK,QAJZ1S,MAoCX4N,YAAYpM,UAAUkS,UAAY,SAAUvL,MAG1C,OADAnI,KAAK2T,WAAwB,IAATxL,MAA8BA,KAC3CnI,MAST4N,YAAYpM,UAAUoS,qBAAuB,WAC3C,IAAIC,MAAQ7T,KAAK8T,OAAOhT,KAAK,KAQ7B,GANI+S,QACF7T,KAAKiR,MAAQjR,KAAKiR,IAAInB,SAAS,KAAO,IAAM,KAAO+D,OAGrD7T,KAAK8T,OAAO1T,OAAS,EAEjBJ,KAAK2T,MAAO,CACd,IAAIlK,MAAQzJ,KAAKiR,IAAIxN,QAAQ,KAE7B,GAAIgG,OAAS,EAAG,CACd,IAAIsK,SAAW/T,KAAKiR,IAAI/P,MAAMuI,MAAQ,GAAGzI,MAAM,KAErB,mBAAfhB,KAAK2T,MACdI,SAAS5L,KAAKnI,KAAK2T,OAEnBI,SAAS5L,OAGXnI,KAAKiR,IAAMjR,KAAKiR,IAAI/P,MAAM,EAAGuI,OAAS,IAAMsK,SAASjT,KAAK,QAMhE8M,YAAYpM,UAAUwS,mBAAqB,WACzCjF,QAAQC,KAAK,gBASfpB,YAAYpM,UAAUyS,cAAgB,SAAUC,OAAQ3F,QAAS4F,OAC/D,IAAInU,KAAKmQ,SAAT,CAIA,IAAIX,IAAM,IAAIuB,MAAM,GAAGhO,OAAOmR,OAAS3F,QAAS,gBAChDiB,IAAIjB,QAAUA,QACdiB,IAAIK,KAAO,eACXL,IAAI2E,MAAQA,MACZnU,KAAKoQ,UAAW,EAChBpQ,KAAKqQ,cAAgBb,IACrBxP,KAAKoS,QACLpS,KAAKoU,SAAS5E,OAGhB5B,YAAYpM,UAAU6S,aAAe,WACnC,IAAIzD,KAAO5Q,KAEPA,KAAKwO,WAAaxO,KAAK8N,SACzB9N,KAAK8N,OAASwG,YAAW,WACvB1D,KAAKqD,cAAc,cAAerD,KAAKpC,SAAU,WAChDxO,KAAKwO,WAINxO,KAAKyO,mBAAqBzO,KAAK+N,wBACjC/N,KAAK+N,sBAAwBuG,YAAW,WACtC1D,KAAKqD,cAAc,uBAAwBrD,KAAKnC,iBAAkB,eACjEzO,KAAKyO,oBCxuBZ,iBAAe,SAAU5N,KACvB,OAAOA,IAAIG,MAAM,SAASR,wBAWX,SAAUK,KACzB,OAAOA,IAAIG,MAAM,SAASyB,QAAO,SAAUN,IAAKtB,KAC9C,IAAIE,MAAQF,IAAIG,MAAM,SAClB2B,IAAM5B,MAAMP,QACZgD,IAAMzC,MAAMP,QAEhB,OADImC,KAAOa,MAAKrB,IAAIQ,KAAOa,KACpBrB,MACN,wBAWgB,SAAUtB,KAC7B,OAAOA,IAAIG,MAAM,SAASyB,QAAO,SAAUN,IAAKtB,KAC9C,IAAIE,MAAQF,IAAIG,MAAM,SAClBiQ,IAAMlQ,MAAM,GAAGG,MAAM,GAAI,GAG7B,OADAiB,IADUpB,MAAM,GAAGC,MAAM,SAAS,GAAGE,MAAM,GAAI,IACpC+P,IACJ9O,MACN,kBCnCYoS,aAOjB,SAASA,aAAapS,KACpB,GAAIA,IAAK,OAWX,SAAeA,KACb,IAAK,IAAIQ,OAAO4R,aAAa/S,UACvBD,OAAOC,UAAUC,eAAeN,KAAKoT,aAAa/S,UAAWmB,OAAMR,IAAIQ,KAAO4R,aAAa/S,UAAUmB,MAG3G,OAAOR,IAhBSgJ,CAAMhJ,KCjBxB,SAASqS,mBAAmB/N,KAAO,OAQnC,SAA4BA,KAAO,GAAI9E,MAAMD,QAAQ+E,KAAM,OAAOgO,kBAAkBhO,KAR1CiO,CAAmBjO,MAM7D,SAA0BkO,MAAQ,GAAsB,oBAAXpQ,QAA0BA,OAAOoJ,YAAYpM,OAAOoT,MAAO,OAAOhT,MAAMiT,KAAKD,MANrDE,CAAiBpO,MAItF,SAAqCtD,EAAG2R,QAAU,IAAK3R,EAAG,OAAQ,GAAiB,iBAANA,EAAgB,OAAOsR,kBAAkBtR,EAAG2R,QAAS,IAAI9B,EAAIzR,OAAOC,UAAUM,SAASX,KAAKgC,GAAGjC,MAAM,GAAI,GAAc,WAAN8R,GAAkB7P,EAAE8B,cAAa+N,EAAI7P,EAAE8B,YAAY+M,MAAM,GAAU,QAANgB,GAAqB,QAANA,EAAa,OAAOrR,MAAMiT,KAAKzR,GAAI,GAAU,cAAN6P,GAAqB,2CAA2C+B,KAAK/B,GAAI,OAAOyB,kBAAkBtR,EAAG2R,QAJxTE,CAA4BvO,MAE1H,WAAgC,MAAM,IAAIpG,UAAU,wIAF8E4U,GAUlI,SAASR,kBAAkBhO,IAAKyF,MAAkB,MAAPA,KAAeA,IAAMzF,IAAIrG,UAAQ8L,IAAMzF,IAAIrG,QAAQ,IAAK,IAAIM,EAAI,EAAGwU,KAAO,IAAIvT,MAAMuK,KAAMxL,EAAIwL,IAAKxL,IAAOwU,KAAKxU,GAAK+F,IAAI/F,GAAM,OAAOwU,KAEhL,SAASC,QACPnV,KAAKoV,UAAY,GD+BnBb,aAAa/S,UAAUyL,IAAM,SAAUuE,OACrC,OAAOxR,KAAK8R,OAAON,MAAME,gBAe3B6C,aAAa/S,UAAU6T,qBAAuB,SAAUvD,QAItD,IAAIwD,GAAKxD,OAAO,iBAAmB,GACnC9R,KAAK0S,KAAOnL,aAAW+N,IAEvB,IAAIC,OAAShO,eAAa+N,IAE1B,IAAK,IAAI3S,OAAO4S,OACVhU,OAAOC,UAAUC,eAAeN,KAAKoU,OAAQ5S,OAAM3C,KAAK2C,KAAO4S,OAAO5S,MAG5E3C,KAAKwV,MAAQ,GAEb,IACM1D,OAAO2D,OACTzV,KAAKwV,MAAQjO,mBAAiBuK,OAAO2D,OAEvC,MAAOC,YAyBXnB,aAAa/S,UAAUmU,qBAAuB,SAAU/F,QACtD,IAAI8C,KAAO9C,OAAS,IAAM,EAE1B5P,KAAK4V,WAAahG,OAClB5P,KAAK4P,OAAS5P,KAAK4V,WACnB5V,KAAK6V,WAAanD,KAElB1S,KAAK8V,KAAgB,IAATpD,KACZ1S,KAAKqR,GAAc,IAATqB,KACV1S,KAAK+V,SAAoB,IAATrD,KAChB1S,KAAKgW,YAAuB,IAATtD,KACnB1S,KAAKiW,YAAuB,IAATvD,KACnB1S,KAAK2P,OAAiB,IAAT+C,MAAuB,IAATA,OAAa1S,KAAKkW,UAE7ClW,KAAKmW,QAAqB,MAAXvG,OACf5P,KAAKoW,SAAsB,MAAXxG,OAChB5P,KAAKqW,UAAuB,MAAXzG,OACjB5P,KAAKsW,WAAwB,MAAX1G,OAClB5P,KAAKuW,aAA0B,MAAX3G,OACpB5P,KAAKwW,cAA2B,MAAX5G,OACrB5P,KAAKyW,UAAuB,MAAX7G,OACjB5P,KAAK0W,SAAsB,MAAX9G,OAChB5P,KAAK2W,oBAAiC,MAAX/G,QC9G7B,CAAC,MAAO,KAAM,OAAQ,MAAO,QAAS,OAAQ,SAAU,OAAQ,kBAAmB,YAAa,QAAS,KAAM,YAAa,UAAW,SAAU,YAAa,QAAS,KAAM,MAAO,MAAO,OAAQ,mBAAmBnK,SAAQ,SAAUL,IAEtO+P,MAAM3T,UAAU4D,IAAM,WACpB,IAAK,IAAIwR,KAAO3V,UAAUb,OAAQ6L,KAAO,IAAItK,MAAMiV,MAAOC,KAAO,EAAGA,KAAOD,KAAMC,OAC/E5K,KAAK4K,MAAQ5V,UAAU4V,MAQzB,OALA7W,KAAKoV,UAAUxU,KAAK,CAClBwE,GAAIA,GACJ6G,KAAMA,OAGDjM,SAIXmV,MAAM3T,UAAUsV,aAAe,SAAU7G,KACvCjQ,KAAKoV,UAAU3P,SAAQ,SAAUsR,KAC/B9G,IAAI8G,IAAI3R,IAAIuB,MAAMsJ,IAAKuE,mBAAmBuC,IAAI9K,WCzBlD,ID6BA,cAAiBkJ,4DEtCjB,SAASzH,QAAQvL,KAAmV,OAAtOuL,QAArD,mBAAXnJ,QAAoD,iBAApBA,OAAOoJ,SAAmC,SAAiBxL,KAAO,cAAcA,KAA2B,SAAiBA,KAAO,OAAOA,KAAyB,mBAAXoC,QAAyBpC,IAAI8C,cAAgBV,QAAUpC,MAAQoC,OAAO/C,UAAY,gBAAkBW,MAAyBA,KAKnX,IAAIyH,KA8BJ,SAASoN,QA5Ba,oBAAXC,OAETrN,KAAOqN,OACkB,oBAATrG,MAEhB7B,QAAQC,KAAK,uEACbpF,UAAO,GAGPA,KAAOgH,KAyBTxP,eAAiB,SAAU4P,OAAQC,KAEjC,MAAmB,mBAARA,IACF,IAAI5P,QAAQ6V,QAAQ,MAAOlG,QAAQE,IAAID,KAIvB,IAArBhQ,UAAUb,OACL,IAAIiB,QAAQ6V,QAAQ,MAAOlG,QAG7B,IAAI3P,QAAQ6V,QAAQlG,OAAQC,MAIrC,IAAIf,QADJ7O,QAAUD,OAAOC,QAEjBA,gBAAkB6V,QAKlBhH,QAAQiH,OAAS,WACf,GAAIvN,KAAKwN,kBAAoBxN,KAAKyN,UAAuC,UAA3BzN,KAAKyN,SAASC,WAAyB1N,KAAK2N,eACxF,OAAO,IAAIH,eAGb,IACE,OAAO,IAAIG,cAAc,qBACzB,MAAO7B,UAET,IACE,OAAO,IAAI6B,cAAc,sBACzB,MAAOC,WAET,IACE,OAAO,IAAID,cAAc,sBACzB,MAAOE,WAET,IACE,OAAO,IAAIF,cAAc,kBACzB,MAAOG,WAET,MAAM,IAAI3G,MAAM,0DAWlB,IAAI4G,KAAO,GAAGA,KAAO,SAAUC,GAC7B,OAAOA,EAAED,QACP,SAAUC,GACZ,OAAOA,EAAEnX,QAAQ,eAAgB,KAUnC,SAAS4N,UAAUlM,KACjB,IAAK0P,WAAS1P,KAAM,OAAOA,IAC3B,IAAI0V,MAAQ,GAEZ,IAAK,IAAIlV,OAAOR,IACVZ,OAAOC,UAAUC,eAAeN,KAAKgB,IAAKQ,MAAMmV,wBAAwBD,MAAOlV,IAAKR,IAAIQ,MAG9F,OAAOkV,MAAM/W,KAAK,KAYpB,SAASgX,wBAAwBD,MAAOlV,IAAKa,KAC3C,QAAY0G,IAAR1G,IAEJ,GAAY,OAARA,IAKJ,GAAI7B,MAAMD,QAAQ8B,KAChBA,IAAIiC,SAAQ,SAAU2C,GACpB0P,wBAAwBD,MAAOlV,IAAKyF,WAEjC,GAAIyJ,WAASrO,KAClB,IAAK,IAAIuU,UAAUvU,IACbjC,OAAOC,UAAUC,eAAeN,KAAKqC,IAAKuU,SAASD,wBAAwBD,MAAO,GAAG9U,OAAOJ,IAAK,KAAKI,OAAOgV,OAAQ,KAAMvU,IAAIuU,cAGrIF,MAAMjX,KAAKoX,UAAUrV,KAAO,IAAMsV,mBAAmBzU,WAbrDqU,MAAMjX,KAAKoX,UAAUrV,MA8BzB,SAASuV,YAAYrX,KAMnB,IALA,IAEIsX,KACAxN,IAHAxI,IAAM,GACN0V,MAAQhX,IAAIG,MAAM,KAIbN,EAAI,EAAGwL,IAAM2L,MAAMzX,OAAQM,EAAIwL,MAAOxL,GAIhC,KAFbiK,KADAwN,KAAON,MAAMnX,IACF+C,QAAQ,MAGjBtB,IAAI+B,mBAAmBiU,OAAS,GAEhChW,IAAI+B,mBAAmBiU,KAAKjX,MAAM,EAAGyJ,OAASzG,mBAAmBiU,KAAKjX,MAAMyJ,IAAM,IAItF,OAAOxI,IA2FT,SAASiW,OAAOC,MAGd,MAAO,qBAAqBtD,KAAKsD,MAiDnC,SAASC,SAASrI,KAChBjQ,KAAKiQ,IAAMA,IACXjQ,KAAKqS,IAAMrS,KAAKiQ,IAAIoC,IAEpBrS,KAAKuY,KAA2B,SAApBvY,KAAKiQ,IAAIe,SAAgD,KAA1BhR,KAAKqS,IAAIlE,cAAiD,SAA1BnO,KAAKqS,IAAIlE,oBAA6D,IAA1BnO,KAAKqS,IAAIlE,aAA+BnO,KAAKqS,IAAImG,aAAe,KACvLxY,KAAKyY,WAAazY,KAAKiQ,IAAIoC,IAAIoG,WAC/B,IAAI7I,OAAS5P,KAAKqS,IAAIzC,OAEP,OAAXA,SACFA,OAAS,KAGX5P,KAAK2V,qBAAqB/F,QAE1B5P,KAAKqT,QAnGP,SAAqBxS,KAQnB,IAPA,IAEI4I,MACAiP,KACAlH,MACAhO,IALAmV,MAAQ9X,IAAIG,MAAM,SAClB4X,OAAS,GAMJlY,EAAI,EAAGwL,IAAMyM,MAAMvY,OAAQM,EAAIwL,MAAOxL,GAI9B,KAFf+I,OADAiP,KAAOC,MAAMjY,IACA+C,QAAQ,QAOrB+N,MAAQkH,KAAKxX,MAAM,EAAGuI,OAAOiI,cAC7BlO,IAAMmU,KAAKe,KAAKxX,MAAMuI,MAAQ,IAC9BmP,OAAOpH,OAAShO,KAGlB,OAAOoV,OA6EQC,CAAY7Y,KAAKqS,IAAIyG,yBACpC9Y,KAAK8R,OAAS9R,KAAKqT,QAInBrT,KAAK8R,OAAO,gBAAkB9R,KAAKqS,IAAI0G,kBAAkB,gBAEzD/Y,KAAKqV,qBAAqBrV,KAAK8R,QAEb,OAAd9R,KAAKuY,MAAiBtI,IAAI7B,cAC5BpO,KAAKgZ,KAAOhZ,KAAKqS,IAAIxD,SAErB7O,KAAKgZ,KAA2B,SAApBhZ,KAAKiQ,IAAIe,OAAoB,KAAOhR,KAAKiZ,WAAWjZ,KAAKuY,KAAOvY,KAAKuY,KAAOvY,KAAKqS,IAAIxD,UA+DrG,SAASqI,QAAQlG,OAAQC,KACvB,IAAIL,KAAO5Q,KACXA,KAAK8T,OAAS9T,KAAK8T,QAAU,GAC7B9T,KAAKgR,OAASA,OACdhR,KAAKiR,IAAMA,IACXjR,KAAK8R,OAAS,GAEd9R,KAAKyR,QAAU,GAEfzR,KAAKoL,GAAG,OAAO,WACb,IAyBI8N,QAzBA1J,IAAM,KACN7C,IAAM,KAEV,IACEA,IAAM,IAAI2L,SAAS1H,MACnB,MAAOlB,MAgBP,OAfAF,IAAM,IAAIuB,MAAM,2CACZ9C,OAAQ,EACZuB,IAAI2J,SAAWzJ,KAEXkB,KAAKyB,KAEP7C,IAAI4J,iBAA+C,IAA1BxI,KAAKyB,IAAIlE,aAA+ByC,KAAKyB,IAAImG,aAAe5H,KAAKyB,IAAIxD,SAElGW,IAAII,OAASgB,KAAKyB,IAAIzC,OAASgB,KAAKyB,IAAIzC,OAAS,KACjDJ,IAAIoG,WAAapG,IAAII,SAErBJ,IAAI4J,YAAc,KAClB5J,IAAII,OAAS,MAGRgB,KAAKwD,SAAS5E,KAGvBoB,KAAK5E,KAAK,WAAYW,KAGtB,IACOiE,KAAKW,cAAc5E,OACtBuM,QAAU,IAAInI,MAAMpE,IAAI8L,YAAc9L,IAAI4L,MAAQ,+BAEpD,MAAO7I,MACPwJ,QAAUxJ,KAIRwJ,SACFA,QAAQC,SAAW3J,IACnB0J,QAAQrK,SAAWlC,IACnBuM,QAAQtJ,OAASjD,IAAIiD,OACrBgB,KAAKwD,SAAS8E,QAASvM,MAEvBiE,KAAKwD,SAAS,KAAMzH,QAwd1B,SAAS0M,IAAIpI,IAAKmC,KAAMhO,IACtB,IAAI6K,IAAMC,QAAQ,SAAUe,KAS5B,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAIqD,KAAKF,MACfhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,IAxxBTC,QAAQoJ,gBAAkBjL,UAiC1B6B,QAAQgI,YAAcA,YAQtBhI,QAAQqJ,MAAQ,CACdC,KAAM,YACNC,KAAM,mBACNC,IAAK,WACLC,WAAY,oCACZC,KAAM,oCACNC,YAAa,qCAWf3J,QAAQ7B,UAAY,CAClByL,oCAAqCzL,UACrC0L,mBAAoBC,mBAWtB9J,QAAQjC,MAAQ,CACd6L,oCAAqC5B,YACrC6B,mBAAoB3M,KAAKa,OA+H3BsG,aAAa+D,SAAS9W,WAYtB8W,SAAS9W,UAAUyX,WAAa,SAAUpY,KACxC,IAAIoN,MAAQiC,QAAQjC,MAAMjO,KAAK0S,MAE/B,OAAI1S,KAAKiQ,IAAI/B,QACJlO,KAAKiQ,IAAI/B,QAAQlO,KAAMa,OAG3BoN,OAASmK,OAAOpY,KAAK0S,QACxBzE,MAAQiC,QAAQjC,MAAM,qBAGjBA,OAASpN,MAAQA,IAAIT,OAAS,GAAKS,eAAeU,QAAU0M,MAAMpN,KAAO,OAUlFyX,SAAS9W,UAAU0U,QAAU,WAC3B,IAAIjG,IAAMjQ,KAAKiQ,IACXe,OAASf,IAAIe,OACbC,IAAMhB,IAAIgB,IACVgJ,IAAM,UAAUlX,OAAOiO,OAAQ,KAAKjO,OAAOkO,IAAK,MAAMlO,OAAO/C,KAAK4P,OAAQ,KAC1EJ,IAAM,IAAIuB,MAAMkJ,KAIpB,OAHAzK,IAAII,OAAS5P,KAAK4P,OAClBJ,IAAIwB,OAASA,OACbxB,IAAIyB,IAAMA,IACHzB,KAOTU,QAAQoI,SAAWA,SAuEnBpN,iBAAQgM,QAAQ1V,WAEhBoM,YAAYsJ,QAAQ1V,WAuBpB0V,QAAQ1V,UAAUkR,KAAO,SAAUA,MAEjC,OADA1S,KAAK4R,IAAI,eAAgB1B,QAAQqJ,MAAM7G,OAASA,MACzC1S,MAuBTkX,QAAQ1V,UAAU0Y,OAAS,SAAUxH,MAEnC,OADA1S,KAAK4R,IAAI,SAAU1B,QAAQqJ,MAAM7G,OAASA,MACnC1S,MAaTkX,QAAQ1V,UAAU2Y,KAAO,SAAU5H,KAAMC,KAAMtQ,SACpB,IAArBjB,UAAUb,SAAcoS,KAAO,IAEb,WAAlB9E,QAAQ8E,OAA+B,OAATA,OAEhCtQ,QAAUsQ,KACVA,KAAO,IAGJtQ,UACHA,QAAU,CACRwQ,KAAsB,mBAAT0H,KAAsB,QAAU,SAIjD,IAAI9S,QAAU,SAAiBhD,QAC7B,GAAoB,mBAAT8V,KACT,OAAOA,KAAK9V,QAGd,MAAM,IAAIyM,MAAM,kDAGlB,OAAO/Q,KAAKsS,MAAMC,KAAMC,KAAMtQ,QAASoF,UAiBzC4P,QAAQ1V,UAAUqS,MAAQ,SAAUrQ,KAGlC,MAFmB,iBAARA,MAAkBA,IAAM6K,UAAU7K,MACzCA,KAAKxD,KAAK8T,OAAOlT,KAAK4C,KACnBxD,MAoBTkX,QAAQ1V,UAAU6Y,OAAS,SAAU7I,MAAO8I,KAAMpY,SAChD,GAAIoY,KAAM,CACR,GAAIta,KAAKiS,MACP,MAAM,IAAIlB,MAAM,8CAGlB/Q,KAAKkS,eAAeC,OAAOX,MAAO8I,KAAMpY,SAAWoY,KAAKtI,MAG1D,OAAOhS,MAGTkX,QAAQ1V,UAAU0Q,aAAe,WAK/B,OAJKlS,KAAKwT,YACRxT,KAAKwT,UAAY,IAAI5J,KAAK2Q,UAGrBva,KAAKwT,WAYd0D,QAAQ1V,UAAU4S,SAAW,SAAU5E,IAAK7C,KAC1C,GAAI3M,KAAKuP,aAAaC,IAAK7C,KACzB,OAAO3M,KAAKgQ,SAGd,IAAI5K,GAAKpF,KAAKwa,UACdxa,KAAK6N,eAED2B,MACExP,KAAKmP,cAAaK,IAAIiL,QAAUza,KAAKoP,SAAW,GACpDpP,KAAKgM,KAAK,QAASwD,MAGrBpK,GAAGoK,IAAK7C,MASVuK,QAAQ1V,UAAUkZ,iBAAmB,WACnC,IAAIlL,IAAM,IAAIuB,MAAM,gKACpBvB,IAAIO,aAAc,EAClBP,IAAII,OAAS5P,KAAK4P,OAClBJ,IAAIwB,OAAShR,KAAKgR,OAClBxB,IAAIyB,IAAMjR,KAAKiR,IACfjR,KAAKoU,SAAS5E,MAIhB0H,QAAQ1V,UAAUmZ,MAAQ,WAExB,OADA5L,QAAQC,KAAK,0DACNhP,MAGTkX,QAAQ1V,UAAUoZ,GAAK1D,QAAQ1V,UAAUmZ,MACzCzD,QAAQ1V,UAAUqZ,OAAS3D,QAAQ1V,UAAUoZ,GAE7C1D,QAAQ1V,UAAUsZ,MAAQ,WACxB,MAAM,IAAI/J,MAAM,gEAGlBmG,QAAQ1V,UAAUuZ,KAAO7D,QAAQ1V,UAAUsZ,MAU3C5D,QAAQ1V,UAAUiS,QAAU,SAAUtR,KAEpC,OAAOA,KAAwB,WAAjBuL,QAAQvL,OAAsBR,MAAMD,QAAQS,MAAgD,oBAAxCZ,OAAOC,UAAUM,SAASX,KAAKgB,MAYnG+U,QAAQ1V,UAAU0P,IAAM,SAAU9L,IAC5BpF,KAAK6Q,YACP9B,QAAQC,KAAK,yEAGfhP,KAAK6Q,YAAa,EAElB7Q,KAAKwa,UAAYpV,IAAM4R,KAEvBhX,KAAK4T,uBAEL5T,KAAKsQ,QAGP4G,QAAQ1V,UAAUwZ,kBAAoB,WACpC,IAAIpK,KAAO5Q,KAEPA,KAAK0O,iBAAmB1O,KAAKgO,sBAC/BhO,KAAKgO,oBAAsBsG,YAAW,WACpC1D,KAAKqD,cAAc,qBAAsBrD,KAAKlC,eAAgB,eAC7D1O,KAAK0O,kBAKZwI,QAAQ1V,UAAU8O,KAAO,WACvB,GAAItQ,KAAKmQ,SAAU,OAAOnQ,KAAKoU,SAAS,IAAIrD,MAAM,+DAClD,IAAIH,KAAO5Q,KACXA,KAAKqS,IAAMnC,QAAQiH,SACnB,IAAI9E,IAAMrS,KAAKqS,IACXe,KAAOpT,KAAKwT,WAAaxT,KAAKiS,MAElCjS,KAAKqU,eAGLhC,IAAI4I,mBAAqB,WACvB,IAAIC,WAAa7I,IAAI6I,WAMrB,GAJIA,YAAc,GAAKtK,KAAK7C,uBAC1BF,aAAa+C,KAAK7C,uBAGD,IAAfmN,WAAJ,CAMA,IAAItL,OAEJ,IACEA,OAASyC,IAAIzC,OACb,MAAOuL,UACPvL,OAAS,EAGX,IAAKA,OAAQ,CACX,GAAIgB,KAAKR,UAAYQ,KAAKT,SAAU,OACpC,OAAOS,KAAK8J,mBAGd9J,KAAK5E,KAAK,SAIZ,IAAIoP,eAAiB,SAAwBC,UAAWlX,GAClDA,EAAEmX,MAAQ,IACZnX,EAAEoX,QAAUpX,EAAEqX,OAASrX,EAAEmX,MAAQ,IAEf,MAAdnX,EAAEoX,SACJ1N,aAAa+C,KAAK5C,sBAItB7J,EAAEkX,UAAYA,UACdzK,KAAK5E,KAAK,WAAY7H,IAGxB,GAAInE,KAAKoM,aAAa,YACpB,IACEiG,IAAIhH,iBAAiB,WAAY+P,eAAeK,KAAK,KAAM,aAEvDpJ,IAAIvD,QACNuD,IAAIvD,OAAOzD,iBAAiB,WAAY+P,eAAeK,KAAK,KAAM,WAEpE,MAAOC,WAMPrJ,IAAIvD,QACN9O,KAAKgb,oBAIP,IACMhb,KAAK2S,UAAY3S,KAAK4S,SACxBP,IAAIsJ,KAAK3b,KAAKgR,OAAQhR,KAAKiR,KAAK,EAAMjR,KAAK2S,SAAU3S,KAAK4S,UAE1DP,IAAIsJ,KAAK3b,KAAKgR,OAAQhR,KAAKiR,KAAK,GAElC,MAAOzB,KAEP,OAAOxP,KAAKoU,SAAS5E,KAMvB,GAFIxP,KAAK8S,mBAAkBT,IAAIQ,iBAAkB,IAE5C7S,KAAKwT,WAA6B,QAAhBxT,KAAKgR,QAAoC,SAAhBhR,KAAKgR,QAAqC,iBAAToC,OAAsBpT,KAAKyT,QAAQL,MAAO,CAEzH,IAAIwI,YAAc5b,KAAKyR,QAAQ,gBAE3BoK,WAAa7b,KAAKsO,aAAe4B,QAAQ7B,UAAUuN,YAAcA,YAAY5a,MAAM,KAAK,GAAK,KAE5F6a,YAAczD,OAAOwD,eACxBC,WAAa3L,QAAQ7B,UAAU,qBAG7BwN,aAAYzI,KAAOyI,WAAWzI,OAIpC,IAAK,IAAI5B,SAASxR,KAAK8R,OACM,OAAvB9R,KAAK8R,OAAON,QACZjQ,OAAOC,UAAUC,eAAeN,KAAKnB,KAAK8R,OAAQN,QAAQa,IAAIyJ,iBAAiBtK,MAAOxR,KAAK8R,OAAON,QAGpGxR,KAAKoO,gBACPiE,IAAIlE,aAAenO,KAAKoO,eAI1BpO,KAAKgM,KAAK,UAAWhM,MAGrBqS,IAAIiB,UAAqB,IAATF,KAAuB,KAAOA,OAGhDlD,QAAQyK,MAAQ,WACd,OAAO,IAAIxF,WAGb,CAAC,MAAO,OAAQ,UAAW,QAAS,MAAO,UAAU1P,SAAQ,SAAUuL,QACrEmE,UAAM3T,UAAUwP,OAAOU,eAAiB,SAAUT,IAAK7L,IACrD,IAAI6K,IAAM,IAAIC,QAAQgH,QAAQlG,OAAQC,KAQtC,OANAjR,KAAK8W,aAAa7G,KAEd7K,IACF6K,IAAIiB,IAAI9L,IAGH6K,QAGXkF,UAAM3T,UAAU6X,IAAMlE,UAAM3T,UAAUua,OAWtC7L,QAAQjD,IAAM,SAAUgE,IAAKmC,KAAMhO,IACjC,IAAI6K,IAAMC,QAAQ,MAAOe,KASzB,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAI4D,MAAMT,MAChBhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,KAaTC,QAAQ8L,KAAO,SAAU/K,IAAKmC,KAAMhO,IAClC,IAAI6K,IAAMC,QAAQ,OAAQe,KAS1B,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAI4D,MAAMT,MAChBhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,KAaTC,QAAQhO,QAAU,SAAU+O,IAAKmC,KAAMhO,IACrC,IAAI6K,IAAMC,QAAQ,UAAWe,KAS7B,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAIqD,KAAKF,MACfhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,KA0BTC,QAAQmJ,IAAMA,IACdnJ,QAAQ6L,OAAS1C,IAWjBnJ,QAAQ+L,MAAQ,SAAUhL,IAAKmC,KAAMhO,IACnC,IAAI6K,IAAMC,QAAQ,QAASe,KAS3B,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAIqD,KAAKF,MACfhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,KAaTC,QAAQgM,KAAO,SAAUjL,IAAKmC,KAAMhO,IAClC,IAAI6K,IAAMC,QAAQ,OAAQe,KAS1B,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAIqD,KAAKF,MACfhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,KAaTC,QAAQiM,IAAM,SAAUlL,IAAKmC,KAAMhO,IACjC,IAAI6K,IAAMC,QAAQ,MAAOe,KASzB,MAPoB,mBAATmC,OACThO,GAAKgO,KACLA,KAAO,MAGLA,MAAMnD,IAAIqD,KAAKF,MACfhO,IAAI6K,IAAIiB,IAAI9L,IACT6K,qCDh9BT,SAAqBmM,KACnB,IAAIC,KAAOC,QAAQF,KACfG,SAAWF,KAAK,GAChBG,gBAAkBH,KAAK,GAC3B,OAAuC,GAA9BE,SAAWC,iBAAuB,EAAKA,gCAOlD,SAAsBJ,KACpB,IAAI7O,IAcA7M,EAbA2b,KAAOC,QAAQF,KACfG,SAAWF,KAAK,GAChBG,gBAAkBH,KAAK,GAEvB5V,IAAM,IAAIgW,IAVhB,SAAsBL,IAAKG,SAAUC,iBACnC,OAAuC,GAA9BD,SAAWC,iBAAuB,EAAKA,gBAS9BE,CAAYN,EAAKG,SAAUC,kBAEzCG,QAAU,EAGVzQ,IAAMsQ,gBAAkB,EACxBD,SAAW,EACXA,SAGJ,IAAK7b,EAAI,EAAGA,EAAIwL,IAAKxL,GAAK,EACxB6M,IACGqP,UAAUR,IAAItX,WAAWpE,KAAO,GAChCkc,UAAUR,IAAItX,WAAWpE,EAAI,KAAO,GACpCkc,UAAUR,IAAItX,WAAWpE,EAAI,KAAO,EACrCkc,UAAUR,IAAItX,WAAWpE,EAAI,IAC/B+F,IAAIkW,WAAcpP,KAAO,GAAM,IAC/B9G,IAAIkW,WAAcpP,KAAO,EAAK,IAC9B9G,IAAIkW,WAAmB,IAANpP,IAGK,IAApBiP,kBACFjP,IACGqP,UAAUR,IAAItX,WAAWpE,KAAO,EAChCkc,UAAUR,IAAItX,WAAWpE,EAAI,KAAO,EACvC+F,IAAIkW,WAAmB,IAANpP,KAGK,IAApBiP,kBACFjP,IACGqP,UAAUR,IAAItX,WAAWpE,KAAO,GAChCkc,UAAUR,IAAItX,WAAWpE,EAAI,KAAO,EACpCkc,UAAUR,IAAItX,WAAWpE,EAAI,KAAO,EACvC+F,IAAIkW,WAAcpP,KAAO,EAAK,IAC9B9G,IAAIkW,WAAmB,IAANpP,KAGnB,OAAO9G,qBAuBT,SAAwBoW,OAQtB,IAPA,IAAItP,IACArB,IAAM2Q,MAAMzc,OACZ0c,WAAa5Q,IAAM,EACnBnL,MAAQ,GAIHL,EAAI,EAAGqc,KAAO7Q,IAAM4Q,WAAYpc,EAAIqc,KAAMrc,GAH9B,MAInBK,MAAMH,KAAKoc,YACTH,MAAOnc,EAAIA,EALM,MAKgBqc,KAAOA,KAAQrc,EAL/B,QAUF,IAAfoc,YACFvP,IAAMsP,MAAM3Q,IAAM,GAClBnL,MAAMH,KACJqc,OAAO1P,KAAO,GACd0P,OAAQ1P,KAAO,EAAK,IACpB,OAEsB,IAAfuP,aACTvP,KAAOsP,MAAM3Q,IAAM,IAAM,GAAK2Q,MAAM3Q,IAAM,GAC1CnL,MAAMH,KACJqc,OAAO1P,KAAO,IACd0P,OAAQ1P,KAAO,EAAK,IACpB0P,OAAQ1P,KAAO,EAAK,IACpB,MAIJ,OAAOxM,MAAMD,KAAK,KAhJhBmc,OAAS,GACTL,UAAY,GACZH,IAA4B,oBAAfS,WAA6BA,WAAavb,MAEvDkO,KAAO,mEACFnP,EAAI,EAAGwL,IAAM2D,KAAKzP,OAAQM,EAAIwL,MAAOxL,EAC5Cuc,OAAOvc,GAAKmP,KAAKnP,GACjBkc,UAAU/M,KAAK/K,WAAWpE,IAAMA,EAQlC,SAAS4b,QAASF,KAChB,IAAIlQ,IAAMkQ,IAAIhc,OAEd,GAAI8L,IAAM,EAAI,EACZ,MAAM,IAAI6E,MAAM,kDAKlB,IAAIwL,SAAWH,IAAI3Y,QAAQ,KAO3B,OANkB,IAAd8Y,WAAiBA,SAAWrQ,KAMzB,CAACqQ,SAJcA,WAAarQ,IAC/B,EACA,EAAKqQ,SAAW,GAsEtB,SAASS,YAAaH,MAAOM,MAAOjM,KAGlC,IAFA,IAAI3D,IARoB6P,IASpBC,OAAS,GACJ3c,EAAIyc,MAAOzc,EAAIwQ,IAAKxQ,GAAK,EAChC6M,KACIsP,MAAMnc,IAAM,GAAM,WAClBmc,MAAMnc,EAAI,IAAM,EAAK,QACP,IAAfmc,MAAMnc,EAAI,IACb2c,OAAOzc,KAdFqc,QADiBG,IAeM7P,MAdT,GAAK,IACxB0P,OAAOG,KAAO,GAAK,IACnBH,OAAOG,KAAO,EAAI,IAClBH,OAAa,GAANG,MAaT,OAAOC,OAAOvc,KAAK,IAjGrB8b,UAAU,IAAI9X,WAAW,IAAM,GAC/B8X,UAAU,IAAI9X,WAAW,IAAM,kGEyB/B,cAAe,CACbV,OAhBF,SAAgBvD,KACd,OAAOyc,SACJC,cAlBL,SAA2B1c,KAEzB,IADA,IAAI4F,IAAM,IAAI9E,MAAMd,IAAIT,QACfyC,EAAI,EAAGA,EAAIhC,IAAIT,OAAQyC,IAC9B4D,IAAI5D,GAAKhC,IAAIiE,WAAWjC,GAE1B,OAAO4D,IAaU+W,CAAkB3c,MAChCJ,QAAQ,MAAO,KACfA,QAAQ,MAAO,MAalBoD,OAVF,SAAgBhD,KAKd,OAJAA,IAnCF,SAAiBA,KACf,IAAI4c,IAAM5c,IAAIT,OAAS,EAGvB,OAAY,IAARqd,IACK5c,IAGFA,IAAM,IAAIc,MAAM,GANb,EAAI8b,MAMkB3c,KAAK,KA2B/B4c,CAAQ7c,KACXJ,QAAQ,KAAM,KACdA,QAAQ,KAAM,KAlBnB,SAA2BoB,OAEzB,IADA,IAAI8b,OAAS,GACJjd,EAAI,EAAGA,EAAImB,MAAMzB,OAAQM,IAChCid,QAAUnZ,OAAOwE,aAAanH,MAAMnB,IAEtC,OAAOid,OAeAC,CAAkBN,SAAOO,YAAYhd,gBCzC7B,CAAEid,IAAK,UCApBhc,SAAWP,OAAOC,UAAUM,SAEhC,SAASic,UAAU5a,EAAG6a,KAAMtL,KAAM6F,MAEhC,GADA7F,KAAgB,UAATA,KAAmB,SAAWA,KACjCvP,UAAYA,EAAE6a,QAAUtL,KAC1B,MAAM,IAAI3B,MAAMwH,MAIpB,SAAS0F,SAAS9a,EAAGuP,KAAM6F,MACzB,UAAWpV,IAAMuP,KACf,MAAM,IAAI3B,MAAMwH,MAIpB,SAAStV,MAAME,EAAGoF,OAAQgQ,MACxB,IAA2B,IAAvBhQ,OAAO9E,QAAQN,GACjB,MAAM,IAAI4N,MAAMwH,MA4CpB,WAAe,CACb2F,MAzCF,SAAe/a,EAAGgb,OAAQC,YAIxB,GAHKD,OAAOE,WAAYlb,GACtB8a,SAAS9a,EAAGgb,OAAOzL,KAAMyL,OAAOG,SAEd,WAAhBH,OAAOzL,MAAqB0L,WAG9B,IAFA,IAAI5b,KAAOjB,OAAOiB,KAAK4b,YAEd3U,MAAQ,EAAGA,MAAQjH,KAAKpC,OAAQqJ,QAAS,CAChD,IAAI5G,EAAIL,KAAKiH,OACR2U,WAAWvb,GAAGwb,WAAYlb,EAAEN,IAC1Bub,WAAWvb,GAAG0b,YAAaH,WAAWvb,GAAG0b,UAAUpb,KACtD4a,UAAU5a,EAAGN,EAAGub,WAAWvb,GAAG6P,KAAM0L,WAAWvb,GAAGyb,SAC9CF,WAAWvb,GAAG0F,QAChBtF,MAAME,EAAEN,GAAIub,WAAWvb,GAAG0F,OAAQ6V,WAAWvb,GAAG2b,kBA6B1DT,UAAWA,UACXE,SAAUA,SACVhb,MAAOA,MACPvB,QAjBF,SAAiBG,OACf,OAAI7B,KAAKye,kBACA9c,MAAMD,QAAQG,OAGS,mBAAzBC,SAASX,KAAKU,QAarB4c,gBAVF,WACE,OAAwB,MAAjB9c,MAAMD,UChDf,SAASgd,qBAAqBnc,QAC5B,GAAIA,MAAAA,OACF,MAAM,IAAIlC,UAAU,2CAItB,IADA,IAAIse,GAAKpd,OAAOgB,QACP7B,EAAI,EAAGA,EAAIO,UAAUb,OAAQM,IAAK,CACzC,IAAIke,WAAa3d,UAAUP,GAC3B,GAAIke,MAAAA,WAKJ,IADA,IAAIC,UAAYtd,OAAOiB,KAAKjB,OAAOqd,aAE7BE,UAAY,EAAG5S,IAAM2S,UAAUze,OACnC0e,UAAY5S,IACZ4S,YACA,CACA,IAAIC,QAAUF,UAAUC,WACpBE,KAAOzd,OAAOyL,yBAAyB4R,WAAYG,cAC1C7U,IAAT8U,MAAsBA,KAAKC,aAC7BN,GAAGI,SAAWH,WAAWG,WAI/B,OAAOJ,GAGT,iBAAe,CACb1R,IArCF,WACE,OAAK1L,OAAOe,OAILf,OAAOe,OAHLoc,sBAoCTA,qBAAsBA,sBCjCxB,SAASQ,KAAKlX,OAAQxF,MACpB,OAAOA,KAAKC,QAAO,SAAS0c,KAAMxc,KAIhC,OAHIqF,OAAOrF,OACTwc,KAAKxc,KAAOqF,OAAOrF,MAEdwc,OACN,IAaL,SAASC,aAAajd,KACpB,IAAIoG,OAAS,GACb,IAAK,IAAI5F,OAAOR,IACdoG,OAAO3H,KAAKuB,IAAIQ,MAElB,OAAO4F,OAGT,SAAS8W,SACP,IAAI9J,OAAS6J,aAAane,WAE1B,OADAsU,OAAO+J,QAAQ,IACRC,aAAatS,MAAMtG,WAAMuD,EAAWqL,QAuF7C,SAASiK,mBAAmBC,MAC1B,IAAInf,MAAQmf,KAAKnf,MACf,qGAEF,OACEA,OAAS,CACPmf,KAAMA,KACNnI,SAAUhX,MAAM,GAChBof,KAAMpf,MAAM,GACZqf,SAAUrf,MAAM,GAChBsf,KAAMtf,MAAM,GACZuf,SAAUvf,MAAM,GAChBwf,OAAQxf,MAAM,GACdyf,KAAMzf,MAAM,IAoBlB,SAASqX,KAAKzV,QAASS,KACrB,IAAIqd,QAAUX,OAAOnd,SAIrB,OAHIA,QAAQS,OACVqd,QAAQrd,KAAOT,QAAQS,KAAKgV,QAEvBqI,QAiCT,iBAAe,CACbC,YAxGF,SAASA,YAAYjY,OAAQkY,YAC3B,MAAsB,iBAAXlY,QAAuBmY,OAAOze,QAAQsG,SAAsB,OAAXA,OACnDA,QAETkY,WAAaA,YAAc,GAEpB3e,OAAOiB,KAAKwF,QAAQvF,QAAO,SAAS2d,EAAGzd,KAG5C,OADAyd,GAD0C,IAA7BF,WAAWzc,QAAQd,KAxCpC,SAAsB9B,KAOpB,IANA,IAEIgP,KAFAwQ,OAAS,GACT5W,MAAQ,EAER6W,eAAgB,EAChBC,kBAAmB,EAEhB9W,MAAQ5I,IAAIT,QACjByP,KAAOhP,IAAIiE,WAAW2E,QAElB8W,kBAAoB1Q,MAAQ,IAAMA,MAAQ,KAC1CyQ,eAAiBzQ,MAAQ,IAAMA,MAAQ,IAEzCwQ,QAAU,IACVA,QAAUxf,IAAI4I,OAAOiI,eAErB2O,QAAUxf,IAAI4I,OAAOiI,cAEvB4O,cAAgBzQ,MAAQ,IAAMA,MAAQ,GACtC0Q,iBAAmB1Q,MAAQ,IAAMA,MAAQ,GACzCpG,QAGF,OAAO4W,OAiByCG,CAAa7d,KAAOA,KACtDsd,YAAYjY,OAAOrF,MACxByd,IACN,MA+FHK,YA5FF,SAASA,YAAYzY,OAAQkY,WAAYhe,SACvC,MAAsB,iBAAX8F,QAAuBmY,OAAOze,QAAQsG,SAAsB,OAAXA,OACnDA,QAGTkY,WAAaA,YAAc,GAC3Bhe,QAAUA,SAAW,GACdX,OAAOiB,KAAKwF,QAAQvF,QAAO,SAAS2d,EAAGzd,KAC5C,IA3BE5B,MA2BEsf,QAAsC,IAA7BH,WAAWzc,QAAQd,MA3B9B5B,MA2ByD4B,IA3B7C3B,MAAM,MACTyB,QAAO,SAAS2d,EAAGvb,GAC9B,OAAOub,EAAIvb,EAAEE,OAAO,GAAGhD,cAAgB8C,EAAE3D,MAAM,KAC9CH,MAAMP,SAwB2DmC,IAOlE,OALAyd,EAAEC,QAAUI,YAAYzY,OAAOqY,SAAWrY,OAAOrF,KAAM,GAAIT,SAEvDA,QAAQwe,eACVN,EAAEzd,KAAO8d,YAAYzY,OAAOrF,KAAM,GAAIT,UAEjCke,IACN,MA6EHO,UApJF,SAAmB3Y,OAAQ4Y,iBACzB,OAAOrf,OAAOiB,KAAKwF,QAAQvF,QAAO,SAAS2d,EAAGzd,KAI5C,OAHsC,IAAlCie,gBAAgBnd,QAAQd,OAC1Byd,EAAEzd,KAAOqF,OAAOrF,MAEXyd,IACN,KA+IH9a,MA/JF,SAAe0C,OAAQxF,MACrB,MAAO,CACLqe,KAAMre,KAAO0c,KAAKlX,OAAQxF,MAAQwF,OAClC8Y,KAAM,SAASC,QAASC,OAEtB,OADAD,QAAUC,MAAQ9B,KAAK6B,QAASC,OAASD,QAClC1B,OAAOrf,KAAK6gB,KAAME,YA2J7B7B,KAAMA,KACN+B,aAzLF,SAAsB9e,IAAK+e,aACzB,IAAIC,WAAa,GACjB,IAAK,IAAIxe,OAAOR,KACoB,IAA9B+e,YAAYzd,QAAQd,MACtBwe,WAAWvgB,KAAK+B,KAGpB,OAAOwe,YAmLP9B,OAAQA,OACR+B,iBA7DF,SAA0BnQ,KACxB,GAAKA,IAAL,CAGA,IAAIoQ,OAAS7B,mBAAmBvO,KAChC,IAAKoQ,OACH,OAAO,KAET,IAAIC,OAASD,OAAO/J,SAAW,KAAO+J,OAAO1B,SAI7C,OAHI0B,OAAOzB,OACT0B,QAAU,IAAMD,OAAOzB,MAElB0B,SAkDP9B,mBAAoBA,mBACpB+B,gBApCF,SAAyBrf,SACvB,OALF,SAAsBA,QAASM,MAC7B,OAAOA,KAAKC,OAAOkV,KAAMzV,SAIlBsf,CAAatf,QAAS,CAAC,WAAY,QAAS,iBAoCnDuf,iBA3BF,SAASA,iBAAiBtf,IAAKuf,KAAMze,OACf,iBAATye,OACTA,KAAOA,KAAK1gB,MAAM,MAGpB,IAAI2gB,KAAOD,KAAK,GAEZvf,IAAIV,eAAekgB,QACD,IAAhBD,KAAKthB,OACP+B,IAAIwf,MAAQ1e,MAEZwe,iBAAiBtf,IAAIwf,MAAOD,KAAKxgB,MAAM,GAAI+B,UCtLjD,SAAS2e,eAAe3R,KACtBjQ,KAAKkQ,QAAUD,IACfjQ,KAAKgR,OAASf,IAAIe,OAClBhR,KAAKiR,IAAMhB,IAAIgB,IACfjR,KAAKgZ,KAAO/I,IAAIgC,MAChBjS,KAAKqT,QAAUpD,IAAIwB,QAyBrB,SAASoQ,WAAW5R,KAClBjQ,KAAKkQ,QAAUD,IAyBjB,SAAS6R,eAAe5f,SACtBlC,KAAK+hB,gBACwB,IAA3B7f,QAAQ6f,gBAA2B7f,QAAQ6f,eAC7C/hB,KAAKgiB,eAAiB9f,QAAQ8f,gBAAkB,KAChDhiB,KAAKiiB,4BAA8B/f,QAAQ+f,4BAC3CjiB,KAAKqT,QAAUnR,QAAQmR,SAAW,GAClCrT,KAAKkiB,oBAAsBhgB,QAAQigB,mBC5DrC,SAASC,YACP,OAAOnL,ODKT2K,eAAepgB,UAAU4Q,MAAQ,WAC/BpS,KAAKkQ,QAAQkC,SAGfwP,eAAepgB,UAAU6gB,UAAY,WACnC,OAAOriB,KAAKgR,QAGd4Q,eAAepgB,UAAU8gB,QAAU,WACjC,OAAOtiB,KAAKgZ,MAGd4I,eAAepgB,UAAU+gB,OAAS,WAChC,OAAOviB,KAAKiR,KAGd2Q,eAAepgB,UAAUghB,WAAa,WACpC,OAAOxiB,KAAKqT,SASdwO,WAAWrgB,UAAUoQ,IAAM,SAASjP,IAAKM,OAEvC,OADAjD,KAAKkQ,QAAUlQ,KAAKkQ,QAAQ0B,IAAIjP,IAAKM,OAC9BjD,MAGT6hB,WAAWrgB,UAAU8R,KAAO,SAAS0F,MAEnC,OADAhZ,KAAKkQ,QAAUlQ,KAAKkQ,QAAQoD,KAAKmP,aAAalB,gBAAgBvI,OACvDhZ,MAGT6hB,WAAWrgB,UAAUqR,gBAAkB,WAErC,OADA7S,KAAKkQ,QAAUlQ,KAAKkQ,QAAQ2C,kBACrB7S,MAGT6hB,WAAWrgB,UAAU0P,IAAM,SAASrF,IAElC,OADA7L,KAAKkQ,QAAQgB,IAAIrF,IACV,IAAI+V,eAAe5hB,KAAKkQ,UAcjC4R,eAAetgB,UAAUkhB,uBAAyB,SAChDC,eACAzgB,SAQA,GANAA,QAAUA,SAAW,GAEjBlC,KAAKiiB,4BAA8B,IACrCU,eAAiBA,eAAe1T,MAAMjP,KAAKiiB,8BAGzC/f,QAAQ0gB,UACV,OAAOD,eAGT,IAAItP,QAAUrT,KAAKqT,QACnBsP,eAAiBA,eAAe/Q,IAAI,eAAgB,oBAIpD,IAFA,IAAIpP,KAAOjB,OAAOiB,KAAKxC,KAAKqT,SAEnBxQ,EAAI,EAAGA,EAAIL,KAAKpC,OAAQyC,IAC/B8f,eAAiBA,eAAe/Q,IAAIpP,KAAKK,GAAIwQ,QAAQ7Q,KAAKK,KAU5D,OAPI7C,KAAK+hB,iBACPY,eAAiBA,eAAe/Q,IAC9B,eACA5R,KAAK6iB,qBAIFF,gBAGTb,eAAetgB,UAAUqhB,iBAAmB,WAC1C,IAAIC,cAAgB9iB,KAAKkiB,oBAAsB,eAAiB,WAC5Da,WAAa,CAAE/Q,KAAM8Q,cAAeE,QAASA,QAAQlF,KACrD9d,KAAKgiB,kBACPe,WAAaN,aAAapD,OAAO,GAAIrf,KAAKgiB,iBAC/BiB,IAAMR,aAAapD,OAAO,GAAIrf,KAAKgiB,eAAeiB,KAC7DF,WAAWE,IAAIH,eAAiBE,QAAQlF,KAE1C,IAAIoF,eAAiB9V,KAAKrF,UAAUgb,YACpC,OAAOI,UAAU/e,OAAO8e,iBAG1BpB,eAAetgB,UAAUyL,IAAM,SAASgE,IAAK/O,SAC3C,OAAO,IAAI2f,WAAW7hB,KAAK0iB,uBAAuBxS,OAAQjD,IAAIgE,KAAM/O,WAGtE4f,eAAetgB,UAAU0a,KAAO,SAASjL,IAAK/O,SAC5C,OAAO,IAAI2f,WACT7hB,KAAK0iB,uBAAuBxS,OAAQgM,KAAKjL,KAAM/O,WAInD4f,eAAetgB,UAAUya,MAAQ,SAAShL,IAAK/O,SAC7C,OAAO,IAAI2f,WACT7hB,KAAK0iB,uBAAuBxS,OAAQ+L,MAAMhL,KAAM/O,WCzGpD,iBAAe,CACb6T,SAxBF,SAAkB9E,KAChBmR,YAAY/K,SAAWpG,KAwBvBmS,YArBF,WACE,OAAOhB,YAAYiB,UAqBnBjB,UAAWA,UACXkB,UAfF,WACE,IAAIjM,SAAW+K,YAAY/K,SACvBiK,OAASjK,SAASiK,OAMtB,OAJKA,SACHA,OAASmB,aAAarB,iBAAiB/J,SAASoI,OAG3C6B,SCtBT,SAASiC,gBAETA,aAAa/hB,UAAUgiB,QAAU,WAC/B,OAAO,MAGTD,aAAa/hB,UAAUiiB,WAAa,aAEpCF,aAAa/hB,UAAUkiB,QAAU,0ECD/B,IAAUC,QAAAA,QAkBV,WACD,SAAStE,SAGR,IAFA,IAAI3e,EAAI,EACJid,OAAS,GACNjd,EAAIO,UAAUb,OAAQM,IAAK,CACjC,IAAI0d,WAAand,UAAWP,GAC5B,IAAK,IAAIiC,OAAOyb,WACfT,OAAOhb,KAAOyb,WAAWzb,KAG3B,OAAOgb,OAGR,SAAS9Z,OAAQ+T,GAChB,OAAOA,EAAEnX,QAAQ,mBAAoByD,oBA0HtC,OAvHA,SAAS0f,KAAMC,WACd,SAASC,OAET,SAASlS,IAAKjP,IAAKM,MAAOmb,YACzB,GAAwB,oBAAbiF,SAAX,CAQkC,iBAJlCjF,WAAaiB,OAAO,CACnBqC,KAAM,KACJoC,IAAI7c,SAAUmX,aAEK2F,UACrB3F,WAAW2F,QAAU,IAAIld,KAAkB,EAAb,IAAIA,KAAkC,MAArBuX,WAAW2F,UAI3D3F,WAAW2F,QAAU3F,WAAW2F,QAAU3F,WAAW2F,QAAQC,cAAgB,GAE7E,IACC,IAAIrG,OAASvQ,KAAKrF,UAAU9E,OACxB,UAAU8R,KAAK4I,UAClB1a,MAAQ0a,QAER,MAAOxZ,IAETlB,MAAQ4gB,UAAU/I,MACjB+I,UAAU/I,MAAM7X,MAAON,KACvBsV,mBAAmBzT,OAAOvB,QACxBxC,QAAQ,4DAA6DyD,oBAExEvB,IAAMsV,mBAAmBzT,OAAO7B,MAC9BlC,QAAQ,2BAA4ByD,oBACpCzD,QAAQ,UAAWgE,QAErB,IAAIwf,sBAAwB,GAC5B,IAAK,IAAIC,iBAAiB9F,WACpBA,WAAW8F,iBAGhBD,uBAAyB,KAAOC,eACE,IAA9B9F,WAAW8F,iBAWfD,uBAAyB,IAAM7F,WAAW8F,eAAeljB,MAAM,KAAK,KAGrE,OAAQqiB,SAASc,OAASxhB,IAAM,IAAMM,MAAQghB,uBAG/C,SAAShX,IAAKtK,IAAK8W,MAClB,GAAwB,oBAAb4J,SAAX,CAUA,IANA,IAAIe,IAAM,GAGNC,QAAUhB,SAASc,OAASd,SAASc,OAAOnjB,MAAM,MAAQ,GAC1DN,EAAI,EAEDA,EAAI2jB,QAAQjkB,OAAQM,IAAK,CAC/B,IAAIK,MAAQsjB,QAAQ3jB,GAAGM,MAAM,KACzBmjB,OAASpjB,MAAMG,MAAM,GAAGJ,KAAK,KAE5B2Y,MAA6B,MAArB0K,OAAOpf,OAAO,KAC1Bof,OAASA,OAAOjjB,MAAM,GAAI,IAG3B,IACC,IAAI8Q,KAAOnO,OAAO9C,MAAM,IAIxB,GAHAojB,QAAUN,UAAUS,MAAQT,WAAWM,OAAQnS,OAC9CnO,OAAOsgB,QAEJ1K,KACH,IACC0K,OAAS/W,KAAKa,MAAMkW,QACnB,MAAOhgB,IAKV,GAFAigB,IAAIpS,MAAQmS,OAERxhB,MAAQqP,KACX,MAEA,MAAO7N,KAGV,OAAOxB,IAAMyhB,IAAIzhB,KAAOyhB,KAoBzB,OAjBAN,IAAIlS,IAAMA,IACVkS,IAAI7W,IAAM,SAAUtK,KACnB,OAAOsK,IAAItK,KAAK,IAEjBmhB,IAAIS,QAAU,SAAU5hB,KACvB,OAAOsK,IAAItK,KAAK,IAEjBmhB,IAAIU,OAAS,SAAU7hB,IAAKyb,YAC3BxM,IAAIjP,IAAK,GAAI0c,OAAOjB,WAAY,CAC/B2F,SAAU,MAIZD,IAAI7c,SAAW,GAEf6c,IAAIW,cAAgBb,KAEbE,IAGDF,EAAK,gBAnJXxiB,eAAiBuiB,aCZnB,SAASe,iBCAT,SAASC,KAAKziB,SACZlC,KAAK4kB,gBAAkB1iB,QAAQ0iB,gBCEjC,SAASC,eAAe3iB,SAGtB,GAFAlC,KAAKgP,KAAO,IAAI2V,KAAK,IACrB3kB,KAAK8kB,QAAU,IAAIJ,eACoB,IAAnCxiB,QAAQ6iB,uBAGZ,IAGE,IAAIC,aAAeC,aAAc7C,YAAY4C,aACzCA,eACFhlB,KAAK8kB,QAAUE,cAEjB,MAAO7gB,GACPnE,KAAKgP,KAAKkW,QAAQ/gB,GAClBnE,KAAKgP,KAAKkW,QAAQ,yDClBtB,SAASC,QAAQjjB,SACflC,KAAKolB,QAAU,IAAIP,eAAe3iB,SCDpC,SAASmjB,eAAenjB,SACtBlC,KAAK8kB,QAAU,IAAIK,QAAQjjB,SCH7B,SAASojB,cAAc3V,MAAO4V,aAC5B,MAAO,CACL5V,MAAOA,MACP6V,iBAAkBD,aLCtBb,cAAcljB,UAAUgiB,QAAU,SAAS7gB,KACzC,OAAO8iB,UAAOxY,IAAItK,MAGpB+hB,cAAcljB,UAAUiiB,WAAa,SAAS9gB,KAC5C8iB,UAAOjB,OAAO7hB,MAGhB+hB,cAAcljB,UAAUkiB,QAAU,SAAS/gB,IAAKM,MAAOf,SACrD,IAAIqT,OAASkN,aAAapD,OACxB,CACE0E,QAAS,GAEX7hB,SAEFujB,UAAO7T,IAAIjP,IAAKM,MAAOsS,SCbzBoP,KAAKnjB,UAAU0jB,QAAU,SAAS5G,SAC5Bte,KAAK4kB,iBAIT7V,QAAQC,KAAKsP,UCafuG,eAAerjB,UAAUkkB,SAAW,WAC9B1lB,KAAK8kB,mBAAmBvB,aAC1BvjB,KAAKgP,KAAKkW,QAAQ,iCAETllB,KAAK8kB,mBAAmBJ,eACjC1kB,KAAKgP,KAAKkW,QAAQ,4CAClBllB,KAAK8kB,QAAU,IAAIvB,eAEnBvjB,KAAKgP,KAAKkW,QAAQ,4CAClBllB,KAAK8kB,QAAU,IAAIJ,gBAIvBG,eAAerjB,UAAUgiB,QAAU,SAAS7gB,KAC1C,IACE,OAAO3C,KAAK8kB,QAAQtB,QAAQ7gB,KAC5B,MAAOwB,GAGP,OAFAnE,KAAKgP,KAAKkW,QAAQ/gB,GAClBnE,KAAK0lB,WACE1lB,KAAKwjB,QAAQ7gB,OAIxBkiB,eAAerjB,UAAUiiB,WAAa,SAAS9gB,KAC7C,IACE,OAAO3C,KAAK8kB,QAAQrB,WAAW9gB,KAC/B,MAAOwB,GAGP,OAFAnE,KAAKgP,KAAKkW,QAAQ/gB,GAClBnE,KAAK0lB,WACE1lB,KAAKyjB,WAAW9gB,OAI3BkiB,eAAerjB,UAAUkiB,QAAU,SAAS/gB,IAAKM,MAAOf,SACtD,IACE,OAAOlC,KAAK8kB,QAAQpB,QAAQ/gB,IAAKM,MAAOf,SACxC,MAAOiC,GAGP,OAFAnE,KAAKgP,KAAKkW,QAAQ/gB,GAClBnE,KAAK0lB,WACE1lB,KAAK0jB,QAAQ/gB,IAAKM,MAAOf,WCzDpCijB,QAAQ3jB,UAAUgiB,QAAU,SAAS7gB,KACnC,IAAIM,MAAQjD,KAAKolB,QAAQ5B,QAAQ7gB,KACjC,IACE,OAAOyK,KAAKa,MAAMhL,OAClB,MAAO0iB,GACP,OAAO1iB,QAGXkiB,QAAQ3jB,UAAUiiB,WAAa,SAAS9gB,KACtC,OAAO3C,KAAKolB,QAAQ3B,WAAW9gB,MAEjCwiB,QAAQ3jB,UAAUkiB,QAAU,SAAS/gB,IAAKM,MAAOf,SAC/C,IAAIuX,KAAOrM,KAAKrF,UAAU9E,OAC1B,OAAOjD,KAAKolB,QAAQ1B,QAAQ/gB,IAAK8W,KAAMvX,UCbzCmjB,eAAe7jB,UAAUoQ,IAAM,SAASgU,WAAYC,KAClD,IAAIC,QAAU,CACZC,mBAAoBH,WACpBI,YAAaH,KAEf7lB,KAAK8kB,QAAQpB,QAAQ,gBAAiBtW,KAAKrF,UAAU+d,WAEvDT,eAAe7jB,UAAUyL,IAAM,WAC7B,IAAI6Y,QAAU9lB,KAAK8kB,QAAQtB,QAAQ,iBACnC,GAAKsC,QAGL,OAAO1Y,KAAKa,MAAM6X,UCPpB,UAAe,CACbR,cAAeA,cACfW,aANF,SAAsBV,aACpB,OAAOD,cAAc,gBAAiBC,eCLxC,SAASW,aAAara,GAAI3J,SAIxB,OAHAA,QAAUA,SAAW,IACbikB,eAAejkB,QAAQikB,cAAejkB,QAAQikB,aAE/C,SAAS3W,IAAK4D,MACnB,IAAIgT,OAEJ,OAAK5W,KAAQ4D,OAIR5D,KAAO4D,KAAK5D,MACfA,IAAM4D,KAAK5D,IACX4D,KAAO,OAGJ5D,KAAO4D,KAAKzD,QACfH,IAAM4D,KACNA,KAAO,MAGL5D,KACF4W,OAAS,CACPjN,SAAU3J,KAGZiT,aAAahB,iBACX2E,OACA,uCACA,SAGE5W,IAAIX,UAAYW,IAAIX,SAAS+G,aAC/BwQ,OAAOxQ,WAAapG,IAAIX,SAAS+G,YAG/BpG,IAAIX,UAAYW,IAAIX,SAAS4J,aAC/B2N,OAAO3N,WAAajJ,IAAIX,SAAS4J,YAG/BjJ,IAAIX,UAAYW,IAAIX,SAASmK,OAC/BxJ,IAAMA,IAAIX,SAASmK,MAGjBxJ,IAAIA,MACNA,IAAMA,IAAIA,KAGZ4W,OAAOvW,KACLL,IAAIK,MAAQL,IAAIG,OAASH,IAAI6W,YAAc7W,IAAII,QAAU,KAE3DwW,OAAOb,YACL/V,IAAIgW,kBACJhW,IAAI8W,mBACJ9W,IAAI+V,aACJ/V,IAAIG,OACJH,IAAI+W,SACJ/W,IAAIA,KACJ,KAEEtN,QAAQskB,mBACVJ,OAAOzW,MAAQyW,OAAOvW,KACtBuW,OAAOE,kBAAoBF,OAAOb,aAGhC/V,IAAIiX,aAAejX,IAAIkX,gBACzBN,OAAOO,aAAe,CACpBC,MAAOpX,IAAIiX,YACXF,QAAS/W,IAAIkX,gBAIblX,IAAIwC,OACNoU,OAAOpU,KAAOxC,IAAIwC,MAGhBxC,IAAIqX,SACNT,OAAOS,OAASrX,IAAIqX,QAGfhb,GAAGua,UAIVhT,KAAKV,MACU,cAAdU,KAAKV,MAAsC,eAAdU,KAAKV,KAKjCxQ,QAAQikB,aACHta,GAAG,KAAMuH,KAAK4F,MAAQ5F,MAGxBvH,GACL,KACA4W,aAAahC,YAAYrN,KAAK4F,MAAQ5F,KAAM,GAAI,CAC9CsN,aAAcxe,QAAQ4kB,sBAVjBjb,GAAG,KAAMuH,KAAKmF,OA/Ed1M,GAAG8D,MAAM2V,cAAc,gBAAiB,0BCJrD,IAAIyB,YAAc,CAEhB,QACA,WACA,MAEA,YACA,gBACA,eACA,QACA,OACA,aACA,WACA,WACA,gBACA,YACA,mBACA,wBACA,iBAGEC,gBAAkB,CAEpB,aACA,mBACA,cACA,MACA,SACA,QAEA,WACA,QACA,YACA,eAGA,YACA,gBACA,gBACA,eACA,WACA,QACA,QACA,QACA,UACA,SACA,cACA,UACA,aACA,iBACA,gBACA,aACA,aACA,SACA,eACA,UACA,cACA,iBACA,wBAIA,cACA,WAqBF,wBAAe,CACbC,iBALF,SAA0BjY,KAAMuG,QAC9B,OAAOkN,aAAavD,KAAK3J,OAAQwR,cAKjCG,qBApBF,SAA8BlY,KAAMuG,QAClC,IAAI4L,WAAasB,aAAaxB,aAAa1L,OAAQyR,iBAUnD,OARI7F,WAAW/gB,OAAS,GACtB4O,KAAKkW,QACH,uEACE/D,WAAWrgB,KAAK,KAChB,KAICyU,SCpFL4R,EAAE,oBAAoBC,WAAWA,WAAW,oBAAoBnQ,OAAOA,OAAO,oBAAoBoQ,OAAOA,OAAO,oBAAoBzW,KAAKA,KAAK,GAAG,SAASzM,EAAEgjB,EAAEhjB,EAAEmjB,GAAG,OAAOH,EAAEG,EAAE,CAAC5F,KAAKvd,EAAE9C,QAAQ,GAAGkmB,QAAQ,SAASJ,EAAEhjB,GAAG,OAAO,WAAW,MAAM,IAAI4M,MAAM,2EAA3B,KAA2GuW,EAAEjmB,SAASimB,EAAEjmB,QAAQ,IAAIimB,EAAEnjB,GAAE,SAASA,EAAEmjB,GAAGnjB,EAAE9C,QAAQ,WAAW,SAAS8C,EAAEgjB,GAAG,MAAM,mBAAmBA,EAAE,IAAIG,EAAE3lB,MAAMD,QAAQC,MAAMD,QAAQ,SAASylB,GAAG,MAAM,mBAAmB5lB,OAAOC,UAAUM,SAASX,KAAKgmB,IAAIzmB,EAAE,EAAEsS,OAAE,EAAO7P,OAAE,EAAOyU,EAAE,SAASuP,EAAEhjB,GAAGqjB,EAAE9mB,GAAGymB,EAAEK,EAAE9mB,EAAE,GAAGyD,EAAE,KAAKzD,GAAG,KAAKyC,EAAEA,EAAEskB,GAAGC,MAAMC,EAAE,oBAAoB1Q,OAAOA,YAAO,EAAOpU,EAAE8kB,GAAG,GAAGC,EAAE/kB,EAAEglB,kBAAkBhlB,EAAEilB,uBAAuBC,EAAE,oBAAoBnX,MAAM,oBAAoBoX,SAAS,qBAAqB,GAAGlmB,SAASX,KAAK6mB,SAASnjB,EAAE,oBAAoBojB,mBAAmB,oBAAoBC,eAAe,oBAAoBC,eAAe,SAAS/H,IAAI,IAAI+G,EAAE7S,WAAW,OAAO,WAAW,OAAO6S,EAAEM,EAAE,IAAI,IAAID,EAAE,IAAI7lB,MAAM,KAAK,SAAS8lB,IAAI,IAAI,IAAIN,EAAE,EAAEA,EAAEzmB,EAAEymB,GAAG,GAAE,EAAGK,EAAEL,IAAIK,EAAEL,EAAE,IAAIK,EAAEL,QAAG,EAAOK,EAAEL,EAAE,QAAG,EAAOzmB,EAAE,EAAE,IAAI0nB,EAAEhgB,EAAEigB,EAAEC,EAAEZ,OAAE,EAAO,SAASa,EAAEpB,EAAEhjB,GAAG,IAAImjB,EAAEtnB,KAAKU,EAAE,IAAIV,KAAKiF,YAAYujB,QAAG,IAAS9nB,EAAEilB,IAAI8C,EAAE/nB,GAAG,IAAIsS,EAAEsU,EAAEoB,OAAO,GAAG1V,EAAE,CAAC,IAAI7P,EAAElC,UAAU+R,EAAE,GAAG4E,GAAE,WAAW,OAAO+Q,EAAE3V,EAAEtS,EAAEyC,EAAEmkB,EAAEsB,iBAAgB/b,EAAEya,EAAE5mB,EAAEymB,EAAEhjB,GAAG,OAAOzD,EAAE,SAASoC,EAAEqkB,GAAG,GAAGA,GAAG,iBAAiBA,GAAGA,EAAEliB,cAAcjF,KAAK,OAAOmnB,EAAE,IAAIhjB,EAAE,IAAInE,KAAKwoB,GAAG,OAAOK,EAAE1kB,EAAEgjB,GAAGhjB,EAAE4jB,EAAEL,EAAE,WAAW,OAAOM,QAAQc,SAASrB,IAAIG,GAAGxf,EAAE,EAAEigB,EAAE,IAAIT,EAAEH,GAAGa,EAAEjF,SAAS0F,eAAe,IAAIV,EAAEW,QAAQV,EAAE,CAACW,eAAc,IAAKvB,EAAE,WAAWY,EAAElV,KAAKhL,IAAIA,EAAE,IAAIvD,IAAIujB,EAAE,IAAID,gBAAgBe,MAAMC,UAAU1B,EAAEC,EAAE,WAAW,OAAOU,EAAEgB,MAAMC,YAAY,KAAK3B,OAAE,IAASC,EAAE,WAAW,IAAI,IAAIR,EAAEmC,SAAS,cAATA,GAA0B/B,QAAQ,SAAS,YAAO,KAAUvU,EAAEmU,EAAEoC,WAAWpC,EAAEqC,cAAc,WAAWxW,EAAEyU,IAAIrH,IAAI,MAAM+G,GAAG,OAAO/G,KAArJ,GAA6JA,IAAI,IAAIuF,EAAE8D,KAAKC,SAAS5nB,SAAS,IAAI6nB,UAAU,GAAG,SAASnB,KAAK,SAASoB,EAAEzC,EAAEG,EAAE5mB,GAAG4mB,EAAEriB,cAAckiB,EAAEliB,aAAavE,IAAI6nB,GAAGjB,EAAEriB,YAAYuL,UAAU1N,EAAE,SAASqkB,EAAEhjB,GAAG,IAAIA,EAAEukB,OAAOmB,EAAE1C,EAAEhjB,EAAEykB,SAAS,IAAIzkB,EAAEukB,OAAOoB,EAAE3C,EAAEhjB,EAAEykB,SAAS/b,EAAE1I,OAAE,GAAO,SAASA,GAAG,OAAO0kB,EAAE1B,EAAEhjB,MAAI,SAASA,GAAG,OAAO2lB,EAAE3C,EAAEhjB,MAAnI,CAAyIgjB,EAAEG,QAAG,IAAS5mB,EAAEmpB,EAAE1C,EAAEG,GAAGnjB,EAAEzD,GAAG,SAASymB,EAAEhjB,EAAEmjB,GAAG1P,GAAE,SAASuP,GAAG,IAAIzmB,GAAE,EAAGsS,EAAE,SAASsU,EAAEtU,EAAE7P,EAAEyU,GAAG,IAAI0P,EAAEnmB,KAAK6R,GAAE,SAASsU,GAAG5mB,IAAIA,GAAE,EAAGyD,IAAImjB,EAAEuB,EAAE1B,EAAEG,GAAGuC,EAAE1C,EAAEG,OAAK,SAASnjB,GAAGzD,IAAIA,GAAE,EAAGopB,EAAE3C,EAAEhjB,OAAM,MAAMgjB,GAAG,OAAOA,GAAzH,CAA6HG,EAAEnjB,IAAIzD,GAAGsS,IAAItS,GAAE,EAAGopB,EAAE3C,EAAEnU,MAAKmU,GAAjM,CAAqMA,EAAEG,EAAE5mB,GAAGmpB,EAAE1C,EAAEG,GAAG,SAASuB,EAAE1B,EAAEhjB,GAAG,GAAGgjB,IAAIhjB,EAAE2lB,EAAE3C,EAAE,IAAI9mB,UAAU,kDAAkD,GAAG2S,SAAStS,EAAEyD,GAAG,OAAOzD,GAAG,WAAWsS,GAAG,aAAaA,EAAE6W,EAAE1C,EAAEhjB,OAAO,CAAC,IAAImjB,OAAE,EAAO,IAAIA,EAAEnjB,EAAEoM,KAAK,MAAMpM,GAAG,YAAY2lB,EAAE3C,EAAEhjB,GAAGylB,EAAEzC,EAAEhjB,EAAEmjB,GAAG,IAAI5mB,EAAEsS,EAAE,SAAS+W,EAAE5C,GAAGA,EAAE6C,UAAU7C,EAAE6C,SAAS7C,EAAEyB,SAASqB,EAAE9C,GAAG,SAAS0C,EAAE1C,EAAEhjB,QAAG,IAASgjB,EAAEuB,SAASvB,EAAEyB,QAAQzkB,EAAEgjB,EAAEuB,OAAO,EAAE,IAAIvB,EAAE+C,aAAa9pB,QAAQwX,EAAEqS,EAAE9C,IAAI,SAAS2C,EAAE3C,EAAEhjB,QAAG,IAASgjB,EAAEuB,SAASvB,EAAEuB,OAAO,EAAEvB,EAAEyB,QAAQzkB,EAAEyT,EAAEmS,EAAE5C,IAAI,SAASta,EAAEsa,EAAEhjB,EAAEmjB,EAAE5mB,GAAG,IAAIsS,EAAEmU,EAAE+C,aAAa/mB,EAAE6P,EAAE5S,OAAO+mB,EAAE6C,SAAS,KAAKhX,EAAE7P,GAAGgB,EAAE6O,EAAE7P,EAAE,GAAGmkB,EAAEtU,EAAE7P,EAAE,GAAGzC,EAAE,IAAIyC,GAAGgkB,EAAEuB,QAAQ9Q,EAAEqS,EAAE9C,GAAG,SAAS8C,EAAE9C,GAAG,IAAIhjB,EAAEgjB,EAAE+C,aAAa5C,EAAEH,EAAEuB,OAAO,GAAG,IAAIvkB,EAAE/D,OAAO,CAAC,IAAI,IAAIM,OAAE,EAAOsS,OAAE,EAAO7P,EAAEgkB,EAAEyB,QAAQhR,EAAE,EAAEA,EAAEzT,EAAE/D,OAAOwX,GAAG,EAAE5E,EAAE7O,EAAEyT,EAAE0P,IAAI5mB,EAAEyD,EAAEyT,IAAI+Q,EAAErB,EAAE5mB,EAAEsS,EAAE7P,GAAG6P,EAAE7P,GAAGgkB,EAAE+C,aAAa9pB,OAAO,GAAG,SAASuoB,EAAExB,EAAEG,EAAE5mB,EAAEsS,GAAG,IAAI7P,EAAEgB,EAAEzD,GAAGkX,OAAE,EAAO+P,OAAE,EAAO9kB,GAAE,EAAG,GAAGM,EAAE,CAAC,IAAIyU,EAAElX,EAAEsS,GAAG,MAAMmU,GAAGtkB,GAAE,EAAG8kB,EAAER,EAAE,GAAGG,IAAI1P,EAAE,YAAYkS,EAAExC,EAAE,IAAIjnB,UAAU,8DAA8DuX,EAAE5E,OAAE,IAASsU,EAAEoB,SAASvlB,GAAGN,EAAEgmB,EAAEvB,EAAE1P,IAAG,IAAK/U,EAAEinB,EAAExC,EAAEK,GAAG,IAAIR,EAAE0C,EAAEvC,EAAE1P,GAAG,IAAIuP,GAAG2C,EAAExC,EAAE1P,IAAI,IAAIuS,EAAE,EAAE,SAAS1B,EAAEtB,GAAGA,EAAExB,GAAGwE,IAAIhD,EAAEuB,YAAO,EAAOvB,EAAEyB,aAAQ,EAAOzB,EAAE+C,aAAa,GAAG,IAAI3mB,EAAE,WAAW,SAAS4jB,EAAEA,EAAEhjB,GAAGnE,KAAKoqB,qBAAqBjD,EAAEnnB,KAAKqqB,QAAQ,IAAIlD,EAAEqB,GAAGxoB,KAAKqqB,QAAQ1E,IAAI8C,EAAEzoB,KAAKqqB,SAAS/C,EAAEnjB,IAAInE,KAAKI,OAAO+D,EAAE/D,OAAOJ,KAAKsqB,WAAWnmB,EAAE/D,OAAOJ,KAAK4oB,QAAQ,IAAIjnB,MAAM3B,KAAKI,QAAQ,IAAIJ,KAAKI,OAAOypB,EAAE7pB,KAAKqqB,QAAQrqB,KAAK4oB,UAAU5oB,KAAKI,OAAOJ,KAAKI,QAAQ,EAAEJ,KAAKuqB,WAAWpmB,GAAG,IAAInE,KAAKsqB,YAAYT,EAAE7pB,KAAKqqB,QAAQrqB,KAAK4oB,WAAWkB,EAAE9pB,KAAKqqB,QAAQ,IAAItZ,MAAM,4CAA4C,OAAOoW,EAAE3lB,UAAU+oB,WAAW,SAASpD,GAAG,IAAI,IAAIhjB,EAAE,OAAE,IAASnE,KAAK0oB,QAAQvkB,EAAEgjB,EAAE/mB,OAAO+D,IAAInE,KAAKwqB,WAAWrD,EAAEhjB,GAAGA,IAAIgjB,EAAE3lB,UAAUgpB,WAAW,SAASrD,EAAEhjB,GAAG,IAAImjB,EAAEtnB,KAAKoqB,qBAAqB1pB,EAAE4mB,EAAE9W,QAAQ,GAAG9P,IAAIoC,EAAE,CAAC,IAAIkQ,OAAE,EAAO7P,OAAE,EAAOyU,GAAE,EAAG,IAAI5E,EAAEmU,EAAE5W,KAAK,MAAM4W,GAAGvP,GAAE,EAAGzU,EAAEgkB,EAAE,GAAGnU,IAAIuV,QAAG,IAASpB,EAAEuB,OAAO1oB,KAAKyqB,WAAWtD,EAAEuB,OAAOvkB,EAAEgjB,EAAEyB,cAAc,GAAG,mBAAmB5V,EAAEhT,KAAKsqB,aAAatqB,KAAK4oB,QAAQzkB,GAAGgjB,OAAO,GAAGG,IAAIoD,EAAE,CAAC,IAAI/C,EAAE,IAAIL,EAAEkB,GAAG5Q,EAAEkS,EAAEnC,EAAExkB,GAAGymB,EAAEjC,EAAER,EAAEnU,GAAGhT,KAAK2qB,cAAchD,EAAExjB,QAAQnE,KAAK2qB,cAAc,IAAIrD,GAAE,SAASnjB,GAAG,OAAOA,EAAEgjB,MAAKhjB,QAAQnE,KAAK2qB,cAAcjqB,EAAEymB,GAAGhjB,IAAIgjB,EAAE3lB,UAAUipB,WAAW,SAAStD,EAAEhjB,EAAEmjB,GAAG,IAAI5mB,EAAEV,KAAKqqB,aAAQ,IAAS3pB,EAAEgoB,SAAS1oB,KAAKsqB,aAAa,IAAInD,EAAE2C,EAAEppB,EAAE4mB,GAAGtnB,KAAK4oB,QAAQzkB,GAAGmjB,GAAG,IAAItnB,KAAKsqB,YAAYT,EAAEnpB,EAAEV,KAAK4oB,UAAUzB,EAAE3lB,UAAUmpB,cAAc,SAASxD,EAAEhjB,GAAG,IAAImjB,EAAEtnB,KAAK6M,EAAEsa,OAAE,GAAO,SAASA,GAAG,OAAOG,EAAEmD,WAAW,EAAEtmB,EAAEgjB,MAAI,SAASA,GAAG,OAAOG,EAAEmD,WAAW,EAAEtmB,EAAEgjB,OAAMA,EAAnwC,GAAwwCuD,EAAE,WAAW,SAASvD,EAAEhjB,GAAGnE,KAAK2lB,GAAGwE,IAAInqB,KAAK4oB,QAAQ5oB,KAAK0oB,YAAO,EAAO1oB,KAAKkqB,aAAa,GAAG1B,IAAIrkB,IAAI,mBAAmBA,GAAG,WAAW,MAAM,IAAI9D,UAAU,sFAA/B,GAAwHL,gBAAgBmnB,EAAE,SAASA,EAAEhjB,GAAG,IAAIA,GAAE,SAASA,GAAG0kB,EAAE1B,EAAEhjB,MAAI,SAASA,GAAG2lB,EAAE3C,EAAEhjB,MAAK,MAAMA,GAAG2lB,EAAE3C,EAAEhjB,IAA1E,CAA+EnE,KAAKmE,GAAG,WAAW,MAAM,IAAI9D,UAAU,yHAA/B,IAA4J,OAAO8mB,EAAE3lB,UAAU2P,MAAM,SAASgW,GAAG,OAAOnnB,KAAKuQ,KAAK,KAAK4W,IAAIA,EAAE3lB,UAAUopB,QAAQ,SAASzD,GAAG,IAAIG,EAAEtnB,KAAKiF,YAAY,OAAOd,EAAEgjB,GAAGnnB,KAAKuQ,MAAK,SAASpM,GAAG,OAAOmjB,EAAE9W,QAAQ2W,KAAK5W,MAAK,WAAW,OAAOpM,QAAK,SAASA,GAAG,OAAOmjB,EAAE9W,QAAQ2W,KAAK5W,MAAK,WAAW,MAAMpM,QAAMnE,KAAKuQ,KAAK4W,EAAEA,IAAIA,EAA7wB,GAAkxB,OAAOuD,EAAElpB,UAAU+O,KAAKgY,EAAEmC,EAAEG,IAAI,SAAS1D,GAAG,OAAO,IAAI5jB,EAAEvD,KAAKmnB,GAAGkD,SAASK,EAAEI,KAAK,SAAS3D,GAAG,IAAIhjB,EAAEnE,KAAK,OAAOsnB,EAAEH,GAAG,IAAIhjB,GAAE,SAASmjB,EAAE5mB,GAAG,IAAI,IAAIsS,EAAEmU,EAAE/mB,OAAO+C,EAAE,EAAEA,EAAE6P,EAAE7P,IAAIgB,EAAEqM,QAAQ2W,EAAEhkB,IAAIoN,KAAK+W,EAAE5mB,MAAK,IAAIyD,GAAE,SAASgjB,EAAEhjB,GAAG,OAAOA,EAAE,IAAI9D,UAAU,wCAAuCqqB,EAAEla,QAAQ1N,EAAE4nB,EAAEja,OAAO,SAAS0W,GAAG,IAAIhjB,EAAE,IAAInE,KAAKwoB,GAAG,OAAOsB,EAAE3lB,EAAEgjB,GAAGhjB,GAAGumB,EAAEK,cAAc,SAAS5D,GAAGhkB,EAAEgkB,GAAGuD,EAAEM,SAAS,SAAS7D,GAAGvP,EAAEuP,GAAGuD,EAAEO,MAAMrT,EAAE8S,EAAEQ,SAAS,WAAW,IAAI/mB,OAAE,EAAO,QAAG,IAASgjB,EAAEhjB,EAAEgjB,OAAO,GAAG,oBAAoBvW,KAAKzM,EAAEyM,UAAU,IAAIzM,EAAEmlB,SAAS,cAATA,GAA0B,MAAMnC,GAAG,MAAM,IAAIpW,MAAM,4EAA4E,IAAIuW,EAAEnjB,EAAE2M,QAAQ,GAAGwW,EAAE,CAAC,IAAI5mB,EAAE,KAAK,IAAIA,EAAEa,OAAOC,UAAUM,SAASX,KAAKmmB,EAAE9W,WAAW,MAAM2W,IAAI,GAAG,qBAAqBzmB,IAAI4mB,EAAE6D,KAAK,OAAOhnB,EAAE2M,QAAQ4Z,GAAGA,EAAE5Z,QAAQ4Z,EAAEA,EAAlzL,MAAyzLhqB,IAAEyD,GAAE,SAASgjB,EAAEhjB,GAAG,IAAImjB,EAAEH,EAAE9lB,QAAQimB,EAAEA,GAAG,SAASH,EAAEhjB,GAAG,IAAImjB,EAAE/lB,OAAOc,QAAQ,WAAW,SAAS8kB,KAAK,OAAO,SAAShjB,GAAG,IAAImjB,EAAE,OAAOH,EAAE3lB,UAAU2C,EAAEmjB,EAAE,IAAIH,EAAEA,EAAE3lB,UAAU,KAAK8lB,GAAhG,GAAsG5mB,EAAE,GAAGsS,EAAEtS,EAAE0qB,IAAI,GAAGjoB,EAAE6P,EAAEqY,KAAK,CAAChM,OAAO,SAAS8H,GAAG,IAAIhjB,EAAEmjB,EAAEtnB,MAAM,OAAOmnB,GAAGhjB,EAAEmnB,MAAMnE,GAAGhjB,EAAE1C,eAAe,SAASzB,KAAK4jB,OAAOzf,EAAEyf,OAAOzf,EAAEyf,KAAK,WAAWzf,EAAEonB,OAAO3H,KAAKjd,MAAM3G,KAAKiB,aAAakD,EAAEyf,KAAKpiB,UAAU2C,EAAEA,EAAEonB,OAAOvrB,KAAKmE,GAAG9B,OAAO,WAAW,IAAI8kB,EAAEnnB,KAAKqf,SAAS,OAAO8H,EAAEvD,KAAKjd,MAAMwgB,EAAElmB,WAAWkmB,GAAGvD,KAAK,aAAa0H,MAAM,SAASnE,GAAG,IAAI,IAAIhjB,KAAKgjB,EAAEA,EAAE1lB,eAAe0C,KAAKnE,KAAKmE,GAAGgjB,EAAEhjB,IAAIgjB,EAAE1lB,eAAe,cAAczB,KAAK8B,SAASqlB,EAAErlB,WAAW0pB,MAAM,WAAW,OAAOxrB,KAAK4jB,KAAKpiB,UAAU6d,OAAOrf,QAAQ4X,EAAE5E,EAAEyY,UAAUtoB,EAAEkc,OAAO,CAACuE,KAAK,SAASuD,EAAEhjB,GAAGgjB,EAAEnnB,KAAK0rB,MAAMvE,GAAG,GAAGnnB,KAAK2rB,SAAS,MAAMxnB,EAAEA,EAAE,EAAEgjB,EAAE/mB,QAAQ0B,SAAS,SAASqlB,GAAG,OAAOA,GAAGtkB,GAAGkF,UAAU/H,OAAO+C,OAAO,SAASokB,GAAG,IAAIhjB,EAAEnE,KAAK0rB,MAAMpE,EAAEH,EAAEuE,MAAMhrB,EAAEV,KAAK2rB,SAAS3Y,EAAEmU,EAAEwE,SAAS,GAAG3rB,KAAK4rB,QAAQlrB,EAAE,EAAE,IAAI,IAAIyC,EAAE,EAAEA,EAAE6P,EAAE7P,IAAIgB,EAAEzD,EAAEyC,IAAI,KAAKmkB,EAAEnkB,IAAI,KAAK,GAAGA,EAAE,EAAE,EAAE,MAAM,IAAIzC,EAAEyC,GAAG,EAAE,OAAO,IAAIA,EAAE,EAAEA,EAAE6P,EAAE7P,GAAG,EAAEgB,EAAEzD,EAAEyC,IAAI,GAAGmkB,EAAEnkB,IAAI,GAAG,OAAOnD,KAAK2rB,UAAU3Y,EAAEhT,MAAM4rB,MAAM,WAAW,IAAIznB,EAAEnE,KAAK0rB,MAAMpE,EAAEtnB,KAAK2rB,SAASxnB,EAAEmjB,IAAI,IAAI,YAAY,GAAGA,EAAE,EAAE,EAAEnjB,EAAE/D,OAAO+mB,EAAE0E,KAAKvE,EAAE,IAAIkE,MAAM,WAAW,IAAIrE,EAAEhkB,EAAEqoB,MAAMrqB,KAAKnB,MAAM,OAAOmnB,EAAEuE,MAAM1rB,KAAK0rB,MAAMxqB,MAAM,GAAGimB,GAAGuC,OAAO,SAASvlB,GAAG,IAAI,IAAImjB,EAAE5mB,EAAE,GAAGsS,EAAE,SAAS7O,GAAGA,EAAEA,EAAE,IAAImjB,EAAE,UAAU5mB,EAAE,WAAW,OAAO,WAAW,IAAIsS,IAAIsU,EAAE,OAAO,MAAMA,IAAIA,GAAG,IAAI5mB,IAAI,KAAKyD,EAAE,MAAM,MAAMA,IAAIA,GAAG,IAAIzD,GAAGA,EAAE,OAAOsS,GAAG,YAAYA,GAAG,KAAKmU,EAAEuC,SAAS,GAAG,GAAG,KAAKvmB,EAAE,EAAEA,EAAEgB,EAAEhB,GAAG,EAAE,CAAC,IAAIwkB,EAAE3U,EAAE,YAAYsU,GAAGH,EAAEuC,WAAWpC,EAAE,UAAUK,IAAIjnB,EAAEE,KAAK,WAAW+mB,IAAI,GAAG,OAAO,IAAI/P,EAAEgM,KAAKljB,EAAEyD,MAAMwjB,EAAEjnB,EAAEorB,IAAI,GAAGjpB,EAAE8kB,EAAEoE,IAAI,CAAChkB,UAAU,SAASof,GAAG,IAAI,IAAIhjB,EAAEgjB,EAAEuE,MAAMpE,EAAEH,EAAEwE,SAASjrB,EAAE,GAAGsS,EAAE,EAAEA,EAAEsU,EAAEtU,IAAI,CAAC,IAAI7P,EAAEgB,EAAE6O,IAAI,KAAK,GAAGA,EAAE,EAAE,EAAE,IAAItS,EAAEE,MAAMuC,IAAI,GAAGrB,SAAS,KAAKpB,EAAEE,MAAM,GAAGuC,GAAGrB,SAAS,KAAK,OAAOpB,EAAEI,KAAK,KAAKmN,MAAM,SAASkZ,GAAG,IAAI,IAAIhjB,EAAEgjB,EAAE/mB,OAAOknB,EAAE,GAAG5mB,EAAE,EAAEA,EAAEyD,EAAEzD,GAAG,EAAE4mB,EAAE5mB,IAAI,IAAIiE,SAASwiB,EAAE6E,OAAOtrB,EAAE,GAAG,KAAK,GAAGA,EAAE,EAAE,EAAE,OAAO,IAAIkX,EAAEgM,KAAK0D,EAAEnjB,EAAE,KAAKyjB,EAAED,EAAEsE,OAAO,CAAClkB,UAAU,SAASof,GAAG,IAAI,IAAIhjB,EAAEgjB,EAAEuE,MAAMpE,EAAEH,EAAEwE,SAASjrB,EAAE,GAAGsS,EAAE,EAAEA,EAAEsU,EAAEtU,IAAItS,EAAEE,KAAK4D,OAAOwE,aAAa7E,EAAE6O,IAAI,KAAK,GAAGA,EAAE,EAAE,EAAE,MAAM,OAAOtS,EAAEI,KAAK,KAAKmN,MAAM,SAASkZ,GAAG,IAAI,IAAIhjB,EAAEgjB,EAAE/mB,OAAOknB,EAAE,GAAG5mB,EAAE,EAAEA,EAAEyD,EAAEzD,IAAI4mB,EAAE5mB,IAAI,KAAK,IAAIymB,EAAEriB,WAAWpE,KAAK,GAAGA,EAAE,EAAE,EAAE,OAAO,IAAIkX,EAAEgM,KAAK0D,EAAEnjB,KAAK4jB,EAAEJ,EAAEuE,KAAK,CAACnkB,UAAU,SAASof,GAAG,IAAI,OAAOjjB,mBAAmBO,OAAOmjB,EAAE7f,UAAUof,KAAK,MAAMA,GAAG,MAAM,IAAIpW,MAAM,0BAA0B9C,MAAM,SAASkZ,GAAG,OAAOS,EAAE3Z,MAAMhK,SAASgU,mBAAmBkP,OAAOtiB,EAAEmO,EAAEmZ,uBAAuBhpB,EAAEkc,OAAO,CAAC+M,MAAM,WAAWpsB,KAAKiS,MAAM,IAAI2F,EAAEgM,KAAK5jB,KAAKqsB,YAAY,GAAGC,QAAQ,SAASnF,GAAG,iBAAiBA,IAAIA,EAAEY,EAAE9Z,MAAMkZ,IAAInnB,KAAKiS,MAAMlP,OAAOokB,GAAGnnB,KAAKqsB,aAAalF,EAAEwE,UAAUY,SAAS,SAASpoB,GAAG,IAAImjB,EAAEtnB,KAAKiS,MAAMvR,EAAE4mB,EAAEoE,MAAM1Y,EAAEsU,EAAEqE,SAASxoB,EAAEnD,KAAKwsB,UAAU7E,EAAE3U,GAAG,EAAE7P,GAAGN,GAAG8kB,EAAExjB,EAAEgjB,EAAE0E,KAAKlE,GAAGR,EAAEsF,KAAK,EAAE9E,GAAG3nB,KAAK0sB,eAAe,IAAIvpB,EAAEykB,EAAET,EAAEwF,IAAI,EAAE9pB,EAAEmQ,GAAG,GAAGnQ,EAAE,CAAC,IAAI,IAAIklB,EAAE,EAAEA,EAAEllB,EAAEklB,GAAG5kB,EAAEnD,KAAK4sB,gBAAgBlsB,EAAEqnB,GAAG,IAAIljB,EAAEnE,EAAEqL,OAAO,EAAElJ,GAAGykB,EAAEqE,UAAU/D,EAAE,OAAO,IAAIhQ,EAAEgM,KAAK/e,EAAE+iB,IAAI4D,MAAM,WAAW,IAAIrE,EAAEhkB,EAAEqoB,MAAMrqB,KAAKnB,MAAM,OAAOmnB,EAAElV,MAAMjS,KAAKiS,MAAMuZ,QAAQrE,GAAGuF,eAAe,IAAItM,GAAGpN,EAAE6Z,OAAOhoB,EAAEwa,OAAO,CAACyN,IAAI3pB,EAAEkc,SAASuE,KAAK,SAASuD,GAAGnnB,KAAK8sB,IAAI9sB,KAAK8sB,IAAIzN,OAAO8H,GAAGnnB,KAAKosB,SAASA,MAAM,WAAWvnB,EAAEunB,MAAMjrB,KAAKnB,MAAMA,KAAK+sB,YAAYC,OAAO,SAAS7F,GAAG,OAAOnnB,KAAKssB,QAAQnF,GAAGnnB,KAAKusB,WAAWvsB,MAAMitB,SAAS,SAAS9F,GAAG,OAAOA,GAAGnnB,KAAKssB,QAAQnF,GAAGnnB,KAAKktB,eAAeV,UAAU,GAAGW,cAAc,SAAShG,GAAG,OAAO,SAAShjB,EAAEmjB,GAAG,OAAO,IAAIH,EAAEvD,KAAK0D,GAAG2F,SAAS9oB,KAAKipB,kBAAkB,SAASjG,GAAG,OAAO,SAAShjB,EAAEmjB,GAAG,OAAO,IAAIlH,EAAEiN,KAAKzJ,KAAKuD,EAAEG,GAAG2F,SAAS9oB,OAAOzD,EAAE4sB,KAAK,IAAI,OAAO5sB,EAAj1G,CAAo1G+oB,SAAQzW,EAAE7O,GAAE,SAASgjB,EAAEhjB,GAAG,IAAImjB,EAAEH,EAAE9lB,SAASimB,EAAE5mB,IAAE,SAASymB,GAAG,IAAIhjB,EAAEmjB,EAAE5mB,EAAEyD,EAAEinB,IAAIpY,EAAEtS,EAAE+qB,UAAUtoB,EAAEzC,EAAEmsB,OAAOjV,EAAEzT,EAAEmpB,KAAK3F,EAAE,GAAG9kB,EAAE,IAAI,WAAW,SAASsB,EAAEA,GAAG,IAAI,IAAImjB,EAAEH,EAAEoG,KAAKppB,GAAGzD,EAAE,EAAEA,GAAG4mB,EAAE5mB,IAAI,KAAKyD,EAAEzD,GAAG,OAAM,EAAG,OAAM,EAAG,SAAS4mB,EAAEH,GAAG,OAAO,YAAYA,GAAG,EAAEA,IAAI,EAAE,IAAI,IAAIzmB,EAAE,EAAEsS,EAAE,EAAEA,EAAE,IAAI7O,EAAEzD,KAAKsS,EAAE,IAAI2U,EAAE3U,GAAGsU,EAAEH,EAAEqG,IAAI9sB,EAAE,MAAMmC,EAAEmQ,GAAGsU,EAAEH,EAAEqG,IAAI9sB,EAAE,EAAE,IAAIsS,KAAKtS,IAApN,GAA2N,IAAIknB,EAAE,GAAGG,EAAEnQ,EAAE6V,OAAOtqB,EAAEkc,OAAO,CAAC0N,SAAS,WAAW/sB,KAAK0tB,MAAM,IAAI1a,EAAE4Q,KAAK+D,EAAEzmB,MAAM,KAAK0rB,gBAAgB,SAASzF,EAAEhjB,GAAG,IAAI,IAAImjB,EAAEtnB,KAAK0tB,MAAMhC,MAAMhrB,EAAE4mB,EAAE,GAAGtU,EAAEsU,EAAE,GAAGnkB,EAAEmkB,EAAE,GAAG1P,EAAE0P,EAAE,GAAGK,EAAEL,EAAE,GAAGS,EAAET,EAAE,GAAGziB,EAAEyiB,EAAE,GAAGlH,EAAEkH,EAAE,GAAGE,EAAE,EAAEA,EAAE,GAAGA,IAAI,CAAC,GAAGA,EAAE,GAAGI,EAAEJ,GAAG,EAAEL,EAAEhjB,EAAEqjB,OAAO,CAAC,IAAIC,EAAEG,EAAEJ,EAAE,IAAIY,EAAER,EAAEJ,EAAE,GAAGI,EAAEJ,KAAKC,GAAG,GAAGA,IAAI,IAAIA,GAAG,GAAGA,IAAI,IAAIA,IAAI,GAAGG,EAAEJ,EAAE,KAAKY,GAAG,GAAGA,IAAI,KAAKA,GAAG,GAAGA,IAAI,IAAIA,IAAI,IAAIR,EAAEJ,EAAE,IAAI,IAAIpf,EAAE1H,EAAEsS,EAAEtS,EAAEyC,EAAE6P,EAAE7P,EAAEklB,EAAEjI,IAAIuH,GAAG,GAAGA,IAAI,IAAIA,GAAG,GAAGA,IAAI,KAAKA,GAAG,EAAEA,IAAI,MAAMA,EAAEI,GAAGJ,EAAE9iB,GAAGhC,EAAE2kB,GAAGI,EAAEJ,GAAGpH,EAAEvb,EAAEA,EAAEkjB,EAAEA,EAAEJ,EAAEA,EAAE/P,EAAEyQ,EAAE,EAAEzQ,EAAEzU,EAAEA,EAAE6P,EAAEA,EAAEtS,EAAEA,EAAE2nB,KAAK3nB,GAAG,GAAGA,IAAI,IAAIA,GAAG,GAAGA,IAAI,KAAKA,GAAG,GAAGA,IAAI,KAAK0H,GAAG,EAAEkf,EAAE,GAAGA,EAAE,GAAG5mB,EAAE,EAAE4mB,EAAE,GAAGA,EAAE,GAAGtU,EAAE,EAAEsU,EAAE,GAAGA,EAAE,GAAGnkB,EAAE,EAAEmkB,EAAE,GAAGA,EAAE,GAAG1P,EAAE,EAAE0P,EAAE,GAAGA,EAAE,GAAGK,EAAE,EAAEL,EAAE,GAAGA,EAAE,GAAGS,EAAE,EAAET,EAAE,GAAGA,EAAE,GAAGziB,EAAE,EAAEyiB,EAAE,GAAGA,EAAE,GAAGlH,EAAE,GAAG8M,YAAY,WAAW,IAAI/oB,EAAEnE,KAAKiS,MAAMqV,EAAEnjB,EAAEunB,MAAMhrB,EAAE,EAAEV,KAAKqsB,YAAYrZ,EAAE,EAAE7O,EAAEwnB,SAAS,OAAOrE,EAAEtU,IAAI,IAAI,KAAK,GAAGA,EAAE,GAAGsU,EAAE,IAAItU,EAAE,KAAK,GAAG,IAAImU,EAAEwG,MAAMjtB,EAAE,YAAY4mB,EAAE,IAAItU,EAAE,KAAK,GAAG,IAAItS,EAAEyD,EAAEwnB,SAAS,EAAErE,EAAElnB,OAAOJ,KAAKusB,WAAWvsB,KAAK0tB,OAAOlC,MAAM,WAAW,IAAIrE,EAAEhkB,EAAEqoB,MAAMrqB,KAAKnB,MAAM,OAAOmnB,EAAEuG,MAAM1tB,KAAK0tB,MAAMlC,QAAQrE,KAAKhjB,EAAEspB,OAAOtqB,EAAEgqB,cAAcpF,GAAG5jB,EAAEypB,WAAWzqB,EAAEiqB,kBAAkBrF,GAA/xC,CAAmyC0B,MAAMnC,EAAEmG,WAAUtqB,EAAEgB,GAAE,SAASgjB,EAAEhjB,GAAG,IAAImjB,EAAEtU,EAAEmU,EAAE9lB,SAASimB,GAAGtU,EAAEtS,KAAG0qB,IAAIK,UAAUzY,EAAE8Y,IAAI+B,OAAO,CAAC9lB,UAAU,SAASof,GAAG,IAAIhjB,EAAEgjB,EAAEuE,MAAMpE,EAAEH,EAAEwE,SAASjrB,EAAEV,KAAK8tB,KAAK3G,EAAEyE,QAAQ,IAAI,IAAI5Y,EAAE,GAAG7P,EAAE,EAAEA,EAAEmkB,EAAEnkB,GAAG,EAAE,IAAI,IAAIyU,GAAGzT,EAAEhB,IAAI,KAAK,GAAGA,EAAE,EAAE,EAAE,MAAM,IAAIgB,EAAEhB,EAAE,IAAI,KAAK,IAAIA,EAAE,GAAG,EAAE,EAAE,MAAM,EAAEgB,EAAEhB,EAAE,IAAI,KAAK,IAAIA,EAAE,GAAG,EAAE,EAAE,IAAIwkB,EAAE,EAAEA,EAAE,GAAGxkB,EAAE,IAAIwkB,EAAEL,EAAEK,IAAI3U,EAAEpS,KAAKF,EAAEqE,OAAO6S,IAAI,GAAG,EAAE+P,GAAG,KAAK,IAAI9kB,EAAEnC,EAAEqE,OAAO,IAAI,GAAGlC,EAAE,KAAKmQ,EAAE5S,OAAO,GAAG4S,EAAEpS,KAAKiC,GAAG,OAAOmQ,EAAElS,KAAK,KAAKmN,MAAM,SAASkZ,GAAG,IAAIhjB,EAAEgjB,EAAE/mB,OAAOM,EAAEV,KAAK8tB,KAAK9a,EAAEhT,KAAK+tB,YAAY,IAAI/a,EAAE,CAACA,EAAEhT,KAAK+tB,YAAY,GAAG,IAAI,IAAI5qB,EAAE,EAAEA,EAAEzC,EAAEN,OAAO+C,IAAI6P,EAAEtS,EAAEoE,WAAW3B,IAAIA,EAAE,IAAIyU,EAAElX,EAAEqE,OAAO,IAAI,GAAG6S,EAAE,CAAC,IAAI+P,EAAER,EAAE1jB,QAAQmU,IAAI,IAAI+P,IAAIxjB,EAAEwjB,GAAG,OAAO,SAASR,EAAEhjB,EAAEzD,GAAG,IAAI,IAAIsS,EAAE,GAAG7P,EAAE,EAAEyU,EAAE,EAAEA,EAAEzT,EAAEyT,IAAI,GAAGA,EAAE,EAAE,CAAC,IAAI+P,EAAEjnB,EAAEymB,EAAEriB,WAAW8S,EAAE,KAAKA,EAAE,EAAE,EAAE/U,EAAEnC,EAAEymB,EAAEriB,WAAW8S,MAAM,EAAEA,EAAE,EAAE,EAAE5E,EAAE7P,IAAI,KAAKwkB,EAAE9kB,IAAI,GAAGM,EAAE,EAAE,EAAEA,IAAI,OAAOmkB,EAAEjlB,OAAO2Q,EAAE7P,GAAtK,CAA0KgkB,EAAEhjB,EAAE6O,IAAI8a,KAAK,qEAAqE9a,EAAE8Y,IAAI+B,WAAUjW,EAAEzT,GAAE,SAASgjB,EAAEhjB,GAAGgjB,EAAE9lB,QAAQX,IAAEorB,IAAIC,OAAMpE,EAAExjB,GAAE,SAASA,EAAEmjB,IAAG,WAAY,IAAIH,EAAE,SAASG,EAAEH,EAAEhjB,EAAEmjB,GAAG,MAAMH,IAAI,iBAAiBA,EAAEnnB,KAAKguB,WAAW7G,EAAEhjB,EAAEmjB,GAAGtnB,KAAKiuB,WAAW9G,EAAE,MAAMhjB,GAAG,iBAAiBgjB,EAAE,IAAIhjB,IAAI,SAASzD,IAAI,OAAO,IAAI4mB,EAAE,MAAM,IAAItU,EAAE,oBAAoBkb,UAAUlb,GAAG,+BAA+Bkb,UAAUC,SAAS7G,EAAE9lB,UAAU4sB,GAAG,SAASjH,EAAEhjB,EAAEmjB,EAAE5mB,EAAEsS,EAAE7P,GAAG,IAAI,IAAIyU,EAAE,MAAMzT,EAAEwjB,EAAExjB,GAAG,KAAKhB,GAAG,GAAG,CAAC,IAAIN,EAAE,MAAM7C,KAAKmnB,GAAGS,EAAE5nB,KAAKmnB,MAAM,GAAGY,EAAEJ,EAAE9kB,EAAE+kB,EAAEhQ,EAAE5E,IAAInQ,EAAE+U,EAAE/U,IAAI,MAAMklB,IAAI,IAAIT,EAAE5mB,IAAI,WAAWsS,MAAM,KAAK+U,IAAI,IAAIJ,EAAEC,GAAG5U,IAAI,IAAIsU,EAAE5mB,KAAK,WAAWmC,EAAE,OAAOmQ,GAAGmU,EAAE,IAAInU,GAAG,YAAYkb,UAAUC,SAAS7G,EAAE9lB,UAAU4sB,GAAG,SAASjH,EAAEhjB,EAAEmjB,EAAE5mB,EAAEsS,EAAE7P,GAAG,OAAOA,GAAG,GAAG,CAAC,IAAIyU,EAAEzT,EAAEnE,KAAKmnB,KAAKG,EAAE5mB,GAAGsS,EAAEA,EAAEyW,KAAKkE,MAAM/V,EAAE,UAAU0P,EAAE5mB,KAAK,SAASkX,EAAE,OAAO5E,GAAGmU,EAAE,KAAKG,EAAE9lB,UAAU4sB,GAAG,SAASjH,EAAEhjB,EAAEmjB,EAAE5mB,EAAEsS,EAAE7P,GAAG,IAAI,IAAIyU,EAAE,MAAMzT,EAAEwjB,EAAExjB,GAAG,KAAKhB,GAAG,GAAG,CAAC,IAAIN,EAAE,MAAM7C,KAAKmnB,GAAGS,EAAE5nB,KAAKmnB,MAAM,GAAGY,EAAEJ,EAAE9kB,EAAE+kB,EAAEhQ,EAAE5E,IAAInQ,EAAE+U,EAAE/U,IAAI,MAAMklB,IAAI,IAAIT,EAAE5mB,GAAGsS,IAAI,KAAK+U,GAAG,IAAIJ,EAAEC,EAAEN,EAAE5mB,KAAK,UAAUmC,EAAE,OAAOmQ,GAAGmU,EAAE,IAAIG,EAAE9lB,UAAU6sB,GAAGlH,EAAEG,EAAE9lB,UAAU8sB,IAAI,GAAGnH,GAAG,EAAEG,EAAE9lB,UAAU+sB,GAAG,GAAGpH,EAAEG,EAAE9lB,UAAUgtB,GAAG/E,KAAK+D,IAAI,EAAE,IAAIlG,EAAE9lB,UAAUitB,GAAG,GAAGtH,EAAEG,EAAE9lB,UAAUktB,GAAG,EAAEvH,EAAE,GAAG,IAAIhkB,EAAEyU,EAAE+P,EAAE,IAAIhmB,MAAM,IAAIwB,EAAE,IAAI2B,WAAW,GAAG8S,EAAE,EAAEA,GAAG,IAAIA,EAAE+P,EAAExkB,KAAKyU,EAAE,IAAIzU,EAAE,IAAI2B,WAAW,GAAG8S,EAAE,GAAGA,EAAE,KAAKA,EAAE+P,EAAExkB,KAAKyU,EAAE,IAAIzU,EAAE,IAAI2B,WAAW,GAAG8S,EAAE,GAAGA,EAAE,KAAKA,EAAE+P,EAAExkB,KAAKyU,EAAE,SAAS/U,EAAEskB,GAAG,MAAM,uCAAuCpiB,OAAOoiB,GAAG,SAASS,EAAET,EAAEhjB,GAAG,IAAImjB,EAAEK,EAAER,EAAEriB,WAAWX,IAAI,OAAO,MAAMmjB,GAAG,EAAEA,EAAE,SAASS,EAAEZ,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOyD,EAAEwqB,QAAQxH,GAAGhjB,EAAE,SAASU,EAAEsiB,GAAG,IAAIhjB,EAAEmjB,EAAE,EAAE,OAAO,IAAInjB,EAAEgjB,IAAI,MAAMA,EAAEhjB,EAAEmjB,GAAG,IAAI,IAAInjB,EAAEgjB,GAAG,KAAKA,EAAEhjB,EAAEmjB,GAAG,GAAG,IAAInjB,EAAEgjB,GAAG,KAAKA,EAAEhjB,EAAEmjB,GAAG,GAAG,IAAInjB,EAAEgjB,GAAG,KAAKA,EAAEhjB,EAAEmjB,GAAG,GAAG,IAAInjB,EAAEgjB,GAAG,KAAKA,EAAEhjB,EAAEmjB,GAAG,GAAGA,EAAE,SAASlH,EAAE+G,GAAGnnB,KAAKooB,EAAEjB,EAAE,SAASK,EAAEL,GAAGnnB,KAAKooB,EAAEjB,EAAEnnB,KAAK4uB,GAAGzH,EAAE0H,WAAW7uB,KAAK8uB,IAAI,MAAM9uB,KAAK4uB,GAAG5uB,KAAK+uB,IAAI/uB,KAAK4uB,IAAI,GAAG5uB,KAAKgvB,IAAI,GAAG7H,EAAEkH,GAAG,IAAI,EAAEruB,KAAKivB,IAAI,EAAE9H,EAAEA,EAAE,SAASM,EAAEN,EAAEhjB,GAAG,OAAOgjB,EAAEhjB,EAAE,SAASikB,EAAEjB,EAAEhjB,GAAG,OAAOgjB,EAAEhjB,EAAE,SAASiE,EAAE+e,EAAEhjB,GAAG,OAAOgjB,EAAEhjB,EAAE,SAASkkB,EAAElB,EAAEhjB,GAAG,OAAOgjB,GAAGhjB,EAAE,SAASmkB,EAAEnB,GAAG,GAAG,GAAGA,EAAE,OAAO,EAAE,IAAIhjB,EAAE,EAAE,OAAO,IAAI,MAAMgjB,KAAKA,IAAI,GAAGhjB,GAAG,IAAI,IAAI,IAAIgjB,KAAKA,IAAI,EAAEhjB,GAAG,GAAG,IAAI,GAAGgjB,KAAKA,IAAI,EAAEhjB,GAAG,GAAG,IAAI,EAAEgjB,KAAKA,IAAI,EAAEhjB,GAAG,GAAG,IAAI,EAAEgjB,MAAMhjB,EAAEA,EAAE,SAASujB,EAAEP,GAAG,IAAI,IAAIhjB,EAAE,EAAE,GAAGgjB,GAAGA,GAAGA,EAAE,IAAIhjB,EAAE,OAAOA,EAAE,SAASokB,KAAK,SAASzlB,EAAEqkB,GAAG,OAAOA,EAAE,SAASxB,EAAEwB,GAAGnnB,KAAKkvB,GAAGxuB,IAAIV,KAAKmvB,GAAGzuB,IAAI4mB,EAAE8H,IAAIC,UAAU,EAAElI,EAAEA,EAAEnnB,KAAKkvB,IAAIlvB,KAAKsvB,GAAGtvB,KAAKkvB,GAAGK,OAAOpI,GAAGnnB,KAAKooB,EAAEjB,EAAE/G,EAAE5e,UAAUguB,QAAQ,SAASrI,GAAG,OAAOA,EAAEvP,EAAE,GAAGuP,EAAEsI,UAAUzvB,KAAKooB,IAAI,EAAEjB,EAAE1J,IAAIzd,KAAKooB,GAAGjB,GAAG/G,EAAE5e,UAAUkuB,OAAO,SAASvI,GAAG,OAAOA,GAAG/G,EAAE5e,UAAUiB,OAAO,SAAS0kB,GAAGA,EAAEwI,SAAS3vB,KAAKooB,EAAE,KAAKjB,IAAI/G,EAAE5e,UAAUouB,MAAM,SAASzI,EAAEhjB,EAAEmjB,GAAGH,EAAE0I,WAAW1rB,EAAEmjB,GAAGtnB,KAAKyC,OAAO6kB,IAAIlH,EAAE5e,UAAUsuB,MAAM,SAAS3I,EAAEhjB,GAAGgjB,EAAE4I,SAAS5rB,GAAGnE,KAAKyC,OAAO0B,IAAIqjB,EAAEhmB,UAAUguB,QAAQ,SAASrI,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOymB,EAAE6I,MAAMX,UAAUrvB,KAAKooB,EAAEjB,EAAEhjB,GAAGA,EAAEwrB,SAAS3vB,KAAKooB,EAAE,KAAKjkB,GAAGgjB,EAAEvP,EAAE,GAAGzT,EAAEsrB,UAAUnI,EAAE2I,MAAM,GAAGjwB,KAAKooB,EAAE8H,MAAM/rB,EAAEA,GAAGA,GAAGqjB,EAAEhmB,UAAUkuB,OAAO,SAASvI,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOymB,EAAEgJ,OAAOhsB,GAAGnE,KAAKyC,OAAO0B,GAAGA,GAAGqjB,EAAEhmB,UAAUiB,OAAO,SAAS0kB,GAAG,KAAKA,EAAEA,GAAGnnB,KAAKivB,KAAK9H,EAAEA,EAAEA,KAAK,EAAE,IAAI,IAAIhjB,EAAE,EAAEA,EAAEnE,KAAKooB,EAAEjB,IAAIhjB,EAAE,CAAC,IAAImjB,EAAE,MAAMH,EAAEhjB,GAAGzD,EAAE4mB,EAAEtnB,KAAK8uB,MAAMxH,EAAEtnB,KAAK+uB,KAAK5H,EAAEhjB,IAAI,IAAInE,KAAK8uB,IAAI9uB,KAAKgvB,KAAK,IAAI7H,EAAEmH,GAAG,IAAInH,EAAEG,EAAEnjB,EAAEnE,KAAKooB,EAAEjB,IAAInnB,KAAKooB,EAAEgG,GAAG,EAAE1tB,EAAEymB,EAAEhjB,EAAE,EAAEnE,KAAKooB,EAAEjB,GAAGA,EAAEG,IAAIH,EAAEoH,IAAIpH,EAAEG,IAAIH,EAAEoH,GAAGpH,IAAIG,KAAKH,EAAEyE,QAAQzE,EAAEiJ,UAAUpwB,KAAKooB,EAAEjB,EAAEA,GAAGA,EAAEsI,UAAUzvB,KAAKooB,IAAI,GAAGjB,EAAE+I,MAAMlwB,KAAKooB,EAAEjB,IAAIK,EAAEhmB,UAAUouB,MAAM,SAASzI,EAAEhjB,EAAEmjB,GAAGH,EAAE0I,WAAW1rB,EAAEmjB,GAAGtnB,KAAKyC,OAAO6kB,IAAIE,EAAEhmB,UAAUsuB,MAAM,SAAS3I,EAAEhjB,GAAGgjB,EAAE4I,SAAS5rB,GAAGnE,KAAKyC,OAAO0B,IAAImjB,EAAE9lB,UAAU2uB,OAAO,SAAShJ,GAAG,IAAI,IAAIhjB,EAAEnE,KAAKmnB,EAAE,EAAEhjB,GAAG,IAAIA,EAAEgjB,EAAEhjB,GAAGnE,KAAKmE,GAAGgjB,EAAEA,EAAEnnB,KAAKmnB,EAAEA,EAAEvP,EAAE5X,KAAK4X,GAAG0P,EAAE9lB,UAAUmtB,QAAQ,SAASxH,GAAGnnB,KAAKmnB,EAAE,EAAEnnB,KAAK4X,EAAEuP,EAAE,GAAG,EAAE,EAAEA,EAAE,EAAEnnB,KAAK,GAAGmnB,EAAEA,GAAG,EAAEnnB,KAAK,GAAGmnB,EAAEnnB,KAAKuuB,GAAGvuB,KAAKmnB,EAAE,GAAGG,EAAE9lB,UAAUysB,WAAW,SAAS9G,EAAEhjB,GAAG,IAAIzD,EAAE,GAAG,IAAIyD,EAAEzD,EAAE,OAAO,GAAG,GAAGyD,EAAEzD,EAAE,OAAO,GAAG,KAAKyD,EAAEzD,EAAE,OAAO,GAAG,GAAGyD,EAAEzD,EAAE,OAAO,GAAG,IAAIyD,EAAEzD,EAAE,MAAM,CAAC,GAAG,GAAGyD,EAAE,YAAYnE,KAAKqwB,UAAUlJ,EAAEhjB,GAAGzD,EAAE,EAAEV,KAAKmnB,EAAE,EAAEnnB,KAAK4X,EAAE,EAAE,IAAI,IAAI5E,EAAEmU,EAAE/mB,OAAO+C,GAAE,EAAGyU,EAAE,IAAI5E,GAAG,GAAG,CAAC,IAAI2U,EAAE,GAAGjnB,EAAE,IAAIymB,EAAEnU,GAAG4U,EAAET,EAAEnU,GAAG2U,EAAE,EAAE,KAAKR,EAAEpiB,OAAOiO,KAAK7P,GAAE,IAAKA,GAAE,EAAG,GAAGyU,EAAE5X,KAAKA,KAAKmnB,KAAKQ,EAAE/P,EAAElX,EAAEV,KAAKquB,IAAIruB,KAAKA,KAAKmnB,EAAE,KAAKQ,GAAG,GAAG3nB,KAAKquB,GAAGzW,GAAG,IAAIA,EAAE5X,KAAKA,KAAKmnB,KAAKQ,GAAG3nB,KAAKquB,GAAGzW,GAAG5X,KAAKA,KAAKmnB,EAAE,IAAIQ,GAAG/P,GAAGA,GAAGlX,IAAIV,KAAKquB,KAAKzW,GAAG5X,KAAKquB,KAAK,GAAG3tB,GAAG,IAAI,IAAIymB,EAAE,MAAMnnB,KAAK4X,GAAG,EAAEA,EAAE,IAAI5X,KAAKA,KAAKmnB,EAAE,KAAK,GAAGnnB,KAAKquB,GAAGzW,GAAG,GAAGA,IAAI5X,KAAK4rB,QAAQzoB,GAAGmkB,EAAE2I,KAAKC,MAAMlwB,KAAKA,OAAOsnB,EAAE9lB,UAAUoqB,MAAM,WAAW,IAAI,IAAIzE,EAAEnnB,KAAK4X,EAAE5X,KAAKsuB,GAAGtuB,KAAKmnB,EAAE,GAAGnnB,KAAKA,KAAKmnB,EAAE,IAAIA,KAAKnnB,KAAKmnB,GAAGG,EAAE9lB,UAAU6tB,UAAU,SAASlI,EAAEhjB,GAAG,IAAImjB,EAAE,IAAIA,EAAEtnB,KAAKmnB,EAAE,EAAEG,GAAG,IAAIA,EAAEnjB,EAAEmjB,EAAEH,GAAGnnB,KAAKsnB,GAAG,IAAIA,EAAEH,EAAE,EAAEG,GAAG,IAAIA,EAAEnjB,EAAEmjB,GAAG,EAAEnjB,EAAEgjB,EAAEnnB,KAAKmnB,EAAEA,EAAEhjB,EAAEyT,EAAE5X,KAAK4X,GAAG0P,EAAE9lB,UAAU4uB,UAAU,SAASjJ,EAAEhjB,GAAG,IAAI,IAAImjB,EAAEH,EAAEG,EAAEtnB,KAAKmnB,IAAIG,EAAEnjB,EAAEmjB,EAAEH,GAAGnnB,KAAKsnB,GAAGnjB,EAAEgjB,EAAEsC,KAAKgD,IAAIzsB,KAAKmnB,EAAEA,EAAE,GAAGhjB,EAAEyT,EAAE5X,KAAK4X,GAAG0P,EAAE9lB,UAAU8uB,SAAS,SAASnJ,EAAEhjB,GAAG,IAAImjB,EAAE5mB,EAAEymB,EAAEnnB,KAAKquB,GAAGrb,EAAEhT,KAAKquB,GAAG3tB,EAAEyC,GAAG,GAAG6P,GAAG,EAAE4E,EAAE6R,KAAKkE,MAAMxG,EAAEnnB,KAAKquB,IAAI1G,EAAE3nB,KAAK4X,GAAGlX,EAAEV,KAAKsuB,GAAG,IAAIhH,EAAEtnB,KAAKmnB,EAAE,EAAEG,GAAG,IAAIA,EAAEnjB,EAAEmjB,EAAE1P,EAAE,GAAG5X,KAAKsnB,IAAItU,EAAE2U,EAAEA,GAAG3nB,KAAKsnB,GAAGnkB,IAAIzC,EAAE,IAAI4mB,EAAE1P,EAAE,EAAE0P,GAAG,IAAIA,EAAEnjB,EAAEmjB,GAAG,EAAEnjB,EAAEyT,GAAG+P,EAAExjB,EAAEgjB,EAAEnnB,KAAKmnB,EAAEvP,EAAE,EAAEzT,EAAEyT,EAAE5X,KAAK4X,EAAEzT,EAAEynB,SAAStE,EAAE9lB,UAAU+uB,SAAS,SAASpJ,EAAEhjB,GAAGA,EAAEyT,EAAE5X,KAAK4X,EAAE,IAAI0P,EAAEmC,KAAKkE,MAAMxG,EAAEnnB,KAAKquB,IAAI,GAAG/G,GAAGtnB,KAAKmnB,EAAEhjB,EAAEgjB,EAAE,MAAM,CAAC,IAAIzmB,EAAEymB,EAAEnnB,KAAKquB,GAAGrb,EAAEhT,KAAKquB,GAAG3tB,EAAEyC,GAAG,GAAGzC,GAAG,EAAEyD,EAAE,GAAGnE,KAAKsnB,IAAI5mB,EAAE,IAAI,IAAIkX,EAAE0P,EAAE,EAAE1P,EAAE5X,KAAKmnB,IAAIvP,EAAEzT,EAAEyT,EAAE0P,EAAE,KAAKtnB,KAAK4X,GAAGzU,IAAI6P,EAAE7O,EAAEyT,EAAE0P,GAAGtnB,KAAK4X,IAAIlX,EAAEA,EAAE,IAAIyD,EAAEnE,KAAKmnB,EAAEG,EAAE,KAAKtnB,KAAK4X,EAAEzU,IAAI6P,GAAG7O,EAAEgjB,EAAEnnB,KAAKmnB,EAAEG,EAAEnjB,EAAEynB,UAAUtE,EAAE9lB,UAAU0uB,MAAM,SAAS/I,EAAEhjB,GAAG,IAAI,IAAImjB,EAAE,EAAE5mB,EAAE,EAAEsS,EAAEyW,KAAKkD,IAAIxF,EAAEA,EAAEnnB,KAAKmnB,GAAGG,EAAEtU,GAAGtS,GAAGV,KAAKsnB,GAAGH,EAAEG,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG,GAAGlH,EAAEA,EAAEnnB,KAAKmnB,EAAE,CAAC,IAAIzmB,GAAGymB,EAAEvP,EAAE0P,EAAEtnB,KAAKmnB,GAAGzmB,GAAGV,KAAKsnB,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG3tB,GAAGV,KAAK4X,MAAM,CAAC,IAAIlX,GAAGV,KAAK4X,EAAE0P,EAAEH,EAAEA,GAAGzmB,GAAGymB,EAAEG,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG3tB,GAAGymB,EAAEvP,EAAEzT,EAAEyT,EAAElX,EAAE,GAAG,EAAE,EAAEA,GAAG,EAAEyD,EAAEmjB,KAAKtnB,KAAKuuB,GAAG7tB,EAAEA,EAAE,IAAIyD,EAAEmjB,KAAK5mB,GAAGyD,EAAEgjB,EAAEG,EAAEnjB,EAAEynB,SAAStE,EAAE9lB,UAAUquB,WAAW,SAAS1I,EAAEhjB,GAAG,IAAIzD,EAAEV,KAAKgwB,MAAMhd,EAAEmU,EAAE6I,MAAM7sB,EAAEzC,EAAEymB,EAAE,IAAIhjB,EAAEgjB,EAAEhkB,EAAE6P,EAAEmU,IAAIhkB,GAAG,GAAGgB,EAAEhB,GAAG,EAAE,IAAIA,EAAE,EAAEA,EAAE6P,EAAEmU,IAAIhkB,EAAEgB,EAAEhB,EAAEzC,EAAEymB,GAAGzmB,EAAE0tB,GAAG,EAAEpb,EAAE7P,GAAGgB,EAAEhB,EAAE,EAAEzC,EAAEymB,GAAGhjB,EAAEyT,EAAE,EAAEzT,EAAEynB,QAAQ5rB,KAAK4X,GAAGuP,EAAEvP,GAAG0P,EAAE2I,KAAKC,MAAM/rB,EAAEA,IAAImjB,EAAE9lB,UAAUuuB,SAAS,SAAS5I,GAAG,IAAI,IAAIhjB,EAAEnE,KAAKgwB,MAAM1I,EAAEH,EAAEA,EAAE,EAAEhjB,EAAEgjB,IAAIG,GAAG,GAAGH,EAAEG,GAAG,EAAE,IAAIA,EAAE,EAAEA,EAAEnjB,EAAEgjB,EAAE,IAAIG,EAAE,CAAC,IAAI5mB,EAAEyD,EAAEiqB,GAAG9G,EAAEnjB,EAAEmjB,GAAGH,EAAE,EAAEG,EAAE,EAAE,IAAIH,EAAEG,EAAEnjB,EAAEgjB,IAAIhjB,EAAEiqB,GAAG9G,EAAE,EAAE,EAAEnjB,EAAEmjB,GAAGH,EAAE,EAAEG,EAAE,EAAE5mB,EAAEyD,EAAEgjB,EAAEG,EAAE,KAAKnjB,EAAEoqB,KAAKpH,EAAEG,EAAEnjB,EAAEgjB,IAAIhjB,EAAEoqB,GAAGpH,EAAEG,EAAEnjB,EAAEgjB,EAAE,GAAG,GAAGA,EAAEA,EAAE,IAAIA,EAAEA,EAAEA,EAAE,IAAIhjB,EAAEiqB,GAAG9G,EAAEnjB,EAAEmjB,GAAGH,EAAE,EAAEG,EAAE,EAAE,IAAIH,EAAEvP,EAAE,EAAEuP,EAAEyE,SAAStE,EAAE9lB,UAAUmuB,SAAS,SAASxI,EAAEhjB,EAAE6O,GAAG,IAAI7P,EAAEgkB,EAAE6I,MAAM,KAAK7sB,EAAEgkB,GAAG,GAAG,CAAC,IAAIvP,EAAE5X,KAAKgwB,MAAM,GAAGpY,EAAEuP,EAAEhkB,EAAEgkB,EAAE,OAAO,MAAMhjB,GAAGA,EAAEwqB,QAAQ,QAAQ,MAAM3b,GAAGhT,KAAKmwB,OAAOnd,IAAI,MAAMA,IAAIA,EAAEtS,KAAK,IAAIinB,EAAEjnB,IAAImC,EAAE7C,KAAK4X,EAAEgQ,EAAET,EAAEvP,EAAEmQ,EAAE/nB,KAAKquB,GAAGxpB,EAAE1B,EAAEA,EAAEgkB,EAAE,IAAIY,EAAE,GAAG5kB,EAAEmtB,SAASvI,EAAEJ,GAAG/P,EAAE0Y,SAASvI,EAAE/U,KAAK7P,EAAEgtB,OAAOxI,GAAG/P,EAAEuY,OAAOnd,IAAI,IAAIoN,EAAEuH,EAAER,EAAEK,EAAEG,EAAEvH,EAAE,GAAG,GAAG,GAAGoH,EAAE,CAAC,IAAIC,EAAED,GAAG,GAAGxnB,KAAKyuB,KAAKrO,EAAE,EAAEuH,EAAEvH,EAAE,IAAIpgB,KAAK0uB,GAAG,GAAGtG,EAAEpoB,KAAKwuB,GAAG/G,EAAErf,GAAG,GAAGpI,KAAKyuB,IAAIhH,EAAEY,EAAE,GAAGroB,KAAK0uB,GAAGpG,EAAEtV,EAAEmU,EAAEO,EAAEY,EAAElI,EAAEmI,EAAE,MAAMpkB,EAAEzD,IAAIyD,EAAE,IAAIwjB,EAAE0H,UAAU3H,EAAEa,GAAGvV,EAAEyc,UAAUlH,IAAI,IAAIvV,EAAEA,EAAEmU,KAAK,EAAEnU,EAAEkd,MAAM3H,EAAEvV,IAAIsU,EAAE8H,IAAIC,UAAUjP,EAAEmI,GAAGA,EAAE2H,MAAMvI,EAAEA,GAAGA,EAAER,EAAE/G,GAAGuH,EAAEA,EAAER,KAAK,EAAE,OAAOO,GAAG,GAAG,CAAC,IAAI5kB,EAAEkQ,IAAIsV,IAAId,EAAExnB,KAAKsuB,GAAG7E,KAAKkE,MAAM3a,EAAEsV,GAAGF,GAAGpV,EAAEsV,EAAE,GAAGD,GAAGjgB,GAAG,IAAI4K,EAAEsV,IAAIX,EAAEyG,GAAG,EAAEtrB,EAAEkQ,EAAE0U,EAAE,EAAEtH,IAAItd,EAAE,IAAI6kB,EAAE0H,UAAU3H,EAAEa,GAAGvV,EAAEkd,MAAM3H,EAAEvV,GAAGA,EAAEsV,KAAKxlB,GAAGkQ,EAAEkd,MAAM3H,EAAEvV,GAAG,MAAM7O,IAAI6O,EAAEod,UAAUhQ,EAAEjc,GAAGtB,GAAG+kB,GAAGN,EAAE2I,KAAKC,MAAM/rB,EAAEA,IAAI6O,EAAEmU,EAAE/G,EAAEpN,EAAE4Y,QAAQ7D,EAAE,GAAG/U,EAAEud,SAASxI,EAAE/U,GAAGnQ,EAAE,GAAGykB,EAAE2I,KAAKC,MAAMld,EAAEA,MAAMsU,EAAE9lB,UAAUqtB,SAAS,WAAW,GAAG7uB,KAAKmnB,EAAE,EAAE,OAAO,EAAE,IAAIA,EAAEnnB,KAAK,GAAG,GAAG,IAAI,EAAEmnB,GAAG,OAAO,EAAE,IAAIhjB,EAAE,EAAEgjB,EAAE,OAAOhjB,GAAGA,GAAGA,GAAGA,EAAEA,GAAG,GAAG,GAAGgjB,GAAGhjB,GAAG,KAAK,GAAG,IAAIgjB,GAAGhjB,GAAG,MAAM,IAAI,MAAMgjB,GAAGhjB,EAAE,QAAQ,QAAQ,EAAEgjB,EAAEhjB,EAAEnE,KAAKuuB,IAAIvuB,KAAKuuB,IAAI,EAAEvuB,KAAKuuB,GAAGpqB,GAAGA,GAAGmjB,EAAE9lB,UAAUgvB,OAAO,WAAW,OAAO,IAAIxwB,KAAKmnB,EAAE,EAAE,EAAEnnB,KAAK,GAAGA,KAAK4X,IAAI0P,EAAE9lB,UAAUivB,IAAI,SAAStJ,EAAEhjB,GAAG,GAAGgjB,EAAE,YAAYA,EAAE,EAAE,OAAOG,EAAE8H,IAAI,IAAIpc,EAAEtS,IAAIyC,EAAEzC,IAAIkX,EAAEzT,EAAEqrB,QAAQxvB,MAAM2nB,EAAE9iB,EAAEsiB,GAAG,EAAE,IAAIvP,EAAEuY,OAAOnd,KAAK2U,GAAG,GAAG,GAAGxjB,EAAE2rB,MAAM9c,EAAE7P,IAAIgkB,EAAE,GAAGQ,GAAG,EAAExjB,EAAEyrB,MAAMzsB,EAAEyU,EAAE5E,OAAO,CAAC,IAAInQ,EAAEmQ,EAAEA,EAAE7P,EAAEA,EAAEN,EAAE,OAAOsB,EAAEurB,OAAO1c,IAAIsU,EAAE9lB,UAAUM,SAAS,SAASqlB,GAAG,GAAGnnB,KAAK4X,EAAE,EAAE,MAAM,IAAI5X,KAAK0wB,SAAS5uB,SAASqlB,GAAG,IAAIhjB,EAAE,GAAG,IAAIgjB,EAAEhjB,EAAE,OAAO,GAAG,GAAGgjB,EAAEhjB,EAAE,OAAO,GAAG,GAAGgjB,EAAEhjB,EAAE,OAAO,GAAG,IAAIgjB,EAAEhjB,EAAE,MAAM,CAAC,GAAG,GAAGgjB,EAAE,OAAOnnB,KAAK2wB,QAAQxJ,GAAGhjB,EAAE,EAAE,IAAImjB,EAAE5mB,GAAG,GAAGyD,GAAG,EAAE6O,GAAE,EAAG7P,EAAE,GAAGyU,EAAE5X,KAAKmnB,EAAEQ,EAAE3nB,KAAKquB,GAAGzW,EAAE5X,KAAKquB,GAAGlqB,EAAE,GAAGyT,KAAK,EAAE,IAAI+P,EAAE3nB,KAAKquB,KAAK/G,EAAEtnB,KAAK4X,IAAI+P,GAAG,IAAI3U,GAAE,EAAG7P,EAAEN,EAAEykB,IAAI1P,GAAG,GAAG+P,EAAExjB,GAAGmjB,GAAGtnB,KAAK4X,IAAI,GAAG+P,GAAG,IAAIxjB,EAAEwjB,EAAEL,GAAGtnB,OAAO4X,KAAK+P,GAAG3nB,KAAKquB,GAAGlqB,KAAKmjB,EAAEtnB,KAAK4X,KAAK+P,GAAGxjB,GAAGzD,EAAEinB,GAAG,IAAIA,GAAG3nB,KAAKquB,KAAKzW,IAAI0P,EAAE,IAAItU,GAAE,GAAIA,IAAI7P,GAAGN,EAAEykB,IAAI,OAAOtU,EAAE7P,EAAE,KAAKmkB,EAAE9lB,UAAUkvB,OAAO,WAAW,IAAIvJ,EAAEzmB,IAAI,OAAO4mB,EAAE2I,KAAKC,MAAMlwB,KAAKmnB,GAAGA,GAAGG,EAAE9lB,UAAUwuB,IAAI,WAAW,OAAOhwB,KAAK4X,EAAE,EAAE5X,KAAK0wB,SAAS1wB,MAAMsnB,EAAE9lB,UAAUiuB,UAAU,SAAStI,GAAG,IAAIhjB,EAAEnE,KAAK4X,EAAEuP,EAAEvP,EAAE,GAAG,GAAGzT,EAAE,OAAOA,EAAE,IAAImjB,EAAEtnB,KAAKmnB,EAAE,GAAG,IAAIhjB,EAAEmjB,EAAEH,EAAEA,GAAG,OAAOnnB,KAAK4X,EAAE,GAAGzT,EAAEA,EAAE,OAAOmjB,GAAG,GAAG,GAAG,IAAInjB,EAAEnE,KAAKsnB,GAAGH,EAAEG,IAAI,OAAOnjB,EAAE,OAAO,GAAGmjB,EAAE9lB,UAAUovB,UAAU,WAAW,OAAO5wB,KAAKmnB,GAAG,EAAE,EAAEnnB,KAAKquB,IAAIruB,KAAKmnB,EAAE,GAAGtiB,EAAE7E,KAAKA,KAAKmnB,EAAE,GAAGnnB,KAAK4X,EAAE5X,KAAKsuB,KAAKhH,EAAE9lB,UAAUic,IAAI,SAAS0J,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKgwB,MAAML,SAASxI,EAAE,KAAKhjB,GAAGnE,KAAK4X,EAAE,GAAGzT,EAAEsrB,UAAUnI,EAAE2I,MAAM,GAAG9I,EAAE+I,MAAM/rB,EAAEA,GAAGA,GAAGmjB,EAAE9lB,UAAUqvB,UAAU,SAAS1J,EAAEhjB,GAAG,IAAImjB,EAAE,OAAOA,EAAEH,EAAE,KAAKhjB,EAAEqsB,SAAS,IAAIpQ,EAAEjc,GAAG,IAAIqjB,EAAErjB,GAAGnE,KAAKywB,IAAItJ,EAAEG,IAAIA,EAAE2I,KAAKlI,EAAE,GAAGT,EAAE8H,IAAIrH,EAAE,GAAGQ,EAAE/mB,UAAUguB,QAAQ1sB,EAAEylB,EAAE/mB,UAAUkuB,OAAO5sB,EAAEylB,EAAE/mB,UAAUouB,MAAM,SAASzI,EAAEhjB,EAAEmjB,GAAGH,EAAE0I,WAAW1rB,EAAEmjB,IAAIiB,EAAE/mB,UAAUsuB,MAAM,SAAS3I,EAAEhjB,GAAGgjB,EAAE4I,SAAS5rB,IAAIwhB,EAAEnkB,UAAUguB,QAAQ,SAASrI,GAAG,GAAGA,EAAEvP,EAAE,GAAGuP,EAAEA,EAAE,EAAEnnB,KAAKooB,EAAEjB,EAAE,OAAOA,EAAE1J,IAAIzd,KAAKooB,GAAG,GAAGjB,EAAEsI,UAAUzvB,KAAKooB,GAAG,EAAE,OAAOjB,EAAE,IAAIhjB,EAAEzD,IAAI,OAAOymB,EAAEgJ,OAAOhsB,GAAGnE,KAAKyC,OAAO0B,GAAGA,GAAGwhB,EAAEnkB,UAAUkuB,OAAO,SAASvI,GAAG,OAAOA,GAAGxB,EAAEnkB,UAAUiB,OAAO,SAAS0kB,GAAG,IAAIA,EAAEiJ,UAAUpwB,KAAKooB,EAAEjB,EAAE,EAAEnnB,KAAKkvB,IAAI/H,EAAEA,EAAEnnB,KAAKooB,EAAEjB,EAAE,IAAIA,EAAEA,EAAEnnB,KAAKooB,EAAEjB,EAAE,EAAEA,EAAEyE,SAAS5rB,KAAKsvB,GAAGwB,gBAAgB9wB,KAAKkvB,GAAGlvB,KAAKooB,EAAEjB,EAAE,EAAEnnB,KAAKmvB,IAAInvB,KAAKooB,EAAE2I,gBAAgB/wB,KAAKmvB,GAAGnvB,KAAKooB,EAAEjB,EAAE,EAAEnnB,KAAKkvB,IAAI/H,EAAEsI,UAAUzvB,KAAKkvB,IAAI,GAAG/H,EAAE6J,WAAW,EAAEhxB,KAAKooB,EAAEjB,EAAE,GAAG,IAAIA,EAAE+I,MAAMlwB,KAAKkvB,GAAG/H,GAAGA,EAAEsI,UAAUzvB,KAAKooB,IAAI,GAAGjB,EAAE+I,MAAMlwB,KAAKooB,EAAEjB,IAAIxB,EAAEnkB,UAAUouB,MAAM,SAASzI,EAAEhjB,EAAEmjB,GAAGH,EAAE0I,WAAW1rB,EAAEmjB,GAAGtnB,KAAKyC,OAAO6kB,IAAI3B,EAAEnkB,UAAUsuB,MAAM,SAAS3I,EAAEhjB,GAAGgjB,EAAE4I,SAAS5rB,GAAGnE,KAAKyC,OAAO0B,IAAI,IAAIqkB,EAAEoB,EAAEf,EAAEkB,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,KAAKF,GAAG,GAAG,IAAIE,EAAEA,EAAE3pB,OAAO,GAAG,SAAS0pB,IAAI,IAAI3C,EAAEA,GAAE,IAAKtgB,MAAMoqB,UAAUrH,EAAEf,MAAM,IAAI1B,EAAEyC,EAAEf,MAAM1B,GAAG,EAAE,IAAIyC,EAAEf,MAAM1B,GAAG,GAAG,IAAIyC,EAAEf,MAAM1B,GAAG,GAAG,IAAI0B,GAAG6B,IAAI7B,GAAG6B,GAAG,GAAGpD,EAAE9lB,UAAU0vB,UAAU,SAAS/J,GAAG,OAAOsC,KAAKkE,MAAMlE,KAAK0H,IAAInxB,KAAKquB,GAAG5E,KAAK2H,IAAIjK,KAAKG,EAAE9lB,UAAUmvB,QAAQ,SAASxJ,GAAG,GAAG,MAAMA,IAAIA,EAAE,IAAI,GAAGnnB,KAAKqxB,UAAUlK,EAAE,GAAGA,EAAE,GAAG,MAAM,IAAI,IAAIhjB,EAAEnE,KAAKkxB,UAAU/J,GAAGG,EAAEmC,KAAK+D,IAAIrG,EAAEhjB,GAAG6O,EAAE+U,EAAET,GAAGnkB,EAAEzC,IAAIkX,EAAElX,IAAIinB,EAAE,GAAG,IAAI3nB,KAAK2vB,SAAS3c,EAAE7P,EAAEyU,GAAGzU,EAAEkuB,SAAS,GAAG1J,GAAGL,EAAE1P,EAAE0Z,YAAYxvB,SAASqlB,GAAG6E,OAAO,GAAGrE,EAAExkB,EAAEwsB,SAAS3c,EAAE7P,EAAEyU,GAAG,OAAOA,EAAE0Z,WAAWxvB,SAASqlB,GAAGQ,GAAGL,EAAE9lB,UAAU6uB,UAAU,SAASlJ,EAAEhjB,GAAGnE,KAAK2uB,QAAQ,GAAG,MAAMxqB,IAAIA,EAAE,IAAI,IAAI,IAAIzD,EAAEV,KAAKkxB,UAAU/sB,GAAG6O,EAAEyW,KAAK+D,IAAIrpB,EAAEzD,GAAGyC,GAAE,EAAGyU,EAAE,EAAE+P,EAAE,EAAE9kB,EAAE,EAAEA,EAAEskB,EAAE/mB,SAASyC,EAAE,CAAC,IAAIklB,EAAEH,EAAET,EAAEtkB,GAAGklB,EAAE,EAAE,KAAKZ,EAAEpiB,OAAOlC,IAAI,GAAG7C,KAAKqxB,WAAWluB,GAAE,IAAKwkB,EAAExjB,EAAEwjB,EAAEI,IAAInQ,GAAGlX,IAAIV,KAAKuxB,UAAUve,GAAGhT,KAAKgxB,WAAWrJ,EAAE,GAAG/P,EAAE,EAAE+P,EAAE,IAAI/P,EAAE,IAAI5X,KAAKuxB,UAAU9H,KAAK+D,IAAIrpB,EAAEyT,IAAI5X,KAAKgxB,WAAWrJ,EAAE,IAAIxkB,GAAGmkB,EAAE2I,KAAKC,MAAMlwB,KAAKA,OAAOsnB,EAAE9lB,UAAUwsB,WAAW,SAAS7G,EAAEhjB,EAAEzD,GAAG,GAAG,iBAAiByD,EAAE,GAAGgjB,EAAE,EAAEnnB,KAAK2uB,QAAQ,QAAQ,IAAI3uB,KAAKguB,WAAW7G,EAAEzmB,GAAGV,KAAKwxB,QAAQrK,EAAE,IAAInnB,KAAKyxB,UAAUnK,EAAE8H,IAAIsC,UAAUvK,EAAE,GAAGiB,EAAEpoB,MAAMA,KAAKwwB,UAAUxwB,KAAKgxB,WAAW,EAAE,IAAIhxB,KAAK2xB,gBAAgBxtB,IAAInE,KAAKgxB,WAAW,EAAE,GAAGhxB,KAAK4wB,YAAYzJ,GAAGnnB,KAAKkwB,MAAM5I,EAAE8H,IAAIsC,UAAUvK,EAAE,GAAGnnB,UAAU,CAAC,IAAIgT,EAAE,IAAIrR,MAAMwB,EAAE,EAAEgkB,EAAEnU,EAAE5S,OAAO,GAAG+mB,GAAG,GAAGhjB,EAAEytB,UAAU5e,GAAG7P,EAAE,EAAE6P,EAAE,KAAK,GAAG7P,GAAG,EAAE6P,EAAE,GAAG,EAAEhT,KAAKiuB,WAAWjb,EAAE,OAAOsU,EAAE9lB,UAAUiwB,UAAU,SAAStK,EAAEhjB,EAAEmjB,GAAG,IAAI5mB,EAAEsS,EAAE7P,EAAEsmB,KAAKkD,IAAIxF,EAAEA,EAAEnnB,KAAKmnB,GAAG,IAAIzmB,EAAE,EAAEA,EAAEyC,IAAIzC,EAAE4mB,EAAE5mB,GAAGyD,EAAEnE,KAAKU,GAAGymB,EAAEzmB,IAAI,GAAGymB,EAAEA,EAAEnnB,KAAKmnB,EAAE,CAAC,IAAInU,EAAEmU,EAAEvP,EAAE5X,KAAKsuB,GAAG5tB,EAAEyC,EAAEzC,EAAEV,KAAKmnB,IAAIzmB,EAAE4mB,EAAE5mB,GAAGyD,EAAEnE,KAAKU,GAAGsS,GAAGsU,EAAEH,EAAEnnB,KAAKmnB,MAAM,CAAC,IAAInU,EAAEhT,KAAK4X,EAAE5X,KAAKsuB,GAAG5tB,EAAEyC,EAAEzC,EAAEymB,EAAEA,IAAIzmB,EAAE4mB,EAAE5mB,GAAGyD,EAAE6O,EAAEmU,EAAEzmB,IAAI4mB,EAAEH,EAAEA,EAAEA,EAAEG,EAAE1P,EAAEzT,EAAEnE,KAAK4X,EAAEuP,EAAEvP,GAAG0P,EAAEsE,SAAStE,EAAE9lB,UAAUqwB,UAAU,SAAS1K,EAAEhjB,GAAG,IAAIzD,EAAE4mB,EAAE8H,IAAIsC,UAAUvK,GAAG,OAAOnnB,KAAKyxB,UAAU/wB,EAAEyD,EAAEzD,GAAGA,GAAG4mB,EAAE9lB,UAAUswB,MAAM,SAAS3K,EAAEhjB,GAAG,IAAI,IAAImjB,EAAE,EAAE5mB,EAAE,EAAEsS,EAAEyW,KAAKkD,IAAIxF,EAAEA,EAAEnnB,KAAKmnB,GAAGG,EAAEtU,GAAGtS,GAAGV,KAAKsnB,GAAGH,EAAEG,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG,GAAGlH,EAAEA,EAAEnnB,KAAKmnB,EAAE,CAAC,IAAIzmB,GAAGymB,EAAEvP,EAAE0P,EAAEtnB,KAAKmnB,GAAGzmB,GAAGV,KAAKsnB,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG3tB,GAAGV,KAAK4X,MAAM,CAAC,IAAIlX,GAAGV,KAAK4X,EAAE0P,EAAEH,EAAEA,GAAGzmB,GAAGymB,EAAEG,GAAGnjB,EAAEmjB,KAAK5mB,EAAEV,KAAKsuB,GAAG5tB,IAAIV,KAAKquB,GAAG3tB,GAAGymB,EAAEvP,EAAEzT,EAAEyT,EAAElX,EAAE,GAAG,EAAE,EAAEA,EAAE,EAAEyD,EAAEmjB,KAAK5mB,EAAEA,GAAG,IAAIyD,EAAEmjB,KAAKtnB,KAAKuuB,GAAG7tB,GAAGyD,EAAEgjB,EAAEG,EAAEnjB,EAAEynB,SAAStE,EAAE9lB,UAAU+vB,UAAU,SAASpK,GAAGnnB,KAAKA,KAAKmnB,GAAGnnB,KAAKouB,GAAG,EAAEjH,EAAE,EAAEnnB,KAAK,EAAE,EAAEA,KAAKmnB,KAAKnnB,KAAKmnB,EAAEnnB,KAAK4rB,SAAStE,EAAE9lB,UAAUwvB,WAAW,SAAS7J,EAAEhjB,GAAG,GAAG,GAAGgjB,EAAE,CAAC,KAAKnnB,KAAKmnB,GAAGhjB,GAAGnE,KAAKA,KAAKmnB,KAAK,EAAE,IAAInnB,KAAKmE,IAAIgjB,EAAEnnB,KAAKmE,IAAInE,KAAKuuB,IAAIvuB,KAAKmE,IAAInE,KAAKuuB,KAAKpqB,GAAGnE,KAAKmnB,IAAInnB,KAAKA,KAAKmnB,KAAK,KAAKnnB,KAAKmE,KAAKmjB,EAAE9lB,UAAUuvB,gBAAgB,SAAS5J,EAAEhjB,EAAEmjB,GAAG,IAAI5mB,EAAEsS,EAAEyW,KAAKkD,IAAI3sB,KAAKmnB,EAAEA,EAAEA,EAAEhjB,GAAG,IAAImjB,EAAE1P,EAAE,EAAE0P,EAAEH,EAAEnU,EAAEA,EAAE,GAAGsU,IAAItU,GAAG,EAAE,IAAItS,EAAE4mB,EAAEH,EAAEnnB,KAAKmnB,EAAEnU,EAAEtS,IAAIsS,EAAEsU,EAAEtU,EAAEhT,KAAKmnB,GAAGnnB,KAAKouB,GAAG,EAAEjH,EAAEnU,GAAGsU,EAAEtU,EAAE,EAAEhT,KAAKmnB,GAAG,IAAIzmB,EAAE+oB,KAAKkD,IAAIxF,EAAEA,EAAEhjB,GAAG6O,EAAEtS,IAAIsS,EAAEhT,KAAKouB,GAAG,EAAEjH,EAAEnU,GAAGsU,EAAEtU,EAAE,EAAE7O,EAAE6O,GAAGsU,EAAEsE,SAAStE,EAAE9lB,UAAUsvB,gBAAgB,SAAS3J,EAAEhjB,EAAEmjB,KAAKnjB,EAAE,IAAIzD,EAAE4mB,EAAEH,EAAEnnB,KAAKmnB,EAAEA,EAAEA,EAAEhjB,EAAE,IAAImjB,EAAE1P,EAAE,IAAIlX,GAAG,GAAG4mB,EAAE5mB,GAAG,EAAE,IAAIA,EAAE+oB,KAAKgD,IAAItoB,EAAEnE,KAAKmnB,EAAE,GAAGzmB,EAAEymB,EAAEA,IAAIzmB,EAAE4mB,EAAEtnB,KAAKmnB,EAAEzmB,EAAEyD,GAAGnE,KAAKouB,GAAGjqB,EAAEzD,EAAEymB,EAAEzmB,GAAG4mB,EAAE,EAAE,EAAEtnB,KAAKmnB,EAAEzmB,EAAEyD,GAAGmjB,EAAEsE,QAAQtE,EAAE8I,UAAU,EAAE9I,IAAIA,EAAE9lB,UAAUuwB,OAAO,SAAS5K,GAAG,GAAGA,GAAG,EAAE,OAAO,EAAE,IAAIhjB,EAAEnE,KAAKuuB,GAAGpH,EAAEG,EAAEtnB,KAAK4X,EAAE,EAAEuP,EAAE,EAAE,EAAE,GAAGnnB,KAAKmnB,EAAE,EAAE,GAAG,GAAGhjB,EAAEmjB,EAAEtnB,KAAK,GAAGmnB,OAAO,IAAI,IAAIzmB,EAAEV,KAAKmnB,EAAE,EAAEzmB,GAAG,IAAIA,EAAE4mB,GAAGnjB,EAAEmjB,EAAEtnB,KAAKU,IAAIymB,EAAE,OAAOG,GAAGA,EAAE9lB,UAAUwwB,YAAY,SAAS7K,GAAG,IAAIhjB,EAAEnE,KAAKiyB,SAAS3K,EAAE8H,KAAKpc,EAAE7O,EAAE+tB,kBAAkB,GAAGlf,GAAG,EAAE,OAAM,EAAG,IAAI7P,EAAEgB,EAAEguB,WAAWnf,IAAImU,EAAEA,EAAE,GAAG,GAAG4C,EAAE3pB,SAAS+mB,EAAE4C,EAAE3pB,QAAQ,IAAI,IAAIwX,EAAElX,IAAIinB,EAAE,EAAEA,EAAER,IAAIQ,EAAE,CAAC/P,EAAE+W,QAAQ5E,EAAEN,KAAKkE,MAAMlE,KAAKC,SAASK,EAAE3pB,UAAU,IAAIyC,EAAE+U,EAAEwa,OAAOjvB,EAAEnD,MAAM,GAAG,GAAG6C,EAAE4sB,UAAUnI,EAAE8H,MAAM,GAAGvsB,EAAE4sB,UAAUtrB,GAAG,CAAC,IAAI,IAAIyjB,EAAE,EAAEA,IAAI5U,GAAG,GAAGnQ,EAAE4sB,UAAUtrB,IAAI,GAAG,IAAItB,EAAEA,EAAEguB,UAAU,EAAE7wB,OAAOyvB,UAAUnI,EAAE8H,KAAK,OAAM,EAAG,GAAG,GAAGvsB,EAAE4sB,UAAUtrB,GAAG,OAAM,GAAI,OAAM,GAAImjB,EAAE9lB,UAAUgqB,MAAM,WAAW,IAAIrE,EAAEzmB,IAAI,OAAOV,KAAKmwB,OAAOhJ,GAAGA,GAAGG,EAAE9lB,UAAU8vB,SAAS,WAAW,GAAGtxB,KAAK4X,EAAE,EAAE,CAAC,GAAG,GAAG5X,KAAKmnB,EAAE,OAAOnnB,KAAK,GAAGA,KAAKuuB,GAAG,GAAG,GAAGvuB,KAAKmnB,EAAE,OAAO,MAAM,CAAC,GAAG,GAAGnnB,KAAKmnB,EAAE,OAAOnnB,KAAK,GAAG,GAAG,GAAGA,KAAKmnB,EAAE,OAAO,EAAE,OAAOnnB,KAAK,IAAI,GAAG,GAAGA,KAAKquB,IAAI,IAAIruB,KAAKquB,GAAGruB,KAAK,IAAIsnB,EAAE9lB,UAAU6wB,UAAU,WAAW,OAAO,GAAGryB,KAAKmnB,EAAEnnB,KAAK4X,EAAE5X,KAAK,IAAI,IAAI,IAAIsnB,EAAE9lB,UAAU8wB,WAAW,WAAW,OAAO,GAAGtyB,KAAKmnB,EAAEnnB,KAAK4X,EAAE5X,KAAK,IAAI,IAAI,IAAIsnB,EAAE9lB,UAAU6vB,OAAO,WAAW,OAAOrxB,KAAK4X,EAAE,GAAG,EAAE5X,KAAKmnB,GAAG,GAAG,GAAGnnB,KAAKmnB,GAAGnnB,KAAK,IAAI,EAAE,EAAE,GAAGsnB,EAAE9lB,UAAUqc,YAAY,WAAW,IAAIsJ,EAAEnnB,KAAKmnB,EAAEhjB,EAAE,IAAIxC,MAAMwC,EAAE,GAAGnE,KAAK4X,EAAE,IAAI0P,EAAE5mB,EAAEV,KAAKquB,GAAGlH,EAAEnnB,KAAKquB,GAAG,EAAErb,EAAE,EAAE,GAAGmU,KAAK,EAAE,IAAIzmB,EAAEV,KAAKquB,KAAK/G,EAAEtnB,KAAKmnB,IAAIzmB,KAAKV,KAAK4X,EAAE5X,KAAKsuB,KAAK5tB,IAAIyD,EAAE6O,KAAKsU,EAAEtnB,KAAK4X,GAAG5X,KAAKquB,GAAG3tB,GAAGymB,GAAG,GAAGzmB,EAAE,GAAG4mB,GAAGtnB,KAAKmnB,IAAI,GAAGzmB,GAAG,IAAI,EAAEA,EAAE4mB,GAAGtnB,OAAOmnB,KAAKzmB,GAAGV,KAAKquB,GAAG,KAAK/G,EAAEtnB,KAAKmnB,KAAKzmB,GAAG,GAAG,IAAIA,GAAG,IAAIA,GAAGV,KAAKquB,KAAKlH,IAAI,IAAI,IAAIG,KAAKA,IAAI,KAAK,GAAGtU,IAAI,IAAIhT,KAAK4X,KAAK,IAAI0P,MAAMtU,GAAGA,EAAE,GAAGsU,GAAGtnB,KAAK4X,KAAKzT,EAAE6O,KAAKsU,GAAG,OAAOnjB,GAAGmjB,EAAE9lB,UAAU+wB,OAAO,SAASpL,GAAG,OAAO,GAAGnnB,KAAKyvB,UAAUtI,IAAIG,EAAE9lB,UAAUmrB,IAAI,SAASxF,GAAG,OAAOnnB,KAAKyvB,UAAUtI,GAAG,EAAEnnB,KAAKmnB,GAAGG,EAAE9lB,UAAUirB,IAAI,SAAStF,GAAG,OAAOnnB,KAAKyvB,UAAUtI,GAAG,EAAEnnB,KAAKmnB,GAAGG,EAAE9lB,UAAUgxB,IAAI,SAASrL,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKyxB,UAAUtK,EAAEM,EAAEtjB,GAAGA,GAAGmjB,EAAE9lB,UAAUixB,GAAG,SAAStL,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKyxB,UAAUtK,EAAEiB,EAAEjkB,GAAGA,GAAGmjB,EAAE9lB,UAAUkxB,IAAI,SAASvL,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKyxB,UAAUtK,EAAE/e,EAAEjE,GAAGA,GAAGmjB,EAAE9lB,UAAUmxB,OAAO,SAASxL,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKyxB,UAAUtK,EAAEkB,EAAElkB,GAAGA,GAAGmjB,EAAE9lB,UAAUoxB,IAAI,WAAW,IAAI,IAAIzL,EAAEzmB,IAAIyD,EAAE,EAAEA,EAAEnE,KAAKmnB,IAAIhjB,EAAEgjB,EAAEhjB,GAAGnE,KAAKsuB,IAAItuB,KAAKmE,GAAG,OAAOgjB,EAAEA,EAAEnnB,KAAKmnB,EAAEA,EAAEvP,GAAG5X,KAAK4X,EAAEuP,GAAGG,EAAE9lB,UAAUkwB,UAAU,SAASvK,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOymB,EAAE,EAAEnnB,KAAKuwB,UAAUpJ,EAAEhjB,GAAGnE,KAAKswB,SAASnJ,EAAEhjB,GAAGA,GAAGmjB,EAAE9lB,UAAU2wB,WAAW,SAAShL,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOymB,EAAE,EAAEnnB,KAAKswB,UAAUnJ,EAAEhjB,GAAGnE,KAAKuwB,SAASpJ,EAAEhjB,GAAGA,GAAGmjB,EAAE9lB,UAAU0wB,gBAAgB,WAAW,IAAI,IAAI/K,EAAE,EAAEA,EAAEnnB,KAAKmnB,IAAIA,EAAE,GAAG,GAAGnnB,KAAKmnB,GAAG,OAAOA,EAAEnnB,KAAKquB,GAAG/F,EAAEtoB,KAAKmnB,IAAI,OAAOnnB,KAAK4X,EAAE,EAAE5X,KAAKmnB,EAAEnnB,KAAKquB,IAAI,GAAG/G,EAAE9lB,UAAUqxB,SAAS,WAAW,IAAI,IAAI1L,EAAE,EAAEhjB,EAAEnE,KAAK4X,EAAE5X,KAAKsuB,GAAGhH,EAAE,EAAEA,EAAEtnB,KAAKmnB,IAAIG,EAAEH,GAAGO,EAAE1nB,KAAKsnB,GAAGnjB,GAAG,OAAOgjB,GAAGG,EAAE9lB,UAAUgwB,QAAQ,SAASrK,GAAG,IAAIhjB,EAAEslB,KAAKkE,MAAMxG,EAAEnnB,KAAKquB,IAAI,OAAOlqB,GAAGnE,KAAKmnB,EAAE,GAAGnnB,KAAK4X,EAAE,IAAI5X,KAAKmE,GAAG,GAAGgjB,EAAEnnB,KAAKquB,KAAK/G,EAAE9lB,UAAUsxB,OAAO,SAAS3L,GAAG,OAAOnnB,KAAK6xB,UAAU1K,EAAEiB,IAAId,EAAE9lB,UAAUuxB,SAAS,SAAS5L,GAAG,OAAOnnB,KAAK6xB,UAAU1K,EAAEkB,IAAIf,EAAE9lB,UAAUwxB,QAAQ,SAAS7L,GAAG,OAAOnnB,KAAK6xB,UAAU1K,EAAE/e,IAAIkf,EAAE9lB,UAAUyxB,IAAI,SAAS9L,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAK8xB,MAAM3K,EAAEhjB,GAAGA,GAAGmjB,EAAE9lB,UAAUywB,SAAS,SAAS9K,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAKkwB,MAAM/I,EAAEhjB,GAAGA,GAAGmjB,EAAE9lB,UAAU0xB,SAAS,SAAS/L,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAK6vB,WAAW1I,EAAEhjB,GAAGA,GAAGmjB,EAAE9lB,UAAU+tB,OAAO,SAASpI,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAK2vB,SAASxI,EAAEhjB,EAAE,MAAMA,GAAGmjB,EAAE9lB,UAAU2xB,UAAU,SAAShM,GAAG,IAAIhjB,EAAEzD,IAAI,OAAOV,KAAK2vB,SAASxI,EAAE,KAAKhjB,GAAGA,GAAGmjB,EAAE9lB,UAAU4xB,mBAAmB,SAASjM,GAAG,IAAIhjB,EAAEzD,IAAI4mB,EAAE5mB,IAAI,OAAOV,KAAK2vB,SAASxI,EAAEhjB,EAAEmjB,GAAG,IAAI3lB,MAAMwC,EAAEmjB,IAAIA,EAAE9lB,UAAU4wB,OAAO,SAASjL,EAAEhjB,GAAG,IAAImjB,EAAEtU,EAAE7P,EAAEgkB,EAAEyJ,YAAYhZ,EAAEmQ,EAAE,GAAG,GAAG5kB,GAAG,EAAE,OAAOyU,EAAE0P,EAAEnkB,EAAE,GAAG,EAAEA,EAAE,GAAG,EAAEA,EAAE,IAAI,EAAEA,EAAE,IAAI,EAAE,EAAE6P,EAAE7P,EAAE,EAAE,IAAIid,EAAEjc,GAAGA,EAAEqsB,SAAS,IAAI7K,EAAExhB,GAAG,IAAIqjB,EAAErjB,GAAG,IAAIwjB,EAAE,IAAIhmB,MAAMkB,EAAE,EAAE+kB,EAAEN,EAAE,EAAEG,GAAG,GAAGH,GAAG,EAAE,GAAGK,EAAE,GAAG3U,EAAEwc,QAAQxvB,MAAMsnB,EAAE,EAAE,CAAC,IAAIc,EAAE1nB,IAAI,IAAIsS,EAAE8c,MAAMnI,EAAE,GAAGS,GAAGvlB,GAAG4kB,GAAGE,EAAE9kB,GAAGnC,IAAIsS,EAAE4c,MAAMxH,EAAET,EAAE9kB,EAAE,GAAG8kB,EAAE9kB,IAAIA,GAAG,EAAE,IAAIuF,EAAEigB,EAAEC,EAAEnB,EAAEA,EAAE,EAAEO,GAAE,EAAGa,EAAE7nB,IAAI,IAAIyC,EAAE0B,EAAEsiB,EAAEmB,IAAI,EAAEA,GAAG,GAAG,CAAC,IAAInlB,GAAGykB,EAAExf,EAAE+e,EAAEmB,IAAInlB,EAAEykB,EAAEH,GAAGrf,GAAG+e,EAAEmB,IAAI,GAAGnlB,EAAE,GAAG,IAAIykB,EAAEzkB,EAAEmlB,EAAE,IAAIlgB,GAAG+e,EAAEmB,EAAE,IAAItoB,KAAKquB,GAAGlrB,EAAEykB,IAAI/kB,EAAEykB,EAAE,IAAI,EAAElf,IAAIA,IAAI,IAAIvF,EAAE,IAAIM,GAAGN,GAAG,IAAIM,GAAGnD,KAAKquB,KAAK/F,GAAGZ,EAAEC,EAAEvf,GAAG+nB,OAAOvY,GAAG8P,GAAE,MAAO,CAAC,KAAK7kB,EAAE,GAAGmQ,EAAE8c,MAAMlY,EAAE2Q,GAAGvV,EAAE8c,MAAMvH,EAAE3Q,GAAG/U,GAAG,EAAEA,EAAE,EAAEmQ,EAAE8c,MAAMlY,EAAE2Q,IAAIF,EAAEzQ,EAAEA,EAAE2Q,EAAEA,EAAEF,GAAGrV,EAAE4c,MAAMrH,EAAEZ,EAAEvf,GAAGwP,GAAG,KAAK0Q,GAAG,GAAG,IAAInB,EAAEmB,GAAG,GAAGnlB,IAAI6P,EAAE8c,MAAMlY,EAAE2Q,GAAGF,EAAEzQ,EAAEA,EAAE2Q,EAAEA,EAAEF,IAAIllB,EAAE,IAAIA,EAAEnD,KAAKquB,GAAG,IAAI/F,GAAG,OAAOtV,EAAE0c,OAAO9X,IAAI0P,EAAE9lB,UAAU6xB,WAAW,SAASlM,GAAG,IAAIhjB,EAAEgjB,EAAEqJ,SAAS,GAAGxwB,KAAKwwB,UAAUrsB,GAAG,GAAGgjB,EAAEkK,SAAS,OAAO/J,EAAE2I,KAAK,IAAI,IAAIvvB,EAAEymB,EAAEqE,QAAQxY,EAAEhT,KAAKwrB,QAAQroB,EAAE4kB,EAAE,GAAGnQ,EAAEmQ,EAAE,GAAGJ,EAAEI,EAAE,GAAGllB,EAAEklB,EAAE,GAAG,GAAGrnB,EAAE2wB,UAAU,CAAC,KAAK3wB,EAAE8vB,UAAU9vB,EAAE6vB,SAAS,EAAE7vB,GAAGyD,GAAGhB,EAAEqtB,UAAU5Y,EAAE4Y,WAAWrtB,EAAE2uB,MAAM9xB,KAAKmD,GAAGyU,EAAEsY,MAAM/I,EAAEvP,IAAIzU,EAAEotB,SAAS,EAAEptB,IAAIyU,EAAE4Y,UAAU5Y,EAAEsY,MAAM/I,EAAEvP,GAAGA,EAAE2Y,SAAS,EAAE3Y,GAAG,KAAK5E,EAAEwd,UAAUxd,EAAEud,SAAS,EAAEvd,GAAG7O,GAAGwjB,EAAE6I,UAAU3tB,EAAE2tB,WAAW7I,EAAEmK,MAAM9xB,KAAK2nB,GAAG9kB,EAAEqtB,MAAM/I,EAAEtkB,IAAI8kB,EAAE4I,SAAS,EAAE5I,IAAI9kB,EAAE2tB,UAAU3tB,EAAEqtB,MAAM/I,EAAEtkB,GAAGA,EAAE0tB,SAAS,EAAE1tB,GAAGnC,EAAE+uB,UAAUzc,IAAI,GAAGtS,EAAEwvB,MAAMld,EAAEtS,GAAGyD,GAAGhB,EAAE+sB,MAAMvI,EAAExkB,GAAGyU,EAAEsY,MAAMrtB,EAAE+U,KAAK5E,EAAEkd,MAAMxvB,EAAEsS,GAAG7O,GAAGwjB,EAAEuI,MAAM/sB,EAAEwkB,GAAG9kB,EAAEqtB,MAAMtY,EAAE/U,IAAI,OAAO,GAAGmQ,EAAEyc,UAAUnI,EAAE8H,KAAK9H,EAAE2I,KAAKptB,EAAE4sB,UAAUtI,IAAI,EAAEtkB,EAAEovB,SAAS9K,GAAGtkB,EAAEwuB,SAAS,GAAGxuB,EAAEivB,MAAM3K,EAAEtkB,GAAGA,EAAEwuB,SAAS,EAAExuB,EAAEowB,IAAI9L,GAAGtkB,GAAGA,GAAGykB,EAAE9lB,UAAUgsB,IAAI,SAASrG,GAAG,OAAOnnB,KAAKywB,IAAItJ,EAAE,IAAIoB,IAAIjB,EAAE9lB,UAAU8xB,IAAI,SAASnM,GAAG,IAAIhjB,EAAEnE,KAAK4X,EAAE,EAAE5X,KAAK0wB,SAAS1wB,KAAKwrB,QAAQlE,EAAEH,EAAEvP,EAAE,EAAEuP,EAAEuJ,SAASvJ,EAAEqE,QAAQ,GAAGrnB,EAAEsrB,UAAUnI,GAAG,EAAE,CAAC,IAAI5mB,EAAEyD,EAAEA,EAAEmjB,EAAEA,EAAE5mB,EAAE,IAAIsS,EAAE7O,EAAE+tB,kBAAkB/uB,EAAEmkB,EAAE4K,kBAAkB,GAAG/uB,EAAE,EAAE,OAAOgB,EAAE,IAAI6O,EAAE7P,IAAIA,EAAE6P,GAAG7P,EAAE,IAAIgB,EAAEosB,SAASptB,EAAEgB,GAAGmjB,EAAEiJ,SAASptB,EAAEmkB,IAAInjB,EAAEktB,SAAS,IAAIre,EAAE7O,EAAE+tB,mBAAmB,GAAG/tB,EAAEosB,SAASvd,EAAE7O,IAAI6O,EAAEsU,EAAE4K,mBAAmB,GAAG5K,EAAEiJ,SAASvd,EAAEsU,GAAGnjB,EAAEsrB,UAAUnI,IAAI,GAAGnjB,EAAE+rB,MAAM5I,EAAEnjB,GAAGA,EAAEosB,SAAS,EAAEpsB,KAAKmjB,EAAE4I,MAAM/rB,EAAEmjB,GAAGA,EAAEiJ,SAAS,EAAEjJ,IAAI,OAAOnkB,EAAE,GAAGmkB,EAAEgJ,SAASntB,EAAEmkB,GAAGA,GAAGA,EAAE9lB,UAAUmwB,gBAAgB,SAASxK,GAAG,IAAIhjB,EAAEmjB,EAAEtnB,KAAKgwB,MAAM,GAAG,GAAG1I,EAAEH,GAAGG,EAAE,IAAIyC,EAAEA,EAAE3pB,OAAO,GAAG,CAAC,IAAI+D,EAAE,EAAEA,EAAE4lB,EAAE3pB,SAAS+D,EAAE,GAAGmjB,EAAE,IAAIyC,EAAE5lB,GAAG,OAAM,EAAG,OAAM,EAAG,GAAGmjB,EAAEkJ,SAAS,OAAM,EAAG,IAAIrsB,EAAE,EAAEA,EAAE4lB,EAAE3pB,QAAQ,CAAC,IAAI,IAAIM,EAAEqpB,EAAE5lB,GAAG6O,EAAE7O,EAAE,EAAE6O,EAAE+W,EAAE3pB,QAAQM,EAAEmpB,GAAGnpB,GAAGqpB,EAAE/W,KAAK,IAAItS,EAAE4mB,EAAEyK,OAAOrxB,GAAGyD,EAAE6O,GAAG,GAAGtS,EAAEqpB,EAAE5lB,MAAM,EAAE,OAAM,EAAG,OAAOmjB,EAAE0K,YAAY7K,IAAIG,EAAE9lB,UAAU+xB,OAAO,WAAW,IAAIpM,EAAEzmB,IAAI,OAAOV,KAAK+vB,SAAS5I,GAAGA,GAAGG,EAAE9lB,UAAUgyB,QAAQ7N,EAAE,MAAMiE,EAAE,CAAC,IAAI/c,EAAE,GAAG+c,EAAE,IAAIjoB,MAAMknB,EAAE,EAAE,oBAAoB5R,QAAQA,OAAOwc,OAAO,GAAGxc,OAAOwc,OAAOC,gBAAgB,CAAC,IAAIzJ,EAAE,IAAI/M,WAAW,IAAI,IAAIjG,OAAOwc,OAAOC,gBAAgBzJ,GAAGpd,EAAE,EAAEA,EAAE,KAAKA,EAAE+c,EAAEf,KAAKoB,EAAEpd,QAAQ,GAAG,YAAYqhB,UAAUC,SAASD,UAAUyF,WAAW,IAAI,CAAC,IAAIhL,EAAE1R,OAAOwc,OAAO/J,OAAO,IAAI,IAAI7c,EAAE,EAAEA,EAAE8b,EAAEvoB,SAASyM,EAAE+c,EAAEf,KAAK,IAAIF,EAAE7jB,WAAW+H,GAAG,KAAKgc,EAAE6B,GAAG7d,EAAE4c,KAAKkE,MAAM,MAAMlE,KAAKC,UAAUE,EAAEf,KAAKhc,IAAI,EAAE+c,EAAEf,KAAK,IAAIhc,EAAEgc,EAAE,EAAEiB,IAAI,SAASK,IAAI,GAAG,MAAM3B,EAAE,CAAC,IAAIsB,KAAKtB,EAAE,IAAIjlB,GAAGqgB,KAAKgG,GAAGf,EAAE,EAAEA,EAAEe,EAAExpB,SAASyoB,EAAEe,EAAEf,GAAG,EAAEA,EAAE,EAAE,OAAOL,EAAE7G,OAAO,SAAS8G,KAAK,SAASllB,IAAIvD,KAAKU,EAAE,EAAEV,KAAKuD,EAAE,EAAEvD,KAAKwoB,EAAE,IAAI7mB,MAAM8mB,EAAEjnB,UAAUowB,UAAU,SAASzK,GAAG,IAAIhjB,EAAE,IAAIA,EAAE,EAAEA,EAAEgjB,EAAE/mB,SAAS+D,EAAEgjB,EAAEhjB,GAAGgmB,KAAK5mB,EAAE/B,UAAUoiB,KAAK,SAASuD,GAAG,IAAIhjB,EAAEmjB,EAAE5mB,EAAE,IAAIyD,EAAE,EAAEA,EAAE,MAAMA,EAAEnE,KAAKwoB,EAAErkB,GAAGA,EAAE,IAAImjB,EAAE,EAAEnjB,EAAE,EAAEA,EAAE,MAAMA,EAAEzD,EAAEV,KAAKwoB,EAAErkB,GAAGnE,KAAKwoB,EAAErkB,GAAGnE,KAAKwoB,EAAElB,EAAEA,EAAEtnB,KAAKwoB,EAAErkB,GAAGgjB,EAAEhjB,EAAEgjB,EAAE/mB,QAAQ,KAAKJ,KAAKwoB,EAAElB,GAAG5mB,EAAEV,KAAKU,EAAE,EAAEV,KAAKuD,EAAE,GAAGA,EAAE/B,UAAUmgB,KAAK,WAAW,IAAIwF,EAAE,OAAOnnB,KAAKU,EAAEV,KAAKU,EAAE,EAAE,IAAIV,KAAKuD,EAAEvD,KAAKuD,EAAEvD,KAAKwoB,EAAExoB,KAAKU,GAAG,IAAIymB,EAAEnnB,KAAKwoB,EAAExoB,KAAKU,GAAGV,KAAKwoB,EAAExoB,KAAKU,GAAGV,KAAKwoB,EAAExoB,KAAKuD,GAAGvD,KAAKwoB,EAAExoB,KAAKuD,GAAG4jB,EAAEnnB,KAAKwoB,EAAErB,EAAEnnB,KAAKwoB,EAAExoB,KAAKU,GAAG,MAAM,IAAIgqB,EAAE,IAAIvmB,EAAE9C,QAAQ,CAAC2E,QAAQshB,EAAEsM,WAAWtM,EAAEuM,aAAapL,KAAKtnB,KAAKgmB,MAAKtkB,EAAE,CAACixB,KAAK,iCAAiCC,OAAO,yCAAyCC,OAAO,yCAAyCC,OAAO,yCAAyCC,OAAO,yCAAyCC,IAAI,uCAAuCC,IAAI,uCAAuCC,UAAU,kCAAkCzM,EAAE,CAACoM,OAAOhhB,GAAG,SAAS+U,EAAEZ,EAAEhjB,GAAG,GAAGnE,KAAKgT,EAAE,KAAKhT,KAAKmE,EAAE,IAAI,MAAMgjB,GAAG,MAAMhjB,GAAGgjB,EAAE/mB,OAAO,GAAG+D,EAAE/D,OAAO,GAAG,MAAM,IAAI2Q,MAAM,oBAAoB/Q,KAAKgT,EAAE,IAAI2U,EAAEiM,WAAWzM,EAAE,IAAInnB,KAAKmE,EAAEQ,SAASR,EAAE,IAAI4jB,EAAEvmB,UAAU8yB,OAAO,SAASnN,EAAEhjB,GAAGA,EAAEA,EAAE1D,QAAQ,sBAAsB,IAAI,IAAI6mB,EAAE,IAAIK,EAAEiM,WAAWzvB,EAAE,IAAI,GAAGmjB,EAAEsJ,YAAY5wB,KAAKgT,EAAE4d,YAAY,MAAM,IAAI7f,MAAM,kDAAkD,IAAIrQ,EAAE,SAASymB,GAAG,IAAI,IAAIhjB,KAAKtB,EAAE,CAAC,IAAIykB,EAAEzkB,EAAEsB,GAAGzD,EAAE4mB,EAAElnB,OAAO,GAAG+mB,EAAEwC,UAAU,EAAEjpB,KAAK4mB,EAAE,MAAM,CAACiN,IAAIpwB,EAAE4b,KAAKoH,EAAEwC,UAAUjpB,IAAI,MAAM,GAAlH,CAAsH4mB,EAAEuJ,UAAU7wB,KAAKmE,EAAEnE,KAAKgT,GAAGlR,SAAS,IAAIrB,QAAQ,SAAS,KAAK,GAAG,IAAIC,EAAEN,OAAO,OAAM,EAAG,IAAIwnB,EAAEnmB,eAAef,EAAE6zB,KAAK,MAAM,IAAIxjB,MAAM,uCAAuC,IAAIiC,EAAE4U,EAAElnB,EAAE6zB,KAAKpN,GAAGrlB,WAAW,OAAOpB,EAAEqf,OAAO/M,GAAG,IAAI,IAAInO,EAAE,GAAGub,EAAE,GAAGoH,EAAE,oBAAoBtK,WAAWA,WAAWvb,MAAM8lB,EAAE,mEAAmEW,EAAE,EAAEhgB,EAAEqf,EAAErnB,OAAOgoB,EAAEhgB,IAAIggB,EAAEvjB,EAAEujB,GAAGX,EAAEW,GAAGhI,EAAEqH,EAAE3iB,WAAWsjB,IAAIA,EAAEhI,EAAE,IAAItb,WAAW,IAAI,GAAGsb,EAAE,IAAItb,WAAW,IAAI,GAAG,IAAIujB,EAAE,SAASlB,GAAG,IAAIhjB,EAAEmjB,EAAE5mB,EAAE,SAASymB,GAAG,IAAIhjB,EAAEgjB,EAAE/mB,OAAO,GAAG+D,EAAE,EAAE,EAAE,MAAM,IAAI4M,MAAM,kDAAkD,IAAIuW,EAAEH,EAAE1jB,QAAQ,KAAK,OAAO,IAAI6jB,IAAIA,EAAEnjB,GAAG,CAACmjB,EAAEA,IAAInjB,EAAE,EAAE,EAAEmjB,EAAE,GAA9J,CAAkKH,GAAGnU,EAAEtS,EAAE,GAAGyC,EAAEzC,EAAE,GAAGkX,EAAE,IAAI4P,EAAE,SAASL,EAAEhjB,EAAEmjB,GAAG,OAAO,GAAGnjB,EAAEmjB,GAAG,EAAEA,EAAjC,CAAoC,EAAEtU,EAAE7P,IAAIwkB,EAAE,EAAE9kB,EAAEM,EAAE,EAAE6P,EAAE,EAAEA,EAAE,IAAIsU,EAAE,EAAEA,EAAEzkB,EAAEykB,GAAG,EAAEnjB,EAAEic,EAAE+G,EAAEriB,WAAWwiB,KAAK,GAAGlH,EAAE+G,EAAEriB,WAAWwiB,EAAE,KAAK,GAAGlH,EAAE+G,EAAEriB,WAAWwiB,EAAE,KAAK,EAAElH,EAAE+G,EAAEriB,WAAWwiB,EAAE,IAAI1P,EAAE+P,KAAKxjB,GAAG,GAAG,IAAIyT,EAAE+P,KAAKxjB,GAAG,EAAE,IAAIyT,EAAE+P,KAAK,IAAIxjB,EAAE,OAAO,IAAIhB,IAAIgB,EAAEic,EAAE+G,EAAEriB,WAAWwiB,KAAK,EAAElH,EAAE+G,EAAEriB,WAAWwiB,EAAE,KAAK,EAAE1P,EAAE+P,KAAK,IAAIxjB,GAAG,IAAIhB,IAAIgB,EAAEic,EAAE+G,EAAEriB,WAAWwiB,KAAK,GAAGlH,EAAE+G,EAAEriB,WAAWwiB,EAAE,KAAK,EAAElH,EAAE+G,EAAEriB,WAAWwiB,EAAE,KAAK,EAAE1P,EAAE+P,KAAKxjB,GAAG,EAAE,IAAIyT,EAAE+P,KAAK,IAAIxjB,GAAGyT,GAAG,SAAS0Q,EAAEnB,GAAG,IAAIhjB,EAAEgjB,EAAE/mB,OAAO,EAAE,OAAO,IAAI+D,EAAEgjB,EAAEA,EAAE,IAAIxlB,MAAM,EAAEwC,EAAE,GAAGrD,KAAK,KAAK,SAAS4mB,EAAEP,GAAG,OAAOA,EAAEmB,EAAEnB,GAAG1mB,QAAQ,MAAM,KAAKA,QAAQ,KAAK,KAAKyD,mBAAmB,SAASijB,GAAG,IAAI,IAAIhjB,EAAE,GAAGmjB,EAAE,EAAEA,EAAEH,EAAE/mB,OAAOknB,IAAInjB,GAAGK,OAAOwE,aAAame,EAAEG,IAAI,OAAOnjB,EAAhF,CAAmFkkB,EAAElB,IAAInmB,MAAM,IAAIwzB,KAAI,SAASrN,GAAG,MAAM,KAAK,KAAKA,EAAEriB,WAAW,GAAGhD,SAAS,KAAKZ,OAAO,MAAKJ,KAAK,KAAK,SAASynB,EAAEpB,GAAG,OAAO,SAASA,GAAG,IAAI,IAAIhjB,EAAE,GAAGmjB,EAAE,EAAEA,EAAEH,EAAE/mB,OAAOknB,IAAI,CAAC,IAAI5mB,EAAEymB,EAAEG,GAAGxlB,SAAS,IAAIqC,GAAG,IAAIzD,EAAEN,OAAOM,EAAE,IAAIA,EAAE,OAAOyD,EAApG,CAAuGkkB,EAAEC,EAAEnB,KAAK,IAAIrkB,EAAEqB,GAAE,SAASA,GAAG,IAAImjB,EAAE5mB,EAAE4mB,EAAEH,EAAEzmB,EAAE,WAAW,SAASymB,EAAEA,GAAG,IAAIhjB,EAAE,GAAG,GAAG,IAAIgjB,EAAE/mB,OAAO,MAAM,GAAG,GAAG,iBAAiB+mB,EAAE,GAAG,MAAM,IAAI9mB,UAAU,kCAAkC8mB,EAAE,IAAI,GAAGA,EAAE,GAAG7mB,MAAM,iBAAiB6mB,EAAE/mB,OAAO,EAAE,CAAC,IAAIknB,EAAEH,EAAE3mB,QAAQ2mB,EAAE,GAAGG,EAAEH,EAAE,GAAGA,EAAE,GAAGA,EAAE,GAAG7mB,MAAM,gBAAgB6mB,EAAE,GAAG1mB,QAAQ,gBAAgB,UAAU0mB,EAAE,GAAG1mB,QAAQ,gBAAgB,SAAS,IAAI,IAAIC,EAAE,EAAEA,EAAEymB,EAAE/mB,OAAOM,IAAI,CAAC,IAAIsS,EAAEmU,EAAEzmB,GAAG,GAAG,iBAAiBsS,EAAE,MAAM,IAAI3S,UAAU,kCAAkC2S,GAAG,KAAKA,IAAItS,EAAE,IAAIsS,EAAEA,EAAEvS,QAAQ,SAAS,KAAKuS,EAAEA,EAAEvS,QAAQ,SAASC,EAAEymB,EAAE/mB,OAAO,EAAE,GAAG,KAAK+D,EAAEvD,KAAKoS,IAAI,IAAI7P,EAAEgB,EAAErD,KAAK,KAAK8W,GAAGzU,EAAEA,EAAE1C,QAAQ,kBAAkB,OAAOO,MAAM,KAAK,OAAO4W,EAAEpX,SAASoX,EAAExX,OAAO,EAAE,IAAI,IAAIwX,EAAE9W,KAAK,KAAK,OAAO,WAAW,OAAOqmB,EAAE,iBAAiBlmB,UAAU,GAAGA,UAAU,GAAG,GAAGC,MAAMC,KAAKF,cAAckD,EAAE9C,QAAQ8C,EAAE9C,QAAQX,IAAI4mB,EAAEmN,QAAQ/zB,OAAM,SAASilB,EAAEwB,EAAEhjB,GAAG,OAAOA,EAAEA,GAAG,GAAG,IAAI2M,SAAQ,SAASwW,EAAE5mB,GAAG,IAAIsS,EAAE,IAAIoE,eAAejU,EAAE,GAAGyU,EAAE,GAAG+P,EAAE,GAAG9kB,EAAE,WAAW,MAAM,CAACwO,GAAG,IAAI2B,EAAEpD,OAAO,IAAI,GAAG6I,WAAWzF,EAAEyF,WAAW7I,OAAOoD,EAAEpD,OAAOqB,IAAI+B,EAAE0hB,YAAYnc,KAAK,WAAW,OAAOzH,QAAQN,QAAQwC,EAAEwF,eAAeiB,KAAK,WAAW,OAAO3I,QAAQN,QAAQpD,KAAKa,MAAM+E,EAAEwF,gBAAgBmc,KAAK,WAAW,OAAO7jB,QAAQN,QAAQ,IAAIokB,KAAK,CAAC5hB,EAAEnE,aAAa2c,MAAM3oB,EAAEwQ,QAAQ,CAAC7Q,KAAK,WAAW,OAAOW,GAAG0xB,QAAQ,WAAW,OAAOjd,GAAG3K,IAAI,SAASka,GAAG,OAAOQ,EAAER,EAAEzV,gBAAgBpQ,IAAI,SAAS6lB,GAAG,OAAOA,EAAEzV,gBAAgBiW,MAAM,IAAI,IAAIC,KAAK5U,EAAE2I,KAAKxX,EAAE6M,QAAQ,MAAMmW,GAAE,GAAInU,EAAE8hB,OAAO,WAAW9hB,EAAE8F,wBAAwBrY,QAAQ,gCAA+B,SAAS0mB,EAAEhjB,EAAEmjB,GAAGnkB,EAAEvC,KAAKuD,EAAEA,EAAEuN,eAAekG,EAAEhX,KAAK,CAACuD,EAAEmjB,IAAIK,EAAExjB,GAAGwjB,EAAExjB,GAAGwjB,EAAExjB,GAAG,IAAImjB,EAAEA,KAAIA,EAAEzkB,MAAMmQ,EAAE+hB,QAAQr0B,EAAEsS,EAAEH,gBAAgB,WAAW1O,EAAE6wB,YAAY7wB,EAAEkP,QAAQL,EAAE8I,iBAAiB8L,EAAEzjB,EAAEkP,QAAQuU,IAAI5U,EAAEM,KAAKnP,EAAE6U,MAAM,SAAQ,SAASwP,EAAErB,GAAG,GAAGA,EAAE9V,GAAG,OAAO8V,EAAE1N,OAAO,IAAItV,EAAE,IAAI4M,MAAMoW,EAAE1O,YAAY,OAAOtU,EAAE0K,SAASsY,EAAErW,QAAQL,OAAOtM,GAAG,SAASylB,EAAEzC,GAAGnnB,KAAKgS,KAAK,qBAAqBhS,KAAKse,QAAQ6I,GAAG,GAAG,SAAS0B,EAAE1B,GAAGnnB,KAAKgS,KAAK,uBAAuBhS,KAAKse,QAAQ6I,GAAG,GAAGyC,EAAEpoB,UAAUuP,MAAMvP,UAAUqnB,EAAErnB,UAAUuP,MAAMvP,UAAU,IAAIuoB,EAAE,WAAW,SAAS5C,KAAK,IAAIhjB,EAAEgjB,EAAE3lB,UAAU,OAAO2C,EAAE8I,IAAI,WAAW,OAAO,MAAM9I,EAAE7C,IAAI,WAAW,OAAO,MAAM6C,EAAEyN,IAAI,WAAW,OAAO,MAAMuV,EAA5I,GAAiJG,EAAE4D,WAAW,IAAIrB,EAAE,SAAS1C,GAAG,MAAM,iBAAiBA,GAAG2C,EAAE,WAAW,OAAO,IAAIjjB,MAAM,SAASgG,EAAEsa,GAAG,IAAIhjB,EAAEgjB,GAAG,GAAG,GAAGnnB,KAAKi1B,UAAU9wB,EAAE8wB,WAAW,IAAIlL,EAAE/pB,KAAKk1B,YAAY/wB,EAAE+wB,aAAa,QAAQl1B,KAAKm1B,OAAOhxB,EAAEgxB,OAAOn1B,KAAKo1B,SAASjxB,EAAEixB,SAASp1B,KAAKq1B,OAAO,IAAIlxB,EAAEkxB,OAAO,EAAElxB,EAAEkxB,QAAQ,GAAGr1B,KAAKs1B,QAAQnxB,EAAEmxB,QAAQt1B,KAAKu1B,OAAOpxB,EAAEoxB,OAAOv1B,KAAKw1B,QAAQ,mBAAmBrxB,EAAEqxB,QAAQrxB,EAAEqxB,QAAQ1L,EAAE9pB,KAAKq1B,OAAO,GAAGr1B,KAAKq1B,OAAO,IAAI,MAAM,IAAIzL,EAAE,8DAA8D,GAAG,UAAU5pB,KAAKk1B,YAAY,MAAM,IAAItL,EAAE,2BAA2B5pB,KAAKk1B,YAAY,wECE11mC,SAASO,cAAcC,QAASC,SAC9B31B,KAAK21B,QAAUA,QAEf,IAAK,IAAI9yB,EAAI,EAAGA,EAAI7C,KAAK21B,QAAQv1B,OAAQyC,IAAK,CAC5C,GAAI7C,KAAK21B,QAAQ9yB,GAAGmgB,UAAYA,QAAQlF,IAAK,CAC3C,IAAI8X,WAAa,GAMjB,MAJI51B,KAAK21B,QAAQ9yB,GAAGoC,aAAejF,KAAK21B,QAAQ9yB,GAAGoC,YAAY+M,OAC7D4jB,WAAa51B,KAAK21B,QAAQ9yB,GAAGoC,YAAY+M,MAGrC,IAAIjB,MACR,UACE6kB,WACA,aACA51B,KAAK21B,QAAQ9yB,GAAGmgB,QAHlB,6CAMEA,QAAQlF,IACR,KAIN9d,KAAK21B,QAAQ9yB,GAAGgzB,WAAWH,UDzBm4mC7oB,EAAErL,UAAU8yB,OAAO,SAASnN,EAAEhjB,EAAEmjB,GAAG,IAAIH,EAAE,OAAOG,EAAE,IAAIuB,EAAE,qCAAoC,GAAI,IAAInoB,EAAEV,KAAK6D,OAAOsjB,GAAG,GAAGzmB,aAAaqQ,MAAM,OAAOuW,EAAE,IAAIuB,EAAE,kCAAiC,GAAI,IAAI7V,EAAEtS,EAAEo1B,QAAQhkB,OAAO,IAAIpR,EAAEo1B,QAAQC,QAAQ5yB,EAAEolB,EAAE7nB,EAAEo1B,QAAQE,WAAWpe,EAAElX,EAAEoR,OAAOyiB,IAAI5M,EAAEjnB,EAAEoR,OAAOmkB,IAAIpzB,EAAEnC,EAAEq1B,QAAQG,IAAItO,EAAElnB,EAAEq1B,QAAQlQ,IAAIkC,EAAErnB,EAAEq1B,QAAQI,IAAItxB,EAAEnE,EAAEq1B,QAAQtF,IAAIrQ,EAAE1f,EAAEq1B,QAAQK,IAAI5O,EAAE9mB,EAAEq1B,QAAQM,IAAI5O,EAAE/mB,EAAEq1B,QAAQO,IAAIlO,EAAE1nB,EAAEq1B,QAAQQ,UAAUnuB,EAAE1H,EAAEq1B,QAAQS,MAAMnO,EAAEroB,KAAKw1B,UAAUlN,EAAEtoB,KAAK,GAAGsoB,EAAE4M,cAActd,EAAE,OAAO0P,EAAE,IAAIuB,EAAE,2BAA2BjR,EAAE,yEAAwE,GAAI5X,KAAKy2B,eAAe1O,EAAEJ,GAAE,SAASR,EAAEvP,GAAG,GAAGuP,EAAE,OAAOG,EAAEH,GAAG,IAAIvP,EAAE0c,OAAOthB,EAAE7P,GAAG,OAAOmkB,EAAE,IAAIuB,EAAE,gCAAgC,IAAId,GAAG,iBAAiBA,EAAE,OAAOT,EAAE,IAAIuB,EAAE,+DAA8D,IAAK,GAAGP,EAAE6M,SAASpN,EAAE,OAAOT,EAAE,IAAIuB,EAAE,0DAA0DP,EAAE6M,OAAO,aAAapN,EAAE,MAAK,GAAI,IAAIH,GAAG,iBAAiBA,EAAE,OAAON,EAAE,IAAIuB,EAAE,iEAAgE,GAAI,IAAIhmB,GAAG,iBAAiBA,IAAIlB,MAAMD,QAAQmB,GAAG,OAAOykB,EAAE,IAAIuB,EAAE,sFAAsF,GAAGlnB,MAAMD,QAAQmB,KAAKA,EAAEiN,SAASwY,EAAE8M,UAAU,OAAO9N,EAAE,IAAIuB,EAAE,4DAA4DP,EAAE8M,SAAS,yBAAyBvyB,EAAE/B,KAAK,MAAM,MAAM,GAAG,iBAAiB+B,GAAGylB,EAAE8M,WAAWvyB,EAAE,OAAOykB,EAAE,IAAIuB,EAAE,4DAA4DP,EAAE8M,SAAS,gBAAgBvyB,EAAE,MAAK,GAAI,GAAGsB,EAAE,CAAC,IAAIiE,GAAG,iBAAiBA,EAAE,OAAOkf,EAAE,IAAIuB,EAAE,iEAAgE,GAAI,GAAGzgB,IAAIjE,EAAE,OAAOmjB,EAAE,IAAIuB,EAAE,iEAAiE1kB,EAAE,aAAaiE,EAAE,MAAK,GAAI,GAAGzG,MAAMD,QAAQmB,IAAIA,EAAEzC,OAAO,EAAE,CAAC,IAAIqnB,GAAG,iBAAiBA,EAAE,OAAOH,EAAE,IAAIuB,EAAE,uHAAsH,IAAK,GAAGpB,IAAIa,EAAE8M,SAAS,OAAO9N,EAAE,IAAIuB,EAAE,oEAAoEP,EAAE8M,SAAS,aAAa3N,EAAE,KAAI,IAAK,IAAI5iB,IAAIglB,EAAEhlB,GAAG,OAAOyiB,EAAE,IAAIuB,EAAE,wEAAuE,IAAK,IAAIrB,IAAIqC,EAAErC,GAAG,OAAOF,EAAE,IAAIuB,EAAE,mEAAmE,IAAIlB,EAAE9iB,EAAEyjB,EAAE+M,OAAO3N,EAAE,IAAI7gB,KAAK,GAAG,GAAG6gB,EAAEgP,cAAc/O,GAAGU,EAAEX,EAAE,OAAOJ,EAAE,IAAIuB,EAAE,oEAAoER,EAAE,+BAA+BX,EAAE,KAAI,IAAK,GAAGtH,GAAGyJ,EAAEzJ,GAAG,CAAC,IAAImI,EAAEnI,EAAEkI,EAAE+M,OAAOvyB,EAAE,IAAI+D,KAAK,GAAG,GAAG/D,EAAE4zB,cAAcnO,GAAGF,EAAEvlB,EAAE,OAAOwkB,EAAE,IAAIuB,EAAE,oEAAoER,EAAE,oCAAoCvlB,EAAE,MAAM,GAAGwlB,EAAEiN,OAAO,CAAC,IAAInN,IAAIyB,EAAEzB,GAAG,OAAOd,EAAE,IAAIuB,EAAE,uHAAuH,IAAIlD,EAAEyC,EAAEE,EAAEiN,OAAOjN,EAAE+M,OAAO7M,EAAE,IAAI3hB,KAAK,GAAG,GAAG2hB,EAAEkO,cAAc/Q,GAAG0C,EAAEG,EAAE,OAAOlB,EAAE,IAAIuB,EAAE,uJAAuJR,EAAE,iCAAiCG,EAAE,MAAM,OAAOlB,EAAE,KAAK5mB,EAAEq1B,aAAYlpB,EAAErL,UAAUi1B,eAAe,SAAStP,EAAEhjB,EAAEmjB,GAAG,IAAI5mB,EAAEV,KAAKgT,EAAEmU,EAAEhjB,EAAE2M,QAAQN,QAAQxQ,KAAKi1B,UAAU3zB,IAAI0R,IAAIzC,MAAK,SAAS+W,GAAG,OAAOA,EAAE5mB,EAAEu0B,UAAUhoB,IAAI+F,IAAI7P,EAAE,CAACmyB,QAAQ50B,EAAE40B,QAAQa,IAAIhP,EAAE8O,IAAI9xB,IAAI,oBAAoBwyB,MAAMhR,EAAEgR,OAAOxzB,EAAEmyB,SAASxyB,EAAEK,EAAEgzB,IAAI,cAAc,cAAc5lB,KAAKiY,GAAGjY,MAAK,SAAS4W,GAAG,IAAIhjB,EAAEmjB,EAAE5mB,EAAEsS,EAAE,KAAK,IAAI7O,EAAE,EAAEA,EAAEgjB,EAAE3kB,KAAKpC,QAAQ,OAAO4S,EAAE7O,KAAKmjB,EAAEH,EAAE3kB,KAAK2B,IAAI8xB,MAAM9yB,EAAE8yB,MAAMjjB,EAAEsU,GAAG,OAAOtU,EAAE,CAAC4jB,QAAQrO,GAAG7nB,EAAEsS,GAAGA,GAAGyd,IAAIlI,EAAE7nB,EAAEyD,UAAI,GAAS,IAAI4M,MAAM,iDAAiD5N,EAAE8yB,IAAI,SAAQ9kB,OAAM,SAASgW,GAAG,MAAMA,MAAK,IAAIhkB,KAAIoN,MAAK,SAAS4W,GAAG,IAAIA,IAAIA,EAAEyP,UAAUzP,EAAEsJ,IAAI,MAAM,IAAI1f,MAAM,6BAA6B,OAAOD,QAAQN,QAAQ9P,EAAEu0B,UAAUrjB,IAAIoB,EAAEmU,IAAI5W,MAAK,WAAW+W,GAAGA,EAAE,KAAK,IAAIS,EAAEZ,EAAEyP,QAAQzP,EAAEsJ,YAAUtf,OAAM,SAASgW,GAAGG,GAAGA,EAAEH,OAAMta,EAAErL,UAAUqC,OAAO,SAASsjB,GAAG,IAAIhjB,EAAEmjB,EAAE5mB,EAAEymB,EAAEnmB,MAAM,KAAK,GAAG,IAAIN,EAAEN,OAAO,OAAO,IAAIyoB,EAAE,iCAAiC,IAAI1kB,EAAEiJ,KAAKa,MAAMyZ,EAAEhnB,EAAE,KAAK4mB,EAAEla,KAAKa,MAAMyZ,EAAEhnB,EAAE,KAAK,MAAMymB,GAAG,OAAO,IAAI0B,EAAE,6CAA6C,MAAM,CAAC/W,OAAO3N,EAAE4xB,QAAQzO,EAAEwO,QAAQ,CAAChkB,OAAOpR,EAAE,GAAGq1B,QAAQr1B,EAAE,GAAGs1B,UAAUt1B,EAAE,MAAMmM,EAAErL,UAAUq1B,oBAAoB,SAAS1P,EAAEhjB,EAAEmjB,EAAE5mB,GAAG,GAAGV,KAAKk1B,cAAc/wB,EAAE,OAAOzD,EAAE,IAAImoB,EAAE,2BAA2B1kB,EAAE,iCAAiCnE,KAAKk1B,YAAY,MAAM,IAAIvN,EAAE9kB,EAAEmQ,EAAEmU,GAAGS,EAAEhQ,EAAE7P,UAAUlF,GAAGklB,EAAEH,EAAE+B,UAAU,EAAE/B,EAAExnB,OAAO,GAAGyE,EAAE+S,EAAE3J,MAAM8Z,GAAG3H,EAAEjd,EAAE4E,UAAUlD,GAAG,OAAOnE,GAAGinB,EAAE,CAACmP,IAAI,IAAIC,IAAI,IAAIC,IAAI,IAAI5W,EAAE3f,QAAQ,UAAS,SAAS0mB,GAAG,OAAOQ,EAAER,QAAOG,EAAE,IAAIuB,EAAE,wBAAwB,QC6B14vC4M,cAAcj0B,UAAUyL,IAAM,SAASgqB,oBACrC,IAAK,IAAIp0B,EAAI,EAAGA,EAAI7C,KAAK21B,QAAQv1B,OAAQyC,IACvC,GAAI7C,KAAK21B,QAAQ9yB,GAAGq0B,SAASD,oBAC3B,OAAOj3B,KAAK21B,QAAQ9yB,GAAG+gB,OAI3B,OAAO,MCZT,WAAe,CACbuT,aAvBF,SAAsB/2B,QAEpB,IAAIg3B,MAAQ,IAAIla,WAAW9c,QACvBud,OAAS,GACT5Z,QACF,oEAEEszB,UACFC,aAAalV,YAAYqR,QAAU6D,aAAalV,YAAYmV,SAC9D,IAAKF,UACH,OAAO,KAKT,IAFA,IAAI3N,OAAS2N,UAAU3D,gBAAgB0D,OAE9Bv0B,EAAI,EAAGA,EAAI6mB,OAAOtpB,OAAQyC,IACjC8a,OAAO/c,KAAKmD,QAAQ2lB,OAAO7mB,GAAKkB,QAAQ3D,SAG1C,OAAOud,OAAO7c,KAAK,MCdrB,SAAS02B,mBAAmBt1B,SAC1B,IAAIu1B,YAAcv1B,QAAQu1B,aAAe,GACzCz3B,KAAK03B,UAAYD,YAAYC,WAJP,kBAKtB13B,KAAK23B,UAAYF,YAAYE,WAAa,GAC1C33B,KAAK8kB,QAAU,IAAIK,QAAQjjB,SAC3BlC,KAAKkC,QAAUA,QCVjB,SAAS01B,cAAc11B,SAkBrB,GAjBAlC,KAAKiR,IAAM/O,QAAQ+O,IACnBjR,KAAKoU,SAAWlS,QAAQkS,SACxBpU,KAAKuO,QAAUrM,QAAQqM,SAAW,IAClCvO,KAAK63B,gBAAkB31B,QAAQ21B,iBAAmB,KAClD73B,KAAK83B,kBAAoB51B,QAAQ41B,mBAAqB,UACtD93B,KAAK+3B,OAAS,KACd/3B,KAAKg4B,cAAgB,KACrBh4B,KAAKi4B,gBAAkB,KACvBj4B,KAAKk4B,8BAAgC,KACrCl4B,KAAKm4B,mBAAqB,KAE1Bn4B,KAAKo4B,eAAiBl2B,QAAQk2B,gBAAkB,CAC9CC,QAAS,WACP,OAAO,IAIkB,mBAAlBr4B,KAAKoU,SACd,MAAM,IAAIrD,MAAM,uCCWpB,SAASunB,kBAAkB5C,SACzB11B,KAAK01B,QAAUA,QACf11B,KAAKgP,KAAO,IAAI2V,KAAK+Q,QAAQ6C,aCxB/B,SAASC,0BAA0B9C,QAASxzB,SAC1ClC,KAAK01B,QAAUA,QACf11B,KAAKu4B,YAAcr2B,QACnBlC,KAAKkQ,QAAU,IAAI4R,eAAe5f,SAClClC,KAAKy4B,kBAAoB,IAAIH,kBAAkB5C,SAC/C11B,KAAK8kB,QAAU,IAAIK,QAAQjjB,SAe7B,SAASw2B,UAAUpX,OAAQqX,MACzB,MAAO,CACL,cACA1gB,mBAAmBqJ,QACnBrJ,mBAAmB0gB,OACnB73B,KAAK,KChCT,SAAS83B,SAASC,MAAO32B,SACvBlC,KAAK01B,QAAUmD,MACf74B,KAAKu4B,YAAcr2B,QACnBlC,KAAK84B,0BAA4B,IAAIN,0BACnCK,MACA74B,KAAKu4B,aAGPv4B,KAAKgP,KAAO,IAAI2V,KAAK,CACnBC,kBAAmB1iB,QAAQ62B,8BJG/BvB,mBAAmBh2B,UAAUwmB,QAAU,SAAS9lB,SAC9C,IAAKA,QAAQiM,aACX,MAAM,IAAI4C,MAAM,4BAElB,IAAIgV,mBAAqB7jB,QAAQ82B,OAAS92B,QAAQ0jB,WAC9CqT,6BAC4C,IAA9C/2B,QAAQiM,aAAa1K,QAAQ,YAE3Bg0B,YAAcz3B,KAAKk5B,oBACrBh3B,QAAQi3B,SACRj3B,QAAQk3B,MACRl3B,QAAQs0B,MACRzQ,mBACAkT,6BAUF,OARK/2B,QAAQk3B,QACXl3B,QAAQk3B,MAAQ3B,YAAY2B,OAG1BH,8BAAgC/2B,QAAQs0B,QAC1Ct0B,QAAQs0B,MAAQiB,YAAYjB,OAGvBt0B,SAGTs1B,mBAAmBh2B,UAAU03B,oBAAsB,SACjDC,SACAC,MACA5C,MACAzQ,mBACAsT,eAkBA,OAhBAD,MAAQA,OAAS1P,OAAOyN,aAAan3B,KAAK23B,WAC1CnB,MAAQA,QAAU6C,cAAgB3P,OAAOyN,aAAan3B,KAAK23B,WAAa,MAEtEL,aAAalV,YAAY/K,SAASqI,OAAS1f,KAAKkC,QAAQo3B,QAExDt5B,KAAK8kB,QAAQpB,QACX1jB,KAAK03B,UAAY0B,MACjB,CACE5C,MAAOA,MACP2C,SAAUA,SACVC,MAAOA,MACPrT,mBAAoBA,oBAEtB,CAAEhC,QK5DgB,EAAI,KL+DnB,CACLqV,MAAOA,MACP5C,MAAOA,QAIXgB,mBAAmBh2B,UAAU+3B,qBAAuB,SAASH,OAC3D,IAAII,gBAIJ,OAFAA,gBAAkBx5B,KAAK8kB,QAAQtB,QAAQxjB,KAAK03B,UAAY0B,OACxDp5B,KAAKy5B,iBAAiBL,OACfI,iBAGThC,mBAAmBh2B,UAAUi4B,iBAAmB,SAASL,OACvDp5B,KAAK8kB,QAAQrB,WAAWzjB,KAAK03B,UAAY0B,QCtD3CxB,cAAcp2B,UAAUoiB,KAAO,WAC7B,IAAIlT,MAAQ1Q,KACR05B,QAAUpC,aAAalV,YAU3B,OARApiB,KAAK+3B,OAAS2B,QAAQrW,SAASsW,cAAc,UAC7C35B,KAAK+3B,OAAO6B,MAAMC,QAAU,OAG5B75B,KAAKm4B,mBAAqB,SAASh0B,GACjCuM,MAAMopB,cAAc31B,IAGdnE,KAAK83B,mBACX,IAAK,UACH93B,KAAK+5B,kBAAoBL,QACzB,MACF,IAAK,OACH15B,KAAK+5B,kBAAoB/5B,KAAK+3B,OAC9B,MACF,QACE,MAAM,IAAIhnB,MACR,oCAAsC/Q,KAAK83B,mBAIjD93B,KAAK+5B,kBAAkB1uB,iBACrBrL,KAAK83B,kBACL93B,KAAKm4B,oBACL,GAGFuB,QAAQrW,SAASrK,KAAKghB,YAAYh6B,KAAK+3B,QAEvC/3B,KAAK+3B,OAAOkC,IAAMj6B,KAAKiR,IAEvBjR,KAAKg4B,cAAgB1jB,YAAW,WAC9B5D,MAAMwpB,mBACLl6B,KAAKuO,UAGVqpB,cAAcp2B,UAAUs4B,cAAgB,SAASxuB,OAC/C,IAAI6uB,UAAY,CAAE7uB,MAAOA,MAAO8uB,aAAcp6B,KAAK+5B,mBAE9C/5B,KAAKo4B,eAAeC,QAAQ8B,aAIjCn6B,KAAKq6B,UACLr6B,KAAKoU,SAAS+lB,aAGhBvC,cAAcp2B,UAAU04B,eAAiB,WACvCl6B,KAAKq6B,UACDr6B,KAAK63B,iBACP73B,KAAK63B,mBAITD,cAAcp2B,UAAU64B,QAAU,WAChC,IAAI3pB,MAAQ1Q,KAEZ6N,aAAa7N,KAAKg4B,eAElBh4B,KAAKi4B,gBAAkB3jB,YAAW,WAChC5D,MAAMqpB,kBAAkBnuB,oBACtB8E,MAAMonB,kBACNpnB,MAAMynB,oBACN,GAGEznB,MAAMqnB,OAAOuC,YACf5pB,MAAMqnB,OAAOuC,WAAWC,YAAY7pB,MAAMqnB,UAE3C,IC7DLO,kBAAkB92B,UAAUg5B,IAAM,SAASt4B,QAAS2J,IAClD,IAAI6E,MAAQ1Q,KACZkC,QAAQu4B,aAAe,cACvBv4B,QAAQw4B,OAAS,OAEjB,IAAIC,cAAgBrD,aAAahU,YAC7BsX,kBAAoBnY,aAAarB,iBAAiBlf,QAAQ24B,aAC9D,GAAID,mBAAqBD,gBAAkBC,kBACzC,OAAO/uB,GAAG,CACR8D,MAAO,kBACP2W,kBACE,6BACAsU,kBACA,uCACAD,cACA,QA/CR,SAA2BG,aAAc54B,QAASkS,UAClC,IAAIwjB,cAAc,CAC9B3mB,IAAK6pB,aACLhD,kBAAmB,UACnB1jB,SAAU,SAAS+lB,WACjB/lB,SAAS,KAAM+lB,YAEjB5rB,QAASrM,QAAQqM,QACjB6pB,eAAgB,CACdC,QAAS,SAAS8B,WAChB,MACgC,2BAA9BA,UAAU7uB,MAAM8H,KAAKV,MACrBxQ,QAAQk3B,QAAUe,UAAU7uB,MAAM8H,KAAKvE,SAASuqB,QAItDvB,gBAAiB,WACfzjB,SAAS,CACPzE,MAAO,UACP2W,kBAAmB,qDACnB8S,MAAOl3B,QAAQk3B,WAIbxV,OA2BRmX,CACE/6B,KAAK01B,QAAQsF,OAAOC,kBAAkB/4B,SACtCA,SACA,SAASsN,IAAK2qB,WACZ,IAAIxqB,MAAQH,IAIZ,IAHKA,KAAO2qB,UAAU7uB,MAAM8H,KAAKvE,SAASc,QACxCA,MAAQwqB,UAAU7uB,MAAM8H,KAAKvE,WAE1Bc,MAAO,CACV,IAAIurB,WAAaf,UAAU7uB,MAAM8H,KAAKvE,SACtC,OAAO6B,MAAMglB,QAAQyF,+BACnBj5B,QACAg5B,WACArvB,IAYJ,MARkB,qBAAhB8D,MAAMA,OACyC,cAA/C2nB,aAAalV,YAAY/K,SAASsI,UAElCjP,MAAM1B,KAAKkW,QACT,kKAGJxU,MAAMglB,QAAQ0F,mBAAmB3B,iBAAiB9pB,MAAMypB,OACjDvtB,GAAG4W,aAAavD,KAAKvP,MAAO,CAAC,QAAS,2BC9BnD6oB,0BAA0Bh3B,UAAU65B,MAAQ,SAASn5B,QAAS2J,IAC5D,IAAI6E,MAAQ1Q,KACRiR,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,oBAC5Cp5B,QAAQyQ,SAAWzQ,QAAQyQ,UAAYzQ,QAAQq5B,aACxCr5B,QAAQq5B,MAEf,IAAIC,iBAAmB,CACrBC,UAAWv5B,QAAQw5B,UAAY17B,KAAKu4B,YAAYmD,SAChD/oB,SAAUzQ,QAAQyQ,UAEhBzQ,QAAQ0Q,WACV4oB,iBAAiB5oB,SAAW1Q,QAAQ0Q,UAElC1Q,QAAQy5B,MACVH,iBAAiBG,IAAMz5B,QAAQy5B,KAEjC,IAAI3C,MAAQ92B,QAAQ82B,OAASh5B,KAAKu4B,YAAYS,MAE9C,GAAIA,MAAO,CACT,IAAI4C,eACF15B,QAAQ05B,gBACR57B,KAAKu4B,YAAYqD,gBACjB,mDACFJ,iBAAiBxC,MAAQA,MACzBwC,iBAAiBK,gBAAkBD,oBAEnCJ,iBAAiBK,gBAAkB,WAErC77B,KAAKkQ,QACFgM,KAAKjL,KACL4B,kBACAS,KAAKkoB,kBACLtqB,KAAI,SAAS1B,IAAK4D,MACjB,GAAI5D,IAAK,CACP,IAAIssB,YAAetsB,IAAIX,UAAYW,IAAIX,SAASmK,MAAS,CACvDrJ,MAAO,gBACP2W,kBAAmBlZ,KAAKrF,UAAUyH,MAEpC,OAAOusB,aAAgBlwB,GAAI,CAAE2a,kBAAkB,GAAxCuV,CAAgDD,aAEzD,IAAIE,WAA8B,IAAlB95B,QAAQ+5B,MACxB/5B,QAAUugB,aAAa9B,UAAUze,QAAS,CACxC,WACA,iBACA,MACA,UAEF,IAAIg6B,iBAAmBzZ,aACpBnd,MAAMpD,SACN4e,KAAK,CAAEqb,YAAa/oB,KAAK4F,KAAKojB,eAC7Bz5B,IAAM+1B,UAAUhoB,MAAM6nB,YAAY+C,QAASloB,KAAK4F,KAAKqjB,OACzD3rB,MAAMoU,QAAQpB,QAAQ/gB,IAAKyQ,KAAK4F,KAAKsjB,YAAa,CAChDvY,QEvGgB,EAAI,KFyGlBiY,UACFtrB,MAAM+nB,kBAAkB+B,IACtB0B,iBACAH,aAAgBlwB,GAAI,CAAE2a,kBAAkB,KAG1C9V,MAAMglB,QAAQ6G,UAAUL,sBAoBhC1D,0BAA0Bh3B,UAAU4S,SAAW,WAC7C,IAAIooB,aAAet4B,mBAlHrB,SAAqB8N,MACnB,IAEIjR,OADQ,IADIu2B,aAAalV,YACD/K,SAAS0I,KAAK4J,UAAU,IAClC3oB,MAAM,IAAMgR,KAAO,KACrC,GAAqB,IAAjBjR,MAAMX,OACR,OAAOW,MACJ2C,MACA1C,MAAM,KACNR,QA0GiCi8B,CAAY,WAC9CC,UAAYpF,aAAalV,YACzB1R,MAAQ1Q,KAEZ08B,UAAUrxB,iBAAiB,WAAW,SAASsxB,KAC7C,GAAsB,wBAAlBA,IAAIvpB,KAAKV,KAAb,CAGA,IAAI/P,IAAM+1B,UAAUiE,IAAIrb,OAAQqb,IAAIvpB,KAAKlD,QAAQ0sB,IAC7CC,SAzBR,SAAwB/X,QAASniB,KAC/B,IACE,IAAIk6B,SAAW/X,QAAQtB,QAAQ7gB,KAE/B,OADAmiB,QAAQrB,WAAW9gB,KACZk6B,UAAY,GACnB,MAAO14B,GACP,MAAO,IAmBQ24B,CAAepsB,MAAMoU,QAASniB,KAE7Cg6B,IAAI16B,OAAOonB,YACT,CACE3W,KAAM,uBACN7D,SAAU,CACRguB,SAAUA,WAGdF,IAAIrb,YAIRob,UAAUlzB,OAAO6f,YAAY,CAAE3W,KAAM,SAAW8pB,eC5HlD5D,SAASp3B,UAAUu7B,qBAAuB,SAAS76B,QAAS2J,IAC1D3J,QAAQ82B,MAAQ92B,QAAQ82B,OAAS92B,QAAQ0jB,kBAClC1jB,QAAQ0jB,WACf5lB,KAAK84B,0BAA0BuC,MAAMn5B,QAAS2J,KAahD+sB,SAASp3B,UAAUw7B,eAAiB,SAAS96B,QAAS2J,IACpD,IAAI6E,MAAQ1Q,KACZ,OAAOA,KAAK01B,QAAQsF,OAAOiC,aAAaC,OAAOh7B,SAAS,SAASsN,KAC/D,OAAIA,IACK3D,GAAG2D,MAEZtN,QAAQ82B,MAAQ92B,QAAQ82B,OAAS92B,QAAQ0jB,kBAClC1jB,QAAQ0jB,WACRlV,MAAMglB,QAAQ2F,MAAMn5B,QAAS2J,4DEtDxC,IAAIsxB,QAAU,WAKZ,SAASC,YAAY1V,EAAGpc,MAAOO,IAC1B6b,EAAE2V,YAAa3V,EAAE2V,YAAY,KAAO/xB,MAAOO,IACrC6b,EAAErc,kBAAkBqc,EAAErc,iBAAiBC,MAAOO,IAAI,GAI7D,SAASH,eAAegc,EAAGpc,MAAOO,IAC7B6b,EAAE4V,YAAa5V,EAAE4V,YAAY,KAAOhyB,MAAOO,IACrC6b,EAAE9b,qBAAqB8b,EAAE9b,oBAAoBN,MAAOO,IAAI,GA+CnE,SAAS0xB,cAActsB,KAChB,eAAe8D,KAAK9D,OAAMA,IAAMgG,OAAOI,SAASoI,MACrD,IAAI2I,EAAI,mCAAmC7e,KAAK0H,KAChD,OAAImX,EAAUA,EAAE,GACTnX,IAoBT,IAAIusB,KAlEJ,WACE,GAAyB,oBAAdtP,UACT,OAAO,EAGT,IAAIuP,IAAM,EACNC,GAAKxP,UAAUyP,UACnB,GAA0B,gCAAtBzP,UAAUC,QAEO,MADV,IAAIyP,OAAO,8BACbr0B,KAAKm0B,MACVD,GAAKI,WAAWD,OAAOE,UAGtB,GAAIJ,GAAGj6B,QAAQ,YAAc,EAAG,CAEf,OADX,IAAIm6B,OAAO,6BACbr0B,KAAKm0B,MACVD,GAAKI,WAAWD,OAAOE,KAI3B,OAAOL,IAAM,EA8CJM,GAEX,MA/B4B,oBAAX9mB,QAA0BA,OAAO7J,MAAQ6J,OAAO7J,KAAKrF,WAC5DkP,OAAO7J,KAAKa,OAASgJ,OAAOoS,YA2C7B,CACL1N,KAAM,SAAS1R,KAAM4B,IACnB,IAAKA,GAAI,KAAM,qCAGf,IAAI2D,IAWAuoB,OAVC9tB,KAAKgH,MAAKzB,IAAM,oCAChBvF,KAAK+zB,YAAWxuB,IAAM,0CACvBA,KAAK8E,YAAW,WAAazI,GAAG2D,OAAS,GAGxCvF,KAAKg0B,cAAah0B,KAAKg0B,YAAc,MACrCh0B,KAAKi0B,kBArEhB,WACE,IAGE,IAAIP,UAAYzP,UAAUyP,UAC1B,OAAyC,GAAjCA,UAAUl6B,QAAQ,aACgB,GAAlCk6B,UAAUl6B,QAAQ,cAAsD,GAAjCk6B,UAAUl6B,QAAQ,WACjE,MAAMU,IACR,OAAO,EA6D0Bg6B,KAAYl0B,KAAKi0B,qBAAkBh0B,GAOhE,IAOIk0B,cAPA9c,OAASrX,KAAKqX,QAAUic,cAActzB,KAAKgH,KAC/C,GAAIqQ,SAAWic,cAActzB,KAAK+zB,WAChC,OAAO1pB,YAAW,WAChBzI,GAAG,+DACF,GAKD2xB,QAIFzF,OAAS1U,SAASsW,cAAc,WAEzB0E,aAAa,MAAOp0B,KAAK+zB,WAChCjG,OAAO6B,MAAMC,QAAU,OACvB9B,OAAOsG,aAAa,OAtIL,yBAuIfhb,SAASrK,KAAKghB,YAAYjC,QAC1BqG,cAAgBrG,OAAOuG,eAGzB,IAAI5W,EAAIzd,KAAKgyB,OAAShlB,OAAO0E,KAAK1R,KAAKgH,IAAKhH,KAAKg0B,YAAah0B,KAAKi0B,iBAC/Dj0B,KAAKgyB,QACPvU,EAAErQ,SAASoI,KAAOxV,KAAKgH,KAGpBmtB,gBAAeA,cAAgB1W,GAGpC,IAAI6W,cAAgBC,aAAY,WAC1B9W,GAAKA,EAAE+W,SACTC,UACI7yB,KACFA,GAAG,gCACHA,GAAK,SAGR,KAECoE,IAAM7C,KAAKrF,UAAU,CAAClF,EAAG,UAAW4kB,EAAGxd,KAAKsL,SAGhD,SAASmpB,UAMP,GALI3G,QAAQ1U,SAASrK,KAAKuhB,YAAYxC,QACtCA,YAAS7tB,EACLq0B,gBAAeA,cAAgBI,cAAcJ,gBACjD7yB,eAAeuL,OAAQ,UAAW2nB,WAClClzB,eAAeuL,OAAQ,SAAUynB,SAC7BhX,EACF,IACEA,EAAEmX,QACF,MAAOC,mBAGPV,cAAc/U,YA3KV,MA2KiC/H,QAGzCoG,EAAI0W,mBAAgBl0B,EAKtB,SAAS00B,UAAUz6B,GACjB,GAAIA,EAAEmd,SAAWA,OAAjB,CACA,IACE,IAAImG,EAAIra,KAAKa,MAAM9J,EAAEiP,MACrB,MAAM5D,KACN,GAAI3D,GACF,OAAOA,GAAG2D,KAEV,MAAMA,IAIE,UAARiY,EAAE5kB,EACJu7B,cAAc/U,YAAYpZ,IAAKqR,QACd,UAARmG,EAAE5kB,GACX67B,UACI7yB,KACFA,GAAG4b,EAAEA,GACL5b,GAAK,OAEU,aAAR4b,EAAE5kB,IACX67B,UACI7yB,KACFA,GAAG,KAAM4b,EAAEA,GACX5b,GAAK,QAOX,OAjCAuxB,YAAYnmB,OAAQ,SAAUynB,SA+B9BtB,YAAYnmB,OAAQ,UAAW2nB,WAExB,CACLG,cAAerX,EACfmX,MAAOH,QACPM,MAAO,WACL,GAAItX,EACF,IACEA,EAAEsX,QACF,MAAO76B,QAOjB86B,OAAQ,SAASpzB,IACf,IAAI1I,EAAI,IACJ+7B,UAAY1B,KAhKtB,WAGE,IADA,IAAI2B,OAASloB,OAAOmoB,OAAOD,OAClBz+B,EAAIy+B,OAAO/+B,OAAS,EAAGM,GAAK,EAAGA,IACtC,IACE,GAAIy+B,OAAOz+B,GAAG2W,SAASC,WAAaL,OAAOI,SAASC,UAChD6nB,OAAOz+B,GAAG2W,SAASqI,OAASzI,OAAOI,SAASqI,MAzE/B,0BA0Ebyf,OAAOz+B,GAAGsR,KAEZ,OAAOmtB,OAAOz+B,GAEhB,MAAMyD,KAqJiBk7B,GAAcpoB,OAAOmoB,OAC5C,IAAKF,UAAW,KAAM,yBACtB,SAASI,OAAOrlB,KACdA,IAAM7M,KAAKrF,UAAUkS,KACjBujB,KAAM0B,UAAUI,OAAOrlB,IAAK9W,GAC3B+7B,UAAU7V,YAAYpP,IAAK9W,GA4BlC,SAASo8B,MAAMp7B,GACb,GApQQ,QAoQJA,EAAEiP,KACJ,IAAM6D,OAAO4nB,QAAW,MAAOW,OAGnCpC,YAAYI,KAAO0B,UAAYjoB,OAAQ,WA9BvC,SAAS2nB,UAAUz6B,GAKjB,IAAIsjB,EACJ,IACEA,EAAIra,KAAKa,MAAM9J,EAAEiP,MACjB,MAAM5D,MACHiY,GAAa,YAARA,EAAE5kB,IACZ6I,eAAeuL,OAAQ,UAAW2nB,WAClCz7B,EAAIgB,EAAEmd,OACFzV,IAIFyI,YAAW,WACTzI,GAAG1I,EAAGskB,EAAEA,GAAG,SAASH,GAClBzb,QAAK3B,EACLo1B,OAAO,CAACz8B,EAAG,WAAY4kB,EAAGH,SAE3B,OAUP8V,YAAYI,KAAO0B,UAAYjoB,OAAQ,UAAWsoB,OAIlD,IACED,OAAO,CAACz8B,EAAG,UACX,MAAMsB,GAENi5B,YAAY8B,UAAW,QAAQ,SAAS/6B,GACtCm7B,OAAO,CAACz8B,EAAG,aAKf,IAAI48B,SAAW,WACb,IAEE/zB,eAAe8xB,KAAO0B,UAAYjoB,OAAQ,UAAWsoB,OACrD,MAAOG,SACL7zB,IAAIyzB,OAAO,CAAEz8B,EAAG,QAAS4kB,EAAG,yBAChC5b,QAAK3B,EAEL,IAAM+M,OAAO4nB,QAAW,MAAO16B,MAGjC,OADAi5B,YAAYnmB,OAAQ,SAAUwoB,UACvB,CACLE,OAAQ,WACNj0B,eAAeuL,OAAQ,SAAUwoB,cAMlC,CACL9jB,KAAM,SAAS1K,IAAK2uB,QAASC,IAAKh0B,IAChCyI,YAAW,WAAazI,GAAG,yBAA2B,IAExDozB,OAAQ,SAASpzB,IACfyI,YAAW,WAAazI,GAAG,yBAA2B,KAjThD,GAuTuBzK,OAAOC,UAC1CD,eAAiB+7B,YChTnB,cAAe,CACbI,cARF,SAAuBtsB,KAChB,eAAe8D,KAAK9D,OAAMA,IAAMgG,OAAOI,SAASoI,MACrD,IAAI2I,EAAI,iCAAiC7e,KAAK0H,KAC9C,OAAImX,EAAUA,EAAE,GACTnX,MCGT,SAAS6uB,eACP9/B,KAAK+/B,eAAiB,KCIxB,SAASC,MAAMtK,QAASxzB,SACtBlC,KAAKu4B,YAAcr2B,QACnBlC,KAAKu4B,YAAY0H,YAAc/9B,QAAQ+9B,YACvCjgC,KAAKg7B,OAAStF,QAAQsF,OACtBh7B,KAAK01B,QAAUA,QAEf11B,KAAKo7B,mBAAqB,IAAI5D,mBAAmBx3B,KAAKu4B,aACtDv4B,KAAK84B,0BAA4B,IAAIN,0BACnC9C,QACA11B,KAAKu4B,aAEPv4B,KAAKgP,KAAO,IAAI2V,KAAK,CACnBC,kBAAmB1iB,QAAQ62B,8BCtB/B,SAASmH,4BAA4Bh+B,SACnClC,KAAKmgC,kBAAoBj+B,QAAQi+B,kBACjCngC,KAAKuO,QAAUrM,QAAQqM,SAAW,IAClCvO,KAAKolB,QAAU,KACfplB,KAAKogC,oBAAsBl+B,QAAQk+B,sBAAuB,EAG1DpgC,KAAKqgC,kBACHn+B,QAAQm+B,mBACR/I,aAAalV,YAAY/K,SAASiK,QAClCgW,aAAalV,YAAY/K,SAASC,SAChC,KACAggB,aAAalV,YAAY/K,SAASsI,UACjC2X,aAAalV,YAAY/K,SAASuI,KAC/B,IAAM0X,aAAalV,YAAY/K,SAASuI,KACxC,ICVV,SAAS0gB,iBAAiBp+B,SACxBlC,KAAKu4B,YAAcr2B,QACnBlC,KAAKkQ,QAAU,IAAI4R,eAAe5f,SAClClC,KAAKo7B,mBAAqB,IAAI5D,mBAAmBx3B,KAAKu4B,aCAxD,SAASgI,YAAYvF,OAAQ94B,SAC3BlC,KAAKu4B,YAAcr2B,QACnBlC,KAAKg7B,OAASA,OACdh7B,KAAKu4B,YAAYpW,oBAAqB,EACtCniB,KAAKkQ,QAAU,IAAI4R,eAAe9hB,KAAKu4B,aAEvCv4B,KAAKgP,KAAO,IAAI2V,KAAK,CACnBC,kBAAmB1iB,QAAQ62B,8BJN/B+G,aAAat+B,UAAUg/B,kBAAoB,SAASt+B,SAClD,IAAIu+B,MAAQv+B,QAAQu+B,OAAS,IACzBC,OAASx+B,QAAQw+B,QAAU,IAC3BhH,QAAUzU,aAAc7C,YAExBue,aACyB,IAApBjH,QAAQiH,QACXjH,QAAQiH,QACRjH,QAAQkH,WACVC,aACyB,IAApBnH,QAAQmH,QACXnH,QAAQmH,QACRnH,QAAQoH,UAEVC,gBAC4B,IAAvBrH,QAAQqH,WACXrH,QAAQqH,WACRrH,QAAQrW,SAASrK,KAAKgoB,YAExBC,iBAC6B,IAAxBvH,QAAQuH,YACXvH,QAAQuH,YACRvH,QAAQrW,SAASrK,KAAKkoB,aAK5B,MAAO,CAAET,MAAOA,MAAOC,OAAQA,OAAQS,KAH5Bj/B,QAAQi/B,MAAQR,SAAWI,WAAaN,OAAS,EAGTW,IAFzCl/B,QAAQk/B,KAAOP,SAAWI,YAAcP,QAAU,IAK9DZ,aAAat+B,UAAU6/B,QAAU,SAASn/B,SACxC,IAAIwO,MAAQ1Q,KACR05B,QAAUzU,aAAc7C,YACxBkf,cAAgBthC,KAAKwgC,kBAAkBt+B,QAAQq/B,cAAgB,IAC/DA,aAAe9e,aAChBnd,MAAMg8B,eACNxgB,KAAK5e,QAAQq/B,cACZtwB,IAAM/O,QAAQ+O,KAAO,cACrBuwB,eAAiBC,cAAaF,aAAc,CAC9Cn9B,QAAQ,EACRiD,UAAW,MAGb,OAAIrH,KAAK+/B,iBAAmB//B,KAAK+/B,eAAetB,SAIhDz+B,KAAK+/B,eAAiBrG,QAAQ/d,KAAK1K,IAAK,qBAAsBuwB,gBAE9DxhC,KAAK+/B,eAAe2B,KAAO,WACzB1hC,KAAK6+B,QACLnuB,MAAMqvB,eAAiB,OAPhB//B,KAAK+/B,gBAahBD,aAAat+B,UAAUmgC,KAAO,SAAS1wB,IAAK2wB,SAAU1/B,QAAS2J,IAC7D,IAAI6E,MAAQ1Q,KACRshC,cAAgBthC,KAAKwgC,kBAAkBt+B,QAAQq/B,cAAgB,IAC/DA,aAAe9e,aAChBnd,MAAMg8B,eACNxgB,KAAK5e,QAAQq/B,cAEZM,eAAiBpf,aAClBnd,MAAM,CACL2L,IAAKA,IACL+sB,UAAW4D,SACX1D,gBAAiBuD,cAAaF,aAAc,CAC1Cl6B,UAAW,IACXjD,QAAQ,IAEV63B,MAAOj8B,KAAK+/B,iBAEbjf,KAAK5e,SAEJ+5B,MAAQkB,QAAQxhB,KAAKkmB,gBAAgB,SAASryB,IAAK4D,MAErD,IAAI5D,KAAoB,gBAAbA,IAAIwC,KAIf,OADAtB,MAAMqvB,eAAiB,KAChBl0B,GAAG2D,IAAK4D,SAKjB,OAFA6oB,MAAM+C,QAEC/C,OChET+D,MAAMx+B,UAAUsgC,kBAAoB,WAClC,IAAIC,cAAgB/hC,KAAKu4B,YAAY5C,QAAQ1oB,IAAI,yBAEjD,OAAI80B,cACKA,cAAcC,kBAGhB,IAAIlC,cASbE,MAAMx+B,UAAU6/B,QAAU,SAASn/B,SACjCA,QAAUA,SAAW,GAErB,IAAI+5B,MAAQj8B,KAAK8hC,oBAGjB,OADA7F,MAAMoF,QAAQn/B,SACP+5B,OAST+D,MAAMx+B,UAAUwgC,gBAAkB,SAAS9/B,QAASm/B,SAClD,OAAIn/B,QAAQ+/B,aACH//B,QAAQ+/B,aAGbZ,QACKrhC,KAAKqhC,QAAQn/B,SAGflC,KAAK8hC,qBAad9B,MAAMx+B,UAAU4S,SAAW,SAASlS,SAClC,IAAIwO,MAAQ1Q,KACR08B,UAAYpF,aAAalV,YAEzB8f,WADJhgC,QAAUA,SAAW,IAEX+9B,aACRjgC,KAAKu4B,YAAY0H,aACjB3I,aAAahU,YAUVoZ,UAAU0C,OASfjC,QAAQ8B,QAAO,SAASgB,YAAa3Y,EAAGzb,IACtC,GAAIo0B,cAAgBiC,UAClB,OAAOr2B,GAAG,CACR8D,MAAO,kBACP2W,kBACE,uBACA2Z,YACA,+CACAiC,UACA,OAGNxxB,MAAMglB,QAAQyM,UAAUjgC,SAAW,IAAI,SAASsN,IAAK4D,MACnD,OAAOvH,GAAG2D,KAAO4D,YArBnBspB,UAAU4C,OAAS,SAASrlB,KACtByiB,UAAUlzB,QACZkzB,UAAUlzB,OAAO6f,YAAYpP,IAAKioB,aAyC1ClC,MAAMx+B,UAAU+6B,UAAY,SAASr6B,QAAS2J,IAC5C,IACIoF,IACA2wB,SACAQ,QAAU,GAEVL,cAAgB/hC,KAAKu4B,YAAY5C,QAAQ1oB,IAAI,mBAE7CsI,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,QACA,SACA,WACA,SACA,eACA,cACA,QACA,QACA,YACA,UAEDzX,KAAK2B,aAAa9B,UAAUze,QAAS,CAAC,kBAgDzC,OA9CAie,OAAOjC,MACL3I,OACA,CAAE7C,KAAM,SAAU4L,QAAS,kCAC3B,CACEnQ,aAAc,CACZuE,KAAM,SACN4L,QAAS,qCAOfsjB,SAAWnN,QAAQz0B,KAAKu4B,YAAY+C,QAAS,cAGzCp5B,QAAQmgC,IAGV9sB,OAAO8sB,KAAM,GAEbD,QAAQ9gB,OAASghB,UAAU/E,cAAchoB,OAAOslB,aAChD+G,SAAWrsB,OAAOslB,aAGhB34B,QAAQq/B,eACVa,QAAQb,aAAe9e,aAAavD,KAAKhd,QAAQq/B,aAAc,CAC7D,QACA,SACA,MACA,UAIAQ,gBACFxsB,OAASwsB,cAAcQ,cAAchtB,UAGvCA,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,SAClCitB,MAAQjtB,OAAOitB,OAAS,8BACxBjtB,OAAO+jB,OAEdroB,IAAMjR,KAAKg7B,OAAOC,kBAAkB1lB,QAE5BvV,KAAKgiC,gBAAgB9/B,SAEhBy/B,KACX1wB,IACA2wB,SACAQ,QACArG,aAAgBlwB,GAAI,CAAEib,oBAAoB,MAkB9CkZ,MAAMx+B,UAAUu7B,qBAAuB,SAAS76B,QAAS2J,IACvD3J,QAAQ82B,MAAQ92B,QAAQ82B,OAAS92B,QAAQ0jB,WACzC1jB,QAAQ+5B,OAAQ,EAChB/5B,QAAUugB,aACPnd,MAAMtF,KAAKu4B,YAAa,CAAC,cAAe,eAAgB,QAAS,UACjEzX,KAAK2B,aAAa9B,UAAUze,QAAS,CAAC,eAAgB,gBACzDA,QAAUlC,KAAKo7B,mBAAmBpT,QAAQ9lB,SAC1ClC,KAAK84B,0BAA0BuC,MAAMn5B,QAAS2J,KAehDm0B,MAAMx+B,UAAUihC,mBAAqB,SAASvgC,QAAS2J,IACrD,IAAI6E,MAAQ1Q,KACZ,OAAOA,KAAKg7B,OAAO0H,aAAapO,OAC9B7R,aAAa9B,UAAUze,QAAS,CAAC,kBACjC,SAASsN,KACP,GAAIA,IACF,OAAO3D,GAAG2D,KAGZtN,QAAQyQ,SAAWzQ,QAAQygC,aAAezgC,QAAQq5B,MAClDr5B,QAAQ0Q,SAAW1Q,QAAQ0gC,wBAEpB1gC,QAAQq5B,aACRr5B,QAAQygC,mBACRzgC,QAAQ0gC,wBACR1gC,QAAQwQ,KAEfhC,MAAMsqB,OAAO6H,uBAAuB3gC,QAAS2J,QAkBnDm0B,MAAMx+B,UAAUw7B,eAAiB,SAAS96B,QAAS2J,IACjD,IAAI6E,MAAQ1Q,KAEZ,OAAOA,KAAKg7B,OAAOiC,aAAaC,OAAOh7B,SAAS,SAASsN,KACvD,GAAIA,IACF,OAAO3D,GAAG2D,KAEZkB,MAAMqsB,qBAAqB76B,QAAS2J,QC5RxCq0B,4BAA4B79B,OAAS,SAASH,SAC5C,OAAO,IAAIg+B,4BAA4Bh+B,UAGzCg+B,4BAA4B1+B,UAAU65B,MAAQ,SAC5CyH,eACA1uB,UAEApU,KAAKolB,QAAU,IAAIwS,cAAc,CAC/BiB,MAAO74B,KAAK64B,MACZ5nB,IAAKjR,KAAKmgC,kBACVrI,kBAAmBgL,eAAiB,UAAY,OAChD1uB,SAAUpU,KAAK+iC,mBAAmB3uB,SAAU0uB,gBAC5Cv0B,QAASvO,KAAKuO,QACd6pB,eAAgBp4B,KAAKgjC,oBACrBnL,gBAAiB,WACfzjB,SACE,KACA,0EAGJ0uB,eAAgBA,iBAAkB,IAGpC9iC,KAAKolB,QAAQxB,QAGfsc,4BAA4B1+B,UAAUwhC,kBAAoB,WACxD,IAAItyB,MAAQ1Q,KACZ,MAAO,CACLq4B,QAAS,SAAS8B,WAChB,OAAQA,UAAU7uB,MAAMoH,MACtB,IAAK,UAEH,OACEynB,UAAU7uB,MAAMgW,SAAW5Q,MAAM2vB,mBACjClG,UAAU7uB,MAAMrJ,SAAWyO,MAAM0U,QAAQ2S,OAAOuG,iBAMhB,IAA9B5tB,MAAM0vB,qBAKRjG,UAAU7uB,MAAM8H,KAAKV,MACrBynB,UAAU7uB,MAAM8H,KAAKV,OAAShC,MAAM0vB,qBAGxC,IAAK,OACH,GAC6D,WAA3DjG,UAAUC,aAAakE,cAAcjnB,SAASC,SAG9C,OAAO,EAGX,QACE,OAAO,MAMjB4oB,4BAA4B1+B,UAAUuhC,mBAAqB,SACzD3uB,SACA0uB,gBAEA,OAAO,SAAS3I,WACd,IAAI8I,cAOFA,cANGH,eAG6B,iBAAzB3I,UAAU7uB,MAAM8H,MACvB+mB,UAAU7uB,MAAM8H,KAAK2M,KAELoa,UAAU7uB,MAAM8H,KAAK2M,KAErBoa,UAAU7uB,MAAM8H,KAPhB+mB,UAAUC,aAAakE,cAAcjnB,SAAS0I,KAShE3L,SAAS,KAAM6uB,iBCzFnB3C,iBAAiB9+B,UAAU65B,MAAQ,SAASn5B,QAAS2J,IACnD,IAAIoF,IACA+H,KAuBJ,OArBA/H,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,mBAAoB,SAE5Dp5B,QAAQyQ,SAAWzQ,QAAQyQ,UAAYzQ,QAAQq5B,MAE/Cr5B,QAAUugB,aAAa9B,UAAUze,QAAS,CAAC,UAE3C8W,KAAOyJ,aACJnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,cACA,SACA,eACA,eACA,QACA,aAEDzX,KAAK5e,SACR8W,KAAOhZ,KAAKo7B,mBAAmBpT,QAAQhP,MAEvCA,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,gBAEhChZ,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAGzBy0B,iBAAiB9+B,UAAU4S,SAAW,SAAS8uB,UAC7C,IAAIC,IAEAC,UAAY9L,aAAalU,eAE7B+f,IAAMC,UAAUzJ,cAAc,QAC1B0J,UAAYH,SACTE,UAAUpqB,KAAKghB,YAAYmJ,KAAKG,SAAS,GAE3CC,UCTPhD,YAAY/+B,UAAU65B,MAAQ,SAASn5B,QAAS2J,IAC9C,GAAIyrB,aAAalV,YAAY/K,SAASqI,OAAS1f,KAAKu4B,YAAYe,OAC9D,MAAM,IAAIvoB,MACR,yEAGJ,IAAIyyB,iBAEAjuB,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,cACA,SACA,eACA,eACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAcR,OAZAie,OAAOjC,MACL3I,OACA,CAAE7C,KAAM,SAAU4L,QAAS,kCAC3B,CACEnQ,aAAc,CACZuE,KAAM,SACN4L,QAAS,sCAKfklB,iBAAmB,IAAIlD,iBAAiBtgC,KAAKu4B,cACrB8C,MAAM9lB,QAAQ,SAAS/F,IAAK4D,MAClD,OAAI5D,IACK3D,GAAG2D,KAELg0B,iBAAiBpvB,SAAShB,UAcrCmtB,YAAY/+B,UAAUw7B,eAAiB,SAAS96B,QAAS2J,IACvD,IAAI6E,MAAQ1Q,KACZ,OAAO0Q,MAAMsqB,OAAOA,OAAOiC,aAAaC,OAAOh7B,SAAS,SAASsN,KAC/D,OAAIA,IACK3D,GAAG2D,KAELkB,MAAM2qB,MAAMn5B,QAAS2J,QAIhC00B,YAAY/+B,UAAUiiC,WAAa,SAASC,sBAAuB73B,IACjE,IAAIoF,IACAsE,OAAS,GAwBb,MAtBqC,mBAA1BmuB,wBACT73B,GAAK63B,sBACLA,uBAAwB,GAG1BvjB,OAAOjC,MAAMwlB,sBAAuB,CAClChxB,KAAM,UACN4L,QAAS,iDAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE1ColB,wBACFnuB,OACE,IACAksB,cAAa,CACXkC,MAAO,EACPlI,UAAWz7B,KAAKu4B,YAAYmD,YAIlCzqB,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,OAAQ,UAAW/lB,QAEpDvV,KAAKkQ,QACTjD,IAAIgE,IAAK,CAAE2R,WAAW,IACtB/P,kBACA3B,IAAI6qB,aAAgBlwB,MCtIzB,IAAImL,KAAO,aAEP/P,WAAW,CACb28B,KAAM,KACNC,UAAW,CACThL,MAAS,SAAUiL,WACjB,IAAIxlB,QAA6B,SAAnBwlB,UAAUpxB,KACtB,6BACA,gCACF,MAAO,gDACYoxB,UAAUC,MADtB,sKAMezlB,QAAU,QAGlC0lB,aAAgB,WACd,MAAO,wEAGTr0B,MAAS,WACP,MAAO,sIAyBb,SAASs0B,wBAAwBC,QAAShiC,QAAS4hC,WACjD,IAAIK,SAAWD,QAAQE,aAAa,aAAeF,QAAQG,aAAa,YAExE,SAASC,SAASrhC,OACJihC,QAAQK,cAAc,yBAC5BthC,MAAQA,OAAS,GAGzB,GAAIkhC,SAGF,OAFAG,gBACArtB,OAAOutB,WAAWpY,MAAM+X,UAI1BD,QAAQb,UAAYnhC,QAAQ2hC,UAAUC,UAAUW,UAAUX,WAE1D,IAAIY,aAAeR,QAAQK,cAAc,eA5B3C,SAA+BL,QAASN,KAAMxvB,UAC5C,IAAIuwB,aAAe,qBAAuBlb,KAAKkE,MAAsB,QAAhBlE,KAAKC,UAC1DzS,OAAO0tB,cAAgB,kBACd1tB,OAAO0tB,cACdvwB,YAEF,IAAIwwB,OAAS3tB,OAAOoM,SAASsW,cAAc,UAC3CiL,OAAO3K,IAAM,8CAAgD2J,KAAO,WAAae,aACjFC,OAAOC,OAAQ,EACf5tB,OAAOoM,SAASrK,KAAKghB,YAAY4K,QAqBjCE,CAAsBZ,EAAShiC,QAAQ0hC,MAAM,WAC3CO,SAAWltB,OAAOutB,WAAWO,OAAOL,aAAc,CAChDtwB,SAAUkwB,SACVU,mBAAoB,WAAcV,YAClCW,iBAAkB,WAAcX,YAChCY,QAASpB,UAAUqB,UAErBjB,QAAQ7F,aAAa,WAAY8F,aAyDrC,YAAe,CAAEY,OAvCjB,SAAgBK,YAAalB,QAAShiC,QAASkS,UAG7C,SAASutB,KAAK0D,MACZA,KAAOA,MAAQruB,KACfouB,YAAYE,cAAa,SAAU91B,IAAKs0B,WACtC,OAAIt0B,KACF00B,QAAQb,UAAYnhC,QAAQ2hC,UAAUl0B,MAAMH,KACrC61B,KAAK71B,MAETs0B,UAAUyB,UAKfrB,QAAQtK,MAAMC,QAAU,GACG,UAAvBiK,UAAUW,SA/EpB,SAA6BP,QAAShiC,QAAS4hC,UAAWnC,MACxDuC,QAAQb,UAAYnhC,QAAQ2hC,UAAUC,UAAUW,UAAUX,WAC1DI,QAAQK,cAAc,mBAAmBl5B,iBAAiB,SAAS,SAAUlH,GAC3EA,EAAEqhC,iBACF7D,UA4EI8D,CAAoBvB,QAAShiC,QAAS4hC,UAAWnC,MACjB,iBAAvBmC,UAAUW,UACnBR,wBAAwBC,QAAShiC,QAAS4hC,gBAE5CuB,SAVEnB,QAAQtK,MAAMC,QAAU,YACxBqK,QAAQb,UAAY,QAqB1B,OAhCAnhC,QAAU8F,aAAO1C,MAAM2B,YAAU6Z,KAAK5e,SAAW,IA8BjDy/B,KAAKvtB,UAEE,CACLsxB,OAAQ/D,KACRgE,SAVF,WACE,IAAIC,aAAe1B,QAAQK,cAAc,yBACzC,GAAKqB,aACL,OAAOA,aAAa3iC,UCvGxB,SAAS4iC,eACP,OAAO,IAAIh/B,KAoBb,SAASi/B,QAAQ5jC,SAEfie,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEgb,OAAQ,CAAE5mB,KAAM,SAAU4L,QAAS,6BACnCod,SAAU,CAAEhpB,KAAM,SAAU4L,QAAS,+BACrCnQ,aAAc,CACZkQ,UAAU,EACV3L,KAAM,SACN4L,QAAS,6BAEXmc,aAAc,CACZpc,UAAU,EACV3L,KAAM,SACN4L,QAAS,6BAEXuc,YAAa,CACXxc,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEXkkB,MAAO,CAAEnkB,UAAU,EAAM3L,KAAM,SAAU4L,QAAS,sBAClD8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,yBAEX2hB,YAAa,CACX5hB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEX+W,OAAQ,CACNhX,UAAU,EACV3L,KAAM,SACN4L,QAAS,uBAEXqX,QAAS,CACPtX,UAAU,EACV3L,KAAM,QACN4L,QAAS,wBAEXiX,OAAQ,CACNlX,UAAU,EACV3L,KAAM,SACN4L,QAAS,uBAEXya,4BAA6B,CAC3B1a,UAAU,EACV3L,KAAM,UACN4L,QAAS,mDAEXyD,eAAgB,CACd1D,UAAU,EACV3L,KAAM,UACN4L,QAAS,sCAEX0D,eAAgB,CACd3D,UAAU,EACV3L,KAAM,SACN4L,QAAS,sCAEX2D,4BAA6B,CAC3B5D,UAAU,EACV3L,KAAM,SACN4L,QAAS,qDAKXpc,QAAQ6jC,WACV5lB,OAAOjC,MACLhc,QAAQ6jC,UACR,CAAErzB,KAAM,SAAU4L,QAAS,iCAC3B,CACE0nB,SAAU,CACR3nB,UAAU,EACV3L,KAAM,SACN4L,QAAS,+BAEX2nB,eAAgB,CACd5nB,UAAU,EACV3L,KAAM,SACN4L,QAAS,qCAEX4nB,WAAY,CACV7nB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAOjBte,KAAKu4B,YAAcr2B,QACnBlC,KAAKu4B,YAAY5C,QAAU,IAAIF,cAC7Bz1B,KACAA,KAAKu4B,YAAY5C,SAAW,IAG9B31B,KAAKu4B,YAAYxW,gBACqB,IAApC/hB,KAAKu4B,YAAYxW,gBACb/hB,KAAKu4B,YAAYxW,eAGvB/hB,KAAKu4B,YAAYtW,4BAA8B/f,QAAQ+f,4BACnDtd,SAASzC,QAAQ+f,4BAA6B,GAC9C,EAEJjiB,KAAKu4B,YAAY4N,OACdnmC,KAAKu4B,YAAYwN,WAAa/lC,KAAKu4B,YAAYwN,UAAUC,UAC1DhmC,KAAKu4B,YAAYe,OAAOt4B,MAAM,KAAK,GAErChB,KAAKu4B,YAAY6N,aACdpmC,KAAKu4B,YAAYwN,WAAa/lC,KAAKu4B,YAAYwN,UAAUE,gBAC1D,WAAajmC,KAAKu4B,YAAYe,OAAS,IAEzCt5B,KAAKu4B,YAAYjD,QACft1B,KAAKu4B,YAAYwN,WAAa/lC,KAAKu4B,YAAYwN,UAAUG,WAE3DlmC,KAAKo7B,mBAAqB,IAAI5D,mBAAmBx3B,KAAKu4B,aAEtDv4B,KAAKg7B,OAAS,IAAIqL,eAAermC,KAAKu4B,aACtCv4B,KAAK+V,SAAW,IAAI6iB,SAAS54B,KAAMA,KAAKu4B,aACxCv4B,KAAKi8B,MAAQ,IAAI+D,MAAMhgC,KAAMA,KAAKu4B,aAClCv4B,KAAK84B,0BAA4B,IAAIN,0BACnCx4B,KACAA,KAAKu4B,aAEPv4B,KAAKy4B,kBAAoB,IAAIH,kBAAkBt4B,MAC/CA,KAAKsmC,gBAAkB,IAAI/F,YAAYvgC,KAAMA,KAAKu4B,aAClDv4B,KAAKumC,eAAiB,IAAIlhB,eAAerlB,KAAKu4B,aCxKhD,SAASiO,2BAA2Bt2B,QAAShO,SAC3ClC,KAAKu4B,YAAcr2B,QACnBlC,KAAKkQ,QAAUA,QCHjB,SAASu2B,aAAav2B,QAAShO,SAC7BlC,KAAKu4B,YAAcr2B,QACnBlC,KAAKkQ,QAAUA,QCoBjB,SAASm2B,eAAexN,MAAO32B,SAIJ,IAArBjB,UAAUb,OACZJ,KAAK64B,MAAQA,MAEb32B,QAAU22B,MAIZ1Y,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEgb,OAAQ,CAAE5mB,KAAM,SAAU4L,QAAS,6BACnCod,SAAU,CAAEhpB,KAAM,SAAU4L,QAAS,+BACrCnQ,aAAc,CACZkQ,UAAU,EACV3L,KAAM,SACN4L,QAAS,6BAEXmc,aAAc,CACZpc,UAAU,EACV3L,KAAM,SACN4L,QAAS,6BAEXuc,YAAa,CACXxc,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEXkkB,MAAO,CAAEnkB,UAAU,EAAM3L,KAAM,SAAU4L,QAAS,sBAClD8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,yBAEXya,4BAA6B,CAC3B1a,UAAU,EACV3L,KAAM,UACN4L,QAAS,mDAEXyD,eAAgB,CACd1D,UAAU,EACV3L,KAAM,UACN4L,QAAS,sCAEX0D,eAAgB,CACd3D,UAAU,EACV3L,KAAM,SACN4L,QAAS,wCAMfte,KAAKu4B,YAAcr2B,QACnBlC,KAAKu4B,YAAYxW,gBACqB,IAApC/hB,KAAKu4B,YAAYxW,gBACb/hB,KAAKu4B,YAAYxW,eAGvB/hB,KAAKu4B,YAAY+C,QAAWt7B,KAAKu4B,YAAYe,QAAoE,IAA1Dt5B,KAAKu4B,YAAYe,OAAO5nB,cAAcjO,QAAQ,QAC/FzD,KAAKu4B,YAAYe,OACjB,WAAat5B,KAAKu4B,YAAYe,OAEpCt5B,KAAKkQ,QAAU,IAAI4R,eAAe9hB,KAAKu4B,aAEvCv4B,KAAK0iC,aAAe,IAAI8D,2BACtBxmC,KAAKkQ,QACLlQ,KAAKu4B,aAEPv4B,KAAKi9B,aAAe,IAAIwJ,aAAazmC,KAAKkQ,QAASlQ,KAAKu4B,aAExDv4B,KAAKgP,KAAO,IAAI2V,KAAK,CACnBC,kBAAmB1iB,QAAQ62B,8BAE7B/4B,KAAKumC,eAAiB,IAAIlhB,eAAerlB,KAAKu4B,aC7FhD,SAASmO,WAAWxkC,SAElBie,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEgb,OAAQ,CAAE5mB,KAAM,SAAU4L,QAAS,6BACnCqoB,MAAO,CAAEj0B,KAAM,SAAU4L,QAAS,4BAClCyD,eAAgB,CACd1D,UAAU,EACV3L,KAAM,UACN4L,QAAS,sCAEX0D,eAAgB,CACd3D,UAAU,EACV3L,KAAM,SACN4L,QAAS,wCAMfte,KAAKu4B,YAAcr2B,QAEnBlC,KAAKu4B,YAAYllB,QAAU,CACzBuzB,cAAe,UAAY5mC,KAAKu4B,YAAYoO,OAG9C3mC,KAAKkQ,QAAU,IAAI4R,eAAe9hB,KAAKu4B,aACvCv4B,KAAKu4B,YAAY+C,QAAU7G,QACzB,WAAaz0B,KAAKu4B,YAAYe,OAC9B,MACA,MJuJJwM,QAAQtkC,UAAU2gC,UAAY,SAASjgC,QAAS2J,IAC9C,IAAIg7B,SACAr3B,IAEC3D,IAAyB,mBAAZ3J,QAIhBA,QAAUA,SAAW,IAHrB2J,GAAK3J,QACLA,QAAU,IAKZ,IAAIw3B,QAAUpC,aAAalV,YAEvB0kB,aACe58B,IAAjBhI,QAAQ6d,KAAqB2Z,QAAQriB,SAAS0I,KAAO7d,QAAQ6d,KAK/D,GAJA+mB,QAAUA,QAAQrmC,QAAQ,SAAU,KAEpComC,SAAWpF,UAASqF,UAEPrlC,eAAe,SAO1B,OANA+N,IAAMG,MAAM2V,cAAcuhB,SAASl3B,MAAOk3B,SAASvgB,mBAE/CugB,SAASzN,QACX5pB,IAAI4pB,MAAQyN,SAASzN,OAGhBvtB,GAAG2D,KAGZ,IACGq3B,SAASplC,eAAe,kBACxBolC,SAASplC,eAAe,cACxBolC,SAASplC,eAAe,iBAEzB,OAAOoK,GAAG,KAAM,MAElB,IAAIk7B,eACF/mC,KAAKu4B,YAAYpqB,cACjBjM,QAAQiM,cACR,IACAnN,MAAM,KACR,OACE+lC,cAAc3mC,OAAS,IACa,IAApC2mC,cAActjC,QAAQ,WACrBojC,SAASplC,eAAe,gBAElBoK,GACL8D,MAAM2V,cACJ,eACA,oGAKJyhB,cAAc3mC,OAAS,IACgB,IAAvC2mC,cAActjC,QAAQ,cACrBojC,SAASplC,eAAe,YAElBoK,GACL8D,MAAM2V,cACJ,eACA,mGAICtlB,KAAKm7B,+BAA+Bj5B,QAAS2kC,SAAUh7B,KAqBhEi6B,QAAQtkC,UAAU25B,+BAAiC,SACjDj5B,QACAg5B,WACArvB,IAEA,IAAI6E,MAAQ1Q,KACZkC,QAAQ8kC,0BACN9kC,QAAQ8kC,2BAA6B9kC,QAAQ+kC,sBAC/C,IAAI7N,MAAQ8B,WAAW9B,MACnB3B,YAAcz3B,KAAKo7B,mBAAmB7B,qBAAqBH,OAC3D8N,iBACFhlC,QAAQk3B,OAAU3B,aAAeA,YAAY2B,OAAU,KAErD+N,6BAA+BD,mBAAqB9N,MAIxD,MAFGA,QAAU8N,kBAAoBhlC,QAAQ8kC,6BAENG,6BACjC,OAAOt7B,GAAG,CACR8D,MAAO,gBACP6V,iBAAkB,4BAGtB,IAAI4hB,iBACFllC,QAAQs0B,OAAUiB,aAAeA,YAAYjB,OAAU,KAErD2C,SAAWj3B,QAAQk3B,OAAU3B,aAAeA,YAAY0B,UAAa,KAErE/kB,SAAW,SAAS5E,IAAKumB,SAC3B,GAAIvmB,IACF,OAAO3D,GAAG2D,KAGV,IAAIqW,IADF4R,aAAeA,YAAY1R,qBAEzBgQ,UACFlQ,IAAMkQ,QAAQlQ,KAEhBnV,MAAM61B,eAAe30B,IAAI6lB,YAAY1R,mBAAoBF,MAE3D,OAAOha,GAAG,KAsFd,SAAgCw7B,SAAUlO,SAAUwN,OAClD,MAAO,CACLW,YAAaD,SAASE,cAAgB,KACtCC,QAASH,SAASI,UAAY,KAC9BC,eAAgBf,OAAS,KACzBxN,SAAUA,UAAY,KACtBwO,aAAcN,SAASO,eAAiB,KACxCxO,MAAOiO,SAASjO,OAAS,KACzByO,UAAWR,SAASS,WAAanjC,SAAS0iC,SAASS,WAAY,IAAM,KACrEC,UAAWV,SAASW,YAAc,KAClCxF,MAAO6E,SAAS7E,OAAS,MAhGTyF,CAAuB/M,WAAY/B,SAAUpD,WAG/D,OAAKmF,WAAWuM,SAGTznC,KAAKkoC,cAAchN,WAAWuM,SAAUL,kBAAkB,SAC/De,gBACApS,SAEA,IAAKoS,gBACH,OAAKjN,WAAWqM,cAIXxR,QAAQqS,SAKN,IAAIC,GAAkBxR,oBAC3BqE,WAAWqM,aACX,QACAxR,QAAQqS,SACR,SAAS54B,KACP,OAAIA,IACK4E,SAASzE,MAAMsW,aAAazW,IAAI8O,UAElClK,SAAS,KAAM2hB,YAhBjB3hB,SAAS,KAAM2hB,SAqB1B,GAC4B,kBAA1BoS,gBAAgBx4B,OACfw4B,gBAAgB3iB,kBACf2iB,gBAAgB3iB,iBAAiB/hB,QAC/B,uDACG,EAEP,OAAO2Q,SAAS+zB,iBAIlB,IAAIG,cAAe,IAAID,GAAkBxkC,OAAOq3B,WAAWuM,UAG3D,GAAgC,UAA5Ba,aAAax2B,OAAOyiB,IACtB,OAAOngB,SAAS+zB,iBAGlB,IAAKG,aAAavS,QAAQS,OAAS,QAAU4Q,iBAC3C,OAAOhzB,SAAS,CACdzE,MAAO,gBACP6V,iBACE,iEACA4hB,iBACA,aACAkB,aAAavS,QAAQS,MACrB,MAIN,IAAK0E,WAAWqM,aAAc,CAM5B,OAAOnzB,SALkB,CACvBzE,MAAO,gBACP4V,YACE,8UAMN,OAAO7U,MAAMsqB,OAAOuN,SAASrN,WAAWqM,cAAc,SACpDiB,YACAC,SAGA,OAAID,YACKp0B,SAASo0B,aAEXp0B,SAAS,KAAMq0B,eA7EjBr0B,SAAS,KAAM,OA+G1B0xB,QAAQtkC,UAAU0mC,cAAgB,SAASvB,MAAOnQ,MAAO3qB,IACxC,IAAIw8B,EAAgB,CACjClT,OAAQn1B,KAAKu4B,YAAY6N,aACzB9Q,QAASt1B,KAAKu4B,YAAYjD,QAC1BF,SAAUp1B,KAAKu4B,YAAYmD,SAC3BrG,OAAQr1B,KAAKu4B,YAAYlD,QAAU,GACnCE,OAAQv1B,KAAKu4B,YAAYhD,OACzBC,QAASx1B,KAAKu4B,YAAY/C,SAAWqQ,eAG9BvR,OAAOqS,MAAOnQ,OAAO,SAAShnB,IAAKumB,SAC1C,GAAIvmB,IACF,OAAO3D,GAAG8D,MAAMsW,aAAazW,IAAI8O,UAGnCzS,GAAG,KAAMkqB,aA0Bb+P,QAAQtkC,UAAUknC,UAAY,SAASxmC,QAAS2J,IAC9C,IACIi3B,iBAAmB5gC,QAAQ4gC,eAC3B1C,oBAAsBl+B,QAAQk+B,sBAAuB,EACrDC,kBACFn+B,QAAQm+B,mBAAqB/I,aAAalV,YAAYd,OACpD/S,QAAUrM,QAAQqM,QAClBmC,MAAQ1Q,KAERuV,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,cACA,eACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAERqT,OAAOpH,aAAeoH,OAAOpH,cAAgB,QAC7CoH,OAAOklB,aAAellB,OAAOklB,cAAgB,WAC7CllB,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,QAEzC4K,OAAOjC,MAAM3I,OAAQ,CACnB7C,KAAM,SACN4L,QAAS,mCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9C/I,OAAOmlB,OAAS,OAEhBnlB,OAASkN,aAAa9B,UAAUpL,OAAQ,CACtC,iBACA,SACA,sBACA,sBAGQ2qB,4BAA4B79B,OAAO,CAC3C89B,kBAAmBngC,KAAKg7B,OAAOC,kBAAkB1lB,QACjD6qB,oBAAqBA,oBACrBC,kBAAmBA,kBACnB9xB,QAASA,UAGH8sB,MAAMyH,gBAAgB,SAAStzB,IAAKuQ,MAC1C,GAAoB,iBAATA,KAGT,OAAOlU,GAAG2D,IAAKuQ,MAEjBrP,MAAMyxB,UAAU,CAAEpiB,KAAMA,MAAQlU,QAmBpCi6B,QAAQtkC,UAAUmnC,aAAe,SAASzmC,QAAS2J,IACjD,IAAI0J,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAER,MAA4B,SAAxBqT,OAAOpH,aACFtC,GAAG,CACR8D,MAAO,QACP2W,kBAAmB,kCAIlBpkB,QAAQs0B,QACXjhB,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,SAGtCA,OAAOslB,aAOZ1a,OAAOjC,MAAM3I,OAAQ,CACnB7C,KAAM,SACN4L,QAAS,mCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9C/I,OAASkN,aAAa9B,UAAUpL,OAAQ,CACtC,iBACA,SACA,6BAEFvV,KAAKy4B,kBAAkB+B,IACrBjlB,OACAwmB,aAAgBlwB,GAAI,CAAE2a,kBAAkB,EAAML,cAAc,MAnBrDta,GAAG,CACR8D,MAAO,QACP2W,kBAAmB,iCA+BzBwf,QAAQtkC,UAAUonC,eAAiB,SAAS1mC,QAAS2J,IACnD,OAAO7L,KAAKg7B,OAAOiC,aAAa2L,eAAe1mC,QAAS2J,KAgB1Di6B,QAAQtkC,UAAUqnC,kBAAoB,SAAS3mC,QAAS2J,IACtD,IAAIi9B,WAAarmB,aACdnd,MAAMtF,KAAKu4B,YAAa,CACvB,eACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,QAAQ4mC,YAGhB,OADA5mC,QAAQ4mC,WAAa9oC,KAAKo7B,mBAAmBpT,QAAQ8gB,YAC9C9oC,KAAKg7B,OAAO0H,aAAavlB,MAAMjb,QAAS2J,KAcjDi6B,QAAQtkC,UAAU07B,OAAS,SAASh7B,QAAS2J,IAC3C,OAAO7L,KAAKg7B,OAAOiC,aAAaC,OAAOh7B,QAAS2J,KAoBlDi6B,QAAQtkC,UAAU+6B,UAAY,SAASr6B,SACrC,IAAIqT,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAERie,OAAOjC,MACL3I,OACA,CAAE7C,KAAM,SAAU4L,QAAS,kCAC3B,CACEnQ,aAAc,CACZuE,KAAM,SACN4L,QAAS,sCAKf/I,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,SAClCitB,MAAQjtB,OAAOitB,OAAS,uBAE/BlL,aAAavhB,SAAS/V,KAAKg7B,OAAOC,kBAAkB1lB,UAgBtDuwB,QAAQtkC,UAAUunC,mBAAqB,SAAS7mC,QAAS2J,IACvD,IAAI6E,MAAQ1Q,KAEZ,OAAOA,KAAKg7B,OAAOiC,aAAaC,OAC9Bza,aAAa9B,UAAUze,QAAS,CAAC,kBACjC,SAASsN,KACP,GAAIA,IACF,OAAO3D,GAAG2D,KAEZtN,QAAQ82B,MAAQ92B,QAAQ0jB,WACnB1jB,QAAQyQ,WACXzQ,QAAQyQ,SAAWzQ,QAAQq5B,OAE7B7qB,MAAMsqB,OAAOK,MAAMn5B,QAAS2J,QA2BlCi6B,QAAQtkC,UAAU65B,MAAQ,SAASn5B,QAAS2J,IAC1C,IAAI0J,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SACRqT,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,QAGvC+hB,aAAalV,YAAY/K,SAASqI,OAAS1f,KAAKu4B,YAAYe,QAE5D/jB,OAAOqQ,WAAarQ,OAAOyjB,aACpBzjB,OAAOyjB,MACdh5B,KAAKsmC,gBAAgBjL,MAAM9lB,OAAQ1J,KAEnC7L,KAAK84B,0BAA0BuC,MAAM9lB,OAAQ1J,KAgBjDi6B,QAAQtkC,UAAUwnC,kBAAoB,SAAS9mC,QAAS2J,IACtD,IAAI0J,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAKR,GAJAqT,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,QAGvC+hB,aAAalV,YAAY/K,SAASqI,OAAS1f,KAAKu4B,YAAYe,OAE5Dt5B,KAAKyiC,mBAAmBltB,OAAQ1J,QAC3B,CACL,IAAIo9B,mBAAqBxmB,aAAapD,OACpC,CACEuc,eAAgB,qDAChB5C,MAAOzjB,OAAOqQ,WACdjT,SAAU4C,OAAOgmB,OAAShmB,OAAOotB,YACjChH,IAAKpmB,OAAOqtB,kBAEdngB,aAAa9B,UAAUpL,OAAQ,CAC7B,aACA,QACA,cACA,sBAGJvV,KAAK84B,0BAA0BuC,MAAM4N,mBAAoBp9B,MAU7Di6B,QAAQtkC,UAAU0nC,kCAAoC,WACpDlpC,KAAKmpC,2BAQPrD,QAAQtkC,UAAU2nC,wBAA0B,WAC1CnpC,KAAK84B,0BAA0B1kB,YAkBjC0xB,QAAQtkC,UAAU4nC,OAAS,SAASlnC,SAClCo1B,aAAavhB,SAAS/V,KAAKg7B,OAAOqO,eAAennC,WAenD4jC,QAAQtkC,UAAUihC,mBAAqB,SAASvgC,QAAS2J,IACvD,IAAI6E,MAAQ1Q,KACRuV,OAASkN,aACVnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,UAEDzX,KAAK5e,SAcR,OAZAie,OAAOjC,MACL3I,OACA,CAAE7C,KAAM,SAAU4L,QAAS,kCAC3B,CACEnQ,aAAc,CACZuE,KAAM,SACN4L,QAAS,qCAKf/I,OAASvV,KAAKo7B,mBAAmBpT,QAAQzS,QAClCvV,KAAKg7B,OAAO0H,aAAapO,OAAO/e,QAAQ,SAAS/F,KACtD,OAAIA,IACK3D,GAAG2D,KAEL8nB,aAAavhB,SAClBrF,MAAMsqB,OAAO0H,aAAa4G,eAAe/zB,aAkB/CuwB,QAAQtkC,UAAU+nC,cAAgB,SAASrF,QAAShiC,QAASkS,UAC3D,OAAOo1B,QAAQzE,OAAO/kC,KAAKg7B,OAAQkJ,QAAShiC,QAASkS,WCt6BvDoyB,2BAA2BhlC,UAAU8nC,eAAiB,SAASpnC,SAC7D,IAAIqT,OACAk0B,QAyDJ,OAtDAtpB,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvCskB,iBAAkB,CAChBlwB,KAAM,SACN4L,QAAS,uCAEXqkB,YAAa,CACXtkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCACTC,UAAW,SAASpb,GAClB,OAAQA,EAAEo4B,QAGdA,MAAO,CACLld,UAAU,EACV3L,KAAM,SACN4L,QAAS,2BACTC,UAAW,SAASpb,GAClB,OAAQA,EAAEw/B,gBAOlBptB,OAASkN,aACNnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,eACA,cACA,QACA,WACA,QACA,QACA,YACA,WACA,UAEDzX,KAAK5e,SAGJlC,KAAKu4B,YAAYxW,iBACnBxM,OAAO6vB,YAAcplC,KAAKkQ,QAAQ2S,oBAGpCtN,OAASkN,aAAaxC,YAAY1K,OAAQ,CAAC,gBAE3Ck0B,QAAUhI,cAAalsB,QAEhBkf,QACLz0B,KAAKu4B,YAAY+C,QACjB,eACA,kBACA,IAAMmO,UAIVjD,2BAA2BhlC,UAAU2b,MAAQ,SAASjb,QAAS2J,IAC7D,IAAIoF,IACA+H,KA2EJ,OAxEAmH,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvChL,KAAM,CACJZ,KAAM,SACN4L,QAAS,0BACT/V,OAAQ,CAAC,OAAQ,QACjBiW,cAAe,oCAEjBmkB,YAAa,CACXtkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCACTC,UAAW,SAASpb,GAClB,MAAkB,SAAXA,EAAEmQ,OAAoBnQ,EAAEo4B,QAGnCA,MAAO,CACLld,UAAU,EACV3L,KAAM,SACN4L,QAAS,2BACTC,UAAW,SAASpb,GAClB,MAAkB,SAAXA,EAAEmQ,OAAoBnQ,EAAEw/B,cAGnCmG,WAAY,CACVzqB,UAAU,EACV3L,KAAM,SACN4L,QAAS,mCAMf6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,eAAgB,UAExDtiB,KAAOyJ,aACJnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,cACA,UAEDzX,KAAK5e,UAECsgC,QACPxpB,KAAK8vB,WAAa9vB,KAAK8vB,YAAc,GACrC9vB,KAAK8vB,WAAWtG,MAAQxpB,KAAK8vB,WAAWtG,OAASxpB,KAAKwpB,OAGpDxpB,KAAK6hB,cACP7hB,KAAK8vB,WAAa9vB,KAAK8vB,YAAc,GACrC9vB,KAAK8vB,WAAWY,aACd1wB,KAAK8vB,WAAWjO,aAAe7hB,KAAK6hB,aAGpC7hB,KAAK7K,eACP6K,KAAK8vB,WAAa9vB,KAAK8vB,YAAc,GACrC9vB,KAAK8vB,WAAWa,cACd3wB,KAAK8vB,WAAW36B,cAAgB6K,KAAK7K,qBAGlC6K,KAAK6hB,mBACL7hB,KAAK7K,oBACL6K,KAAKwpB,MAEZxpB,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,cAAe,eAE/ChZ,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAGzB26B,2BAA2BhlC,UAAU8yB,OAAS,SAASpyB,QAAS2J,IAC9D,IAAIoF,IACA24B,YA6CJ,OA1CAzpB,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvCskB,iBAAkB,CAChBlwB,KAAM,SACN4L,QAAS,uCAEXqkB,YAAa,CACXtkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCACTC,UAAW,SAASpb,GAClB,OAAQA,EAAEo4B,QAGdA,MAAO,CACLld,UAAU,EACV3L,KAAM,SACN4L,QAAS,2BACTC,UAAW,SAASpb,GAClB,OAAQA,EAAEw/B,gBAOlBxiB,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CsrB,YAAcnnB,aAAavD,KAAKhd,QAAS,CACvC,aACA,mBACA,cACA,QACA,gBAEF0nC,YAAcnnB,aAAaxC,YAAY2pB,YAAa,CAAC,gBAErD34B,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,eAAgB,UAEjDt7B,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAKs2B,aACL14B,IAAI6qB,aAAgBlwB,MCpLzB46B,aAAajlC,UAAU07B,OAAS,SAASh7B,QAAS2J,IAChD,IAAIoF,IACA+H,KACA6wB,SA+BJ,OA7BA1pB,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvCid,MAAO,CAAE7oB,KAAM,SAAU4L,QAAS,4BAClC1L,SAAU,CAAEF,KAAM,SAAU4L,QAAS,iCAGzC6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,gBAAiB,UAIzDuO,UAFA7wB,KAAOyJ,aAAand,MAAMtF,KAAKu4B,YAAa,CAAC,WAAY,UAAUzX,KAAK5e,UAExD4nC,eAAiB9wB,KAAK+wB,aAEtC/wB,KAAOyJ,aAAa9B,UAAU3H,KAAM,CAClC,QACA,eACA,kBAGFA,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,gBAEnC6wB,WACF7wB,KAAK8wB,cAAgBD,UAGhB7pC,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAkBzB46B,aAAajlC,UAAUonC,eAAiB,SAAS1mC,QAAS2J,IACxD,IAAIoF,IACA+H,KAoBJ,OAlBAmH,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvCid,MAAO,CAAE7oB,KAAM,SAAU4L,QAAS,8BAGtC6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,gBAAiB,mBAEzDtiB,KAAOyJ,aACJnd,MAAMtF,KAAKu4B,YAAa,CAAC,aACzBzX,KAAK5e,QAAS,CAAC,QAAS,eAE3B8W,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,gBAEhChZ,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MCazBw6B,eAAe7kC,UAAUy5B,kBAAoB,SAAS/4B,SACpD,IAAIqT,OACAk0B,QA+EJ,OA7EAtpB,OAAOjC,MAAMhc,QAAS,CACpBwQ,KAAM,SACN4L,QAAS,mCAGX/I,OAASkN,aACNnd,MAAMtF,KAAKu4B,YAAa,CACvB,WACA,eACA,eACA,cACA,QACA,aAEDzX,KAAK5e,SAGRie,OAAOjC,MACL3I,OACA,CAAE7C,KAAM,SAAU4L,QAAS,kCAC3B,CACEod,SAAU,CAAEhpB,KAAM,SAAU4L,QAAS,+BACrCuc,YAAa,CACXxc,UAAU,EACV3L,KAAM,SACN4L,QAAS,kCAEXnQ,aAAc,CACZuE,KAAM,SACN4L,QAAS,mCAEXkY,MAAO,CACL9jB,KAAM,SACN4L,QAAS,2BACTC,UAAW,SAASpb,GAClB,OACsC,IAApCA,EAAEgL,aAAa1K,QAAQ,UACiB,IAAxCN,EAAEgL,aAAa1K,QAAQ,cAI7B++B,MAAO,CACLnkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEX8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCAOXte,KAAKu4B,YAAYxW,iBACnBxM,OAAO6vB,YAAcplC,KAAKkQ,QAAQ2S,oBAGhCtN,OAAOy0B,kBAAoB7pB,OAAOze,QAAQ6T,OAAOy0B,oBACnDz0B,OAAOy0B,iBAAmBz0B,OAAOy0B,iBAAiBlpC,KAAK,MAGzDyU,OAASkN,aAAa9B,UAAUpL,OAAQ,CACtC,WACA,eACA,SACA,SACA,UACA,aAEFA,OAASkN,aAAaxC,YAAY1K,OAAQ,CAAC,gBAC3CA,OAAS00B,oBAAoB/iB,qBAAqBlnB,KAAKgP,KAAMuG,QAE7Dk0B,QAAUhI,cAAalsB,QAEhBkf,QAAQz0B,KAAKu4B,YAAY+C,QAAS,YAAa,IAAMmO,UAiB9DpD,eAAe7kC,UAAU6nC,eAAiB,SAASnnC,SACjD,IAAIqT,OACAk0B,QA6BJ,OA3BAtpB,OAAOjC,MAAMhc,QAAS,CACpBmc,UAAU,EACV3L,KAAM,SACN4L,QAAS,mCAGX/I,OAASkN,aACNnd,MAAMtF,KAAKu4B,YAAa,CAAC,aACzBzX,KAAK5e,SAAW,IAGflC,KAAKu4B,YAAYxW,iBACnBxM,OAAO6vB,YAAcplC,KAAKkQ,QAAQ2S,oBAGpCtN,OAASkN,aAAaxC,YAAY1K,OAAQ,CAAC,cAAe,aAE1Dk0B,QAAUhI,cAAahf,aAAa9B,UAAUpL,OAAQ,CAAC,eAErDrT,cACsBgI,IAAtBhI,QAAQgoC,YACc,IAAtBhoC,QAAQgoC,WACc,UAAtBhoC,QAAQgoC,YAERT,SAAW,cAGNhV,QAAQz0B,KAAKu4B,YAAY+C,QAAS,KAAM,SAAU,IAAMmO,UAoCjEpD,eAAe7kC,UAAU2oC,0BAA4B,SAASjoC,QAAS2J,IAsBrE,OArBAsU,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACE3L,SAAU,CAAED,KAAM,SAAU4L,QAAS,+BACrC1L,SAAU,CAAEF,KAAM,SAAU4L,QAAS,+BACrCkkB,MAAO,CACLnkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEX8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCAKfpc,QAAQkoC,UAAY,WAEbpqC,KAAKqqC,WAAWnoC,QAAS2J,KAgBlCw6B,eAAe7kC,UAAU65B,MAAQ,SAASn5B,QAAS2J,IAuBjD,OAtBAsU,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACE3L,SAAU,CAAED,KAAM,SAAU4L,QAAS,+BACrC1L,SAAU,CAAEF,KAAM,SAAU4L,QAAS,+BACrC0a,MAAO,CAAEtmB,KAAM,SAAU4L,QAAS,4BAClCkkB,MAAO,CACLnkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEX8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCAKfpc,QAAQkoC,UAAY,mDAEbpqC,KAAKqqC,WAAWnoC,QAAS2J,KASlCw6B,eAAe7kC,UAAU6oC,WAAa,SAASnoC,QAAS2J,IACtD,IAAIoF,IACA+H,KAoCJ,OAlCAmH,OAAOjC,MAAMhc,QAAS,CACpBwQ,KAAM,SACN4L,QAAS,mCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS,SAEjDtiB,KAAOyJ,aACJnd,MAAMtF,KAAKu4B,YAAa,CAAC,WAAY,QAAS,aAC9CzX,KAAK5e,SAERie,OAAOjC,MACLlF,KACA,CAAEtG,KAAM,SAAU4L,QAAS,kCAC3B,CACEod,SAAU,CAAEhpB,KAAM,SAAU4L,QAAS,+BACrC8rB,UAAW,CAAE13B,KAAM,SAAU4L,QAAS,gCACtCkkB,MAAO,CACLnkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,4BAEX8W,SAAU,CACR/W,UAAU,EACV3L,KAAM,SACN4L,QAAS,iCAKftF,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,gBACvCA,KAAOixB,oBAAoBhjB,iBAAiBjnB,KAAKgP,KAAMgK,MAEhDhZ,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAmBzBw6B,eAAe7kC,UAAUqhC,uBAAyB,SAAS3gC,QAAS2J,IAClE,IAAIoF,IACA+H,KA4BJ,OA1BAmH,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACE3L,SAAU,CAAED,KAAM,SAAU4L,QAAS,+BACrC1L,SAAU,CAAEF,KAAM,SAAU4L,QAAS,+BACrCsH,WAAY,CAAElT,KAAM,SAAU4L,QAAS,iCACvCkkB,MAAO,CACLnkB,UAAU,EACV3L,KAAM,SACN4L,QAAS,8BAIf6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS,MAEjDtiB,KAAOyJ,aACJnd,MAAMtF,KAAKu4B,YAAa,CAAC,WAAY,UACrCzX,KAAK5e,QAAS,CAAC,WAAY,WAAY,QAAS,aAAc,YAEjE8W,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,iBAElCsxB,WAAatxB,KAAKsxB,YAAc,WAE9BtqC,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAUzBw6B,eAAe7kC,UAAUiiC,WAAa,SAASC,sBAAuB73B,IAOpE,GALK7L,KAAK64B,QACR74B,KAAK64B,MAAQ,IAAIiN,QAAQ9lC,KAAKu4B,cAG9BjB,aAAalV,YAAY/K,SAASqI,OAAS1f,KAAKu4B,YAAYe,OAE5D,OAAOt5B,KAAK64B,MAAMyN,gBAAgB7C,WAAWC,sBAAuB73B,IAEjC,mBAA1B63B,wBACT73B,GAAK63B,uBAEPvjB,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAC9C,IAAIisB,SAAWvqC,KAAKu4B,YAAYmD,SAC5B8O,mBAAqBxqC,KAAKumC,eAAet5B,OAAS,GAEtDjN,KAAK64B,MAAM8P,aACT,CACEx6B,aAAc,iBACdq0B,MAAO,uBACP5c,WAAY4kB,mBAAmBzkB,mBAC/BxX,QAAS,MAEX,SAASiB,IAAKmO,QACZ,OAAInO,IACgB,mBAAdA,IAAIG,MACC9D,GAAG,KAAM,CAAE4+B,KAAK,KAEP,qBAAdj7B,IAAIG,QACNH,IAAI8W,kBACF,iIAEGza,GAAG2D,IAAK,CAAEi7B,KAAK,KAGtBD,mBAAmBxkB,aACnBwkB,mBAAmBxkB,cAAgBrI,OAAO+pB,eAAe7hB,IAElDha,GAAG2D,IAAK,CAAEi7B,KAAK,IAEjB5+B,GAAG,KAAM,CACdka,mBAAoB,CAClB/T,KAAMw4B,mBAAmBzkB,oBAE3B2kB,eAAgB/sB,OAAO+pB,eAAe7hB,IACtC8kB,iBACEhtB,OAAO+pB,eAAenM,OAAS5d,OAAO+pB,eAAe11B,KACvD44B,iBAAkBL,SAClBM,eAAgB,CAACN,UACjBE,KAAK,QAoBbpE,eAAe7kC,UAAU+mC,SAAW,SAASjB,YAAaz7B,IACxD,IAAIoF,IAUJ,OARAkP,OAAOjC,MAAMopB,YAAa,CACxB50B,KAAM,SACN4L,QAAS,uCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,YAEjCt7B,KAAKkQ,QACTjD,IAAIgE,KACJW,IAAI,gBAAiB,UAAY01B,aACjCp2B,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MAU7CkgB,eAAe7kC,UAAU8jC,aAAe,SAASz5B,IAG/C,GAFAsU,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,+BAEzCte,KAAKu4B,YAAYa,MACpB,OAAOvtB,KAGT,IAAIoF,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,mBAAoB,aAEhE,OAAOt7B,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK,CAAE8lB,MAAOp5B,KAAKu4B,YAAYa,QAC/BloB,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MAyB7CkgB,eAAe7kC,UAAUspC,WAAa,SAAS5oC,QAAS2J,IACtD,IAAIoF,IACA+H,KAiBJ,OAfAmH,OAAOjC,MACLhc,QACA,CAAEwQ,KAAM,SAAU4L,QAAS,kCAC3B,CACEgsB,WAAY,CAAE53B,KAAM,SAAU4L,QAAS,mCAG3C6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,cAExCtiB,KAAOyJ,aAAand,MAAMtF,KAAKu4B,YAAa,CAAC,aAAazX,KAAK5e,SAE/D8W,KAAOyJ,aAAaxC,YAAYjH,KAAM,CAAC,gBAEhChZ,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK0F,MACL9H,IAAI6qB,aAAgBlwB,MAUzBw6B,eAAe7kC,UAAUupC,eAAiB,SAASl/B,IACjD,IAAIoF,IAMJ,OAJAkP,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,OAAQ,SAAU,WAEnDt7B,KAAKkQ,QAAQjD,IAAIgE,KAAKC,IAAI6qB,aAAgBlwB,MC1jBnD66B,WAAWllC,UAAUwpC,QAAU,SAASC,OAAQp/B,IAC9C,IAAIoF,IAUJ,OARAkP,OAAOjC,MAAM+sB,OAAQ,CACnBv4B,KAAM,SACN4L,QAAS,kCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS2P,QAE1CjrC,KAAKkQ,QAAQjD,IAAIgE,KAAKC,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MAavEugB,WAAWllC,UAAU0pC,kBAAoB,SAASD,OAAQlB,aAAcl+B,IACtE,IAAIoF,IAcJ,OAZAkP,OAAOjC,MAAM+sB,OAAQ,CACnBv4B,KAAM,SACN4L,QAAS,kCAEX6B,OAAOjC,MAAM6rB,aAAc,CACzBr3B,KAAM,SACN4L,QAAS,wCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS2P,QAE1CjrC,KAAKkQ,QACT+L,MAAMhL,KACNqC,KAAK,CAAEw2B,cAAeC,eACtB74B,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MAY7CugB,WAAWllC,UAAU2pC,oBAAsB,SAASF,OAAQ14B,KAAM1G,IAChE,IAAIoF,IAcJ,OAZAkP,OAAOjC,MAAM+sB,OAAQ,CACnBv4B,KAAM,SACN4L,QAAS,kCAEX6B,OAAOjC,MAAM3L,KAAM,CACjBG,KAAM,SACN4L,QAAS,gCAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAE9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS2P,QAE1CjrC,KAAKkQ,QACT+L,MAAMhL,KACNqC,KAAKf,MACLrB,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MAY7CugB,WAAWllC,UAAU4pC,SAAW,SAASH,OAAQI,mBAAoBx/B,IACnE,IAAIoF,IAeJ,OAbAkP,OAAOjC,MAAM+sB,OAAQ,CACnBv4B,KAAM,SACN4L,QAAS,kCAEX6B,OAAOjC,MAAMmtB,mBAAoB,CAC/B34B,KAAM,SACN4L,QAAS,8CAEX6B,OAAOjC,MAAMrS,GAAI,CAAE6G,KAAM,WAAY4L,QAAS,8BAG9CrN,IAAMwjB,QAAQz0B,KAAKu4B,YAAY+C,QAAS,QAAS2P,OAAQ,cAElDjrC,KAAKkQ,QACTgM,KAAKjL,KACLqC,KAAK,CAAEg4B,UAAWD,qBAClBn6B,IAAI6qB,aAAgBlwB,GAAI,CAAEsa,cAAc,MC/J7C,UAAe,CACbkgB,eAAgBA,eAChBK,WAAYA,WACZZ,QAASA,QACT9iB,QAASA"} \ No newline at end of file diff --git a/build/auth0.min.js b/build/auth0.min.js new file mode 100644 index 00000000..d13cbfc7 --- /dev/null +++ b/build/auth0.min.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +!function(global,factory){"object"==typeof exports&&"undefined"!=typeof module?factory(exports):"function"==typeof define&&define.amd?define(["exports"],factory):factory((global=global||self).auth0={})}(this,(function(exports){"use strict";var commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function createCommonjsModule(fn,module){return fn(module={exports:{}},module.exports),module.exports}var urlJoin=createCommonjsModule((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray(val)){for(var mapped=[],i=0;i-1?val.split(","):val},parseKeys=function(givenKey,val,options,valuesParsed){if(givenKey){var key=options.allowDots?givenKey.replace(/\.([^.[]+)/g,"[$1]"):givenKey,child=/(\[[^[\]]*])/g,segment=options.depth>0&&/(\[[^[\]]*])/.exec(key),parent=segment?key.slice(0,segment.index):key,keys=[];if(parent){if(!options.plainObjects&&has$2.call(Object.prototype,parent)&&!options.allowPrototypes)return;keys.push(parent)}for(var i=0;options.depth>0&&null!==(segment=child.exec(key))&&i=0;--i){var obj,root=chain[i];if("[]"===root&&options.parseArrays)obj=[].concat(leaf);else{obj=options.plainObjects?Object.create(null):{};var cleanRoot="["===root.charAt(0)&&"]"===root.charAt(root.length-1)?root.slice(1,-1):root,index=parseInt(cleanRoot,10);options.parseArrays||""!==cleanRoot?!isNaN(index)&&root!==cleanRoot&&String(index)===cleanRoot&&index>=0&&options.parseArrays&&index<=options.arrayLimit?(obj=[])[index]=leaf:obj[cleanRoot]=leaf:obj={0:leaf}}leaf=obj}return leaf}(keys,val,options,valuesParsed)}},lib_parse=function(str,opts){var options=function(opts){if(!opts)return defaults$1;if(null!==opts.decoder&&void 0!==opts.decoder&&"function"!=typeof opts.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==opts.charset&&"utf-8"!==opts.charset&&"iso-8859-1"!==opts.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var charset=void 0===opts.charset?defaults$1.charset:opts.charset;return{allowDots:void 0===opts.allowDots?defaults$1.allowDots:!!opts.allowDots,allowPrototypes:"boolean"==typeof opts.allowPrototypes?opts.allowPrototypes:defaults$1.allowPrototypes,arrayLimit:"number"==typeof opts.arrayLimit?opts.arrayLimit:defaults$1.arrayLimit,charset:charset,charsetSentinel:"boolean"==typeof opts.charsetSentinel?opts.charsetSentinel:defaults$1.charsetSentinel,comma:"boolean"==typeof opts.comma?opts.comma:defaults$1.comma,decoder:"function"==typeof opts.decoder?opts.decoder:defaults$1.decoder,delimiter:"string"==typeof opts.delimiter||utils.isRegExp(opts.delimiter)?opts.delimiter:defaults$1.delimiter,depth:"number"==typeof opts.depth||!1===opts.depth?+opts.depth:defaults$1.depth,ignoreQueryPrefix:!0===opts.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof opts.interpretNumericEntities?opts.interpretNumericEntities:defaults$1.interpretNumericEntities,parameterLimit:"number"==typeof opts.parameterLimit?opts.parameterLimit:defaults$1.parameterLimit,parseArrays:!1!==opts.parseArrays,plainObjects:"boolean"==typeof opts.plainObjects?opts.plainObjects:defaults$1.plainObjects,strictNullHandling:"boolean"==typeof opts.strictNullHandling?opts.strictNullHandling:defaults$1.strictNullHandling}}(opts);if(""===str||null==str)return options.plainObjects?Object.create(null):{};for(var tempObj="string"==typeof str?function(str,options){var i,obj={},cleanStr=options.ignoreQueryPrefix?str.replace(/^\?/,""):str,limit=options.parameterLimit===1/0?void 0:options.parameterLimit,parts=cleanStr.split(options.delimiter,limit),skipIndex=-1,charset=options.charset;if(options.charsetSentinel)for(i=0;i-1&&(val=isArray$2(val)?[val]:val),has$2.call(obj,key)?obj[key]=utils.combine(obj[key],val):obj[key]=val}return obj}(str,options):str,obj=options.plainObjects?Object.create(null):{},keys=Object.keys(tempObj),i=0;i0?prefix+joined:""},componentEmitter=createCommonjsModule((function(module){function Emitter(obj){if(obj)return function(obj){for(var key in Emitter.prototype)obj[key]=Emitter.prototype[key];return obj}(obj)}module.exports=Emitter,Emitter.prototype.on=Emitter.prototype.addEventListener=function(event,fn){return this._callbacks=this._callbacks||{},(this._callbacks["$"+event]=this._callbacks["$"+event]||[]).push(fn),this},Emitter.prototype.once=function(event,fn){function on(){this.off(event,on),fn.apply(this,arguments)}return on.fn=fn,this.on(event,on),this},Emitter.prototype.off=Emitter.prototype.removeListener=Emitter.prototype.removeAllListeners=Emitter.prototype.removeEventListener=function(event,fn){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var cb,callbacks=this._callbacks["$"+event];if(!callbacks)return this;if(1==arguments.length)return delete this._callbacks["$"+event],this;for(var i=0;ib?1:0}function deterministicStringify(obj,replacer,spacer){var res,tmp=function deterministicDecirc(val,k,stack,parent){var i;if("object"==typeof val&&null!==val){for(i=0;i0)for(var i=0;i=this._maxRetries)return!1;if(this._retryCallback)try{var override=this._retryCallback(err,res);if(!0===override)return!0;if(!1===override)return!1}catch(err_){console.error(err_)}if(res&&res.status&&res.status>=500&&501!==res.status)return!0;if(err){if(err.code&&ERROR_CODES.includes(err.code))return!0;if(err.timeout&&"ECONNABORTED"===err.code)return!0;if(err.crossDomain)return!0}return!1},RequestBase.prototype._retry=function(){return this.clearTimeout(),this.req&&(this.req=null,this.req=this.request()),this._aborted=!1,this.timedout=!1,this.timedoutError=null,this._end()},RequestBase.prototype.then=function(resolve,reject){var _this=this;if(!this._fullfilledPromise){var self=this;this._endCalled&&console.warn("Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises"),this._fullfilledPromise=new Promise((function(resolve,reject){self.on("abort",(function(){if(!(_this._maxRetries&&_this._maxRetries>_this._retries))if(_this.timedout&&_this.timedoutError)reject(_this.timedoutError);else{var err=new Error("Aborted");err.code="ABORTED",err.status=_this.status,err.method=_this.method,err.url=_this.url,reject(err)}})),self.end((function(err,res){err?reject(err):resolve(res)}))}))}return this._fullfilledPromise.then(resolve,reject)},RequestBase.prototype.catch=function(cb){return this.then(void 0,cb)},RequestBase.prototype.use=function(fn){return fn(this),this},RequestBase.prototype.ok=function(cb){if("function"!=typeof cb)throw new Error("Callback required");return this._okCallback=cb,this},RequestBase.prototype._isResponseOK=function(res){return!!res&&(this._okCallback?this._okCallback(res):res.status>=200&&res.status<300)},RequestBase.prototype.get=function(field){return this._header[field.toLowerCase()]},RequestBase.prototype.getHeader=RequestBase.prototype.get,RequestBase.prototype.set=function(field,val){if(isObject_1(field)){for(var key in field)Object.prototype.hasOwnProperty.call(field,key)&&this.set(key,field[key]);return this}return this._header[field.toLowerCase()]=val,this.header[field]=val,this},RequestBase.prototype.unset=function(field){return delete this._header[field.toLowerCase()],delete this.header[field],this},RequestBase.prototype.field=function(name,val){if(null==name)throw new Error(".field(name, val) name can not be empty");if(this._data)throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()");if(isObject_1(name)){for(var key in name)Object.prototype.hasOwnProperty.call(name,key)&&this.field(key,name[key]);return this}if(Array.isArray(val)){for(var i in val)Object.prototype.hasOwnProperty.call(val,i)&&this.field(name,val[i]);return this}if(null==val)throw new Error(".field(name, val) val can not be empty");return"boolean"==typeof val&&(val=String(val)),this._getFormData().append(name,val),this},RequestBase.prototype.abort=function(){return this._aborted||(this._aborted=!0,this.xhr&&this.xhr.abort(),this.req&&this.req.abort(),this.clearTimeout(),this.emit("abort")),this},RequestBase.prototype._auth=function(user,pass,options,base64Encoder){switch(options.type){case"basic":this.set("Authorization","Basic ".concat(base64Encoder("".concat(user,":").concat(pass))));break;case"auto":this.username=user,this.password=pass;break;case"bearer":this.set("Authorization","Bearer ".concat(user))}return this},RequestBase.prototype.withCredentials=function(on){return void 0===on&&(on=!0),this._withCredentials=on,this},RequestBase.prototype.redirects=function(n){return this._maxRedirects=n,this},RequestBase.prototype.maxResponseSize=function(n){if("number"!=typeof n)throw new TypeError("Invalid argument");return this._maxResponseSize=n,this},RequestBase.prototype.toJSON=function(){return{method:this.method,url:this.url,data:this._data,headers:this._header}},RequestBase.prototype.send=function(data){var isObj=isObject_1(data),type=this._header["content-type"];if(this._formData)throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()");if(isObj&&!this._data)Array.isArray(data)?this._data=[]:this._isHost(data)||(this._data={});else if(data&&this._data&&this._isHost(this._data))throw new Error("Can't merge these send calls");if(isObj&&isObject_1(this._data))for(var key in data)Object.prototype.hasOwnProperty.call(data,key)&&(this._data[key]=data[key]);else"string"==typeof data?(type||this.type("form"),type=this._header["content-type"],this._data="application/x-www-form-urlencoded"===type?this._data?"".concat(this._data,"&").concat(data):data:(this._data||"")+data):this._data=data;return!isObj||this._isHost(data)||type||this.type("json"),this},RequestBase.prototype.sortQuery=function(sort){return this._sort=void 0===sort||sort,this},RequestBase.prototype._finalizeQueryString=function(){var query=this._query.join("&");if(query&&(this.url+=(this.url.includes("?")?"&":"?")+query),this._query.length=0,this._sort){var index=this.url.indexOf("?");if(index>=0){var queryArr=this.url.slice(index+1).split("&");"function"==typeof this._sort?queryArr.sort(this._sort):queryArr.sort(),this.url=this.url.slice(0,index)+"?"+queryArr.join("&")}}},RequestBase.prototype._appendQueryString=function(){console.warn("Unsupported")},RequestBase.prototype._timeoutError=function(reason,timeout,errno){if(!this._aborted){var err=new Error("".concat(reason+timeout,"ms exceeded"));err.timeout=timeout,err.code="ECONNABORTED",err.errno=errno,this.timedout=!0,this.timedoutError=err,this.abort(),this.callback(err)}},RequestBase.prototype._setTimeouts=function(){var self=this;this._timeout&&!this._timer&&(this._timer=setTimeout((function(){self._timeoutError("Timeout of ",self._timeout,"ETIME")}),this._timeout)),this._responseTimeout&&!this._responseTimeoutTimer&&(this._responseTimeoutTimer=setTimeout((function(){self._timeoutError("Response timeout of ",self._responseTimeout,"ETIMEDOUT")}),this._responseTimeout))};var utils$1_type=function(str){return str.split(/ *; */).shift()},utils$1_params=function(str){return str.split(/ *; */).reduce((function(obj,str){var parts=str.split(/ *= */),key=parts.shift(),val=parts.shift();return key&&val&&(obj[key]=val),obj}),{})},utils$1_parseLinks=function(str){return str.split(/ *, */).reduce((function(obj,str){var parts=str.split(/ *; */),url=parts[0].slice(1,-1);return obj[parts[1].split(/ *= */)[1].slice(1,-1)]=url,obj}),{})},responseBase=ResponseBase;function ResponseBase(obj){if(obj)return function(obj){for(var key in ResponseBase.prototype)Object.prototype.hasOwnProperty.call(ResponseBase.prototype,key)&&(obj[key]=ResponseBase.prototype[key]);return obj}(obj)}function _toConsumableArray(arr){return function(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}(arr)||function(iter){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(iter))return Array.from(iter)}(arr)||function(o,minLen){if(!o)return;if("string"==typeof o)return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);"Object"===n&&o.constructor&&(n=o.constructor.name);if("Map"===n||"Set"===n)return Array.from(o);if("Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}(arr)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _arrayLikeToArray(arr,len){(null==len||len>arr.length)&&(len=arr.length);for(var i=0,arr2=new Array(len);i0||str instanceof Object)?parse(str):null)},Response.prototype.toError=function(){var req=this.req,method=req.method,url=req.url,msg="cannot ".concat(method," ").concat(url," (").concat(this.status,")"),err=new Error(msg);return err.status=this.status,err.method=method,err.url=url,err},request.Response=Response,componentEmitter(Request.prototype),requestBase(Request.prototype),Request.prototype.type=function(type){return this.set("Content-Type",request.types[type]||type),this},Request.prototype.accept=function(type){return this.set("Accept",request.types[type]||type),this},Request.prototype.auth=function(user,pass,options){1===arguments.length&&(pass=""),"object"===_typeof(pass)&&null!==pass&&(options=pass,pass=""),options||(options={type:"function"==typeof btoa?"basic":"auto"});var encoder=function(string){if("function"==typeof btoa)return btoa(string);throw new Error("Cannot use basic auth, btoa is not a function")};return this._auth(user,pass,options,encoder)},Request.prototype.query=function(val){return"string"!=typeof val&&(val=serialize(val)),val&&this._query.push(val),this},Request.prototype.attach=function(field,file,options){if(file){if(this._data)throw new Error("superagent can't mix .send() and .attach()");this._getFormData().append(field,file,options||file.name)}return this},Request.prototype._getFormData=function(){return this._formData||(this._formData=new root.FormData),this._formData},Request.prototype.callback=function(err,res){if(this._shouldRetry(err,res))return this._retry();var fn=this._callback;this.clearTimeout(),err&&(this._maxRetries&&(err.retries=this._retries-1),this.emit("error",err)),fn(err,res)},Request.prototype.crossDomainError=function(){var err=new Error("Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.");err.crossDomain=!0,err.status=this.status,err.method=this.method,err.url=this.url,this.callback(err)},Request.prototype.agent=function(){return console.warn("This is not supported in browser version of superagent"),this},Request.prototype.ca=Request.prototype.agent,Request.prototype.buffer=Request.prototype.ca,Request.prototype.write=function(){throw new Error("Streaming is not supported in browser version of superagent")},Request.prototype.pipe=Request.prototype.write,Request.prototype._isHost=function(obj){return obj&&"object"===_typeof(obj)&&!Array.isArray(obj)&&"[object Object]"!==Object.prototype.toString.call(obj)},Request.prototype.end=function(fn){this._endCalled&&console.warn("Warning: .end() was called twice. This is not supported in superagent"),this._endCalled=!0,this._callback=fn||noop,this._finalizeQueryString(),this._end()},Request.prototype._setUploadTimeout=function(){var self=this;this._uploadTimeout&&!this._uploadTimeoutTimer&&(this._uploadTimeoutTimer=setTimeout((function(){self._timeoutError("Upload timeout of ",self._uploadTimeout,"ETIMEDOUT")}),this._uploadTimeout))},Request.prototype._end=function(){if(this._aborted)return this.callback(new Error("The request has been aborted even before .end() was called"));var self=this;this.xhr=request.getXHR();var xhr=this.xhr,data=this._formData||this._data;this._setTimeouts(),xhr.onreadystatechange=function(){var readyState=xhr.readyState;if(readyState>=2&&self._responseTimeoutTimer&&clearTimeout(self._responseTimeoutTimer),4===readyState){var status;try{status=xhr.status}catch(_unused5){status=0}if(!status){if(self.timedout||self._aborted)return;return self.crossDomainError()}self.emit("end")}};var handleProgress=function(direction,e){e.total>0&&(e.percent=e.loaded/e.total*100,100===e.percent&&clearTimeout(self._uploadTimeoutTimer)),e.direction=direction,self.emit("progress",e)};if(this.hasListeners("progress"))try{xhr.addEventListener("progress",handleProgress.bind(null,"download")),xhr.upload&&xhr.upload.addEventListener("progress",handleProgress.bind(null,"upload"))}catch(_unused6){}xhr.upload&&this._setUploadTimeout();try{this.username&&this.password?xhr.open(this.method,this.url,!0,this.username,this.password):xhr.open(this.method,this.url,!0)}catch(err){return this.callback(err)}if(this._withCredentials&&(xhr.withCredentials=!0),!this._formData&&"GET"!==this.method&&"HEAD"!==this.method&&"string"!=typeof data&&!this._isHost(data)){var contentType=this._header["content-type"],_serialize=this._serializer||request.serialize[contentType?contentType.split(";")[0]:""];!_serialize&&isJSON(contentType)&&(_serialize=request.serialize["application/json"]),_serialize&&(data=_serialize(data))}for(var field in this.header)null!==this.header[field]&&Object.prototype.hasOwnProperty.call(this.header,field)&&xhr.setRequestHeader(field,this.header[field]);this._responseType&&(xhr.responseType=this._responseType),this.emit("request",this),xhr.send(void 0===data?null:data)},request.agent=function(){return new agentBase},["GET","POST","OPTIONS","PATCH","PUT","DELETE"].forEach((function(method){agentBase.prototype[method.toLowerCase()]=function(url,fn){var req=new request.Request(method,url);return this._setDefaults(req),fn&&req.end(fn),req}})),agentBase.prototype.del=agentBase.prototype.delete,request.get=function(url,data,fn){var req=request("GET",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.head=function(url,data,fn){var req=request("HEAD",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.options=function(url,data,fn){var req=request("OPTIONS",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.del=del,request.delete=del,request.patch=function(url,data,fn){var req=request("PATCH",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.post=function(url,data,fn){var req=request("POST",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.put=function(url,data,fn){var req=request("PUT",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req}})),byteLength_1=(client.Request,function(b64){var lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1];return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}),toByteArray_1=function(b64){var tmp,i,lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1],arr=new Arr(function(b64,validLen,placeHoldersLen){return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}(0,validLen,placeHoldersLen)),curByte=0,len=placeHoldersLen>0?validLen-4:validLen;for(i=0;i>16&255,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp;2===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<2|revLookup[b64.charCodeAt(i+1)]>>4,arr[curByte++]=255&tmp);1===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<10|revLookup[b64.charCodeAt(i+1)]<<4|revLookup[b64.charCodeAt(i+2)]>>2,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp);return arr},fromByteArray_1=function(uint8){for(var tmp,len=uint8.length,extraBytes=len%3,parts=[],i=0,len2=len-extraBytes;ilen2?len2:i+16383));1===extraBytes?(tmp=uint8[len-1],parts.push(lookup[tmp>>2]+lookup[tmp<<4&63]+"==")):2===extraBytes&&(tmp=(uint8[len-2]<<8)+uint8[len-1],parts.push(lookup[tmp>>10]+lookup[tmp>>4&63]+lookup[tmp<<2&63]+"="));return parts.join("")},lookup=[],revLookup=[],Arr="undefined"!=typeof Uint8Array?Uint8Array:Array,code="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=0,len=code.length;i0)throw new Error("Invalid string. Length must be a multiple of 4");var validLen=b64.indexOf("=");return-1===validLen&&(validLen=len),[validLen,validLen===len?0:4-validLen%4]}function encodeChunk(uint8,start,end){for(var tmp,num,output=[],i=start;i>18&63]+lookup[num>>12&63]+lookup[num>>6&63]+lookup[63&num]);return output.join("")}revLookup["-".charCodeAt(0)]=62,revLookup["_".charCodeAt(0)]=63;var base64Js={byteLength:byteLength_1,toByteArray:toByteArray_1,fromByteArray:fromByteArray_1};var base64Url={encode:function(str){return base64Js.fromByteArray(function(str){for(var arr=new Array(str.length),a=0;a=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function RequestWrapper(req){this.request=req,this.method=req.method,this.url=req.url,this.body=req._data,this.headers=req._header}function RequestObj(req){this.request=req}function RequestBuilder(options){this._sendTelemetry=!1!==options._sendTelemetry||options._sendTelemetry,this._telemetryInfo=options._telemetryInfo||null,this._timesToRetryFailedRequests=options._timesToRetryFailedRequests,this.headers=options.headers||{},this._universalLoginPage=options.universalLoginPage}function getWindow(){return window}RequestWrapper.prototype.abort=function(){this.request.abort()},RequestWrapper.prototype.getMethod=function(){return this.method},RequestWrapper.prototype.getBody=function(){return this.body},RequestWrapper.prototype.getUrl=function(){return this.url},RequestWrapper.prototype.getHeaders=function(){return this.headers},RequestObj.prototype.set=function(key,value){return this.request=this.request.set(key,value),this},RequestObj.prototype.send=function(body){return this.request=this.request.send(objectHelper.trimUserDetails(body)),this},RequestObj.prototype.withCredentials=function(){return this.request=this.request.withCredentials(),this},RequestObj.prototype.end=function(cb){return this.request.end(cb),new RequestWrapper(this.request)},RequestBuilder.prototype.setCommonConfiguration=function(ongoingRequest,options){if(options=options||{},this._timesToRetryFailedRequests>0&&(ongoingRequest=ongoingRequest.retry(this._timesToRetryFailedRequests)),options.noHeaders)return ongoingRequest;var headers=this.headers;ongoingRequest=ongoingRequest.set("Content-Type","application/json");for(var keys=Object.keys(this.headers),a=0;a0&&warn.warning("Following parameters are not allowed on the `/authorize` endpoint: ["+notAllowed.join(",")+"]"),params}},t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e((function(e,r){e.exports=function(){function e(t){return"function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)})),o=e((function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64)})),s=e((function(t,e){t.exports=i$1.enc.Hex})),h=e((function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e))}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return"-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return"0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()}));function _(t,e){return e=e||{},new Promise((function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,(function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r})),r(a())},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)}))}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||""}function A(t){this.name="TokenValidationError",this.message=t||""}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return"number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}function PluginHandler(webAuth,plugins){this.plugins=plugins;for(var a=0;a1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)}))},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then((function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then((function(t){var e,r,i,n=null;for(e=0;e-1){null!==new RegExp("rv:([0-9]{2,2}[.0-9]{0,})").exec(ua)&&(rv=parseFloat(RegExp.$1))}return rv>=8}();return"undefined"!=typeof window&&window.JSON&&window.JSON.stringify&&window.JSON.parse&&window.postMessage?{open:function(opts,cb){if(!cb)throw"missing required callback argument";var err,iframe;opts.url||(err="missing required 'url' parameter"),opts.relay_url||(err="missing required 'relay_url' parameter"),err&&setTimeout((function(){cb(err)}),0),opts.window_name||(opts.window_name=null),opts.window_features&&!function(){try{var userAgent=navigator.userAgent;return-1!=userAgent.indexOf("Fennec/")||-1!=userAgent.indexOf("Firefox/")&&-1!=userAgent.indexOf("Android")}catch(e){}return!1}()||(opts.window_features=void 0);var messageTarget,origin=opts.origin||extractOrigin(opts.url);if(origin!==extractOrigin(opts.relay_url))return setTimeout((function(){cb("invalid arguments: origin of url and relay_url must match")}),0);isIE&&((iframe=document.createElement("iframe")).setAttribute("src",opts.relay_url),iframe.style.display="none",iframe.setAttribute("name","__winchan_relay_frame"),document.body.appendChild(iframe),messageTarget=iframe.contentWindow);var w=opts.popup||window.open(opts.url,opts.window_name,opts.window_features);opts.popup&&(w.location.href=opts.url),messageTarget||(messageTarget=w);var closeInterval=setInterval((function(){w&&w.closed&&(cleanup(),cb&&(cb("User closed the popup window"),cb=null))}),500),req=JSON.stringify({a:"request",d:opts.params});function cleanup(){if(iframe&&document.body.removeChild(iframe),iframe=void 0,closeInterval&&(closeInterval=clearInterval(closeInterval)),removeListener(window,"message",onMessage),removeListener(window,"unload",cleanup),w)try{w.close()}catch(securityViolation){messageTarget.postMessage("die",origin)}w=messageTarget=void 0}function onMessage(e){if(e.origin===origin){try{var d=JSON.parse(e.data)}catch(err){if(cb)return cb(err);throw err}"ready"===d.a?messageTarget.postMessage(req,origin):"error"===d.a?(cleanup(),cb&&(cb(d.d),cb=null)):"response"===d.a&&(cleanup(),cb&&(cb(null,d.d),cb=null))}}return addListener(window,"unload",cleanup),addListener(window,"message",onMessage),{originalPopup:w,close:cleanup,focus:function(){if(w)try{w.focus()}catch(e){}}}},onOpen:function(cb){var o="*",msgTarget=isIE?function(){for(var frames=window.opener.frames,i=frames.length-1;i>=0;i--)try{if(frames[i].location.protocol===window.location.protocol&&frames[i].location.host===window.location.host&&"__winchan_relay_frame"===frames[i].name)return frames[i]}catch(e){}}():window.opener;if(!msgTarget)throw"can't find relay frame";function doPost(msg){msg=JSON.stringify(msg),isIE?msgTarget.doPost(msg,o):msgTarget.postMessage(msg,o)}function onDie(e){if("die"===e.data)try{window.close()}catch(o_O){}}addListener(isIE?msgTarget:window,"message",(function onMessage(e){var d;try{d=JSON.parse(e.data)}catch(err){}d&&"request"===d.a&&(removeListener(window,"message",onMessage),o=e.origin,cb&&setTimeout((function(){cb(o,d.d,(function(r){cb=void 0,doPost({a:"response",d:r})}))}),0))})),addListener(isIE?msgTarget:window,"message",onDie);try{doPost({a:"ready"})}catch(e){addListener(msgTarget,"load",(function(e){doPost({a:"ready"})}))}var onUnload=function(){try{removeListener(isIE?msgTarget:window,"message",onDie)}catch(ohWell){}cb&&doPost({a:"error",d:"client closed window"}),cb=void 0;try{window.close()}catch(e){}};return addListener(window,"unload",onUnload),{detach:function(){removeListener(window,"unload",onUnload)}}}}:{open:function(url,winopts,arg,cb){setTimeout((function(){cb("unsupported browser")}),0)},onOpen:function(cb){setTimeout((function(){cb("unsupported browser")}),0)}}}();module.exports&&(module.exports=WinChan)}));var urlHelper={extractOrigin:function(url){/^https?:\/\//.test(url)||(url=window.location.href);var m=/^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url);return m?m[1]:url}};function PopupHandler(){this._current_popup=null}function Popup(webAuth,options){this.baseOptions=options,this.baseOptions.popupOrigin=options.popupOrigin,this.client=webAuth.client,this.webAuth=webAuth,this.transactionManager=new TransactionManager(this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(webAuth,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}function SilentAuthenticationHandler(options){this.authenticationUrl=options.authenticationUrl,this.timeout=options.timeout||6e4,this.handler=null,this.postMessageDataType=options.postMessageDataType||!1,this.postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().location.origin||windowHelper.getWindow().location.protocol+"//"+windowHelper.getWindow().location.hostname+(windowHelper.getWindow().location.port?":"+windowHelper.getWindow().location.port:"")}function UsernamePassword(options){this.baseOptions=options,this.request=new RequestBuilder(options),this.transactionManager=new TransactionManager(this.baseOptions)}function HostedPages(client,options){this.baseOptions=options,this.client=client,this.baseOptions.universalLoginPage=!0,this.request=new RequestBuilder(this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}PopupHandler.prototype.calculatePosition=function(options){var width=options.width||500,height=options.height||600,_window=windowHelper.getWindow(),screenX=void 0!==_window.screenX?_window.screenX:_window.screenLeft,screenY=void 0!==_window.screenY?_window.screenY:_window.screenTop,outerWidth=void 0!==_window.outerWidth?_window.outerWidth:_window.document.body.clientWidth,outerHeight=void 0!==_window.outerHeight?_window.outerHeight:_window.document.body.clientHeight;return{width:width,height:height,left:options.left||screenX+(outerWidth-width)/2,top:options.top||screenY+(outerHeight-height)/2}},PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHelper.getWindow(),popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),url=options.url||"about:blank",windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"auth0_signup_popup",windowFeatures),this._current_popup.kill=function(){this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,relayUrl,options,cb){var _this=this,popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),winchanOptions=objectHelper.merge({url:url,relay_url:relayUrl,window_features:lib_stringify(popupOptions,{delimiter:",",encode:!1}),popup:this._current_popup}).with(options),popup=winchan.open(winchanOptions,(function(err,data){if(!err||"SyntaxError"!==err.name)return _this._current_popup=null,cb(err,data)}));return popup.focus(),popup},Popup.prototype.buildPopupHandler=function(){var pluginHandler=this.baseOptions.plugins.get("popup.getPopupHandler");return pluginHandler?pluginHandler.getPopupHandler():new PopupHandler},Popup.prototype.preload=function(options){options=options||{};var popup=this.buildPopupHandler();return popup.preload(options),popup},Popup.prototype.getPopupHandler=function(options,preload){return options.popupHandler?options.popupHandler:preload?this.preload(options):this.buildPopupHandler()},Popup.prototype.callback=function(options){var _this=this,theWindow=windowHelper.getWindow(),originUrl=(options=options||{}).popupOrigin||this.baseOptions.popupOrigin||windowHelper.getOrigin();theWindow.opener?winchan.onOpen((function(popupOrigin,r,cb){if(popupOrigin!==originUrl)return cb({error:"origin_mismatch",error_description:"The popup's origin ("+popupOrigin+") should match the `popupOrigin` parameter ("+originUrl+")."});_this.webAuth.parseHash(options||{},(function(err,data){return cb(err||data)}))})):theWindow.doPost=function(msg){theWindow.parent&&theWindow.parent.postMessage(msg,originUrl)}},Popup.prototype.authorize=function(options,cb){var url,relayUrl,popOpts={},pluginHandler=this.baseOptions.plugins.get("popup.authorize"),params=objectHelper.merge(this.baseOptions,["clientID","scope","domain","audience","tenant","responseType","redirectUri","_csrf","state","_intstate","nonce"]).with(objectHelper.blacklist(options,["popupHandler"]));return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),relayUrl=urlJoin(this.baseOptions.rootUrl,"relay.html"),options.owp?params.owp=!0:(popOpts.origin=urlHelper.extractOrigin(params.redirectUri),relayUrl=params.redirectUri),options.popupOptions&&(popOpts.popupOptions=objectHelper.pick(options.popupOptions,["width","height","top","left"])),pluginHandler&&(params=pluginHandler.processParams(params)),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",delete params.domain,url=this.client.buildAuthorizeUrl(params),this.getPopupHandler(options).load(url,relayUrl,popOpts,wrapCallback(cb,{keepOriginalCasing:!0}))},Popup.prototype.loginWithCredentials=function(options,cb){options.realm=options.realm||options.connection,options.popup=!0,options=objectHelper.merge(this.baseOptions,["redirectUri","responseType","state","nonce"]).with(objectHelper.blacklist(options,["popupHandler","connection"])),options=this.transactionManager.process(options),this.crossOriginAuthentication.login(options,cb)},Popup.prototype.passwordlessVerify=function(options,cb){var _this=this;return this.client.passwordless.verify(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.username=options.phoneNumber||options.email,options.password=options.verificationCode,delete options.email,delete options.phoneNumber,delete options.verificationCode,delete options.type,_this.client.loginWithResourceOwner(options,cb)}))},Popup.prototype.signupAndLogin=function(options,cb){var _this=this;return this.client.dbConnection.signup(options,(function(err){if(err)return cb(err);_this.loginWithCredentials(options,cb)}))},SilentAuthenticationHandler.create=function(options){return new SilentAuthenticationHandler(options)},SilentAuthenticationHandler.prototype.login=function(usePostMessage,callback){this.handler=new IframeHandler({auth0:this.auth0,url:this.authenticationUrl,eventListenerType:usePostMessage?"message":"load",callback:this.getCallbackHandler(callback,usePostMessage),timeout:this.timeout,eventValidator:this.getEventValidator(),timeoutCallback:function(){callback(null,"#error=timeout&error_description=Timeout+during+authentication+renew.")},usePostMessage:usePostMessage||!1}),this.handler.init()},SilentAuthenticationHandler.prototype.getEventValidator=function(){var _this=this;return{isValid:function(eventData){switch(eventData.event.type){case"message":return eventData.event.origin===_this.postMessageOrigin&&eventData.event.source===_this.handler.iframe.contentWindow&&(!1===_this.postMessageDataType||eventData.event.data.type&&eventData.event.data.type===_this.postMessageDataType);case"load":if("about:"===eventData.sourceObject.contentWindow.location.protocol)return!1;default:return!0}}}},SilentAuthenticationHandler.prototype.getCallbackHandler=function(callback,usePostMessage){return function(eventData){var callbackValue;callbackValue=usePostMessage?"object"==typeof eventData.event.data&&eventData.event.data.hash?eventData.event.data.hash:eventData.event.data:eventData.sourceObject.contentWindow.location.hash,callback(null,callbackValue)}},UsernamePassword.prototype.login=function(options,cb){var url,body;return url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","login"),options.username=options.username||options.email,options=objectHelper.blacklist(options,["email"]),body=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience"]).with(options),body=this.transactionManager.process(body),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},UsernamePassword.prototype.callback=function(formHtml){var div,_document=windowHelper.getDocument();(div=_document.createElement("div")).innerHTML=formHtml,_document.body.appendChild(div).children[0].submit()},HostedPages.prototype.login=function(options,cb){if(windowHelper.getWindow().location.host!==this.baseOptions.domain)throw new Error("This method is meant to be used only inside the Universal Login Page.");var usernamePassword,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(usernamePassword=new UsernamePassword(this.baseOptions)).login(params,(function(err,data){return err?cb(err):usernamePassword.callback(data)}))},HostedPages.prototype.signupAndLogin=function(options,cb){var _this=this;return _this.client.client.dbConnection.signup(options,(function(err){return err?cb(err):_this.login(options,cb)}))},HostedPages.prototype.getSSOData=function(withActiveDirectories,cb){var url,params="";return"function"==typeof withActiveDirectories&&(cb=withActiveDirectories,withActiveDirectories=!1),assert.check(withActiveDirectories,{type:"boolean",message:"withActiveDirectories parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),withActiveDirectories&&(params="?"+lib_stringify({ldaps:1,client_id:this.baseOptions.clientID})),url=urlJoin(this.baseOptions.rootUrl,"user","ssodata",params),this.request.get(url,{noHeaders:!0}).withCredentials().end(wrapCallback(cb))};var noop=function(){},defaults$2={lang:"en",templates:{auth0:function(challenge){var message="code"===challenge.type?"Enter the code shown above":"Solve the formula shown above";return'
\n \n \n
\n'},recaptcha_v2:function(){return'
'},error:function(){return'
Error getting the bot detection challenge. Please contact the system administrator.
'}}};function handleRecaptchaProvider(element,options,challenge){var widgetId=element.hasAttribute("data-wid")&&element.getAttribute("data-wid");function setValue(value){element.querySelector('input[name="captcha"]').value=value||""}if(widgetId)return setValue(),void window.grecaptcha.reset(widgetId);element.innerHTML=options.templates[challenge.provider](challenge);var recaptchaDiv=element.querySelector(".recaptcha");!function(element,lang,callback){var callbackName="recaptchaCallback_"+Math.floor(1000001*Math.random());window[callbackName]=function(){delete window[callbackName],callback()};var script=window.document.createElement("script");script.src="https://www.google.com/recaptcha/api.js?hl="+lang+"&onload="+callbackName,script.async=!0,window.document.body.appendChild(script)}(0,options.lang,(function(){widgetId=window.grecaptcha.render(recaptchaDiv,{callback:setValue,"expired-callback":function(){setValue()},"error-callback":function(){setValue()},sitekey:challenge.siteKey}),element.setAttribute("data-wid",widgetId)}))}var captcha={render:function(auth0Client,element,options,callback){function load(done){done=done||noop,auth0Client.getChallenge((function(err,challenge){return err?(element.innerHTML=options.templates.error(err),done(err)):challenge.required?(element.style.display="","auth0"===challenge.provider?function(element,options,challenge,load){element.innerHTML=options.templates[challenge.provider](challenge),element.querySelector(".captcha-reload").addEventListener("click",(function(e){e.preventDefault(),load()}))}(element,options,challenge,load):"recaptcha_v2"===challenge.provider&&handleRecaptchaProvider(element,options,challenge),void done()):(element.style.display="none",void(element.innerHTML=""))}))}return options=objectHelper.merge(defaults$2).with(options||{}),load(callback),{reload:load,getValue:function(){var captchaInput=element.querySelector('input[name="captcha"]');if(captchaInput)return captchaInput.value}}}};function defaultClock(){return new Date}function WebAuth(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},popupOrigin:{optional:!0,type:"string",message:"popupOrigin is not valid"},leeway:{optional:!0,type:"number",message:"leeway is not valid"},plugins:{optional:!0,type:"array",message:"plugins is not valid"},maxAge:{optional:!0,type:"number",message:"maxAge is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"},_timesToRetryFailedRequests:{optional:!0,type:"number",message:"_timesToRetryFailedRequests option is not valid"}}),options.overrides&&assert.check(options.overrides,{type:"object",message:"overrides option is not valid"},{__tenant:{optional:!0,type:"string",message:"__tenant option is required"},__token_issuer:{optional:!0,type:"string",message:"__token_issuer option is required"},__jwks_uri:{optional:!0,type:"string",message:"__jwks_uri is required"}}),this.baseOptions=options,this.baseOptions.plugins=new PluginHandler(this,this.baseOptions.plugins||[]),this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions._timesToRetryFailedRequests=options._timesToRetryFailedRequests?parseInt(options._timesToRetryFailedRequests,0):0,this.baseOptions.tenant=this.baseOptions.overrides&&this.baseOptions.overrides.__tenant||this.baseOptions.domain.split(".")[0],this.baseOptions.token_issuer=this.baseOptions.overrides&&this.baseOptions.overrides.__token_issuer||"https://"+this.baseOptions.domain+"/",this.baseOptions.jwksURI=this.baseOptions.overrides&&this.baseOptions.overrides.__jwks_uri,this.transactionManager=new TransactionManager(this.baseOptions),this.client=new Authentication(this.baseOptions),this.redirect=new Redirect(this,this.baseOptions),this.popup=new Popup(this,this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(this,this.baseOptions),this.webMessageHandler=new WebMessageHandler(this),this._universalLogin=new HostedPages(this,this.baseOptions),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function PasswordlessAuthentication(request,options){this.baseOptions=options,this.request=request}function DBConnection(request,options){this.baseOptions=options,this.request=request}function Authentication(auth0,options){2===arguments.length?this.auth0=auth0:options=auth0,assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions.rootUrl=this.baseOptions.domain&&0===this.baseOptions.domain.toLowerCase().indexOf("http")?this.baseOptions.domain:"https://"+this.baseOptions.domain,this.request=new RequestBuilder(this.baseOptions),this.passwordless=new PasswordlessAuthentication(this.request,this.baseOptions),this.dbConnection=new DBConnection(this.request,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings}),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function Management(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},token:{type:"string",message:"token option is required"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions.headers={Authorization:"Bearer "+this.baseOptions.token},this.request=new RequestBuilder(this.baseOptions),this.baseOptions.rootUrl=urlJoin("https://"+this.baseOptions.domain,"api","v2")}WebAuth.prototype.parseHash=function(options,cb){var parsedQs,err;cb||"function"!=typeof options?options=options||{}:(cb=options,options={});var _window=windowHelper.getWindow(),hashStr=void 0===options.hash?_window.location.hash:options.hash;if(hashStr=hashStr.replace(/^#?\/?/,""),(parsedQs=lib_parse(hashStr)).hasOwnProperty("error"))return err=error.buildResponse(parsedQs.error,parsedQs.error_description),parsedQs.state&&(err.state=parsedQs.state),cb(err);if(!parsedQs.hasOwnProperty("access_token")&&!parsedQs.hasOwnProperty("id_token")&&!parsedQs.hasOwnProperty("refresh_token"))return cb(null,null);var responseTypes=(this.baseOptions.responseType||options.responseType||"").split(" ");return responseTypes.length>0&&-1!==responseTypes.indexOf("token")&&!parsedQs.hasOwnProperty("access_token")?cb(error.buildResponse("invalid_hash","response_type contains `token`, but the parsed hash does not contain an `access_token` property")):responseTypes.length>0&&-1!==responseTypes.indexOf("id_token")&&!parsedQs.hasOwnProperty("id_token")?cb(error.buildResponse("invalid_hash","response_type contains `id_token`, but the parsed hash does not contain an `id_token` property")):this.validateAuthenticationResponse(options,parsedQs,cb)},WebAuth.prototype.validateAuthenticationResponse=function(options,parsedHash,cb){var _this=this;options.__enableIdPInitiatedLogin=options.__enableIdPInitiatedLogin||options.__enableImpersonation;var state=parsedHash.state,transaction=this.transactionManager.getStoredTransaction(state),transactionState=options.state||transaction&&transaction.state||null,transactionStateMatchesState=transactionState===state;if(!(!state&&!transactionState&&options.__enableIdPInitiatedLogin)&&!transactionStateMatchesState)return cb({error:"invalid_token",errorDescription:"`state` does not match."});var transactionNonce=options.nonce||transaction&&transaction.nonce||null,appState=options.state||transaction&&transaction.appState||null,callback=function(err,payload){if(err)return cb(err);var sub;transaction&&transaction.lastUsedConnection&&(payload&&(sub=payload.sub),_this.ssodataStorage.set(transaction.lastUsedConnection,sub));return cb(null,function(qsParams,appState,token){return{accessToken:qsParams.access_token||null,idToken:qsParams.id_token||null,idTokenPayload:token||null,appState:appState||null,refreshToken:qsParams.refresh_token||null,state:qsParams.state||null,expiresIn:qsParams.expires_in?parseInt(qsParams.expires_in,10):null,tokenType:qsParams.token_type||null,scope:qsParams.scope||null}}(parsedHash,appState,payload))};return parsedHash.id_token?this.validateToken(parsedHash.id_token,transactionNonce,(function(validationError,payload){if(!validationError)return parsedHash.access_token&&payload.at_hash?(new k).validateAccessToken(parsedHash.access_token,"RS256",payload.at_hash,(function(err){return err?callback(error.invalidToken(err.message)):callback(null,payload)})):callback(null,payload);if("invalid_token"!==validationError.error||validationError.errorDescription&&validationError.errorDescription.indexOf("Nonce (nonce) claim value mismatch in the ID token")>-1)return callback(validationError);var decodedToken=(new k).decode(parsedHash.id_token);if("HS256"!==decodedToken.header.alg)return callback(validationError);if((decodedToken.payload.nonce||null)!==transactionNonce)return callback({error:"invalid_token",errorDescription:'Nonce (nonce) claim value mismatch in the ID token; expected "'+transactionNonce+'", found "'+decodedToken.payload.nonce+'"'});if(!parsedHash.access_token){return callback({error:"invalid_token",description:"The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token"})}return _this.client.userInfo(parsedHash.access_token,(function(errUserInfo,profile){return errUserInfo?callback(errUserInfo):callback(null,profile)}))})):callback(null,null)},WebAuth.prototype.validateToken=function(token,nonce,cb){new k({issuer:this.baseOptions.token_issuer,jwksURI:this.baseOptions.jwksURI,audience:this.baseOptions.clientID,leeway:this.baseOptions.leeway||60,maxAge:this.baseOptions.maxAge,__clock:this.baseOptions.__clock||defaultClock}).verify(token,nonce,(function(err,payload){if(err)return cb(error.invalidToken(err.message));cb(null,payload)}))},WebAuth.prototype.renewAuth=function(options,cb){var usePostMessage=!!options.usePostMessage,postMessageDataType=options.postMessageDataType||!1,postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().origin,timeout=options.timeout,_this=this,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","responseType","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params.responseType=params.responseType||"token",params.responseMode=params.responseMode||"fragment",params=this.transactionManager.process(params),assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params.prompt="none",params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType","postMessageOrigin"]),SilentAuthenticationHandler.create({authenticationUrl:this.client.buildAuthorizeUrl(params),postMessageDataType:postMessageDataType,postMessageOrigin:postMessageOrigin,timeout:timeout}).login(usePostMessage,(function(err,hash){if("object"==typeof hash)return cb(err,hash);_this.parseHash({hash:hash},cb)}))},WebAuth.prototype.checkSession=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return"code"===params.responseType?cb({error:"error",error_description:"responseType can't be `code`"}):(options.nonce||(params=this.transactionManager.process(params)),params.redirectUri?(assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType"]),void this.webMessageHandler.run(params,wrapCallback(cb,{forceLegacyError:!0,ignoreCasing:!0}))):cb({error:"error",error_description:"redirectUri can't be empty"}))},WebAuth.prototype.changePassword=function(options,cb){return this.client.dbConnection.changePassword(options,cb)},WebAuth.prototype.passwordlessStart=function(options,cb){var authParams=objectHelper.merge(this.baseOptions,["responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options.authParams);return options.authParams=this.transactionManager.process(authParams),this.client.passwordless.start(options,cb)},WebAuth.prototype.signup=function(options,cb){return this.client.dbConnection.signup(options,cb)},WebAuth.prototype.authorize=function(options){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",windowHelper.redirect(this.client.buildAuthorizeUrl(params))},WebAuth.prototype.signupAndAuthorize=function(options,cb){var _this=this;return this.client.dbConnection.signup(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.realm=options.connection,options.username||(options.username=options.email),_this.client.login(options,cb)}))},WebAuth.prototype.login=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain?(params.connection=params.realm,delete params.realm,this._universalLogin.login(params,cb)):this.crossOriginAuthentication.login(params,cb)},WebAuth.prototype.passwordlessLogin=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);if(params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain)this.passwordlessVerify(params,cb);else{var crossOriginOptions=objectHelper.extend({credentialType:"http://auth0.com/oauth/grant-type/passwordless/otp",realm:params.connection,username:params.email||params.phoneNumber,otp:params.verificationCode},objectHelper.blacklist(params,["connection","email","phoneNumber","verificationCode"]));this.crossOriginAuthentication.login(crossOriginOptions,cb)}},WebAuth.prototype.crossOriginAuthenticationCallback=function(){this.crossOriginVerification()},WebAuth.prototype.crossOriginVerification=function(){this.crossOriginAuthentication.callback()},WebAuth.prototype.logout=function(options){windowHelper.redirect(this.client.buildLogoutUrl(options))},WebAuth.prototype.passwordlessVerify=function(options,cb){var _this=this,params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),params=this.transactionManager.process(params),this.client.passwordless.verify(params,(function(err){return err?cb(err):windowHelper.redirect(_this.client.passwordless.buildVerifyUrl(params))}))},WebAuth.prototype.renderCaptcha=function(element,options,callback){return captcha.render(this.client,element,options,callback)},PasswordlessAuthentication.prototype.buildVerifyUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","protocol","nonce"]).with(options),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client"]),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"passwordless","verify_redirect","?"+qString)},PasswordlessAuthentication.prototype.start=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},send:{type:"string",message:"send option is required",values:["link","code"],value_message:"send is not valid ([link, code])"},phoneNumber:{optional:!0,type:"string",message:"phoneNumber option is required",condition:function(o){return"code"===o.send||!o.email}},email:{optional:!0,type:"string",message:"email option is required",condition:function(o){return"link"===o.send||!o.phoneNumber}},authParams:{optional:!0,type:"object",message:"authParams option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"passwordless","start"),(body=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope"]).with(options)).scope&&(body.authParams=body.authParams||{},body.authParams.scope=body.authParams.scope||body.scope),body.redirectUri&&(body.authParams=body.authParams||{},body.authParams.redirect_uri=body.authParams.redirectUri||body.redirectUri),body.responseType&&(body.authParams=body.authParams||{},body.authParams.response_type=body.authParams.responseType||body.responseType),delete body.redirectUri,delete body.responseType,delete body.scope,body=objectHelper.toSnakeCase(body,["auth0Client","authParams"]),this.request.post(url).send(body).end(wrapCallback(cb))},PasswordlessAuthentication.prototype.verify=function(options,cb){var url,cleanOption;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),cleanOption=objectHelper.pick(options,["connection","verificationCode","phoneNumber","email","auth0Client"]),cleanOption=objectHelper.toSnakeCase(cleanOption,["auth0Client"]),url=urlJoin(this.baseOptions.rootUrl,"passwordless","verify"),this.request.post(url).send(cleanOption).end(wrapCallback(cb))},DBConnection.prototype.signup=function(options,cb){var url,body,metadata;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"},password:{type:"string",message:"password option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","signup"),metadata=(body=objectHelper.merge(this.baseOptions,["clientID","state"]).with(options)).user_metadata||body.userMetadata,body=objectHelper.blacklist(body,["scope","userMetadata","user_metadata"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),metadata&&(body.user_metadata=metadata),this.request.post(url).send(body).end(wrapCallback(cb))},DBConnection.prototype.changePassword=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","change_password"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options,["email","connection"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.buildAuthorizeUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience"]).with(options),assert.check(params,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},redirectUri:{optional:!0,type:"string",message:"redirectUri option is required"},responseType:{type:"string",message:"responseType option is required"},nonce:{type:"string",message:"nonce option is required",condition:function(o){return-1===o.responseType.indexOf("code")&&-1!==o.responseType.indexOf("id_token")}},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params.connection_scope&&assert.isArray(params.connection_scope)&&(params.connection_scope=params.connection_scope.join(",")),params=objectHelper.blacklist(params,["username","popupOptions","domain","tenant","timeout","appState"]),params=objectHelper.toSnakeCase(params,["auth0Client"]),params=parametersWhitelist.oauthAuthorizeParams(this.warn,params),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"authorize","?"+qString)},Authentication.prototype.buildLogoutUrl=function(options){var params,qString;return assert.check(options,{optional:!0,type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID"]).with(options||{}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client","returnTo"]),qString=lib_stringify(objectHelper.blacklist(params,["federated"])),options&&void 0!==options.federated&&!1!==options.federated&&"false"!==options.federated&&(qString+="&federated"),urlJoin(this.baseOptions.rootUrl,"v2","logout","?"+qString)},Authentication.prototype.loginWithDefaultDirectory=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="password",this.oauthToken(options,cb)},Authentication.prototype.login=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},realm:{type:"string",message:"realm option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="http://auth0.com/oauth/grant-type/password-realm",this.oauthToken(options,cb)},Authentication.prototype.oauthToken=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","token"),body=objectHelper.merge(this.baseOptions,["clientID","scope","audience"]).with(options),assert.check(body,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},grantType:{type:"string",message:"grantType option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),body=objectHelper.toSnakeCase(body,["auth0Client"]),body=parametersWhitelist.oauthTokenParams(this.warn,body),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.loginWithResourceOwner=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},connection:{type:"string",message:"connection option is required"},scope:{optional:!0,type:"string",message:"scope option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","ro"),body=objectHelper.merge(this.baseOptions,["clientID","scope"]).with(options,["username","password","scope","connection","device"]),(body=objectHelper.toSnakeCase(body,["auth0Client"])).grant_type=body.grant_type||"password",this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getSSOData=function(withActiveDirectories,cb){if(this.auth0||(this.auth0=new WebAuth(this.baseOptions)),windowHelper.getWindow().location.host===this.baseOptions.domain)return this.auth0._universalLogin.getSSOData(withActiveDirectories,cb);"function"==typeof withActiveDirectories&&(cb=withActiveDirectories),assert.check(cb,{type:"function",message:"cb parameter is not valid"});var clientId=this.baseOptions.clientID,ssodataInformation=this.ssodataStorage.get()||{};this.auth0.checkSession({responseType:"token id_token",scope:"openid profile email",connection:ssodataInformation.lastUsedConnection,timeout:5e3},(function(err,result){return err?"login_required"===err.error?cb(null,{sso:!1}):("consent_required"===err.error&&(err.error_description="Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`."),cb(err,{sso:!1})):ssodataInformation.lastUsedSub&&ssodataInformation.lastUsedSub!==result.idTokenPayload.sub?cb(err,{sso:!1}):cb(null,{lastUsedConnection:{name:ssodataInformation.lastUsedConnection},lastUsedUserID:result.idTokenPayload.sub,lastUsedUsername:result.idTokenPayload.email||result.idTokenPayload.name,lastUsedClientID:clientId,sessionClients:[clientId],sso:!0})}))},Authentication.prototype.userInfo=function(accessToken,cb){var url;return assert.check(accessToken,{type:"string",message:"accessToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"userinfo"),this.request.get(url).set("Authorization","Bearer "+accessToken).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.getChallenge=function(cb){if(assert.check(cb,{type:"function",message:"cb parameter is not valid"}),!this.baseOptions.state)return cb();var url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","challenge");return this.request.post(url).send({state:this.baseOptions.state}).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.delegation=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{grant_type:{type:"string",message:"grant_type option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"delegation"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getUserCountry=function(cb){var url;return assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"user","geoloc","country"),this.request.get(url).end(wrapCallback(cb))},Management.prototype.getUser=function(userId,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.get(url).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserMetadata=function(userId,userMetadata,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(userMetadata,{type:"object",message:"userMetadata parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send({user_metadata:userMetadata}).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserAttributes=function(userId,user,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(user,{type:"object",message:"user parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send(user).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.linkUser=function(userId,secondaryUserToken,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(secondaryUserToken,{type:"string",message:"secondaryUserToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId,"identities"),this.request.post(url).send({link_with:secondaryUserToken}).end(wrapCallback(cb,{ignoreCasing:!0}))};var index={Authentication:Authentication,Management:Management,WebAuth:WebAuth,version:version};exports.Authentication=Authentication,exports.Management=Management,exports.WebAuth=WebAuth,exports.default=index,exports.version=version,Object.defineProperty(exports,"__esModule",{value:!0})})); +//# sourceMappingURL=auth0.min.js.map diff --git a/build/auth0.min.js.map b/build/auth0.min.js.map new file mode 100644 index 00000000..61f47e35 --- /dev/null +++ b/build/auth0.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"auth0.min.js","sources":["../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../node_modules/component-emitter/index.js","../node_modules/fast-safe-stringify/index.js","../node_modules/superagent/lib/is-object.js","../node_modules/superagent/lib/request-base.js","../node_modules/superagent/lib/utils.js","../node_modules/superagent/lib/response-base.js","../node_modules/superagent/lib/agent-base.js","../node_modules/base64-js/index.js","../node_modules/superagent/lib/client.js","../src/helper/base64_url.js","../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/request-builder.js","../src/helper/window.js","../src/helper/storage/dummy.js","../node_modules/js-cookie/src/js.cookie.js","../src/helper/storage/cookie.js","../src/helper/warn.js","../src/helper/storage/handler.js","../src/helper/storage.js","../src/helper/ssodata.js","../src/helper/error.js","../src/helper/response-handler.js","../src/helper/parameters-whitelist.js","../node_modules/idtoken-verifier/build/idtoken-verifier.esm.js","../src/helper/plugins.js","../src/helper/random.js","../src/web-auth/transaction-manager.js","../src/helper/iframe-handler.js","../src/web-auth/web-message-handler.js","../src/web-auth/cross-origin-authentication.js","../src/web-auth/redirect.js","../src/helper/times.js","../node_modules/winchan/winchan.js","../src/helper/url.js","../src/helper/popup-handler.js","../src/web-auth/popup.js","../src/web-auth/silent-authentication-handler.js","../src/web-auth/username-password.js","../src/web-auth/hosted-pages.js","../src/web-auth/captcha.js","../src/web-auth/index.js","../src/authentication/passwordless-authentication.js","../src/authentication/db-connection.js","../src/authentication/index.js","../src/management/index.js","../src/index.js"],"sourcesContent":["(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","\r\n/**\r\n * Expose `Emitter`.\r\n */\r\n\r\nif (typeof module !== 'undefined') {\r\n module.exports = Emitter;\r\n}\r\n\r\n/**\r\n * Initialize a new `Emitter`.\r\n *\r\n * @api public\r\n */\r\n\r\nfunction Emitter(obj) {\r\n if (obj) return mixin(obj);\r\n};\r\n\r\n/**\r\n * Mixin the emitter properties.\r\n *\r\n * @param {Object} obj\r\n * @return {Object}\r\n * @api private\r\n */\r\n\r\nfunction mixin(obj) {\r\n for (var key in Emitter.prototype) {\r\n obj[key] = Emitter.prototype[key];\r\n }\r\n return obj;\r\n}\r\n\r\n/**\r\n * Listen on the given `event` with `fn`.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.on =\r\nEmitter.prototype.addEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\r\n .push(fn);\r\n return this;\r\n};\r\n\r\n/**\r\n * Adds an `event` listener that will be invoked a single\r\n * time then automatically removed.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.once = function(event, fn){\r\n function on() {\r\n this.off(event, on);\r\n fn.apply(this, arguments);\r\n }\r\n\r\n on.fn = fn;\r\n this.on(event, on);\r\n return this;\r\n};\r\n\r\n/**\r\n * Remove the given callback for `event` or all\r\n * registered callbacks.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.off =\r\nEmitter.prototype.removeListener =\r\nEmitter.prototype.removeAllListeners =\r\nEmitter.prototype.removeEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n\r\n // all\r\n if (0 == arguments.length) {\r\n this._callbacks = {};\r\n return this;\r\n }\r\n\r\n // specific event\r\n var callbacks = this._callbacks['$' + event];\r\n if (!callbacks) return this;\r\n\r\n // remove all handlers\r\n if (1 == arguments.length) {\r\n delete this._callbacks['$' + event];\r\n return this;\r\n }\r\n\r\n // remove specific handler\r\n var cb;\r\n for (var i = 0; i < callbacks.length; i++) {\r\n cb = callbacks[i];\r\n if (cb === fn || cb.fn === fn) {\r\n callbacks.splice(i, 1);\r\n break;\r\n }\r\n }\r\n\r\n // Remove event specific arrays for event types that no\r\n // one is subscribed for to avoid memory leak.\r\n if (callbacks.length === 0) {\r\n delete this._callbacks['$' + event];\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Emit `event` with the given args.\r\n *\r\n * @param {String} event\r\n * @param {Mixed} ...\r\n * @return {Emitter}\r\n */\r\n\r\nEmitter.prototype.emit = function(event){\r\n this._callbacks = this._callbacks || {};\r\n\r\n var args = new Array(arguments.length - 1)\r\n , callbacks = this._callbacks['$' + event];\r\n\r\n for (var i = 1; i < arguments.length; i++) {\r\n args[i - 1] = arguments[i];\r\n }\r\n\r\n if (callbacks) {\r\n callbacks = callbacks.slice(0);\r\n for (var i = 0, len = callbacks.length; i < len; ++i) {\r\n callbacks[i].apply(this, args);\r\n }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Return array of callbacks for `event`.\r\n *\r\n * @param {String} event\r\n * @return {Array}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.listeners = function(event){\r\n this._callbacks = this._callbacks || {};\r\n return this._callbacks['$' + event] || [];\r\n};\r\n\r\n/**\r\n * Check if this emitter has `event` handlers.\r\n *\r\n * @param {String} event\r\n * @return {Boolean}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.hasListeners = function(event){\r\n return !! this.listeners(event).length;\r\n};\r\n","module.exports = stringify\nstringify.default = stringify\nstringify.stable = deterministicStringify\nstringify.stableStringify = deterministicStringify\n\nvar arr = []\nvar replacerStack = []\n\n// Regular stringify\nfunction stringify (obj, replacer, spacer) {\n decirc(obj, '', [], undefined)\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer)\n } else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\nfunction decirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, stack, val)\n }\n } else {\n var keys = Object.keys(val)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n decirc(val[key], key, stack, val)\n }\n }\n stack.pop()\n }\n}\n\n// Stable-stringify\nfunction compareFunction (a, b) {\n if (a < b) {\n return -1\n }\n if (a > b) {\n return 1\n }\n return 0\n}\n\nfunction deterministicStringify (obj, replacer, spacer) {\n var tmp = deterministicDecirc(obj, '', [], undefined) || obj\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer)\n } else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\n\nfunction deterministicDecirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n if (typeof val.toJSON === 'function') {\n return\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, stack, val)\n }\n } else {\n // Create a temporary object in the required way\n var tmp = {}\n var keys = Object.keys(val).sort(compareFunction)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n deterministicDecirc(val[key], key, stack, val)\n tmp[key] = val[key]\n }\n if (parent !== undefined) {\n arr.push([parent, k, val])\n parent[k] = tmp\n } else {\n return tmp\n }\n }\n stack.pop()\n }\n}\n\n// wraps replacer function to handle values we couldn't replace\n// and mark them as [Circular]\nfunction replaceGetterValues (replacer) {\n replacer = replacer !== undefined ? replacer : function (k, v) { return v }\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i]\n if (part[1] === key && part[0] === val) {\n val = '[Circular]'\n replacerStack.splice(i, 1)\n break\n }\n }\n }\n return replacer.call(this, key, val)\n }\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\nfunction isObject(obj) {\n return obj !== null && _typeof(obj) === 'object';\n}\n\nmodule.exports = isObject;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pcy1vYmplY3QuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJvYmoiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7Ozs7Ozs7QUFRQSxTQUFTQSxRQUFULENBQWtCQyxHQUFsQixFQUF1QjtBQUNyQixTQUFPQSxHQUFHLEtBQUssSUFBUixJQUFnQixRQUFPQSxHQUFQLE1BQWUsUUFBdEM7QUFDRDs7QUFFREMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCSCxRQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYW4gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge0Jvb2xlYW59XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBpc09iamVjdChvYmopIHtcbiAgcmV0dXJuIG9iaiAhPT0gbnVsbCAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0Jztcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBpc09iamVjdDtcbiJdfQ==","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Module of mixed-in functions shared between node and client code\n */\nvar isObject = require('./is-object');\n/**\n * Expose `RequestBase`.\n */\n\n\nmodule.exports = RequestBase;\n/**\n * Initialize a new `RequestBase`.\n *\n * @api public\n */\n\nfunction RequestBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in RequestBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.clearTimeout = function () {\n clearTimeout(this._timer);\n clearTimeout(this._responseTimeoutTimer);\n clearTimeout(this._uploadTimeoutTimer);\n delete this._timer;\n delete this._responseTimeoutTimer;\n delete this._uploadTimeoutTimer;\n return this;\n};\n/**\n * Override default response body parser\n *\n * This function will be called to convert incoming data into request.body\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.parse = function (fn) {\n this._parser = fn;\n return this;\n};\n/**\n * Set format of binary response body.\n * In browser valid formats are 'blob' and 'arraybuffer',\n * which return Blob and ArrayBuffer, respectively.\n *\n * In Node all values result in Buffer.\n *\n * Examples:\n *\n * req.get('/')\n * .responseType('blob')\n * .end(callback);\n *\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.responseType = function (val) {\n this._responseType = val;\n return this;\n};\n/**\n * Override default request body serializer\n *\n * This function will be called to convert data set via .send or .attach into payload to send\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.serialize = function (fn) {\n this._serializer = fn;\n return this;\n};\n/**\n * Set timeouts.\n *\n * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time.\n * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections.\n * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off\n *\n * Value of 0 or false means no timeout.\n *\n * @param {Number|Object} ms or {response, deadline}\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.timeout = function (options) {\n if (!options || _typeof(options) !== 'object') {\n this._timeout = options;\n this._responseTimeout = 0;\n this._uploadTimeout = 0;\n return this;\n }\n\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option)) {\n switch (option) {\n case 'deadline':\n this._timeout = options.deadline;\n break;\n\n case 'response':\n this._responseTimeout = options.response;\n break;\n\n case 'upload':\n this._uploadTimeout = options.upload;\n break;\n\n default:\n console.warn('Unknown timeout option', option);\n }\n }\n }\n\n return this;\n};\n/**\n * Set number of retry attempts on error.\n *\n * Failed requests will be retried 'count' times if timeout or err.code >= 500.\n *\n * @param {Number} count\n * @param {Function} [fn]\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.retry = function (count, fn) {\n // Default to 1 if no count passed or true\n if (arguments.length === 0 || count === true) count = 1;\n if (count <= 0) count = 0;\n this._maxRetries = count;\n this._retries = 0;\n this._retryCallback = fn;\n return this;\n};\n\nvar ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT'];\n/**\n * Determine if a request should be retried.\n * (Borrowed from segmentio/superagent-retry)\n *\n * @param {Error} err an error\n * @param {Response} [res] response\n * @returns {Boolean} if segment should be retried\n */\n\nRequestBase.prototype._shouldRetry = function (err, res) {\n if (!this._maxRetries || this._retries++ >= this._maxRetries) {\n return false;\n }\n\n if (this._retryCallback) {\n try {\n var override = this._retryCallback(err, res);\n\n if (override === true) return true;\n if (override === false) return false; // undefined falls back to defaults\n } catch (err_) {\n console.error(err_);\n }\n }\n\n if (res && res.status && res.status >= 500 && res.status !== 501) return true;\n\n if (err) {\n if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout\n\n if (err.timeout && err.code === 'ECONNABORTED') return true;\n if (err.crossDomain) return true;\n }\n\n return false;\n};\n/**\n * Retry request\n *\n * @return {Request} for chaining\n * @api private\n */\n\n\nRequestBase.prototype._retry = function () {\n this.clearTimeout(); // node\n\n if (this.req) {\n this.req = null;\n this.req = this.request();\n }\n\n this._aborted = false;\n this.timedout = false;\n this.timedoutError = null;\n return this._end();\n};\n/**\n * Promise support\n *\n * @param {Function} resolve\n * @param {Function} [reject]\n * @return {Request}\n */\n\n\nRequestBase.prototype.then = function (resolve, reject) {\n var _this = this;\n\n if (!this._fullfilledPromise) {\n var self = this;\n\n if (this._endCalled) {\n console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises');\n }\n\n this._fullfilledPromise = new Promise(function (resolve, reject) {\n self.on('abort', function () {\n if (_this._maxRetries && _this._maxRetries > _this._retries) {\n return;\n }\n\n if (_this.timedout && _this.timedoutError) {\n reject(_this.timedoutError);\n return;\n }\n\n var err = new Error('Aborted');\n err.code = 'ABORTED';\n err.status = _this.status;\n err.method = _this.method;\n err.url = _this.url;\n reject(err);\n });\n self.end(function (err, res) {\n if (err) reject(err);else resolve(res);\n });\n });\n }\n\n return this._fullfilledPromise.then(resolve, reject);\n};\n\nRequestBase.prototype.catch = function (cb) {\n return this.then(undefined, cb);\n};\n/**\n * Allow for extension\n */\n\n\nRequestBase.prototype.use = function (fn) {\n fn(this);\n return this;\n};\n\nRequestBase.prototype.ok = function (cb) {\n if (typeof cb !== 'function') throw new Error('Callback required');\n this._okCallback = cb;\n return this;\n};\n\nRequestBase.prototype._isResponseOK = function (res) {\n if (!res) {\n return false;\n }\n\n if (this._okCallback) {\n return this._okCallback(res);\n }\n\n return res.status >= 200 && res.status < 300;\n};\n/**\n * Get request header `field`.\n * Case-insensitive.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nRequestBase.prototype.get = function (field) {\n return this._header[field.toLowerCase()];\n};\n/**\n * Get case-insensitive header `field` value.\n * This is a deprecated internal API. Use `.get(field)` instead.\n *\n * (getHeader is no longer used internally by the superagent code base)\n *\n * @param {String} field\n * @return {String}\n * @api private\n * @deprecated\n */\n\n\nRequestBase.prototype.getHeader = RequestBase.prototype.get;\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n * Case-insensitive.\n *\n * Examples:\n *\n * req.get('/')\n * .set('Accept', 'application/json')\n * .set('X-API-Key', 'foobar')\n * .end(callback);\n *\n * req.get('/')\n * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n * .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequestBase.prototype.set = function (field, val) {\n if (isObject(field)) {\n for (var key in field) {\n if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]);\n }\n\n return this;\n }\n\n this._header[field.toLowerCase()] = val;\n this.header[field] = val;\n return this;\n};\n/**\n * Remove header `field`.\n * Case-insensitive.\n *\n * Example:\n *\n * req.get('/')\n * .unset('User-Agent')\n * .end(callback);\n *\n * @param {String} field field name\n */\n\n\nRequestBase.prototype.unset = function (field) {\n delete this._header[field.toLowerCase()];\n delete this.header[field];\n return this;\n};\n/**\n * Write the field `name` and `val`, or multiple fields with one object\n * for \"multipart/form-data\" request bodies.\n *\n * ``` js\n * request.post('/upload')\n * .field('foo', 'bar')\n * .end(callback);\n *\n * request.post('/upload')\n * .field({ foo: 'bar', baz: 'qux' })\n * .end(callback);\n * ```\n *\n * @param {String|Object} name name of field\n * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.field = function (name, val) {\n // name should be either a string or an object.\n if (name === null || undefined === name) {\n throw new Error('.field(name, val) name can not be empty');\n }\n\n if (this._data) {\n throw new Error(\".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObject(name)) {\n for (var key in name) {\n if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]);\n }\n\n return this;\n }\n\n if (Array.isArray(val)) {\n for (var i in val) {\n if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]);\n }\n\n return this;\n } // val should be defined now\n\n\n if (val === null || undefined === val) {\n throw new Error('.field(name, val) val can not be empty');\n }\n\n if (typeof val === 'boolean') {\n val = String(val);\n }\n\n this._getFormData().append(name, val);\n\n return this;\n};\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request} request\n * @api public\n */\n\n\nRequestBase.prototype.abort = function () {\n if (this._aborted) {\n return this;\n }\n\n this._aborted = true;\n if (this.xhr) this.xhr.abort(); // browser\n\n if (this.req) this.req.abort(); // node\n\n this.clearTimeout();\n this.emit('abort');\n return this;\n};\n\nRequestBase.prototype._auth = function (user, pass, options, base64Encoder) {\n switch (options.type) {\n case 'basic':\n this.set('Authorization', \"Basic \".concat(base64Encoder(\"\".concat(user, \":\").concat(pass))));\n break;\n\n case 'auto':\n this.username = user;\n this.password = pass;\n break;\n\n case 'bearer':\n // usage would be .auth(accessToken, { type: 'bearer' })\n this.set('Authorization', \"Bearer \".concat(user));\n break;\n\n default:\n break;\n }\n\n return this;\n};\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\n\nRequestBase.prototype.withCredentials = function (on) {\n // This is browser-only functionality. Node side is no-op.\n if (on === undefined) on = true;\n this._withCredentials = on;\n return this;\n};\n/**\n * Set the max redirects to `n`. Does nothing in browser XHR implementation.\n *\n * @param {Number} n\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.redirects = function (n) {\n this._maxRedirects = n;\n return this;\n};\n/**\n * Maximum size of buffered response body, in bytes. Counts uncompressed size.\n * Default 200MB.\n *\n * @param {Number} n number of bytes\n * @return {Request} for chaining\n */\n\n\nRequestBase.prototype.maxResponseSize = function (n) {\n if (typeof n !== 'number') {\n throw new TypeError('Invalid argument');\n }\n\n this._maxResponseSize = n;\n return this;\n};\n/**\n * Convert to a plain javascript object (not JSON string) of scalar properties.\n * Note as this method is designed to return a useful non-this value,\n * it cannot be chained.\n *\n * @return {Object} describing method, url, and data of this request\n * @api public\n */\n\n\nRequestBase.prototype.toJSON = function () {\n return {\n method: this.method,\n url: this.url,\n data: this._data,\n headers: this._header\n };\n};\n/**\n * Send `data` as the request body, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n * // manual json\n * request.post('/user')\n * .type('json')\n * .send('{\"name\":\"tj\"}')\n * .end(callback)\n *\n * // auto json\n * request.post('/user')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // manual x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send('name=tj')\n * .end(callback)\n *\n * // auto x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // defaults to x-www-form-urlencoded\n * request.post('/user')\n * .send('name=tobi')\n * .send('species=ferret')\n * .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n// eslint-disable-next-line complexity\n\n\nRequestBase.prototype.send = function (data) {\n var isObj = isObject(data);\n var type = this._header['content-type'];\n\n if (this._formData) {\n throw new Error(\".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObj && !this._data) {\n if (Array.isArray(data)) {\n this._data = [];\n } else if (!this._isHost(data)) {\n this._data = {};\n }\n } else if (data && this._data && this._isHost(this._data)) {\n throw new Error(\"Can't merge these send calls\");\n } // merge\n\n\n if (isObj && isObject(this._data)) {\n for (var key in data) {\n if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key];\n }\n } else if (typeof data === 'string') {\n // default to x-www-form-urlencoded\n if (!type) this.type('form');\n type = this._header['content-type'];\n\n if (type === 'application/x-www-form-urlencoded') {\n this._data = this._data ? \"\".concat(this._data, \"&\").concat(data) : data;\n } else {\n this._data = (this._data || '') + data;\n }\n } else {\n this._data = data;\n }\n\n if (!isObj || this._isHost(data)) {\n return this;\n } // default to json\n\n\n if (!type) this.type('json');\n return this;\n};\n/**\n * Sort `querystring` by the sort function\n *\n *\n * Examples:\n *\n * // default order\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery()\n * .end(callback)\n *\n * // customized sort function\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery(function(a, b){\n * return a.length - b.length;\n * })\n * .end(callback)\n *\n *\n * @param {Function} sort\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.sortQuery = function (sort) {\n // _sort default to true but otherwise can be a function or boolean\n this._sort = typeof sort === 'undefined' ? true : sort;\n return this;\n};\n/**\n * Compose querystring to append to req.url\n *\n * @api private\n */\n\n\nRequestBase.prototype._finalizeQueryString = function () {\n var query = this._query.join('&');\n\n if (query) {\n this.url += (this.url.includes('?') ? '&' : '?') + query;\n }\n\n this._query.length = 0; // Makes the call idempotent\n\n if (this._sort) {\n var index = this.url.indexOf('?');\n\n if (index >= 0) {\n var queryArr = this.url.slice(index + 1).split('&');\n\n if (typeof this._sort === 'function') {\n queryArr.sort(this._sort);\n } else {\n queryArr.sort();\n }\n\n this.url = this.url.slice(0, index) + '?' + queryArr.join('&');\n }\n }\n}; // For backwards compat only\n\n\nRequestBase.prototype._appendQueryString = function () {\n console.warn('Unsupported');\n};\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\n\nRequestBase.prototype._timeoutError = function (reason, timeout, errno) {\n if (this._aborted) {\n return;\n }\n\n var err = new Error(\"\".concat(reason + timeout, \"ms exceeded\"));\n err.timeout = timeout;\n err.code = 'ECONNABORTED';\n err.errno = errno;\n this.timedout = true;\n this.timedoutError = err;\n this.abort();\n this.callback(err);\n};\n\nRequestBase.prototype._setTimeouts = function () {\n var self = this; // deadline\n\n if (this._timeout && !this._timer) {\n this._timer = setTimeout(function () {\n self._timeoutError('Timeout of ', self._timeout, 'ETIME');\n }, this._timeout);\n } // response timeout\n\n\n if (this._responseTimeout && !this._responseTimeoutTimer) {\n this._responseTimeoutTimer = setTimeout(function () {\n self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT');\n }, this._responseTimeout);\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXF1ZXN0LWJhc2UuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJyZXF1aXJlIiwibW9kdWxlIiwiZXhwb3J0cyIsIlJlcXVlc3RCYXNlIiwib2JqIiwibWl4aW4iLCJrZXkiLCJwcm90b3R5cGUiLCJPYmplY3QiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJjbGVhclRpbWVvdXQiLCJfdGltZXIiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJfdXBsb2FkVGltZW91dFRpbWVyIiwicGFyc2UiLCJmbiIsIl9wYXJzZXIiLCJyZXNwb25zZVR5cGUiLCJ2YWwiLCJfcmVzcG9uc2VUeXBlIiwic2VyaWFsaXplIiwiX3NlcmlhbGl6ZXIiLCJ0aW1lb3V0Iiwib3B0aW9ucyIsIl90aW1lb3V0IiwiX3Jlc3BvbnNlVGltZW91dCIsIl91cGxvYWRUaW1lb3V0Iiwib3B0aW9uIiwiZGVhZGxpbmUiLCJyZXNwb25zZSIsInVwbG9hZCIsImNvbnNvbGUiLCJ3YXJuIiwicmV0cnkiLCJjb3VudCIsImFyZ3VtZW50cyIsImxlbmd0aCIsIl9tYXhSZXRyaWVzIiwiX3JldHJpZXMiLCJfcmV0cnlDYWxsYmFjayIsIkVSUk9SX0NPREVTIiwiX3Nob3VsZFJldHJ5IiwiZXJyIiwicmVzIiwib3ZlcnJpZGUiLCJlcnJfIiwiZXJyb3IiLCJzdGF0dXMiLCJjb2RlIiwiaW5jbHVkZXMiLCJjcm9zc0RvbWFpbiIsIl9yZXRyeSIsInJlcSIsInJlcXVlc3QiLCJfYWJvcnRlZCIsInRpbWVkb3V0IiwidGltZWRvdXRFcnJvciIsIl9lbmQiLCJ0aGVuIiwicmVzb2x2ZSIsInJlamVjdCIsIl9mdWxsZmlsbGVkUHJvbWlzZSIsInNlbGYiLCJfZW5kQ2FsbGVkIiwiUHJvbWlzZSIsIm9uIiwiRXJyb3IiLCJtZXRob2QiLCJ1cmwiLCJlbmQiLCJjYXRjaCIsImNiIiwidW5kZWZpbmVkIiwidXNlIiwib2siLCJfb2tDYWxsYmFjayIsIl9pc1Jlc3BvbnNlT0siLCJnZXQiLCJmaWVsZCIsIl9oZWFkZXIiLCJ0b0xvd2VyQ2FzZSIsImdldEhlYWRlciIsInNldCIsImhlYWRlciIsInVuc2V0IiwibmFtZSIsIl9kYXRhIiwiQXJyYXkiLCJpc0FycmF5IiwiaSIsIlN0cmluZyIsIl9nZXRGb3JtRGF0YSIsImFwcGVuZCIsImFib3J0IiwieGhyIiwiZW1pdCIsIl9hdXRoIiwidXNlciIsInBhc3MiLCJiYXNlNjRFbmNvZGVyIiwidHlwZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJ3aXRoQ3JlZGVudGlhbHMiLCJfd2l0aENyZWRlbnRpYWxzIiwicmVkaXJlY3RzIiwibiIsIl9tYXhSZWRpcmVjdHMiLCJtYXhSZXNwb25zZVNpemUiLCJUeXBlRXJyb3IiLCJfbWF4UmVzcG9uc2VTaXplIiwidG9KU09OIiwiZGF0YSIsImhlYWRlcnMiLCJzZW5kIiwiaXNPYmoiLCJfZm9ybURhdGEiLCJfaXNIb3N0Iiwic29ydFF1ZXJ5Iiwic29ydCIsIl9zb3J0IiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJxdWVyeSIsIl9xdWVyeSIsImpvaW4iLCJpbmRleCIsImluZGV4T2YiLCJxdWVyeUFyciIsInNsaWNlIiwic3BsaXQiLCJfYXBwZW5kUXVlcnlTdHJpbmciLCJfdGltZW91dEVycm9yIiwicmVhc29uIiwiZXJybm8iLCJjYWxsYmFjayIsIl9zZXRUaW1lb3V0cyIsInNldFRpbWVvdXQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7O0FBR0EsSUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsYUFBRCxDQUF4QjtBQUVBOzs7OztBQUlBQyxNQUFNLENBQUNDLE9BQVAsR0FBaUJDLFdBQWpCO0FBRUE7Ozs7OztBQU1BLFNBQVNBLFdBQVQsQ0FBcUJDLEdBQXJCLEVBQTBCO0FBQ3hCLE1BQUlBLEdBQUosRUFBUyxPQUFPQyxLQUFLLENBQUNELEdBQUQsQ0FBWjtBQUNWO0FBRUQ7Ozs7Ozs7OztBQVFBLFNBQVNDLEtBQVQsQ0FBZUQsR0FBZixFQUFvQjtBQUNsQixPQUFLLElBQU1FLEdBQVgsSUFBa0JI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LEVBRXJCLEtBQUtBLFFBRmdCLENBQXhCO0FBR0QsR0FSNkMsQ0FVOUM7OztBQUNBLE1BQUksS0FBS0MsZ0JBQUwsSUFBeUIsQ0FBQyxLQUFLYixxQkFBbkMsRUFBMEQ7QUFDeEQsU0FBS0EscUJBQUwsR0FBNkI0SCxVQUFVLENBQUMsWUFBTTtBQUM1QzFFLE1BQUFBLElBQUksQ0FBQ3FFLGFBQUwsQ0FDRSxzQkFERixFQUVFckUsSUFBSSxDQUFDckMsZ0JBRlAsRUFHRSxXQUhGO0FBS0QsS0FOc0MsRUFNcEMsS0FBS0EsZ0JBTitCLENBQXZDO0FBT0Q7QUFDRixDQXBCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTW9kdWxlIG9mIG1peGVkLWluIGZ1bmN0aW9ucyBzaGFyZWQgYmV0d2VlbiBub2RlIGFuZCBjbGllbnQgY29kZVxuICovXG5jb25zdCBpc09iamVjdCA9IHJlcXVpcmUoJy4vaXMtb2JqZWN0Jyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXF1ZXN0QmFzZWAuXG4gKi9cblxubW9kdWxlLmV4cG9ydHMgPSBSZXF1ZXN0QmFzZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0QmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0QmFzZShvYmopIHtcbiAgaWYgKG9iaikgcmV0dXJuIG1peGluKG9iaik7XG59XG5cbi8qKlxuICogTWl4aW4gdGhlIHByb3RvdHlwZSBwcm9wZXJ0aWVzLlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIG1peGluKG9iaikge1xuICBmb3IgKGNvbnN0IGtleSBpbiBSZXF1ZXN0QmFzZS5wcm90b3R5cGUpIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKFJlcXVlc3RCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVxdWVzdEJhc2UucHJvdG90eXBlW2tleV07XG4gIH1cblxuICByZXR1cm4gb2JqO1xufVxuXG4vKipcbiAqIENsZWFyIHByZXZpb3VzIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5jbGVhclRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3RpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3VwbG9hZFRpbWVvdXRUaW1lcik7XG4gIGRlbGV0ZSB0aGlzLl90aW1lcjtcbiAgZGVsZXRlIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyO1xuICBkZWxldGUgdGhpcy5fdXBsb2FkVGltZW91dFRpbWVyO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogT3ZlcnJpZGUgZGVmYXVsdCByZXNwb25zZSBib2R5IHBhcnNlclxuICpcbiAqIFRoaXMgZnVuY3Rpb24gd2lsbCBiZSBjYWxsZWQgdG8gY29udmVydCBpbmNvbWluZyBkYXRhIGludG8gcmVxdWVzdC5ib2R5XG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnBhcnNlID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fcGFyc2VyID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgZm9ybWF0IG9mIGJpbmFyeSByZXNwb25zZSBib2R5LlxuICogSW4gYnJvd3NlciB2YWxpZCBmb3JtYXRzIGFyZSAnYmxvYicgYW5kICdhcnJheWJ1ZmZlcicsXG4gKiB3aGljaCByZXR1cm4gQmxvYiBhbmQgQXJyYXlCdWZmZXIsIHJlc3BlY3RpdmVseS5cbiAqXG4gKiBJbiBOb2RlIGFsbCB2YWx1ZXMgcmVzdWx0IGluIEJ1ZmZlci5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5yZXNwb25zZVR5cGUoJ2Jsb2InKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB2YWxcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVzcG9uc2VUeXBlID0gZnVuY3Rpb24odmFsKSB7XG4gIHRoaXMuX3Jlc3BvbnNlVHlwZSA9IHZhbDtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIE92ZXJyaWRlIGRlZmF1bHQgcmVxdWVzdCBib2R5IHNlcmlhbGl6ZXJcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYmUgY2FsbGVkIHRvIGNvbnZlcnQgZGF0YSBzZXQgdmlhIC5zZW5kIG9yIC5hdHRhY2ggaW50byBwYXlsb2FkIHRvIHNlbmRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VyaWFsaXplID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fc2VyaWFsaXplciA9IGZuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IHRpbWVvdXRzLlxuICpcbiAqIC0gcmVzcG9uc2UgdGltZW91dCBpcyB0aW1lIGJldHdlZW4gc2VuZGluZyByZXF1ZXN0IGFuZCByZWNlaXZpbmcgdGhlIGZpcnN0IGJ5dGUgb2YgdGhlIHJlc3BvbnNlLiBJbmNsdWRlcyBETlMgYW5kIGNvbm5lY3Rpb24gdGltZS5cbiAqIC0gZGVhZGxpbmUgaXMgdGhlIHRpbWUgZnJvbSBzdGFydCBvZiB0aGUgcmVxdWVzdCB0byByZWNlaXZpbmcgcmVzcG9uc2UgYm9keSBpbiBmdWxsLiBJZiB0aGUgZGVhZGxpbmUgaXMgdG9vIHNob3J0IGxhcmdlIGZpbGVzIG1heSBub3QgbG9hZCBhdCBhbGwgb24gc2xvdyBjb25uZWN0aW9ucy5cbiAqIC0gdXBsb2FkIGlzIHRoZSB0aW1lICBzaW5jZSBsYXN0IGJpdCBvZiBkYXRhIHdhcyBzZW50IG9yIHJlY2VpdmVkLiBUaGlzIHRpbWVvdXQgd29ya3Mgb25seSBpZiBkZWFkbGluZSB0aW1lb3V0IGlzIG9mZlxuICpcbiAqIFZhbHVlIG9mIDAgb3IgZmFsc2UgbWVhbnMgbm8gdGltZW91dC5cbiAqXG4gKiBAcGFyYW0ge051bWJlcnxPYmplY3R9IG1zIG9yIHtyZXNwb25zZSwgZGVhZGxpbmV9XG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnRpbWVvdXQgPSBmdW5jdGlvbihvcHRpb25zKSB7XG4gIGlmICghb3B0aW9ucyB8fCB0eXBlb2Ygb3B0aW9ucyAhPT0gJ29iamVjdCcpIHtcbiAgICB0aGlzLl90aW1lb3V0ID0gb3B0aW9ucztcbiAgICB0aGlzLl9yZXNwb25zZVRpbWVvdXQgPSAwO1xuICAgIHRoaXMuX3VwbG9hZFRpbWVvdXQgPSAwO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZm9yIChjb25zdCBvcHRpb24gaW4gb3B0aW9ucykge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob3B0aW9ucywgb3B0aW9uKSkge1xuICAgICAgc3dpdGNoIChvcHRpb24pIHtcbiAgICAgICAgY2FzZSAnZGVhZGxpbmUnOlxuICAgICAgICAgIHRoaXMuX3RpbWVvdXQgPSBvcHRpb25zLmRlYWRsaW5lO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdyZXNwb25zZSc6XG4gICAgICAgICAgdGhpcy5fcmVzcG9uc2VUaW1lb3V0ID0gb3B0aW9ucy5yZXNwb25zZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAndXBsb2FkJzpcbiAgICAgICAgICB0aGlzLl91cGxvYWRUaW1lb3V0ID0gb3B0aW9ucy51cGxvYWQ7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgY29uc29sZS53YXJuKCdVbmtub3duIHRpbWVvdXQgb3B0aW9uJywgb3B0aW9uKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IG51bWJlciBvZiByZXRyeSBhdHRlbXB0cyBvbiBlcnJvci5cbiAqXG4gKiBGYWlsZWQgcmVxdWVzdHMgd2lsbCBiZSByZXRyaWVkICdjb3VudCcgdGltZXMgaWYgdGltZW91dCBvciBlcnIuY29kZSA+PSA1MDAuXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IGNvdW50XG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnJldHJ5ID0gZnVuY3Rpb24oY291bnQsIGZuKSB7XG4gIC8vIERlZmF1bHQgdG8gMSBpZiBubyBjb3VudCBwYXNzZWQgb3IgdHJ1ZVxuICBpZiAoYXJndW1lbnRzLmxlbmd0aCA9PT0gMCB8fCBjb3VudCA9PT0gdHJ1ZSkgY291bnQgPSAxO1xuICBpZiAoY291bnQgPD0gMCkgY291bnQgPSAwO1xuICB0aGlzLl9tYXhSZXRyaWVzID0gY291bnQ7XG4gIHRoaXMuX3JldHJpZXMgPSAwO1xuICB0aGlzLl9yZXRyeUNhbGxiYWNrID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuY29uc3QgRVJST1JfQ09ERVMgPSBbJ0VDT05OUkVTRVQnLCAnRVRJTUVET1VUJywgJ0VBRERSSU5GTycsICdFU09DS0VUVElNRURPVVQnXTtcblxuLyoqXG4gKiBEZXRlcm1pbmUgaWYgYSByZXF1ZXN0IHNob3VsZCBiZSByZXRyaWVkLlxuICogKEJvcnJvd2VkIGZyb20gc2VnbWVudGlvL3N1cGVyYWdlbnQtcmV0cnkpXG4gKlxuICogQHBhcmFtIHtFcnJvcn0gZXJyIGFuIGVycm9yXG4gKiBAcGFyYW0ge1Jlc3BvbnNlfSBbcmVzXSByZXNwb25zZVxuICogQHJldHVybnMge0Jvb2xlYW59IGlmIHNlZ21lbnQgc2hvdWxkIGJlIHJldHJpZWRcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zaG91bGRSZXRyeSA9IGZ1bmN0aW9uKGVyciwgcmVzKSB7XG4gIGlmICghdGhpcy5fbWF4UmV0cmllcyB8fCB0aGlzLl9yZXRyaWVzKysgPj0gdGhpcy5fbWF4UmV0cmllcykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICh0aGlzLl9yZXRyeUNhbGxiYWNrKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IG92ZXJyaWRlID0gdGhpcy5fcmV0cnlDYWxsYmFjayhlcnIsIHJlcyk7XG4gICAgICBpZiAob3ZlcnJpZGUgPT09IHRydWUpIHJldHVybiB0cnVlO1xuICAgICAgaWYgKG92ZXJyaWRlID09PSBmYWxzZSkgcmV0dXJuIGZhbHNlO1xuICAgICAgLy8gdW5kZWZpbmVkIGZhbGxzIGJhY2sgdG8gZGVmYXVsdHNcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycl8pO1xuICAgIH1cbiAgfVxuXG4gIGlmIChyZXMgJiYgcmVzLnN0YXR1cyAmJiByZXMuc3RhdHVzID49IDUwMCAmJiByZXMuc3RhdHVzICE9PSA1MDEpIHJldHVybiB0cnVlO1xuICBpZiAoZXJyKSB7XG4gICAgaWYgKGVyci5jb2RlICYmIEVSUk9SX0NPREVTLmluY2x1ZGVzKGVyci5jb2RlKSkgcmV0dXJuIHRydWU7XG4gICAgLy8gU3VwZXJhZ2VudCB0aW1lb3V0XG4gICAgaWYgKGVyci50aW1lb3V0ICYmIGVyci5jb2RlID09PSAnRUNPTk5BQk9SVEVEJykgcmV0dXJuIHRydWU7XG4gICAgaWYgKGVyci5jcm9zc0RvbWFpbikgcmV0dXJuIHRydWU7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59O1xuXG4vKipcbiAqIFJldHJ5IHJlcXVlc3RcbiAqXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fcmV0cnkgPSBmdW5jdGlvbigpIHtcbiAgdGhpcy5jbGVhclRpbWVvdXQoKTtcblxuICAvLyBub2RlXG4gIGlmICh0aGlzLnJlcSkge1xuICAgIHRoaXMucmVxID0gbnVsbDtcbiAgICB0aGlzLnJlcSA9IHRoaXMucmVxdWVzdCgpO1xuICB9XG5cbiAgdGhpcy5fYWJvcnRlZCA9IGZhbHNlO1xuICB0aGlzLnRpbWVkb3V0ID0gZmFsc2U7XG4gIHRoaXMudGltZWRvdXRFcnJvciA9IG51bGw7XG5cbiAgcmV0dXJuIHRoaXMuX2VuZCgpO1xufTtcblxuLyoqXG4gKiBQcm9taXNlIHN1cHBvcnRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSByZXNvbHZlXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbcmVqZWN0XVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudGhlbiA9IGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkge1xuICBpZiAoIXRoaXMuX2Z1bGxmaWxsZWRQcm9taXNlKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgaWYgKHRoaXMuX2VuZENhbGxlZCkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnV2FybmluZzogc3VwZXJhZ2VudCByZXF1ZXN0IHdhcyBzZW50IHR3aWNlLCBiZWNhdXNlIGJvdGggLmVuZCgpIGFuZCAudGhlbigpIHdlcmUgY2FsbGVkLiBOZXZlciBjYWxsIC5lbmQoKSBpZiB5b3UgdXNlIHByb21pc2VzJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHNlbGYub24oJ2Fib3J0JywgKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5fbWF4UmV0cmllcyAmJiB0aGlzLl9tYXhSZXRyaWVzID4gdGhpcy5fcmV0cmllcykge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLnRpbWVkb3V0ICYmIHRoaXMudGltZWRvdXRFcnJvcikge1xuICAgICAgICAgIHJlamVjdCh0aGlzLnRpbWVkb3V0RXJyb3IpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGVyciA9IG5ldyBFcnJvcignQWJvcnRlZCcpO1xuICAgICAgICBlcnIuY29kZSA9ICdBQk9SVEVEJztcbiAgICAgICAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICAgICAgICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gICAgICAgIGVyci51cmwgPSB0aGlzLnVybDtcbiAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICB9KTtcbiAgICAgIHNlbGYuZW5kKChlcnIsIHJlcykgPT4ge1xuICAgICAgICBpZiAoZXJyKSByZWplY3QoZXJyKTtcbiAgICAgICAgZWxzZSByZXNvbHZlKHJlcyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZS50aGVuKHJlc29sdmUsIHJlamVjdCk7XG59O1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuY2F0Y2ggPSBmdW5jdGlvbihjYikge1xuICByZXR1cm4gdGhpcy50aGVuKHVuZGVmaW5lZCwgY2IpO1xufTtcblxuLyoqXG4gKiBBbGxvdyBmb3IgZXh0ZW5zaW9uXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnVzZSA9IGZ1bmN0aW9uKGZuKSB7XG4gIGZuKHRoaXMpO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5vayA9IGZ1bmN0aW9uKGNiKSB7XG4gIGlmICh0eXBlb2YgY2IgIT09ICdmdW5jdGlvbicpIHRocm93IG5ldyBFcnJvcignQ2FsbGJhY2sgcmVxdWlyZWQnKTtcbiAgdGhpcy5fb2tDYWxsYmFjayA9IGNiO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5faXNSZXNwb25zZU9LID0gZnVuY3Rpb24ocmVzKSB7XG4gIGlmICghcmVzKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKHRoaXMuX29rQ2FsbGJhY2spIHtcbiAgICByZXR1cm4gdGhpcy5fb2tDYWxsYmFjayhyZXMpO1xuICB9XG5cbiAgcmV0dXJuIHJlcy5zdGF0dXMgPj0gMjAwICYmIHJlcy5zdGF0dXMgPCAzMDA7XG59O1xuXG4vKipcbiAqIEdldCByZXF1ZXN0IGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGRcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLl9oZWFkZXJbZmllbGQudG9Mb3dlckNhc2UoKV07XG59O1xuXG4vKipcbiAqIEdldCBjYXNlLWluc2Vuc2l0aXZlIGhlYWRlciBgZmllbGRgIHZhbHVlLlxuICogVGhpcyBpcyBhIGRlcHJlY2F0ZWQgaW50ZXJuYWwgQVBJLiBVc2UgYC5nZXQoZmllbGQpYCBpbnN0ZWFkLlxuICpcbiAqIChnZXRIZWFkZXIgaXMgbm8gbG9uZ2VyIHVzZWQgaW50ZXJuYWxseSBieSB0aGUgc3VwZXJhZ2VudCBjb2RlIGJhc2UpXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGZpZWxkXG4gKiBAcmV0dXJuIHtTdHJpbmd9XG4gKiBAYXBpIHByaXZhdGVcbiAqIEBkZXByZWNhdGVkXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldEhlYWRlciA9IFJlcXVlc3RCYXNlLnByb3RvdHlwZS5nZXQ7XG5cbi8qKlxuICogU2V0IGhlYWRlciBgZmllbGRgIHRvIGB2YWxgLCBvciBtdWx0aXBsZSBmaWVsZHMgd2l0aCBvbmUgb2JqZWN0LlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoJ0FjY2VwdCcsICdhcHBsaWNhdGlvbi9qc29uJylcbiAqICAgICAgICAuc2V0KCdYLUFQSS1LZXknLCAnZm9vYmFyJylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoeyBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJywgJ1gtQVBJLUtleSc6ICdmb29iYXInIH0pXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd8T2JqZWN0fSBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zZXQgPSBmdW5jdGlvbihmaWVsZCwgdmFsKSB7XG4gIGlmIChpc09iamVjdChmaWVsZCkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBmaWVsZCkge1xuICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChmaWVsZCwga2V5KSlcbiAgICAgICAgdGhpcy5zZXQoa2V5LCBmaWVsZFtrZXldKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRoaXMuX2hlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXSA9IHZhbDtcbiAgdGhpcy5oZWFkZXJbZmllbGRdID0gdmFsO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogUmVtb3ZlIGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlOlxuICpcbiAqICAgICAgcmVxLmdldCgnLycpXG4gKiAgICAgICAgLnVuc2V0KCdVc2VyLUFnZW50JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGQgZmllbGQgbmFtZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudW5zZXQgPSBmdW5jdGlvbihmaWVsZCkge1xuICBkZWxldGUgdGhpcy5faGVhZGVyW2ZpZWxkLnRvTG93ZXJDYXNlKCldO1xuICBkZWxldGUgdGhpcy5oZWFkZXJbZmllbGRdO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogV3JpdGUgdGhlIGZpZWxkIGBuYW1lYCBhbmQgYHZhbGAsIG9yIG11bHRpcGxlIGZpZWxkcyB3aXRoIG9uZSBvYmplY3RcbiAqIGZvciBcIm11bHRpcGFydC9mb3JtLWRhdGFcIiByZXF1ZXN0IGJvZGllcy5cbiAqXG4gKiBgYGAganNcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCgnZm9vJywgJ2JhcicpXG4gKiAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCh7IGZvbzogJ2JhcicsIGJhejogJ3F1eCcgfSlcbiAqICAgLmVuZChjYWxsYmFjayk7XG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ3xPYmplY3R9IG5hbWUgbmFtZSBvZiBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd8QmxvYnxGaWxlfEJ1ZmZlcnxmcy5SZWFkU3RyZWFtfSB2YWwgdmFsdWUgb2YgZmllbGRcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmZpZWxkID0gZnVuY3Rpb24obmFtZSwgdmFsKSB7XG4gIC8vIG5hbWUgc2hvdWxkIGJlIGVpdGhlciBhIHN0cmluZyBvciBhbiBvYmplY3QuXG4gIGlmIChuYW1lID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gbmFtZSkge1xuICAgIHRocm93IG5ldyBFcnJvcignLmZpZWxkKG5hbWUsIHZhbCkgbmFtZSBjYW4gbm90IGJlIGVtcHR5Jyk7XG4gIH1cblxuICBpZiAodGhpcy5fZGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLmZpZWxkKCkgY2FuJ3QgYmUgdXNlZCBpZiAuc2VuZCgpIGlzIHVzZWQuIFBsZWFzZSB1c2Ugb25seSAuc2VuZCgpIG9yIG9ubHkgLmZpZWxkKCkgJiAuYXR0YWNoKClcIlxuICAgICk7XG4gIH1cblxuICBpZiAoaXNPYmplY3QobmFtZSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBuYW1lKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG5hbWUsIGtleSkpXG4gICAgICAgIHRoaXMuZmllbGQoa2V5LCBuYW1lW2tleV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkodmFsKSkge1xuICAgIGZvciAoY29uc3QgaSBpbiB2YWwpIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmFsLCBpKSlcbiAgICAgICAgdGhpcy5maWVsZChuYW1lLCB2YWxbaV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLy8gdmFsIHNob3VsZCBiZSBkZWZpbmVkIG5vd1xuICBpZiAodmFsID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gdmFsKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCcuZmllbGQobmFtZSwgdmFsKSB2YWwgY2FuIG5vdCBiZSBlbXB0eScpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiB2YWwgPT09ICdib29sZWFuJykge1xuICAgIHZhbCA9IFN0cmluZyh2YWwpO1xuICB9XG5cbiAgdGhpcy5fZ2V0Rm9ybURhdGEoKS5hcHBlbmQobmFtZSwgdmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIEFib3J0IHRoZSByZXF1ZXN0LCBhbmQgY2xlYXIgcG90ZW50aWFsIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmFib3J0ID0gZnVuY3Rpb24oKSB7XG4gIGlmICh0aGlzLl9hYm9ydGVkKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICB0aGlzLl9hYm9ydGVkID0gdHJ1ZTtcbiAgaWYgKHRoaXMueGhyKSB0aGlzLnhoci5hYm9ydCgpOyAvLyBicm93c2VyXG4gIGlmICh0aGlzLnJlcSkgdGhpcy5yZXEuYWJvcnQoKTsgLy8gbm9kZVxuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuICB0aGlzLmVtaXQoJ2Fib3J0Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hdXRoID0gZnVuY3Rpb24odXNlciwgcGFzcywgb3B0aW9ucywgYmFzZTY0RW5jb2Rlcikge1xuICBzd2l0Y2ggKG9wdGlvbnMudHlwZSkge1xuICAgIGNhc2UgJ2Jhc2ljJzpcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJhc2ljICR7YmFzZTY0RW5jb2RlcihgJHt1c2VyfToke3Bhc3N9YCl9YCk7XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2F1dG8nOlxuICAgICAgdGhpcy51c2VybmFtZSA9IHVzZXI7XG4gICAgICB0aGlzLnBhc3N3b3JkID0gcGFzcztcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnYmVhcmVyJzogLy8gdXNhZ2Ugd291bGQgYmUgLmF1dGgoYWNjZXNzVG9rZW4sIHsgdHlwZTogJ2JlYXJlcicgfSlcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3VzZXJ9YCk7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgYnJlYWs7XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogRW5hYmxlIHRyYW5zbWlzc2lvbiBvZiBjb29raWVzIHdpdGggeC1kb21haW4gcmVxdWVzdHMuXG4gKlxuICogTm90ZSB0aGF0IGZvciB0aGlzIHRvIHdvcmsgdGhlIG9yaWdpbiBtdXN0IG5vdCBiZVxuICogdXNpbmcgXCJBY2Nlc3MtQ29udHJvbC1BbGxvdy1PcmlnaW5cIiB3aXRoIGEgd2lsZGNhcmQsXG4gKiBhbmQgYWxzbyBtdXN0IHNldCBcIkFjY2Vzcy1Db250cm9sLUFsbG93LUNyZWRlbnRpYWxzXCJcbiAqIHRvIFwidHJ1ZVwiLlxuICpcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLndpdGhDcmVkZW50aWFscyA9IGZ1bmN0aW9uKG9uKSB7XG4gIC8vIFRoaXMgaXMgYnJvd3Nlci1vbmx5IGZ1bmN0aW9uYWxpdHkuIE5vZGUgc2lkZSBpcyBuby1vcC5cbiAgaWYgKG9uID09PSB1bmRlZmluZWQpIG9uID0gdHJ1ZTtcbiAgdGhpcy5fd2l0aENyZWRlbnRpYWxzID0gb247XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgdGhlIG1heCByZWRpcmVjdHMgdG8gYG5gLiBEb2VzIG5vdGhpbmcgaW4gYnJvd3NlciBYSFIgaW1wbGVtZW50YXRpb24uXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IG5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVkaXJlY3RzID0gZnVuY3Rpb24obikge1xuICB0aGlzLl9tYXhSZWRpcmVjdHMgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogTWF4aW11bSBzaXplIG9mIGJ1ZmZlcmVkIHJlc3BvbnNlIGJvZHksIGluIGJ5dGVzLiBDb3VudHMgdW5jb21wcmVzc2VkIHNpemUuXG4gKiBEZWZhdWx0IDIwME1CLlxuICpcbiAqIEBwYXJhbSB7TnVtYmVyfSBuIG51bWJlciBvZiBieXRlc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKi9cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5tYXhSZXNwb25zZVNpemUgPSBmdW5jdGlvbihuKSB7XG4gIGlmICh0eXBlb2YgbiAhPT0gJ251bWJlcicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdJbnZhbGlkIGFyZ3VtZW50Jyk7XG4gIH1cblxuICB0aGlzLl9tYXhSZXNwb25zZVNpemUgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29udmVydCB0byBhIHBsYWluIGphdmFzY3JpcHQgb2JqZWN0IChub3QgSlNPTiBzdHJpbmcpIG9mIHNjYWxhciBwcm9wZXJ0aWVzLlxuICogTm90ZSBhcyB0aGlzIG1ldGhvZCBpcyBkZXNpZ25lZCB0byByZXR1cm4gYSB1c2VmdWwgbm9uLXRoaXMgdmFsdWUsXG4gKiBpdCBjYW5ub3QgYmUgY2hhaW5lZC5cbiAqXG4gKiBAcmV0dXJuIHtPYmplY3R9IGRlc2NyaWJpbmcgbWV0aG9kLCB1cmwsIGFuZCBkYXRhIG9mIHRoaXMgcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudG9KU09OID0gZnVuY3Rpb24oKSB7XG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiB0aGlzLm1ldGhvZCxcbiAgICB1cmw6IHRoaXMudXJsLFxuICAgIGRhdGE6IHRoaXMuX2RhdGEsXG4gICAgaGVhZGVyczogdGhpcy5faGVhZGVyXG4gIH07XG59O1xuXG4vKipcbiAqIFNlbmQgYGRhdGFgIGFzIHRoZSByZXF1ZXN0IGJvZHksIGRlZmF1bHRpbmcgdGhlIGAudHlwZSgpYCB0byBcImpzb25cIiB3aGVuXG4gKiBhbiBvYmplY3QgaXMgZ2l2ZW4uXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICAgICAgLy8gbWFudWFsIGpzb25cbiAqICAgICAgIHJlcXVlc3QucG9zdCgnL3VzZXInKVxuICogICAgICAgICAudHlwZSgnanNvbicpXG4gKiAgICAgICAgIC5zZW5kKCd7XCJuYW1lXCI6XCJ0alwifScpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gYXV0byBqc29uXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gbWFudWFsIHgtd3d3LWZvcm0tdXJsZW5jb2RlZFxuICogICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgIC50eXBlKCdmb3JtJylcbiAqICAgICAgICAgLnNlbmQoJ25hbWU9dGonKVxuICogICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqICAgICAgIC8vIGF1dG8geC13d3ctZm9ybS11cmxlbmNvZGVkXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnR5cGUoJ2Zvcm0nKVxuICogICAgICAgICAuc2VuZCh7IG5hbWU6ICd0aicgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0cyB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoJ25hbWU9dG9iaScpXG4gKiAgICAgICAgLnNlbmQoJ3NwZWNpZXM9ZmVycmV0JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gZGF0YVxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VuZCA9IGZ1bmN0aW9uKGRhdGEpIHtcbiAgY29uc3QgaXNPYmogPSBpc09iamVjdChkYXRhKTtcbiAgbGV0IHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuXG4gIGlmICh0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLnNlbmQoKSBjYW4ndCBiZSB1c2VkIGlmIC5hdHRhY2goKSBvciAuZmllbGQoKSBpcyB1c2VkLiBQbGVhc2UgdXNlIG9ubHkgLnNlbmQoKSBvciBvbmx5IC5maWVsZCgpICYgLmF0dGFjaCgpXCJcbiAgICApO1xuICB9XG5cbiAgaWYgKGlzT2JqICYmICF0aGlzLl9kYXRhKSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSBbXTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLl9pc0hvc3QoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSB7fTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoZGF0YSAmJiB0aGlzLl9kYXRhICYmIHRoaXMuX2lzSG9zdCh0aGlzLl9kYXRhKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIkNhbid0IG1lcmdlIHRoZXNlIHNlbmQgY2FsbHNcIik7XG4gIH1cblxuICAvLyBtZXJnZVxuICBpZiAoaXNPYmogJiYgaXNPYmplY3QodGhpcy5fZGF0YSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGRhdGEsIGtleSkpXG4gICAgICAgIHRoaXMuX2RhdGFba2V5XSA9IGRhdGFba2V5XTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodHlwZW9mIGRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgLy8gZGVmYXVsdCB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAgICBpZiAoIXR5cGUpIHRoaXMudHlwZSgnZm9ybScpO1xuICAgIHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGlmICh0eXBlID09PSAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJykge1xuICAgICAgdGhpcy5fZGF0YSA9IHRoaXMuX2RhdGEgPyBgJHt0aGlzLl9kYXRhfSYke2RhdGF9YCA6IGRhdGE7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2RhdGEgPSAodGhpcy5fZGF0YSB8fCAnJykgKyBkYXRhO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICB0aGlzLl9kYXRhID0gZGF0YTtcbiAgfVxuXG4gIGlmICghaXNPYmogfHwgdGhpcy5faXNIb3N0KGRhdGEpKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvLyBkZWZhdWx0IHRvIGpzb25cbiAgaWYgKCF0eXBlKSB0aGlzLnR5cGUoJ2pzb24nKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNvcnQgYHF1ZXJ5c3RyaW5nYCBieSB0aGUgc29ydCBmdW5jdGlvblxuICpcbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0IG9yZGVyXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeSgpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gY3VzdG9taXplZCBzb3J0IGZ1bmN0aW9uXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeShmdW5jdGlvbihhLCBiKXtcbiAqICAgICAgICAgICByZXR1cm4gYS5sZW5ndGggLSBiLmxlbmd0aDtcbiAqICAgICAgICAgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gc29ydFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zb3J0UXVlcnkgPSBmdW5jdGlvbihzb3J0KSB7XG4gIC8vIF9zb3J0IGRlZmF1bHQgdG8gdHJ1ZSBidXQgb3RoZXJ3aXNlIGNhbiBiZSBhIGZ1bmN0aW9uIG9yIGJvb2xlYW5cbiAgdGhpcy5fc29ydCA9IHR5cGVvZiBzb3J0ID09PSAndW5kZWZpbmVkJyA/IHRydWUgOiBzb3J0O1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29tcG9zZSBxdWVyeXN0cmluZyB0byBhcHBlbmQgdG8gcmVxLnVybFxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuX2ZpbmFsaXplUXVlcnlTdHJpbmcgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgcXVlcnkgPSB0aGlzLl9xdWVyeS5qb2luKCcmJyk7XG4gIGlmIChxdWVyeSkge1xuICAgIHRoaXMudXJsICs9ICh0aGlzLnVybC5pbmNsdWRlcygnPycpID8gJyYnIDogJz8nKSArIHF1ZXJ5O1xuICB9XG5cbiAgdGhpcy5fcXVlcnkubGVuZ3RoID0gMDsgLy8gTWFrZXMgdGhlIGNhbGwgaWRlbXBvdGVudFxuXG4gIGlmICh0aGlzLl9zb3J0KSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLnVybC5pbmRleE9mKCc/Jyk7XG4gICAgaWYgKGluZGV4ID49IDApIHtcbiAgICAgIGNvbnN0IHF1ZXJ5QXJyID0gdGhpcy51cmwuc2xpY2UoaW5kZXggKyAxKS5zcGxpdCgnJicpO1xuICAgICAgaWYgKHR5cGVvZiB0aGlzLl9zb3J0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHF1ZXJ5QXJyLnNvcnQodGhpcy5fc29ydCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBxdWVyeUFyci5zb3J0KCk7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudXJsID0gdGhpcy51cmwuc2xpY2UoMCwgaW5kZXgpICsgJz8nICsgcXVlcnlBcnIuam9pbignJicpO1xuICAgIH1cbiAgfVxufTtcblxuLy8gRm9yIGJhY2t3YXJkcyBjb21wYXQgb25seVxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hcHBlbmRRdWVyeVN0cmluZyA9ICgpID0+IHtcbiAgY29uc29sZS53YXJuKCdVbnN1cHBvcnRlZCcpO1xufTtcblxuLyoqXG4gKiBJbnZva2UgY2FsbGJhY2sgd2l0aCB0aW1lb3V0IGVycm9yLlxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fdGltZW91dEVycm9yID0gZnVuY3Rpb24ocmVhc29uLCB0aW1lb3V0LCBlcnJubykge1xuICBpZiAodGhpcy5fYWJvcnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGVyciA9IG5ldyBFcnJvcihgJHtyZWFzb24gKyB0aW1lb3V0fW1zIGV4Y2VlZGVkYCk7XG4gIGVyci50aW1lb3V0ID0gdGltZW91dDtcbiAgZXJyLmNvZGUgPSAnRUNPTk5BQk9SVEVEJztcbiAgZXJyLmVycm5vID0gZXJybm87XG4gIHRoaXMudGltZWRvdXQgPSB0cnVlO1xuICB0aGlzLnRpbWVkb3V0RXJyb3IgPSBlcnI7XG4gIHRoaXMuYWJvcnQoKTtcbiAgdGhpcy5jYWxsYmFjayhlcnIpO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zZXRUaW1lb3V0cyA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBzZWxmID0gdGhpcztcblxuICAvLyBkZWFkbGluZVxuICBpZiAodGhpcy5fdGltZW91dCAmJiAhdGhpcy5fdGltZXIpIHtcbiAgICB0aGlzLl90aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2VsZi5fdGltZW91dEVycm9yKCdUaW1lb3V0IG9mICcsIHNlbGYuX3RpbWVvdXQsICdFVElNRScpO1xuICAgIH0sIHRoaXMuX3RpbWVvdXQpO1xuICB9XG5cbiAgLy8gcmVzcG9uc2UgdGltZW91dFxuICBpZiAodGhpcy5fcmVzcG9uc2VUaW1lb3V0ICYmICF0aGlzLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZWxmLl90aW1lb3V0RXJyb3IoXG4gICAgICAgICdSZXNwb25zZSB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3Jlc3BvbnNlVGltZW91dCxcbiAgICAgICAgJ0VUSU1FRE9VVCdcbiAgICAgICk7XG4gICAgfSwgdGhpcy5fcmVzcG9uc2VUaW1lb3V0KTtcbiAgfVxufTtcbiJdfQ==","\"use strict\";\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\nexports.type = function (str) {\n return str.split(/ *; */).shift();\n};\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.params = function (str) {\n return str.split(/ *; */).reduce(function (obj, str) {\n var parts = str.split(/ *= */);\n var key = parts.shift();\n var val = parts.shift();\n if (key && val) obj[key] = val;\n return obj;\n }, {});\n};\n/**\n * Parse Link header fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.parseLinks = function (str) {\n return str.split(/ *, */).reduce(function (obj, str) {\n var parts = str.split(/ *; */);\n var url = parts[0].slice(1, -1);\n var rel = parts[1].split(/ *= */)[1].slice(1, -1);\n obj[rel] = url;\n return obj;\n }, {});\n};\n/**\n * Strip content related fields from `header`.\n *\n * @param {Object} header\n * @return {Object} header\n * @api private\n */\n\n\nexports.cleanHeader = function (header, changesOrigin) {\n delete header['content-type'];\n delete header['content-length'];\n delete header['transfer-encoding'];\n delete header.host; // secuirty\n\n if (changesOrigin) {\n delete header.authorization;\n delete header.cookie;\n }\n\n return header;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJleHBvcnRzIiwidHlwZSIsInN0ciIsInNwbGl0Iiwic2hpZnQiLCJwYXJhbXMiLCJyZWR1Y2UiLCJvYmoiLCJwYXJ0cyIsImtleSIsInZhbCIsInBhcnNlTGlua3MiLCJ1cmwiLCJzbGljZSIsInJlbCIsImNsZWFuSGVhZGVyIiwiaGVhZGVyIiwiY2hhbmdlc09yaWdpbiIsImhvc3QiLCJhdXRob3JpemF0aW9uIiwiY29va2llIl0sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7O0FBUUFBLE9BQU8sQ0FBQ0MsSUFBUixHQUFlLFVBQUFDLEdBQUc7QUFBQSxTQUFJQSxHQUFHLENBQUNDLEtBQUosQ0FBVSxPQUFWLEVBQW1CQyxLQUFuQixFQUFKO0FBQUEsQ0FBbEI7QUFFQTs7Ozs7Ozs7O0FBUUFKLE9BQU8sQ0FBQ0ssTUFBUixHQUFpQixVQUFBSCxHQUFHO0FBQUEsU0FDbEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTU0sR0FBRyxHQUFHRCxLQUFLLENBQUNKLEtBQU4sRUFBWjtBQUNBLFFBQU1NLEdBQUcsR0FBR0YsS0FBSyxDQUFDSixLQUFOLEVBQVo7QUFFQSxRQUFJSyxHQUFHLElBQUlDLEdBQVgsRUFBZ0JILEdBQUcsQ0FBQ0UsR0FBRCxDQUFILEdBQVdDLEdBQVg7QUFDaEIsV0FBT0gsR0FBUDtBQUNELEdBUEQsRUFPRyxFQVBILENBRGtCO0FBQUEsQ0FBcEI7QUFVQTs7Ozs7Ozs7O0FBUUFQLE9BQU8sQ0FBQ1csVUFBUixHQUFxQixVQUFBVCxHQUFHO0FBQUEsU0FDdEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTVMsR0FBRyxHQUFHSixLQUFLLENBQUMsQ0FBRCxDQUFMLENBQVNLLEtBQVQsQ0FBZSxDQUFmLEVBQWtCLENBQUMsQ0FBbkIsQ0FBWjtBQUNBLFFBQU1DLEdBQUcsR0FBR04sS0FBSyxDQUFDLENBQUQsQ0FBTCxDQUFTTCxLQUFULENBQWUsT0FBZixFQUF3QixDQUF4QixFQUEyQlUsS0FBM0IsQ0FBaUMsQ0FBakMsRUFBb0MsQ0FBQyxDQUFyQyxDQUFaO0FBQ0FOLElBQUFBLEdBQUcsQ0FBQ08sR0FBRCxDQUFILEdBQVdGLEdBQVg7QUFDQSxXQUFPTCxHQUFQO0FBQ0QsR0FORCxFQU1HLEVBTkgsQ0FEc0I7QUFBQSxDQUF4QjtBQVNBOzs7Ozs7Ozs7QUFRQVAsT0FBTyxDQUFDZSxXQUFSLEdBQXNCLFVBQUNDLE1BQUQsRUFBU0MsYUFBVCxFQUEyQjtBQUMvQyxTQUFPRCxNQUFNLENBQUMsY0FBRCxDQUFiO0FBQ0EsU0FBT0EsTUFBTSxDQUFDLGdCQUFELENBQWI7QUFDQSxTQUFPQSxNQUFNLENBQUMsbUJBQUQsQ0FBYjtBQUNBLFNBQU9BLE1BQU0sQ0FBQ0UsSUFBZCxDQUorQyxDQUsvQzs7QUFDQSxNQUFJRCxhQUFKLEVBQW1CO0FBQ2pCLFdBQU9ELE1BQU0sQ0FBQ0csYUFBZDtBQUNBLFdBQU9ILE1BQU0sQ0FBQ0ksTUFBZDtBQUNEOztBQUVELFNBQU9KLE1BQVA7QUFDRCxDQVpEIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXR1cm4gdGhlIG1pbWUgdHlwZSBmb3IgdGhlIGdpdmVuIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMudHlwZSA9IHN0ciA9PiBzdHIuc3BsaXQoLyAqOyAqLykuc2hpZnQoKTtcblxuLyoqXG4gKiBSZXR1cm4gaGVhZGVyIGZpZWxkIHBhcmFtZXRlcnMuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHN0clxuICogQHJldHVybiB7T2JqZWN0fVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZXhwb3J0cy5wYXJhbXMgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKjsgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo9ICovKTtcbiAgICBjb25zdCBrZXkgPSBwYXJ0cy5zaGlmdCgpO1xuICAgIGNvbnN0IHZhbCA9IHBhcnRzLnNoaWZ0KCk7XG5cbiAgICBpZiAoa2V5ICYmIHZhbCkgb2JqW2tleV0gPSB2YWw7XG4gICAgcmV0dXJuIG9iajtcbiAgfSwge30pO1xuXG4vKipcbiAqIFBhcnNlIExpbmsgaGVhZGVyIGZpZWxkcy5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5leHBvcnRzLnBhcnNlTGlua3MgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKiwgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo7ICovKTtcbiAgICBjb25zdCB1cmwgPSBwYXJ0c1swXS5zbGljZSgxLCAtMSk7XG4gICAgY29uc3QgcmVsID0gcGFydHNbMV0uc3BsaXQoLyAqPSAqLylbMV0uc2xpY2UoMSwgLTEpO1xuICAgIG9ialtyZWxdID0gdXJsO1xuICAgIHJldHVybiBvYmo7XG4gIH0sIHt9KTtcblxuLyoqXG4gKiBTdHJpcCBjb250ZW50IHJlbGF0ZWQgZmllbGRzIGZyb20gYGhlYWRlcmAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IGhlYWRlclxuICogQHJldHVybiB7T2JqZWN0fSBoZWFkZXJcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMuY2xlYW5IZWFkZXIgPSAoaGVhZGVyLCBjaGFuZ2VzT3JpZ2luKSA9PiB7XG4gIGRlbGV0ZSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICBkZWxldGUgaGVhZGVyWydjb250ZW50LWxlbmd0aCddO1xuICBkZWxldGUgaGVhZGVyWyd0cmFuc2Zlci1lbmNvZGluZyddO1xuICBkZWxldGUgaGVhZGVyLmhvc3Q7XG4gIC8vIHNlY3VpcnR5XG4gIGlmIChjaGFuZ2VzT3JpZ2luKSB7XG4gICAgZGVsZXRlIGhlYWRlci5hdXRob3JpemF0aW9uO1xuICAgIGRlbGV0ZSBoZWFkZXIuY29va2llO1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcjtcbn07XG4iXX0=","\"use strict\";\n\n/**\n * Module dependencies.\n */\nvar utils = require('./utils');\n/**\n * Expose `ResponseBase`.\n */\n\n\nmodule.exports = ResponseBase;\n/**\n * Initialize a new `ResponseBase`.\n *\n * @api public\n */\n\nfunction ResponseBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in ResponseBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nResponseBase.prototype.get = function (field) {\n return this.header[field.toLowerCase()];\n};\n/**\n * Set header related properties:\n *\n * - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\n\nResponseBase.prototype._setHeaderProperties = function (header) {\n // TODO: moar!\n // TODO: make this a util\n // content-type\n var ct = header['content-type'] || '';\n this.type = utils.type(ct); // params\n\n var params = utils.params(ct);\n\n for (var key in params) {\n if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key];\n }\n\n this.links = {}; // links\n\n try {\n if (header.link) {\n this.links = utils.parseLinks(header.link);\n }\n } catch (_unused) {// ignore\n }\n};\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n * - .noContent\n * - .badRequest\n * - .unauthorized\n * - .notAcceptable\n * - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\n\nResponseBase.prototype._setStatusProperties = function (status) {\n var type = status / 100 | 0; // status / class\n\n this.statusCode = status;\n this.status = this.statusCode;\n this.statusType = type; // basics\n\n this.info = type === 1;\n this.ok = type === 2;\n this.redirect = type === 3;\n this.clientError = type === 4;\n this.serverError = type === 5;\n this.error = type === 4 || type === 5 ? this.toError() : false; // sugar\n\n this.created = status === 201;\n this.accepted = status === 202;\n this.noContent = status === 204;\n this.badRequest = status === 400;\n this.unauthorized = status === 401;\n this.notAcceptable = status === 406;\n this.forbidden = status === 403;\n this.notFound = status === 404;\n this.unprocessableEntity = status === 422;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS1iYXNlLmpzIl0sIm5hbWVzIjpbInV0aWxzIiwicmVxdWlyZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJSZXNwb25zZUJhc2UiLCJvYmoiLCJtaXhpbiIsImtleSIsInByb3RvdHlwZSIsIk9iamVjdCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImdldCIsImZpZWxkIiwiaGVhZGVyIiwidG9Mb3dlckNhc2UiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsImN0IiwidHlwZSIsInBhcmFtcyIsImxpbmtzIiwibGluayIsInBhcnNlTGlua3MiLCJfc2V0U3RhdHVzUHJvcGVydGllcyIsInN0YXR1cyIsInN0YXR1c0NvZGUiLCJzdGF0dXNUeXBlIiwiaW5mbyIsIm9rIiwicmVkaXJlY3QiLCJjbGllbnRFcnJvciIsInNlcnZlckVycm9yIiwiZXJyb3IiLCJ0b0Vycm9yIiwiY3JlYXRlZCIsImFjY2VwdGVkIiwibm9Db250ZW50IiwiYmFkUmVxdWVzdCIsInVuYXV0aG9yaXplZCIsIm5vdEFjY2VwdGFibGUiLCJmb3JiaWRkZW4iLCJub3RGb3VuZCIsInVucHJvY2Vzc2FibGVFbnRpdHkiXSwibWFwcGluZ3MiOiI7O0FBQUE7OztBQUlBLElBQU1BLEtBQUssR0FBR0MsT0FBTyxDQUFDLFNBQUQsQ0FBckI7QUFFQTs7Ozs7QUFJQUMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCQyxZQUFqQjtBQUVBOzs7Ozs7QUFNQSxTQUFTQSxZQUFULENBQXNCQyxHQUF0QixFQUEyQjtBQUN6QixNQUFJQSxHQUFKLEVBQVMsT0FBT0MsS0FBSyxDQUFDRCxHQUFELENBQVo7QUFDVjtBQUVEOzs7Ozs7Ozs7QUFRQSxTQUFTQyxLQUFULENBQWVELEdBQWYsRUFBb0I7QUFDbEIsT0FBSyxJQUFNRSxHQUFYLElBQWtCSCxZQUFZLENBQUNJLFNBQS9CLEVBQTBDO0FBQ3hDLFFBQUlDLE1BQU0sQ0FBQ0QsU0FBUCxDQUFpQkUsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFD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LEdBQTJCbEIsTUFBTSxLQUFLLEdBQXRDO0FBQ0QsQ0ExQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1vZHVsZSBkZXBlbmRlbmNpZXMuXG4gKi9cblxuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzJyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXNwb25zZUJhc2VgLlxuICovXG5cbm1vZHVsZS5leHBvcnRzID0gUmVzcG9uc2VCYXNlO1xuXG4vKipcbiAqIEluaXRpYWxpemUgYSBuZXcgYFJlc3BvbnNlQmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXNwb25zZUJhc2Uob2JqKSB7XG4gIGlmIChvYmopIHJldHVybiBtaXhpbihvYmopO1xufVxuXG4vKipcbiAqIE1peGluIHRoZSBwcm90b3R5cGUgcHJvcGVydGllcy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBtaXhpbihvYmopIHtcbiAgZm9yIChjb25zdCBrZXkgaW4gUmVzcG9uc2VCYXNlLnByb3RvdHlwZSkge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoUmVzcG9uc2VCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVzcG9uc2VCYXNlLnByb3RvdHlwZVtrZXldO1xuICB9XG5cbiAgcmV0dXJuIG9iajtcbn1cblxuLyoqXG4gKiBHZXQgY2FzZS1pbnNlbnNpdGl2ZSBgZmllbGRgIHZhbHVlLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLmhlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXTtcbn07XG5cbi8qKlxuICogU2V0IGhlYWRlciByZWxhdGVkIHByb3BlcnRpZXM6XG4gKlxuICogICAtIGAudHlwZWAgdGhlIGNvbnRlbnQgdHlwZSB3aXRob3V0IHBhcmFtc1xuICpcbiAqIEEgcmVzcG9uc2Ugb2YgXCJDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9dXRmLThcIlxuICogd2lsbCBwcm92aWRlIHlvdSB3aXRoIGEgYC50eXBlYCBvZiBcInRleHQvcGxhaW5cIi5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gaGVhZGVyXG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLl9zZXRIZWFkZXJQcm9wZXJ0aWVzID0gZnVuY3Rpb24oaGVhZGVyKSB7XG4gIC8vIFRPRE86IG1vYXIhXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIHV0aWxcblxuICAvLyBjb250ZW50LXR5cGVcbiAgY29uc3QgY3QgPSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddIHx8ICcnO1xuICB0aGlzLnR5cGUgPSB1dGlscy50eXBlKGN0KTtcblxuICAvLyBwYXJhbXNcbiAgY29uc3QgcGFyYW1zID0gdXRpbHMucGFyYW1zKGN0KTtcbiAgZm9yIChjb25zdCBrZXkgaW4gcGFyYW1zKSB7XG4gICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChwYXJhbXMsIGtleSkpXG4gICAgICB0aGlzW2tleV0gPSBwYXJhbXNba2V5XTtcbiAgfVxuXG4gIHRoaXMubGlua3MgPSB7fTtcblxuICAvLyBsaW5rc1xuICB0cnkge1xuICAgIGlmIChoZWFkZXIubGluaykge1xuICAgICAgdGhpcy5saW5rcyA9IHV0aWxzLnBhcnNlTGlua3MoaGVhZGVyLmxpbmspO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlXG4gIH1cbn07XG5cbi8qKlxuICogU2V0IGZsYWdzIHN1Y2ggYXMgYC5va2AgYmFzZWQgb24gYHN0YXR1c2AuXG4gKlxuICogRm9yIGV4YW1wbGUgYSAyeHggcmVzcG9uc2Ugd2lsbCBnaXZlIHlvdSBhIGAub2tgIG9mIF9fdHJ1ZV9fXG4gKiB3aGVyZWFzIDV4eCB3aWxsIGJlIF9fZmFsc2VfXyBhbmQgYC5lcnJvcmAgd2lsbCBiZSBfX3RydWVfXy4gVGhlXG4gKiBgLmNsaWVudEVycm9yYCBhbmQgYC5zZXJ2ZXJFcnJvcmAgYXJlIGFsc28gYXZhaWxhYmxlIHRvIGJlIG1vcmVcbiAqIHNwZWNpZmljLCBhbmQgYC5zdGF0dXNUeXBlYCBpcyB0aGUgY2xhc3Mgb2YgZXJyb3IgcmFuZ2luZyBmcm9tIDEuLjVcbiAqIHNvbWV0aW1lcyB1c2VmdWwgZm9yIG1hcHBpbmcgcmVzcG9uZCBjb2xvcnMgZXRjLlxuICpcbiAqIFwic3VnYXJcIiBwcm9wZXJ0aWVzIGFyZSBhbHNvIGRlZmluZWQgZm9yIGNvbW1vbiBjYXNlcy4gQ3VycmVudGx5IHByb3ZpZGluZzpcbiAqXG4gKiAgIC0gLm5vQ29udGVudFxuICogICAtIC5iYWRSZXF1ZXN0XG4gKiAgIC0gLnVuYXV0aG9yaXplZFxuICogICAtIC5ub3RBY2NlcHRhYmxlXG4gKiAgIC0gLm5vdEZvdW5kXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IHN0YXR1c1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVzcG9uc2VCYXNlLnByb3RvdHlwZS5fc2V0U3RhdHVzUHJvcGVydGllcyA9IGZ1bmN0aW9uKHN0YXR1cykge1xuICBjb25zdCB0eXBlID0gKHN0YXR1cyAvIDEwMCkgfCAwO1xuXG4gIC8vIHN0YXR1cyAvIGNsYXNzXG4gIHRoaXMuc3RhdHVzQ29kZSA9IHN0YXR1cztcbiAgdGhpcy5zdGF0dXMgPSB0aGlzLnN0YXR1c0NvZGU7XG4gIHRoaXMuc3RhdHVzVHlwZSA9IHR5cGU7XG5cbiAgLy8gYmFzaWNzXG4gIHRoaXMuaW5mbyA9IHR5cGUgPT09IDE7XG4gIHRoaXMub2sgPSB0eXBlID09PSAyO1xuICB0aGlzLnJlZGlyZWN0ID0gdHlwZSA9PT0gMztcbiAgdGhpcy5jbGllbnRFcnJvciA9IHR5cGUgPT09IDQ7XG4gIHRoaXMuc2VydmVyRXJyb3IgPSB0eXBlID09PSA1O1xuICB0aGlzLmVycm9yID0gdHlwZSA9PT0gNCB8fCB0eXBlID09PSA1ID8gdGhpcy50b0Vycm9yKCkgOiBmYWxzZTtcblxuICAvLyBzdWdhclxuICB0aGlzLmNyZWF0ZWQgPSBzdGF0dXMgPT09IDIwMTtcbiAgdGhpcy5hY2NlcHRlZCA9IHN0YXR1cyA9PT0gMjAyO1xuICB0aGlzLm5vQ29udGVudCA9IHN0YXR1cyA9PT0gMjA0O1xuICB0aGlzLmJhZFJlcXVlc3QgPSBzdGF0dXMgPT09IDQwMDtcbiAgdGhpcy51bmF1dGhvcml6ZWQgPSBzdGF0dXMgPT09IDQwMTtcbiAgdGhpcy5ub3RBY2NlcHRhYmxlID0gc3RhdHVzID09PSA0MDY7XG4gIHRoaXMuZm9yYmlkZGVuID0gc3RhdHVzID09PSA0MDM7XG4gIHRoaXMubm90Rm91bmQgPSBzdGF0dXMgPT09IDQwNDtcbiAgdGhpcy51bnByb2Nlc3NhYmxlRW50aXR5ID0gc3RhdHVzID09PSA0MjI7XG59O1xuIl19","\"use strict\";\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction Agent() {\n this._defaults = [];\n}\n\n['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) {\n // Default setting for all requests from this agent\n Agent.prototype[fn] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this._defaults.push({\n fn: fn,\n args: args\n });\n\n return this;\n };\n});\n\nAgent.prototype._setDefaults = function (req) {\n this._defaults.forEach(function (def) {\n req[def.fn].apply(req, _toConsumableArray(def.args));\n });\n};\n\nmodule.exports = Agent;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hZ2VudC1iYXNlLmpzIl0sIm5hbWVzIjpbIkFnZW50IiwiX2RlZmF1bHRzIiwiZm9yRWFjaCIsImZuIiwicHJvdG90eXBlIiwiYXJncyIsInB1c2giLCJfc2V0RGVmYXVsdHMiLCJyZXEiLCJkZWYiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7OztBQUFBLFNBQVNBLEtBQVQsR0FBaUI7QUFDZixPQUFLQyxTQUFMLEdBQWlCLEVBQWpCO0FBQ0Q7O0FBRUQsQ0FDRSxLQURGLEVBRUUsSUFGRixFQUdFLE1BSEYsRUFJRSxLQUpGLEVBS0UsT0FMRixFQU1FLE1BTkYsRUFPRSxRQVBGLEVBUUUsTUFSRixFQVNFLGlCQVRGLEVBVUUsV0FWRixFQVdFLE9BWEYsRUFZRSxJQVpGLEVBYUUsV0FiRixFQWNFLFNBZEYsRUFlRSxRQWZGLEVBZ0JFLFdBaEJGLEVBaUJFLE9BakJGLEVBa0JFLElBbEJGLEVBbUJFLEtBbkJGLEVBb0JFLEtBcEJGLEVBcUJFLE1BckJGLEVBc0JFLGlCQXRCRixFQXVCRUMsT0F2QkYsQ0F1QlUsVUFBQUMsRUFBRSxFQUFJO0FBQ2Q7QUFDQUgsRUFBQUEsS0FBSyxDQUFDSSxTQUFOLENBQWdCRCxFQUFoQixJQUFzQixZQUFrQjtBQUFBLHNDQUFORSxJQUFNO0FBQU5BLE1BQUFBLElBQU07QUFBQTs7QUFDdEMsU0FBS0osU0FBTCxDQUFlSyxJQUFmLENBQW9CO0FBQUVILE1BQUFBLEVBQUUsRUFBRkEsRUFBRjtBQUFNRSxNQUFBQSxJQUFJLEVBQUpBO0FBQU4sS0FBcEI7O0FBQ0EsV0FBTyxJQUFQO0FBQ0QsR0FIRDtBQUlELENBN0JEOztBQStCQUwsS0FBSyxDQUFDSSxTQUFOLENBQWdCRyxZQUFoQixHQUErQixVQUFTQyxHQUFULEVBQWM7QUFDM0MsT0FBS1AsU0FBTCxDQUFlQyxPQUFmLENBQXVCLFVBQUFPLEdBQUcsRUFBSTtBQUM1QkQsSUFBQUEsR0FBRyxDQUFDQyxHQUFHLENBQUNOLEVBQUwsQ0FBSCxPQUFBSyxHQUFHLHFCQUFZQyxHQUFHLENBQUNKLElBQWhCLEVBQUg7QUFDRCxHQUZEO0FBR0QsQ0FKRDs7QUFNQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxLQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIEFnZW50KCkge1xuICB0aGlzLl9kZWZhdWx0cyA9IFtdO1xufVxuXG5bXG4gICd1c2UnLFxuICAnb24nLFxuICAnb25jZScsXG4gICdzZXQnLFxuICAncXVlcnknLFxuICAndHlwZScsXG4gICdhY2NlcHQnLFxuICAnYXV0aCcsXG4gICd3aXRoQ3JlZGVudGlhbHMnLFxuICAnc29ydFF1ZXJ5JyxcbiAgJ3JldHJ5JyxcbiAgJ29rJyxcbiAgJ3JlZGlyZWN0cycsXG4gICd0aW1lb3V0JyxcbiAgJ2J1ZmZlcicsXG4gICdzZXJpYWxpemUnLFxuICAncGFyc2UnLFxuICAnY2EnLFxuICAna2V5JyxcbiAgJ3BmeCcsXG4gICdjZXJ0JyxcbiAgJ2Rpc2FibGVUTFNDZXJ0cydcbl0uZm9yRWFjaChmbiA9PiB7XG4gIC8vIERlZmF1bHQgc2V0dGluZyBmb3IgYWxsIHJlcXVlc3RzIGZyb20gdGhpcyBhZ2VudFxuICBBZ2VudC5wcm90b3R5cGVbZm5dID0gZnVuY3Rpb24oLi4uYXJncykge1xuICAgIHRoaXMuX2RlZmF1bHRzLnB1c2goeyBmbiwgYXJncyB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbn0pO1xuXG5BZ2VudC5wcm90b3R5cGUuX3NldERlZmF1bHRzID0gZnVuY3Rpb24ocmVxKSB7XG4gIHRoaXMuX2RlZmF1bHRzLmZvckVhY2goZGVmID0+IHtcbiAgICByZXFbZGVmLmZuXSguLi5kZWYuYXJncyk7XG4gIH0pO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSBBZ2VudDtcbiJdfQ==","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Root reference for iframes.\n */\nvar root;\n\nif (typeof window !== 'undefined') {\n // Browser window\n root = window;\n} else if (typeof self === 'undefined') {\n // Other environments\n console.warn('Using browser-only version of superagent in non-browser environment');\n root = void 0;\n} else {\n // Web Worker\n root = self;\n}\n\nvar Emitter = require('component-emitter');\n\nvar safeStringify = require('fast-safe-stringify');\n\nvar RequestBase = require('./request-base');\n\nvar isObject = require('./is-object');\n\nvar ResponseBase = require('./response-base');\n\nvar Agent = require('./agent-base');\n/**\n * Noop.\n */\n\n\nfunction noop() {}\n/**\n * Expose `request`.\n */\n\n\nmodule.exports = function (method, url) {\n // callback\n if (typeof url === 'function') {\n return new exports.Request('GET', method).end(url);\n } // url first\n\n\n if (arguments.length === 1) {\n return new exports.Request('GET', method);\n }\n\n return new exports.Request(method, url);\n};\n\nexports = module.exports;\nvar request = exports;\nexports.Request = Request;\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) {\n return new XMLHttpRequest();\n }\n\n try {\n return new ActiveXObject('Microsoft.XMLHTTP');\n } catch (_unused) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.6.0');\n } catch (_unused2) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.3.0');\n } catch (_unused3) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP');\n } catch (_unused4) {}\n\n throw new Error('Browser-only version of superagent could not find XHR');\n};\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\n\nvar trim = ''.trim ? function (s) {\n return s.trim();\n} : function (s) {\n return s.replace(/(^\\s*|\\s*$)/g, '');\n};\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n if (!isObject(obj)) return obj;\n var pairs = [];\n\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]);\n }\n\n return pairs.join('&');\n}\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n if (val === undefined) return;\n\n if (val === null) {\n pairs.push(encodeURI(key));\n return;\n }\n\n if (Array.isArray(val)) {\n val.forEach(function (v) {\n pushEncodedKeyValuePair(pairs, key, v);\n });\n } else if (isObject(val)) {\n for (var subkey in val) {\n if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, \"\".concat(key, \"[\").concat(subkey, \"]\"), val[subkey]);\n }\n } else {\n pairs.push(encodeURI(key) + '=' + encodeURIComponent(val));\n }\n}\n/**\n * Expose serialization method.\n */\n\n\nrequest.serializeObject = serialize;\n/**\n * Parse the given x-www-form-urlencoded `str`.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseString(str) {\n var obj = {};\n var pairs = str.split('&');\n var pair;\n var pos;\n\n for (var i = 0, len = pairs.length; i < len; ++i) {\n pair = pairs[i];\n pos = pair.indexOf('=');\n\n if (pos === -1) {\n obj[decodeURIComponent(pair)] = '';\n } else {\n obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1));\n }\n }\n\n return obj;\n}\n/**\n * Expose parser.\n */\n\n\nrequest.parseString = parseString;\n/**\n * Default MIME type map.\n *\n * superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n html: 'text/html',\n json: 'application/json',\n xml: 'text/xml',\n urlencoded: 'application/x-www-form-urlencoded',\n form: 'application/x-www-form-urlencoded',\n 'form-data': 'application/x-www-form-urlencoded'\n};\n/**\n * Default serialization map.\n *\n * superagent.serialize['application/xml'] = function(obj){\n * return 'generated xml here';\n * };\n *\n */\n\nrequest.serialize = {\n 'application/x-www-form-urlencoded': serialize,\n 'application/json': safeStringify\n};\n/**\n * Default parsers.\n *\n * superagent.parse['application/xml'] = function(str){\n * return { object parsed from str };\n * };\n *\n */\n\nrequest.parse = {\n 'application/x-www-form-urlencoded': parseString,\n 'application/json': JSON.parse\n};\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n var lines = str.split(/\\r?\\n/);\n var fields = {};\n var index;\n var line;\n var field;\n var val;\n\n for (var i = 0, len = lines.length; i < len; ++i) {\n line = lines[i];\n index = line.indexOf(':');\n\n if (index === -1) {\n // could be empty line, just skip it\n continue;\n }\n\n field = line.slice(0, index).toLowerCase();\n val = trim(line.slice(index + 1));\n fields[field] = val;\n }\n\n return fields;\n}\n/**\n * Check if `mime` is json or has +json structured syntax suffix.\n *\n * @param {String} mime\n * @return {Boolean}\n * @api private\n */\n\n\nfunction isJSON(mime) {\n // should match /json or +json\n // but not /json-seq\n return /[/+]json($|[^-\\w])/.test(mime);\n}\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n * - set flags (.ok, .error, etc)\n * - parse header\n *\n * Examples:\n *\n * Aliasing `superagent` as `request` is nice:\n *\n * request = superagent;\n *\n * We can use the promise-like API, or pass callbacks:\n *\n * request.get('/').end(function(res){});\n * request.get('/', function(res){});\n *\n * Sending data can be chained:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' })\n * .end(function(res){});\n *\n * Or passed to `.send()`:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' }, function(res){});\n *\n * Or passed to `.post()`:\n *\n * request\n * .post('/user', { name: 'tj' })\n * .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n * request\n * .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\n\nfunction Response(req) {\n this.req = req;\n this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers\n\n this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null;\n this.statusText = this.req.xhr.statusText;\n var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n\n if (status === 1223) {\n status = 204;\n }\n\n this._setStatusProperties(status);\n\n this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n this.header = this.headers; // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n // getResponseHeader still works. so we get content-type even if getting\n // other headers fails.\n\n this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n\n this._setHeaderProperties(this.header);\n\n if (this.text === null && req._responseType) {\n this.body = this.xhr.response;\n } else {\n this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response);\n }\n} // eslint-disable-next-line new-cap\n\n\nResponseBase(Response.prototype);\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype._parseBody = function (str) {\n var parse = request.parse[this.type];\n\n if (this.req._parser) {\n return this.req._parser(this, str);\n }\n\n if (!parse && isJSON(this.type)) {\n parse = request.parse['application/json'];\n }\n\n return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null;\n};\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\n\nResponse.prototype.toError = function () {\n var req = this.req;\n var method = req.method;\n var url = req.url;\n var msg = \"cannot \".concat(method, \" \").concat(url, \" (\").concat(this.status, \")\");\n var err = new Error(msg);\n err.status = this.status;\n err.method = method;\n err.url = url;\n return err;\n};\n/**\n * Expose `Response`.\n */\n\n\nrequest.Response = Response;\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n var self = this;\n this._query = this._query || [];\n this.method = method;\n this.url = url;\n this.header = {}; // preserves header name case\n\n this._header = {}; // coerces header names to lowercase\n\n this.on('end', function () {\n var err = null;\n var res = null;\n\n try {\n res = new Response(self);\n } catch (err_) {\n err = new Error('Parser is unable to parse the response');\n err.parse = true;\n err.original = err_; // issue #675: return the raw response if the response parsing fails\n\n if (self.xhr) {\n // ie9 doesn't have 'response' property\n err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails\n\n err.status = self.xhr.status ? self.xhr.status : null;\n err.statusCode = err.status; // backwards-compat only\n } else {\n err.rawResponse = null;\n err.status = null;\n }\n\n return self.callback(err);\n }\n\n self.emit('response', res);\n var new_err;\n\n try {\n if (!self._isResponseOK(res)) {\n new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response');\n }\n } catch (err_) {\n new_err = err_; // ok() callback can throw\n } // #1000 don't catch errors from the callback to avoid double calling it\n\n\n if (new_err) {\n new_err.original = err;\n new_err.response = res;\n new_err.status = res.status;\n self.callback(new_err, res);\n } else {\n self.callback(null, res);\n }\n });\n}\n/**\n * Mixin `Emitter` and `RequestBase`.\n */\n// eslint-disable-next-line new-cap\n\n\nEmitter(Request.prototype); // eslint-disable-next-line new-cap\n\nRequestBase(Request.prototype);\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.xml = 'application/xml';\n *\n * request.post('/')\n * .type('xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * request.post('/')\n * .type('application/xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function (type) {\n this.set('Content-Type', request.types[type] || type);\n return this;\n};\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.json = 'application/json';\n *\n * request.get('/agent')\n * .accept('json')\n * .end(callback);\n *\n * request.get('/agent')\n * .accept('application/json')\n * .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.accept = function (type) {\n this.set('Accept', request.types[type] || type);\n return this;\n};\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} [pass] optional in case of using 'bearer' as type\n * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic')\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.auth = function (user, pass, options) {\n if (arguments.length === 1) pass = '';\n\n if (_typeof(pass) === 'object' && pass !== null) {\n // pass is optional and can be replaced with options\n options = pass;\n pass = '';\n }\n\n if (!options) {\n options = {\n type: typeof btoa === 'function' ? 'basic' : 'auto'\n };\n }\n\n var encoder = function encoder(string) {\n if (typeof btoa === 'function') {\n return btoa(string);\n }\n\n throw new Error('Cannot use basic auth, btoa is not a function');\n };\n\n return this._auth(user, pass, options, encoder);\n};\n/**\n * Add query-string `val`.\n *\n * Examples:\n *\n * request.get('/shoes')\n * .query('size=10')\n * .query({ color: 'blue' })\n *\n * @param {Object|String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.query = function (val) {\n if (typeof val !== 'string') val = serialize(val);\n if (val) this._query.push(val);\n return this;\n};\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `options` (or filename).\n *\n * ``` js\n * request.post('/upload')\n * .attach('content', new Blob(['hey!'], { type: \"text/html\"}))\n * .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String|Object} options\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.attach = function (field, file, options) {\n if (file) {\n if (this._data) {\n throw new Error(\"superagent can't mix .send() and .attach()\");\n }\n\n this._getFormData().append(field, file, options || file.name);\n }\n\n return this;\n};\n\nRequest.prototype._getFormData = function () {\n if (!this._formData) {\n this._formData = new root.FormData();\n }\n\n return this._formData;\n};\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\n\nRequest.prototype.callback = function (err, res) {\n if (this._shouldRetry(err, res)) {\n return this._retry();\n }\n\n var fn = this._callback;\n this.clearTimeout();\n\n if (err) {\n if (this._maxRetries) err.retries = this._retries - 1;\n this.emit('error', err);\n }\n\n fn(err, res);\n};\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\n\nRequest.prototype.crossDomainError = function () {\n var err = new Error('Request has been terminated\\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.');\n err.crossDomain = true;\n err.status = this.status;\n err.method = this.method;\n err.url = this.url;\n this.callback(err);\n}; // This only warns, because the request is still likely to work\n\n\nRequest.prototype.agent = function () {\n console.warn('This is not supported in browser version of superagent');\n return this;\n};\n\nRequest.prototype.ca = Request.prototype.agent;\nRequest.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected\n\nRequest.prototype.write = function () {\n throw new Error('Streaming is not supported in browser version of superagent');\n};\n\nRequest.prototype.pipe = Request.prototype.write;\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * @param {Object} obj host object\n * @return {Boolean} is a host object\n * @api private\n */\n\nRequest.prototype._isHost = function (obj) {\n // Native objects stringify to [object File], [object Blob], [object FormData], etc.\n return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]';\n};\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.end = function (fn) {\n if (this._endCalled) {\n console.warn('Warning: .end() was called twice. This is not supported in superagent');\n }\n\n this._endCalled = true; // store callback\n\n this._callback = fn || noop; // querystring\n\n this._finalizeQueryString();\n\n this._end();\n};\n\nRequest.prototype._setUploadTimeout = function () {\n var self = this; // upload timeout it's wokrs only if deadline timeout is off\n\n if (this._uploadTimeout && !this._uploadTimeoutTimer) {\n this._uploadTimeoutTimer = setTimeout(function () {\n self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT');\n }, this._uploadTimeout);\n }\n}; // eslint-disable-next-line complexity\n\n\nRequest.prototype._end = function () {\n if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called'));\n var self = this;\n this.xhr = request.getXHR();\n var xhr = this.xhr;\n var data = this._formData || this._data;\n\n this._setTimeouts(); // state change\n\n\n xhr.onreadystatechange = function () {\n var readyState = xhr.readyState;\n\n if (readyState >= 2 && self._responseTimeoutTimer) {\n clearTimeout(self._responseTimeoutTimer);\n }\n\n if (readyState !== 4) {\n return;\n } // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n // result in the error \"Could not complete the operation due to error c00c023f\"\n\n\n var status;\n\n try {\n status = xhr.status;\n } catch (_unused5) {\n status = 0;\n }\n\n if (!status) {\n if (self.timedout || self._aborted) return;\n return self.crossDomainError();\n }\n\n self.emit('end');\n }; // progress\n\n\n var handleProgress = function handleProgress(direction, e) {\n if (e.total > 0) {\n e.percent = e.loaded / e.total * 100;\n\n if (e.percent === 100) {\n clearTimeout(self._uploadTimeoutTimer);\n }\n }\n\n e.direction = direction;\n self.emit('progress', e);\n };\n\n if (this.hasListeners('progress')) {\n try {\n xhr.addEventListener('progress', handleProgress.bind(null, 'download'));\n\n if (xhr.upload) {\n xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload'));\n }\n } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n // Reported here:\n // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n }\n }\n\n if (xhr.upload) {\n this._setUploadTimeout();\n } // initiate request\n\n\n try {\n if (this.username && this.password) {\n xhr.open(this.method, this.url, true, this.username, this.password);\n } else {\n xhr.open(this.method, this.url, true);\n }\n } catch (err) {\n // see #1149\n return this.callback(err);\n } // CORS\n\n\n if (this._withCredentials) xhr.withCredentials = true; // body\n\n if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) {\n // serialize stuff\n var contentType = this._header['content-type'];\n\n var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : ''];\n\n if (!_serialize && isJSON(contentType)) {\n _serialize = request.serialize['application/json'];\n }\n\n if (_serialize) data = _serialize(data);\n } // set header fields\n\n\n for (var field in this.header) {\n if (this.header[field] === null) continue;\n if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]);\n }\n\n if (this._responseType) {\n xhr.responseType = this._responseType;\n } // send stuff\n\n\n this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n // We need null here if data is undefined\n\n xhr.send(typeof data === 'undefined' ? null : data);\n};\n\nrequest.agent = function () {\n return new Agent();\n};\n\n['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) {\n Agent.prototype[method.toLowerCase()] = function (url, fn) {\n var req = new request.Request(method, url);\n\n this._setDefaults(req);\n\n if (fn) {\n req.end(fn);\n }\n\n return req;\n };\n});\nAgent.prototype.del = Agent.prototype.delete;\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.get = function (url, data, fn) {\n var req = request('GET', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.head = function (url, data, fn) {\n var req = request('HEAD', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * OPTIONS query to `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.options = function (url, data, fn) {\n var req = request('OPTIONS', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * DELETE `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nfunction del(url, data, fn) {\n var req = request('DELETE', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n}\n\nrequest.del = del;\nrequest.delete = del;\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function (url, data, fn) {\n var req = request('PATCH', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.post = function (url, data, fn) {\n var req = request('POST', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.put = function (url, data, fn) {\n var req = request('PUT', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jbGllbnQuanMiXSwibmFtZXMiOlsicm9vdCIsIndpbmRvdyIsInNlbGYiLCJjb25zb2xlIiwid2FybiIsIkVtaXR0ZXIiLCJyZXF1aXJlIiwic2FmZVN0cmluZ2lmeSIsIlJlcXVlc3RCYXNlIiwiaXNPYmplY3QiLCJSZXNwb25zZUJhc2UiLCJBZ2VudCIsIm5vb3AiLCJtb2R1bGUiLCJleHBvcnRzIiwibWV0aG9kIiwidXJsIiwiUmVxdWVzdCIsImVuZCIsImFyZ3VtZW50cyIsImxlbmd0aCIsInJlcXVlc3QiLCJnZXRYSFIiLCJYTUxIdHRwUmVxdWVzdCIsImxvY2F0aW9uIiwicHJvdG9jb2wiLCJBY3RpdmVYT2JqZWN0IiwiRXJyb3IiLCJ0cmltIiwicyIsInJlcGxhY2UiLCJzZXJpYWxpemUiLCJvYmoiLCJwYWlycyIsImtleSIsIk9iamVjdCIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsInB1c2hFbmNvZGVkS2V5VmFsdWVQYWlyIiwiam9pbiIsInZhbCIsInVuZGVmaW5lZCIsInB1c2giLCJlbmNvZGVVUkkiLCJBcnJheSIsImlzQXJyYXkiLCJmb3JFYWNoIiwidiIsInN1YmtleSIsImVuY29kZVVSSUNvbXBvbmVudCIsInNlcmlhbGl6ZU9iamVjdCIsInBhcnNlU3RyaW5nIiwic3RyIiwic3BsaXQiLCJwYWlyIiwicG9zIiwiaSIsImxlbiIsImluZGV4T2YiLCJkZWNvZGVVUklDb21wb25lbnQiLCJzbGljZSIsInR5cGVzIiwiaHRtbCIsImpzb24iLCJ4bWwiLCJ1cmxlbmNvZGVkIiwiZm9ybSIsInBhcnNlIiwiSlNPTiIsInBhcnNlSGVhZGVyIiwibGluZXMiLCJmaWVsZHMiLCJpbmRleCIsImxpbmUiLCJmaWVsZCIsInRvTG93ZXJDYXNlIiwiaXNKU09OIiwibWltZSIsInRlc3QiLCJSZXNwb25zZSIsInJlcSIsInhociIsInRleHQiLCJyZXNwb25zZVR5cGUiLCJyZXNwb25zZVRleHQiLCJzdGF0dXNUZXh0Iiwic3RhdHVzIiwiX3NldFN0YXR1c1Byb3BlcnRpZXMiLCJoZWFkZXJzIiwiZ2V0QWxsUmVzcG9uc2VIZWFkZXJzIiwiaGVhZGVyIiwiZ2V0UmVzcG9uc2VIZWFkZXIiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsIl9yZXNwb25zZVR5cGUiLCJib2R5IiwicmVzcG9uc2UiLCJfcGFyc2VCb2R5IiwidHlwZSIsIl9wYXJzZXIiLCJ0b0Vycm9yIiwibXNnIiwiZXJyIiwiX3F1ZXJ5IiwiX2hlYWRlciIsIm9uIiwicmVzIiwiZXJyXyIsIm9yaWdpbmFsIiwicmF3UmVzcG9uc2UiLCJzdGF0dXNDb2RlIiwiY2FsbGJhY2siLCJlbWl0IiwibmV3X2VyciIsIl9pc1Jlc3BvbnNlT0siLCJzZXQiLCJhY2NlcHQiLCJhdXRoIiwidXNlciIsInBhc3MiLCJvcHRpb25zIiwiYnRvYSIsImVuY29kZXIiLCJzdHJpbmciLCJfYXV0aCIsInF1ZXJ5IiwiYXR0YWNoIiwiZmlsZSIsIl9kYXRhIiwiX2dldEZvcm1EYXRhIiwiYXBwZW5kIiwibmFtZSIsIl9mb3JtRGF0YSIsIkZvcm1EYXRhIiwiX3Nob3VsZFJldHJ5IiwiX3JldHJ5IiwiZm4iLCJfY2FsbGJhY2siLCJjbGVhclRpbWVvdXQiLCJfbWF4UmV0cmllcyIsInJldHJpZXMiLCJfcmV0cmllcyIsImNyb3NzRG9tYWluRXJyb3IiLCJjcm9zc0RvbWFpbiIsImFnZW50IiwiY2EiLCJidWZmZXIiLCJ3cml0ZSIsInBpcGUiLCJfaXNIb3N0IiwidG9TdHJpbmciLCJfZW5kQ2FsbGVkIiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJfZW5kIiwiX3NldFVwbG9hZFRpbWVvdXQiLCJfdXBsb2FkVGltZW91dCIsIl91cGxvYWRUaW1lb3V0VGltZXIiLCJzZXRUaW1lb3V0IiwiX3RpbWVvdXRFcnJvciIsIl9hYm9ydGVkIiwiZGF0YSIsIl9zZXRUaW1lb3V0cyIsIm9ucmVhZHlzdGF0ZWNoYW5nZSIsInJlYWR5U3RhdGUiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJ0aW1lZG91dCIsImhhbmRsZVByb2dyZXNzIiwiZGlyZWN0aW9uIiwiZSIsInRvdGFsIiwicGVyY2VudCIsImxvYWRlZCIsImhhc0xpc3RlbmVycyIsImFkZEV2ZW50TGlzdGVuZXIiLCJiaW5kIiwidXBsb2FkIiwidXNlcm5hbWUiLCJwYXNzd29yZCIsIm9wZW4iLCJfd2l0aENyZWRlbnRpYWxzIiwid2l0aENyZWRlbnRpYWxzIiwiY29udGVudFR5cGUiLCJfc2VyaWFsaXplciIsInNldFJlcXVlc3RIZWFkZXIiLCJzZW5kIiwiX3NldERlZmF1bHRzIiwiZGVsIiwiZGVsZXRlIiwiZ2V0IiwiaGVhZCIsInBhdGNoIiwicG9zdCIsInB1dCJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7QUFJQSxJQUFJQSxJQUFKOztBQUNBLElBQUksT0FBT0MsTUFBUCxLQUFrQixXQUF0QixFQUFtQztBQUNqQztBQUNBRCxFQUFBQSxJQUFJLEdBQUdDLE1BQVA7QUFDRCxDQUhELE1BR08sSUFBSSxPQUFPQyxJQUFQLEtBQWdCLFdBQXBCLEVBQWlDO0FBQ3RDO0FBQ0FDLEVBQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUNFLHFFQURGO0FBR0FKLEVBQUFBLElBQUksU0FBSjtBQUNELENBTk0sTUFNQTtBQUNMO0FBQ0FBLEVBQUFBLElBQUksR0FBR0UsSUFBUDtBQUNEOztBQUVELElBQU1HLE9BQU8sR0FBR0MsT0FBTyxDQUFDLG1CQUFELENBQXZCOztBQUNBLElBQU1DLGFBQWEsR0FBR0QsT0FBTyxDQUFDLHFCQUFELENBQTdCOztBQUNBLElBQU1FLFdBQVcsR0FBR0YsT0FBTyxDQUFDLGdCQUFELENBQTNCOztBQUNBLElBQU1HLFFBQVEsR0FBR0gsT0FBTyxDQUFDLGFBQUQsQ0FBeEI7O0FBQ0EsSUFBTUksWUFBWSxHQUFHSixPQUFPLENBQUMsaUJBQUQsQ0FBNUI7O0FBQ0EsSUFBTUssS0FBSyxHQUFHTCxPQUFPLENBQUMsY0FBRCxDQUFyQjtBQUVBOzs7OztBQUlBLFNBQVNNLElBQVQsR0FBZ0IsQ0FBRTtBQUVsQjs7Ozs7QUFJ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cmVuY2UgZm9yIGlmcmFtZXMuXG4gKi9cblxubGV0IHJvb3Q7XG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgLy8gQnJvd3NlciB3aW5kb3dcbiAgcm9vdCA9IHdpbmRvdztcbn0gZWxzZSBpZiAodHlwZW9mIHNlbGYgPT09ICd1bmRlZmluZWQnKSB7XG4gIC8vIE90aGVyIGVudmlyb25tZW50c1xuICBjb25zb2xlLndhcm4oXG4gICAgJ1VzaW5nIGJyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgaW4gbm9uLWJyb3dzZXIgZW52aXJvbm1lbnQnXG4gICk7XG4gIHJvb3QgPSB0aGlzO1xufSBlbHNlIHtcbiAgLy8gV2ViIFdvcmtlclxuICByb290ID0gc2VsZjtcbn1cblxuY29uc3QgRW1pdHRlciA9IHJlcXVpcmUoJ2NvbXBvbmVudC1lbWl0dGVyJyk7XG5jb25zdCBzYWZlU3RyaW5naWZ5ID0gcmVxdWlyZSgnZmFzdC1zYWZlLXN0cmluZ2lmeScpO1xuY29uc3QgUmVxdWVzdEJhc2UgPSByZXF1aXJlKCcuL3JlcXVlc3QtYmFzZScpO1xuY29uc3QgaXNPYmplY3QgPSByZXF1aXJlKCcuL2lzLW9iamVjdCcpO1xuY29uc3QgUmVzcG9uc2VCYXNlID0gcmVxdWlyZSgnLi9yZXNwb25zZS1iYXNlJyk7XG5jb25zdCBBZ2VudCA9IHJlcXVpcmUoJy4vYWdlbnQtYmFzZScpO1xuXG4vKipcbiAqIE5vb3AuXG4gKi9cblxuZnVuY3Rpb24gbm9vcCgpIHt9XG5cbi8qKlxuICogRXhwb3NlIGByZXF1ZXN0YC5cbiAqL1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKG1ldGhvZCwgdXJsKSB7XG4gIC8vIGNhbGxiYWNrXG4gIGlmICh0eXBlb2YgdXJsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIG5ldyBleHBvcnRzLlJlcXVlc3QoJ0dFVCcsIG1ldGhvZCkuZW5kKHVybCk7XG4gIH1cblxuICAvLyB1cmwgZmlyc3RcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHtcbiAgICByZXR1cm4gbmV3IGV4cG9ydHMuUmVxdWVzdCgnR0VUJywgbWV0aG9kKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgZXhwb3J0cy5SZXF1ZXN0KG1ldGhvZCwgdXJsKTtcbn07XG5cbmV4cG9ydHMgPSBtb2R1bGUuZXhwb3J0cztcblxuY29uc3QgcmVxdWVzdCA9IGV4cG9ydHM7XG5cbmV4cG9ydHMuUmVxdWVzdCA9IFJlcXVlc3Q7XG5cbi8qKlxuICogRGV0ZXJtaW5lIFhIUi5cbiAqL1xuXG5yZXF1ZXN0LmdldFhIUiA9ICgpID0+IHtcbiAgaWYgKFxuICAgIHJvb3QuWE1MSHR0cFJlcXVlc3QgJiZcbiAgICAoIXJvb3QubG9jYXRpb24gfHxcbiAgICAgIHJvb3QubG9jYXRpb24ucHJvdG9jb2wgIT09ICdmaWxlOicgfHxcbiAgICAgICFyb290LkFjdGl2ZVhPYmplY3QpXG4gICkge1xuICAgIHJldHVybiBuZXcgWE1MSHR0cFJlcXVlc3QoKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgcmV0dXJuIG5ldyBBY3RpdmVYT2JqZWN0KCdNaWNyb3NvZnQuWE1MSFRUUCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjYuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjMuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQJyk7XG4gIH0gY2F0Y2gge31cblxuICB0aHJvdyBuZXcgRXJyb3IoJ0Jyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgY291bGQgbm90IGZpbmQgWEhSJyk7XG59O1xuXG4vKipcbiAqIFJlbW92ZXMgbGVhZGluZyBhbmQgdHJhaWxpbmcgd2hpdGVzcGFjZSwgYWRkZWQgdG8gc3VwcG9ydCBJRS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc1xuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuY29uc3QgdHJpbSA9ICcnLnRyaW0gPyBzID0+IHMudHJpbSgpIDogcyA9PiBzLnJlcGxhY2UoLyheXFxzKnxcXHMqJCkvZywgJycpO1xuXG4vKipcbiAqIFNlcmlhbGl6ZSB0aGUgZ2l2ZW4gYG9iamAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9ialxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gc2VyaWFsaXplKG9iaikge1xuICBpZiAoIWlzT2JqZWN0KG9iaikpIHJldHVybiBvYmo7XG4gIGNvbnN0IHBhaXJzID0gW107XG4gIGZvciAoY29uc3Qga2V5IGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBrZXkpKVxuICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGtleSwgb2JqW2tleV0pO1xuICB9XG5cbiAgcmV0dXJuIHBhaXJzLmpvaW4oJyYnKTtcbn1cblxuLyoqXG4gKiBIZWxwcyAnc2VyaWFsaXplJyB3aXRoIHNlcmlhbGl6aW5nIGFycmF5cy5cbiAqIE11dGF0ZXMgdGhlIHBhaXJzIGFycmF5LlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IHBhaXJzXG4gKiBAcGFyYW0ge1N0cmluZ30ga2V5XG4gKiBAcGFyYW0ge01peGVkfSB2YWxcbiAqL1xuXG5mdW5jdGlvbiBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2YWwpIHtcbiAgaWYgKHZhbCA9PT0gdW5kZWZpbmVkKSByZXR1cm47XG4gIGlmICh2YWwgPT09IG51bGwpIHtcbiAgICBwYWlycy5wdXNoKGVuY29kZVVSSShrZXkpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheSh2YWwpKSB7XG4gICAgdmFsLmZvckVhY2godiA9PiB7XG4gICAgICBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2KTtcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc09iamVjdCh2YWwpKSB7XG4gICAgZm9yIChjb25zdCBzdWJrZXkgaW4gdmFsKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHZhbCwgc3Via2V5KSlcbiAgICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGAke2tleX1bJHtzdWJrZXl9XWAsIHZhbFtzdWJrZXldKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcGFpcnMucHVzaChlbmNvZGVVUkkoa2V5KSArICc9JyArIGVuY29kZVVSSUNvbXBvbmVudCh2YWwpKTtcbiAgfVxufVxuXG4vKipcbiAqIEV4cG9zZSBzZXJpYWxpemF0aW9uIG1ldGhvZC5cbiAqL1xuXG5yZXF1ZXN0LnNlcmlhbGl6ZU9iamVjdCA9IHNlcmlhbGl6ZTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4geC13d3ctZm9ybS11cmxlbmNvZGVkIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgY29uc3QgcGFpcnMgPSBzdHIuc3BsaXQoJyYnKTtcbiAgbGV0IHBhaXI7XG4gIGxldCBwb3M7XG5cbiAgZm9yIChsZXQgaSA9IDAsIGxlbiA9IHBhaXJzLmxlbmd0aDsgaSA8IGxlbjsgKytpKSB7XG4gICAgcGFpciA9IHBhaXJzW2ldO1xuICAgIHBvcyA9IHBhaXIuaW5kZXhPZignPScpO1xuICAgIGlmIChwb3MgPT09IC0xKSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIpXSA9ICcnO1xuICAgIH0gZWxzZSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIuc2xpY2UoMCwgcG9zKSldID0gZGVjb2RlVVJJQ29tcG9uZW50KFxuICAgICAgICBwYWlyLnNsaWNlKHBvcyArIDEpXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbi8qKlxuICogRXhwb3NlIHBhcnNlci5cbiAqL1xuXG5yZXF1ZXN0LnBhcnNlU3RyaW5nID0gcGFyc2VTdHJpbmc7XG5cbi8qKlxuICogRGVmYXVsdCBNSU1FIHR5cGUgbWFwLlxuICpcbiAqICAgICBzdXBlcmFnZW50LnR5cGVzLnhtbCA9ICdhcHBsaWNhdGlvbi94bWwnO1xuICpcbiAqL1xuXG5yZXF1ZXN0LnR5cGVzID0ge1xuICBodG1sOiAndGV4dC9odG1sJyxcbiAganNvbjogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICB4bWw6ICd0ZXh0L3htbCcsXG4gIHVybGVuY29kZWQ6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnLFxuICBmb3JtOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyxcbiAgJ2Zvcm0tZGF0YSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG59O1xuXG4vKipcbiAqIERlZmF1bHQgc2VyaWFsaXphdGlvbiBtYXAuXG4gKlxuICogICAgIHN1cGVyYWdlbnQuc2VyaWFsaXplWydhcHBsaWNhdGlvbi94bWwnXSA9IGZ1bmN0aW9uKG9iail7XG4gKiAgICAgICByZXR1cm4gJ2dlbmVyYXRlZCB4bWwgaGVyZSc7XG4gKiAgICAgfTtcbiAqXG4gKi9cblxucmVxdWVzdC5zZXJpYWxpemUgPSB7XG4gICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnOiBzZXJpYWxpemUsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogc2FmZVN0cmluZ2lmeVxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcnNlcnMuXG4gKlxuICogICAgIHN1cGVyYWdlbnQucGFyc2VbJ2FwcGxpY2F0aW9uL3htbCddID0gZnVuY3Rpb24oc3RyKXtcbiAqICAgICAgIHJldHVybiB7IG9iamVjdCBwYXJzZWQgZnJvbSBzdHIgfTtcbiAqICAgICB9O1xuICpcbiAqL1xuXG5yZXF1ZXN0LnBhcnNlID0ge1xuICAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJzogcGFyc2VTdHJpbmcsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogSlNPTi5wYXJzZVxufTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gaGVhZGVyIGBzdHJgIGludG9cbiAqIGFuIG9iamVjdCBjb250YWluaW5nIHRoZSBtYXBwZWQgZmllbGRzLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlSGVhZGVyKHN0cikge1xuICBjb25zdCBsaW5lcyA9IHN0ci5zcGxpdCgvXFxyP1xcbi8pO1xuICBjb25zdCBmaWVsZHMgPSB7fTtcbiAgbGV0IGluZGV4O1xuICBsZXQgbGluZTtcbiAgbGV0IGZpZWxkO1xuICBsZXQgdmFsO1xuXG4gIGZvciAobGV0IGkgPSAwLCBsZW4gPSBsaW5lcy5sZW5ndGg7IGkgPCBsZW47ICsraSkge1xuICAgIGxpbmUgPSBsaW5lc1tpXTtcbiAgICBpbmRleCA9IGxpbmUuaW5kZXhPZignOicpO1xuICAgIGlmIChpbmRleCA9PT0gLTEpIHtcbiAgICAgIC8vIGNvdWxkIGJlIGVtcHR5IGxpbmUsIGp1c3Qgc2tpcCBpdFxuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgZmllbGQgPSBsaW5lLnNsaWNlKDAsIGluZGV4KS50b0xvd2VyQ2FzZSgpO1xuICAgIHZhbCA9IHRyaW0obGluZS5zbGljZShpbmRleCArIDEpKTtcbiAgICBmaWVsZHNbZmllbGRdID0gdmFsO1xuICB9XG5cbiAgcmV0dXJuIGZpZWxkcztcbn1cblxuLyoqXG4gKiBDaGVjayBpZiBgbWltZWAgaXMganNvbiBvciBoYXMgK2pzb24gc3RydWN0dXJlZCBzeW50YXggc3VmZml4LlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBtaW1lXG4gKiBAcmV0dXJuIHtCb29sZWFufVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gaXNKU09OKG1pbWUpIHtcbiAgLy8gc2hvdWxkIG1hdGNoIC9qc29uIG9yICtqc29uXG4gIC8vIGJ1dCBub3QgL2pzb24tc2VxXG4gIHJldHVybiAvWy8rXWpzb24oJHxbXi1cXHddKS8udGVzdChtaW1lKTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXNwb25zZWAgd2l0aCB0aGUgZ2l2ZW4gYHhocmAuXG4gKlxuICogIC0gc2V0IGZsYWdzICgub2ssIC5lcnJvciwgZXRjKVxuICogIC0gcGFyc2UgaGVhZGVyXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogIEFsaWFzaW5nIGBzdXBlcmFnZW50YCBhcyBgcmVxdWVzdGAgaXMgbmljZTpcbiAqXG4gKiAgICAgIHJlcXVlc3QgPSBzdXBlcmFnZW50O1xuICpcbiAqICBXZSBjYW4gdXNlIHRoZSBwcm9taXNlLWxpa2UgQVBJLCBvciBwYXNzIGNhbGxiYWNrczpcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJykuZW5kKGZ1bmN0aW9uKHJlcyl7fSk7XG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJywgZnVuY3Rpb24ocmVzKXt9KTtcbiAqXG4gKiAgU2VuZGluZyBkYXRhIGNhbiBiZSBjaGFpbmVkOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqICBPciBwYXNzZWQgdG8gYC5zZW5kKClgOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogIE9yIHBhc3NlZCB0byBgLnBvc3QoKWA6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqIE9yIGZ1cnRoZXIgcmVkdWNlZCB0byBhIHNpbmdsZSBjYWxsIGZvciBzaW1wbGUgY2FzZXM6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogQHBhcmFtIHtYTUxIVFRQUmVxdWVzdH0geGhyXG4gKiBAcGFyYW0ge09iamVjdH0gb3B0aW9uc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gUmVzcG9uc2UocmVxKSB7XG4gIHRoaXMucmVxID0gcmVxO1xuICB0aGlzLnhociA9IHRoaXMucmVxLnhocjtcbiAgLy8gcmVzcG9uc2VUZXh0IGlzIGFjY2Vzc2libGUgb25seSBpZiByZXNwb25zZVR5cGUgaXMgJycgb3IgJ3RleHQnIGFuZCBvbiBvbGRlciBicm93c2Vyc1xuICB0aGlzLnRleHQgPVxuICAgICh0aGlzLnJlcS5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgICAgKHRoaXMueGhyLnJlc3BvbnNlVHlwZSA9PT0gJycgfHwgdGhpcy54aHIucmVzcG9uc2VUeXBlID09PSAndGV4dCcpKSB8fFxuICAgIHR5cGVvZiB0aGlzLnhoci5yZXNwb25zZVR5cGUgPT09ICd1bmRlZmluZWQnXG4gICAgICA/IHRoaXMueGhyLnJlc3BvbnNlVGV4dFxuICAgICAgOiBudWxsO1xuICB0aGlzLnN0YXR1c1RleHQgPSB0aGlzLnJlcS54aHIuc3RhdHVzVGV4dDtcbiAgbGV0IHsgc3RhdHVzIH0gPSB0aGlzLnhocjtcbiAgLy8gaGFuZGxlIElFOSBidWc6IGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTAwNDY5NzIvbXNpZS1yZXR1cm5zLXN0YXR1cy1jb2RlLW9mLTEyMjMtZm9yLWFqYXgtcmVxdWVzdFxuICBpZiAoc3RhdHVzID09PSAxMjIzKSB7XG4gICAgc3RhdHVzID0gMjA0O1xuICB9XG5cbiAgdGhpcy5fc2V0U3RhdHVzUHJvcGVydGllcyhzdGF0dXMpO1xuICB0aGlzLmhlYWRlcnMgPSBwYXJzZUhlYWRlcih0aGlzLnhoci5nZXRBbGxSZXNwb25zZUhlYWRlcnMoKSk7XG4gIHRoaXMuaGVhZGVyID0gdGhpcy5oZWFkZXJzO1xuICAvLyBnZXRBbGxSZXNwb25zZUhlYWRlcnMgc29tZXRpbWVzIGZhbHNlbHkgcmV0dXJucyBcIlwiIGZvciBDT1JTIHJlcXVlc3RzLCBidXRcbiAgLy8gZ2V0UmVzcG9uc2VIZWFkZXIgc3RpbGwgd29ya3MuIHNvIHdlIGdldCBjb250ZW50LXR5cGUgZXZlbiBpZiBnZXR0aW5nXG4gIC8vIG90aGVyIGhlYWRlcnMgZmFpbHMuXG4gIHRoaXMuaGVhZGVyWydjb250ZW50LXR5cGUnXSA9IHRoaXMueGhyLmdldFJlc3BvbnNlSGVhZGVyKCdjb250ZW50LXR5cGUnKTtcbiAgdGhpcy5fc2V0SGVhZGVyUHJvcGVydGllcyh0aGlzLmhlYWRlcik7XG5cbiAgaWYgKHRoaXMudGV4dCA9PT0gbnVsbCAmJiByZXEuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHRoaXMuYm9keSA9IHRoaXMueGhyLnJlc3BvbnNlO1xuICB9IGVsc2Uge1xuICAgIHRoaXMuYm9keSA9XG4gICAgICB0aGlzLnJlcS5tZXRob2QgPT09ICdIRUFEJ1xuICAgICAgICA/IG51bGxcbiAgICAgICAgOiB0aGlzLl9wYXJzZUJvZHkodGhpcy50ZXh0ID8gdGhpcy50ZXh0IDogdGhpcy54aHIucmVzcG9uc2UpO1xuICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXNwb25zZUJhc2UoUmVzcG9uc2UucHJvdG90eXBlKTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gYm9keSBgc3RyYC5cbiAqXG4gKiBVc2VkIGZvciBhdXRvLXBhcnNpbmcgb2YgYm9kaWVzLiBQYXJzZXJzXG4gKiBhcmUgZGVmaW5lZCBvbiB0aGUgYHN1cGVyYWdlbnQucGFyc2VgIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtNaXhlZH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlc3BvbnNlLnByb3RvdHlwZS5fcGFyc2VCb2R5ID0gZnVuY3Rpb24oc3RyKSB7XG4gIGxldCBwYXJzZSA9IHJlcXVlc3QucGFyc2VbdGhpcy50eXBlXTtcbiAgaWYgKHRoaXMucmVxLl9wYXJzZXIpIHtcbiAgICByZXR1cm4gdGhpcy5yZXEuX3BhcnNlcih0aGlzLCBzdHIpO1xuICB9XG5cbiAgaWYgKCFwYXJzZSAmJiBpc0pTT04odGhpcy50eXBlKSkge1xuICAgIHBhcnNlID0gcmVxdWVzdC5wYXJzZVsnYXBwbGljYXRpb24vanNvbiddO1xuICB9XG5cbiAgcmV0dXJuIHBhcnNlICYmIHN0ciAmJiAoc3RyLmxlbmd0aCA+IDAgfHwgc3RyIGluc3RhbmNlb2YgT2JqZWN0KVxuICAgID8gcGFyc2Uoc3RyKVxuICAgIDogbnVsbDtcbn07XG5cbi8qKlxuICogUmV0dXJuIGFuIGBFcnJvcmAgcmVwcmVzZW50YXRpdmUgb2YgdGhpcyByZXNwb25zZS5cbiAqXG4gKiBAcmV0dXJuIHtFcnJvcn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVzcG9uc2UucHJvdG90eXBlLnRvRXJyb3IgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgeyByZXEgfSA9IHRoaXM7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSByZXE7XG4gIGNvbnN0IHsgdXJsIH0gPSByZXE7XG5cbiAgY29uc3QgbXNnID0gYGNhbm5vdCAke21ldGhvZH0gJHt1cmx9ICgke3RoaXMuc3RhdHVzfSlgO1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IobXNnKTtcbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gbWV0aG9kO1xuICBlcnIudXJsID0gdXJsO1xuXG4gIHJldHVybiBlcnI7XG59O1xuXG4vKipcbiAqIEV4cG9zZSBgUmVzcG9uc2VgLlxuICovXG5cbnJlcXVlc3QuUmVzcG9uc2UgPSBSZXNwb25zZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0YCB3aXRoIHRoZSBnaXZlbiBgbWV0aG9kYCBhbmQgYHVybGAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IG1ldGhvZFxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0KG1ldGhvZCwgdXJsKSB7XG4gIGNvbnN0IHNlbGYgPSB0aGlzO1xuICB0aGlzLl9xdWVyeSA9IHRoaXMuX3F1ZXJ5IHx8IFtdO1xuICB0aGlzLm1ldGhvZCA9IG1ldGhvZDtcbiAgdGhpcy51cmwgPSB1cmw7XG4gIHRoaXMuaGVhZGVyID0ge307IC8vIHByZXNlcnZlcyBoZWFkZXIgbmFtZSBjYXNlXG4gIHRoaXMuX2hlYWRlciA9IHt9OyAvLyBjb2VyY2VzIGhlYWRlciBuYW1lcyB0byBsb3dlcmNhc2VcbiAgdGhpcy5vbignZW5kJywgKCkgPT4ge1xuICAgIGxldCBlcnIgPSBudWxsO1xuICAgIGxldCByZXMgPSBudWxsO1xuXG4gICAgdHJ5IHtcbiAgICAgIHJlcyA9IG5ldyBSZXNwb25zZShzZWxmKTtcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBlcnIgPSBuZXcgRXJyb3IoJ1BhcnNlciBpcyB1bmFibGUgdG8gcGFyc2UgdGhlIHJlc3BvbnNlJyk7XG4gICAgICBlcnIucGFyc2UgPSB0cnVlO1xuICAgICAgZXJyLm9yaWdpbmFsID0gZXJyXztcbiAgICAgIC8vIGlzc3VlICM2NzU6IHJldHVybiB0aGUgcmF3IHJlc3BvbnNlIGlmIHRoZSByZXNwb25zZSBwYXJzaW5nIGZhaWxzXG4gICAgICBpZiAoc2VsZi54aHIpIHtcbiAgICAgICAgLy8gaWU5IGRvZXNuJ3QgaGF2ZSAncmVzcG9uc2UnIHByb3BlcnR5XG4gICAgICAgIGVyci5yYXdSZXNwb25zZSA9XG4gICAgICAgICAgdHlwZW9mIHNlbGYueGhyLnJlc3BvbnNlVHlwZSA9PT0gJ3VuZGVmaW5lZCdcbiAgICAgICAgICAgID8gc2VsZi54aHIucmVzcG9uc2VUZXh0XG4gICAgICAgICAgICA6IHNlbGYueGhyLnJlc3BvbnNlO1xuICAgICAgICAvLyBpc3N1ZSAjODc2OiByZXR1cm4gdGhlIGh0dHAgc3RhdHVzIGNvZGUgaWYgdGhlIHJlc3BvbnNlIHBhcnNpbmcgZmFpbHNcbiAgICAgICAgZXJyLnN0YXR1cyA9IHNlbGYueGhyLnN0YXR1cyA/IHNlbGYueGhyLnN0YXR1cyA6IG51bGw7XG4gICAgICAgIGVyci5zdGF0dXNDb2RlID0gZXJyLnN0YXR1czsgLy8gYmFja3dhcmRzLWNvbXBhdCBvbmx5XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBlcnIucmF3UmVzcG9uc2UgPSBudWxsO1xuICAgICAgICBlcnIuc3RhdHVzID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNlbGYuY2FsbGJhY2soZXJyKTtcbiAgICB9XG5cbiAgICBzZWxmLmVtaXQoJ3Jlc3BvbnNlJywgcmVzKTtcblxuICAgIGxldCBuZXdfZXJyO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXNlbGYuX2lzUmVzcG9uc2VPSyhyZXMpKSB7XG4gICAgICAgIG5ld19lcnIgPSBuZXcgRXJyb3IoXG4gICAgICAgICAgcmVzLnN0YXR1c1RleHQgfHwgcmVzLnRleHQgfHwgJ1Vuc3VjY2Vzc2Z1bCBIVFRQIHJlc3BvbnNlJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycl8pIHtcbiAgICAgIG5ld19lcnIgPSBlcnJfOyAvLyBvaygpIGNhbGxiYWNrIGNhbiB0aHJvd1xuICAgIH1cblxuICAgIC8vICMxMDAwIGRvbid0IGNhdGNoIGVycm9ycyBmcm9tIHRoZSBjYWxsYmFjayB0byBhdm9pZCBkb3VibGUgY2FsbGluZyBpdFxuICAgIGlmIChuZXdfZXJyKSB7XG4gICAgICBuZXdfZXJyLm9yaWdpbmFsID0gZXJyO1xuICAgICAgbmV3X2Vyci5yZXNwb25zZSA9IHJlcztcbiAgICAgIG5ld19lcnIuc3RhdHVzID0gcmVzLnN0YXR1cztcbiAgICAgIHNlbGYuY2FsbGJhY2sobmV3X2VyciwgcmVzKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2VsZi5jYWxsYmFjayhudWxsLCByZXMpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogTWl4aW4gYEVtaXR0ZXJgIGFuZCBgUmVxdWVzdEJhc2VgLlxuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5FbWl0dGVyKFJlcXVlc3QucHJvdG90eXBlKTtcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXF1ZXN0QmFzZShSZXF1ZXN0LnByb3RvdHlwZSk7XG5cbi8qKlxuICogU2V0IENvbnRlbnQtVHlwZSB0byBgdHlwZWAsIG1hcHBpbmcgdmFsdWVzIGZyb20gYHJlcXVlc3QudHlwZXNgLlxuICpcbiAqIEV4YW1wbGVzOlxuICpcbiAqICAgICAgc3VwZXJhZ2VudC50eXBlcy54bWwgPSAnYXBwbGljYXRpb24veG1sJztcbiAqXG4gKiAgICAgIHJlcXVlc3QucG9zdCgnLycpXG4gKiAgICAgICAgLnR5cGUoJ3htbCcpXG4gKiAgICAgICAgLnNlbmQoeG1sc3RyaW5nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvJylcbiAqICAgICAgICAudHlwZSgnYXBwbGljYXRpb24veG1sJylcbiAqICAgICAgICAuc2VuZCh4bWxzdHJpbmcpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHR5cGVcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS50eXBlID0gZnVuY3Rpb24odHlwZSkge1xuICB0aGlzLnNldCgnQ29udGVudC1UeXBlJywgcmVxdWVzdC50eXBlc1t0eXBlXSB8fCB0eXBlKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNldCBBY2NlcHQgdG8gYHR5cGVgLCBtYXBwaW5nIHZhbHVlcyBmcm9tIGByZXF1ZXN0LnR5cGVzYC5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHN1cGVyYWdlbnQudHlwZXMuanNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJztcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvYWdlbnQnKVxuICogICAgICAgIC5hY2NlcHQoJ2pzb24nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5nZXQoJy9hZ2VudCcpXG4gKiAgICAgICAgLmFjY2VwdCgnYXBwbGljYXRpb24vanNvbicpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGFjY2VwdFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmFjY2VwdCA9IGZ1bmN0aW9uKHR5cGUpIHtcbiAgdGhpcy5zZXQoJ0FjY2VwdCcsIHJlcXVlc3QudHlwZXNbdHlwZV0gfHwgdHlwZSk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgQXV0aG9yaXphdGlvbiBmaWVsZCB2YWx1ZSB3aXRoIGB1c2VyYCBhbmQgYHBhc3NgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1c2VyXG4gKiBAcGFyYW0ge1N0cmluZ30gW3Bhc3NdIG9wdGlvbmFsIGluIGNhc2Ugb2YgdXNpbmcgJ2JlYXJlcicgYXMgdHlwZVxuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMgd2l0aCAndHlwZScgcHJvcGVydHkgJ2F1dG8nLCAnYmFzaWMnIG9yICdiZWFyZXInIChkZWZhdWx0ICdiYXNpYycpXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuYXV0aCA9IGZ1bmN0aW9uKHVzZXIsIHBhc3MsIG9wdGlvbnMpIHtcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHBhc3MgPSAnJztcbiAgaWYgKHR5cGVvZiBwYXNzID09PSAnb2JqZWN0JyAmJiBwYXNzICE9PSBudWxsKSB7XG4gICAgLy8gcGFzcyBpcyBvcHRpb25hbCBhbmQgY2FuIGJlIHJlcGxhY2VkIHdpdGggb3B0aW9uc1xuICAgIG9wdGlvbnMgPSBwYXNzO1xuICAgIHBhc3MgPSAnJztcbiAgfVxuXG4gIGlmICghb3B0aW9ucykge1xuICAgIG9wdGlvbnMgPSB7XG4gICAgICB0eXBlOiB0eXBlb2YgYnRvYSA9PT0gJ2Z1bmN0aW9uJyA/ICdiYXNpYycgOiAnYXV0bydcbiAgICB9O1xuICB9XG5cbiAgY29uc3QgZW5jb2RlciA9IHN0cmluZyA9PiB7XG4gICAgaWYgKHR5cGVvZiBidG9hID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYnRvYShzdHJpbmcpO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IHVzZSBiYXNpYyBhdXRoLCBidG9hIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gIH07XG5cbiAgcmV0dXJuIHRoaXMuX2F1dGgodXNlciwgcGFzcywgb3B0aW9ucywgZW5jb2Rlcik7XG59O1xuXG4vKipcbiAqIEFkZCBxdWVyeS1zdHJpbmcgYHZhbGAuXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICByZXF1ZXN0LmdldCgnL3Nob2VzJylcbiAqICAgICAucXVlcnkoJ3NpemU9MTAnKVxuICogICAgIC5xdWVyeSh7IGNvbG9yOiAnYmx1ZScgfSlcbiAqXG4gKiBAcGFyYW0ge09iamVjdHxTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLnF1ZXJ5ID0gZnVuY3Rpb24odmFsKSB7XG4gIGlmICh0eXBlb2YgdmFsICE9PSAnc3RyaW5nJykgdmFsID0gc2VyaWFsaXplKHZhbCk7XG4gIGlmICh2YWwpIHRoaXMuX3F1ZXJ5LnB1c2godmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFF1ZXVlIHRoZSBnaXZlbiBgZmlsZWAgYXMgYW4gYXR0YWNobWVudCB0byB0aGUgc3BlY2lmaWVkIGBmaWVsZGAsXG4gKiB3aXRoIG9wdGlvbmFsIGBvcHRpb25zYCAob3IgZmlsZW5hbWUpLlxuICpcbiAqIGBgYCBqc1xuICogcmVxdWVzdC5wb3N0KCcvdXBsb2FkJylcbiAqICAgLmF0dGFjaCgnY29udGVudCcsIG5ldyBCbG9iKFsnPGEgaWQ9XCJhXCI+PGIgaWQ9XCJiXCI+aGV5ITwvYj48L2E+J10sIHsgdHlwZTogXCJ0ZXh0L2h0bWxcIn0pKVxuICogICAuZW5kKGNhbGxiYWNrKTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHBhcmFtIHtCbG9ifEZpbGV9IGZpbGVcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gb3B0aW9uc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmF0dGFjaCA9IGZ1bmN0aW9uKGZpZWxkLCBmaWxlLCBvcHRpb25zKSB7XG4gIGlmIChmaWxlKSB7XG4gICAgaWYgKHRoaXMuX2RhdGEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInN1cGVyYWdlbnQgY2FuJ3QgbWl4IC5zZW5kKCkgYW5kIC5hdHRhY2goKVwiKTtcbiAgICB9XG5cbiAgICB0aGlzLl9nZXRGb3JtRGF0YSgpLmFwcGVuZChmaWVsZCwgZmlsZSwgb3B0aW9ucyB8fCBmaWxlLm5hbWUpO1xuICB9XG5cbiAgcmV0dXJuIHRoaXM7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5fZ2V0Rm9ybURhdGEgPSBmdW5jdGlvbigpIHtcbiAgaWYgKCF0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRoaXMuX2Zvcm1EYXRhID0gbmV3IHJvb3QuRm9ybURhdGEoKTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mb3JtRGF0YTtcbn07XG5cbi8qKlxuICogSW52b2tlIHRoZSBjYWxsYmFjayB3aXRoIGBlcnJgIGFuZCBgcmVzYFxuICogYW5kIGhhbmRsZSBhcml0eSBjaGVjay5cbiAqXG4gKiBAcGFyYW0ge0Vycm9yfSBlcnJcbiAqIEBwYXJhbSB7UmVzcG9uc2V9IHJlc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY2FsbGJhY2sgPSBmdW5jdGlvbihlcnIsIHJlcykge1xuICBpZiAodGhpcy5fc2hvdWxkUmV0cnkoZXJyLCByZXMpKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JldHJ5KCk7XG4gIH1cblxuICBjb25zdCBmbiA9IHRoaXMuX2NhbGxiYWNrO1xuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuXG4gIGlmIChlcnIpIHtcbiAgICBpZiAodGhpcy5fbWF4UmV0cmllcykgZXJyLnJldHJpZXMgPSB0aGlzLl9yZXRyaWVzIC0gMTtcbiAgICB0aGlzLmVtaXQoJ2Vycm9yJywgZXJyKTtcbiAgfVxuXG4gIGZuKGVyciwgcmVzKTtcbn07XG5cbi8qKlxuICogSW52b2tlIGNhbGxiYWNrIHdpdGggeC1kb21haW4gZXJyb3IuXG4gKlxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY3Jvc3NEb21haW5FcnJvciA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IoXG4gICAgJ1JlcXVlc3QgaGFzIGJlZW4gdGVybWluYXRlZFxcblBvc3NpYmxlIGNhdXNlczogdGhlIG5ldHdvcmsgaXMgb2ZmbGluZSwgT3JpZ2luIGlzIG5vdCBhbGxvd2VkIGJ5IEFjY2Vzcy1Db250cm9sLUFsbG93LU9yaWdpbiwgdGhlIHBhZ2UgaXMgYmVpbmcgdW5sb2FkZWQsIGV0Yy4nXG4gICk7XG4gIGVyci5jcm9zc0RvbWFpbiA9IHRydWU7XG5cbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gIGVyci51cmwgPSB0aGlzLnVybDtcblxuICB0aGlzLmNhbGxiYWNrKGVycik7XG59O1xuXG4vLyBUaGlzIG9ubHkgd2FybnMsIGJlY2F1c2UgdGhlIHJlcXVlc3QgaXMgc3RpbGwgbGlrZWx5IHRvIHdvcmtcblJlcXVlc3QucHJvdG90eXBlLmFnZW50ID0gZnVuY3Rpb24oKSB7XG4gIGNvbnNvbGUud2FybignVGhpcyBpcyBub3Qgc3VwcG9ydGVkIGluIGJyb3dzZXIgdmVyc2lvbiBvZiBzdXBlcmFnZW50Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuY2EgPSBSZXF1ZXN0LnByb3RvdHlwZS5hZ2VudDtcblJlcXVlc3QucHJvdG90eXBlLmJ1ZmZlciA9IFJlcXVlc3QucHJvdG90eXBlLmNhO1xuXG4vLyBUaGlzIHRocm93cywgYmVjYXVzZSBpdCBjYW4ndCBzZW5kL3JlY2VpdmUgZGF0YSBhcyBleHBlY3RlZFxuUmVxdWVzdC5wcm90b3R5cGUud3JpdGUgPSAoKSA9PiB7XG4gIHRocm93IG5ldyBFcnJvcihcbiAgICAnU3RyZWFtaW5nIGlzIG5vdCBzdXBwb3J0ZWQgaW4gYnJvd3NlciB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQnXG4gICk7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5waXBlID0gUmVxdWVzdC5wcm90b3R5cGUud3JpdGU7XG5cbi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYSBob3N0IG9iamVjdCxcbiAqIHdlIGRvbid0IHdhbnQgdG8gc2VyaWFsaXplIHRoZXNlIDopXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9iaiBob3N0IG9iamVjdFxuICogQHJldHVybiB7Qm9vbGVhbn0gaXMgYSBob3N0IG9iamVjdFxuICogQGFwaSBwcml2YXRlXG4gKi9cblJlcXVlc3QucHJvdG90eXBlLl9pc0hvc3QgPSBmdW5jdGlvbihvYmopIHtcbiAgLy8gTmF0aXZlIG9iamVjdHMgc3RyaW5naWZ5IHRvIFtvYmplY3QgRmlsZV0sIFtvYmplY3QgQmxvYl0sIFtvYmplY3QgRm9ybURhdGFdLCBldGMuXG4gIHJldHVybiAoXG4gICAgb2JqICYmXG4gICAgdHlwZW9mIG9iaiA9PT0gJ29iamVjdCcgJiZcbiAgICAhQXJyYXkuaXNBcnJheShvYmopICYmXG4gICAgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKG9iaikgIT09ICdbb2JqZWN0IE9iamVjdF0nXG4gICk7XG59O1xuXG4vKipcbiAqIEluaXRpYXRlIHJlcXVlc3QsIGludm9raW5nIGNhbGxiYWNrIGBmbihyZXMpYFxuICogd2l0aCBhbiBpbnN0YW5jZW9mIGBSZXNwb25zZWAuXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gZm5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5lbmQgPSBmdW5jdGlvbihmbikge1xuICBpZiAodGhpcy5fZW5kQ2FsbGVkKSB7XG4gICAgY29uc29sZS53YXJuKFxuICAgICAgJ1dhcm5pbmc6IC5lbmQoKSB3YXMgY2FsbGVkIHR3aWNlLiBUaGlzIGlzIG5vdCBzdXBwb3J0ZWQgaW4gc3VwZXJhZ2VudCdcbiAgICApO1xuICB9XG5cbiAgdGhpcy5fZW5kQ2FsbGVkID0gdHJ1ZTtcblxuICAvLyBzdG9yZSBjYWxsYmFja1xuICB0aGlzLl9jYWxsYmFjayA9IGZuIHx8IG5vb3A7XG5cbiAgLy8gcXVlcnlzdHJpbmdcbiAgdGhpcy5fZmluYWxpemVRdWVyeVN0cmluZygpO1xuXG4gIHRoaXMuX2VuZCgpO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuX3NldFVwbG9hZFRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY29uc3Qgc2VsZiA9IHRoaXM7XG5cbiAgLy8gdXBsb2FkIHRpbWVvdXQgaXQncyB3b2tycyBvbmx5IGlmIGRlYWRsaW5lIHRpbWVvdXQgaXMgb2ZmXG4gIGlmICh0aGlzLl91cGxvYWRUaW1lb3V0ICYmICF0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIpIHtcbiAgICB0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlbGYuX3RpbWVvdXRFcnJvcihcbiAgICAgICAgJ1VwbG9hZCB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3VwbG9hZFRpbWVvdXQsXG4gICAgICAgICdFVElNRURPVVQnXG4gICAgICApO1xuICAgIH0sIHRoaXMuX3VwbG9hZFRpbWVvdXQpO1xuICB9XG59O1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29tcGxleGl0eVxuUmVxdWVzdC5wcm90b3R5cGUuX2VuZCA9IGZ1bmN0aW9uKCkge1xuICBpZiAodGhpcy5fYWJvcnRlZClcbiAgICByZXR1cm4gdGhpcy5jYWxsYmFjayhcbiAgICAgIG5ldyBFcnJvcignVGhlIHJlcXVlc3QgaGFzIGJlZW4gYWJvcnRlZCBldmVuIGJlZm9yZSAuZW5kKCkgd2FzIGNhbGxlZCcpXG4gICAgKTtcblxuICBjb25zdCBzZWxmID0gdGhpcztcbiAgdGhpcy54aHIgPSByZXF1ZXN0LmdldFhIUigpO1xuICBjb25zdCB7IHhociB9ID0gdGhpcztcbiAgbGV0IGRhdGEgPSB0aGlzLl9mb3JtRGF0YSB8fCB0aGlzLl9kYXRhO1xuXG4gIHRoaXMuX3NldFRpbWVvdXRzKCk7XG5cbiAgLy8gc3RhdGUgY2hhbmdlXG4gIHhoci5vbnJlYWR5c3RhdGVjaGFuZ2UgPSAoKSA9PiB7XG4gICAgY29uc3QgeyByZWFkeVN0YXRlIH0gPSB4aHI7XG4gICAgaWYgKHJlYWR5U3RhdGUgPj0gMiAmJiBzZWxmLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgICAgY2xlYXJUaW1lb3V0KHNlbGYuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgICB9XG5cbiAgICBpZiAocmVhZHlTdGF0ZSAhPT0gNCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIEluIElFOSwgcmVhZHMgdG8gYW55IHByb3BlcnR5IChlLmcuIHN0YXR1cykgb2ZmIG9mIGFuIGFib3J0ZWQgWEhSIHdpbGxcbiAgICAvLyByZXN1bHQgaW4gdGhlIGVycm9yIFwiQ291bGQgbm90IGNvbXBsZXRlIHRoZSBvcGVyYXRpb24gZHVlIHRvIGVycm9yIGMwMGMwMjNmXCJcbiAgICBsZXQgc3RhdHVzO1xuICAgIHRyeSB7XG4gICAgICBzdGF0dXMgPSB4aHIuc3RhdHVzO1xuICAgIH0gY2F0Y2gge1xuICAgICAgc3RhdHVzID0gMDtcbiAgICB9XG5cbiAgICBpZiAoIXN0YXR1cykge1xuICAgICAgaWYgKHNlbGYudGltZWRvdXQgfHwgc2VsZi5fYWJvcnRlZCkgcmV0dXJuO1xuICAgICAgcmV0dXJuIHNlbGYuY3Jvc3NEb21haW5FcnJvcigpO1xuICAgIH1cblxuICAgIHNlbGYuZW1pdCgnZW5kJyk7XG4gIH07XG5cbiAgLy8gcHJvZ3Jlc3NcbiAgY29uc3QgaGFuZGxlUHJvZ3Jlc3MgPSAoZGlyZWN0aW9uLCBlKSA9PiB7XG4gICAgaWYgKGUudG90YWwgPiAwKSB7XG4gICAgICBlLnBlcmNlbnQgPSAoZS5sb2FkZWQgLyBlLnRvdGFsKSAqIDEwMDtcblxuICAgICAgaWYgKGUucGVyY2VudCA9PT0gMTAwKSB7XG4gICAgICAgIGNsZWFyVGltZW91dChzZWxmLl91cGxvYWRUaW1lb3V0VGltZXIpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGUuZGlyZWN0aW9uID0gZGlyZWN0aW9uO1xuICAgIHNlbGYuZW1pdCgncHJvZ3Jlc3MnLCBlKTtcbiAgfTtcblxuICBpZiAodGhpcy5oYXNMaXN0ZW5lcnMoJ3Byb2dyZXNzJykpIHtcbiAgICB0cnkge1xuICAgICAgeGhyLmFkZEV2ZW50TGlzdGVuZXIoJ3Byb2dyZXNzJywgaGFuZGxlUHJvZ3Jlc3MuYmluZChudWxsLCAnZG93bmxvYWQnKSk7XG4gICAgICBpZiAoeGhyLnVwbG9hZCkge1xuICAgICAgICB4aHIudXBsb2FkLmFkZEV2ZW50TGlzdGVuZXIoXG4gICAgICAgICAgJ3Byb2dyZXNzJyxcbiAgICAgICAgICBoYW5kbGVQcm9ncmVzcy5iaW5kKG51bGwsICd1cGxvYWQnKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gQWNjZXNzaW5nIHhoci51cGxvYWQgZmFpbHMgaW4gSUUgZnJvbSBhIHdlYiB3b3JrZXIsIHNvIGp1c3QgcHJldGVuZCBpdCBkb2Vzbid0IGV4aXN0LlxuICAgICAgLy8gUmVwb3J0ZWQgaGVyZTpcbiAgICAgIC8vIGh0dHBzOi8vY29ubmVjdC5taWNyb3NvZnQuY29tL0lFL2ZlZWRiYWNrL2RldGFpbHMvODM3MjQ1L3htbGh0dHByZXF1ZXN0LXVwbG9hZC10aHJvd3MtaW52YWxpZC1hcmd1bWVudC13aGVuLXVzZWQtZnJvbS13ZWItd29ya2VyLWNvbnRleHRcbiAgICB9XG4gIH1cblxuICBpZiAoeGhyLnVwbG9hZCkge1xuICAgIHRoaXMuX3NldFVwbG9hZFRpbWVvdXQoKTtcbiAgfVxuXG4gIC8vIGluaXRpYXRlIHJlcXVlc3RcbiAgdHJ5IHtcbiAgICBpZiAodGhpcy51c2VybmFtZSAmJiB0aGlzLnBhc3N3b3JkKSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUsIHRoaXMudXNlcm5hbWUsIHRoaXMucGFzc3dvcmQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUpO1xuICAgIH1cbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgLy8gc2VlICMxMTQ5XG4gICAgcmV0dXJuIHRoaXMuY2FsbGJhY2soZXJyKTtcbiAgfVxuXG4gIC8vIENPUlNcbiAgaWYgKHRoaXMuX3dpdGhDcmVkZW50aWFscykgeGhyLndpdGhDcmVkZW50aWFscyA9IHRydWU7XG5cbiAgLy8gYm9keVxuICBpZiAoXG4gICAgIXRoaXMuX2Zvcm1EYXRhICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdHRVQnICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgIHR5cGVvZiBkYXRhICE9PSAnc3RyaW5nJyAmJlxuICAgICF0aGlzLl9pc0hvc3QoZGF0YSlcbiAgKSB7XG4gICAgLy8gc2VyaWFsaXplIHN0dWZmXG4gICAgY29uc3QgY29udGVudFR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGxldCBzZXJpYWxpemUgPVxuICAgICAgdGhpcy5fc2VyaWFsaXplciB8fFxuICAgICAgcmVxdWVzdC5zZXJpYWxpemVbY29udGVudFR5cGUgPyBjb250ZW50VHlwZS5zcGxpdCgnOycpWzBdIDogJyddO1xuICAgIGlmICghc2VyaWFsaXplICYmIGlzSlNPTihjb250ZW50VHlwZSkpIHtcbiAgICAgIHNlcmlhbGl6ZSA9IHJlcXVlc3Quc2VyaWFsaXplWydhcHBsaWNhdGlvbi9qc29uJ107XG4gICAgfVxuXG4gICAgaWYgKHNlcmlhbGl6ZSkgZGF0YSA9IHNlcmlhbGl6ZShkYXRhKTtcbiAgfVxuXG4gIC8vIHNldCBoZWFkZXIgZmllbGRzXG4gIGZvciAoY29uc3QgZmllbGQgaW4gdGhpcy5oZWFkZXIpIHtcbiAgICBpZiAodGhpcy5oZWFkZXJbZmllbGRdID09PSBudWxsKSBjb250aW51ZTtcblxuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodGhpcy5oZWFkZXIsIGZpZWxkKSlcbiAgICAgIHhoci5zZXRSZXF1ZXN0SGVhZGVyKGZpZWxkLCB0aGlzLmhlYWRlcltmaWVsZF0pO1xuICB9XG5cbiAgaWYgKHRoaXMuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHhoci5yZXNwb25zZVR5cGUgPSB0aGlzLl9yZXNwb25zZVR5cGU7XG4gIH1cblxuICAvLyBzZW5kIHN0dWZmXG4gIHRoaXMuZW1pdCgncmVxdWVzdCcsIHRoaXMpO1xuXG4gIC8vIElFMTEgeGhyLnNlbmQodW5kZWZpbmVkKSBzZW5kcyAndW5kZWZpbmVkJyBzdHJpbmcgYXMgUE9TVCBwYXlsb2FkIChpbnN0ZWFkIG9mIG5vdGhpbmcpXG4gIC8vIFdlIG5lZWQgbnVsbCBoZXJlIGlmIGRhdGEgaXMgdW5kZWZpbmVkXG4gIHhoci5zZW5kKHR5cGVvZiBkYXRhID09PSAndW5kZWZpbmVkJyA/IG51bGwgOiBkYXRhKTtcbn07XG5cbnJlcXVlc3QuYWdlbnQgPSAoKSA9PiBuZXcgQWdlbnQoKTtcblxuWydHRVQnLCAnUE9TVCcsICdPUFRJT05TJywgJ1BBVENIJywgJ1BVVCcsICdERUxFVEUnXS5mb3JFYWNoKG1ldGhvZCA9PiB7XG4gIEFnZW50LnByb3RvdHlwZVttZXRob2QudG9Mb3dlckNhc2UoKV0gPSBmdW5jdGlvbih1cmwsIGZuKSB7XG4gICAgY29uc3QgcmVxID0gbmV3IHJlcXVlc3QuUmVxdWVzdChtZXRob2QsIHVybCk7XG4gICAgdGhpcy5fc2V0RGVmYXVsdHMocmVxKTtcbiAgICBpZiAoZm4pIHtcbiAgICAgIHJlcS5lbmQoZm4pO1xuICAgIH1cblxuICAgIHJldHVybiByZXE7XG4gIH07XG59KTtcblxuQWdlbnQucHJvdG90eXBlLmRlbCA9IEFnZW50LnByb3RvdHlwZS5kZWxldGU7XG5cbi8qKlxuICogR0VUIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5nZXQgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdHRVQnLCB1cmwpO1xuICBpZiAodHlwZW9mIGRhdGEgPT09ICdmdW5jdGlvbicpIHtcbiAgICBmbiA9IGRhdGE7XG4gICAgZGF0YSA9IG51bGw7XG4gIH1cblxuICBpZiAoZGF0YSkgcmVxLnF1ZXJ5KGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBIRUFEIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5oZWFkID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnSEVBRCcsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEucXVlcnkoZGF0YSk7XG4gIGlmIChmbikgcmVxLmVuZChmbik7XG4gIHJldHVybiByZXE7XG59O1xuXG4vKipcbiAqIE9QVElPTlMgcXVlcnkgdG8gYHVybGAgd2l0aCBvcHRpb25hbCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZHxGdW5jdGlvbn0gW2RhdGFdIG9yIGZuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0Lm9wdGlvbnMgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdPUFRJT05TJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBERUxFVEUgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfSBbZGF0YV1cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbmZ1bmN0aW9uIGRlbCh1cmwsIGRhdGEsIGZuKSB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ0RFTEVURScsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEuc2VuZChkYXRhKTtcbiAgaWYgKGZuKSByZXEuZW5kKGZuKTtcbiAgcmV0dXJuIHJlcTtcbn1cblxucmVxdWVzdC5kZWwgPSBkZWw7XG5yZXF1ZXN0LmRlbGV0ZSA9IGRlbDtcblxuLyoqXG4gKiBQQVRDSCBgdXJsYCB3aXRoIG9wdGlvbmFsIGBkYXRhYCBhbmQgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR9IFtkYXRhXVxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5wYXRjaCA9ICh1cmwsIGRhdGEsIGZuKSA9PiB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ1BBVENIJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQT1NUIGB1cmxgIHdpdGggb3B0aW9uYWwgYGRhdGFgIGFuZCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZH0gW2RhdGFdXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0LnBvc3QgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdQT1NUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQVVQgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfEZ1bmN0aW9ufSBbZGF0YV0gb3IgZm5cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbnJlcXVlc3QucHV0ID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnUFVUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcbiJdfQ==","import base64 from 'base64-js';\n\nfunction padding(str) {\n var mod = str.length % 4;\n var pad = 4 - mod;\n\n if (mod === 0) {\n return str;\n }\n\n return str + new Array(1 + pad).join('=');\n}\n\nfunction stringToByteArray(str) {\n var arr = new Array(str.length);\n for (var a = 0; a < str.length; a++) {\n arr[a] = str.charCodeAt(a);\n }\n return arr;\n}\n\nfunction byteArrayToString(array) {\n var result = '';\n for (var i = 0; i < array.length; i++) {\n result += String.fromCharCode(array[i]);\n }\n return result;\n}\n\nfunction encode(str) {\n return base64\n .fromByteArray(stringToByteArray(str))\n .replace(/\\+/g, '-') // Convert '+' to '-'\n .replace(/\\//g, '_'); // Convert '/' to '_'\n}\n\nfunction decode(str) {\n str = padding(str)\n .replace(/-/g, '+') // Convert '-' to '+'\n .replace(/_/g, '/'); // Convert '_' to '/'\n\n return byteArrayToString(base64.toByteArray(str));\n}\n\nexport default {\n encode: encode,\n decode: decode\n};\n","module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","/* eslint-disable no-param-reassign */\nimport request from 'superagent';\nimport base64Url from './base64_url';\nimport version from '../version';\nimport objectHelper from './object';\n\n// ------------------------------------------------ RequestWrapper\n\nfunction RequestWrapper(req) {\n this.request = req;\n this.method = req.method;\n this.url = req.url;\n this.body = req._data;\n this.headers = req._header;\n}\n\nRequestWrapper.prototype.abort = function() {\n this.request.abort();\n};\n\nRequestWrapper.prototype.getMethod = function() {\n return this.method;\n};\n\nRequestWrapper.prototype.getBody = function() {\n return this.body;\n};\n\nRequestWrapper.prototype.getUrl = function() {\n return this.url;\n};\n\nRequestWrapper.prototype.getHeaders = function() {\n return this.headers;\n};\n\n// ------------------------------------------------ RequestObj\n\nfunction RequestObj(req) {\n this.request = req;\n}\n\nRequestObj.prototype.set = function(key, value) {\n this.request = this.request.set(key, value);\n return this;\n};\n\nRequestObj.prototype.send = function(body) {\n this.request = this.request.send(objectHelper.trimUserDetails(body));\n return this;\n};\n\nRequestObj.prototype.withCredentials = function() {\n this.request = this.request.withCredentials();\n return this;\n};\n\nRequestObj.prototype.end = function(cb) {\n this.request.end(cb);\n return new RequestWrapper(this.request);\n};\n\n// ------------------------------------------------ RequestBuilder\n\nfunction RequestBuilder(options) {\n this._sendTelemetry =\n options._sendTelemetry === false ? options._sendTelemetry : true;\n this._telemetryInfo = options._telemetryInfo || null;\n this._timesToRetryFailedRequests = options._timesToRetryFailedRequests;\n this.headers = options.headers || {};\n this._universalLoginPage = options.universalLoginPage;\n}\n\nRequestBuilder.prototype.setCommonConfiguration = function(\n ongoingRequest,\n options\n) {\n options = options || {};\n\n if (this._timesToRetryFailedRequests > 0) {\n ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests);\n }\n\n if (options.noHeaders) {\n return ongoingRequest;\n }\n\n var headers = this.headers;\n ongoingRequest = ongoingRequest.set('Content-Type', 'application/json');\n\n var keys = Object.keys(this.headers);\n\n for (var a = 0; a < keys.length; a++) {\n ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]);\n }\n\n if (this._sendTelemetry) {\n ongoingRequest = ongoingRequest.set(\n 'Auth0-Client',\n this.getTelemetryData()\n );\n }\n\n return ongoingRequest;\n};\n\nRequestBuilder.prototype.getTelemetryData = function() {\n var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js';\n var clientInfo = { name: telemetryName, version: version.raw };\n if (this._telemetryInfo) {\n clientInfo = objectHelper.extend({}, this._telemetryInfo);\n clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env);\n clientInfo.env[telemetryName] = version.raw;\n }\n var jsonClientInfo = JSON.stringify(clientInfo);\n return base64Url.encode(jsonClientInfo);\n};\n\nRequestBuilder.prototype.get = function(url, options) {\n return new RequestObj(this.setCommonConfiguration(request.get(url), options));\n};\n\nRequestBuilder.prototype.post = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.post(url), options)\n );\n};\n\nRequestBuilder.prototype.patch = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.patch(url), options)\n );\n};\n\nexport default RequestBuilder;\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","function DummyStorage() {}\n\nDummyStorage.prototype.getItem = function() {\n return null;\n};\n\nDummyStorage.prototype.removeItem = function() {};\n\nDummyStorage.prototype.setItem = function() {};\n\nexport default DummyStorage;\n","/*!\n * JavaScript Cookie v2.2.1\n * https://github.com/js-cookie/js-cookie\n *\n * Copyright 2006, 2015 Klaus Hartl & Fagner Brack\n * Released under the MIT license\n */\n;(function (factory) {\n\tvar registeredInModuleLoader;\n\tif (typeof define === 'function' && define.amd) {\n\t\tdefine(factory);\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (typeof exports === 'object') {\n\t\tmodule.exports = factory();\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (!registeredInModuleLoader) {\n\t\tvar OldCookies = window.Cookies;\n\t\tvar api = window.Cookies = factory();\n\t\tapi.noConflict = function () {\n\t\t\twindow.Cookies = OldCookies;\n\t\t\treturn api;\n\t\t};\n\t}\n}(function () {\n\tfunction extend () {\n\t\tvar i = 0;\n\t\tvar result = {};\n\t\tfor (; i < arguments.length; i++) {\n\t\t\tvar attributes = arguments[ i ];\n\t\t\tfor (var key in attributes) {\n\t\t\t\tresult[key] = attributes[key];\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction decode (s) {\n\t\treturn s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent);\n\t}\n\n\tfunction init (converter) {\n\t\tfunction api() {}\n\n\t\tfunction set (key, value, attributes) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tattributes = extend({\n\t\t\t\tpath: '/'\n\t\t\t}, api.defaults, attributes);\n\n\t\t\tif (typeof attributes.expires === 'number') {\n\t\t\t\tattributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5);\n\t\t\t}\n\n\t\t\t// We're using \"expires\" because \"max-age\" is not supported by IE\n\t\t\tattributes.expires = attributes.expires ? attributes.expires.toUTCString() : '';\n\n\t\t\ttry {\n\t\t\t\tvar result = JSON.stringify(value);\n\t\t\t\tif (/^[\\{\\[]/.test(result)) {\n\t\t\t\t\tvalue = result;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\n\t\t\tvalue = converter.write ?\n\t\t\t\tconverter.write(value, key) :\n\t\t\t\tencodeURIComponent(String(value))\n\t\t\t\t\t.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n\t\t\tkey = encodeURIComponent(String(key))\n\t\t\t\t.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n\t\t\t\t.replace(/[\\(\\)]/g, escape);\n\n\t\t\tvar stringifiedAttributes = '';\n\t\t\tfor (var attributeName in attributes) {\n\t\t\t\tif (!attributes[attributeName]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tstringifiedAttributes += '; ' + attributeName;\n\t\t\t\tif (attributes[attributeName] === true) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Considers RFC 6265 section 5.2:\n\t\t\t\t// ...\n\t\t\t\t// 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n\t\t\t\t// character:\n\t\t\t\t// Consume the characters of the unparsed-attributes up to,\n\t\t\t\t// not including, the first %x3B (\";\") character.\n\t\t\t\t// ...\n\t\t\t\tstringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n\t\t\t}\n\n\t\t\treturn (document.cookie = key + '=' + value + stringifiedAttributes);\n\t\t}\n\n\t\tfunction get (key, json) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar jar = {};\n\t\t\t// To prevent the for loop in the first place assign an empty array\n\t\t\t// in case there are no cookies at all.\n\t\t\tvar cookies = document.cookie ? document.cookie.split('; ') : [];\n\t\t\tvar i = 0;\n\n\t\t\tfor (; i < cookies.length; i++) {\n\t\t\t\tvar parts = cookies[i].split('=');\n\t\t\t\tvar cookie = parts.slice(1).join('=');\n\n\t\t\t\tif (!json && cookie.charAt(0) === '\"') {\n\t\t\t\t\tcookie = cookie.slice(1, -1);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tvar name = decode(parts[0]);\n\t\t\t\t\tcookie = (converter.read || converter)(cookie, name) ||\n\t\t\t\t\t\tdecode(cookie);\n\n\t\t\t\t\tif (json) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tcookie = JSON.parse(cookie);\n\t\t\t\t\t\t} catch (e) {}\n\t\t\t\t\t}\n\n\t\t\t\t\tjar[name] = cookie;\n\n\t\t\t\t\tif (key === name) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\t\t\t}\n\n\t\t\treturn key ? jar[key] : jar;\n\t\t}\n\n\t\tapi.set = set;\n\t\tapi.get = function (key) {\n\t\t\treturn get(key, false /* read as raw */);\n\t\t};\n\t\tapi.getJSON = function (key) {\n\t\t\treturn get(key, true /* read as json */);\n\t\t};\n\t\tapi.remove = function (key, attributes) {\n\t\t\tset(key, '', extend(attributes, {\n\t\t\t\texpires: -1\n\t\t\t}));\n\t\t};\n\n\t\tapi.defaults = {};\n\n\t\tapi.withConverter = init;\n\n\t\treturn api;\n\t}\n\n\treturn init(function () {});\n}));\n","import Cookie from 'js-cookie';\nimport objectHelper from '../object';\nfunction CookieStorage() {}\n\nCookieStorage.prototype.getItem = function(key) {\n return Cookie.get(key);\n};\n\nCookieStorage.prototype.removeItem = function(key) {\n Cookie.remove(key);\n};\n\nCookieStorage.prototype.setItem = function(key, value, options) {\n var params = objectHelper.extend(\n {\n expires: 1 // 1 day\n },\n options\n );\n Cookie.set(key, value, params);\n};\n\nexport default CookieStorage;\n","/* eslint-disable no-console */\n\nfunction Warn(options) {\n this.disableWarnings = options.disableWarnings;\n}\n\nWarn.prototype.warning = function(message) {\n if (this.disableWarnings) {\n return;\n }\n\n console.warn(message);\n};\n\nexport default Warn;\n","import windowHandler from '../window';\nimport DummyStorage from './dummy';\nimport CookieStorage from './cookie';\nimport Warn from '../warn';\n\nfunction StorageHandler(options) {\n this.warn = new Warn({});\n this.storage = new CookieStorage();\n if (options.__tryLocalStorageFirst !== true) {\n return;\n }\n try {\n // some browsers throw an error when trying to access localStorage\n // when localStorage is disabled.\n var localStorage = windowHandler.getWindow().localStorage;\n if (localStorage) {\n this.storage = localStorage;\n }\n } catch (e) {\n this.warn.warning(e);\n this.warn.warning(\"Can't use localStorage. Using CookieStorage instead.\");\n }\n}\n\nStorageHandler.prototype.failover = function() {\n if (this.storage instanceof DummyStorage) {\n this.warn.warning('DummyStorage: ignore failover');\n return;\n } else if (this.storage instanceof CookieStorage) {\n this.warn.warning('CookieStorage: failing over DummyStorage');\n this.storage = new DummyStorage();\n } else {\n this.warn.warning('LocalStorage: failing over CookieStorage');\n this.storage = new CookieStorage();\n }\n};\n\nStorageHandler.prototype.getItem = function(key) {\n try {\n return this.storage.getItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.getItem(key);\n }\n};\n\nStorageHandler.prototype.removeItem = function(key) {\n try {\n return this.storage.removeItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.removeItem(key);\n }\n};\n\nStorageHandler.prototype.setItem = function(key, value, options) {\n try {\n return this.storage.setItem(key, value, options);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.setItem(key, value, options);\n }\n};\n\nexport default StorageHandler;\n","import StorageHandler from './storage/handler';\n\nfunction Storage(options) {\n this.handler = new StorageHandler(options);\n}\n\nStorage.prototype.getItem = function(key) {\n var value = this.handler.getItem(key);\n try {\n return JSON.parse(value);\n } catch (_) {\n return value;\n }\n};\nStorage.prototype.removeItem = function(key) {\n return this.handler.removeItem(key);\n};\nStorage.prototype.setItem = function(key, value, options) {\n var json = JSON.stringify(value);\n return this.handler.setItem(key, json, options);\n};\n\nexport default Storage;\n","import Storage from './storage';\n\nfunction SSODataStorage(options) {\n this.storage = new Storage(options);\n}\n\nSSODataStorage.prototype.set = function(connection, sub) {\n var ssodata = {\n lastUsedConnection: connection,\n lastUsedSub: sub\n };\n this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata));\n};\nSSODataStorage.prototype.get = function() {\n var ssodata = this.storage.getItem('auth0.ssodata');\n if (!ssodata) {\n return;\n }\n return JSON.parse(ssodata);\n};\n\nexport default SSODataStorage;\n","function buildResponse(error, description) {\n return {\n error: error,\n errorDescription: description\n };\n}\n\nfunction invalidToken(description) {\n return buildResponse('invalid_token', description);\n}\n\nexport default {\n buildResponse: buildResponse,\n invalidToken: invalidToken\n};\n","import error from './error';\nimport objectHelper from './object';\n\nfunction wrapCallback(cb, options) {\n options = options || {};\n options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false;\n\n return function(err, data) {\n var errObj;\n\n if (!err && !data) {\n return cb(error.buildResponse('generic_error', 'Something went wrong'));\n }\n\n if (!err && data.err) {\n err = data.err;\n data = null;\n }\n\n if (!err && data.error) {\n err = data;\n data = null;\n }\n\n if (err) {\n errObj = {\n original: err\n };\n\n objectHelper.updatePropertyOn(\n errObj,\n 'original.response.req._data.password',\n '*****'\n );\n\n if (err.response && err.response.statusCode) {\n errObj.statusCode = err.response.statusCode;\n }\n\n if (err.response && err.response.statusText) {\n errObj.statusText = err.response.statusText;\n }\n\n if (err.response && err.response.body) {\n err = err.response.body;\n }\n\n if (err.err) {\n err = err.err;\n }\n\n errObj.code =\n err.code || err.error || err.error_code || err.status || null;\n\n errObj.description =\n err.errorDescription ||\n err.error_description ||\n err.description ||\n err.error ||\n err.details ||\n err.err ||\n null;\n\n if (options.forceLegacyError) {\n errObj.error = errObj.code;\n errObj.error_description = errObj.description;\n }\n\n if (err.error_codes && err.error_details) {\n errObj.errorDetails = {\n codes: err.error_codes,\n details: err.error_details\n };\n }\n\n if (err.name) {\n errObj.name = err.name;\n }\n\n if (err.policy) {\n errObj.policy = err.policy;\n }\n\n return cb(errObj);\n }\n\n if (\n data.type &&\n (data.type === 'text/html' || data.type === 'text/plain')\n ) {\n return cb(null, data.text);\n }\n\n if (options.ignoreCasing) {\n return cb(null, data.body || data);\n }\n\n return cb(\n null,\n objectHelper.toCamelCase(data.body || data, [], {\n keepOriginal: options.keepOriginalCasing\n })\n );\n };\n}\n\nexport default wrapCallback;\n","// For future reference:,\n// The only parameters that should be allowed are parameters\n// defined by the specification, or existing parameters that we\n// need for compatibility\n\nimport objectHelper from './object';\n\nvar tokenParams = [\n // auth0\n 'realm',\n 'audience',\n 'otp',\n // oauth2\n 'client_id',\n 'client_secret',\n 'redirect_uri',\n 'scope',\n 'code',\n 'grant_type',\n 'username',\n 'password',\n 'refresh_token',\n 'assertion',\n 'client_assertion',\n 'client_assertion_type',\n 'code_verifier'\n];\n\nvar authorizeParams = [\n // auth0\n 'connection',\n 'connection_scope',\n 'auth0Client',\n 'owp',\n 'device',\n 'realm',\n\n 'protocol',\n '_csrf',\n '_intstate',\n 'login_ticket',\n\n // oauth2\n 'client_id',\n 'response_type',\n 'response_mode',\n 'redirect_uri',\n 'audience',\n 'scope',\n 'state',\n 'nonce',\n 'display',\n 'prompt',\n 'screen_hint',\n 'max_age',\n 'ui_locales',\n 'claims_locales',\n 'id_token_hint',\n 'login_hint',\n 'acr_values',\n 'claims',\n 'registration',\n 'request',\n 'request_uri',\n 'code_challenge',\n 'code_challenge_method',\n\n // ADDITIONAL_PARAMETERS:\n // https://auth0.com/docs/api/authentication?javascript#social\n 'access_type',\n 'display'\n];\n\nfunction oauthAuthorizeParams(warn, params) {\n var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams);\n\n if (notAllowed.length > 0) {\n warn.warning(\n 'Following parameters are not allowed on the `/authorize` endpoint: [' +\n notAllowed.join(',') +\n ']'\n );\n }\n\n return params;\n}\n\nfunction oauthTokenParams(warn, params) {\n return objectHelper.pick(params, tokenParams);\n}\n\nexport default {\n oauthTokenParams: oauthTokenParams,\n oauthAuthorizeParams: oauthAuthorizeParams\n};\n","var t=\"undefined\"!=typeof globalThis?globalThis:\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error(\"Dynamic requires are not currently supported by @rollup/plugin-commonjs\")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return\"function\"==typeof t}var r=Array.isArray?Array.isArray:function(t){return\"[object Array]\"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h=\"undefined\"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f=\"undefined\"==typeof self&&\"undefined\"!=typeof process&&\"[object process]\"==={}.toString.call(process),c=\"undefined\"!=typeof Uint8ClampedArray&&\"undefined\"!=typeof importScripts&&\"undefined\"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error(\"Malformed UTF-8 data\")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){\"string\"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)}),o=e(function(t,e){var r,n;t.exports=(r=(n=i).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join(\"\")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\"},n.enc.Base64)}),s=e(function(t,e){t.exports=i.enc.Hex}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&(\"number\"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&\"string\"!=typeof t?256:e))}function i(){return new r(null)}var n=\"undefined\"!=typeof navigator;n&&\"Microsoft Internet Explorer\"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&\"Netscape\"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?\"-\"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return\"-\"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:\"0\"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return\"0\";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h=\"\";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if(\"number\"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error(\"Invalid key data\");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\\s\\n]]/gi,\"\");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error(\"Signature does not match with the key modulus.\");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,\"\"));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error(\"Hashing algorithm is not supported.\");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,d=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",m=0,v=d.length;m0)throw new Error(\"Invalid string. Length must be a multiple of 4\");var r=t.indexOf(\"=\");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join(\"=\")}function w(t){return t=g(t).replace(/\\-/g,\"+\").replace(/_/g,\"/\"),decodeURIComponent(function(t){for(var e=\"\",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\\/\\/\\//)?t[0].replace(/^([^/:]+):\\/*/,\"$1:///\"):t[0].replace(/^([^/:]+):\\/*/,\"$1://\");for(var i=0;i0&&(n=n.replace(/^[\\/]+/,\"\")),n=n.replace(/[\\/]+$/,i0?\"?\":\"\")+s.join(\"&\")}return function(){return t(\"object\"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||\"get\",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\\S\\n]*([\\s\\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+\",\"+r:r}),r(a())},n.onerror=i,n.withCredentials=\"include\"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name=\"ConfigurationError\",this.message=t||\"\"}function A(t){this.name=\"TokenValidationError\",this.message=t||\"\"}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return\"number\"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||\"RS256\",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock=\"function\"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D(\"The leeway should be positive and lower than five minutes.\");if(\"RS256\"!==this.expectedAlg)throw new D('Signature algorithm of \"'+this.expectedAlg+'\" is not supported. Expected the ID token to be signed with \"RS256\".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A(\"ID token is required but missing\"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A(\"ID token could not be decoded\"),!1);var n=i.encoded.header+\".\"+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of \"'+s+'\" is not supported. Expected the ID token to be signed with \"RS256\".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A(\"Invalid ID token signature.\"));if(!f||\"string\"!=typeof f)return r(new A(\"Issuer (iss) claim must be a string present in the ID token\",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected \"'+g.issuer+'\", found \"'+f+'\"'),!1);if(!u||\"string\"!=typeof u)return r(new A(\"Subject (sub) claim must be a string present in the ID token\"),!1);if(!a||\"string\"!=typeof a&&!Array.isArray(a))return r(new A(\"Audience (aud) claim must be a string or array of strings present in the ID token\"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but was not one of \"'+a.join(\", \")+'\"'));if(\"string\"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but found \"'+a+'\"'),!1);if(e){if(!v||\"string\"!=typeof v)return r(new A(\"Nonce (nonce) claim must be a string present in the ID token\"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected \"'+e+'\", found \"'+v+'\"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||\"string\"!=typeof d)return r(new A(\"Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values\",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected \"'+g.audience+'\", found \"'+d+'\"',!1))}if(!c||!x(c))return r(new A(\"Expiration Time (exp) claim must be a number present in the ID token\",!1));if(!l||!x(l))return r(new A(\"Issued At (iat) claim must be a number present in the ID token\"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time \"'+y+'\" is after expiration time \"'+w+'\"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time \"'+y+'\" is after last auth time at \"'+S+'\"'))}return r(null,i.payload)})},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},(\"undefined\"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,\".well-known\",\"jwks.json\")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11\n else if (ua.indexOf(\"Trident\") > -1) {\n var re = new RegExp(\"rv:([0-9]{2,2}[\\.0-9]{0,})\");\n if (re.exec(ua) !== null) {\n rv = parseFloat(RegExp.$1);\n }\n }\n\n return rv >= 8;\n }\n\n // checking Mobile Firefox (Fennec)\n function isFennec() {\n try {\n // We must check for both XUL and Java versions of Fennec. Both have\n // distinct UA strings.\n var userAgent = navigator.userAgent;\n return (userAgent.indexOf('Fennec/') != -1) || // XUL\n (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java\n } catch(e) {}\n return false;\n }\n\n // feature checking to see if this platform is supported at all\n function isSupported() {\n return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify &&\n window.JSON.parse && window.postMessage);\n }\n\n // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\n function extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[\\-_a-zA-Z\\.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n }\n\n // find the relay iframe in the opener\n function findRelay() {\n var loc = window.location;\n var frames = window.opener.frames;\n for (var i = frames.length - 1; i >= 0; i--) {\n try {\n if (frames[i].location.protocol === window.location.protocol &&\n frames[i].location.host === window.location.host &&\n frames[i].name === RELAY_FRAME_NAME)\n {\n return frames[i];\n }\n } catch(e) { }\n }\n return;\n }\n\n var isIE = isInternetExplorer();\n\n if (isSupported()) {\n /* General flow:\n * 0. user clicks\n * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM\n * 2. caller opens window (with content from trusted domain)\n * 3. window on opening adds a listener to 'message'\n * (IE SPECIFIC) 4. window on opening finds iframe\n * 5. window checks if iframe is \"loaded\" - has a 'doPost' function yet\n * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller\n * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready\n * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event\n * 6. caller upon reciept of 'ready', sends args\n */\n return {\n open: function(opts, cb) {\n if (!cb) throw \"missing required callback argument\";\n\n // test required options\n var err;\n if (!opts.url) err = \"missing required 'url' parameter\";\n if (!opts.relay_url) err = \"missing required 'relay_url' parameter\";\n if (err) setTimeout(function() { cb(err); }, 0);\n\n // supply default options\n if (!opts.window_name) opts.window_name = null;\n if (!opts.window_features || isFennec()) opts.window_features = undefined;\n\n // opts.params may be undefined\n\n var iframe;\n\n // sanity check, are url and relay_url the same origin?\n var origin = opts.origin || extractOrigin(opts.url);\n if (origin !== extractOrigin(opts.relay_url)) {\n return setTimeout(function() {\n cb('invalid arguments: origin of url and relay_url must match');\n }, 0);\n }\n\n var messageTarget;\n\n if (isIE) {\n // first we need to add a \"relay\" iframe to the document that's served\n // from the target domain. We can postmessage into a iframe, but not a\n // window\n iframe = document.createElement(\"iframe\");\n // iframe.setAttribute('name', framename);\n iframe.setAttribute('src', opts.relay_url);\n iframe.style.display = \"none\";\n iframe.setAttribute('name', RELAY_FRAME_NAME);\n document.body.appendChild(iframe);\n messageTarget = iframe.contentWindow;\n }\n\n var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features);\n if (opts.popup) {\n w.location.href = opts.url;\n }\n\n if (!messageTarget) messageTarget = w;\n\n // lets listen in case the window blows up before telling us\n var closeInterval = setInterval(function() {\n if (w && w.closed) {\n cleanup();\n if (cb) {\n cb('User closed the popup window');\n cb = null;\n }\n }\n }, 500);\n\n var req = JSON.stringify({a: 'request', d: opts.params});\n\n // cleanup on unload\n function cleanup() {\n if (iframe) document.body.removeChild(iframe);\n iframe = undefined;\n if (closeInterval) closeInterval = clearInterval(closeInterval);\n removeListener(window, 'message', onMessage);\n removeListener(window, 'unload', cleanup);\n if (w) {\n try {\n w.close();\n } catch (securityViolation) {\n // This happens in Opera 12 sometimes\n // see https://github.com/mozilla/browserid/issues/1844\n messageTarget.postMessage(CLOSE_CMD, origin);\n }\n }\n w = messageTarget = undefined;\n }\n\n addListener(window, 'unload', cleanup);\n\n function onMessage(e) {\n if (e.origin !== origin) { return; }\n try {\n var d = JSON.parse(e.data);\n } catch(err) {\n if (cb) {\n return cb(err);\n } else {\n throw err;\n }\n }\n\n if (d.a === 'ready') {\n messageTarget.postMessage(req, origin);\n } else if (d.a === 'error') {\n cleanup();\n if (cb) {\n cb(d.d);\n cb = null;\n }\n } else if (d.a === 'response') {\n cleanup();\n if (cb) {\n cb(null, d.d);\n cb = null;\n }\n }\n }\n\n addListener(window, 'message', onMessage);\n\n return {\n originalPopup: w,\n close: cleanup,\n focus: function() {\n if (w) {\n try {\n w.focus();\n } catch (e) {\n // IE7 blows up here, do nothing\n }\n }\n }\n };\n },\n onOpen: function(cb) {\n var o = \"*\";\n var msgTarget = isIE ? findRelay() : window.opener;\n if (!msgTarget) throw \"can't find relay frame\";\n function doPost(msg) {\n msg = JSON.stringify(msg);\n if (isIE) msgTarget.doPost(msg, o);\n else msgTarget.postMessage(msg, o);\n }\n\n function onMessage(e) {\n // only one message gets through, but let's make sure it's actually\n // the message we're looking for (other code may be using\n // postmessage) - we do this by ensuring the payload can\n // be parsed, and it's got an 'a' (action) value of 'request'.\n var d;\n try {\n d = JSON.parse(e.data);\n } catch(err) { }\n if (!d || d.a !== 'request') return;\n removeListener(window, 'message', onMessage);\n o = e.origin;\n if (cb) {\n // this setTimeout is critically important for IE8 -\n // in ie8 sometimes addListener for 'message' can synchronously\n // cause your callback to be invoked. awesome.\n setTimeout(function() {\n cb(o, d.d, function(r) {\n cb = undefined;\n doPost({a: 'response', d: r});\n });\n }, 0);\n }\n }\n\n function onDie(e) {\n if (e.data === CLOSE_CMD) {\n try { window.close(); } catch (o_O) {}\n }\n }\n addListener(isIE ? msgTarget : window, 'message', onMessage);\n addListener(isIE ? msgTarget : window, 'message', onDie);\n\n // we cannot post to our parent that we're ready before the iframe\n // is loaded. (IE specific possible failure)\n try {\n doPost({a: \"ready\"});\n } catch(e) {\n // this code should never be exectued outside IE\n addListener(msgTarget, 'load', function(e) {\n doPost({a: \"ready\"});\n });\n }\n\n // if window is unloaded and the client hasn't called cb, it's an error\n var onUnload = function() {\n try {\n // IE8 doesn't like this...\n removeListener(isIE ? msgTarget : window, 'message', onDie);\n } catch (ohWell) { }\n if (cb) doPost({ a: 'error', d: 'client closed window' });\n cb = undefined;\n // explicitly close the window, in case the client is trying to reload or nav\n try { window.close(); } catch (e) { }\n };\n addListener(window, 'unload', onUnload);\n return {\n detach: function() {\n removeListener(window, 'unload', onUnload);\n }\n };\n }\n };\n } else {\n return {\n open: function(url, winopts, arg, cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n },\n onOpen: function(cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n }\n };\n }\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n module.exports = WinChan;\n}\n","// given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\nfunction extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[-_a-zA-Z.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n}\n\nexport default {\n extractOrigin: extractOrigin\n};\n","/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\nimport WinChan from 'winchan';\n\nimport windowHandler from './window';\nimport objectHelper from './object';\nimport qs from 'qs';\n\nfunction PopupHandler() {\n this._current_popup = null;\n}\n\nPopupHandler.prototype.calculatePosition = function(options) {\n var width = options.width || 500;\n var height = options.height || 600;\n var _window = windowHandler.getWindow();\n\n var screenX =\n typeof _window.screenX !== 'undefined'\n ? _window.screenX\n : _window.screenLeft;\n var screenY =\n typeof _window.screenY !== 'undefined'\n ? _window.screenY\n : _window.screenTop;\n\n var outerWidth =\n typeof _window.outerWidth !== 'undefined'\n ? _window.outerWidth\n : _window.document.body.clientWidth;\n\n var outerHeight =\n typeof _window.outerHeight !== 'undefined'\n ? _window.outerHeight\n : _window.document.body.clientHeight;\n\n var left = options.left || screenX + (outerWidth - width) / 2;\n var top = options.top || screenY + (outerHeight - height) / 2;\n\n return { width: width, height: height, left: left, top: top };\n};\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n var url = options.url || 'about:blank';\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures);\n\n this._current_popup.kill = function() {\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, relayUrl, options, cb) {\n var _this = this;\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n\n var winchanOptions = objectHelper\n .merge({\n url: url,\n relay_url: relayUrl,\n window_features: qs.stringify(popupOptions, {\n delimiter: ',',\n encode: false\n }),\n popup: this._current_popup\n })\n .with(options);\n\n var popup = WinChan.open(winchanOptions, function(err, data) {\n // Ignores messages sent by browser extensions.\n if (err && err.name === 'SyntaxError') {\n return;\n }\n _this._current_popup = null;\n return cb(err, data);\n });\n\n popup.focus();\n\n return popup;\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport WinChan from 'winchan';\n\nimport urlHelper from '../helper/url';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\nimport PopupHandler from '../helper/popup-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport TransactionManager from './transaction-manager';\nimport CrossOriginAuthentication from './cross-origin-authentication';\n\nfunction Popup(webAuth, options) {\n this.baseOptions = options;\n this.baseOptions.popupOrigin = options.popupOrigin;\n this.client = webAuth.client;\n this.webAuth = webAuth;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n webAuth,\n this.baseOptions\n );\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * Returns a new instance of the popup handler\n *\n * @method buildPopupHandler\n * @private\n */\nPopup.prototype.buildPopupHandler = function() {\n var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler');\n\n if (pluginHandler) {\n return pluginHandler.getPopupHandler();\n }\n\n return new PopupHandler();\n};\n\n/**\n * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser.\n *\n * @method preload\n * @param {Object} options receives the window height and width and any other window feature to be sent to window.open\n */\nPopup.prototype.preload = function(options) {\n options = options || {};\n\n var popup = this.buildPopupHandler();\n\n popup.preload(options);\n return popup;\n};\n\n/**\n * Internal use.\n *\n * @method getPopupHandler\n * @private\n */\nPopup.prototype.getPopupHandler = function(options, preload) {\n if (options.popupHandler) {\n return options.popupHandler;\n }\n\n if (preload) {\n return this.preload(options);\n }\n\n return this.buildPopupHandler();\n};\n\n/**\n * Handles the popup logic for the callback page.\n *\n * @method callback\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @see {@link parseHash}\n */\nPopup.prototype.callback = function(options) {\n var _this = this;\n var theWindow = windowHelper.getWindow();\n options = options || {};\n var originUrl =\n options.popupOrigin ||\n this.baseOptions.popupOrigin ||\n windowHelper.getOrigin();\n\n /*\n in IE 11, there's a bug that makes window.opener return undefined.\n The callback page will still call `popup.callback()` which will run this method\n in the relay page. WinChan expects the relay page to have a global `doPost` function,\n which will be called with the response.\n\n IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/\n */\n if (!theWindow.opener) {\n theWindow.doPost = function(msg) {\n if (theWindow.parent) {\n theWindow.parent.postMessage(msg, originUrl);\n }\n };\n return;\n }\n\n WinChan.onOpen(function(popupOrigin, r, cb) {\n if (popupOrigin !== originUrl) {\n return cb({\n error: 'origin_mismatch',\n error_description:\n \"The popup's origin (\" +\n popupOrigin +\n ') should match the `popupOrigin` parameter (' +\n originUrl +\n ').'\n });\n }\n _this.webAuth.parseHash(options || {}, function(err, data) {\n return cb(err || data);\n });\n });\n};\n\n/**\n * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`.\n *\n * @method authorize\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response.\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nPopup.prototype.authorize = function(options, cb) {\n var popup;\n var url;\n var relayUrl;\n var popOpts = {};\n\n var pluginHandler = this.baseOptions.plugins.get('popup.authorize');\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'scope',\n 'domain',\n 'audience',\n 'tenant',\n 'responseType',\n 'redirectUri',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(objectHelper.blacklist(options, ['popupHandler']));\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n // the relay page should not be necessary as long it happens in the same domain\n // (a redirectUri shoul be provided). It is necessary when using OWP\n relayUrl = urljoin(this.baseOptions.rootUrl, 'relay.html');\n\n // if a owp is enabled, it should use the owp flag\n if (options.owp) {\n // used by server to render the relay page instead of sending the chunk in the\n // url to the callback\n params.owp = true;\n } else {\n popOpts.origin = urlHelper.extractOrigin(params.redirectUri);\n relayUrl = params.redirectUri;\n }\n\n if (options.popupOptions) {\n popOpts.popupOptions = objectHelper.pick(options.popupOptions, [\n 'width',\n 'height',\n 'top',\n 'left'\n ]);\n }\n\n if (pluginHandler) {\n params = pluginHandler.processParams(params);\n }\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n delete params.domain;\n\n url = this.client.buildAuthorizeUrl(params);\n\n popup = this.getPopupHandler(options);\n\n return popup.load(\n url,\n relayUrl,\n popOpts,\n responseHandler(cb, { keepOriginalCasing: true })\n );\n};\n\n/**\n * Performs authentication with username/email and password with a database connection inside a new window\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method loginWithCredentials\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`.\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nPopup.prototype.loginWithCredentials = function(options, cb) {\n options.realm = options.realm || options.connection;\n options.popup = true;\n options = objectHelper\n .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce'])\n .with(objectHelper.blacklist(options, ['popupHandler', 'connection']));\n options = this.transactionManager.process(options);\n this.crossOriginAuthentication.login(options, cb);\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nPopup.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n return this.client.passwordless.verify(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n\n options.username = options.phoneNumber || options.email;\n options.password = options.verificationCode;\n\n delete options.email;\n delete options.phoneNumber;\n delete options.verificationCode;\n delete options.type;\n\n _this.client.loginWithResourceOwner(options, cb);\n }\n );\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link signupAndAuthorize}.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nPopup.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n _this.loginWithCredentials(options, cb);\n });\n};\n\nexport default Popup;\n","import IframeHandler from '../helper/iframe-handler';\nimport windowHelper from '../helper/window';\n\nfunction SilentAuthenticationHandler(options) {\n this.authenticationUrl = options.authenticationUrl;\n this.timeout = options.timeout || 60 * 1000;\n this.handler = null;\n this.postMessageDataType = options.postMessageDataType || false;\n\n // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually\n this.postMessageOrigin =\n options.postMessageOrigin ||\n windowHelper.getWindow().location.origin ||\n windowHelper.getWindow().location.protocol +\n '//' +\n windowHelper.getWindow().location.hostname +\n (windowHelper.getWindow().location.port\n ? ':' + windowHelper.getWindow().location.port\n : '');\n}\n\nSilentAuthenticationHandler.create = function(options) {\n return new SilentAuthenticationHandler(options);\n};\n\nSilentAuthenticationHandler.prototype.login = function(\n usePostMessage,\n callback\n) {\n this.handler = new IframeHandler({\n auth0: this.auth0,\n url: this.authenticationUrl,\n eventListenerType: usePostMessage ? 'message' : 'load',\n callback: this.getCallbackHandler(callback, usePostMessage),\n timeout: this.timeout,\n eventValidator: this.getEventValidator(),\n timeoutCallback: function() {\n callback(\n null,\n '#error=timeout&error_description=Timeout+during+authentication+renew.'\n );\n },\n usePostMessage: usePostMessage || false\n });\n\n this.handler.init();\n};\n\nSilentAuthenticationHandler.prototype.getEventValidator = function() {\n var _this = this;\n return {\n isValid: function(eventData) {\n switch (eventData.event.type) {\n case 'message':\n // Message must come from the expected origin and iframe window.\n if (\n eventData.event.origin !== _this.postMessageOrigin ||\n eventData.event.source !== _this.handler.iframe.contentWindow\n ) {\n return false;\n }\n\n // Default behaviour, return all message events from the iframe.\n if (_this.postMessageDataType === false) {\n return true;\n }\n\n return (\n eventData.event.data.type &&\n eventData.event.data.type === _this.postMessageDataType\n );\n\n case 'load':\n if (\n eventData.sourceObject.contentWindow.location.protocol === 'about:'\n ) {\n // Chrome is automatically loading the about:blank page, we ignore this.\n return false;\n }\n // Fall through to default\n default:\n return true;\n }\n }\n };\n};\n\nSilentAuthenticationHandler.prototype.getCallbackHandler = function(\n callback,\n usePostMessage\n) {\n return function(eventData) {\n var callbackValue;\n if (!usePostMessage) {\n callbackValue = eventData.sourceObject.contentWindow.location.hash;\n } else if (\n typeof eventData.event.data === 'object' &&\n eventData.event.data.hash\n ) {\n callbackValue = eventData.event.data.hash;\n } else {\n callbackValue = eventData.event.data;\n }\n callback(null, callbackValue);\n };\n};\n\nexport default SilentAuthenticationHandler;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport windowHelper from '../helper/window';\nimport TransactionManager from './transaction-manager';\n\nfunction UsernamePassword(options) {\n this.baseOptions = options;\n this.request = new RequestBuilder(options);\n this.transactionManager = new TransactionManager(this.baseOptions);\n}\n\nUsernamePassword.prototype.login = function(options, cb) {\n var url;\n var body;\n\n url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'login');\n\n options.username = options.username || options.email; // eslint-disable-line\n\n options = objectHelper.blacklist(options, ['email']); // eslint-disable-line\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience'\n ])\n .with(options);\n body = this.transactionManager.process(body);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nUsernamePassword.prototype.callback = function(formHtml) {\n var div;\n var form;\n var _document = windowHelper.getDocument();\n\n div = _document.createElement('div');\n div.innerHTML = formHtml;\n form = _document.body.appendChild(div).children[0];\n\n form.submit();\n};\n\nexport default UsernamePassword;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport UsernamePassword from './username-password';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport assert from '../helper/assert';\n\nfunction HostedPages(client, options) {\n this.baseOptions = options;\n this.client = client;\n this.baseOptions.universalLoginPage = true;\n this.request = new RequestBuilder(this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * @callback credentialsCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the AuthN request\n * @param {String} result.accessToken token that can be used with {@link userinfo}\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Performs authentication with username/email and password with a database connection\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method login\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.login = function(options, cb) {\n if (windowHelper.getWindow().location.host !== this.baseOptions.domain) {\n throw new Error(\n 'This method is meant to be used only inside the Universal Login Page.'\n );\n }\n var usernamePassword;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n usernamePassword = new UsernamePassword(this.baseOptions);\n return usernamePassword.login(params, function(err, data) {\n if (err) {\n return cb(err);\n }\n return usernamePassword.callback(data);\n });\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n return _this.client.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n return _this.login(options, cb);\n });\n};\n\nHostedPages.prototype.getSSOData = function(withActiveDirectories, cb) {\n var url;\n var params = '';\n\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n withActiveDirectories = false;\n }\n\n assert.check(withActiveDirectories, {\n type: 'boolean',\n message: 'withActiveDirectories parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (withActiveDirectories) {\n params =\n '?' +\n qs.stringify({\n ldaps: 1,\n client_id: this.baseOptions.clientID\n });\n }\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'ssodata', params);\n\n return this.request\n .get(url, { noHeaders: true })\n .withCredentials()\n .end(responseHandler(cb));\n};\n\nexport default HostedPages;\n","// eslint-disable-next-line no-unused-vars\nimport Authentication from '../authentication';\nimport object from '../helper/object';\n\nvar noop = function () { };\n\nvar defaults = {\n lang: 'en',\n templates: {\n 'auth0': function (challenge) {\n var message = challenge.type === 'code' ?\n 'Enter the code shown above' :\n 'Solve the formula shown above';\n return '
\\n' +\n ' \\n' +\n ' \\n' +\n '
\\n' +\n '';\n }\n ,\n 'recaptcha_v2': function () {\n return '
';\n }\n ,\n 'error': function () {\n return '
Error getting the bot detection challenge. Please contact the system administrator.
'\n }\n }\n};\n\nfunction handleAuth0Provider(element, options, challenge, load) {\n element.innerHTML = options.templates[challenge.provider](challenge);\n element.querySelector('.captcha-reload').addEventListener('click', function (e) {\n e.preventDefault();\n load();\n });\n}\n\nfunction injectRecaptchaScript(element, lang, callback) {\n var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001);\n window[callbackName] = function () {\n delete window[callbackName];\n callback();\n };\n var script = window.document.createElement('script');\n script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName;\n script.async = true;\n window.document.body.appendChild(script);\n}\n\nfunction handleRecaptchaProvider(element, options, challenge) {\n var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid');\n\n function setValue(value) {\n var input = element.querySelector('input[name=\"captcha\"]');\n input.value = value || '';\n }\n\n if (widgetId) {\n setValue();\n window.grecaptcha.reset(widgetId);\n return;\n }\n\n element.innerHTML = options.templates[challenge.provider](challenge);\n\n var recaptchaDiv = element.querySelector('.recaptcha');\n\n injectRecaptchaScript(element, options.lang, function () {\n widgetId = window.grecaptcha.render(recaptchaDiv, {\n callback: setValue,\n 'expired-callback': function () { setValue(); },\n 'error-callback': function () { setValue(); },\n sitekey: challenge.siteKey\n });\n element.setAttribute('data-wid', widgetId)\n });\n}\n\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n *\n * @param {Authentication} auth0Client The challenge response from the authentication server\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha*\n * @param {Function} [callback] an optional callback function\n */\nfunction render(auth0Client, element, options, callback) {\n options = object.merge(defaults).with(options || {});\n\n function load(done) {\n done = done || noop;\n auth0Client.getChallenge(function (err, challenge) {\n if (err) {\n element.innerHTML = options.templates.error(err);\n return done(err);\n }\n if (!challenge.required) {\n element.style.display = 'none';\n element.innerHTML = '';\n return;\n }\n element.style.display = '';\n if (challenge.provider === 'auth0') {\n handleAuth0Provider(element, options, challenge, load);\n } else if (challenge.provider === 'recaptcha_v2') {\n handleRecaptchaProvider(element, options, challenge);\n }\n done();\n });\n }\n\n function getValue() {\n var captchaInput = element.querySelector('input[name=\"captcha\"]');\n if (!captchaInput) { return; }\n return captchaInput.value;\n }\n\n load(callback);\n\n return {\n reload: load,\n getValue: getValue\n };\n}\n\nexport default { render: render };\n","import IdTokenVerifier from 'idtoken-verifier';\nimport qs from 'qs';\n\nimport assert from '../helper/assert';\nimport error from '../helper/error';\nimport PluginHandler from '../helper/plugins';\nimport windowHelper from '../helper/window';\nimport objectHelper from '../helper/object';\nimport SSODataStorage from '../helper/ssodata';\nimport responseHandler from '../helper/response-handler';\nimport TransactionManager from './transaction-manager';\nimport Authentication from '../authentication';\nimport Redirect from './redirect';\nimport Popup from './popup';\nimport SilentAuthenticationHandler from './silent-authentication-handler';\nimport CrossOriginAuthentication from './cross-origin-authentication';\nimport WebMessageHandler from './web-message-handler';\nimport HostedPages from './hosted-pages';\nimport captcha from './captcha';\n\nfunction defaultClock() {\n return new Date();\n}\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds.\n * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server.\n * @param {Array} [options.plugins]\n * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js}\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction WebAuth(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n popupOrigin: {\n optional: true,\n type: 'string',\n message: 'popupOrigin is not valid'\n },\n leeway: {\n optional: true,\n type: 'number',\n message: 'leeway is not valid'\n },\n plugins: {\n optional: true,\n type: 'array',\n message: 'plugins is not valid'\n },\n maxAge: {\n optional: true,\n type: 'number',\n message: 'maxAge is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n _timesToRetryFailedRequests: {\n optional: true,\n type: 'number',\n message: '_timesToRetryFailedRequests option is not valid'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(\n options.overrides,\n { type: 'object', message: 'overrides option is not valid' },\n {\n __tenant: {\n optional: true,\n type: 'string',\n message: '__tenant option is required'\n },\n __token_issuer: {\n optional: true,\n type: 'string',\n message: '__token_issuer option is required'\n },\n __jwks_uri: {\n optional: true,\n type: 'string',\n message: '__jwks_uri is required'\n }\n }\n );\n }\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions.plugins = new PluginHandler(\n this,\n this.baseOptions.plugins || []\n );\n\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n\n this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests\n ? parseInt(options._timesToRetryFailedRequests, 0)\n : 0;\n\n this.baseOptions.tenant =\n (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) ||\n this.baseOptions.domain.split('.')[0];\n\n this.baseOptions.token_issuer =\n (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) ||\n 'https://' + this.baseOptions.domain + '/';\n\n this.baseOptions.jwksURI =\n this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n\n this.client = new Authentication(this.baseOptions);\n this.redirect = new Redirect(this, this.baseOptions);\n this.popup = new Popup(this, this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n this,\n this.baseOptions\n );\n this.webMessageHandler = new WebMessageHandler(this);\n this._universalLogin = new HostedPages(this, this.baseOptions);\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method parseHash\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType.\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.parseHash = function(options, cb) {\n var parsedQs;\n var err;\n\n if (!cb && typeof options === 'function') {\n cb = options;\n options = {};\n } else {\n options = options || {};\n }\n\n var _window = windowHelper.getWindow();\n\n var hashStr =\n options.hash === undefined ? _window.location.hash : options.hash;\n hashStr = hashStr.replace(/^#?\\/?/, '');\n\n parsedQs = qs.parse(hashStr);\n\n if (parsedQs.hasOwnProperty('error')) {\n err = error.buildResponse(parsedQs.error, parsedQs.error_description);\n\n if (parsedQs.state) {\n err.state = parsedQs.state;\n }\n\n return cb(err);\n }\n\n if (\n !parsedQs.hasOwnProperty('access_token') &&\n !parsedQs.hasOwnProperty('id_token') &&\n !parsedQs.hasOwnProperty('refresh_token')\n ) {\n return cb(null, null);\n }\n var responseTypes = (\n this.baseOptions.responseType ||\n options.responseType ||\n ''\n ).split(' ');\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('token') !== -1 &&\n !parsedQs.hasOwnProperty('access_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `token`, but the parsed hash does not contain an `access_token` property'\n )\n );\n }\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('id_token') !== -1 &&\n !parsedQs.hasOwnProperty('id_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property'\n )\n );\n }\n return this.validateAuthenticationResponse(options, parsedQs, cb);\n};\n\n/**\n * Validates an Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method validateAuthenticationResponse\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {Object} parsedHash an object that represents the parsed hash\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.validateAuthenticationResponse = function(\n options,\n parsedHash,\n cb\n) {\n var _this = this;\n options.__enableIdPInitiatedLogin =\n options.__enableIdPInitiatedLogin || options.__enableImpersonation;\n var state = parsedHash.state;\n var transaction = this.transactionManager.getStoredTransaction(state);\n var transactionState =\n options.state || (transaction && transaction.state) || null;\n\n var transactionStateMatchesState = transactionState === state;\n var shouldBypassStateChecking =\n !state && !transactionState && options.__enableIdPInitiatedLogin;\n\n if (!shouldBypassStateChecking && !transactionStateMatchesState) {\n return cb({\n error: 'invalid_token',\n errorDescription: '`state` does not match.'\n });\n }\n var transactionNonce =\n options.nonce || (transaction && transaction.nonce) || null;\n\n var appState = options.state || (transaction && transaction.appState) || null;\n\n var callback = function(err, payload) {\n if (err) {\n return cb(err);\n }\n if (transaction && transaction.lastUsedConnection) {\n var sub;\n if (payload) {\n sub = payload.sub;\n }\n _this.ssodataStorage.set(transaction.lastUsedConnection, sub);\n }\n return cb(null, buildParseHashResponse(parsedHash, appState, payload));\n };\n\n if (!parsedHash.id_token) {\n return callback(null, null);\n }\n return this.validateToken(parsedHash.id_token, transactionNonce, function(\n validationError,\n payload\n ) {\n if (!validationError) {\n if (!parsedHash.access_token) {\n return callback(null, payload);\n }\n // id_token's generated by non-oidc applications don't have at_hash\n if (!payload.at_hash) {\n return callback(null, payload);\n }\n // here we're absolutely sure that the id_token's alg is RS256\n // and that the id_token is valid, so we can check the access_token\n return new IdTokenVerifier().validateAccessToken(\n parsedHash.access_token,\n 'RS256',\n payload.at_hash,\n function(err) {\n if (err) {\n return callback(error.invalidToken(err.message));\n }\n return callback(null, payload);\n }\n );\n }\n\n if (\n validationError.error !== 'invalid_token' ||\n (validationError.errorDescription &&\n validationError.errorDescription.indexOf(\n 'Nonce (nonce) claim value mismatch in the ID token'\n ) > -1)\n ) {\n return callback(validationError);\n }\n\n // if it's an invalid_token error, decode the token\n var decodedToken = new IdTokenVerifier().decode(parsedHash.id_token);\n\n // if the alg is not HS256, return the raw error\n if (decodedToken.header.alg !== 'HS256') {\n return callback(validationError);\n }\n\n if ((decodedToken.payload.nonce || null) !== transactionNonce) {\n return callback({\n error: 'invalid_token',\n errorDescription:\n 'Nonce (nonce) claim value mismatch in the ID token; expected \"' +\n transactionNonce +\n '\", found \"' +\n decodedToken.payload.nonce +\n '\"'\n });\n }\n\n if (!parsedHash.access_token) {\n var noAccessTokenError = {\n error: 'invalid_token',\n description:\n 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token'\n };\n return callback(noAccessTokenError);\n }\n\n // if the alg is HS256, use the /userinfo endpoint to build the payload\n return _this.client.userInfo(parsedHash.access_token, function(\n errUserInfo,\n profile\n ) {\n // if the /userinfo request fails, use the validationError instead\n if (errUserInfo) {\n return callback(errUserInfo);\n }\n return callback(null, profile);\n });\n });\n};\n\nfunction buildParseHashResponse(qsParams, appState, token) {\n return {\n accessToken: qsParams.access_token || null,\n idToken: qsParams.id_token || null,\n idTokenPayload: token || null,\n appState: appState || null,\n refreshToken: qsParams.refresh_token || null,\n state: qsParams.state || null,\n expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null,\n tokenType: qsParams.token_type || null,\n scope: qsParams.scope || null\n };\n}\n\n/**\n * @callback validateTokenCallback\n * @param {Error} [err] error returned by while validating the token\n * @param {Object} [payload] claims stored in the token\n */\n\n/**\n * Decodes the a JWT and verifies its nonce value\n *\n * @method validateToken\n * @private\n * @param {String} token\n * @param {String} nonce\n * @param {validateTokenCallback} cb\n */\nWebAuth.prototype.validateToken = function(token, nonce, cb) {\n var verifier = new IdTokenVerifier({\n issuer: this.baseOptions.token_issuer,\n jwksURI: this.baseOptions.jwksURI,\n audience: this.baseOptions.clientID,\n leeway: this.baseOptions.leeway || 60,\n maxAge: this.baseOptions.maxAge,\n __clock: this.baseOptions.__clock || defaultClock\n });\n\n verifier.verify(token, nonce, function(err, payload) {\n if (err) {\n return cb(error.invalidToken(err.message));\n }\n\n cb(null, payload);\n });\n};\n\n/**\n * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session.\n * This method requires that all Auth is performed with {@link authorize}\n * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method.\n *\n * @method renewAuth\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback.\n * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy.\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.renewAuth = function(options, cb) {\n var handler;\n var usePostMessage = !!options.usePostMessage;\n var postMessageDataType = options.postMessageDataType || false;\n var postMessageOrigin =\n options.postMessageOrigin || windowHelper.getWindow().origin;\n var timeout = options.timeout;\n var _this = this;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'responseType',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n params.responseType = params.responseType || 'token';\n params.responseMode = params.responseMode || 'fragment';\n params = this.transactionManager.process(params);\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params.prompt = 'none';\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType',\n 'postMessageOrigin'\n ]);\n\n handler = SilentAuthenticationHandler.create({\n authenticationUrl: this.client.buildAuthorizeUrl(params),\n postMessageDataType: postMessageDataType,\n postMessageOrigin: postMessageOrigin,\n timeout: timeout\n });\n\n handler.login(usePostMessage, function(err, hash) {\n if (typeof hash === 'object') {\n // hash was already parsed, so we just return it.\n // it's here to be backwards compatible and should be removed in the next major version.\n return cb(err, hash);\n }\n _this.parseHash({ hash: hash }, cb);\n });\n};\n\n/**\n * Renews an existing session on Auth0's servers using `response_mode=web_message`\n *\n * @method checkSession\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {checkSessionCallback} cb\n * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens}\n */\nWebAuth.prototype.checkSession = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n if (params.responseType === 'code') {\n return cb({\n error: 'error',\n error_description: \"responseType can't be `code`\"\n });\n }\n\n if (!options.nonce) {\n params = this.transactionManager.process(params);\n }\n\n if (!params.redirectUri) {\n return cb({\n error: 'error',\n error_description: \"redirectUri can't be empty\"\n });\n }\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType'\n ]);\n this.webMessageHandler.run(\n params,\n responseHandler(cb, { forceLegacyError: true, ignoreCasing: true })\n );\n};\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nWebAuth.prototype.changePassword = function(options, cb) {\n return this.client.dbConnection.changePassword(options, cb);\n};\n\n/**\n * Starts a passwordless authentication transaction.\n *\n * @method passwordlessStart\n * @param {Object} options\n * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid\n * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email`\n * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber`\n * @param {String} options.connection name of the passwordless connection\n * @param {Object} [options.authParams] additional Auth parameters when using `link`\n * @param {Function} cb\n * @see {@link https://auth0.com/docs/api/authentication#passwordless}\n */\nWebAuth.prototype.passwordlessStart = function(options, cb) {\n var authParams = objectHelper\n .merge(this.baseOptions, [\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options.authParams);\n\n options.authParams = this.transactionManager.process(authParams);\n return this.client.passwordless.start(options, cb);\n};\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nWebAuth.prototype.signup = function(options, cb) {\n return this.client.dbConnection.signup(options, cb);\n};\n\n/**\n * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction.\n * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`.\n *\n * @method authorize\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} [options.appState] any values that you want back on the authentication response\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.authorize = function(options) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n\n windowHelper.redirect(this.client.buildAuthorizeUrl(params));\n};\n\n/**\n * Signs up a new user, automatically logs the user in after the signup and returns the user token.\n * The login will be done using /oauth/token with password-realm grant type.\n *\n * @method signupAndAuthorize\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {tokenCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n * @see {@link https://auth0.com/docs/api-auth/grant/password}\n */\nWebAuth.prototype.signupAndAuthorize = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n options.realm = options.connection;\n if (!options.username) {\n options.username = options.email;\n }\n _this.client.login(options, cb);\n }\n );\n};\n\n/**\n * @callback crossOriginLoginCallback\n * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Logs the user in with username and password using the correct flow based on where it's called from:\n * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint\n * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow\n * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`.\n * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data.\n * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.**\n *\n * @method login\n * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.username] Username (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.password Password\n * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.login = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n params.connection = params.realm;\n delete params.realm;\n this._universalLogin.login(params, cb);\n } else {\n this.crossOriginAuthentication.login(params, cb);\n }\n};\n\n/**\n * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user.\n * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor.\n *\n * @method passwordlessLogin\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.verificationCode Verification Code (OTP)\n * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'.\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.passwordlessLogin = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n this.passwordlessVerify(params, cb);\n } else {\n var crossOriginOptions = objectHelper.extend(\n {\n credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp',\n realm: params.connection,\n username: params.email || params.phoneNumber,\n otp: params.verificationCode\n },\n objectHelper.blacklist(params, [\n 'connection',\n 'email',\n 'phoneNumber',\n 'verificationCode'\n ])\n );\n this.crossOriginAuthentication.login(crossOriginOptions, cb);\n }\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginAuthenticationCallback\n * @deprecated Use {@link crossOriginVerification} instead.\n */\nWebAuth.prototype.crossOriginAuthenticationCallback = function() {\n this.crossOriginVerification();\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginVerification\n */\nWebAuth.prototype.crossOriginVerification = function() {\n this.crossOriginAuthentication.callback();\n};\n\n/**\n * Redirects to the auth0 logout endpoint\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n *\n * @method logout\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nWebAuth.prototype.logout = function(options) {\n windowHelper.redirect(this.client.buildLogoutUrl(options));\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nWebAuth.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n return this.client.passwordless.verify(params, function(err) {\n if (err) {\n return cb(err);\n }\n return windowHelper.redirect(\n _this.client.passwordless.buildVerifyUrl(params)\n );\n });\n};\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n * This function can only be used in the context of a Classic Universal Login Page.\n *\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha\n * @param {Function} [callback] An optional completion callback\n */\nWebAuth.prototype.renderCaptcha = function(element, options, callback) {\n return captcha.render(this.client, element, options, callback);\n};\n\nexport default WebAuth;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport qs from 'qs';\nimport responseHandler from '../helper/response-handler';\n\nfunction PasswordlessAuthentication(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\nPasswordlessAuthentication.prototype.buildVerifyUrl = function(options) {\n var params;\n var qString;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'protocol',\n 'nonce'\n ])\n .with(options);\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n\n qString = qs.stringify(params);\n\n return urljoin(\n this.baseOptions.rootUrl,\n 'passwordless',\n 'verify_redirect',\n '?' + qString\n );\n};\n\nPasswordlessAuthentication.prototype.start = function(options, cb) {\n var url;\n var body;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n send: {\n type: 'string',\n message: 'send option is required',\n values: ['link', 'code'],\n value_message: 'send is not valid ([link, code])'\n },\n phoneNumber: {\n optional: true,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return o.send === 'code' || !o.email;\n }\n },\n email: {\n optional: true,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return o.send === 'link' || !o.phoneNumber;\n }\n },\n authParams: {\n optional: true,\n type: 'object',\n message: 'authParams option is required'\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'start');\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope'\n ])\n .with(options);\n\n if (body.scope) {\n body.authParams = body.authParams || {};\n body.authParams.scope = body.authParams.scope || body.scope;\n }\n\n if (body.redirectUri) {\n body.authParams = body.authParams || {};\n body.authParams.redirect_uri =\n body.authParams.redirectUri || body.redirectUri;\n }\n\n if (body.responseType) {\n body.authParams = body.authParams || {};\n body.authParams.response_type =\n body.authParams.responseType || body.responseType;\n }\n\n delete body.redirectUri;\n delete body.responseType;\n delete body.scope;\n\n body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nPasswordlessAuthentication.prototype.verify = function(options, cb) {\n var url;\n var cleanOption;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n cleanOption = objectHelper.pick(options, [\n 'connection',\n 'verificationCode',\n 'phoneNumber',\n 'email',\n 'auth0Client'\n ]);\n cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']);\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'verify');\n\n return this.request\n .post(url)\n .send(cleanOption)\n .end(responseHandler(cb));\n};\n\nexport default PasswordlessAuthentication;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\nfunction DBConnection(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\n/**\n * @callback signUpCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the signup failed\n * @param {Object} [result] result of the signup request\n * @param {Object} result.email user's email\n * @param {Object} result.emailVerified if the user's email was verified\n */\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username`\n * @param {String} options.connection name of the connection where the user will be created\n * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata`\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nDBConnection.prototype.signup = function(options, cb) {\n var url;\n var body;\n var metadata;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' },\n password: { type: 'string', message: 'password option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'signup');\n\n body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options);\n\n metadata = body.user_metadata || body.userMetadata;\n\n body = objectHelper.blacklist(body, [\n 'scope',\n 'userMetadata',\n 'user_metadata'\n ]);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n if (metadata) {\n body.user_metadata = metadata;\n }\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * @callback changePasswordCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nDBConnection.prototype.changePassword = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options, ['email', 'connection']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nexport default DBConnection;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport RequestBuilder from '../helper/request-builder';\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport SSODataStorage from '../helper/ssodata';\nimport windowHelper from '../helper/window';\nimport responseHandler from '../helper/response-handler';\nimport parametersWhitelist from '../helper/parameters-whitelist';\nimport Warn from '../helper/warn';\nimport WebAuth from '../web-auth/index';\nimport PasswordlessAuthentication from './passwordless-authentication';\nimport DBConnection from './db-connection';\n\n/**\n * Creates a new Auth0 Authentication API client\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction Authentication(auth0, options) {\n // If we have two arguments, the first one is a WebAuth instance, so we assign that\n // if not, it's an options object and then we should use that as options instead\n // this is here because we don't want to break people coming from v8\n if (arguments.length === 2) {\n this.auth0 = auth0;\n } else {\n options = auth0;\n }\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n \n this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0)\n ? this.baseOptions.domain\n : 'https://' + this.baseOptions.domain;\n \n this.request = new RequestBuilder(this.baseOptions);\n\n this.passwordless = new PasswordlessAuthentication(\n this.request,\n this.baseOptions\n );\n this.dbConnection = new DBConnection(this.request, this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction\n *\n * @method buildAuthorizeUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n * @see {@link https://auth0.com/docs/api/authentication#social}\n */\nAuthentication.prototype.buildAuthorizeUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience'\n ])\n .with(options);\n\n /* eslint-disable */\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri option is required'\n },\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n },\n nonce: {\n type: 'string',\n message: 'nonce option is required',\n condition: function(o) {\n return (\n o.responseType.indexOf('code') === -1 &&\n o.responseType.indexOf('id_token') !== -1\n );\n }\n },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n /* eslint-enable */\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n if (params.connection_scope && assert.isArray(params.connection_scope)) {\n params.connection_scope = params.connection_scope.join(',');\n }\n\n params = objectHelper.blacklist(params, [\n 'username',\n 'popupOptions',\n 'domain',\n 'tenant',\n 'timeout',\n 'appState'\n ]);\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n params = parametersWhitelist.oauthAuthorizeParams(this.warn, params);\n\n qString = qs.stringify(params);\n\n return urljoin(this.baseOptions.rootUrl, 'authorize', '?' + qString);\n};\n\n/**\n * Builds and returns the Logout url in order to initialize a new authN/authZ transaction\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n * @method buildLogoutUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nAuthentication.prototype.buildLogoutUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n optional: true,\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options || {});\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']);\n\n qString = qs.stringify(objectHelper.blacklist(params, ['federated']));\n if (\n options &&\n options.federated !== undefined &&\n options.federated !== false &&\n options.federated !== 'false'\n ) {\n qString += '&federated';\n }\n\n return urljoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString);\n};\n\n/**\n * @callback authorizeCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null.\n * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} [result.expiresIn] number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n * @param {Object} [result.appState] values that you receive back on the authentication response\n */\n\n/**\n * @callback tokenCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request\n * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} result.expiresIn number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory.\n *\n * @method loginWithDefaultDirectory\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.loginWithDefaultDirectory = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'password';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password-realm` grant type\n *\n * @method login\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.login = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n realm: { type: 'string', message: 'realm option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'http://auth0.com/oauth/grant-type/password-realm';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint\n *\n * @method oauthToken\n * @private\n */\nAuthentication.prototype.oauthToken = function(options, cb) {\n var url;\n var body;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'token');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope', 'audience'])\n .with(options);\n\n assert.check(\n body,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n grantType: { type: 'string', message: 'grantType option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n body = parametersWhitelist.oauthTokenParams(this.warn, body);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Performs authentication calling `/oauth/ro` endpoint with username\n * and password for a given connection name.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link login} or {@link loginWithDefaultDirectory}.\n *\n * @method loginWithResourceOwner\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.device] name of the device/browser where the Auth was requested\n * @param {tokenCallback} cb function called with the result of the request\n */\nAuthentication.prototype.loginWithResourceOwner = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n connection: { type: 'string', message: 'connection option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'ro');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope'])\n .with(options, ['username', 'password', 'scope', 'connection', 'device']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n body.grant_type = body.grant_type || 'password';\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Uses {@link checkSession} and localStorage to return data from the last successful authentication request.\n *\n * @method getSSOData\n * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible\n * @param {Function} cb\n */\nAuthentication.prototype.getSSOData = function(withActiveDirectories, cb) {\n /* istanbul ignore if */\n if (!this.auth0) {\n this.auth0 = new WebAuth(this.baseOptions);\n }\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb);\n }\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n }\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n var clientId = this.baseOptions.clientID;\n var ssodataInformation = this.ssodataStorage.get() || {};\n\n this.auth0.checkSession(\n {\n responseType: 'token id_token',\n scope: 'openid profile email',\n connection: ssodataInformation.lastUsedConnection,\n timeout: 5000\n },\n function(err, result) {\n if (err) {\n if (err.error === 'login_required') {\n return cb(null, { sso: false });\n }\n if (err.error === 'consent_required') {\n err.error_description =\n 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.';\n }\n return cb(err, { sso: false });\n }\n if (\n ssodataInformation.lastUsedSub &&\n ssodataInformation.lastUsedSub !== result.idTokenPayload.sub\n ) {\n return cb(err, { sso: false });\n }\n return cb(null, {\n lastUsedConnection: {\n name: ssodataInformation.lastUsedConnection\n },\n lastUsedUserID: result.idTokenPayload.sub,\n lastUsedUsername:\n result.idTokenPayload.email || result.idTokenPayload.name,\n lastUsedClientID: clientId,\n sessionClients: [clientId],\n sso: true\n });\n }\n );\n};\n\n/**\n * @callback userInfoCallback\n * @param {Error} [err] error returned by Auth0\n * @param {Object} [userInfo] user information\n */\n\n/**\n * Makes a call to the `/userinfo` endpoint and returns the user profile\n *\n * @method userInfo\n * @param {String} accessToken token issued to a user after Auth\n * @param {userInfoCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#get-user-info}\n */\nAuthentication.prototype.userInfo = function(accessToken, cb) {\n var url;\n\n assert.check(accessToken, {\n type: 'string',\n message: 'accessToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'userinfo');\n\n return this.request\n .get(url)\n .set('Authorization', 'Bearer ' + accessToken)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Makes a call to the `/usernamepassword/challenge` endpoint\n * and returns the challenge (captcha) if necessary.\n *\n * @method getChallenge\n * @param {callback} cb\n */\nAuthentication.prototype.getChallenge = function(cb) {\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (!this.baseOptions.state) {\n return cb();\n }\n\n var url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge');\n\n return this.request\n .post(url)\n .send({ state: this.baseOptions.state })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * @callback delegationCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed\n * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used\n */\n\n/**\n * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token`\n *\n * @method delegation\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer`\n * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required\n * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required\n * @param {String} [options.target] the target ClientID of the delegation\n * @param {String} [options.scope] either `openid` or `openid profile email`\n * @param {String} [options.apiType] the api to be called\n * @param {delegationCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#delegation}\n * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.delegation = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n grant_type: { type: 'string', message: 'grant_type option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'delegation');\n\n body = objectHelper.merge(this.baseOptions, ['clientID']).with(options);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Fetches the user country based on the ip.\n *\n * @method getUserCountry\n * @private\n * @param {Function} cb\n */\nAuthentication.prototype.getUserCountry = function(cb) {\n var url;\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country');\n\n return this.request.get(url).end(responseHandler(cb));\n};\n\nexport default Authentication;\n","import urljoin from 'url-join';\n\nimport RequestBuilder from '../helper/request-builder';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\n/**\n * Auth0 Management API Client (methods allowed to be called from the browser only)\n * @constructor\n * @param {Object} options\n * @param {Object} options.domain your Auth0 acount domain\n * @param {Object} options.token a valid API token\n */\nfunction Management(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n token: { type: 'string', message: 'token option is required' },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n }\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n\n this.baseOptions.headers = {\n Authorization: 'Bearer ' + this.baseOptions.token\n };\n\n this.request = new RequestBuilder(this.baseOptions);\n this.baseOptions.rootUrl = urljoin(\n 'https://' + this.baseOptions.domain,\n 'api',\n 'v2'\n );\n}\n\n/**\n * @callback userCallback\n * @param {Error} [err] failure reason for the failed request to Management API\n * @param {Object} [result] user profile\n */\n\n/**\n * Returns the user profile\n *\n * @method getUser\n * @param {String} userId identifier of the user to retrieve\n * @param {userCallback} cb\n * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id\n */\nManagement.prototype.getUser = function(userId, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request.get(url).end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user metdata. It will patch the user metdata with the attributes sent.\n *\n *\n * @method patchUserMetadata\n * @param {String} userId\n * @param {Object} userMetadata\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserMetadata = function(userId, userMetadata, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(userMetadata, {\n type: 'object',\n message: 'userMetadata parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send({ user_metadata: userMetadata })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user attributes. It will patch the user attributes that the server allows it.\n *\n * @method patchUserAttributes\n * @param {String} userId\n * @param {Object} user\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserAttributes = function(userId, user, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(user, {\n type: 'object',\n message: 'user parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send(user)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Link two users\n *\n * @method linkUser\n * @param {String} userId\n * @param {String} secondaryUserToken\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities}\n */\nManagement.prototype.linkUser = function(userId, secondaryUserToken, cb) {\n var url;\n /* eslint-disable */\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(secondaryUserToken, {\n type: 'string',\n message: 'secondaryUserToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n /* eslint-enable */\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId, 'identities');\n\n return this.request\n .post(url)\n .send({ link_with: secondaryUserToken })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\nexport default Management;\n","import Authentication from './authentication';\nimport Management from './management';\nimport WebAuth from './web-auth';\nimport version from './version';\n\nexport { Authentication, Management, WebAuth, version };\n\nexport default {\n Authentication: Authentication,\n Management: Management,\n WebAuth: WebAuth,\n version: version\n};\n"],"names":["context","definition","this","normalize","strArray","resultArray","length","TypeError","match","first","shift","replace","i","component","push","str","join","parts","split","arguments","slice","call","module","exports","has","Object","prototype","hasOwnProperty","isArray","Array","hexTable","array","toString","toUpperCase","arrayToObject","source","options","obj","plainObjects","create","assign","target","keys","reduce","acc","key","combine","a","b","concat","compact","value","queue","o","prop","refs","item","j","val","indexOf","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","c","charCodeAt","charAt","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","merge","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","apply","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","object","generateArrayPrefix","filter","sort","v","isNonNullishPrimitive","objKeys","values","keyPrefix","arrayLimit","depth","ignoreQueryPrefix","interpretNumericEntities","parameterLimit","parseArrays","numberStr","fromCharCode","parseArrayValue","parseKeys","givenKey","valuesParsed","child","segment","exec","parent","index","chain","leaf","root","cleanRoot","isNaN","0","parseObject","opts","undefined","normalizeParseOptions","tempObj","cleanStr","limit","Infinity","skipIndex","part","bracketEqualsPos","pos","encodedVal","parseValues","newObj","normalizeStringifyOptions","arrayFormat","joined","Emitter","mixin","on","addEventListener","event","_callbacks","once","off","removeListener","removeAllListeners","removeEventListener","cb","callbacks","splice","emit","args","len","listeners","hasListeners","stable","deterministicStringify","stableStringify","replacerStack","replacer","spacer","res","decirc","k","stack","propertyDescriptor","getOwnPropertyDescriptor","get","configurable","defineProperty","JSON","replaceGetterValues","compareFunction","tmp","deterministicDecirc","toJSON","_typeof","iterator","RequestBase","clearTimeout","_timer","_responseTimeoutTimer","_uploadTimeoutTimer","parse","_parser","responseType","_responseType","serialize","_serializer","timeout","_timeout","_responseTimeout","_uploadTimeout","option","deadline","response","upload","console","warn","retry","count","_maxRetries","_retries","_retryCallback","ERROR_CODES","_shouldRetry","err","override","err_","error","status","code","includes","crossDomain","_retry","req","request","_aborted","timedout","timedoutError","_end","then","resolve","reject","_this","_fullfilledPromise","self","_endCalled","Promise","Error","method","url","end","catch","use","ok","_okCallback","_isResponseOK","field","_header","toLowerCase","getHeader","set","isObject","header","unset","name","_data","_getFormData","append","abort","xhr","_auth","user","pass","base64Encoder","type","username","password","withCredentials","_withCredentials","redirects","n","_maxRedirects","maxResponseSize","_maxResponseSize","data","headers","send","isObj","_formData","_isHost","sortQuery","_sort","_finalizeQueryString","query","_query","queryArr","_appendQueryString","_timeoutError","reason","errno","callback","_setTimeouts","setTimeout","ResponseBase","_toConsumableArray","_arrayLikeToArray","_arrayWithoutHoles","iter","from","_iterableToArray","minLen","test","_unsupportedIterableToArray","_nonIterableSpread","arr2","Agent","_defaults","_setHeaderProperties","ct","params","links","link","_unused","_setStatusProperties","statusCode","statusType","info","redirect","clientError","serverError","toError","created","accepted","noContent","badRequest","unauthorized","notAcceptable","forbidden","notFound","unprocessableEntity","_len","_key","_setDefaults","def","noop","window","Request","getXHR","XMLHttpRequest","location","protocol","ActiveXObject","_unused2","_unused3","_unused4","trim","s","pairs","pushEncodedKeyValuePair","subkey","encodeURI","encodeURIComponent","parseString","pair","isJSON","mime","Response","text","responseText","statusText","line","lines","fields","parseHeader","getAllResponseHeaders","getResponseHeader","body","_parseBody","new_err","original","rawResponse","del","serializeObject","types","html","json","xml","urlencoded","form","form-data","application/x-www-form-urlencoded","application/json","safeStringify","msg","accept","auth","btoa","attach","file","FormData","_callback","retries","crossDomainError","agent","ca","buffer","write","pipe","_setUploadTimeout","onreadystatechange","readyState","_unused5","handleProgress","direction","total","percent","loaded","bind","_unused6","open","contentType","_serialize","setRequestHeader","delete","head","patch","post","put","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","lookup","Uint8Array","start","num","output","base64","fromByteArray","stringToByteArray","mod","padding","result","byteArrayToString","toByteArray","raw","attribute","attr","variable","check","config","attributes","optional","message","condition","value_message","supportsIsArray","objectAssignPolyfill","to","nextSource","keysArray","nextIndex","nextKey","desc","enumerable","pick","prev","objectValues","extend","unshift","objectAssign","getLocationFromUrl","href","host","hostname","port","pathname","search","hash","trimmed","toSnakeCase","exceptions","assert","p","newKey","wasPrevNumber","wasPrevUppercase","camelToSnake","toCamelCase","keepOriginal","blacklist","blacklistedKeys","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","RequestWrapper","RequestObj","RequestBuilder","_sendTelemetry","_telemetryInfo","_timesToRetryFailedRequests","_universalLoginPage","universalLoginPage","getWindow","getMethod","getBody","getUrl","getHeaders","objectHelper","setCommonConfiguration","ongoingRequest","noHeaders","getTelemetryData","telemetryName","clientInfo","version","env","jsonClientInfo","base64Url","getDocument","document","getOrigin","DummyStorage","getItem","removeItem","setItem","factory","init","converter","api","expires","toUTCString","stringifiedAttributes","attributeName","cookie","jar","cookies","read","getJSON","remove","withConverter","CookieStorage","Warn","disableWarnings","StorageHandler","storage","__tryLocalStorageFirst","localStorage","windowHandler","warning","Storage","handler","SSODataStorage","buildResponse","description","errorDescription","Cookie","failover","_","connection","sub","ssodata","lastUsedConnection","lastUsedSub","invalidToken","wrapCallback","ignoreCasing","errObj","error_code","error_description","details","forceLegacyError","error_codes","error_details","errorDetails","codes","policy","keepOriginalCasing","tokenParams","authorizeParams","oauthTokenParams","oauthAuthorizeParams","t","globalThis","global","r","require","l","d","w","h","u","MutationObserver","WebKitMutationObserver","f","process","Uint8ClampedArray","importScripts","MessageChannel","m","y","g","T","S","C","_state","I","_result","A","nextTick","createTextNode","observe","characterData","port1","onmessage","port2","postMessage","Function","runOnLoop","runOnContext","Math","random","substring","D","x","E","B","_onerror","M","_subscribers","R","_instanceConstructor","promise","_remaining","_enumerate","_eachEntry","_settledAt","O","_willSettleAt","finally","all","race","_setScheduler","_setAsap","_asap","polyfill","cast","lib","Base","mixIn","$super","clone","WordArray","words","sigBytes","clamp","ceil","enc","Hex","substr","Latin1","Utf8","BufferedBlockAlgorithm","reset","_nDataBytes","_append","_process","blockSize","max","_minBufferSize","min","_doProcessBlock","Hasher","cfg","_doReset","update","finalize","_doFinalize","_createHelper","_createHmacHelper","HMAC","algo","sqrt","pow","SHA256","_hash","floor","HmacSHA256","Base64","_map","_reverseMap","fromNumber","fromString","navigator","appName","am","DB","DM","DV","FV","F1","F2","fromInt","mp","invDigit","mpl","mph","um","mt2","r2","q3","ONE","dlShiftTo","mu","divide","convert","compareTo","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","abs","ZERO","subTo","copyTo","drShiftTo","fromRadix","lShiftTo","rShiftTo","isEven","exp","negate","toRadix","bitLength","modPowInt","multiplyUpperTo","multiplyLowerTo","dAddOffset","getTime","chunkSize","LN2","log","signum","intValue","dMultiply","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","changeBit","addTo","modInt","millerRabin","subtract","getLowestSetBit","shiftRight","modPow","byteValue","shortValue","equals","and","or","xor","andNot","not","bitCount","setBit","clearBit","flipBit","add","multiply","remainder","divideAndRemainder","modInverse","gcd","square","Barrett","crypto","getRandomValues","appVersion","BigInteger","SecureRandom","sha1","sha224","sha256","sha384","sha512","md2","md5","ripemd160","verify","alg","map","urljoin","responseURL","blob","Blob","entries","onload","onerror","credentials","jwksCache","expectedAlg","issuer","audience","leeway","jwksURI","maxAge","__clock","PluginHandler","webAuth","plugins","pluginName","setWebAuth","encoded","payload","signature","kid","aud","iss","nbf","iat","azp","auth_time","nonce","getRsaVerifier","setUTCSeconds","fetch","modulus","validateAccessToken","+","/","=","extensibilityPoint","supports","randomString","bytes","cryptoObj","windowHelper","msCrypto","TransactionManager","transaction","namespace","keyLength","IframeHandler","timeoutCallback","eventListenerType","iframe","timeoutHandle","_destroyTimeout","transientMessageEventListener","proxyEventListener","eventValidator","isValid","WebMessageHandler","baseOptions","CrossOriginAuthentication","webMessageHandler","createKey","coId","Redirect","auth0","crossOriginAuthentication","_disableDeprecationWarnings","realm","responseTypeIncludesIdToken","generateTransaction","appState","state","generateNonce","domain","getStoredTransaction","transactionData","clearTransaction","_window","createElement","style","display","eventListener","eventSourceObject","appendChild","src","timeoutHandler","eventData","sourceObject","destroy","parentNode","removeChild","run","responseMode","prompt","currentOrigin","redirectUriOrigin","redirectUri","authorizeUrl","runWebMessageFlow","client","buildAuthorizeUrl","parsedHash","validateAuthenticationResponse","transactionManager","login","rootUrl","email","authenticateBody","client_id","clientID","otp","credentialType","credential_type","errorObject","responseHandler","popupMode","popup","authorizeOptions","loginTicket","login_ticket","co_id","co_verifier","authorize","targetOrigin","getFragment","theWindow","evt","id","verifier","tryGetVerifier","loginWithCredentials","signupAndLogin","dbConnection","signup","WinChan","addListener","attachEvent","detachEvent","extractOrigin","isIE","rv","ua","userAgent","RegExp","parseFloat","$1","isInternetExplorer","relay_url","window_name","window_features","isFennec","messageTarget","setAttribute","contentWindow","closeInterval","setInterval","closed","cleanup","clearInterval","onMessage","close","securityViolation","originalPopup","focus","onOpen","msgTarget","frames","opener","findRelay","doPost","onDie","o_O","onUnload","ohWell","detach","winopts","arg","PopupHandler","_current_popup","Popup","popupOrigin","SilentAuthenticationHandler","authenticationUrl","postMessageDataType","postMessageOrigin","UsernamePassword","HostedPages","calculatePosition","width","height","screenX","screenLeft","screenY","screenTop","outerWidth","clientWidth","outerHeight","clientHeight","left","top","preload","popupPosition","popupOptions","windowFeatures","qs","kill","load","relayUrl","winchanOptions","buildPopupHandler","pluginHandler","getPopupHandler","popupHandler","originUrl","parseHash","popOpts","owp","urlHelper","processParams","scope","passwordlessVerify","passwordless","phoneNumber","verificationCode","loginWithResourceOwner","usePostMessage","getCallbackHandler","getEventValidator","callbackValue","formHtml","div","_document","innerHTML","children","submit","usernamePassword","getSSOData","withActiveDirectories","ldaps","lang","templates","challenge","image","recaptcha_v2","handleRecaptchaProvider","element","widgetId","hasAttribute","getAttribute","setValue","querySelector","grecaptcha","provider","recaptchaDiv","callbackName","script","async","injectRecaptchaScript","render","expired-callback","error-callback","sitekey","siteKey","auth0Client","done","getChallenge","required","preventDefault","handleAuth0Provider","reload","getValue","captchaInput","defaultClock","WebAuth","overrides","__tenant","__token_issuer","__jwks_uri","tenant","token_issuer","Authentication","_universalLogin","ssodataStorage","PasswordlessAuthentication","DBConnection","Management","token","Authorization","parsedQs","hashStr","responseTypes","__enableIdPInitiatedLogin","__enableImpersonation","transactionState","transactionStateMatchesState","transactionNonce","qsParams","accessToken","access_token","idToken","id_token","idTokenPayload","refreshToken","refresh_token","expiresIn","expires_in","tokenType","token_type","buildParseHashResponse","validateToken","validationError","at_hash","IdTokenVerifier","decodedToken","userInfo","errUserInfo","profile","renewAuth","checkSession","changePassword","passwordlessStart","authParams","signupAndAuthorize","passwordlessLogin","crossOriginOptions","crossOriginAuthenticationCallback","crossOriginVerification","logout","buildLogoutUrl","buildVerifyUrl","renderCaptcha","captcha","qString","redirect_uri","response_type","cleanOption","metadata","user_metadata","userMetadata","connection_scope","parametersWhitelist","federated","loginWithDefaultDirectory","grantType","oauthToken","grant_type","clientId","ssodataInformation","sso","lastUsedUserID","lastUsedUsername","lastUsedClientID","sessionClients","delegation","getUserCountry","getUser","userId","patchUserMetadata","patchUserAttributes","linkUser","secondaryUserToken","link_with"],"mappings":"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"} \ No newline at end of file diff --git a/build/cordova-auth0-plugin.js b/build/cordova-auth0-plugin.js new file mode 100644 index 00000000..3a10c723 --- /dev/null +++ b/build/cordova-auth0-plugin.js @@ -0,0 +1,1426 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.CordovaAuth0Plugin = factory()); +}(this, (function () { 'use strict'; + + var version = { raw: '9.14.3' }; + + var toString = Object.prototype.toString; + + function attribute(o, attr, type, text) { + type = type === 'array' ? 'object' : type; + if (o && typeof o[attr] !== type) { + throw new Error(text); + } + } + + function variable(o, type, text) { + if (typeof o !== type) { + throw new Error(text); + } + } + + function value(o, values, text) { + if (values.indexOf(o) === -1) { + throw new Error(text); + } + } + + function check(o, config, attributes) { + if (!config.optional || o) { + variable(o, config.type, config.message); + } + if (config.type === 'object' && attributes) { + var keys = Object.keys(attributes); + + for (var index = 0; index < keys.length; index++) { + var a = keys[index]; + if (!attributes[a].optional || o[a]) { + if (!attributes[a].condition || attributes[a].condition(o)) { + attribute(o, a, attributes[a].type, attributes[a].message); + if (attributes[a].values) { + value(o[a], attributes[a].values, attributes[a].value_message); + } + } + } + } + } + } + + /** + * Wrap `Array.isArray` Polyfill for IE9 + * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray + * + * @param {Array} array + * @private + */ + function isArray(array) { + if (this.supportsIsArray()) { + return Array.isArray(array); + } + + return toString.call(array) === '[object Array]'; + } + + function supportsIsArray() { + return Array.isArray != null; + } + + var assert = { + check: check, + attribute: attribute, + variable: variable, + value: value, + isArray: isArray, + supportsIsArray: supportsIsArray + }; + + /* eslint-disable no-continue */ + + function get() { + if (!Object.assign) { + return objectAssignPolyfill; + } + + return Object.assign; + } + + function objectAssignPolyfill(target) { + if (target === undefined || target === null) { + throw new TypeError('Cannot convert first argument to object'); + } + + var to = Object(target); + for (var i = 1; i < arguments.length; i++) { + var nextSource = arguments[i]; + if (nextSource === undefined || nextSource === null) { + continue; + } + + var keysArray = Object.keys(Object(nextSource)); + for ( + var nextIndex = 0, len = keysArray.length; + nextIndex < len; + nextIndex++ + ) { + var nextKey = keysArray[nextIndex]; + var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); + if (desc !== undefined && desc.enumerable) { + to[nextKey] = nextSource[nextKey]; + } + } + } + return to; + } + + var objectAssign = { + get: get, + objectAssignPolyfill: objectAssignPolyfill + }; + + /* eslint-disable no-param-reassign */ + + function pick(object, keys) { + return keys.reduce(function(prev, key) { + if (object[key]) { + prev[key] = object[key]; + } + return prev; + }, {}); + } + + function getKeysNotIn(obj, allowedKeys) { + var notAllowed = []; + for (var key in obj) { + if (allowedKeys.indexOf(key) === -1) { + notAllowed.push(key); + } + } + return notAllowed; + } + + function objectValues(obj) { + var values = []; + for (var key in obj) { + values.push(obj[key]); + } + return values; + } + + function extend() { + var params = objectValues(arguments); + params.unshift({}); + return objectAssign.get().apply(undefined, params); + } + + function merge(object, keys) { + return { + base: keys ? pick(object, keys) : object, + with: function(object2, keys2) { + object2 = keys2 ? pick(object2, keys2) : object2; + return extend(this.base, object2); + } + }; + } + + function blacklist(object, blacklistedKeys) { + return Object.keys(object).reduce(function(p, key) { + if (blacklistedKeys.indexOf(key) === -1) { + p[key] = object[key]; + } + return p; + }, {}); + } + + function camelToSnake(str) { + var newKey = ''; + var index = 0; + var code; + var wasPrevNumber = true; + var wasPrevUppercase = true; + + while (index < str.length) { + code = str.charCodeAt(index); + if ( + (!wasPrevUppercase && code >= 65 && code <= 90) || + (!wasPrevNumber && code >= 48 && code <= 57) + ) { + newKey += '_'; + newKey += str[index].toLowerCase(); + } else { + newKey += str[index].toLowerCase(); + } + wasPrevNumber = code >= 48 && code <= 57; + wasPrevUppercase = code >= 65 && code <= 90; + index++; + } + + return newKey; + } + + function snakeToCamel(str) { + var parts = str.split('_'); + return parts.reduce(function(p, c) { + return p + c.charAt(0).toUpperCase() + c.slice(1); + }, parts.shift()); + } + + function toSnakeCase(object, exceptions) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + exceptions = exceptions || []; + + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key; + p[newKey] = toSnakeCase(object[key]); + return p; + }, {}); + } + + function toCamelCase(object, exceptions, options) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + + exceptions = exceptions || []; + options = options || {}; + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key; + + p[newKey] = toCamelCase(object[newKey] || object[key], [], options); + + if (options.keepOriginal) { + p[key] = toCamelCase(object[key], [], options); + } + return p; + }, {}); + } + + function getLocationFromUrl(href) { + var match = href.match( + /^(https?:|file:|chrome-extension:)\/\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\?[^#]*|)(#.*|)$/ + ); + return ( + match && { + href: href, + protocol: match[1], + host: match[2], + hostname: match[3], + port: match[4], + pathname: match[5], + search: match[6], + hash: match[7] + } + ); + } + + function getOriginFromUrl(url) { + if (!url) { + return undefined; + } + var parsed = getLocationFromUrl(url); + if (!parsed) { + return null; + } + var origin = parsed.protocol + '//' + parsed.hostname; + if (parsed.port) { + origin += ':' + parsed.port; + } + return origin; + } + + function trim(options, key) { + var trimmed = extend(options); + if (options[key]) { + trimmed[key] = options[key].trim(); + } + return trimmed; + } + + function trimMultiple(options, keys) { + return keys.reduce(trim, options); + } + + function trimUserDetails(options) { + return trimMultiple(options, ['username', 'email', 'phoneNumber']); + } + + /** + * Updates the value of a property on the given object, using a deep path selector. + * @param {object} obj The object to set the property value on + * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3'] + * @param {any} value The value to set + */ + function updatePropertyOn(obj, path, value) { + if (typeof path === 'string') { + path = path.split('.'); + } + + var next = path[0]; + + if (obj.hasOwnProperty(next)) { + if (path.length === 1) { + obj[next] = value; + } else { + updatePropertyOn(obj[next], path.slice(1), value); + } + } + } + + var objectHelper = { + toSnakeCase: toSnakeCase, + toCamelCase: toCamelCase, + blacklist: blacklist, + merge: merge, + pick: pick, + getKeysNotIn: getKeysNotIn, + extend: extend, + getOriginFromUrl: getOriginFromUrl, + getLocationFromUrl: getLocationFromUrl, + trimUserDetails: trimUserDetails, + updatePropertyOn: updatePropertyOn + }; + + function redirect(url) { + getWindow().location = url; + } + + function getDocument() { + return getWindow().document; + } + + function getWindow() { + return window; + } + + function getOrigin() { + var location = getWindow().location; + var origin = location.origin; + + if (!origin) { + origin = objectHelper.getOriginFromUrl(location.href); + } + + return origin; + } + + var windowHandler = { + redirect: redirect, + getDocument: getDocument, + getWindow: getWindow, + getOrigin: getOrigin + }; + + var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var urlJoin = createCommonjsModule(function (module) { + (function (name, context, definition) { + if ( module.exports) module.exports = definition(); + else context[name] = definition(); + })('urljoin', commonjsGlobal, function () { + + function normalize (strArray) { + var resultArray = []; + if (strArray.length === 0) { return ''; } + + if (typeof strArray[0] !== 'string') { + throw new TypeError('Url must be a string. Received ' + strArray[0]); + } + + // If the first part is a plain protocol, we combine it with the next part. + if (strArray[0].match(/^[^/:]+:\/*$/) && strArray.length > 1) { + var first = strArray.shift(); + strArray[0] = first + strArray[0]; + } + + // There must be two or three slashes in the file protocol, two slashes in anything else. + if (strArray[0].match(/^file:\/\/\//)) { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1:///'); + } else { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1://'); + } + + for (var i = 0; i < strArray.length; i++) { + var component = strArray[i]; + + if (typeof component !== 'string') { + throw new TypeError('Url must be a string. Received ' + component); + } + + if (component === '') { continue; } + + if (i > 0) { + // Removing the starting slashes for each component but the first. + component = component.replace(/^[\/]+/, ''); + } + if (i < strArray.length - 1) { + // Removing the ending slashes for each component but the last. + component = component.replace(/[\/]+$/, ''); + } else { + // For the last component we will combine multiple slashes to a single one. + component = component.replace(/[\/]+$/, '/'); + } + + resultArray.push(component); + + } + + var str = resultArray.join('/'); + // Each input component is now separated by a single slash except the possible first plain protocol part. + + // remove trailing slash before parameters or hash + str = str.replace(/\/(\?|&|#[^!])/g, '$1'); + + // replace ? in parameters with & + var parts = str.split('?'); + str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&'); + + return str; + } + + return function () { + var input; + + if (typeof arguments[0] === 'object') { + input = arguments[0]; + } else { + input = [].slice.call(arguments); + } + + return normalize(input); + }; + + }); + }); + + var has = Object.prototype.hasOwnProperty; + var isArray$1 = Array.isArray; + + var hexTable = (function () { + var array = []; + for (var i = 0; i < 256; ++i) { + array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase()); + } + + return array; + }()); + + var compactQueue = function compactQueue(queue) { + while (queue.length > 1) { + var item = queue.pop(); + var obj = item.obj[item.prop]; + + if (isArray$1(obj)) { + var compacted = []; + + for (var j = 0; j < obj.length; ++j) { + if (typeof obj[j] !== 'undefined') { + compacted.push(obj[j]); + } + } + + item.obj[item.prop] = compacted; + } + } + }; + + var arrayToObject = function arrayToObject(source, options) { + var obj = options && options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; + }; + + var merge$1 = function merge(target, source, options) { + /* eslint no-param-reassign: 0 */ + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (isArray$1(target)) { + target.push(source); + } else if (target && typeof target === 'object') { + if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) { + target[source] = true; + } + } else { + return [target, source]; + } + + return target; + } + + if (!target || typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (isArray$1(target) && !isArray$1(source)) { + mergeTarget = arrayToObject(target, options); + } + + if (isArray$1(target) && isArray$1(source)) { + source.forEach(function (item, i) { + if (has.call(target, i)) { + var targetItem = target[i]; + if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') { + target[i] = merge(targetItem, item, options); + } else { + target.push(item); + } + } else { + target[i] = item; + } + }); + return target; + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (has.call(acc, key)) { + acc[key] = merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); + }; + + var assign = function assignSingleSource(target, source) { + return Object.keys(source).reduce(function (acc, key) { + acc[key] = source[key]; + return acc; + }, target); + }; + + var decode = function (str, decoder, charset) { + var strWithoutPlus = str.replace(/\+/g, ' '); + if (charset === 'iso-8859-1') { + // unescape never throws, no try...catch needed: + return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape); + } + // utf-8 + try { + return decodeURIComponent(strWithoutPlus); + } catch (e) { + return strWithoutPlus; + } + }; + + var encode = function encode(str, defaultEncoder, charset) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = str; + if (typeof str === 'symbol') { + string = Symbol.prototype.toString.call(str); + } else if (typeof str !== 'string') { + string = String(str); + } + + if (charset === 'iso-8859-1') { + return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) { + return '%26%23' + parseInt($0.slice(2), 16) + '%3B'; + }); + } + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D // - + || c === 0x2E // . + || c === 0x5F // _ + || c === 0x7E // ~ + || (c >= 0x30 && c <= 0x39) // 0-9 + || (c >= 0x41 && c <= 0x5A) // a-z + || (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + + hexTable[0x80 | ((c >> 12) & 0x3F)] + + hexTable[0x80 | ((c >> 6) & 0x3F)] + + hexTable[0x80 | (c & 0x3F)]; + } + + return out; + }; + + var compact = function compact(value) { + var queue = [{ obj: { o: value }, prop: 'o' }]; + var refs = []; + + for (var i = 0; i < queue.length; ++i) { + var item = queue[i]; + var obj = item.obj[item.prop]; + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + var val = obj[key]; + if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) { + queue.push({ obj: obj, prop: key }); + refs.push(val); + } + } + } + + compactQueue(queue); + + return value; + }; + + var isRegExp = function isRegExp(obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; + }; + + var isBuffer = function isBuffer(obj) { + if (!obj || typeof obj !== 'object') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); + }; + + var combine = function combine(a, b) { + return [].concat(a, b); + }; + + var maybeMap = function maybeMap(val, fn) { + if (isArray$1(val)) { + var mapped = []; + for (var i = 0; i < val.length; i += 1) { + mapped.push(fn(val[i])); + } + return mapped; + } + return fn(val); + }; + + var utils = { + arrayToObject: arrayToObject, + assign: assign, + combine: combine, + compact: compact, + decode: decode, + encode: encode, + isBuffer: isBuffer, + isRegExp: isRegExp, + maybeMap: maybeMap, + merge: merge$1 + }; + + var replace = String.prototype.replace; + var percentTwenties = /%20/g; + + + + var Format = { + RFC1738: 'RFC1738', + RFC3986: 'RFC3986' + }; + + var formats = utils.assign( + { + 'default': Format.RFC3986, + formatters: { + RFC1738: function (value) { + return replace.call(value, percentTwenties, '+'); + }, + RFC3986: function (value) { + return String(value); + } + } + }, + Format + ); + + var has$1 = Object.prototype.hasOwnProperty; + + var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + comma: 'comma', + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } + }; + + var isArray$2 = Array.isArray; + var push = Array.prototype.push; + var pushToArray = function (arr, valueOrArray) { + push.apply(arr, isArray$2(valueOrArray) ? valueOrArray : [valueOrArray]); + }; + + var toISO = Date.prototype.toISOString; + + var defaultFormat = formats['default']; + var defaults = { + addQueryPrefix: false, + allowDots: false, + charset: 'utf-8', + charsetSentinel: false, + delimiter: '&', + encode: true, + encoder: utils.encode, + encodeValuesOnly: false, + format: defaultFormat, + formatter: formats.formatters[defaultFormat], + // deprecated + indices: false, + serializeDate: function serializeDate(date) { + return toISO.call(date); + }, + skipNulls: false, + strictNullHandling: false + }; + + var isNonNullishPrimitive = function isNonNullishPrimitive(v) { + return typeof v === 'string' + || typeof v === 'number' + || typeof v === 'boolean' + || typeof v === 'symbol' + || typeof v === 'bigint'; + }; + + var stringify = function stringify( + object, + prefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + ) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = serializeDate(obj); + } else if (generateArrayPrefix === 'comma' && isArray$2(obj)) { + obj = utils.maybeMap(obj, function (value) { + if (value instanceof Date) { + return serializeDate(value); + } + return value; + }).join(','); + } + + if (obj === null) { + if (strictNullHandling) { + return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix; + } + + obj = ''; + } + + if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) { + if (encoder) { + var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key'); + return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))]; + } + return [formatter(prefix) + '=' + formatter(String(obj))]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (isArray$2(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + var value = obj[key]; + + if (skipNulls && value === null) { + continue; + } + + var keyPrefix = isArray$2(obj) + ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix + : prefix + (allowDots ? '.' + key : '[' + key + ']'); + + pushToArray(values, stringify( + value, + keyPrefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + )); + } + + return values; + }; + + var normalizeStringifyOptions = function normalizeStringifyOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + var charset = opts.charset || defaults.charset; + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + + var format = formats['default']; + if (typeof opts.format !== 'undefined') { + if (!has$1.call(formats.formatters, opts.format)) { + throw new TypeError('Unknown format option provided.'); + } + format = opts.format; + } + var formatter = formats.formatters[format]; + + var filter = defaults.filter; + if (typeof opts.filter === 'function' || isArray$2(opts.filter)) { + filter = opts.filter; + } + + return { + addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix, + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter, + encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode, + encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder, + encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly, + filter: filter, + formatter: formatter, + serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate, + skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls, + sort: typeof opts.sort === 'function' ? opts.sort : null, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; + }; + + var stringify_1 = function (object, opts) { + var obj = object; + var options = normalizeStringifyOptions(opts); + + var objKeys; + var filter; + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (isArray$2(options.filter)) { + filter = options.filter; + objKeys = filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (opts && opts.arrayFormat in arrayPrefixGenerators) { + arrayFormat = opts.arrayFormat; + } else if (opts && 'indices' in opts) { + arrayFormat = opts.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (options.sort) { + objKeys.sort(options.sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (options.skipNulls && obj[key] === null) { + continue; + } + pushToArray(keys, stringify( + obj[key], + key, + generateArrayPrefix, + options.strictNullHandling, + options.skipNulls, + options.encode ? options.encoder : null, + options.filter, + options.sort, + options.allowDots, + options.serializeDate, + options.formatter, + options.encodeValuesOnly, + options.charset + )); + } + + var joined = keys.join(options.delimiter); + var prefix = options.addQueryPrefix === true ? '?' : ''; + + if (options.charsetSentinel) { + if (options.charset === 'iso-8859-1') { + // encodeURIComponent('✓'), the "numeric entity" representation of a checkmark + prefix += 'utf8=%26%2310003%3B&'; + } else { + // encodeURIComponent('✓') + prefix += 'utf8=%E2%9C%93&'; + } + } + + return joined.length > 0 ? prefix + joined : ''; + }; + + var has$2 = Object.prototype.hasOwnProperty; + var isArray$3 = Array.isArray; + + var defaults$1 = { + allowDots: false, + allowPrototypes: false, + arrayLimit: 20, + charset: 'utf-8', + charsetSentinel: false, + comma: false, + decoder: utils.decode, + delimiter: '&', + depth: 5, + ignoreQueryPrefix: false, + interpretNumericEntities: false, + parameterLimit: 1000, + parseArrays: true, + plainObjects: false, + strictNullHandling: false + }; + + var interpretNumericEntities = function (str) { + return str.replace(/&#(\d+);/g, function ($0, numberStr) { + return String.fromCharCode(parseInt(numberStr, 10)); + }); + }; + + var parseArrayValue = function (val, options) { + if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) { + return val.split(','); + } + + return val; + }; + + // This is what browsers will submit when the ✓ character occurs in an + // application/x-www-form-urlencoded body and the encoding of the page containing + // the form is iso-8859-1, or when the submitted form has an accept-charset + // attribute of iso-8859-1. Presumably also with other charsets that do not contain + // the ✓ character, such as us-ascii. + var isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓') + + // These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded. + var charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓') + + var parseValues = function parseQueryStringValues(str, options) { + var obj = {}; + var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\?/, '') : str; + var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit; + var parts = cleanStr.split(options.delimiter, limit); + var skipIndex = -1; // Keep track of where the utf8 sentinel was found + var i; + + var charset = options.charset; + if (options.charsetSentinel) { + for (i = 0; i < parts.length; ++i) { + if (parts[i].indexOf('utf8=') === 0) { + if (parts[i] === charsetSentinel) { + charset = 'utf-8'; + } else if (parts[i] === isoSentinel) { + charset = 'iso-8859-1'; + } + skipIndex = i; + i = parts.length; // The eslint settings do not allow break; + } + } + } + + for (i = 0; i < parts.length; ++i) { + if (i === skipIndex) { + continue; + } + var part = parts[i]; + + var bracketEqualsPos = part.indexOf(']='); + var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1; + + var key, val; + if (pos === -1) { + key = options.decoder(part, defaults$1.decoder, charset, 'key'); + val = options.strictNullHandling ? null : ''; + } else { + key = options.decoder(part.slice(0, pos), defaults$1.decoder, charset, 'key'); + val = utils.maybeMap( + parseArrayValue(part.slice(pos + 1), options), + function (encodedVal) { + return options.decoder(encodedVal, defaults$1.decoder, charset, 'value'); + } + ); + } + + if (val && options.interpretNumericEntities && charset === 'iso-8859-1') { + val = interpretNumericEntities(val); + } + + if (part.indexOf('[]=') > -1) { + val = isArray$3(val) ? [val] : val; + } + + if (has$2.call(obj, key)) { + obj[key] = utils.combine(obj[key], val); + } else { + obj[key] = val; + } + } + + return obj; + }; + + var parseObject = function (chain, val, options, valuesParsed) { + var leaf = valuesParsed ? val : parseArrayValue(val, options); + + for (var i = chain.length - 1; i >= 0; --i) { + var obj; + var root = chain[i]; + + if (root === '[]' && options.parseArrays) { + obj = [].concat(leaf); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root; + var index = parseInt(cleanRoot, 10); + if (!options.parseArrays && cleanRoot === '') { + obj = { 0: leaf }; + } else if ( + !isNaN(index) + && root !== cleanRoot + && String(index) === cleanRoot + && index >= 0 + && (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = leaf; + } else { + obj[cleanRoot] = leaf; + } + } + + leaf = obj; // eslint-disable-line no-param-reassign + } + + return leaf; + }; + + var parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^.[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var brackets = /(\[[^[\]]*])/; + var child = /(\[[^[\]]*])/g; + + // Get the parent + + var segment = options.depth > 0 && brackets.exec(key); + var parent = segment ? key.slice(0, segment.index) : key; + + // Stash the parent if it exists + + var keys = []; + if (parent) { + // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties + if (!options.plainObjects && has$2.call(Object.prototype, parent)) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(parent); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && has$2.call(Object.prototype, segment[1].slice(1, -1))) { + if (!options.allowPrototypes) { + return; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options, valuesParsed); + }; + + var normalizeParseOptions = function normalizeParseOptions(opts) { + if (!opts) { + return defaults$1; + } + + if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + var charset = typeof opts.charset === 'undefined' ? defaults$1.charset : opts.charset; + + return { + allowDots: typeof opts.allowDots === 'undefined' ? defaults$1.allowDots : !!opts.allowDots, + allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults$1.allowPrototypes, + arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults$1.arrayLimit, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults$1.charsetSentinel, + comma: typeof opts.comma === 'boolean' ? opts.comma : defaults$1.comma, + decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults$1.decoder, + delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults$1.delimiter, + // eslint-disable-next-line no-implicit-coercion, no-extra-parens + depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults$1.depth, + ignoreQueryPrefix: opts.ignoreQueryPrefix === true, + interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults$1.interpretNumericEntities, + parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults$1.parameterLimit, + parseArrays: opts.parseArrays !== false, + plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults$1.plainObjects, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults$1.strictNullHandling + }; + }; + + var parse = function (str, opts) { + var options = normalizeParseOptions(opts); + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string'); + obj = utils.merge(obj, newObj, options); + } + + return utils.compact(obj); + }; + + var lib = { + formats: formats, + parse: parse, + stringify: stringify_1 + }; + + function PopupHandler(webAuth) { + this.webAuth = webAuth; + this._current_popup = null; + this.options = null; + } + + PopupHandler.prototype.preload = function(options) { + var _this = this; + var _window = windowHandler.getWindow(); + + var url = options.url || 'about:blank'; + var popupOptions = options.popupOptions || {}; + + popupOptions.location = 'yes'; + delete popupOptions.width; + delete popupOptions.height; + + var windowFeatures = lib.stringify(popupOptions, { + encode: false, + delimiter: ',' + }); + + if (this._current_popup && !this._current_popup.closed) { + return this._current_popup; + } + + this._current_popup = _window.open(url, '_blank', windowFeatures); + + this._current_popup.kill = function(success) { + _this._current_popup.success = success; + this.close(); + _this._current_popup = null; + }; + + return this._current_popup; + }; + + PopupHandler.prototype.load = function(url, _, options, cb) { + var _this = this; + this.url = url; + this.options = options; + if (!this._current_popup) { + options.url = url; + this.preload(options); + } else { + this._current_popup.location.href = url; + } + + this.transientErrorHandler = function(event) { + _this.errorHandler(event, cb); + }; + + this.transientStartHandler = function(event) { + _this.startHandler(event, cb); + }; + + this.transientExitHandler = function() { + _this.exitHandler(cb); + }; + + this._current_popup.addEventListener('loaderror', this.transientErrorHandler); + this._current_popup.addEventListener('loadstart', this.transientStartHandler); + this._current_popup.addEventListener('exit', this.transientExitHandler); + }; + + PopupHandler.prototype.errorHandler = function(event, cb) { + if (!this._current_popup) { + return; + } + + this._current_popup.kill(true); + + cb({ error: 'window_error', errorDescription: event.message }); + }; + + PopupHandler.prototype.unhook = function() { + this._current_popup.removeEventListener( + 'loaderror', + this.transientErrorHandler + ); + this._current_popup.removeEventListener( + 'loadstart', + this.transientStartHandler + ); + this._current_popup.removeEventListener('exit', this.transientExitHandler); + }; + + PopupHandler.prototype.exitHandler = function(cb) { + if (!this._current_popup) { + return; + } + + // when the modal is closed, this event is called which ends up removing the + // event listeners. If you move this before closing the modal, it will add ~1 sec + // delay between the user being redirected to the callback and the popup gets closed. + this.unhook(); + + if (!this._current_popup.success) { + cb({ error: 'window_closed', errorDescription: 'Browser window closed' }); + } + }; + + PopupHandler.prototype.startHandler = function(event, cb) { + var _this = this; + + if (!this._current_popup) { + return; + } + + var callbackUrl = urlJoin( + 'https:', + this.webAuth.baseOptions.domain, + '/mobile' + ); + + if (event.url && !(event.url.indexOf(callbackUrl + '#') === 0)) { + return; + } + + var parts = event.url.split('#'); + + if (parts.length === 1) { + return; + } + + var opts = { hash: parts.pop() }; + + if (this.options.nonce) { + opts.nonce = this.options.nonce; + } + + this.webAuth.parseHash(opts, function(error, result) { + if (error || result) { + _this._current_popup.kill(true); + cb(error, result); + } + }); + }; + + function PluginHandler(webAuth) { + this.webAuth = webAuth; + } + + PluginHandler.prototype.processParams = function(params) { + params.redirectUri = urlJoin('https://' + params.domain, 'mobile'); + delete params.owp; + return params; + }; + + PluginHandler.prototype.getPopupHandler = function() { + return new PopupHandler(this.webAuth); + }; + + function CordovaPlugin() { + this.webAuth = null; + this.version = version.raw; + this.extensibilityPoints = ['popup.authorize', 'popup.getPopupHandler']; + } + + CordovaPlugin.prototype.setWebAuth = function(webAuth) { + this.webAuth = webAuth; + }; + + CordovaPlugin.prototype.supports = function(extensibilityPoint) { + var _window = windowHandler.getWindow(); + return ( + (!!_window.cordova || !!_window.electron) && + this.extensibilityPoints.indexOf(extensibilityPoint) > -1 + ); + }; + + CordovaPlugin.prototype.init = function() { + return new PluginHandler(this.webAuth); + }; + + return CordovaPlugin; + +}))); diff --git a/build/cordova-auth0-plugin.min.js b/build/cordova-auth0-plugin.min.js new file mode 100644 index 00000000..d6a12b3d --- /dev/null +++ b/build/cordova-auth0-plugin.min.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +!function(global,factory){"object"==typeof exports&&"undefined"!=typeof module?module.exports=factory():"function"==typeof define&&define.amd?define(factory):(global=global||self).CordovaAuth0Plugin=factory()}(this,(function(){"use strict";var version_raw="9.14.3",toString=Object.prototype.toString;function attribute(o,attr,type,text){if(type="array"===type?"object":type,o&&typeof o[attr]!==type)throw new Error(text)}function variable(o,type,text){if(typeof o!==type)throw new Error(text)}function value(o,values,text){if(-1===values.indexOf(o))throw new Error(text)}var assert={check:function(o,config,attributes){if(config.optional&&!o||variable(o,config.type,config.message),"object"===config.type&&attributes)for(var keys=Object.keys(attributes),index=0;index=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function getWindow(){return window}var windowHandler={redirect:function(url){getWindow().location=url},getDocument:function(){return getWindow().document},getWindow:getWindow,getOrigin:function(){var location=getWindow().location,origin=location.origin;return origin||(origin=objectHelper.getOriginFromUrl(location.href)),origin}},commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};var urlJoin=function(fn,module){return fn(module={exports:{}},module.exports),module.exports}((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray$1=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray$1(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray$1(val)){for(var mapped=[],i=0;i0?prefix+joined:""});function PopupHandler(webAuth){this.webAuth=webAuth,this._current_popup=null,this.options=null}function PluginHandler(webAuth){this.webAuth=webAuth}function CordovaPlugin(){this.webAuth=null,this.version=version_raw,this.extensibilityPoints=["popup.authorize","popup.getPopupHandler"]}return PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHandler.getWindow(),url=options.url||"about:blank",popupOptions=options.popupOptions||{};popupOptions.location="yes",delete popupOptions.width,delete popupOptions.height;var windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"_blank",windowFeatures),this._current_popup.kill=function(success){_this._current_popup.success=success,this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,_,options,cb){var _this=this;this.url=url,this.options=options,this._current_popup?this._current_popup.location.href=url:(options.url=url,this.preload(options)),this.transientErrorHandler=function(event){_this.errorHandler(event,cb)},this.transientStartHandler=function(event){_this.startHandler(event,cb)},this.transientExitHandler=function(){_this.exitHandler(cb)},this._current_popup.addEventListener("loaderror",this.transientErrorHandler),this._current_popup.addEventListener("loadstart",this.transientStartHandler),this._current_popup.addEventListener("exit",this.transientExitHandler)},PopupHandler.prototype.errorHandler=function(event,cb){this._current_popup&&(this._current_popup.kill(!0),cb({error:"window_error",errorDescription:event.message}))},PopupHandler.prototype.unhook=function(){this._current_popup.removeEventListener("loaderror",this.transientErrorHandler),this._current_popup.removeEventListener("loadstart",this.transientStartHandler),this._current_popup.removeEventListener("exit",this.transientExitHandler)},PopupHandler.prototype.exitHandler=function(cb){this._current_popup&&(this.unhook(),this._current_popup.success||cb({error:"window_closed",errorDescription:"Browser window closed"}))},PopupHandler.prototype.startHandler=function(event,cb){var _this=this;if(this._current_popup){var callbackUrl=urlJoin("https:",this.webAuth.baseOptions.domain,"/mobile");if(!event.url||0===event.url.indexOf(callbackUrl+"#")){var parts=event.url.split("#");if(1!==parts.length){var opts={hash:parts.pop()};this.options.nonce&&(opts.nonce=this.options.nonce),this.webAuth.parseHash(opts,(function(error,result){(error||result)&&(_this._current_popup.kill(!0),cb(error,result))}))}}}},PluginHandler.prototype.processParams=function(params){return params.redirectUri=urlJoin("https://"+params.domain,"mobile"),delete params.owp,params},PluginHandler.prototype.getPopupHandler=function(){return new PopupHandler(this.webAuth)},CordovaPlugin.prototype.setWebAuth=function(webAuth){this.webAuth=webAuth},CordovaPlugin.prototype.supports=function(extensibilityPoint){var _window=windowHandler.getWindow();return(!!_window.cordova||!!_window.electron)&&this.extensibilityPoints.indexOf(extensibilityPoint)>-1},CordovaPlugin.prototype.init=function(){return new PluginHandler(this.webAuth)},CordovaPlugin})); +//# sourceMappingURL=cordova-auth0-plugin.min.js.map diff --git a/build/cordova-auth0-plugin.min.js.map b/build/cordova-auth0-plugin.min.js.map new file mode 100644 index 00000000..d3718974 --- /dev/null +++ b/build/cordova-auth0-plugin.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"cordova-auth0-plugin.min.js","sources":["../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/window.js","../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../plugins/cordova/popup-handler.js","../plugins/cordova/plugin-handler.js","../plugins/cordova/index.js"],"sourcesContent":["module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","import windowHandler from '../../src/helper/window';\nimport qs from 'qs';\nimport urljoin from 'url-join';\n\nfunction PopupHandler(webAuth) {\n this.webAuth = webAuth;\n this._current_popup = null;\n this.options = null;\n}\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n\n var url = options.url || 'about:blank';\n var popupOptions = options.popupOptions || {};\n\n popupOptions.location = 'yes';\n delete popupOptions.width;\n delete popupOptions.height;\n\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, '_blank', windowFeatures);\n\n this._current_popup.kill = function(success) {\n _this._current_popup.success = success;\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, _, options, cb) {\n var _this = this;\n this.url = url;\n this.options = options;\n if (!this._current_popup) {\n options.url = url;\n this.preload(options);\n } else {\n this._current_popup.location.href = url;\n }\n\n this.transientErrorHandler = function(event) {\n _this.errorHandler(event, cb);\n };\n\n this.transientStartHandler = function(event) {\n _this.startHandler(event, cb);\n };\n\n this.transientExitHandler = function() {\n _this.exitHandler(cb);\n };\n\n this._current_popup.addEventListener('loaderror', this.transientErrorHandler);\n this._current_popup.addEventListener('loadstart', this.transientStartHandler);\n this._current_popup.addEventListener('exit', this.transientExitHandler);\n};\n\nPopupHandler.prototype.errorHandler = function(event, cb) {\n if (!this._current_popup) {\n return;\n }\n\n this._current_popup.kill(true);\n\n cb({ error: 'window_error', errorDescription: event.message });\n};\n\nPopupHandler.prototype.unhook = function() {\n this._current_popup.removeEventListener(\n 'loaderror',\n this.transientErrorHandler\n );\n this._current_popup.removeEventListener(\n 'loadstart',\n this.transientStartHandler\n );\n this._current_popup.removeEventListener('exit', this.transientExitHandler);\n};\n\nPopupHandler.prototype.exitHandler = function(cb) {\n if (!this._current_popup) {\n return;\n }\n\n // when the modal is closed, this event is called which ends up removing the\n // event listeners. If you move this before closing the modal, it will add ~1 sec\n // delay between the user being redirected to the callback and the popup gets closed.\n this.unhook();\n\n if (!this._current_popup.success) {\n cb({ error: 'window_closed', errorDescription: 'Browser window closed' });\n }\n};\n\nPopupHandler.prototype.startHandler = function(event, cb) {\n var _this = this;\n\n if (!this._current_popup) {\n return;\n }\n\n var callbackUrl = urljoin(\n 'https:',\n this.webAuth.baseOptions.domain,\n '/mobile'\n );\n\n if (event.url && !(event.url.indexOf(callbackUrl + '#') === 0)) {\n return;\n }\n\n var parts = event.url.split('#');\n\n if (parts.length === 1) {\n return;\n }\n\n var opts = { hash: parts.pop() };\n\n if (this.options.nonce) {\n opts.nonce = this.options.nonce;\n }\n\n this.webAuth.parseHash(opts, function(error, result) {\n if (error || result) {\n _this._current_popup.kill(true);\n cb(error, result);\n }\n });\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport PopupHandler from './popup-handler';\n\nfunction PluginHandler(webAuth) {\n this.webAuth = webAuth;\n}\n\nPluginHandler.prototype.processParams = function(params) {\n params.redirectUri = urljoin('https://' + params.domain, 'mobile');\n delete params.owp;\n return params;\n};\n\nPluginHandler.prototype.getPopupHandler = function() {\n return new PopupHandler(this.webAuth);\n};\n\nexport default PluginHandler;\n","import version from '../../src/version';\nimport windowHandler from '../../src/helper/window';\nimport PluginHandler from './plugin-handler';\n\nfunction CordovaPlugin() {\n this.webAuth = null;\n this.version = version.raw;\n this.extensibilityPoints = ['popup.authorize', 'popup.getPopupHandler'];\n}\n\nCordovaPlugin.prototype.setWebAuth = function(webAuth) {\n this.webAuth = webAuth;\n};\n\nCordovaPlugin.prototype.supports = function(extensibilityPoint) {\n var _window = windowHandler.getWindow();\n return (\n (!!_window.cordova || !!_window.electron) &&\n this.extensibilityPoints.indexOf(extensibilityPoint) > -1\n );\n};\n\nCordovaPlugin.prototype.init = function() {\n return new PluginHandler(this.webAuth);\n};\n\nexport default CordovaPlugin;\n"],"names":["toString","Object","prototype","attribute","o","attr","type","text","Error","variable","value","values","indexOf","check","config","attributes","optional","message","keys","index","length","a","condition","value_message","isArray","array","this","supportsIsArray","Array","call","objectAssignPolyfill","target","TypeError","to","i","arguments","nextSource","keysArray","nextIndex","len","nextKey","desc","getOwnPropertyDescriptor","undefined","enumerable","get","assign","pick","object","reduce","prev","key","objectValues","obj","push","extend","params","unshift","objectAssign","apply","getLocationFromUrl","href","match","protocol","host","hostname","port","pathname","search","hash","trim","options","trimmed","toSnakeCase","exceptions","assert","p","str","code","newKey","wasPrevNumber","wasPrevUppercase","charCodeAt","toLowerCase","camelToSnake","toCamelCase","parts","split","c","charAt","toUpperCase","slice","shift","keepOriginal","blacklist","blacklistedKeys","merge","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","url","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","hasOwnProperty","getWindow","window","redirect","location","getDocument","document","getOrigin","objectHelper","context","definition","normalize","strArray","resultArray","first","replace","component","join","module","exports","has","hexTable","arrayToObject","source","plainObjects","create","acc","combine","b","concat","compact","queue","prop","refs","item","j","val","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","generateArrayPrefix","filter","sort","v","objKeys","keyPrefix","opts","normalizeStringifyOptions","arrayFormat","joined","PopupHandler","webAuth","_current_popup","PluginHandler","CordovaPlugin","version","extensibilityPoints","preload","_this","_window","windowHandler","popupOptions","width","height","windowFeatures","qs","closed","open","kill","success","close","load","_","cb","transientErrorHandler","event","errorHandler","transientStartHandler","startHandler","transientExitHandler","exitHandler","addEventListener","error","errorDescription","unhook","removeEventListener","callbackUrl","urljoin","baseOptions","domain","nonce","parseHash","result","processParams","redirectUri","owp","getPopupHandler","setWebAuth","supports","extensibilityPoint","cordova","electron","init"],"mappings":"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"} \ No newline at end of file diff --git a/dist/auth0.js b/dist/auth0.js new file mode 100644 index 00000000..064749b6 --- /dev/null +++ b/dist/auth0.js @@ -0,0 +1,8176 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (global = global || self, factory(global.auth0 = {})); +}(this, (function (exports) { 'use strict'; + + var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var urlJoin = createCommonjsModule(function (module) { + (function (name, context, definition) { + if ( module.exports) module.exports = definition(); + else context[name] = definition(); + })('urljoin', commonjsGlobal, function () { + + function normalize (strArray) { + var resultArray = []; + if (strArray.length === 0) { return ''; } + + if (typeof strArray[0] !== 'string') { + throw new TypeError('Url must be a string. Received ' + strArray[0]); + } + + // If the first part is a plain protocol, we combine it with the next part. + if (strArray[0].match(/^[^/:]+:\/*$/) && strArray.length > 1) { + var first = strArray.shift(); + strArray[0] = first + strArray[0]; + } + + // There must be two or three slashes in the file protocol, two slashes in anything else. + if (strArray[0].match(/^file:\/\/\//)) { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1:///'); + } else { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1://'); + } + + for (var i = 0; i < strArray.length; i++) { + var component = strArray[i]; + + if (typeof component !== 'string') { + throw new TypeError('Url must be a string. Received ' + component); + } + + if (component === '') { continue; } + + if (i > 0) { + // Removing the starting slashes for each component but the first. + component = component.replace(/^[\/]+/, ''); + } + if (i < strArray.length - 1) { + // Removing the ending slashes for each component but the last. + component = component.replace(/[\/]+$/, ''); + } else { + // For the last component we will combine multiple slashes to a single one. + component = component.replace(/[\/]+$/, '/'); + } + + resultArray.push(component); + + } + + var str = resultArray.join('/'); + // Each input component is now separated by a single slash except the possible first plain protocol part. + + // remove trailing slash before parameters or hash + str = str.replace(/\/(\?|&|#[^!])/g, '$1'); + + // replace ? in parameters with & + var parts = str.split('?'); + str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&'); + + return str; + } + + return function () { + var input; + + if (typeof arguments[0] === 'object') { + input = arguments[0]; + } else { + input = [].slice.call(arguments); + } + + return normalize(input); + }; + + }); + }); + + var has = Object.prototype.hasOwnProperty; + var isArray = Array.isArray; + + var hexTable = (function () { + var array = []; + for (var i = 0; i < 256; ++i) { + array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase()); + } + + return array; + }()); + + var compactQueue = function compactQueue(queue) { + while (queue.length > 1) { + var item = queue.pop(); + var obj = item.obj[item.prop]; + + if (isArray(obj)) { + var compacted = []; + + for (var j = 0; j < obj.length; ++j) { + if (typeof obj[j] !== 'undefined') { + compacted.push(obj[j]); + } + } + + item.obj[item.prop] = compacted; + } + } + }; + + var arrayToObject = function arrayToObject(source, options) { + var obj = options && options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; + }; + + var merge = function merge(target, source, options) { + /* eslint no-param-reassign: 0 */ + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (isArray(target)) { + target.push(source); + } else if (target && typeof target === 'object') { + if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) { + target[source] = true; + } + } else { + return [target, source]; + } + + return target; + } + + if (!target || typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (isArray(target) && !isArray(source)) { + mergeTarget = arrayToObject(target, options); + } + + if (isArray(target) && isArray(source)) { + source.forEach(function (item, i) { + if (has.call(target, i)) { + var targetItem = target[i]; + if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') { + target[i] = merge(targetItem, item, options); + } else { + target.push(item); + } + } else { + target[i] = item; + } + }); + return target; + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (has.call(acc, key)) { + acc[key] = merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); + }; + + var assign = function assignSingleSource(target, source) { + return Object.keys(source).reduce(function (acc, key) { + acc[key] = source[key]; + return acc; + }, target); + }; + + var decode = function (str, decoder, charset) { + var strWithoutPlus = str.replace(/\+/g, ' '); + if (charset === 'iso-8859-1') { + // unescape never throws, no try...catch needed: + return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape); + } + // utf-8 + try { + return decodeURIComponent(strWithoutPlus); + } catch (e) { + return strWithoutPlus; + } + }; + + var encode = function encode(str, defaultEncoder, charset) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = str; + if (typeof str === 'symbol') { + string = Symbol.prototype.toString.call(str); + } else if (typeof str !== 'string') { + string = String(str); + } + + if (charset === 'iso-8859-1') { + return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) { + return '%26%23' + parseInt($0.slice(2), 16) + '%3B'; + }); + } + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D // - + || c === 0x2E // . + || c === 0x5F // _ + || c === 0x7E // ~ + || (c >= 0x30 && c <= 0x39) // 0-9 + || (c >= 0x41 && c <= 0x5A) // a-z + || (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + + hexTable[0x80 | ((c >> 12) & 0x3F)] + + hexTable[0x80 | ((c >> 6) & 0x3F)] + + hexTable[0x80 | (c & 0x3F)]; + } + + return out; + }; + + var compact = function compact(value) { + var queue = [{ obj: { o: value }, prop: 'o' }]; + var refs = []; + + for (var i = 0; i < queue.length; ++i) { + var item = queue[i]; + var obj = item.obj[item.prop]; + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + var val = obj[key]; + if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) { + queue.push({ obj: obj, prop: key }); + refs.push(val); + } + } + } + + compactQueue(queue); + + return value; + }; + + var isRegExp = function isRegExp(obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; + }; + + var isBuffer = function isBuffer(obj) { + if (!obj || typeof obj !== 'object') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); + }; + + var combine = function combine(a, b) { + return [].concat(a, b); + }; + + var maybeMap = function maybeMap(val, fn) { + if (isArray(val)) { + var mapped = []; + for (var i = 0; i < val.length; i += 1) { + mapped.push(fn(val[i])); + } + return mapped; + } + return fn(val); + }; + + var utils = { + arrayToObject: arrayToObject, + assign: assign, + combine: combine, + compact: compact, + decode: decode, + encode: encode, + isBuffer: isBuffer, + isRegExp: isRegExp, + maybeMap: maybeMap, + merge: merge + }; + + var replace = String.prototype.replace; + var percentTwenties = /%20/g; + + + + var Format = { + RFC1738: 'RFC1738', + RFC3986: 'RFC3986' + }; + + var formats = utils.assign( + { + 'default': Format.RFC3986, + formatters: { + RFC1738: function (value) { + return replace.call(value, percentTwenties, '+'); + }, + RFC3986: function (value) { + return String(value); + } + } + }, + Format + ); + + var has$1 = Object.prototype.hasOwnProperty; + + var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + comma: 'comma', + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } + }; + + var isArray$1 = Array.isArray; + var push = Array.prototype.push; + var pushToArray = function (arr, valueOrArray) { + push.apply(arr, isArray$1(valueOrArray) ? valueOrArray : [valueOrArray]); + }; + + var toISO = Date.prototype.toISOString; + + var defaultFormat = formats['default']; + var defaults = { + addQueryPrefix: false, + allowDots: false, + charset: 'utf-8', + charsetSentinel: false, + delimiter: '&', + encode: true, + encoder: utils.encode, + encodeValuesOnly: false, + format: defaultFormat, + formatter: formats.formatters[defaultFormat], + // deprecated + indices: false, + serializeDate: function serializeDate(date) { + return toISO.call(date); + }, + skipNulls: false, + strictNullHandling: false + }; + + var isNonNullishPrimitive = function isNonNullishPrimitive(v) { + return typeof v === 'string' + || typeof v === 'number' + || typeof v === 'boolean' + || typeof v === 'symbol' + || typeof v === 'bigint'; + }; + + var stringify = function stringify( + object, + prefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + ) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = serializeDate(obj); + } else if (generateArrayPrefix === 'comma' && isArray$1(obj)) { + obj = utils.maybeMap(obj, function (value) { + if (value instanceof Date) { + return serializeDate(value); + } + return value; + }).join(','); + } + + if (obj === null) { + if (strictNullHandling) { + return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix; + } + + obj = ''; + } + + if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) { + if (encoder) { + var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key'); + return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))]; + } + return [formatter(prefix) + '=' + formatter(String(obj))]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (isArray$1(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + var value = obj[key]; + + if (skipNulls && value === null) { + continue; + } + + var keyPrefix = isArray$1(obj) + ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix + : prefix + (allowDots ? '.' + key : '[' + key + ']'); + + pushToArray(values, stringify( + value, + keyPrefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + )); + } + + return values; + }; + + var normalizeStringifyOptions = function normalizeStringifyOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + var charset = opts.charset || defaults.charset; + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + + var format = formats['default']; + if (typeof opts.format !== 'undefined') { + if (!has$1.call(formats.formatters, opts.format)) { + throw new TypeError('Unknown format option provided.'); + } + format = opts.format; + } + var formatter = formats.formatters[format]; + + var filter = defaults.filter; + if (typeof opts.filter === 'function' || isArray$1(opts.filter)) { + filter = opts.filter; + } + + return { + addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix, + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter, + encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode, + encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder, + encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly, + filter: filter, + formatter: formatter, + serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate, + skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls, + sort: typeof opts.sort === 'function' ? opts.sort : null, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; + }; + + var stringify_1 = function (object, opts) { + var obj = object; + var options = normalizeStringifyOptions(opts); + + var objKeys; + var filter; + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (isArray$1(options.filter)) { + filter = options.filter; + objKeys = filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (opts && opts.arrayFormat in arrayPrefixGenerators) { + arrayFormat = opts.arrayFormat; + } else if (opts && 'indices' in opts) { + arrayFormat = opts.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (options.sort) { + objKeys.sort(options.sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (options.skipNulls && obj[key] === null) { + continue; + } + pushToArray(keys, stringify( + obj[key], + key, + generateArrayPrefix, + options.strictNullHandling, + options.skipNulls, + options.encode ? options.encoder : null, + options.filter, + options.sort, + options.allowDots, + options.serializeDate, + options.formatter, + options.encodeValuesOnly, + options.charset + )); + } + + var joined = keys.join(options.delimiter); + var prefix = options.addQueryPrefix === true ? '?' : ''; + + if (options.charsetSentinel) { + if (options.charset === 'iso-8859-1') { + // encodeURIComponent('✓'), the "numeric entity" representation of a checkmark + prefix += 'utf8=%26%2310003%3B&'; + } else { + // encodeURIComponent('✓') + prefix += 'utf8=%E2%9C%93&'; + } + } + + return joined.length > 0 ? prefix + joined : ''; + }; + + var has$2 = Object.prototype.hasOwnProperty; + var isArray$2 = Array.isArray; + + var defaults$1 = { + allowDots: false, + allowPrototypes: false, + arrayLimit: 20, + charset: 'utf-8', + charsetSentinel: false, + comma: false, + decoder: utils.decode, + delimiter: '&', + depth: 5, + ignoreQueryPrefix: false, + interpretNumericEntities: false, + parameterLimit: 1000, + parseArrays: true, + plainObjects: false, + strictNullHandling: false + }; + + var interpretNumericEntities = function (str) { + return str.replace(/&#(\d+);/g, function ($0, numberStr) { + return String.fromCharCode(parseInt(numberStr, 10)); + }); + }; + + var parseArrayValue = function (val, options) { + if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) { + return val.split(','); + } + + return val; + }; + + // This is what browsers will submit when the ✓ character occurs in an + // application/x-www-form-urlencoded body and the encoding of the page containing + // the form is iso-8859-1, or when the submitted form has an accept-charset + // attribute of iso-8859-1. Presumably also with other charsets that do not contain + // the ✓ character, such as us-ascii. + var isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓') + + // These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded. + var charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓') + + var parseValues = function parseQueryStringValues(str, options) { + var obj = {}; + var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\?/, '') : str; + var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit; + var parts = cleanStr.split(options.delimiter, limit); + var skipIndex = -1; // Keep track of where the utf8 sentinel was found + var i; + + var charset = options.charset; + if (options.charsetSentinel) { + for (i = 0; i < parts.length; ++i) { + if (parts[i].indexOf('utf8=') === 0) { + if (parts[i] === charsetSentinel) { + charset = 'utf-8'; + } else if (parts[i] === isoSentinel) { + charset = 'iso-8859-1'; + } + skipIndex = i; + i = parts.length; // The eslint settings do not allow break; + } + } + } + + for (i = 0; i < parts.length; ++i) { + if (i === skipIndex) { + continue; + } + var part = parts[i]; + + var bracketEqualsPos = part.indexOf(']='); + var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1; + + var key, val; + if (pos === -1) { + key = options.decoder(part, defaults$1.decoder, charset, 'key'); + val = options.strictNullHandling ? null : ''; + } else { + key = options.decoder(part.slice(0, pos), defaults$1.decoder, charset, 'key'); + val = utils.maybeMap( + parseArrayValue(part.slice(pos + 1), options), + function (encodedVal) { + return options.decoder(encodedVal, defaults$1.decoder, charset, 'value'); + } + ); + } + + if (val && options.interpretNumericEntities && charset === 'iso-8859-1') { + val = interpretNumericEntities(val); + } + + if (part.indexOf('[]=') > -1) { + val = isArray$2(val) ? [val] : val; + } + + if (has$2.call(obj, key)) { + obj[key] = utils.combine(obj[key], val); + } else { + obj[key] = val; + } + } + + return obj; + }; + + var parseObject = function (chain, val, options, valuesParsed) { + var leaf = valuesParsed ? val : parseArrayValue(val, options); + + for (var i = chain.length - 1; i >= 0; --i) { + var obj; + var root = chain[i]; + + if (root === '[]' && options.parseArrays) { + obj = [].concat(leaf); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root; + var index = parseInt(cleanRoot, 10); + if (!options.parseArrays && cleanRoot === '') { + obj = { 0: leaf }; + } else if ( + !isNaN(index) + && root !== cleanRoot + && String(index) === cleanRoot + && index >= 0 + && (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = leaf; + } else { + obj[cleanRoot] = leaf; + } + } + + leaf = obj; // eslint-disable-line no-param-reassign + } + + return leaf; + }; + + var parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^.[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var brackets = /(\[[^[\]]*])/; + var child = /(\[[^[\]]*])/g; + + // Get the parent + + var segment = options.depth > 0 && brackets.exec(key); + var parent = segment ? key.slice(0, segment.index) : key; + + // Stash the parent if it exists + + var keys = []; + if (parent) { + // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties + if (!options.plainObjects && has$2.call(Object.prototype, parent)) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(parent); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && has$2.call(Object.prototype, segment[1].slice(1, -1))) { + if (!options.allowPrototypes) { + return; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options, valuesParsed); + }; + + var normalizeParseOptions = function normalizeParseOptions(opts) { + if (!opts) { + return defaults$1; + } + + if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + var charset = typeof opts.charset === 'undefined' ? defaults$1.charset : opts.charset; + + return { + allowDots: typeof opts.allowDots === 'undefined' ? defaults$1.allowDots : !!opts.allowDots, + allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults$1.allowPrototypes, + arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults$1.arrayLimit, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults$1.charsetSentinel, + comma: typeof opts.comma === 'boolean' ? opts.comma : defaults$1.comma, + decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults$1.decoder, + delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults$1.delimiter, + // eslint-disable-next-line no-implicit-coercion, no-extra-parens + depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults$1.depth, + ignoreQueryPrefix: opts.ignoreQueryPrefix === true, + interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults$1.interpretNumericEntities, + parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults$1.parameterLimit, + parseArrays: opts.parseArrays !== false, + plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults$1.plainObjects, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults$1.strictNullHandling + }; + }; + + var parse = function (str, opts) { + var options = normalizeParseOptions(opts); + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string'); + obj = utils.merge(obj, newObj, options); + } + + return utils.compact(obj); + }; + + var lib = { + formats: formats, + parse: parse, + stringify: stringify_1 + }; + + var componentEmitter = createCommonjsModule(function (module) { + /** + * Expose `Emitter`. + */ + + { + module.exports = Emitter; + } + + /** + * Initialize a new `Emitter`. + * + * @api public + */ + + function Emitter(obj) { + if (obj) return mixin(obj); + } + /** + * Mixin the emitter properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + function mixin(obj) { + for (var key in Emitter.prototype) { + obj[key] = Emitter.prototype[key]; + } + return obj; + } + + /** + * Listen on the given `event` with `fn`. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.on = + Emitter.prototype.addEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + (this._callbacks['$' + event] = this._callbacks['$' + event] || []) + .push(fn); + return this; + }; + + /** + * Adds an `event` listener that will be invoked a single + * time then automatically removed. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.once = function(event, fn){ + function on() { + this.off(event, on); + fn.apply(this, arguments); + } + + on.fn = fn; + this.on(event, on); + return this; + }; + + /** + * Remove the given callback for `event` or all + * registered callbacks. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.off = + Emitter.prototype.removeListener = + Emitter.prototype.removeAllListeners = + Emitter.prototype.removeEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + + // all + if (0 == arguments.length) { + this._callbacks = {}; + return this; + } + + // specific event + var callbacks = this._callbacks['$' + event]; + if (!callbacks) return this; + + // remove all handlers + if (1 == arguments.length) { + delete this._callbacks['$' + event]; + return this; + } + + // remove specific handler + var cb; + for (var i = 0; i < callbacks.length; i++) { + cb = callbacks[i]; + if (cb === fn || cb.fn === fn) { + callbacks.splice(i, 1); + break; + } + } + + // Remove event specific arrays for event types that no + // one is subscribed for to avoid memory leak. + if (callbacks.length === 0) { + delete this._callbacks['$' + event]; + } + + return this; + }; + + /** + * Emit `event` with the given args. + * + * @param {String} event + * @param {Mixed} ... + * @return {Emitter} + */ + + Emitter.prototype.emit = function(event){ + this._callbacks = this._callbacks || {}; + + var args = new Array(arguments.length - 1) + , callbacks = this._callbacks['$' + event]; + + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + + if (callbacks) { + callbacks = callbacks.slice(0); + for (var i = 0, len = callbacks.length; i < len; ++i) { + callbacks[i].apply(this, args); + } + } + + return this; + }; + + /** + * Return array of callbacks for `event`. + * + * @param {String} event + * @return {Array} + * @api public + */ + + Emitter.prototype.listeners = function(event){ + this._callbacks = this._callbacks || {}; + return this._callbacks['$' + event] || []; + }; + + /** + * Check if this emitter has `event` handlers. + * + * @param {String} event + * @return {Boolean} + * @api public + */ + + Emitter.prototype.hasListeners = function(event){ + return !! this.listeners(event).length; + }; + }); + + var fastSafeStringify = stringify$1; + stringify$1.default = stringify$1; + stringify$1.stable = deterministicStringify; + stringify$1.stableStringify = deterministicStringify; + + var arr = []; + var replacerStack = []; + + // Regular stringify + function stringify$1 (obj, replacer, spacer) { + decirc(obj, '', [], undefined); + var res; + if (replacerStack.length === 0) { + res = JSON.stringify(obj, replacer, spacer); + } else { + res = JSON.stringify(obj, replaceGetterValues(replacer), spacer); + } + while (arr.length !== 0) { + var part = arr.pop(); + if (part.length === 4) { + Object.defineProperty(part[0], part[1], part[3]); + } else { + part[0][part[1]] = part[2]; + } + } + return res + } + function decirc (val, k, stack, parent) { + var i; + if (typeof val === 'object' && val !== null) { + for (i = 0; i < stack.length; i++) { + if (stack[i] === val) { + var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k); + if (propertyDescriptor.get !== undefined) { + if (propertyDescriptor.configurable) { + Object.defineProperty(parent, k, { value: '[Circular]' }); + arr.push([parent, k, val, propertyDescriptor]); + } else { + replacerStack.push([val, k]); + } + } else { + parent[k] = '[Circular]'; + arr.push([parent, k, val]); + } + return + } + } + stack.push(val); + // Optimize for Arrays. Big arrays could kill the performance otherwise! + if (Array.isArray(val)) { + for (i = 0; i < val.length; i++) { + decirc(val[i], i, stack, val); + } + } else { + var keys = Object.keys(val); + for (i = 0; i < keys.length; i++) { + var key = keys[i]; + decirc(val[key], key, stack, val); + } + } + stack.pop(); + } + } + + // Stable-stringify + function compareFunction (a, b) { + if (a < b) { + return -1 + } + if (a > b) { + return 1 + } + return 0 + } + + function deterministicStringify (obj, replacer, spacer) { + var tmp = deterministicDecirc(obj, '', [], undefined) || obj; + var res; + if (replacerStack.length === 0) { + res = JSON.stringify(tmp, replacer, spacer); + } else { + res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer); + } + while (arr.length !== 0) { + var part = arr.pop(); + if (part.length === 4) { + Object.defineProperty(part[0], part[1], part[3]); + } else { + part[0][part[1]] = part[2]; + } + } + return res + } + + function deterministicDecirc (val, k, stack, parent) { + var i; + if (typeof val === 'object' && val !== null) { + for (i = 0; i < stack.length; i++) { + if (stack[i] === val) { + var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k); + if (propertyDescriptor.get !== undefined) { + if (propertyDescriptor.configurable) { + Object.defineProperty(parent, k, { value: '[Circular]' }); + arr.push([parent, k, val, propertyDescriptor]); + } else { + replacerStack.push([val, k]); + } + } else { + parent[k] = '[Circular]'; + arr.push([parent, k, val]); + } + return + } + } + if (typeof val.toJSON === 'function') { + return + } + stack.push(val); + // Optimize for Arrays. Big arrays could kill the performance otherwise! + if (Array.isArray(val)) { + for (i = 0; i < val.length; i++) { + deterministicDecirc(val[i], i, stack, val); + } + } else { + // Create a temporary object in the required way + var tmp = {}; + var keys = Object.keys(val).sort(compareFunction); + for (i = 0; i < keys.length; i++) { + var key = keys[i]; + deterministicDecirc(val[key], key, stack, val); + tmp[key] = val[key]; + } + if (parent !== undefined) { + arr.push([parent, k, val]); + parent[k] = tmp; + } else { + return tmp + } + } + stack.pop(); + } + } + + // wraps replacer function to handle values we couldn't replace + // and mark them as [Circular] + function replaceGetterValues (replacer) { + replacer = replacer !== undefined ? replacer : function (k, v) { return v }; + return function (key, val) { + if (replacerStack.length > 0) { + for (var i = 0; i < replacerStack.length; i++) { + var part = replacerStack[i]; + if (part[1] === key && part[0] === val) { + val = '[Circular]'; + replacerStack.splice(i, 1); + break + } + } + } + return replacer.call(this, key, val) + } + } + + function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } + + /** + * Check if `obj` is an object. + * + * @param {Object} obj + * @return {Boolean} + * @api private + */ + function isObject(obj) { + return obj !== null && _typeof(obj) === 'object'; + } + + var isObject_1 = isObject; + + function _typeof$1(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof$1 = function _typeof(obj) { return typeof obj; }; } else { _typeof$1 = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof$1(obj); } + + /** + * Module of mixed-in functions shared between node and client code + */ + + /** + * Expose `RequestBase`. + */ + + + var requestBase = RequestBase; + /** + * Initialize a new `RequestBase`. + * + * @api public + */ + + function RequestBase(obj) { + if (obj) return mixin(obj); + } + /** + * Mixin the prototype properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + + function mixin(obj) { + for (var key in RequestBase.prototype) { + if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key]; + } + + return obj; + } + /** + * Clear previous timeout. + * + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.clearTimeout = function () { + clearTimeout(this._timer); + clearTimeout(this._responseTimeoutTimer); + clearTimeout(this._uploadTimeoutTimer); + delete this._timer; + delete this._responseTimeoutTimer; + delete this._uploadTimeoutTimer; + return this; + }; + /** + * Override default response body parser + * + * This function will be called to convert incoming data into request.body + * + * @param {Function} + * @api public + */ + + + RequestBase.prototype.parse = function (fn) { + this._parser = fn; + return this; + }; + /** + * Set format of binary response body. + * In browser valid formats are 'blob' and 'arraybuffer', + * which return Blob and ArrayBuffer, respectively. + * + * In Node all values result in Buffer. + * + * Examples: + * + * req.get('/') + * .responseType('blob') + * .end(callback); + * + * @param {String} val + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.responseType = function (val) { + this._responseType = val; + return this; + }; + /** + * Override default request body serializer + * + * This function will be called to convert data set via .send or .attach into payload to send + * + * @param {Function} + * @api public + */ + + + RequestBase.prototype.serialize = function (fn) { + this._serializer = fn; + return this; + }; + /** + * Set timeouts. + * + * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time. + * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections. + * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off + * + * Value of 0 or false means no timeout. + * + * @param {Number|Object} ms or {response, deadline} + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.timeout = function (options) { + if (!options || _typeof$1(options) !== 'object') { + this._timeout = options; + this._responseTimeout = 0; + this._uploadTimeout = 0; + return this; + } + + for (var option in options) { + if (Object.prototype.hasOwnProperty.call(options, option)) { + switch (option) { + case 'deadline': + this._timeout = options.deadline; + break; + + case 'response': + this._responseTimeout = options.response; + break; + + case 'upload': + this._uploadTimeout = options.upload; + break; + + default: + console.warn('Unknown timeout option', option); + } + } + } + + return this; + }; + /** + * Set number of retry attempts on error. + * + * Failed requests will be retried 'count' times if timeout or err.code >= 500. + * + * @param {Number} count + * @param {Function} [fn] + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.retry = function (count, fn) { + // Default to 1 if no count passed or true + if (arguments.length === 0 || count === true) count = 1; + if (count <= 0) count = 0; + this._maxRetries = count; + this._retries = 0; + this._retryCallback = fn; + return this; + }; + + var ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT']; + /** + * Determine if a request should be retried. + * (Borrowed from segmentio/superagent-retry) + * + * @param {Error} err an error + * @param {Response} [res] response + * @returns {Boolean} if segment should be retried + */ + + RequestBase.prototype._shouldRetry = function (err, res) { + if (!this._maxRetries || this._retries++ >= this._maxRetries) { + return false; + } + + if (this._retryCallback) { + try { + var override = this._retryCallback(err, res); + + if (override === true) return true; + if (override === false) return false; // undefined falls back to defaults + } catch (err_) { + console.error(err_); + } + } + + if (res && res.status && res.status >= 500 && res.status !== 501) return true; + + if (err) { + if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout + + if (err.timeout && err.code === 'ECONNABORTED') return true; + if (err.crossDomain) return true; + } + + return false; + }; + /** + * Retry request + * + * @return {Request} for chaining + * @api private + */ + + + RequestBase.prototype._retry = function () { + this.clearTimeout(); // node + + if (this.req) { + this.req = null; + this.req = this.request(); + } + + this._aborted = false; + this.timedout = false; + this.timedoutError = null; + return this._end(); + }; + /** + * Promise support + * + * @param {Function} resolve + * @param {Function} [reject] + * @return {Request} + */ + + + RequestBase.prototype.then = function (resolve, reject) { + var _this = this; + + if (!this._fullfilledPromise) { + var self = this; + + if (this._endCalled) { + console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises'); + } + + this._fullfilledPromise = new Promise(function (resolve, reject) { + self.on('abort', function () { + if (_this._maxRetries && _this._maxRetries > _this._retries) { + return; + } + + if (_this.timedout && _this.timedoutError) { + reject(_this.timedoutError); + return; + } + + var err = new Error('Aborted'); + err.code = 'ABORTED'; + err.status = _this.status; + err.method = _this.method; + err.url = _this.url; + reject(err); + }); + self.end(function (err, res) { + if (err) reject(err);else resolve(res); + }); + }); + } + + return this._fullfilledPromise.then(resolve, reject); + }; + + RequestBase.prototype.catch = function (cb) { + return this.then(undefined, cb); + }; + /** + * Allow for extension + */ + + + RequestBase.prototype.use = function (fn) { + fn(this); + return this; + }; + + RequestBase.prototype.ok = function (cb) { + if (typeof cb !== 'function') throw new Error('Callback required'); + this._okCallback = cb; + return this; + }; + + RequestBase.prototype._isResponseOK = function (res) { + if (!res) { + return false; + } + + if (this._okCallback) { + return this._okCallback(res); + } + + return res.status >= 200 && res.status < 300; + }; + /** + * Get request header `field`. + * Case-insensitive. + * + * @param {String} field + * @return {String} + * @api public + */ + + + RequestBase.prototype.get = function (field) { + return this._header[field.toLowerCase()]; + }; + /** + * Get case-insensitive header `field` value. + * This is a deprecated internal API. Use `.get(field)` instead. + * + * (getHeader is no longer used internally by the superagent code base) + * + * @param {String} field + * @return {String} + * @api private + * @deprecated + */ + + + RequestBase.prototype.getHeader = RequestBase.prototype.get; + /** + * Set header `field` to `val`, or multiple fields with one object. + * Case-insensitive. + * + * Examples: + * + * req.get('/') + * .set('Accept', 'application/json') + * .set('X-API-Key', 'foobar') + * .end(callback); + * + * req.get('/') + * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' }) + * .end(callback); + * + * @param {String|Object} field + * @param {String} val + * @return {Request} for chaining + * @api public + */ + + RequestBase.prototype.set = function (field, val) { + if (isObject_1(field)) { + for (var key in field) { + if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]); + } + + return this; + } + + this._header[field.toLowerCase()] = val; + this.header[field] = val; + return this; + }; + /** + * Remove header `field`. + * Case-insensitive. + * + * Example: + * + * req.get('/') + * .unset('User-Agent') + * .end(callback); + * + * @param {String} field field name + */ + + + RequestBase.prototype.unset = function (field) { + delete this._header[field.toLowerCase()]; + delete this.header[field]; + return this; + }; + /** + * Write the field `name` and `val`, or multiple fields with one object + * for "multipart/form-data" request bodies. + * + * ``` js + * request.post('/upload') + * .field('foo', 'bar') + * .end(callback); + * + * request.post('/upload') + * .field({ foo: 'bar', baz: 'qux' }) + * .end(callback); + * ``` + * + * @param {String|Object} name name of field + * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.field = function (name, val) { + // name should be either a string or an object. + if (name === null || undefined === name) { + throw new Error('.field(name, val) name can not be empty'); + } + + if (this._data) { + throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()"); + } + + if (isObject_1(name)) { + for (var key in name) { + if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]); + } + + return this; + } + + if (Array.isArray(val)) { + for (var i in val) { + if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]); + } + + return this; + } // val should be defined now + + + if (val === null || undefined === val) { + throw new Error('.field(name, val) val can not be empty'); + } + + if (typeof val === 'boolean') { + val = String(val); + } + + this._getFormData().append(name, val); + + return this; + }; + /** + * Abort the request, and clear potential timeout. + * + * @return {Request} request + * @api public + */ + + + RequestBase.prototype.abort = function () { + if (this._aborted) { + return this; + } + + this._aborted = true; + if (this.xhr) this.xhr.abort(); // browser + + if (this.req) this.req.abort(); // node + + this.clearTimeout(); + this.emit('abort'); + return this; + }; + + RequestBase.prototype._auth = function (user, pass, options, base64Encoder) { + switch (options.type) { + case 'basic': + this.set('Authorization', "Basic ".concat(base64Encoder("".concat(user, ":").concat(pass)))); + break; + + case 'auto': + this.username = user; + this.password = pass; + break; + + case 'bearer': + // usage would be .auth(accessToken, { type: 'bearer' }) + this.set('Authorization', "Bearer ".concat(user)); + break; + } + + return this; + }; + /** + * Enable transmission of cookies with x-domain requests. + * + * Note that for this to work the origin must not be + * using "Access-Control-Allow-Origin" with a wildcard, + * and also must set "Access-Control-Allow-Credentials" + * to "true". + * + * @api public + */ + + + RequestBase.prototype.withCredentials = function (on) { + // This is browser-only functionality. Node side is no-op. + if (on === undefined) on = true; + this._withCredentials = on; + return this; + }; + /** + * Set the max redirects to `n`. Does nothing in browser XHR implementation. + * + * @param {Number} n + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.redirects = function (n) { + this._maxRedirects = n; + return this; + }; + /** + * Maximum size of buffered response body, in bytes. Counts uncompressed size. + * Default 200MB. + * + * @param {Number} n number of bytes + * @return {Request} for chaining + */ + + + RequestBase.prototype.maxResponseSize = function (n) { + if (typeof n !== 'number') { + throw new TypeError('Invalid argument'); + } + + this._maxResponseSize = n; + return this; + }; + /** + * Convert to a plain javascript object (not JSON string) of scalar properties. + * Note as this method is designed to return a useful non-this value, + * it cannot be chained. + * + * @return {Object} describing method, url, and data of this request + * @api public + */ + + + RequestBase.prototype.toJSON = function () { + return { + method: this.method, + url: this.url, + data: this._data, + headers: this._header + }; + }; + /** + * Send `data` as the request body, defaulting the `.type()` to "json" when + * an object is given. + * + * Examples: + * + * // manual json + * request.post('/user') + * .type('json') + * .send('{"name":"tj"}') + * .end(callback) + * + * // auto json + * request.post('/user') + * .send({ name: 'tj' }) + * .end(callback) + * + * // manual x-www-form-urlencoded + * request.post('/user') + * .type('form') + * .send('name=tj') + * .end(callback) + * + * // auto x-www-form-urlencoded + * request.post('/user') + * .type('form') + * .send({ name: 'tj' }) + * .end(callback) + * + * // defaults to x-www-form-urlencoded + * request.post('/user') + * .send('name=tobi') + * .send('species=ferret') + * .end(callback) + * + * @param {String|Object} data + * @return {Request} for chaining + * @api public + */ + // eslint-disable-next-line complexity + + + RequestBase.prototype.send = function (data) { + var isObj = isObject_1(data); + var type = this._header['content-type']; + + if (this._formData) { + throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()"); + } + + if (isObj && !this._data) { + if (Array.isArray(data)) { + this._data = []; + } else if (!this._isHost(data)) { + this._data = {}; + } + } else if (data && this._data && this._isHost(this._data)) { + throw new Error("Can't merge these send calls"); + } // merge + + + if (isObj && isObject_1(this._data)) { + for (var key in data) { + if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key]; + } + } else if (typeof data === 'string') { + // default to x-www-form-urlencoded + if (!type) this.type('form'); + type = this._header['content-type']; + + if (type === 'application/x-www-form-urlencoded') { + this._data = this._data ? "".concat(this._data, "&").concat(data) : data; + } else { + this._data = (this._data || '') + data; + } + } else { + this._data = data; + } + + if (!isObj || this._isHost(data)) { + return this; + } // default to json + + + if (!type) this.type('json'); + return this; + }; + /** + * Sort `querystring` by the sort function + * + * + * Examples: + * + * // default order + * request.get('/user') + * .query('name=Nick') + * .query('search=Manny') + * .sortQuery() + * .end(callback) + * + * // customized sort function + * request.get('/user') + * .query('name=Nick') + * .query('search=Manny') + * .sortQuery(function(a, b){ + * return a.length - b.length; + * }) + * .end(callback) + * + * + * @param {Function} sort + * @return {Request} for chaining + * @api public + */ + + + RequestBase.prototype.sortQuery = function (sort) { + // _sort default to true but otherwise can be a function or boolean + this._sort = typeof sort === 'undefined' ? true : sort; + return this; + }; + /** + * Compose querystring to append to req.url + * + * @api private + */ + + + RequestBase.prototype._finalizeQueryString = function () { + var query = this._query.join('&'); + + if (query) { + this.url += (this.url.includes('?') ? '&' : '?') + query; + } + + this._query.length = 0; // Makes the call idempotent + + if (this._sort) { + var index = this.url.indexOf('?'); + + if (index >= 0) { + var queryArr = this.url.slice(index + 1).split('&'); + + if (typeof this._sort === 'function') { + queryArr.sort(this._sort); + } else { + queryArr.sort(); + } + + this.url = this.url.slice(0, index) + '?' + queryArr.join('&'); + } + } + }; // For backwards compat only + + + RequestBase.prototype._appendQueryString = function () { + console.warn('Unsupported'); + }; + /** + * Invoke callback with timeout error. + * + * @api private + */ + + + RequestBase.prototype._timeoutError = function (reason, timeout, errno) { + if (this._aborted) { + return; + } + + var err = new Error("".concat(reason + timeout, "ms exceeded")); + err.timeout = timeout; + err.code = 'ECONNABORTED'; + err.errno = errno; + this.timedout = true; + this.timedoutError = err; + this.abort(); + this.callback(err); + }; + + RequestBase.prototype._setTimeouts = function () { + var self = this; // deadline + + if (this._timeout && !this._timer) { + this._timer = setTimeout(function () { + self._timeoutError('Timeout of ', self._timeout, 'ETIME'); + }, this._timeout); + } // response timeout + + + if (this._responseTimeout && !this._responseTimeoutTimer) { + this._responseTimeoutTimer = setTimeout(function () { + self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT'); + }, this._responseTimeout); + } + }; + + /** + * Return the mime type for the given `str`. + * + * @param {String} str + * @return {String} + * @api private + */ + var type = function (str) { + return str.split(/ *; */).shift(); + }; + /** + * Return header field parameters. + * + * @param {String} str + * @return {Object} + * @api private + */ + + + var params = function (str) { + return str.split(/ *; */).reduce(function (obj, str) { + var parts = str.split(/ *= */); + var key = parts.shift(); + var val = parts.shift(); + if (key && val) obj[key] = val; + return obj; + }, {}); + }; + /** + * Parse Link header fields. + * + * @param {String} str + * @return {Object} + * @api private + */ + + + var parseLinks = function (str) { + return str.split(/ *, */).reduce(function (obj, str) { + var parts = str.split(/ *; */); + var url = parts[0].slice(1, -1); + var rel = parts[1].split(/ *= */)[1].slice(1, -1); + obj[rel] = url; + return obj; + }, {}); + }; + /** + * Strip content related fields from `header`. + * + * @param {Object} header + * @return {Object} header + * @api private + */ + + + var cleanHeader = function (header, changesOrigin) { + delete header['content-type']; + delete header['content-length']; + delete header['transfer-encoding']; + delete header.host; // secuirty + + if (changesOrigin) { + delete header.authorization; + delete header.cookie; + } + + return header; + }; + + + var utils$1 = { + type: type, + params: params, + parseLinks: parseLinks, + cleanHeader: cleanHeader + }; + + /** + * Module dependencies. + */ + + /** + * Expose `ResponseBase`. + */ + + + var responseBase = ResponseBase; + /** + * Initialize a new `ResponseBase`. + * + * @api public + */ + + function ResponseBase(obj) { + if (obj) return mixin$1(obj); + } + /** + * Mixin the prototype properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + + function mixin$1(obj) { + for (var key in ResponseBase.prototype) { + if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key]; + } + + return obj; + } + /** + * Get case-insensitive `field` value. + * + * @param {String} field + * @return {String} + * @api public + */ + + + ResponseBase.prototype.get = function (field) { + return this.header[field.toLowerCase()]; + }; + /** + * Set header related properties: + * + * - `.type` the content type without params + * + * A response of "Content-Type: text/plain; charset=utf-8" + * will provide you with a `.type` of "text/plain". + * + * @param {Object} header + * @api private + */ + + + ResponseBase.prototype._setHeaderProperties = function (header) { + // TODO: moar! + // TODO: make this a util + // content-type + var ct = header['content-type'] || ''; + this.type = utils$1.type(ct); // params + + var params = utils$1.params(ct); + + for (var key in params) { + if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key]; + } + + this.links = {}; // links + + try { + if (header.link) { + this.links = utils$1.parseLinks(header.link); + } + } catch (_unused) {// ignore + } + }; + /** + * Set flags such as `.ok` based on `status`. + * + * For example a 2xx response will give you a `.ok` of __true__ + * whereas 5xx will be __false__ and `.error` will be __true__. The + * `.clientError` and `.serverError` are also available to be more + * specific, and `.statusType` is the class of error ranging from 1..5 + * sometimes useful for mapping respond colors etc. + * + * "sugar" properties are also defined for common cases. Currently providing: + * + * - .noContent + * - .badRequest + * - .unauthorized + * - .notAcceptable + * - .notFound + * + * @param {Number} status + * @api private + */ + + + ResponseBase.prototype._setStatusProperties = function (status) { + var type = status / 100 | 0; // status / class + + this.statusCode = status; + this.status = this.statusCode; + this.statusType = type; // basics + + this.info = type === 1; + this.ok = type === 2; + this.redirect = type === 3; + this.clientError = type === 4; + this.serverError = type === 5; + this.error = type === 4 || type === 5 ? this.toError() : false; // sugar + + this.created = status === 201; + this.accepted = status === 202; + this.noContent = status === 204; + this.badRequest = status === 400; + this.unauthorized = status === 401; + this.notAcceptable = status === 406; + this.forbidden = status === 403; + this.notFound = status === 404; + this.unprocessableEntity = status === 422; + }; + + function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } + + function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } + + function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } + + function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } + + function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } + + function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } + + function Agent() { + this._defaults = []; + } + + ['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) { + // Default setting for all requests from this agent + Agent.prototype[fn] = function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + this._defaults.push({ + fn: fn, + args: args + }); + + return this; + }; + }); + + Agent.prototype._setDefaults = function (req) { + this._defaults.forEach(function (def) { + req[def.fn].apply(req, _toConsumableArray(def.args)); + }); + }; + + var agentBase = Agent; + + var client = createCommonjsModule(function (module, exports) { + + function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } + + /** + * Root reference for iframes. + */ + var root; + + if (typeof window !== 'undefined') { + // Browser window + root = window; + } else if (typeof self === 'undefined') { + // Other environments + console.warn('Using browser-only version of superagent in non-browser environment'); + root = void 0; + } else { + // Web Worker + root = self; + } + + + + + + + + + + + + + /** + * Noop. + */ + + + function noop() {} + /** + * Expose `request`. + */ + + + module.exports = function (method, url) { + // callback + if (typeof url === 'function') { + return new exports.Request('GET', method).end(url); + } // url first + + + if (arguments.length === 1) { + return new exports.Request('GET', method); + } + + return new exports.Request(method, url); + }; + + exports = module.exports; + var request = exports; + exports.Request = Request; + /** + * Determine XHR. + */ + + request.getXHR = function () { + if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) { + return new XMLHttpRequest(); + } + + try { + return new ActiveXObject('Microsoft.XMLHTTP'); + } catch (_unused) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP.6.0'); + } catch (_unused2) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP.3.0'); + } catch (_unused3) {} + + try { + return new ActiveXObject('Msxml2.XMLHTTP'); + } catch (_unused4) {} + + throw new Error('Browser-only version of superagent could not find XHR'); + }; + /** + * Removes leading and trailing whitespace, added to support IE. + * + * @param {String} s + * @return {String} + * @api private + */ + + + var trim = ''.trim ? function (s) { + return s.trim(); + } : function (s) { + return s.replace(/(^\s*|\s*$)/g, ''); + }; + /** + * Serialize the given `obj`. + * + * @param {Object} obj + * @return {String} + * @api private + */ + + function serialize(obj) { + if (!isObject_1(obj)) return obj; + var pairs = []; + + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]); + } + + return pairs.join('&'); + } + /** + * Helps 'serialize' with serializing arrays. + * Mutates the pairs array. + * + * @param {Array} pairs + * @param {String} key + * @param {Mixed} val + */ + + + function pushEncodedKeyValuePair(pairs, key, val) { + if (val === undefined) return; + + if (val === null) { + pairs.push(encodeURI(key)); + return; + } + + if (Array.isArray(val)) { + val.forEach(function (v) { + pushEncodedKeyValuePair(pairs, key, v); + }); + } else if (isObject_1(val)) { + for (var subkey in val) { + if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, "".concat(key, "[").concat(subkey, "]"), val[subkey]); + } + } else { + pairs.push(encodeURI(key) + '=' + encodeURIComponent(val)); + } + } + /** + * Expose serialization method. + */ + + + request.serializeObject = serialize; + /** + * Parse the given x-www-form-urlencoded `str`. + * + * @param {String} str + * @return {Object} + * @api private + */ + + function parseString(str) { + var obj = {}; + var pairs = str.split('&'); + var pair; + var pos; + + for (var i = 0, len = pairs.length; i < len; ++i) { + pair = pairs[i]; + pos = pair.indexOf('='); + + if (pos === -1) { + obj[decodeURIComponent(pair)] = ''; + } else { + obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1)); + } + } + + return obj; + } + /** + * Expose parser. + */ + + + request.parseString = parseString; + /** + * Default MIME type map. + * + * superagent.types.xml = 'application/xml'; + * + */ + + request.types = { + html: 'text/html', + json: 'application/json', + xml: 'text/xml', + urlencoded: 'application/x-www-form-urlencoded', + form: 'application/x-www-form-urlencoded', + 'form-data': 'application/x-www-form-urlencoded' + }; + /** + * Default serialization map. + * + * superagent.serialize['application/xml'] = function(obj){ + * return 'generated xml here'; + * }; + * + */ + + request.serialize = { + 'application/x-www-form-urlencoded': serialize, + 'application/json': fastSafeStringify + }; + /** + * Default parsers. + * + * superagent.parse['application/xml'] = function(str){ + * return { object parsed from str }; + * }; + * + */ + + request.parse = { + 'application/x-www-form-urlencoded': parseString, + 'application/json': JSON.parse + }; + /** + * Parse the given header `str` into + * an object containing the mapped fields. + * + * @param {String} str + * @return {Object} + * @api private + */ + + function parseHeader(str) { + var lines = str.split(/\r?\n/); + var fields = {}; + var index; + var line; + var field; + var val; + + for (var i = 0, len = lines.length; i < len; ++i) { + line = lines[i]; + index = line.indexOf(':'); + + if (index === -1) { + // could be empty line, just skip it + continue; + } + + field = line.slice(0, index).toLowerCase(); + val = trim(line.slice(index + 1)); + fields[field] = val; + } + + return fields; + } + /** + * Check if `mime` is json or has +json structured syntax suffix. + * + * @param {String} mime + * @return {Boolean} + * @api private + */ + + + function isJSON(mime) { + // should match /json or +json + // but not /json-seq + return /[/+]json($|[^-\w])/.test(mime); + } + /** + * Initialize a new `Response` with the given `xhr`. + * + * - set flags (.ok, .error, etc) + * - parse header + * + * Examples: + * + * Aliasing `superagent` as `request` is nice: + * + * request = superagent; + * + * We can use the promise-like API, or pass callbacks: + * + * request.get('/').end(function(res){}); + * request.get('/', function(res){}); + * + * Sending data can be chained: + * + * request + * .post('/user') + * .send({ name: 'tj' }) + * .end(function(res){}); + * + * Or passed to `.send()`: + * + * request + * .post('/user') + * .send({ name: 'tj' }, function(res){}); + * + * Or passed to `.post()`: + * + * request + * .post('/user', { name: 'tj' }) + * .end(function(res){}); + * + * Or further reduced to a single call for simple cases: + * + * request + * .post('/user', { name: 'tj' }, function(res){}); + * + * @param {XMLHTTPRequest} xhr + * @param {Object} options + * @api private + */ + + + function Response(req) { + this.req = req; + this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers + + this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null; + this.statusText = this.req.xhr.statusText; + var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request + + if (status === 1223) { + status = 204; + } + + this._setStatusProperties(status); + + this.headers = parseHeader(this.xhr.getAllResponseHeaders()); + this.header = this.headers; // getAllResponseHeaders sometimes falsely returns "" for CORS requests, but + // getResponseHeader still works. so we get content-type even if getting + // other headers fails. + + this.header['content-type'] = this.xhr.getResponseHeader('content-type'); + + this._setHeaderProperties(this.header); + + if (this.text === null && req._responseType) { + this.body = this.xhr.response; + } else { + this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response); + } + } // eslint-disable-next-line new-cap + + + responseBase(Response.prototype); + /** + * Parse the given body `str`. + * + * Used for auto-parsing of bodies. Parsers + * are defined on the `superagent.parse` object. + * + * @param {String} str + * @return {Mixed} + * @api private + */ + + Response.prototype._parseBody = function (str) { + var parse = request.parse[this.type]; + + if (this.req._parser) { + return this.req._parser(this, str); + } + + if (!parse && isJSON(this.type)) { + parse = request.parse['application/json']; + } + + return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null; + }; + /** + * Return an `Error` representative of this response. + * + * @return {Error} + * @api public + */ + + + Response.prototype.toError = function () { + var req = this.req; + var method = req.method; + var url = req.url; + var msg = "cannot ".concat(method, " ").concat(url, " (").concat(this.status, ")"); + var err = new Error(msg); + err.status = this.status; + err.method = method; + err.url = url; + return err; + }; + /** + * Expose `Response`. + */ + + + request.Response = Response; + /** + * Initialize a new `Request` with the given `method` and `url`. + * + * @param {String} method + * @param {String} url + * @api public + */ + + function Request(method, url) { + var self = this; + this._query = this._query || []; + this.method = method; + this.url = url; + this.header = {}; // preserves header name case + + this._header = {}; // coerces header names to lowercase + + this.on('end', function () { + var err = null; + var res = null; + + try { + res = new Response(self); + } catch (err_) { + err = new Error('Parser is unable to parse the response'); + err.parse = true; + err.original = err_; // issue #675: return the raw response if the response parsing fails + + if (self.xhr) { + // ie9 doesn't have 'response' property + err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails + + err.status = self.xhr.status ? self.xhr.status : null; + err.statusCode = err.status; // backwards-compat only + } else { + err.rawResponse = null; + err.status = null; + } + + return self.callback(err); + } + + self.emit('response', res); + var new_err; + + try { + if (!self._isResponseOK(res)) { + new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response'); + } + } catch (err_) { + new_err = err_; // ok() callback can throw + } // #1000 don't catch errors from the callback to avoid double calling it + + + if (new_err) { + new_err.original = err; + new_err.response = res; + new_err.status = res.status; + self.callback(new_err, res); + } else { + self.callback(null, res); + } + }); + } + /** + * Mixin `Emitter` and `RequestBase`. + */ + // eslint-disable-next-line new-cap + + + componentEmitter(Request.prototype); // eslint-disable-next-line new-cap + + requestBase(Request.prototype); + /** + * Set Content-Type to `type`, mapping values from `request.types`. + * + * Examples: + * + * superagent.types.xml = 'application/xml'; + * + * request.post('/') + * .type('xml') + * .send(xmlstring) + * .end(callback); + * + * request.post('/') + * .type('application/xml') + * .send(xmlstring) + * .end(callback); + * + * @param {String} type + * @return {Request} for chaining + * @api public + */ + + Request.prototype.type = function (type) { + this.set('Content-Type', request.types[type] || type); + return this; + }; + /** + * Set Accept to `type`, mapping values from `request.types`. + * + * Examples: + * + * superagent.types.json = 'application/json'; + * + * request.get('/agent') + * .accept('json') + * .end(callback); + * + * request.get('/agent') + * .accept('application/json') + * .end(callback); + * + * @param {String} accept + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.accept = function (type) { + this.set('Accept', request.types[type] || type); + return this; + }; + /** + * Set Authorization field value with `user` and `pass`. + * + * @param {String} user + * @param {String} [pass] optional in case of using 'bearer' as type + * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic') + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.auth = function (user, pass, options) { + if (arguments.length === 1) pass = ''; + + if (_typeof(pass) === 'object' && pass !== null) { + // pass is optional and can be replaced with options + options = pass; + pass = ''; + } + + if (!options) { + options = { + type: typeof btoa === 'function' ? 'basic' : 'auto' + }; + } + + var encoder = function encoder(string) { + if (typeof btoa === 'function') { + return btoa(string); + } + + throw new Error('Cannot use basic auth, btoa is not a function'); + }; + + return this._auth(user, pass, options, encoder); + }; + /** + * Add query-string `val`. + * + * Examples: + * + * request.get('/shoes') + * .query('size=10') + * .query({ color: 'blue' }) + * + * @param {Object|String} val + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.query = function (val) { + if (typeof val !== 'string') val = serialize(val); + if (val) this._query.push(val); + return this; + }; + /** + * Queue the given `file` as an attachment to the specified `field`, + * with optional `options` (or filename). + * + * ``` js + * request.post('/upload') + * .attach('content', new Blob(['hey!'], { type: "text/html"})) + * .end(callback); + * ``` + * + * @param {String} field + * @param {Blob|File} file + * @param {String|Object} options + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.attach = function (field, file, options) { + if (file) { + if (this._data) { + throw new Error("superagent can't mix .send() and .attach()"); + } + + this._getFormData().append(field, file, options || file.name); + } + + return this; + }; + + Request.prototype._getFormData = function () { + if (!this._formData) { + this._formData = new root.FormData(); + } + + return this._formData; + }; + /** + * Invoke the callback with `err` and `res` + * and handle arity check. + * + * @param {Error} err + * @param {Response} res + * @api private + */ + + + Request.prototype.callback = function (err, res) { + if (this._shouldRetry(err, res)) { + return this._retry(); + } + + var fn = this._callback; + this.clearTimeout(); + + if (err) { + if (this._maxRetries) err.retries = this._retries - 1; + this.emit('error', err); + } + + fn(err, res); + }; + /** + * Invoke callback with x-domain error. + * + * @api private + */ + + + Request.prototype.crossDomainError = function () { + var err = new Error('Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.'); + err.crossDomain = true; + err.status = this.status; + err.method = this.method; + err.url = this.url; + this.callback(err); + }; // This only warns, because the request is still likely to work + + + Request.prototype.agent = function () { + console.warn('This is not supported in browser version of superagent'); + return this; + }; + + Request.prototype.ca = Request.prototype.agent; + Request.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected + + Request.prototype.write = function () { + throw new Error('Streaming is not supported in browser version of superagent'); + }; + + Request.prototype.pipe = Request.prototype.write; + /** + * Check if `obj` is a host object, + * we don't want to serialize these :) + * + * @param {Object} obj host object + * @return {Boolean} is a host object + * @api private + */ + + Request.prototype._isHost = function (obj) { + // Native objects stringify to [object File], [object Blob], [object FormData], etc. + return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]'; + }; + /** + * Initiate request, invoking callback `fn(res)` + * with an instanceof `Response`. + * + * @param {Function} fn + * @return {Request} for chaining + * @api public + */ + + + Request.prototype.end = function (fn) { + if (this._endCalled) { + console.warn('Warning: .end() was called twice. This is not supported in superagent'); + } + + this._endCalled = true; // store callback + + this._callback = fn || noop; // querystring + + this._finalizeQueryString(); + + this._end(); + }; + + Request.prototype._setUploadTimeout = function () { + var self = this; // upload timeout it's wokrs only if deadline timeout is off + + if (this._uploadTimeout && !this._uploadTimeoutTimer) { + this._uploadTimeoutTimer = setTimeout(function () { + self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT'); + }, this._uploadTimeout); + } + }; // eslint-disable-next-line complexity + + + Request.prototype._end = function () { + if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called')); + var self = this; + this.xhr = request.getXHR(); + var xhr = this.xhr; + var data = this._formData || this._data; + + this._setTimeouts(); // state change + + + xhr.onreadystatechange = function () { + var readyState = xhr.readyState; + + if (readyState >= 2 && self._responseTimeoutTimer) { + clearTimeout(self._responseTimeoutTimer); + } + + if (readyState !== 4) { + return; + } // In IE9, reads to any property (e.g. status) off of an aborted XHR will + // result in the error "Could not complete the operation due to error c00c023f" + + + var status; + + try { + status = xhr.status; + } catch (_unused5) { + status = 0; + } + + if (!status) { + if (self.timedout || self._aborted) return; + return self.crossDomainError(); + } + + self.emit('end'); + }; // progress + + + var handleProgress = function handleProgress(direction, e) { + if (e.total > 0) { + e.percent = e.loaded / e.total * 100; + + if (e.percent === 100) { + clearTimeout(self._uploadTimeoutTimer); + } + } + + e.direction = direction; + self.emit('progress', e); + }; + + if (this.hasListeners('progress')) { + try { + xhr.addEventListener('progress', handleProgress.bind(null, 'download')); + + if (xhr.upload) { + xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload')); + } + } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist. + // Reported here: + // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context + } + } + + if (xhr.upload) { + this._setUploadTimeout(); + } // initiate request + + + try { + if (this.username && this.password) { + xhr.open(this.method, this.url, true, this.username, this.password); + } else { + xhr.open(this.method, this.url, true); + } + } catch (err) { + // see #1149 + return this.callback(err); + } // CORS + + + if (this._withCredentials) xhr.withCredentials = true; // body + + if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) { + // serialize stuff + var contentType = this._header['content-type']; + + var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : '']; + + if (!_serialize && isJSON(contentType)) { + _serialize = request.serialize['application/json']; + } + + if (_serialize) data = _serialize(data); + } // set header fields + + + for (var field in this.header) { + if (this.header[field] === null) continue; + if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]); + } + + if (this._responseType) { + xhr.responseType = this._responseType; + } // send stuff + + + this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing) + // We need null here if data is undefined + + xhr.send(typeof data === 'undefined' ? null : data); + }; + + request.agent = function () { + return new agentBase(); + }; + + ['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) { + agentBase.prototype[method.toLowerCase()] = function (url, fn) { + var req = new request.Request(method, url); + + this._setDefaults(req); + + if (fn) { + req.end(fn); + } + + return req; + }; + }); + agentBase.prototype.del = agentBase.prototype.delete; + /** + * GET `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + request.get = function (url, data, fn) { + var req = request('GET', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.query(data); + if (fn) req.end(fn); + return req; + }; + /** + * HEAD `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.head = function (url, data, fn) { + var req = request('HEAD', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.query(data); + if (fn) req.end(fn); + return req; + }; + /** + * OPTIONS query to `url` with optional callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.options = function (url, data, fn) { + var req = request('OPTIONS', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * DELETE `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + function del(url, data, fn) { + var req = request('DELETE', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + } + + request.del = del; + request.delete = del; + /** + * PATCH `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + request.patch = function (url, data, fn) { + var req = request('PATCH', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * POST `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed} [data] + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.post = function (url, data, fn) { + var req = request('POST', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + /** + * PUT `url` with optional `data` and callback `fn(res)`. + * + * @param {String} url + * @param {Mixed|Function} [data] or fn + * @param {Function} [fn] + * @return {Request} + * @api public + */ + + + request.put = function (url, data, fn) { + var req = request('PUT', url); + + if (typeof data === 'function') { + fn = data; + data = null; + } + + if (data) req.send(data); + if (fn) req.end(fn); + return req; + }; + + }); + var client_1 = client.Request; + + var byteLength_1 = byteLength; + var toByteArray_1 = toByteArray; + var fromByteArray_1 = fromByteArray; + + var lookup = []; + var revLookup = []; + var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array; + + var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; + for (var i = 0, len = code.length; i < len; ++i) { + lookup[i] = code[i]; + revLookup[code.charCodeAt(i)] = i; + } + + // Support decoding URL-safe base64 strings, as Node.js does. + // See: https://en.wikipedia.org/wiki/Base64#URL_applications + revLookup['-'.charCodeAt(0)] = 62; + revLookup['_'.charCodeAt(0)] = 63; + + function getLens (b64) { + var len = b64.length; + + if (len % 4 > 0) { + throw new Error('Invalid string. Length must be a multiple of 4') + } + + // Trim off extra bytes after placeholder bytes are found + // See: https://github.com/beatgammit/base64-js/issues/42 + var validLen = b64.indexOf('='); + if (validLen === -1) validLen = len; + + var placeHoldersLen = validLen === len + ? 0 + : 4 - (validLen % 4); + + return [validLen, placeHoldersLen] + } + + // base64 is 4/3 + up to two characters of the original data + function byteLength (b64) { + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen + } + + function _byteLength (b64, validLen, placeHoldersLen) { + return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen + } + + function toByteArray (b64) { + var tmp; + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + + var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen)); + + var curByte = 0; + + // if there are placeholders, only get up to the last complete 4 chars + var len = placeHoldersLen > 0 + ? validLen - 4 + : validLen; + + var i; + for (i = 0; i < len; i += 4) { + tmp = + (revLookup[b64.charCodeAt(i)] << 18) | + (revLookup[b64.charCodeAt(i + 1)] << 12) | + (revLookup[b64.charCodeAt(i + 2)] << 6) | + revLookup[b64.charCodeAt(i + 3)]; + arr[curByte++] = (tmp >> 16) & 0xFF; + arr[curByte++] = (tmp >> 8) & 0xFF; + arr[curByte++] = tmp & 0xFF; + } + + if (placeHoldersLen === 2) { + tmp = + (revLookup[b64.charCodeAt(i)] << 2) | + (revLookup[b64.charCodeAt(i + 1)] >> 4); + arr[curByte++] = tmp & 0xFF; + } + + if (placeHoldersLen === 1) { + tmp = + (revLookup[b64.charCodeAt(i)] << 10) | + (revLookup[b64.charCodeAt(i + 1)] << 4) | + (revLookup[b64.charCodeAt(i + 2)] >> 2); + arr[curByte++] = (tmp >> 8) & 0xFF; + arr[curByte++] = tmp & 0xFF; + } + + return arr + } + + function tripletToBase64 (num) { + return lookup[num >> 18 & 0x3F] + + lookup[num >> 12 & 0x3F] + + lookup[num >> 6 & 0x3F] + + lookup[num & 0x3F] + } + + function encodeChunk (uint8, start, end) { + var tmp; + var output = []; + for (var i = start; i < end; i += 3) { + tmp = + ((uint8[i] << 16) & 0xFF0000) + + ((uint8[i + 1] << 8) & 0xFF00) + + (uint8[i + 2] & 0xFF); + output.push(tripletToBase64(tmp)); + } + return output.join('') + } + + function fromByteArray (uint8) { + var tmp; + var len = uint8.length; + var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes + var parts = []; + var maxChunkLength = 16383; // must be multiple of 3 + + // go through the array every three bytes, we'll deal with trailing stuff later + for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { + parts.push(encodeChunk( + uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength) + )); + } + + // pad the end with zeros, but make sure to not forget the extra bytes + if (extraBytes === 1) { + tmp = uint8[len - 1]; + parts.push( + lookup[tmp >> 2] + + lookup[(tmp << 4) & 0x3F] + + '==' + ); + } else if (extraBytes === 2) { + tmp = (uint8[len - 2] << 8) + uint8[len - 1]; + parts.push( + lookup[tmp >> 10] + + lookup[(tmp >> 4) & 0x3F] + + lookup[(tmp << 2) & 0x3F] + + '=' + ); + } + + return parts.join('') + } + + var base64Js = { + byteLength: byteLength_1, + toByteArray: toByteArray_1, + fromByteArray: fromByteArray_1 + }; + + function padding(str) { + var mod = str.length % 4; + var pad = 4 - mod; + + if (mod === 0) { + return str; + } + + return str + new Array(1 + pad).join('='); + } + + function stringToByteArray(str) { + var arr = new Array(str.length); + for (var a = 0; a < str.length; a++) { + arr[a] = str.charCodeAt(a); + } + return arr; + } + + function byteArrayToString(array) { + var result = ''; + for (var i = 0; i < array.length; i++) { + result += String.fromCharCode(array[i]); + } + return result; + } + + function encode$1(str) { + return base64Js + .fromByteArray(stringToByteArray(str)) + .replace(/\+/g, '-') // Convert '+' to '-' + .replace(/\//g, '_'); // Convert '/' to '_' + } + + function decode$1(str) { + str = padding(str) + .replace(/-/g, '+') // Convert '-' to '+' + .replace(/_/g, '/'); // Convert '_' to '/' + + return byteArrayToString(base64Js.toByteArray(str)); + } + + var base64Url = { + encode: encode$1, + decode: decode$1 + }; + + var version = { raw: '9.14.3' }; + + var toString = Object.prototype.toString; + + function attribute(o, attr, type, text) { + type = type === 'array' ? 'object' : type; + if (o && typeof o[attr] !== type) { + throw new Error(text); + } + } + + function variable(o, type, text) { + if (typeof o !== type) { + throw new Error(text); + } + } + + function value(o, values, text) { + if (values.indexOf(o) === -1) { + throw new Error(text); + } + } + + function check(o, config, attributes) { + if (!config.optional || o) { + variable(o, config.type, config.message); + } + if (config.type === 'object' && attributes) { + var keys = Object.keys(attributes); + + for (var index = 0; index < keys.length; index++) { + var a = keys[index]; + if (!attributes[a].optional || o[a]) { + if (!attributes[a].condition || attributes[a].condition(o)) { + attribute(o, a, attributes[a].type, attributes[a].message); + if (attributes[a].values) { + value(o[a], attributes[a].values, attributes[a].value_message); + } + } + } + } + } + } + + /** + * Wrap `Array.isArray` Polyfill for IE9 + * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray + * + * @param {Array} array + * @private + */ + function isArray$3(array) { + if (this.supportsIsArray()) { + return Array.isArray(array); + } + + return toString.call(array) === '[object Array]'; + } + + function supportsIsArray() { + return Array.isArray != null; + } + + var assert = { + check: check, + attribute: attribute, + variable: variable, + value: value, + isArray: isArray$3, + supportsIsArray: supportsIsArray + }; + + /* eslint-disable no-continue */ + + function get() { + if (!Object.assign) { + return objectAssignPolyfill; + } + + return Object.assign; + } + + function objectAssignPolyfill(target) { + if (target === undefined || target === null) { + throw new TypeError('Cannot convert first argument to object'); + } + + var to = Object(target); + for (var i = 1; i < arguments.length; i++) { + var nextSource = arguments[i]; + if (nextSource === undefined || nextSource === null) { + continue; + } + + var keysArray = Object.keys(Object(nextSource)); + for ( + var nextIndex = 0, len = keysArray.length; + nextIndex < len; + nextIndex++ + ) { + var nextKey = keysArray[nextIndex]; + var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); + if (desc !== undefined && desc.enumerable) { + to[nextKey] = nextSource[nextKey]; + } + } + } + return to; + } + + var objectAssign = { + get: get, + objectAssignPolyfill: objectAssignPolyfill + }; + + /* eslint-disable no-param-reassign */ + + function pick(object, keys) { + return keys.reduce(function(prev, key) { + if (object[key]) { + prev[key] = object[key]; + } + return prev; + }, {}); + } + + function getKeysNotIn(obj, allowedKeys) { + var notAllowed = []; + for (var key in obj) { + if (allowedKeys.indexOf(key) === -1) { + notAllowed.push(key); + } + } + return notAllowed; + } + + function objectValues(obj) { + var values = []; + for (var key in obj) { + values.push(obj[key]); + } + return values; + } + + function extend() { + var params = objectValues(arguments); + params.unshift({}); + return objectAssign.get().apply(undefined, params); + } + + function merge$1(object, keys) { + return { + base: keys ? pick(object, keys) : object, + with: function(object2, keys2) { + object2 = keys2 ? pick(object2, keys2) : object2; + return extend(this.base, object2); + } + }; + } + + function blacklist(object, blacklistedKeys) { + return Object.keys(object).reduce(function(p, key) { + if (blacklistedKeys.indexOf(key) === -1) { + p[key] = object[key]; + } + return p; + }, {}); + } + + function camelToSnake(str) { + var newKey = ''; + var index = 0; + var code; + var wasPrevNumber = true; + var wasPrevUppercase = true; + + while (index < str.length) { + code = str.charCodeAt(index); + if ( + (!wasPrevUppercase && code >= 65 && code <= 90) || + (!wasPrevNumber && code >= 48 && code <= 57) + ) { + newKey += '_'; + newKey += str[index].toLowerCase(); + } else { + newKey += str[index].toLowerCase(); + } + wasPrevNumber = code >= 48 && code <= 57; + wasPrevUppercase = code >= 65 && code <= 90; + index++; + } + + return newKey; + } + + function snakeToCamel(str) { + var parts = str.split('_'); + return parts.reduce(function(p, c) { + return p + c.charAt(0).toUpperCase() + c.slice(1); + }, parts.shift()); + } + + function toSnakeCase(object, exceptions) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + exceptions = exceptions || []; + + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key; + p[newKey] = toSnakeCase(object[key]); + return p; + }, {}); + } + + function toCamelCase(object, exceptions, options) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + + exceptions = exceptions || []; + options = options || {}; + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key; + + p[newKey] = toCamelCase(object[newKey] || object[key], [], options); + + if (options.keepOriginal) { + p[key] = toCamelCase(object[key], [], options); + } + return p; + }, {}); + } + + function getLocationFromUrl(href) { + var match = href.match( + /^(https?:|file:|chrome-extension:)\/\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\?[^#]*|)(#.*|)$/ + ); + return ( + match && { + href: href, + protocol: match[1], + host: match[2], + hostname: match[3], + port: match[4], + pathname: match[5], + search: match[6], + hash: match[7] + } + ); + } + + function getOriginFromUrl(url) { + if (!url) { + return undefined; + } + var parsed = getLocationFromUrl(url); + if (!parsed) { + return null; + } + var origin = parsed.protocol + '//' + parsed.hostname; + if (parsed.port) { + origin += ':' + parsed.port; + } + return origin; + } + + function trim(options, key) { + var trimmed = extend(options); + if (options[key]) { + trimmed[key] = options[key].trim(); + } + return trimmed; + } + + function trimMultiple(options, keys) { + return keys.reduce(trim, options); + } + + function trimUserDetails(options) { + return trimMultiple(options, ['username', 'email', 'phoneNumber']); + } + + /** + * Updates the value of a property on the given object, using a deep path selector. + * @param {object} obj The object to set the property value on + * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3'] + * @param {any} value The value to set + */ + function updatePropertyOn(obj, path, value) { + if (typeof path === 'string') { + path = path.split('.'); + } + + var next = path[0]; + + if (obj.hasOwnProperty(next)) { + if (path.length === 1) { + obj[next] = value; + } else { + updatePropertyOn(obj[next], path.slice(1), value); + } + } + } + + var objectHelper = { + toSnakeCase: toSnakeCase, + toCamelCase: toCamelCase, + blacklist: blacklist, + merge: merge$1, + pick: pick, + getKeysNotIn: getKeysNotIn, + extend: extend, + getOriginFromUrl: getOriginFromUrl, + getLocationFromUrl: getLocationFromUrl, + trimUserDetails: trimUserDetails, + updatePropertyOn: updatePropertyOn + }; + + /* eslint-disable no-param-reassign */ + + // ------------------------------------------------ RequestWrapper + + function RequestWrapper(req) { + this.request = req; + this.method = req.method; + this.url = req.url; + this.body = req._data; + this.headers = req._header; + } + + RequestWrapper.prototype.abort = function() { + this.request.abort(); + }; + + RequestWrapper.prototype.getMethod = function() { + return this.method; + }; + + RequestWrapper.prototype.getBody = function() { + return this.body; + }; + + RequestWrapper.prototype.getUrl = function() { + return this.url; + }; + + RequestWrapper.prototype.getHeaders = function() { + return this.headers; + }; + + // ------------------------------------------------ RequestObj + + function RequestObj(req) { + this.request = req; + } + + RequestObj.prototype.set = function(key, value) { + this.request = this.request.set(key, value); + return this; + }; + + RequestObj.prototype.send = function(body) { + this.request = this.request.send(objectHelper.trimUserDetails(body)); + return this; + }; + + RequestObj.prototype.withCredentials = function() { + this.request = this.request.withCredentials(); + return this; + }; + + RequestObj.prototype.end = function(cb) { + this.request.end(cb); + return new RequestWrapper(this.request); + }; + + // ------------------------------------------------ RequestBuilder + + function RequestBuilder(options) { + this._sendTelemetry = + options._sendTelemetry === false ? options._sendTelemetry : true; + this._telemetryInfo = options._telemetryInfo || null; + this._timesToRetryFailedRequests = options._timesToRetryFailedRequests; + this.headers = options.headers || {}; + this._universalLoginPage = options.universalLoginPage; + } + + RequestBuilder.prototype.setCommonConfiguration = function( + ongoingRequest, + options + ) { + options = options || {}; + + if (this._timesToRetryFailedRequests > 0) { + ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests); + } + + if (options.noHeaders) { + return ongoingRequest; + } + + var headers = this.headers; + ongoingRequest = ongoingRequest.set('Content-Type', 'application/json'); + + var keys = Object.keys(this.headers); + + for (var a = 0; a < keys.length; a++) { + ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]); + } + + if (this._sendTelemetry) { + ongoingRequest = ongoingRequest.set( + 'Auth0-Client', + this.getTelemetryData() + ); + } + + return ongoingRequest; + }; + + RequestBuilder.prototype.getTelemetryData = function() { + var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js'; + var clientInfo = { name: telemetryName, version: version.raw }; + if (this._telemetryInfo) { + clientInfo = objectHelper.extend({}, this._telemetryInfo); + clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env); + clientInfo.env[telemetryName] = version.raw; + } + var jsonClientInfo = JSON.stringify(clientInfo); + return base64Url.encode(jsonClientInfo); + }; + + RequestBuilder.prototype.get = function(url, options) { + return new RequestObj(this.setCommonConfiguration(client.get(url), options)); + }; + + RequestBuilder.prototype.post = function(url, options) { + return new RequestObj( + this.setCommonConfiguration(client.post(url), options) + ); + }; + + RequestBuilder.prototype.patch = function(url, options) { + return new RequestObj( + this.setCommonConfiguration(client.patch(url), options) + ); + }; + + function redirect(url) { + getWindow().location = url; + } + + function getDocument() { + return getWindow().document; + } + + function getWindow() { + return window; + } + + function getOrigin() { + var location = getWindow().location; + var origin = location.origin; + + if (!origin) { + origin = objectHelper.getOriginFromUrl(location.href); + } + + return origin; + } + + var windowHelper = { + redirect: redirect, + getDocument: getDocument, + getWindow: getWindow, + getOrigin: getOrigin + }; + + function DummyStorage() {} + + DummyStorage.prototype.getItem = function() { + return null; + }; + + DummyStorage.prototype.removeItem = function() {}; + + DummyStorage.prototype.setItem = function() {}; + + var js_cookie = createCommonjsModule(function (module, exports) { + (function (factory) { + var registeredInModuleLoader; + { + module.exports = factory(); + registeredInModuleLoader = true; + } + if (!registeredInModuleLoader) { + var OldCookies = window.Cookies; + var api = window.Cookies = factory(); + api.noConflict = function () { + window.Cookies = OldCookies; + return api; + }; + } + }(function () { + function extend () { + var i = 0; + var result = {}; + for (; i < arguments.length; i++) { + var attributes = arguments[ i ]; + for (var key in attributes) { + result[key] = attributes[key]; + } + } + return result; + } + + function decode (s) { + return s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent); + } + + function init (converter) { + function api() {} + + function set (key, value, attributes) { + if (typeof document === 'undefined') { + return; + } + + attributes = extend({ + path: '/' + }, api.defaults, attributes); + + if (typeof attributes.expires === 'number') { + attributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5); + } + + // We're using "expires" because "max-age" is not supported by IE + attributes.expires = attributes.expires ? attributes.expires.toUTCString() : ''; + + try { + var result = JSON.stringify(value); + if (/^[\{\[]/.test(result)) { + value = result; + } + } catch (e) {} + + value = converter.write ? + converter.write(value, key) : + encodeURIComponent(String(value)) + .replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent); + + key = encodeURIComponent(String(key)) + .replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent) + .replace(/[\(\)]/g, escape); + + var stringifiedAttributes = ''; + for (var attributeName in attributes) { + if (!attributes[attributeName]) { + continue; + } + stringifiedAttributes += '; ' + attributeName; + if (attributes[attributeName] === true) { + continue; + } + + // Considers RFC 6265 section 5.2: + // ... + // 3. If the remaining unparsed-attributes contains a %x3B (";") + // character: + // Consume the characters of the unparsed-attributes up to, + // not including, the first %x3B (";") character. + // ... + stringifiedAttributes += '=' + attributes[attributeName].split(';')[0]; + } + + return (document.cookie = key + '=' + value + stringifiedAttributes); + } + + function get (key, json) { + if (typeof document === 'undefined') { + return; + } + + var jar = {}; + // To prevent the for loop in the first place assign an empty array + // in case there are no cookies at all. + var cookies = document.cookie ? document.cookie.split('; ') : []; + var i = 0; + + for (; i < cookies.length; i++) { + var parts = cookies[i].split('='); + var cookie = parts.slice(1).join('='); + + if (!json && cookie.charAt(0) === '"') { + cookie = cookie.slice(1, -1); + } + + try { + var name = decode(parts[0]); + cookie = (converter.read || converter)(cookie, name) || + decode(cookie); + + if (json) { + try { + cookie = JSON.parse(cookie); + } catch (e) {} + } + + jar[name] = cookie; + + if (key === name) { + break; + } + } catch (e) {} + } + + return key ? jar[key] : jar; + } + + api.set = set; + api.get = function (key) { + return get(key, false /* read as raw */); + }; + api.getJSON = function (key) { + return get(key, true /* read as json */); + }; + api.remove = function (key, attributes) { + set(key, '', extend(attributes, { + expires: -1 + })); + }; + + api.defaults = {}; + + api.withConverter = init; + + return api; + } + + return init(function () {}); + })); + }); + + function CookieStorage() {} + + CookieStorage.prototype.getItem = function(key) { + return js_cookie.get(key); + }; + + CookieStorage.prototype.removeItem = function(key) { + js_cookie.remove(key); + }; + + CookieStorage.prototype.setItem = function(key, value, options) { + var params = objectHelper.extend( + { + expires: 1 // 1 day + }, + options + ); + js_cookie.set(key, value, params); + }; + + /* eslint-disable no-console */ + + function Warn(options) { + this.disableWarnings = options.disableWarnings; + } + + Warn.prototype.warning = function(message) { + if (this.disableWarnings) { + return; + } + + console.warn(message); + }; + + function StorageHandler(options) { + this.warn = new Warn({}); + this.storage = new CookieStorage(); + if (options.__tryLocalStorageFirst !== true) { + return; + } + try { + // some browsers throw an error when trying to access localStorage + // when localStorage is disabled. + var localStorage = windowHelper.getWindow().localStorage; + if (localStorage) { + this.storage = localStorage; + } + } catch (e) { + this.warn.warning(e); + this.warn.warning("Can't use localStorage. Using CookieStorage instead."); + } + } + + StorageHandler.prototype.failover = function() { + if (this.storage instanceof DummyStorage) { + this.warn.warning('DummyStorage: ignore failover'); + return; + } else if (this.storage instanceof CookieStorage) { + this.warn.warning('CookieStorage: failing over DummyStorage'); + this.storage = new DummyStorage(); + } else { + this.warn.warning('LocalStorage: failing over CookieStorage'); + this.storage = new CookieStorage(); + } + }; + + StorageHandler.prototype.getItem = function(key) { + try { + return this.storage.getItem(key); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.getItem(key); + } + }; + + StorageHandler.prototype.removeItem = function(key) { + try { + return this.storage.removeItem(key); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.removeItem(key); + } + }; + + StorageHandler.prototype.setItem = function(key, value, options) { + try { + return this.storage.setItem(key, value, options); + } catch (e) { + this.warn.warning(e); + this.failover(); + return this.setItem(key, value, options); + } + }; + + function Storage(options) { + this.handler = new StorageHandler(options); + } + + Storage.prototype.getItem = function(key) { + var value = this.handler.getItem(key); + try { + return JSON.parse(value); + } catch (_) { + return value; + } + }; + Storage.prototype.removeItem = function(key) { + return this.handler.removeItem(key); + }; + Storage.prototype.setItem = function(key, value, options) { + var json = JSON.stringify(value); + return this.handler.setItem(key, json, options); + }; + + function SSODataStorage(options) { + this.storage = new Storage(options); + } + + SSODataStorage.prototype.set = function(connection, sub) { + var ssodata = { + lastUsedConnection: connection, + lastUsedSub: sub + }; + this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata)); + }; + SSODataStorage.prototype.get = function() { + var ssodata = this.storage.getItem('auth0.ssodata'); + if (!ssodata) { + return; + } + return JSON.parse(ssodata); + }; + + function buildResponse(error, description) { + return { + error: error, + errorDescription: description + }; + } + + function invalidToken(description) { + return buildResponse('invalid_token', description); + } + + var error = { + buildResponse: buildResponse, + invalidToken: invalidToken + }; + + function wrapCallback(cb, options) { + options = options || {}; + options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false; + + return function(err, data) { + var errObj; + + if (!err && !data) { + return cb(error.buildResponse('generic_error', 'Something went wrong')); + } + + if (!err && data.err) { + err = data.err; + data = null; + } + + if (!err && data.error) { + err = data; + data = null; + } + + if (err) { + errObj = { + original: err + }; + + objectHelper.updatePropertyOn( + errObj, + 'original.response.req._data.password', + '*****' + ); + + if (err.response && err.response.statusCode) { + errObj.statusCode = err.response.statusCode; + } + + if (err.response && err.response.statusText) { + errObj.statusText = err.response.statusText; + } + + if (err.response && err.response.body) { + err = err.response.body; + } + + if (err.err) { + err = err.err; + } + + errObj.code = + err.code || err.error || err.error_code || err.status || null; + + errObj.description = + err.errorDescription || + err.error_description || + err.description || + err.error || + err.details || + err.err || + null; + + if (options.forceLegacyError) { + errObj.error = errObj.code; + errObj.error_description = errObj.description; + } + + if (err.error_codes && err.error_details) { + errObj.errorDetails = { + codes: err.error_codes, + details: err.error_details + }; + } + + if (err.name) { + errObj.name = err.name; + } + + if (err.policy) { + errObj.policy = err.policy; + } + + return cb(errObj); + } + + if ( + data.type && + (data.type === 'text/html' || data.type === 'text/plain') + ) { + return cb(null, data.text); + } + + if (options.ignoreCasing) { + return cb(null, data.body || data); + } + + return cb( + null, + objectHelper.toCamelCase(data.body || data, [], { + keepOriginal: options.keepOriginalCasing + }) + ); + }; + } + + // For future reference:, + + var tokenParams = [ + // auth0 + 'realm', + 'audience', + 'otp', + // oauth2 + 'client_id', + 'client_secret', + 'redirect_uri', + 'scope', + 'code', + 'grant_type', + 'username', + 'password', + 'refresh_token', + 'assertion', + 'client_assertion', + 'client_assertion_type', + 'code_verifier' + ]; + + var authorizeParams = [ + // auth0 + 'connection', + 'connection_scope', + 'auth0Client', + 'owp', + 'device', + 'realm', + + 'protocol', + '_csrf', + '_intstate', + 'login_ticket', + + // oauth2 + 'client_id', + 'response_type', + 'response_mode', + 'redirect_uri', + 'audience', + 'scope', + 'state', + 'nonce', + 'display', + 'prompt', + 'screen_hint', + 'max_age', + 'ui_locales', + 'claims_locales', + 'id_token_hint', + 'login_hint', + 'acr_values', + 'claims', + 'registration', + 'request', + 'request_uri', + 'code_challenge', + 'code_challenge_method', + + // ADDITIONAL_PARAMETERS: + // https://auth0.com/docs/api/authentication?javascript#social + 'access_type', + 'display' + ]; + + function oauthAuthorizeParams(warn, params) { + var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams); + + if (notAllowed.length > 0) { + warn.warning( + 'Following parameters are not allowed on the `/authorize` endpoint: [' + + notAllowed.join(',') + + ']' + ); + } + + return params; + } + + function oauthTokenParams(warn, params) { + return objectHelper.pick(params, tokenParams); + } + + var parametersWhitelist = { + oauthTokenParams: oauthTokenParams, + oauthAuthorizeParams: oauthAuthorizeParams + }; + + var t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return "function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return "[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w());},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4);},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16));}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0;},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes;},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16];}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0;}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0;},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f);}(Math),r.SHA256);}),o=e(function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++;}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64);}),s=e(function(t,e){t.exports=i$1.enc.Hex;}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e));}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a;}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s;}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a;}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t;}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t;}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t);},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++;}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t);},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s;},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0;},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else {if(4!=e)return void this.fromRadix(t,e);i=2;}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB));}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t;},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s;},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp();},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else {var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s;}else {for(i+=this.s;r>=this.DB;i-=t.s;}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp();},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1);}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp();},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n);}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return (e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else {var a=n;n=o,o=a;}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return "-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else {if(4!=t)return this.toRadix(t);e=2;}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r);},T.prototype.sqrTo=function(t,e){t.squareTo(e);},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t);},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r);},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e);};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O);}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return "0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0));}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this);},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else {var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s;}else {for(i+=this.s;r>=this.DB;i+=t.s;}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp();},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp();},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e];}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return !1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2;}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else {for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s);}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a));}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i;}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E();}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16);}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return {alg:e,hash:t.substring(i)}}return []}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return !1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return -1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0];}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i();});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return {ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r;}),r(a());},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null);})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||"";}function A(t){this.name="TokenValidationError",this.message=t||"";}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return "number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A("ID token is required but missing"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A("ID token could not be decoded"),!1);var n=i.encoded.header+"."+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of "'+s+'" is not supported. Expected the ID token to be signed with "RS256".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A("Invalid ID token signature."));if(!f||"string"!=typeof f)return r(new A("Issuer (iss) claim must be a string present in the ID token",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected "'+g.issuer+'", found "'+f+'"'),!1);if(!u||"string"!=typeof u)return r(new A("Subject (sub) claim must be a string present in the ID token"),!1);if(!a||"string"!=typeof a&&!Array.isArray(a))return r(new A("Audience (aud) claim must be a string or array of strings present in the ID token"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected "'+g.audience+'" but was not one of "'+a.join(", ")+'"'));if("string"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected "'+g.audience+'" but found "'+a+'"'),!1);if(e){if(!v||"string"!=typeof v)return r(new A("Nonce (nonce) claim must be a string present in the ID token"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected "'+e+'", found "'+v+'"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)});},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11 + else if (ua.indexOf("Trident") > -1) { + var re = new RegExp("rv:([0-9]{2,2}[\.0-9]{0,})"); + if (re.exec(ua) !== null) { + rv = parseFloat(RegExp.$1); + } + } + + return rv >= 8; + } + + // checking Mobile Firefox (Fennec) + function isFennec() { + try { + // We must check for both XUL and Java versions of Fennec. Both have + // distinct UA strings. + var userAgent = navigator.userAgent; + return (userAgent.indexOf('Fennec/') != -1) || // XUL + (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java + } catch(e) {} + return false; + } + + // feature checking to see if this platform is supported at all + function isSupported() { + return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify && + window.JSON.parse && window.postMessage); + } + + // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30 + function extractOrigin(url) { + if (!/^https?:\/\//.test(url)) url = window.location.href; + var m = /^(https?:\/\/[\-_a-zA-Z\.0-9:]+)/.exec(url); + if (m) return m[1]; + return url; + } + + // find the relay iframe in the opener + function findRelay() { + var frames = window.opener.frames; + for (var i = frames.length - 1; i >= 0; i--) { + try { + if (frames[i].location.protocol === window.location.protocol && + frames[i].location.host === window.location.host && + frames[i].name === RELAY_FRAME_NAME) + { + return frames[i]; + } + } catch(e) { } + } + return; + } + + var isIE = isInternetExplorer(); + + if (isSupported()) { + /* General flow: + * 0. user clicks + * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM + * 2. caller opens window (with content from trusted domain) + * 3. window on opening adds a listener to 'message' + * (IE SPECIFIC) 4. window on opening finds iframe + * 5. window checks if iframe is "loaded" - has a 'doPost' function yet + * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller + * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready + * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event + * 6. caller upon reciept of 'ready', sends args + */ + return { + open: function(opts, cb) { + if (!cb) throw "missing required callback argument"; + + // test required options + var err; + if (!opts.url) err = "missing required 'url' parameter"; + if (!opts.relay_url) err = "missing required 'relay_url' parameter"; + if (err) setTimeout(function() { cb(err); }, 0); + + // supply default options + if (!opts.window_name) opts.window_name = null; + if (!opts.window_features || isFennec()) opts.window_features = undefined; + + // opts.params may be undefined + + var iframe; + + // sanity check, are url and relay_url the same origin? + var origin = opts.origin || extractOrigin(opts.url); + if (origin !== extractOrigin(opts.relay_url)) { + return setTimeout(function() { + cb('invalid arguments: origin of url and relay_url must match'); + }, 0); + } + + var messageTarget; + + if (isIE) { + // first we need to add a "relay" iframe to the document that's served + // from the target domain. We can postmessage into a iframe, but not a + // window + iframe = document.createElement("iframe"); + // iframe.setAttribute('name', framename); + iframe.setAttribute('src', opts.relay_url); + iframe.style.display = "none"; + iframe.setAttribute('name', RELAY_FRAME_NAME); + document.body.appendChild(iframe); + messageTarget = iframe.contentWindow; + } + + var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features); + if (opts.popup) { + w.location.href = opts.url; + } + + if (!messageTarget) messageTarget = w; + + // lets listen in case the window blows up before telling us + var closeInterval = setInterval(function() { + if (w && w.closed) { + cleanup(); + if (cb) { + cb('User closed the popup window'); + cb = null; + } + } + }, 500); + + var req = JSON.stringify({a: 'request', d: opts.params}); + + // cleanup on unload + function cleanup() { + if (iframe) document.body.removeChild(iframe); + iframe = undefined; + if (closeInterval) closeInterval = clearInterval(closeInterval); + removeListener(window, 'message', onMessage); + removeListener(window, 'unload', cleanup); + if (w) { + try { + w.close(); + } catch (securityViolation) { + // This happens in Opera 12 sometimes + // see https://github.com/mozilla/browserid/issues/1844 + messageTarget.postMessage(CLOSE_CMD, origin); + } + } + w = messageTarget = undefined; + } + + addListener(window, 'unload', cleanup); + + function onMessage(e) { + if (e.origin !== origin) { return; } + try { + var d = JSON.parse(e.data); + } catch(err) { + if (cb) { + return cb(err); + } else { + throw err; + } + } + + if (d.a === 'ready') { + messageTarget.postMessage(req, origin); + } else if (d.a === 'error') { + cleanup(); + if (cb) { + cb(d.d); + cb = null; + } + } else if (d.a === 'response') { + cleanup(); + if (cb) { + cb(null, d.d); + cb = null; + } + } + } + + addListener(window, 'message', onMessage); + + return { + originalPopup: w, + close: cleanup, + focus: function() { + if (w) { + try { + w.focus(); + } catch (e) { + // IE7 blows up here, do nothing + } + } + } + }; + }, + onOpen: function(cb) { + var o = "*"; + var msgTarget = isIE ? findRelay() : window.opener; + if (!msgTarget) throw "can't find relay frame"; + function doPost(msg) { + msg = JSON.stringify(msg); + if (isIE) msgTarget.doPost(msg, o); + else msgTarget.postMessage(msg, o); + } + + function onMessage(e) { + // only one message gets through, but let's make sure it's actually + // the message we're looking for (other code may be using + // postmessage) - we do this by ensuring the payload can + // be parsed, and it's got an 'a' (action) value of 'request'. + var d; + try { + d = JSON.parse(e.data); + } catch(err) { } + if (!d || d.a !== 'request') return; + removeListener(window, 'message', onMessage); + o = e.origin; + if (cb) { + // this setTimeout is critically important for IE8 - + // in ie8 sometimes addListener for 'message' can synchronously + // cause your callback to be invoked. awesome. + setTimeout(function() { + cb(o, d.d, function(r) { + cb = undefined; + doPost({a: 'response', d: r}); + }); + }, 0); + } + } + + function onDie(e) { + if (e.data === CLOSE_CMD) { + try { window.close(); } catch (o_O) {} + } + } + addListener(isIE ? msgTarget : window, 'message', onMessage); + addListener(isIE ? msgTarget : window, 'message', onDie); + + // we cannot post to our parent that we're ready before the iframe + // is loaded. (IE specific possible failure) + try { + doPost({a: "ready"}); + } catch(e) { + // this code should never be exectued outside IE + addListener(msgTarget, 'load', function(e) { + doPost({a: "ready"}); + }); + } + + // if window is unloaded and the client hasn't called cb, it's an error + var onUnload = function() { + try { + // IE8 doesn't like this... + removeListener(isIE ? msgTarget : window, 'message', onDie); + } catch (ohWell) { } + if (cb) doPost({ a: 'error', d: 'client closed window' }); + cb = undefined; + // explicitly close the window, in case the client is trying to reload or nav + try { window.close(); } catch (e) { } + }; + addListener(window, 'unload', onUnload); + return { + detach: function() { + removeListener(window, 'unload', onUnload); + } + }; + } + }; + } else { + return { + open: function(url, winopts, arg, cb) { + setTimeout(function() { cb("unsupported browser"); }, 0); + }, + onOpen: function(cb) { + setTimeout(function() { cb("unsupported browser"); }, 0); + } + }; + } + })(); + + if ( module.exports) { + module.exports = WinChan; + } + }); + + // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30 + function extractOrigin(url) { + if (!/^https?:\/\//.test(url)) url = window.location.href; + var m = /^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url); + if (m) return m[1]; + return url; + } + + var urlHelper = { + extractOrigin: extractOrigin + }; + + /* eslint-disable no-restricted-syntax */ + + function PopupHandler() { + this._current_popup = null; + } + + PopupHandler.prototype.calculatePosition = function(options) { + var width = options.width || 500; + var height = options.height || 600; + var _window = windowHelper.getWindow(); + + var screenX = + typeof _window.screenX !== 'undefined' + ? _window.screenX + : _window.screenLeft; + var screenY = + typeof _window.screenY !== 'undefined' + ? _window.screenY + : _window.screenTop; + + var outerWidth = + typeof _window.outerWidth !== 'undefined' + ? _window.outerWidth + : _window.document.body.clientWidth; + + var outerHeight = + typeof _window.outerHeight !== 'undefined' + ? _window.outerHeight + : _window.document.body.clientHeight; + + var left = options.left || screenX + (outerWidth - width) / 2; + var top = options.top || screenY + (outerHeight - height) / 2; + + return { width: width, height: height, left: left, top: top }; + }; + + PopupHandler.prototype.preload = function(options) { + var _this = this; + var _window = windowHelper.getWindow(); + var popupPosition = this.calculatePosition(options.popupOptions || {}); + var popupOptions = objectHelper + .merge(popupPosition) + .with(options.popupOptions); + var url = options.url || 'about:blank'; + var windowFeatures = lib.stringify(popupOptions, { + encode: false, + delimiter: ',' + }); + + if (this._current_popup && !this._current_popup.closed) { + return this._current_popup; + } + + this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures); + + this._current_popup.kill = function() { + this.close(); + _this._current_popup = null; + }; + + return this._current_popup; + }; + + PopupHandler.prototype.load = function(url, relayUrl, options, cb) { + var _this = this; + var popupPosition = this.calculatePosition(options.popupOptions || {}); + var popupOptions = objectHelper + .merge(popupPosition) + .with(options.popupOptions); + + var winchanOptions = objectHelper + .merge({ + url: url, + relay_url: relayUrl, + window_features: lib.stringify(popupOptions, { + delimiter: ',', + encode: false + }), + popup: this._current_popup + }) + .with(options); + + var popup = winchan.open(winchanOptions, function(err, data) { + // Ignores messages sent by browser extensions. + if (err && err.name === 'SyntaxError') { + return; + } + _this._current_popup = null; + return cb(err, data); + }); + + popup.focus(); + + return popup; + }; + + function Popup(webAuth, options) { + this.baseOptions = options; + this.baseOptions.popupOrigin = options.popupOrigin; + this.client = webAuth.client; + this.webAuth = webAuth; + + this.transactionManager = new TransactionManager(this.baseOptions); + this.crossOriginAuthentication = new CrossOriginAuthentication( + webAuth, + this.baseOptions + ); + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + } + + /** + * Returns a new instance of the popup handler + * + * @method buildPopupHandler + * @private + */ + Popup.prototype.buildPopupHandler = function() { + var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler'); + + if (pluginHandler) { + return pluginHandler.getPopupHandler(); + } + + return new PopupHandler(); + }; + + /** + * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser. + * + * @method preload + * @param {Object} options receives the window height and width and any other window feature to be sent to window.open + */ + Popup.prototype.preload = function(options) { + options = options || {}; + + var popup = this.buildPopupHandler(); + + popup.preload(options); + return popup; + }; + + /** + * Internal use. + * + * @method getPopupHandler + * @private + */ + Popup.prototype.getPopupHandler = function(options, preload) { + if (options.popupHandler) { + return options.popupHandler; + } + + if (preload) { + return this.preload(options); + } + + return this.buildPopupHandler(); + }; + + /** + * Handles the popup logic for the callback page. + * + * @method callback + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @see {@link parseHash} + */ + Popup.prototype.callback = function(options) { + var _this = this; + var theWindow = windowHelper.getWindow(); + options = options || {}; + var originUrl = + options.popupOrigin || + this.baseOptions.popupOrigin || + windowHelper.getOrigin(); + + /* + in IE 11, there's a bug that makes window.opener return undefined. + The callback page will still call `popup.callback()` which will run this method + in the relay page. WinChan expects the relay page to have a global `doPost` function, + which will be called with the response. + + IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/ + */ + if (!theWindow.opener) { + theWindow.doPost = function(msg) { + if (theWindow.parent) { + theWindow.parent.postMessage(msg, originUrl); + } + }; + return; + } + + winchan.onOpen(function(popupOrigin, r, cb) { + if (popupOrigin !== originUrl) { + return cb({ + error: 'origin_mismatch', + error_description: + "The popup's origin (" + + popupOrigin + + ') should match the `popupOrigin` parameter (' + + originUrl + + ').' + }); + } + _this.webAuth.parseHash(options || {}, function(err, data) { + return cb(err || data); + }); + }); + }; + + /** + * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`. + * + * @method authorize + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response. + * @param {authorizeCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + Popup.prototype.authorize = function(options, cb) { + var popup; + var url; + var relayUrl; + var popOpts = {}; + + var pluginHandler = this.baseOptions.plugins.get('popup.authorize'); + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'scope', + 'domain', + 'audience', + 'tenant', + 'responseType', + 'redirectUri', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(objectHelper.blacklist(options, ['popupHandler'])); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + // the relay page should not be necessary as long it happens in the same domain + // (a redirectUri shoul be provided). It is necessary when using OWP + relayUrl = urlJoin(this.baseOptions.rootUrl, 'relay.html'); + + // if a owp is enabled, it should use the owp flag + if (options.owp) { + // used by server to render the relay page instead of sending the chunk in the + // url to the callback + params.owp = true; + } else { + popOpts.origin = urlHelper.extractOrigin(params.redirectUri); + relayUrl = params.redirectUri; + } + + if (options.popupOptions) { + popOpts.popupOptions = objectHelper.pick(options.popupOptions, [ + 'width', + 'height', + 'top', + 'left' + ]); + } + + if (pluginHandler) { + params = pluginHandler.processParams(params); + } + + params = this.transactionManager.process(params); + params.scope = params.scope || 'openid profile email'; + delete params.domain; + + url = this.client.buildAuthorizeUrl(params); + + popup = this.getPopupHandler(options); + + return popup.load( + url, + relayUrl, + popOpts, + wrapCallback(cb, { keepOriginalCasing: true }) + ); + }; + + /** + * Performs authentication with username/email and password with a database connection inside a new window + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link login}. + * + * @method loginWithCredentials + * @param {Object} options + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token` + * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`. + * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email` + * @param {credentialsCallback} cb + */ + Popup.prototype.loginWithCredentials = function(options, cb) { + options.realm = options.realm || options.connection; + options.popup = true; + options = objectHelper + .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce']) + .with(objectHelper.blacklist(options, ['popupHandler', 'connection'])); + options = this.transactionManager.process(options); + this.crossOriginAuthentication.login(options, cb); + }; + + /** + * Verifies the passwordless TOTP and redirects to finish the passwordless transaction + * + * @method passwordlessVerify + * @param {Object} options + * @param {String} options.type `sms` or `email` + * @param {String} options.phoneNumber only if type = sms + * @param {String} options.email only if type = email + * @param {String} options.connection the connection name + * @param {String} options.verificationCode the TOTP code + * @param {Function} cb + */ + Popup.prototype.passwordlessVerify = function(options, cb) { + var _this = this; + return this.client.passwordless.verify( + objectHelper.blacklist(options, ['popupHandler']), + function(err) { + if (err) { + return cb(err); + } + + options.username = options.phoneNumber || options.email; + options.password = options.verificationCode; + + delete options.email; + delete options.phoneNumber; + delete options.verificationCode; + delete options.type; + + _this.client.loginWithResourceOwner(options, cb); + } + ); + }; + + /** + * Signs up a new user and automatically logs the user in after the signup. + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link signupAndAuthorize}. + * + * @method signupAndLogin + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {credentialsCallback} cb + */ + Popup.prototype.signupAndLogin = function(options, cb) { + var _this = this; + + return this.client.dbConnection.signup(options, function(err) { + if (err) { + return cb(err); + } + _this.loginWithCredentials(options, cb); + }); + }; + + function SilentAuthenticationHandler(options) { + this.authenticationUrl = options.authenticationUrl; + this.timeout = options.timeout || 60 * 1000; + this.handler = null; + this.postMessageDataType = options.postMessageDataType || false; + + // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually + this.postMessageOrigin = + options.postMessageOrigin || + windowHelper.getWindow().location.origin || + windowHelper.getWindow().location.protocol + + '//' + + windowHelper.getWindow().location.hostname + + (windowHelper.getWindow().location.port + ? ':' + windowHelper.getWindow().location.port + : ''); + } + + SilentAuthenticationHandler.create = function(options) { + return new SilentAuthenticationHandler(options); + }; + + SilentAuthenticationHandler.prototype.login = function( + usePostMessage, + callback + ) { + this.handler = new IframeHandler({ + auth0: this.auth0, + url: this.authenticationUrl, + eventListenerType: usePostMessage ? 'message' : 'load', + callback: this.getCallbackHandler(callback, usePostMessage), + timeout: this.timeout, + eventValidator: this.getEventValidator(), + timeoutCallback: function() { + callback( + null, + '#error=timeout&error_description=Timeout+during+authentication+renew.' + ); + }, + usePostMessage: usePostMessage || false + }); + + this.handler.init(); + }; + + SilentAuthenticationHandler.prototype.getEventValidator = function() { + var _this = this; + return { + isValid: function(eventData) { + switch (eventData.event.type) { + case 'message': + // Message must come from the expected origin and iframe window. + if ( + eventData.event.origin !== _this.postMessageOrigin || + eventData.event.source !== _this.handler.iframe.contentWindow + ) { + return false; + } + + // Default behaviour, return all message events from the iframe. + if (_this.postMessageDataType === false) { + return true; + } + + return ( + eventData.event.data.type && + eventData.event.data.type === _this.postMessageDataType + ); + + case 'load': + if ( + eventData.sourceObject.contentWindow.location.protocol === 'about:' + ) { + // Chrome is automatically loading the about:blank page, we ignore this. + return false; + } + // Fall through to default + default: + return true; + } + } + }; + }; + + SilentAuthenticationHandler.prototype.getCallbackHandler = function( + callback, + usePostMessage + ) { + return function(eventData) { + var callbackValue; + if (!usePostMessage) { + callbackValue = eventData.sourceObject.contentWindow.location.hash; + } else if ( + typeof eventData.event.data === 'object' && + eventData.event.data.hash + ) { + callbackValue = eventData.event.data.hash; + } else { + callbackValue = eventData.event.data; + } + callback(null, callbackValue); + }; + }; + + function UsernamePassword(options) { + this.baseOptions = options; + this.request = new RequestBuilder(options); + this.transactionManager = new TransactionManager(this.baseOptions); + } + + UsernamePassword.prototype.login = function(options, cb) { + var url; + var body; + + url = urlJoin(this.baseOptions.rootUrl, 'usernamepassword', 'login'); + + options.username = options.username || options.email; // eslint-disable-line + + options = objectHelper.blacklist(options, ['email']); // eslint-disable-line + + body = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'tenant', + 'responseType', + 'responseMode', + 'scope', + 'audience' + ]) + .with(options); + body = this.transactionManager.process(body); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + UsernamePassword.prototype.callback = function(formHtml) { + var div; + var form; + var _document = windowHelper.getDocument(); + + div = _document.createElement('div'); + div.innerHTML = formHtml; + form = _document.body.appendChild(div).children[0]; + + form.submit(); + }; + + function HostedPages(client, options) { + this.baseOptions = options; + this.client = client; + this.baseOptions.universalLoginPage = true; + this.request = new RequestBuilder(this.baseOptions); + + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + } + + /** + * @callback credentialsCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the AuthN request + * @param {String} result.accessToken token that can be used with {@link userinfo} + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + */ + + /** + * Performs authentication with username/email and password with a database connection + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link authorize} or {@link login}. + * + * @method login + * @param {Object} options + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token` + * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment` + * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email` + * @param {credentialsCallback} cb + */ + HostedPages.prototype.login = function(options, cb) { + if (windowHelper.getWindow().location.host !== this.baseOptions.domain) { + throw new Error( + 'This method is meant to be used only inside the Universal Login Page.' + ); + } + var usernamePassword; + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'tenant', + 'responseType', + 'responseMode', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + usernamePassword = new UsernamePassword(this.baseOptions); + return usernamePassword.login(params, function(err, data) { + if (err) { + return cb(err); + } + return usernamePassword.callback(data); + }); + }; + + /** + * Signs up a new user and automatically logs the user in after the signup. + * + * @method signupAndLogin + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {credentialsCallback} cb + */ + HostedPages.prototype.signupAndLogin = function(options, cb) { + var _this = this; + return _this.client.client.dbConnection.signup(options, function(err) { + if (err) { + return cb(err); + } + return _this.login(options, cb); + }); + }; + + HostedPages.prototype.getSSOData = function(withActiveDirectories, cb) { + var url; + var params = ''; + + if (typeof withActiveDirectories === 'function') { + cb = withActiveDirectories; + withActiveDirectories = false; + } + + assert.check(withActiveDirectories, { + type: 'boolean', + message: 'withActiveDirectories parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + if (withActiveDirectories) { + params = + '?' + + lib.stringify({ + ldaps: 1, + client_id: this.baseOptions.clientID + }); + } + + url = urlJoin(this.baseOptions.rootUrl, 'user', 'ssodata', params); + + return this.request + .get(url, { noHeaders: true }) + .withCredentials() + .end(wrapCallback(cb)); + }; + + // eslint-disable-next-line no-unused-vars + + var noop = function () { }; + + var defaults$2 = { + lang: 'en', + templates: { + 'auth0': function (challenge) { + var message = challenge.type === 'code' ? + 'Enter the code shown above' : + 'Solve the formula shown above'; + return '
\n' + + ' \n' + + ' \n' + + '
\n' + + ''; + } + , + 'recaptcha_v2': function () { + return '
'; + } + , + 'error': function () { + return '
Error getting the bot detection challenge. Please contact the system administrator.
' + } + } + }; + + function handleAuth0Provider(element, options, challenge, load) { + element.innerHTML = options.templates[challenge.provider](challenge); + element.querySelector('.captcha-reload').addEventListener('click', function (e) { + e.preventDefault(); + load(); + }); + } + + function injectRecaptchaScript(element, lang, callback) { + var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001); + window[callbackName] = function () { + delete window[callbackName]; + callback(); + }; + var script = window.document.createElement('script'); + script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName; + script.async = true; + window.document.body.appendChild(script); + } + + function handleRecaptchaProvider(element, options, challenge) { + var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid'); + + function setValue(value) { + var input = element.querySelector('input[name="captcha"]'); + input.value = value || ''; + } + + if (widgetId) { + setValue(); + window.grecaptcha.reset(widgetId); + return; + } + + element.innerHTML = options.templates[challenge.provider](challenge); + + var recaptchaDiv = element.querySelector('.recaptcha'); + + injectRecaptchaScript(element, options.lang, function () { + widgetId = window.grecaptcha.render(recaptchaDiv, { + callback: setValue, + 'expired-callback': function () { setValue(); }, + 'error-callback': function () { setValue(); }, + sitekey: challenge.siteKey + }); + element.setAttribute('data-wid', widgetId); + }); + } + + + /** + * + * Renders the captcha challenge in the provided element. + * + * @param {Authentication} auth0Client The challenge response from the authentication server + * @param {HTMLElement} element The element where the captcha needs to be rendered + * @param {Object} options The configuration options for the captcha + * @param {Object} [options.templates] An object containaing templates for each captcha provider + * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string + * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string + * @param {String} [options.lang=en] the ISO code of the language for recaptcha* + * @param {Function} [callback] an optional callback function + */ + function render(auth0Client, element, options, callback) { + options = objectHelper.merge(defaults$2).with(options || {}); + + function load(done) { + done = done || noop; + auth0Client.getChallenge(function (err, challenge) { + if (err) { + element.innerHTML = options.templates.error(err); + return done(err); + } + if (!challenge.required) { + element.style.display = 'none'; + element.innerHTML = ''; + return; + } + element.style.display = ''; + if (challenge.provider === 'auth0') { + handleAuth0Provider(element, options, challenge, load); + } else if (challenge.provider === 'recaptcha_v2') { + handleRecaptchaProvider(element, options, challenge); + } + done(); + }); + } + + function getValue() { + var captchaInput = element.querySelector('input[name="captcha"]'); + if (!captchaInput) { return; } + return captchaInput.value; + } + + load(callback); + + return { + reload: load, + getValue: getValue + }; + } + + var captcha = { render: render }; + + function defaultClock() { + return new Date(); + } + + /** + * Handles all the browser's AuthN/AuthZ flows + * @constructor + * @param {Object} options + * @param {String} options.domain your Auth0 domain + * @param {String} options.clientID the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds. + * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server. + * @param {Array} [options.plugins] + * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js} + * @see {@link https://auth0.com/docs/api/authentication} + */ + function WebAuth(options) { + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + clientID: { type: 'string', message: 'clientID option is required' }, + responseType: { + optional: true, + type: 'string', + message: 'responseType is not valid' + }, + responseMode: { + optional: true, + type: 'string', + message: 'responseMode is not valid' + }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri is not valid' + }, + scope: { optional: true, type: 'string', message: 'scope is not valid' }, + audience: { + optional: true, + type: 'string', + message: 'audience is not valid' + }, + popupOrigin: { + optional: true, + type: 'string', + message: 'popupOrigin is not valid' + }, + leeway: { + optional: true, + type: 'number', + message: 'leeway is not valid' + }, + plugins: { + optional: true, + type: 'array', + message: 'plugins is not valid' + }, + maxAge: { + optional: true, + type: 'number', + message: 'maxAge is not valid' + }, + _disableDeprecationWarnings: { + optional: true, + type: 'boolean', + message: '_disableDeprecationWarnings option is not valid' + }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + }, + _timesToRetryFailedRequests: { + optional: true, + type: 'number', + message: '_timesToRetryFailedRequests option is not valid' + } + } + ); + + if (options.overrides) { + assert.check( + options.overrides, + { type: 'object', message: 'overrides option is not valid' }, + { + __tenant: { + optional: true, + type: 'string', + message: '__tenant option is required' + }, + __token_issuer: { + optional: true, + type: 'string', + message: '__token_issuer option is required' + }, + __jwks_uri: { + optional: true, + type: 'string', + message: '__jwks_uri is required' + } + } + ); + } + /* eslint-enable */ + + this.baseOptions = options; + this.baseOptions.plugins = new PluginHandler( + this, + this.baseOptions.plugins || [] + ); + + this.baseOptions._sendTelemetry = + this.baseOptions._sendTelemetry === false + ? this.baseOptions._sendTelemetry + : true; + + this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests + ? parseInt(options._timesToRetryFailedRequests, 0) + : 0; + + this.baseOptions.tenant = + (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) || + this.baseOptions.domain.split('.')[0]; + + this.baseOptions.token_issuer = + (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) || + 'https://' + this.baseOptions.domain + '/'; + + this.baseOptions.jwksURI = + this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri; + + this.transactionManager = new TransactionManager(this.baseOptions); + + this.client = new Authentication(this.baseOptions); + this.redirect = new Redirect(this, this.baseOptions); + this.popup = new Popup(this, this.baseOptions); + this.crossOriginAuthentication = new CrossOriginAuthentication( + this, + this.baseOptions + ); + this.webMessageHandler = new WebMessageHandler(this); + this._universalLogin = new HostedPages(this, this.baseOptions); + this.ssodataStorage = new SSODataStorage(this.baseOptions); + } + + /** + * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize} + * + * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed + * by the `/.well-known/jwks.json` endpoint of your account. + * Tokens signed with the HS256 algorithm cannot be properly validated. + * Instead, a call to {@link userInfo} will be made with the parsed `access_token`. + * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback. + * Tokens signed with other algorithms will not be accepted. + * + * @method parseHash + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType. + * @param {authorizeCallback} cb + */ + WebAuth.prototype.parseHash = function(options, cb) { + var parsedQs; + var err; + + if (!cb && typeof options === 'function') { + cb = options; + options = {}; + } else { + options = options || {}; + } + + var _window = windowHelper.getWindow(); + + var hashStr = + options.hash === undefined ? _window.location.hash : options.hash; + hashStr = hashStr.replace(/^#?\/?/, ''); + + parsedQs = lib.parse(hashStr); + + if (parsedQs.hasOwnProperty('error')) { + err = error.buildResponse(parsedQs.error, parsedQs.error_description); + + if (parsedQs.state) { + err.state = parsedQs.state; + } + + return cb(err); + } + + if ( + !parsedQs.hasOwnProperty('access_token') && + !parsedQs.hasOwnProperty('id_token') && + !parsedQs.hasOwnProperty('refresh_token') + ) { + return cb(null, null); + } + var responseTypes = ( + this.baseOptions.responseType || + options.responseType || + '' + ).split(' '); + if ( + responseTypes.length > 0 && + responseTypes.indexOf('token') !== -1 && + !parsedQs.hasOwnProperty('access_token') + ) { + return cb( + error.buildResponse( + 'invalid_hash', + 'response_type contains `token`, but the parsed hash does not contain an `access_token` property' + ) + ); + } + if ( + responseTypes.length > 0 && + responseTypes.indexOf('id_token') !== -1 && + !parsedQs.hasOwnProperty('id_token') + ) { + return cb( + error.buildResponse( + 'invalid_hash', + 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property' + ) + ); + } + return this.validateAuthenticationResponse(options, parsedQs, cb); + }; + + /** + * Validates an Auth response from a Auth flow started with {@link authorize} + * + * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed + * by the `/.well-known/jwks.json` endpoint of your account. + * Tokens signed with the HS256 algorithm cannot be properly validated. + * Instead, a call to {@link userInfo} will be made with the parsed `access_token`. + * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback. + * Tokens signed with other algorithms will not be accepted. + * + * @method validateAuthenticationResponse + * @param {Object} options + * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash + * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF + * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks + * @param {Object} parsedHash an object that represents the parsed hash + * @param {authorizeCallback} cb + */ + WebAuth.prototype.validateAuthenticationResponse = function( + options, + parsedHash, + cb + ) { + var _this = this; + options.__enableIdPInitiatedLogin = + options.__enableIdPInitiatedLogin || options.__enableImpersonation; + var state = parsedHash.state; + var transaction = this.transactionManager.getStoredTransaction(state); + var transactionState = + options.state || (transaction && transaction.state) || null; + + var transactionStateMatchesState = transactionState === state; + var shouldBypassStateChecking = + !state && !transactionState && options.__enableIdPInitiatedLogin; + + if (!shouldBypassStateChecking && !transactionStateMatchesState) { + return cb({ + error: 'invalid_token', + errorDescription: '`state` does not match.' + }); + } + var transactionNonce = + options.nonce || (transaction && transaction.nonce) || null; + + var appState = options.state || (transaction && transaction.appState) || null; + + var callback = function(err, payload) { + if (err) { + return cb(err); + } + if (transaction && transaction.lastUsedConnection) { + var sub; + if (payload) { + sub = payload.sub; + } + _this.ssodataStorage.set(transaction.lastUsedConnection, sub); + } + return cb(null, buildParseHashResponse(parsedHash, appState, payload)); + }; + + if (!parsedHash.id_token) { + return callback(null, null); + } + return this.validateToken(parsedHash.id_token, transactionNonce, function( + validationError, + payload + ) { + if (!validationError) { + if (!parsedHash.access_token) { + return callback(null, payload); + } + // id_token's generated by non-oidc applications don't have at_hash + if (!payload.at_hash) { + return callback(null, payload); + } + // here we're absolutely sure that the id_token's alg is RS256 + // and that the id_token is valid, so we can check the access_token + return new k().validateAccessToken( + parsedHash.access_token, + 'RS256', + payload.at_hash, + function(err) { + if (err) { + return callback(error.invalidToken(err.message)); + } + return callback(null, payload); + } + ); + } + + if ( + validationError.error !== 'invalid_token' || + (validationError.errorDescription && + validationError.errorDescription.indexOf( + 'Nonce (nonce) claim value mismatch in the ID token' + ) > -1) + ) { + return callback(validationError); + } + + // if it's an invalid_token error, decode the token + var decodedToken = new k().decode(parsedHash.id_token); + + // if the alg is not HS256, return the raw error + if (decodedToken.header.alg !== 'HS256') { + return callback(validationError); + } + + if ((decodedToken.payload.nonce || null) !== transactionNonce) { + return callback({ + error: 'invalid_token', + errorDescription: + 'Nonce (nonce) claim value mismatch in the ID token; expected "' + + transactionNonce + + '", found "' + + decodedToken.payload.nonce + + '"' + }); + } + + if (!parsedHash.access_token) { + var noAccessTokenError = { + error: 'invalid_token', + description: + 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token' + }; + return callback(noAccessTokenError); + } + + // if the alg is HS256, use the /userinfo endpoint to build the payload + return _this.client.userInfo(parsedHash.access_token, function( + errUserInfo, + profile + ) { + // if the /userinfo request fails, use the validationError instead + if (errUserInfo) { + return callback(errUserInfo); + } + return callback(null, profile); + }); + }); + }; + + function buildParseHashResponse(qsParams, appState, token) { + return { + accessToken: qsParams.access_token || null, + idToken: qsParams.id_token || null, + idTokenPayload: token || null, + appState: appState || null, + refreshToken: qsParams.refresh_token || null, + state: qsParams.state || null, + expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null, + tokenType: qsParams.token_type || null, + scope: qsParams.scope || null + }; + } + + /** + * @callback validateTokenCallback + * @param {Error} [err] error returned by while validating the token + * @param {Object} [payload] claims stored in the token + */ + + /** + * Decodes the a JWT and verifies its nonce value + * + * @method validateToken + * @private + * @param {String} token + * @param {String} nonce + * @param {validateTokenCallback} cb + */ + WebAuth.prototype.validateToken = function(token, nonce, cb) { + var verifier = new k({ + issuer: this.baseOptions.token_issuer, + jwksURI: this.baseOptions.jwksURI, + audience: this.baseOptions.clientID, + leeway: this.baseOptions.leeway || 60, + maxAge: this.baseOptions.maxAge, + __clock: this.baseOptions.__clock || defaultClock + }); + + verifier.verify(token, nonce, function(err, payload) { + if (err) { + return cb(error.invalidToken(err.message)); + } + + cb(null, payload); + }); + }; + + /** + * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session. + * This method requires that all Auth is performed with {@link authorize} + * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method. + * + * @method renewAuth + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback. + * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy. + * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration. + * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed + * @param {authorizeCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + WebAuth.prototype.renewAuth = function(options, cb) { + var handler; + var usePostMessage = !!options.usePostMessage; + var postMessageDataType = options.postMessageDataType || false; + var postMessageOrigin = + options.postMessageOrigin || windowHelper.getWindow().origin; + var timeout = options.timeout; + var _this = this; + + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'redirectUri', + 'responseType', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + params.responseType = params.responseType || 'token'; + params.responseMode = params.responseMode || 'fragment'; + params = this.transactionManager.process(params); + + assert.check(params, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + params.prompt = 'none'; + + params = objectHelper.blacklist(params, [ + 'usePostMessage', + 'tenant', + 'postMessageDataType', + 'postMessageOrigin' + ]); + + handler = SilentAuthenticationHandler.create({ + authenticationUrl: this.client.buildAuthorizeUrl(params), + postMessageDataType: postMessageDataType, + postMessageOrigin: postMessageOrigin, + timeout: timeout + }); + + handler.login(usePostMessage, function(err, hash) { + if (typeof hash === 'object') { + // hash was already parsed, so we just return it. + // it's here to be backwards compatible and should be removed in the next major version. + return cb(err, hash); + } + _this.parseHash({ hash: hash }, cb); + }); + }; + + /** + * Renews an existing session on Auth0's servers using `response_mode=web_message` + * + * @method checkSession + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration. + * @param {checkSessionCallback} cb + * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens} + */ + WebAuth.prototype.checkSession = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + if (params.responseType === 'code') { + return cb({ + error: 'error', + error_description: "responseType can't be `code`" + }); + } + + if (!options.nonce) { + params = this.transactionManager.process(params); + } + + if (!params.redirectUri) { + return cb({ + error: 'error', + error_description: "redirectUri can't be empty" + }); + } + + assert.check(params, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + params = objectHelper.blacklist(params, [ + 'usePostMessage', + 'tenant', + 'postMessageDataType' + ]); + this.webMessageHandler.run( + params, + wrapCallback(cb, { forceLegacyError: true, ignoreCasing: true }) + ); + }; + + /** + * Request an email with instruction to change a user's password + * + * @method changePassword + * @param {Object} options + * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0 + * @param {String} options.connection name of the connection where the user was created + * @param {changePasswordCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#change-password} + */ + WebAuth.prototype.changePassword = function(options, cb) { + return this.client.dbConnection.changePassword(options, cb); + }; + + /** + * Starts a passwordless authentication transaction. + * + * @method passwordlessStart + * @param {Object} options + * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid + * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email` + * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber` + * @param {String} options.connection name of the passwordless connection + * @param {Object} [options.authParams] additional Auth parameters when using `link` + * @param {Function} cb + * @see {@link https://auth0.com/docs/api/authentication#passwordless} + */ + WebAuth.prototype.passwordlessStart = function(options, cb) { + var authParams = objectHelper + .merge(this.baseOptions, [ + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options.authParams); + + options.authParams = this.transactionManager.process(authParams); + return this.client.passwordless.start(options, cb); + }; + + /** + * Creates a new user in a Auth0 Database connection + * + * @method signup + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {signUpCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + */ + WebAuth.prototype.signup = function(options, cb) { + return this.client.dbConnection.signup(options, cb); + }; + + /** + * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction. + * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`. + * + * @method authorize + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Object} [options.appState] any values that you want back on the authentication response + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + */ + WebAuth.prototype.authorize = function(options) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + params = this.transactionManager.process(params); + params.scope = params.scope || 'openid profile email'; + + windowHelper.redirect(this.client.buildAuthorizeUrl(params)); + }; + + /** + * Signs up a new user, automatically logs the user in after the signup and returns the user token. + * The login will be done using /oauth/token with password-realm grant type. + * + * @method signupAndAuthorize + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} options.connection name of the connection where the user will be created + * @param {tokenCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + * @see {@link https://auth0.com/docs/api-auth/grant/password} + */ + WebAuth.prototype.signupAndAuthorize = function(options, cb) { + var _this = this; + + return this.client.dbConnection.signup( + objectHelper.blacklist(options, ['popupHandler']), + function(err) { + if (err) { + return cb(err); + } + options.realm = options.connection; + if (!options.username) { + options.username = options.email; + } + _this.client.login(options, cb); + } + ); + }; + + /** + * @callback crossOriginLoginCallback + * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed + */ + + /** + * Logs the user in with username and password using the correct flow based on where it's called from: + * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint + * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow + * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`. + * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data. + * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.** + * + * @method login + * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired + * @param {String} [options.username] Username (mutually exclusive with email) + * @param {String} [options.email] Email (mutually exclusive with username) + * @param {String} options.password Password + * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name + * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`. + */ + WebAuth.prototype.login = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + params = this.transactionManager.process(params); + + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + params.connection = params.realm; + delete params.realm; + this._universalLogin.login(params, cb); + } else { + this.crossOriginAuthentication.login(params, cb); + } + }; + + /** + * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user. + * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor. + * + * @method passwordlessLogin + * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired + * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email) + * @param {String} [options.email] Email (mutually exclusive with username) + * @param {String} options.verificationCode Verification Code (OTP) + * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'. + * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`. + */ + WebAuth.prototype.passwordlessLogin = function(options, cb) { + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + params = this.transactionManager.process(params); + + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + this.passwordlessVerify(params, cb); + } else { + var crossOriginOptions = objectHelper.extend( + { + credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp', + realm: params.connection, + username: params.email || params.phoneNumber, + otp: params.verificationCode + }, + objectHelper.blacklist(params, [ + 'connection', + 'email', + 'phoneNumber', + 'verificationCode' + ]) + ); + this.crossOriginAuthentication.login(crossOriginOptions, cb); + } + }; + + /** + * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url. + * + * @method crossOriginAuthenticationCallback + * @deprecated Use {@link crossOriginVerification} instead. + */ + WebAuth.prototype.crossOriginAuthenticationCallback = function() { + this.crossOriginVerification(); + }; + + /** + * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url. + * + * @method crossOriginVerification + */ + WebAuth.prototype.crossOriginVerification = function() { + this.crossOriginAuthentication.callback(); + }; + + /** + * Redirects to the auth0 logout endpoint + * + * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list: + * + * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level). + * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level). + * + * @method logout + * @param {Object} [options] + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.returnTo] URL to be redirected after the logout + * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP. + * @see {@link https://auth0.com/docs/api/authentication#logout} + */ + WebAuth.prototype.logout = function(options) { + windowHelper.redirect(this.client.buildLogoutUrl(options)); + }; + + /** + * Verifies the passwordless TOTP and redirects to finish the passwordless transaction + * + * @method passwordlessVerify + * @param {Object} options + * @param {String} options.type `sms` or `email` + * @param {String} options.phoneNumber only if type = sms + * @param {String} options.email only if type = email + * @param {String} options.connection the connection name + * @param {String} options.verificationCode the TOTP code + * @param {Function} cb + */ + WebAuth.prototype.passwordlessVerify = function(options, cb) { + var _this = this; + var params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'nonce' + ]) + .with(options); + + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + responseType: { + type: 'string', + message: 'responseType option is required' + } + } + ); + + params = this.transactionManager.process(params); + return this.client.passwordless.verify(params, function(err) { + if (err) { + return cb(err); + } + return windowHelper.redirect( + _this.client.passwordless.buildVerifyUrl(params) + ); + }); + }; + + /** + * + * Renders the captcha challenge in the provided element. + * This function can only be used in the context of a Classic Universal Login Page. + * + * @param {HTMLElement} element The element where the captcha needs to be rendered + * @param {Object} options The configuration options for the captcha + * @param {Object} [options.templates] An object containaing templates for each captcha provider + * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string + * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string + * @param {String} [options.lang=en] the ISO code of the language for recaptcha + * @param {Function} [callback] An optional completion callback + */ + WebAuth.prototype.renderCaptcha = function(element, options, callback) { + return captcha.render(this.client, element, options, callback); + }; + + function PasswordlessAuthentication(request, options) { + this.baseOptions = options; + this.request = request; + } + + PasswordlessAuthentication.prototype.buildVerifyUrl = function(options) { + var params; + var qString; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + verificationCode: { + type: 'string', + message: 'verificationCode option is required' + }, + phoneNumber: { + optional: false, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return !o.email; + } + }, + email: { + optional: false, + type: 'string', + message: 'email option is required', + condition: function(o) { + return !o.phoneNumber; + } + } + } + ); + /* eslint-enable */ + + params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience', + '_csrf', + 'state', + '_intstate', + 'protocol', + 'nonce' + ]) + .with(options); + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + params = objectHelper.toSnakeCase(params, ['auth0Client']); + + qString = lib.stringify(params); + + return urlJoin( + this.baseOptions.rootUrl, + 'passwordless', + 'verify_redirect', + '?' + qString + ); + }; + + PasswordlessAuthentication.prototype.start = function(options, cb) { + var url; + var body; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + send: { + type: 'string', + message: 'send option is required', + values: ['link', 'code'], + value_message: 'send is not valid ([link, code])' + }, + phoneNumber: { + optional: true, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return o.send === 'code' || !o.email; + } + }, + email: { + optional: true, + type: 'string', + message: 'email option is required', + condition: function(o) { + return o.send === 'link' || !o.phoneNumber; + } + }, + authParams: { + optional: true, + type: 'object', + message: 'authParams option is required' + } + } + ); + /* eslint-enable */ + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'passwordless', 'start'); + + body = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'redirectUri', + 'scope' + ]) + .with(options); + + if (body.scope) { + body.authParams = body.authParams || {}; + body.authParams.scope = body.authParams.scope || body.scope; + } + + if (body.redirectUri) { + body.authParams = body.authParams || {}; + body.authParams.redirect_uri = + body.authParams.redirectUri || body.redirectUri; + } + + if (body.responseType) { + body.authParams = body.authParams || {}; + body.authParams.response_type = + body.authParams.responseType || body.responseType; + } + + delete body.redirectUri; + delete body.responseType; + delete body.scope; + + body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + PasswordlessAuthentication.prototype.verify = function(options, cb) { + var url; + var cleanOption; + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + verificationCode: { + type: 'string', + message: 'verificationCode option is required' + }, + phoneNumber: { + optional: false, + type: 'string', + message: 'phoneNumber option is required', + condition: function(o) { + return !o.email; + } + }, + email: { + optional: false, + type: 'string', + message: 'email option is required', + condition: function(o) { + return !o.phoneNumber; + } + } + } + ); + /* eslint-enable */ + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + cleanOption = objectHelper.pick(options, [ + 'connection', + 'verificationCode', + 'phoneNumber', + 'email', + 'auth0Client' + ]); + cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']); + + url = urlJoin(this.baseOptions.rootUrl, 'passwordless', 'verify'); + + return this.request + .post(url) + .send(cleanOption) + .end(wrapCallback(cb)); + }; + + function DBConnection(request, options) { + this.baseOptions = options; + this.request = request; + } + + /** + * @callback signUpCallback + * @param {Error} [err] error returned by Auth0 with the reason why the signup failed + * @param {Object} [result] result of the signup request + * @param {Object} result.email user's email + * @param {Object} result.emailVerified if the user's email was verified + */ + + /** + * Creates a new user in a Auth0 Database connection + * + * @method signup + * @param {Object} options + * @param {String} options.email user email address + * @param {String} options.password user password + * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username` + * @param {String} options.connection name of the connection where the user will be created + * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata` + * @param {signUpCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#signup} + */ + DBConnection.prototype.signup = function(options, cb) { + var url; + var body; + var metadata; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + email: { type: 'string', message: 'email option is required' }, + password: { type: 'string', message: 'password option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'dbconnections', 'signup'); + + body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options); + + metadata = body.user_metadata || body.userMetadata; + + body = objectHelper.blacklist(body, [ + 'scope', + 'userMetadata', + 'user_metadata' + ]); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + if (metadata) { + body.user_metadata = metadata; + } + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * @callback changePasswordCallback + * @param {Error} [err] error returned by Auth0 with the reason why the request failed + */ + + /** + * Request an email with instruction to change a user's password + * + * @method changePassword + * @param {Object} options + * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0 + * @param {String} options.connection name of the connection where the user was created + * @param {changePasswordCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#change-password} + */ + DBConnection.prototype.changePassword = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + connection: { type: 'string', message: 'connection option is required' }, + email: { type: 'string', message: 'email option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password'); + + body = objectHelper + .merge(this.baseOptions, ['clientID']) + .with(options, ['email', 'connection']); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Creates a new Auth0 Authentication API client + * @constructor + * @param {Object} options + * @param {String} options.domain your Auth0 domain + * @param {String} options.clientID the Client ID found on your Application settings page + * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @see {@link https://auth0.com/docs/api/authentication} + */ + function Authentication(auth0, options) { + // If we have two arguments, the first one is a WebAuth instance, so we assign that + // if not, it's an options object and then we should use that as options instead + // this is here because we don't want to break people coming from v8 + if (arguments.length === 2) { + this.auth0 = auth0; + } else { + options = auth0; + } + + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + clientID: { type: 'string', message: 'clientID option is required' }, + responseType: { + optional: true, + type: 'string', + message: 'responseType is not valid' + }, + responseMode: { + optional: true, + type: 'string', + message: 'responseMode is not valid' + }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri is not valid' + }, + scope: { optional: true, type: 'string', message: 'scope is not valid' }, + audience: { + optional: true, + type: 'string', + message: 'audience is not valid' + }, + _disableDeprecationWarnings: { + optional: true, + type: 'boolean', + message: '_disableDeprecationWarnings option is not valid' + }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + }, + } + ); + /* eslint-enable */ + + this.baseOptions = options; + this.baseOptions._sendTelemetry = + this.baseOptions._sendTelemetry === false + ? this.baseOptions._sendTelemetry + : true; + + this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0) + ? this.baseOptions.domain + : 'https://' + this.baseOptions.domain; + + this.request = new RequestBuilder(this.baseOptions); + + this.passwordless = new PasswordlessAuthentication( + this.request, + this.baseOptions + ); + this.dbConnection = new DBConnection(this.request, this.baseOptions); + + this.warn = new Warn({ + disableWarnings: !!options._disableDeprecationWarnings + }); + this.ssodataStorage = new SSODataStorage(this.baseOptions); + } + + /** + * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction + * + * @method buildAuthorizeUrl + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response + * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html} + * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes} + * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state} + * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce} + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @see {@link https://auth0.com/docs/api/authentication#authorize-client} + * @see {@link https://auth0.com/docs/api/authentication#social} + */ + Authentication.prototype.buildAuthorizeUrl = function(options) { + var params; + var qString; + + assert.check(options, { + type: 'object', + message: 'options parameter is not valid' + }); + + params = objectHelper + .merge(this.baseOptions, [ + 'clientID', + 'responseType', + 'responseMode', + 'redirectUri', + 'scope', + 'audience' + ]) + .with(options); + + /* eslint-disable */ + assert.check( + params, + { type: 'object', message: 'options parameter is not valid' }, + { + clientID: { type: 'string', message: 'clientID option is required' }, + redirectUri: { + optional: true, + type: 'string', + message: 'redirectUri option is required' + }, + responseType: { + type: 'string', + message: 'responseType option is required' + }, + nonce: { + type: 'string', + message: 'nonce option is required', + condition: function(o) { + return ( + o.responseType.indexOf('code') === -1 && + o.responseType.indexOf('id_token') !== -1 + ); + } + }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + /* eslint-enable */ + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + if (params.connection_scope && assert.isArray(params.connection_scope)) { + params.connection_scope = params.connection_scope.join(','); + } + + params = objectHelper.blacklist(params, [ + 'username', + 'popupOptions', + 'domain', + 'tenant', + 'timeout', + 'appState' + ]); + params = objectHelper.toSnakeCase(params, ['auth0Client']); + params = parametersWhitelist.oauthAuthorizeParams(this.warn, params); + + qString = lib.stringify(params); + + return urlJoin(this.baseOptions.rootUrl, 'authorize', '?' + qString); + }; + + /** + * Builds and returns the Logout url in order to initialize a new authN/authZ transaction + * + * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list: + * + * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level). + * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level). + * @method buildLogoutUrl + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} [options.returnTo] URL to be redirected after the logout + * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP. + * @see {@link https://auth0.com/docs/api/authentication#logout} + */ + Authentication.prototype.buildLogoutUrl = function(options) { + var params; + var qString; + + assert.check(options, { + optional: true, + type: 'object', + message: 'options parameter is not valid' + }); + + params = objectHelper + .merge(this.baseOptions, ['clientID']) + .with(options || {}); + + // eslint-disable-next-line + if (this.baseOptions._sendTelemetry) { + params.auth0Client = this.request.getTelemetryData(); + } + + params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']); + + qString = lib.stringify(objectHelper.blacklist(params, ['federated'])); + if ( + options && + options.federated !== undefined && + options.federated !== false && + options.federated !== 'false' + ) { + qString += '&federated'; + } + + return urlJoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString); + }; + + /** + * @callback authorizeCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null. + * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint) + * @param {Number} [result.expiresIn] number of seconds until the access token expires + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + * @param {Object} [result.appState] values that you receive back on the authentication response + */ + + /** + * @callback tokenCallback + * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure + * @param {Object} [result] result of the Auth request + * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint) + * @param {Number} result.expiresIn number of seconds until the access token expires + * @param {String} [result.idToken] token that identifies the user + * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them. + */ + + /** + * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory. + * + * @method loginWithDefaultDirectory + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {tokenCallback} cb function called with the result of the request + * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.loginWithDefaultDirectory = function(options, cb) { + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + options.grantType = 'password'; + + return this.oauthToken(options, cb); + }; + + /** + * Makes a call to the `oauth/token` endpoint with `password-realm` grant type + * + * @method login + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth + * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication` + * @param {tokenCallback} cb function called with the result of the request + * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.login = function(options, cb) { + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + realm: { type: 'string', message: 'realm option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + options.grantType = 'http://auth0.com/oauth/grant-type/password-realm'; + + return this.oauthToken(options, cb); + }; + + /** + * Makes a call to the `oauth/token` endpoint + * + * @method oauthToken + * @private + */ + Authentication.prototype.oauthToken = function(options, cb) { + var url; + var body; + + assert.check(options, { + type: 'object', + message: 'options parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'oauth', 'token'); + + body = objectHelper + .merge(this.baseOptions, ['clientID', 'scope', 'audience']) + .with(options); + + assert.check( + body, + { type: 'object', message: 'options parameter is not valid' }, + { + clientID: { type: 'string', message: 'clientID option is required' }, + grantType: { type: 'string', message: 'grantType option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + }, + audience: { + optional: true, + type: 'string', + message: 'audience option is required' + } + } + ); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + body = parametersWhitelist.oauthTokenParams(this.warn, body); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Performs authentication calling `/oauth/ro` endpoint with username + * and password for a given connection name. + * + * This method is not compatible with API Auth so if you need to fetch API tokens with audience + * you should use {@link login} or {@link loginWithDefaultDirectory}. + * + * @method loginWithResourceOwner + * @param {Object} options + * @param {String} options.username email or username of the user that will perform Auth + * @param {String} options.password the password of the user that will perform Auth + * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication` + * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email` + * @param {String} [options.device] name of the device/browser where the Auth was requested + * @param {tokenCallback} cb function called with the result of the request + */ + Authentication.prototype.loginWithResourceOwner = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + username: { type: 'string', message: 'username option is required' }, + password: { type: 'string', message: 'password option is required' }, + connection: { type: 'string', message: 'connection option is required' }, + scope: { + optional: true, + type: 'string', + message: 'scope option is required' + } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'oauth', 'ro'); + + body = objectHelper + .merge(this.baseOptions, ['clientID', 'scope']) + .with(options, ['username', 'password', 'scope', 'connection', 'device']); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + body.grant_type = body.grant_type || 'password'; + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Uses {@link checkSession} and localStorage to return data from the last successful authentication request. + * + * @method getSSOData + * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible + * @param {Function} cb + */ + Authentication.prototype.getSSOData = function(withActiveDirectories, cb) { + /* istanbul ignore if */ + if (!this.auth0) { + this.auth0 = new WebAuth(this.baseOptions); + } + var isHostedLoginPage = + windowHelper.getWindow().location.host === this.baseOptions.domain; + if (isHostedLoginPage) { + return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb); + } + if (typeof withActiveDirectories === 'function') { + cb = withActiveDirectories; + } + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + var clientId = this.baseOptions.clientID; + var ssodataInformation = this.ssodataStorage.get() || {}; + + this.auth0.checkSession( + { + responseType: 'token id_token', + scope: 'openid profile email', + connection: ssodataInformation.lastUsedConnection, + timeout: 5000 + }, + function(err, result) { + if (err) { + if (err.error === 'login_required') { + return cb(null, { sso: false }); + } + if (err.error === 'consent_required') { + err.error_description = + 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.'; + } + return cb(err, { sso: false }); + } + if ( + ssodataInformation.lastUsedSub && + ssodataInformation.lastUsedSub !== result.idTokenPayload.sub + ) { + return cb(err, { sso: false }); + } + return cb(null, { + lastUsedConnection: { + name: ssodataInformation.lastUsedConnection + }, + lastUsedUserID: result.idTokenPayload.sub, + lastUsedUsername: + result.idTokenPayload.email || result.idTokenPayload.name, + lastUsedClientID: clientId, + sessionClients: [clientId], + sso: true + }); + } + ); + }; + + /** + * @callback userInfoCallback + * @param {Error} [err] error returned by Auth0 + * @param {Object} [userInfo] user information + */ + + /** + * Makes a call to the `/userinfo` endpoint and returns the user profile + * + * @method userInfo + * @param {String} accessToken token issued to a user after Auth + * @param {userInfoCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#get-user-info} + */ + Authentication.prototype.userInfo = function(accessToken, cb) { + var url; + + assert.check(accessToken, { + type: 'string', + message: 'accessToken parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'userinfo'); + + return this.request + .get(url) + .set('Authorization', 'Bearer ' + accessToken) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Makes a call to the `/usernamepassword/challenge` endpoint + * and returns the challenge (captcha) if necessary. + * + * @method getChallenge + * @param {callback} cb + */ + Authentication.prototype.getChallenge = function(cb) { + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + if (!this.baseOptions.state) { + return cb(); + } + + var url = urlJoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge'); + + return this.request + .post(url) + .send({ state: this.baseOptions.state }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * @callback delegationCallback + * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed + * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used + */ + + /** + * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token` + * + * @method delegation + * @param {Object} options + * @param {String} [options.clientID] the Client ID found on your Application settings page + * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer` + * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required + * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required + * @param {String} [options.target] the target ClientID of the delegation + * @param {String} [options.scope] either `openid` or `openid profile email` + * @param {String} [options.apiType] the api to be called + * @param {delegationCallback} cb + * @see {@link https://auth0.com/docs/api/authentication#delegation} + * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}. + */ + Authentication.prototype.delegation = function(options, cb) { + var url; + var body; + + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + grant_type: { type: 'string', message: 'grant_type option is required' } + } + ); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'delegation'); + + body = objectHelper.merge(this.baseOptions, ['clientID']).with(options); + + body = objectHelper.toSnakeCase(body, ['auth0Client']); + + return this.request + .post(url) + .send(body) + .end(wrapCallback(cb)); + }; + + /** + * Fetches the user country based on the ip. + * + * @method getUserCountry + * @private + * @param {Function} cb + */ + Authentication.prototype.getUserCountry = function(cb) { + var url; + + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country'); + + return this.request.get(url).end(wrapCallback(cb)); + }; + + /** + * Auth0 Management API Client (methods allowed to be called from the browser only) + * @constructor + * @param {Object} options + * @param {Object} options.domain your Auth0 acount domain + * @param {Object} options.token a valid API token + */ + function Management(options) { + /* eslint-disable */ + assert.check( + options, + { type: 'object', message: 'options parameter is not valid' }, + { + domain: { type: 'string', message: 'domain option is required' }, + token: { type: 'string', message: 'token option is required' }, + _sendTelemetry: { + optional: true, + type: 'boolean', + message: '_sendTelemetry option is not valid' + }, + _telemetryInfo: { + optional: true, + type: 'object', + message: '_telemetryInfo option is not valid' + } + } + ); + /* eslint-enable */ + + this.baseOptions = options; + + this.baseOptions.headers = { + Authorization: 'Bearer ' + this.baseOptions.token + }; + + this.request = new RequestBuilder(this.baseOptions); + this.baseOptions.rootUrl = urlJoin( + 'https://' + this.baseOptions.domain, + 'api', + 'v2' + ); + } + + /** + * @callback userCallback + * @param {Error} [err] failure reason for the failed request to Management API + * @param {Object} [result] user profile + */ + + /** + * Returns the user profile + * + * @method getUser + * @param {String} userId identifier of the user to retrieve + * @param {userCallback} cb + * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id + */ + Management.prototype.getUser = function(userId, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request.get(url).end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Updates the user metdata. It will patch the user metdata with the attributes sent. + * + * + * @method patchUserMetadata + * @param {String} userId + * @param {Object} userMetadata + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id} + */ + Management.prototype.patchUserMetadata = function(userId, userMetadata, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(userMetadata, { + type: 'object', + message: 'userMetadata parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request + .patch(url) + .send({ user_metadata: userMetadata }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Updates the user attributes. It will patch the user attributes that the server allows it. + * + * @method patchUserAttributes + * @param {String} userId + * @param {Object} user + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id} + */ + Management.prototype.patchUserAttributes = function(userId, user, cb) { + var url; + + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(user, { + type: 'object', + message: 'user parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId); + + return this.request + .patch(url) + .send(user) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + /** + * Link two users + * + * @method linkUser + * @param {String} userId + * @param {String} secondaryUserToken + * @param {userCallback} cb + * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities} + */ + Management.prototype.linkUser = function(userId, secondaryUserToken, cb) { + var url; + /* eslint-disable */ + assert.check(userId, { + type: 'string', + message: 'userId parameter is not valid' + }); + assert.check(secondaryUserToken, { + type: 'string', + message: 'secondaryUserToken parameter is not valid' + }); + assert.check(cb, { type: 'function', message: 'cb parameter is not valid' }); + /* eslint-enable */ + + url = urlJoin(this.baseOptions.rootUrl, 'users', userId, 'identities'); + + return this.request + .post(url) + .send({ link_with: secondaryUserToken }) + .end(wrapCallback(cb, { ignoreCasing: true })); + }; + + var index = { + Authentication: Authentication, + Management: Management, + WebAuth: WebAuth, + version: version + }; + + exports.Authentication = Authentication; + exports.Management = Management; + exports.WebAuth = WebAuth; + exports.default = index; + exports.version = version; + + Object.defineProperty(exports, '__esModule', { value: true }); + +}))); diff --git a/dist/auth0.min.esm.js b/dist/auth0.min.esm.js new file mode 100644 index 00000000..01ac74be --- /dev/null +++ b/dist/auth0.min.esm.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +var commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function createCommonjsModule(fn,module){return fn(module={exports:{}},module.exports),module.exports}var urlJoin=createCommonjsModule((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray(val)){for(var mapped=[],i=0;i-1?val.split(","):val},parseKeys=function(givenKey,val,options,valuesParsed){if(givenKey){var key=options.allowDots?givenKey.replace(/\.([^.[]+)/g,"[$1]"):givenKey,child=/(\[[^[\]]*])/g,segment=options.depth>0&&/(\[[^[\]]*])/.exec(key),parent=segment?key.slice(0,segment.index):key,keys=[];if(parent){if(!options.plainObjects&&has$2.call(Object.prototype,parent)&&!options.allowPrototypes)return;keys.push(parent)}for(var i=0;options.depth>0&&null!==(segment=child.exec(key))&&i=0;--i){var obj,root=chain[i];if("[]"===root&&options.parseArrays)obj=[].concat(leaf);else{obj=options.plainObjects?Object.create(null):{};var cleanRoot="["===root.charAt(0)&&"]"===root.charAt(root.length-1)?root.slice(1,-1):root,index=parseInt(cleanRoot,10);options.parseArrays||""!==cleanRoot?!isNaN(index)&&root!==cleanRoot&&String(index)===cleanRoot&&index>=0&&options.parseArrays&&index<=options.arrayLimit?(obj=[])[index]=leaf:obj[cleanRoot]=leaf:obj={0:leaf}}leaf=obj}return leaf}(keys,val,options,valuesParsed)}},lib_parse=function(str,opts){var options=function(opts){if(!opts)return defaults$1;if(null!==opts.decoder&&void 0!==opts.decoder&&"function"!=typeof opts.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==opts.charset&&"utf-8"!==opts.charset&&"iso-8859-1"!==opts.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var charset=void 0===opts.charset?defaults$1.charset:opts.charset;return{allowDots:void 0===opts.allowDots?defaults$1.allowDots:!!opts.allowDots,allowPrototypes:"boolean"==typeof opts.allowPrototypes?opts.allowPrototypes:defaults$1.allowPrototypes,arrayLimit:"number"==typeof opts.arrayLimit?opts.arrayLimit:defaults$1.arrayLimit,charset:charset,charsetSentinel:"boolean"==typeof opts.charsetSentinel?opts.charsetSentinel:defaults$1.charsetSentinel,comma:"boolean"==typeof opts.comma?opts.comma:defaults$1.comma,decoder:"function"==typeof opts.decoder?opts.decoder:defaults$1.decoder,delimiter:"string"==typeof opts.delimiter||utils.isRegExp(opts.delimiter)?opts.delimiter:defaults$1.delimiter,depth:"number"==typeof opts.depth||!1===opts.depth?+opts.depth:defaults$1.depth,ignoreQueryPrefix:!0===opts.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof opts.interpretNumericEntities?opts.interpretNumericEntities:defaults$1.interpretNumericEntities,parameterLimit:"number"==typeof opts.parameterLimit?opts.parameterLimit:defaults$1.parameterLimit,parseArrays:!1!==opts.parseArrays,plainObjects:"boolean"==typeof opts.plainObjects?opts.plainObjects:defaults$1.plainObjects,strictNullHandling:"boolean"==typeof opts.strictNullHandling?opts.strictNullHandling:defaults$1.strictNullHandling}}(opts);if(""===str||null==str)return options.plainObjects?Object.create(null):{};for(var tempObj="string"==typeof str?function(str,options){var i,obj={},cleanStr=options.ignoreQueryPrefix?str.replace(/^\?/,""):str,limit=options.parameterLimit===1/0?void 0:options.parameterLimit,parts=cleanStr.split(options.delimiter,limit),skipIndex=-1,charset=options.charset;if(options.charsetSentinel)for(i=0;i-1&&(val=isArray$2(val)?[val]:val),has$2.call(obj,key)?obj[key]=utils.combine(obj[key],val):obj[key]=val}return obj}(str,options):str,obj=options.plainObjects?Object.create(null):{},keys=Object.keys(tempObj),i=0;i0?prefix+joined:""},componentEmitter=createCommonjsModule((function(module){function Emitter(obj){if(obj)return function(obj){for(var key in Emitter.prototype)obj[key]=Emitter.prototype[key];return obj}(obj)}module.exports=Emitter,Emitter.prototype.on=Emitter.prototype.addEventListener=function(event,fn){return this._callbacks=this._callbacks||{},(this._callbacks["$"+event]=this._callbacks["$"+event]||[]).push(fn),this},Emitter.prototype.once=function(event,fn){function on(){this.off(event,on),fn.apply(this,arguments)}return on.fn=fn,this.on(event,on),this},Emitter.prototype.off=Emitter.prototype.removeListener=Emitter.prototype.removeAllListeners=Emitter.prototype.removeEventListener=function(event,fn){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var cb,callbacks=this._callbacks["$"+event];if(!callbacks)return this;if(1==arguments.length)return delete this._callbacks["$"+event],this;for(var i=0;ib?1:0}function deterministicStringify(obj,replacer,spacer){var res,tmp=function deterministicDecirc(val,k,stack,parent){var i;if("object"==typeof val&&null!==val){for(i=0;i0)for(var i=0;i=this._maxRetries)return!1;if(this._retryCallback)try{var override=this._retryCallback(err,res);if(!0===override)return!0;if(!1===override)return!1}catch(err_){console.error(err_)}if(res&&res.status&&res.status>=500&&501!==res.status)return!0;if(err){if(err.code&&ERROR_CODES.includes(err.code))return!0;if(err.timeout&&"ECONNABORTED"===err.code)return!0;if(err.crossDomain)return!0}return!1},RequestBase.prototype._retry=function(){return this.clearTimeout(),this.req&&(this.req=null,this.req=this.request()),this._aborted=!1,this.timedout=!1,this.timedoutError=null,this._end()},RequestBase.prototype.then=function(resolve,reject){var _this=this;if(!this._fullfilledPromise){var self=this;this._endCalled&&console.warn("Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises"),this._fullfilledPromise=new Promise((function(resolve,reject){self.on("abort",(function(){if(!(_this._maxRetries&&_this._maxRetries>_this._retries))if(_this.timedout&&_this.timedoutError)reject(_this.timedoutError);else{var err=new Error("Aborted");err.code="ABORTED",err.status=_this.status,err.method=_this.method,err.url=_this.url,reject(err)}})),self.end((function(err,res){err?reject(err):resolve(res)}))}))}return this._fullfilledPromise.then(resolve,reject)},RequestBase.prototype.catch=function(cb){return this.then(void 0,cb)},RequestBase.prototype.use=function(fn){return fn(this),this},RequestBase.prototype.ok=function(cb){if("function"!=typeof cb)throw new Error("Callback required");return this._okCallback=cb,this},RequestBase.prototype._isResponseOK=function(res){return!!res&&(this._okCallback?this._okCallback(res):res.status>=200&&res.status<300)},RequestBase.prototype.get=function(field){return this._header[field.toLowerCase()]},RequestBase.prototype.getHeader=RequestBase.prototype.get,RequestBase.prototype.set=function(field,val){if(isObject_1(field)){for(var key in field)Object.prototype.hasOwnProperty.call(field,key)&&this.set(key,field[key]);return this}return this._header[field.toLowerCase()]=val,this.header[field]=val,this},RequestBase.prototype.unset=function(field){return delete this._header[field.toLowerCase()],delete this.header[field],this},RequestBase.prototype.field=function(name,val){if(null==name)throw new Error(".field(name, val) name can not be empty");if(this._data)throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()");if(isObject_1(name)){for(var key in name)Object.prototype.hasOwnProperty.call(name,key)&&this.field(key,name[key]);return this}if(Array.isArray(val)){for(var i in val)Object.prototype.hasOwnProperty.call(val,i)&&this.field(name,val[i]);return this}if(null==val)throw new Error(".field(name, val) val can not be empty");return"boolean"==typeof val&&(val=String(val)),this._getFormData().append(name,val),this},RequestBase.prototype.abort=function(){return this._aborted||(this._aborted=!0,this.xhr&&this.xhr.abort(),this.req&&this.req.abort(),this.clearTimeout(),this.emit("abort")),this},RequestBase.prototype._auth=function(user,pass,options,base64Encoder){switch(options.type){case"basic":this.set("Authorization","Basic ".concat(base64Encoder("".concat(user,":").concat(pass))));break;case"auto":this.username=user,this.password=pass;break;case"bearer":this.set("Authorization","Bearer ".concat(user))}return this},RequestBase.prototype.withCredentials=function(on){return void 0===on&&(on=!0),this._withCredentials=on,this},RequestBase.prototype.redirects=function(n){return this._maxRedirects=n,this},RequestBase.prototype.maxResponseSize=function(n){if("number"!=typeof n)throw new TypeError("Invalid argument");return this._maxResponseSize=n,this},RequestBase.prototype.toJSON=function(){return{method:this.method,url:this.url,data:this._data,headers:this._header}},RequestBase.prototype.send=function(data){var isObj=isObject_1(data),type=this._header["content-type"];if(this._formData)throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()");if(isObj&&!this._data)Array.isArray(data)?this._data=[]:this._isHost(data)||(this._data={});else if(data&&this._data&&this._isHost(this._data))throw new Error("Can't merge these send calls");if(isObj&&isObject_1(this._data))for(var key in data)Object.prototype.hasOwnProperty.call(data,key)&&(this._data[key]=data[key]);else"string"==typeof data?(type||this.type("form"),type=this._header["content-type"],this._data="application/x-www-form-urlencoded"===type?this._data?"".concat(this._data,"&").concat(data):data:(this._data||"")+data):this._data=data;return!isObj||this._isHost(data)||type||this.type("json"),this},RequestBase.prototype.sortQuery=function(sort){return this._sort=void 0===sort||sort,this},RequestBase.prototype._finalizeQueryString=function(){var query=this._query.join("&");if(query&&(this.url+=(this.url.includes("?")?"&":"?")+query),this._query.length=0,this._sort){var index=this.url.indexOf("?");if(index>=0){var queryArr=this.url.slice(index+1).split("&");"function"==typeof this._sort?queryArr.sort(this._sort):queryArr.sort(),this.url=this.url.slice(0,index)+"?"+queryArr.join("&")}}},RequestBase.prototype._appendQueryString=function(){console.warn("Unsupported")},RequestBase.prototype._timeoutError=function(reason,timeout,errno){if(!this._aborted){var err=new Error("".concat(reason+timeout,"ms exceeded"));err.timeout=timeout,err.code="ECONNABORTED",err.errno=errno,this.timedout=!0,this.timedoutError=err,this.abort(),this.callback(err)}},RequestBase.prototype._setTimeouts=function(){var self=this;this._timeout&&!this._timer&&(this._timer=setTimeout((function(){self._timeoutError("Timeout of ",self._timeout,"ETIME")}),this._timeout)),this._responseTimeout&&!this._responseTimeoutTimer&&(this._responseTimeoutTimer=setTimeout((function(){self._timeoutError("Response timeout of ",self._responseTimeout,"ETIMEDOUT")}),this._responseTimeout))};var utils$1_type=function(str){return str.split(/ *; */).shift()},utils$1_params=function(str){return str.split(/ *; */).reduce((function(obj,str){var parts=str.split(/ *= */),key=parts.shift(),val=parts.shift();return key&&val&&(obj[key]=val),obj}),{})},utils$1_parseLinks=function(str){return str.split(/ *, */).reduce((function(obj,str){var parts=str.split(/ *; */),url=parts[0].slice(1,-1);return obj[parts[1].split(/ *= */)[1].slice(1,-1)]=url,obj}),{})},responseBase=ResponseBase;function ResponseBase(obj){if(obj)return function(obj){for(var key in ResponseBase.prototype)Object.prototype.hasOwnProperty.call(ResponseBase.prototype,key)&&(obj[key]=ResponseBase.prototype[key]);return obj}(obj)}function _toConsumableArray(arr){return function(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}(arr)||function(iter){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(iter))return Array.from(iter)}(arr)||function(o,minLen){if(!o)return;if("string"==typeof o)return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);"Object"===n&&o.constructor&&(n=o.constructor.name);if("Map"===n||"Set"===n)return Array.from(o);if("Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}(arr)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _arrayLikeToArray(arr,len){(null==len||len>arr.length)&&(len=arr.length);for(var i=0,arr2=new Array(len);i0||str instanceof Object)?parse(str):null)},Response.prototype.toError=function(){var req=this.req,method=req.method,url=req.url,msg="cannot ".concat(method," ").concat(url," (").concat(this.status,")"),err=new Error(msg);return err.status=this.status,err.method=method,err.url=url,err},request.Response=Response,componentEmitter(Request.prototype),requestBase(Request.prototype),Request.prototype.type=function(type){return this.set("Content-Type",request.types[type]||type),this},Request.prototype.accept=function(type){return this.set("Accept",request.types[type]||type),this},Request.prototype.auth=function(user,pass,options){1===arguments.length&&(pass=""),"object"===_typeof(pass)&&null!==pass&&(options=pass,pass=""),options||(options={type:"function"==typeof btoa?"basic":"auto"});var encoder=function(string){if("function"==typeof btoa)return btoa(string);throw new Error("Cannot use basic auth, btoa is not a function")};return this._auth(user,pass,options,encoder)},Request.prototype.query=function(val){return"string"!=typeof val&&(val=serialize(val)),val&&this._query.push(val),this},Request.prototype.attach=function(field,file,options){if(file){if(this._data)throw new Error("superagent can't mix .send() and .attach()");this._getFormData().append(field,file,options||file.name)}return this},Request.prototype._getFormData=function(){return this._formData||(this._formData=new root.FormData),this._formData},Request.prototype.callback=function(err,res){if(this._shouldRetry(err,res))return this._retry();var fn=this._callback;this.clearTimeout(),err&&(this._maxRetries&&(err.retries=this._retries-1),this.emit("error",err)),fn(err,res)},Request.prototype.crossDomainError=function(){var err=new Error("Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.");err.crossDomain=!0,err.status=this.status,err.method=this.method,err.url=this.url,this.callback(err)},Request.prototype.agent=function(){return console.warn("This is not supported in browser version of superagent"),this},Request.prototype.ca=Request.prototype.agent,Request.prototype.buffer=Request.prototype.ca,Request.prototype.write=function(){throw new Error("Streaming is not supported in browser version of superagent")},Request.prototype.pipe=Request.prototype.write,Request.prototype._isHost=function(obj){return obj&&"object"===_typeof(obj)&&!Array.isArray(obj)&&"[object Object]"!==Object.prototype.toString.call(obj)},Request.prototype.end=function(fn){this._endCalled&&console.warn("Warning: .end() was called twice. This is not supported in superagent"),this._endCalled=!0,this._callback=fn||noop,this._finalizeQueryString(),this._end()},Request.prototype._setUploadTimeout=function(){var self=this;this._uploadTimeout&&!this._uploadTimeoutTimer&&(this._uploadTimeoutTimer=setTimeout((function(){self._timeoutError("Upload timeout of ",self._uploadTimeout,"ETIMEDOUT")}),this._uploadTimeout))},Request.prototype._end=function(){if(this._aborted)return this.callback(new Error("The request has been aborted even before .end() was called"));var self=this;this.xhr=request.getXHR();var xhr=this.xhr,data=this._formData||this._data;this._setTimeouts(),xhr.onreadystatechange=function(){var readyState=xhr.readyState;if(readyState>=2&&self._responseTimeoutTimer&&clearTimeout(self._responseTimeoutTimer),4===readyState){var status;try{status=xhr.status}catch(_unused5){status=0}if(!status){if(self.timedout||self._aborted)return;return self.crossDomainError()}self.emit("end")}};var handleProgress=function(direction,e){e.total>0&&(e.percent=e.loaded/e.total*100,100===e.percent&&clearTimeout(self._uploadTimeoutTimer)),e.direction=direction,self.emit("progress",e)};if(this.hasListeners("progress"))try{xhr.addEventListener("progress",handleProgress.bind(null,"download")),xhr.upload&&xhr.upload.addEventListener("progress",handleProgress.bind(null,"upload"))}catch(_unused6){}xhr.upload&&this._setUploadTimeout();try{this.username&&this.password?xhr.open(this.method,this.url,!0,this.username,this.password):xhr.open(this.method,this.url,!0)}catch(err){return this.callback(err)}if(this._withCredentials&&(xhr.withCredentials=!0),!this._formData&&"GET"!==this.method&&"HEAD"!==this.method&&"string"!=typeof data&&!this._isHost(data)){var contentType=this._header["content-type"],_serialize=this._serializer||request.serialize[contentType?contentType.split(";")[0]:""];!_serialize&&isJSON(contentType)&&(_serialize=request.serialize["application/json"]),_serialize&&(data=_serialize(data))}for(var field in this.header)null!==this.header[field]&&Object.prototype.hasOwnProperty.call(this.header,field)&&xhr.setRequestHeader(field,this.header[field]);this._responseType&&(xhr.responseType=this._responseType),this.emit("request",this),xhr.send(void 0===data?null:data)},request.agent=function(){return new agentBase},["GET","POST","OPTIONS","PATCH","PUT","DELETE"].forEach((function(method){agentBase.prototype[method.toLowerCase()]=function(url,fn){var req=new request.Request(method,url);return this._setDefaults(req),fn&&req.end(fn),req}})),agentBase.prototype.del=agentBase.prototype.delete,request.get=function(url,data,fn){var req=request("GET",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.head=function(url,data,fn){var req=request("HEAD",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.options=function(url,data,fn){var req=request("OPTIONS",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.del=del,request.delete=del,request.patch=function(url,data,fn){var req=request("PATCH",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.post=function(url,data,fn){var req=request("POST",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.put=function(url,data,fn){var req=request("PUT",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req}})),byteLength_1=(client.Request,function(b64){var lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1];return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}),toByteArray_1=function(b64){var tmp,i,lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1],arr=new Arr(function(b64,validLen,placeHoldersLen){return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}(0,validLen,placeHoldersLen)),curByte=0,len=placeHoldersLen>0?validLen-4:validLen;for(i=0;i>16&255,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp;2===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<2|revLookup[b64.charCodeAt(i+1)]>>4,arr[curByte++]=255&tmp);1===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<10|revLookup[b64.charCodeAt(i+1)]<<4|revLookup[b64.charCodeAt(i+2)]>>2,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp);return arr},fromByteArray_1=function(uint8){for(var tmp,len=uint8.length,extraBytes=len%3,parts=[],i=0,len2=len-extraBytes;ilen2?len2:i+16383));1===extraBytes?(tmp=uint8[len-1],parts.push(lookup[tmp>>2]+lookup[tmp<<4&63]+"==")):2===extraBytes&&(tmp=(uint8[len-2]<<8)+uint8[len-1],parts.push(lookup[tmp>>10]+lookup[tmp>>4&63]+lookup[tmp<<2&63]+"="));return parts.join("")},lookup=[],revLookup=[],Arr="undefined"!=typeof Uint8Array?Uint8Array:Array,code="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=0,len=code.length;i0)throw new Error("Invalid string. Length must be a multiple of 4");var validLen=b64.indexOf("=");return-1===validLen&&(validLen=len),[validLen,validLen===len?0:4-validLen%4]}function encodeChunk(uint8,start,end){for(var tmp,num,output=[],i=start;i>18&63]+lookup[num>>12&63]+lookup[num>>6&63]+lookup[63&num]);return output.join("")}revLookup["-".charCodeAt(0)]=62,revLookup["_".charCodeAt(0)]=63;var base64Js={byteLength:byteLength_1,toByteArray:toByteArray_1,fromByteArray:fromByteArray_1};var base64Url={encode:function(str){return base64Js.fromByteArray(function(str){for(var arr=new Array(str.length),a=0;a=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function RequestWrapper(req){this.request=req,this.method=req.method,this.url=req.url,this.body=req._data,this.headers=req._header}function RequestObj(req){this.request=req}function RequestBuilder(options){this._sendTelemetry=!1!==options._sendTelemetry||options._sendTelemetry,this._telemetryInfo=options._telemetryInfo||null,this._timesToRetryFailedRequests=options._timesToRetryFailedRequests,this.headers=options.headers||{},this._universalLoginPage=options.universalLoginPage}function getWindow(){return window}RequestWrapper.prototype.abort=function(){this.request.abort()},RequestWrapper.prototype.getMethod=function(){return this.method},RequestWrapper.prototype.getBody=function(){return this.body},RequestWrapper.prototype.getUrl=function(){return this.url},RequestWrapper.prototype.getHeaders=function(){return this.headers},RequestObj.prototype.set=function(key,value){return this.request=this.request.set(key,value),this},RequestObj.prototype.send=function(body){return this.request=this.request.send(objectHelper.trimUserDetails(body)),this},RequestObj.prototype.withCredentials=function(){return this.request=this.request.withCredentials(),this},RequestObj.prototype.end=function(cb){return this.request.end(cb),new RequestWrapper(this.request)},RequestBuilder.prototype.setCommonConfiguration=function(ongoingRequest,options){if(options=options||{},this._timesToRetryFailedRequests>0&&(ongoingRequest=ongoingRequest.retry(this._timesToRetryFailedRequests)),options.noHeaders)return ongoingRequest;var headers=this.headers;ongoingRequest=ongoingRequest.set("Content-Type","application/json");for(var keys=Object.keys(this.headers),a=0;a0&&warn.warning("Following parameters are not allowed on the `/authorize` endpoint: ["+notAllowed.join(",")+"]"),params}},t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e((function(e,r){e.exports=function(){function e(t){return"function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)})),o=e((function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64)})),s=e((function(t,e){t.exports=i$1.enc.Hex})),h=e((function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e))}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return"-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return"0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()}));function _(t,e){return e=e||{},new Promise((function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,(function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r})),r(a())},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)}))}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||""}function A(t){this.name="TokenValidationError",this.message=t||""}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return"number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}function PluginHandler(webAuth,plugins){this.plugins=plugins;for(var a=0;a1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)}))},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then((function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then((function(t){var e,r,i,n=null;for(e=0;e-1){null!==new RegExp("rv:([0-9]{2,2}[.0-9]{0,})").exec(ua)&&(rv=parseFloat(RegExp.$1))}return rv>=8}();return"undefined"!=typeof window&&window.JSON&&window.JSON.stringify&&window.JSON.parse&&window.postMessage?{open:function(opts,cb){if(!cb)throw"missing required callback argument";var err,iframe;opts.url||(err="missing required 'url' parameter"),opts.relay_url||(err="missing required 'relay_url' parameter"),err&&setTimeout((function(){cb(err)}),0),opts.window_name||(opts.window_name=null),opts.window_features&&!function(){try{var userAgent=navigator.userAgent;return-1!=userAgent.indexOf("Fennec/")||-1!=userAgent.indexOf("Firefox/")&&-1!=userAgent.indexOf("Android")}catch(e){}return!1}()||(opts.window_features=void 0);var messageTarget,origin=opts.origin||extractOrigin(opts.url);if(origin!==extractOrigin(opts.relay_url))return setTimeout((function(){cb("invalid arguments: origin of url and relay_url must match")}),0);isIE&&((iframe=document.createElement("iframe")).setAttribute("src",opts.relay_url),iframe.style.display="none",iframe.setAttribute("name","__winchan_relay_frame"),document.body.appendChild(iframe),messageTarget=iframe.contentWindow);var w=opts.popup||window.open(opts.url,opts.window_name,opts.window_features);opts.popup&&(w.location.href=opts.url),messageTarget||(messageTarget=w);var closeInterval=setInterval((function(){w&&w.closed&&(cleanup(),cb&&(cb("User closed the popup window"),cb=null))}),500),req=JSON.stringify({a:"request",d:opts.params});function cleanup(){if(iframe&&document.body.removeChild(iframe),iframe=void 0,closeInterval&&(closeInterval=clearInterval(closeInterval)),removeListener(window,"message",onMessage),removeListener(window,"unload",cleanup),w)try{w.close()}catch(securityViolation){messageTarget.postMessage("die",origin)}w=messageTarget=void 0}function onMessage(e){if(e.origin===origin){try{var d=JSON.parse(e.data)}catch(err){if(cb)return cb(err);throw err}"ready"===d.a?messageTarget.postMessage(req,origin):"error"===d.a?(cleanup(),cb&&(cb(d.d),cb=null)):"response"===d.a&&(cleanup(),cb&&(cb(null,d.d),cb=null))}}return addListener(window,"unload",cleanup),addListener(window,"message",onMessage),{originalPopup:w,close:cleanup,focus:function(){if(w)try{w.focus()}catch(e){}}}},onOpen:function(cb){var o="*",msgTarget=isIE?function(){for(var frames=window.opener.frames,i=frames.length-1;i>=0;i--)try{if(frames[i].location.protocol===window.location.protocol&&frames[i].location.host===window.location.host&&"__winchan_relay_frame"===frames[i].name)return frames[i]}catch(e){}}():window.opener;if(!msgTarget)throw"can't find relay frame";function doPost(msg){msg=JSON.stringify(msg),isIE?msgTarget.doPost(msg,o):msgTarget.postMessage(msg,o)}function onDie(e){if("die"===e.data)try{window.close()}catch(o_O){}}addListener(isIE?msgTarget:window,"message",(function onMessage(e){var d;try{d=JSON.parse(e.data)}catch(err){}d&&"request"===d.a&&(removeListener(window,"message",onMessage),o=e.origin,cb&&setTimeout((function(){cb(o,d.d,(function(r){cb=void 0,doPost({a:"response",d:r})}))}),0))})),addListener(isIE?msgTarget:window,"message",onDie);try{doPost({a:"ready"})}catch(e){addListener(msgTarget,"load",(function(e){doPost({a:"ready"})}))}var onUnload=function(){try{removeListener(isIE?msgTarget:window,"message",onDie)}catch(ohWell){}cb&&doPost({a:"error",d:"client closed window"}),cb=void 0;try{window.close()}catch(e){}};return addListener(window,"unload",onUnload),{detach:function(){removeListener(window,"unload",onUnload)}}}}:{open:function(url,winopts,arg,cb){setTimeout((function(){cb("unsupported browser")}),0)},onOpen:function(cb){setTimeout((function(){cb("unsupported browser")}),0)}}}();module.exports&&(module.exports=WinChan)}));var urlHelper={extractOrigin:function(url){/^https?:\/\//.test(url)||(url=window.location.href);var m=/^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url);return m?m[1]:url}};function PopupHandler(){this._current_popup=null}function Popup(webAuth,options){this.baseOptions=options,this.baseOptions.popupOrigin=options.popupOrigin,this.client=webAuth.client,this.webAuth=webAuth,this.transactionManager=new TransactionManager(this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(webAuth,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}function SilentAuthenticationHandler(options){this.authenticationUrl=options.authenticationUrl,this.timeout=options.timeout||6e4,this.handler=null,this.postMessageDataType=options.postMessageDataType||!1,this.postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().location.origin||windowHelper.getWindow().location.protocol+"//"+windowHelper.getWindow().location.hostname+(windowHelper.getWindow().location.port?":"+windowHelper.getWindow().location.port:"")}function UsernamePassword(options){this.baseOptions=options,this.request=new RequestBuilder(options),this.transactionManager=new TransactionManager(this.baseOptions)}function HostedPages(client,options){this.baseOptions=options,this.client=client,this.baseOptions.universalLoginPage=!0,this.request=new RequestBuilder(this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}PopupHandler.prototype.calculatePosition=function(options){var width=options.width||500,height=options.height||600,_window=windowHelper.getWindow(),screenX=void 0!==_window.screenX?_window.screenX:_window.screenLeft,screenY=void 0!==_window.screenY?_window.screenY:_window.screenTop,outerWidth=void 0!==_window.outerWidth?_window.outerWidth:_window.document.body.clientWidth,outerHeight=void 0!==_window.outerHeight?_window.outerHeight:_window.document.body.clientHeight;return{width:width,height:height,left:options.left||screenX+(outerWidth-width)/2,top:options.top||screenY+(outerHeight-height)/2}},PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHelper.getWindow(),popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),url=options.url||"about:blank",windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"auth0_signup_popup",windowFeatures),this._current_popup.kill=function(){this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,relayUrl,options,cb){var _this=this,popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),winchanOptions=objectHelper.merge({url:url,relay_url:relayUrl,window_features:lib_stringify(popupOptions,{delimiter:",",encode:!1}),popup:this._current_popup}).with(options),popup=winchan.open(winchanOptions,(function(err,data){if(!err||"SyntaxError"!==err.name)return _this._current_popup=null,cb(err,data)}));return popup.focus(),popup},Popup.prototype.buildPopupHandler=function(){var pluginHandler=this.baseOptions.plugins.get("popup.getPopupHandler");return pluginHandler?pluginHandler.getPopupHandler():new PopupHandler},Popup.prototype.preload=function(options){options=options||{};var popup=this.buildPopupHandler();return popup.preload(options),popup},Popup.prototype.getPopupHandler=function(options,preload){return options.popupHandler?options.popupHandler:preload?this.preload(options):this.buildPopupHandler()},Popup.prototype.callback=function(options){var _this=this,theWindow=windowHelper.getWindow(),originUrl=(options=options||{}).popupOrigin||this.baseOptions.popupOrigin||windowHelper.getOrigin();theWindow.opener?winchan.onOpen((function(popupOrigin,r,cb){if(popupOrigin!==originUrl)return cb({error:"origin_mismatch",error_description:"The popup's origin ("+popupOrigin+") should match the `popupOrigin` parameter ("+originUrl+")."});_this.webAuth.parseHash(options||{},(function(err,data){return cb(err||data)}))})):theWindow.doPost=function(msg){theWindow.parent&&theWindow.parent.postMessage(msg,originUrl)}},Popup.prototype.authorize=function(options,cb){var url,relayUrl,popOpts={},pluginHandler=this.baseOptions.plugins.get("popup.authorize"),params=objectHelper.merge(this.baseOptions,["clientID","scope","domain","audience","tenant","responseType","redirectUri","_csrf","state","_intstate","nonce"]).with(objectHelper.blacklist(options,["popupHandler"]));return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),relayUrl=urlJoin(this.baseOptions.rootUrl,"relay.html"),options.owp?params.owp=!0:(popOpts.origin=urlHelper.extractOrigin(params.redirectUri),relayUrl=params.redirectUri),options.popupOptions&&(popOpts.popupOptions=objectHelper.pick(options.popupOptions,["width","height","top","left"])),pluginHandler&&(params=pluginHandler.processParams(params)),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",delete params.domain,url=this.client.buildAuthorizeUrl(params),this.getPopupHandler(options).load(url,relayUrl,popOpts,wrapCallback(cb,{keepOriginalCasing:!0}))},Popup.prototype.loginWithCredentials=function(options,cb){options.realm=options.realm||options.connection,options.popup=!0,options=objectHelper.merge(this.baseOptions,["redirectUri","responseType","state","nonce"]).with(objectHelper.blacklist(options,["popupHandler","connection"])),options=this.transactionManager.process(options),this.crossOriginAuthentication.login(options,cb)},Popup.prototype.passwordlessVerify=function(options,cb){var _this=this;return this.client.passwordless.verify(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.username=options.phoneNumber||options.email,options.password=options.verificationCode,delete options.email,delete options.phoneNumber,delete options.verificationCode,delete options.type,_this.client.loginWithResourceOwner(options,cb)}))},Popup.prototype.signupAndLogin=function(options,cb){var _this=this;return this.client.dbConnection.signup(options,(function(err){if(err)return cb(err);_this.loginWithCredentials(options,cb)}))},SilentAuthenticationHandler.create=function(options){return new SilentAuthenticationHandler(options)},SilentAuthenticationHandler.prototype.login=function(usePostMessage,callback){this.handler=new IframeHandler({auth0:this.auth0,url:this.authenticationUrl,eventListenerType:usePostMessage?"message":"load",callback:this.getCallbackHandler(callback,usePostMessage),timeout:this.timeout,eventValidator:this.getEventValidator(),timeoutCallback:function(){callback(null,"#error=timeout&error_description=Timeout+during+authentication+renew.")},usePostMessage:usePostMessage||!1}),this.handler.init()},SilentAuthenticationHandler.prototype.getEventValidator=function(){var _this=this;return{isValid:function(eventData){switch(eventData.event.type){case"message":return eventData.event.origin===_this.postMessageOrigin&&eventData.event.source===_this.handler.iframe.contentWindow&&(!1===_this.postMessageDataType||eventData.event.data.type&&eventData.event.data.type===_this.postMessageDataType);case"load":if("about:"===eventData.sourceObject.contentWindow.location.protocol)return!1;default:return!0}}}},SilentAuthenticationHandler.prototype.getCallbackHandler=function(callback,usePostMessage){return function(eventData){var callbackValue;callbackValue=usePostMessage?"object"==typeof eventData.event.data&&eventData.event.data.hash?eventData.event.data.hash:eventData.event.data:eventData.sourceObject.contentWindow.location.hash,callback(null,callbackValue)}},UsernamePassword.prototype.login=function(options,cb){var url,body;return url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","login"),options.username=options.username||options.email,options=objectHelper.blacklist(options,["email"]),body=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience"]).with(options),body=this.transactionManager.process(body),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},UsernamePassword.prototype.callback=function(formHtml){var div,_document=windowHelper.getDocument();(div=_document.createElement("div")).innerHTML=formHtml,_document.body.appendChild(div).children[0].submit()},HostedPages.prototype.login=function(options,cb){if(windowHelper.getWindow().location.host!==this.baseOptions.domain)throw new Error("This method is meant to be used only inside the Universal Login Page.");var usernamePassword,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(usernamePassword=new UsernamePassword(this.baseOptions)).login(params,(function(err,data){return err?cb(err):usernamePassword.callback(data)}))},HostedPages.prototype.signupAndLogin=function(options,cb){var _this=this;return _this.client.client.dbConnection.signup(options,(function(err){return err?cb(err):_this.login(options,cb)}))},HostedPages.prototype.getSSOData=function(withActiveDirectories,cb){var url,params="";return"function"==typeof withActiveDirectories&&(cb=withActiveDirectories,withActiveDirectories=!1),assert.check(withActiveDirectories,{type:"boolean",message:"withActiveDirectories parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),withActiveDirectories&&(params="?"+lib_stringify({ldaps:1,client_id:this.baseOptions.clientID})),url=urlJoin(this.baseOptions.rootUrl,"user","ssodata",params),this.request.get(url,{noHeaders:!0}).withCredentials().end(wrapCallback(cb))};var noop=function(){},defaults$2={lang:"en",templates:{auth0:function(challenge){var message="code"===challenge.type?"Enter the code shown above":"Solve the formula shown above";return'
\n \n \n
\n'},recaptcha_v2:function(){return'
'},error:function(){return'
Error getting the bot detection challenge. Please contact the system administrator.
'}}};function handleRecaptchaProvider(element,options,challenge){var widgetId=element.hasAttribute("data-wid")&&element.getAttribute("data-wid");function setValue(value){element.querySelector('input[name="captcha"]').value=value||""}if(widgetId)return setValue(),void window.grecaptcha.reset(widgetId);element.innerHTML=options.templates[challenge.provider](challenge);var recaptchaDiv=element.querySelector(".recaptcha");!function(element,lang,callback){var callbackName="recaptchaCallback_"+Math.floor(1000001*Math.random());window[callbackName]=function(){delete window[callbackName],callback()};var script=window.document.createElement("script");script.src="https://www.google.com/recaptcha/api.js?hl="+lang+"&onload="+callbackName,script.async=!0,window.document.body.appendChild(script)}(0,options.lang,(function(){widgetId=window.grecaptcha.render(recaptchaDiv,{callback:setValue,"expired-callback":function(){setValue()},"error-callback":function(){setValue()},sitekey:challenge.siteKey}),element.setAttribute("data-wid",widgetId)}))}var captcha={render:function(auth0Client,element,options,callback){function load(done){done=done||noop,auth0Client.getChallenge((function(err,challenge){return err?(element.innerHTML=options.templates.error(err),done(err)):challenge.required?(element.style.display="","auth0"===challenge.provider?function(element,options,challenge,load){element.innerHTML=options.templates[challenge.provider](challenge),element.querySelector(".captcha-reload").addEventListener("click",(function(e){e.preventDefault(),load()}))}(element,options,challenge,load):"recaptcha_v2"===challenge.provider&&handleRecaptchaProvider(element,options,challenge),void done()):(element.style.display="none",void(element.innerHTML=""))}))}return options=objectHelper.merge(defaults$2).with(options||{}),load(callback),{reload:load,getValue:function(){var captchaInput=element.querySelector('input[name="captcha"]');if(captchaInput)return captchaInput.value}}}};function defaultClock(){return new Date}function WebAuth(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},popupOrigin:{optional:!0,type:"string",message:"popupOrigin is not valid"},leeway:{optional:!0,type:"number",message:"leeway is not valid"},plugins:{optional:!0,type:"array",message:"plugins is not valid"},maxAge:{optional:!0,type:"number",message:"maxAge is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"},_timesToRetryFailedRequests:{optional:!0,type:"number",message:"_timesToRetryFailedRequests option is not valid"}}),options.overrides&&assert.check(options.overrides,{type:"object",message:"overrides option is not valid"},{__tenant:{optional:!0,type:"string",message:"__tenant option is required"},__token_issuer:{optional:!0,type:"string",message:"__token_issuer option is required"},__jwks_uri:{optional:!0,type:"string",message:"__jwks_uri is required"}}),this.baseOptions=options,this.baseOptions.plugins=new PluginHandler(this,this.baseOptions.plugins||[]),this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions._timesToRetryFailedRequests=options._timesToRetryFailedRequests?parseInt(options._timesToRetryFailedRequests,0):0,this.baseOptions.tenant=this.baseOptions.overrides&&this.baseOptions.overrides.__tenant||this.baseOptions.domain.split(".")[0],this.baseOptions.token_issuer=this.baseOptions.overrides&&this.baseOptions.overrides.__token_issuer||"https://"+this.baseOptions.domain+"/",this.baseOptions.jwksURI=this.baseOptions.overrides&&this.baseOptions.overrides.__jwks_uri,this.transactionManager=new TransactionManager(this.baseOptions),this.client=new Authentication(this.baseOptions),this.redirect=new Redirect(this,this.baseOptions),this.popup=new Popup(this,this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(this,this.baseOptions),this.webMessageHandler=new WebMessageHandler(this),this._universalLogin=new HostedPages(this,this.baseOptions),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function PasswordlessAuthentication(request,options){this.baseOptions=options,this.request=request}function DBConnection(request,options){this.baseOptions=options,this.request=request}function Authentication(auth0,options){2===arguments.length?this.auth0=auth0:options=auth0,assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions.rootUrl=this.baseOptions.domain&&0===this.baseOptions.domain.toLowerCase().indexOf("http")?this.baseOptions.domain:"https://"+this.baseOptions.domain,this.request=new RequestBuilder(this.baseOptions),this.passwordless=new PasswordlessAuthentication(this.request,this.baseOptions),this.dbConnection=new DBConnection(this.request,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings}),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function Management(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},token:{type:"string",message:"token option is required"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions.headers={Authorization:"Bearer "+this.baseOptions.token},this.request=new RequestBuilder(this.baseOptions),this.baseOptions.rootUrl=urlJoin("https://"+this.baseOptions.domain,"api","v2")}WebAuth.prototype.parseHash=function(options,cb){var parsedQs,err;cb||"function"!=typeof options?options=options||{}:(cb=options,options={});var _window=windowHelper.getWindow(),hashStr=void 0===options.hash?_window.location.hash:options.hash;if(hashStr=hashStr.replace(/^#?\/?/,""),(parsedQs=lib_parse(hashStr)).hasOwnProperty("error"))return err=error.buildResponse(parsedQs.error,parsedQs.error_description),parsedQs.state&&(err.state=parsedQs.state),cb(err);if(!parsedQs.hasOwnProperty("access_token")&&!parsedQs.hasOwnProperty("id_token")&&!parsedQs.hasOwnProperty("refresh_token"))return cb(null,null);var responseTypes=(this.baseOptions.responseType||options.responseType||"").split(" ");return responseTypes.length>0&&-1!==responseTypes.indexOf("token")&&!parsedQs.hasOwnProperty("access_token")?cb(error.buildResponse("invalid_hash","response_type contains `token`, but the parsed hash does not contain an `access_token` property")):responseTypes.length>0&&-1!==responseTypes.indexOf("id_token")&&!parsedQs.hasOwnProperty("id_token")?cb(error.buildResponse("invalid_hash","response_type contains `id_token`, but the parsed hash does not contain an `id_token` property")):this.validateAuthenticationResponse(options,parsedQs,cb)},WebAuth.prototype.validateAuthenticationResponse=function(options,parsedHash,cb){var _this=this;options.__enableIdPInitiatedLogin=options.__enableIdPInitiatedLogin||options.__enableImpersonation;var state=parsedHash.state,transaction=this.transactionManager.getStoredTransaction(state),transactionState=options.state||transaction&&transaction.state||null,transactionStateMatchesState=transactionState===state;if(!(!state&&!transactionState&&options.__enableIdPInitiatedLogin)&&!transactionStateMatchesState)return cb({error:"invalid_token",errorDescription:"`state` does not match."});var transactionNonce=options.nonce||transaction&&transaction.nonce||null,appState=options.state||transaction&&transaction.appState||null,callback=function(err,payload){if(err)return cb(err);var sub;transaction&&transaction.lastUsedConnection&&(payload&&(sub=payload.sub),_this.ssodataStorage.set(transaction.lastUsedConnection,sub));return cb(null,function(qsParams,appState,token){return{accessToken:qsParams.access_token||null,idToken:qsParams.id_token||null,idTokenPayload:token||null,appState:appState||null,refreshToken:qsParams.refresh_token||null,state:qsParams.state||null,expiresIn:qsParams.expires_in?parseInt(qsParams.expires_in,10):null,tokenType:qsParams.token_type||null,scope:qsParams.scope||null}}(parsedHash,appState,payload))};return parsedHash.id_token?this.validateToken(parsedHash.id_token,transactionNonce,(function(validationError,payload){if(!validationError)return parsedHash.access_token&&payload.at_hash?(new k).validateAccessToken(parsedHash.access_token,"RS256",payload.at_hash,(function(err){return err?callback(error.invalidToken(err.message)):callback(null,payload)})):callback(null,payload);if("invalid_token"!==validationError.error||validationError.errorDescription&&validationError.errorDescription.indexOf("Nonce (nonce) claim value mismatch in the ID token")>-1)return callback(validationError);var decodedToken=(new k).decode(parsedHash.id_token);if("HS256"!==decodedToken.header.alg)return callback(validationError);if((decodedToken.payload.nonce||null)!==transactionNonce)return callback({error:"invalid_token",errorDescription:'Nonce (nonce) claim value mismatch in the ID token; expected "'+transactionNonce+'", found "'+decodedToken.payload.nonce+'"'});if(!parsedHash.access_token){return callback({error:"invalid_token",description:"The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token"})}return _this.client.userInfo(parsedHash.access_token,(function(errUserInfo,profile){return errUserInfo?callback(errUserInfo):callback(null,profile)}))})):callback(null,null)},WebAuth.prototype.validateToken=function(token,nonce,cb){new k({issuer:this.baseOptions.token_issuer,jwksURI:this.baseOptions.jwksURI,audience:this.baseOptions.clientID,leeway:this.baseOptions.leeway||60,maxAge:this.baseOptions.maxAge,__clock:this.baseOptions.__clock||defaultClock}).verify(token,nonce,(function(err,payload){if(err)return cb(error.invalidToken(err.message));cb(null,payload)}))},WebAuth.prototype.renewAuth=function(options,cb){var usePostMessage=!!options.usePostMessage,postMessageDataType=options.postMessageDataType||!1,postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().origin,timeout=options.timeout,_this=this,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","responseType","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params.responseType=params.responseType||"token",params.responseMode=params.responseMode||"fragment",params=this.transactionManager.process(params),assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params.prompt="none",params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType","postMessageOrigin"]),SilentAuthenticationHandler.create({authenticationUrl:this.client.buildAuthorizeUrl(params),postMessageDataType:postMessageDataType,postMessageOrigin:postMessageOrigin,timeout:timeout}).login(usePostMessage,(function(err,hash){if("object"==typeof hash)return cb(err,hash);_this.parseHash({hash:hash},cb)}))},WebAuth.prototype.checkSession=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return"code"===params.responseType?cb({error:"error",error_description:"responseType can't be `code`"}):(options.nonce||(params=this.transactionManager.process(params)),params.redirectUri?(assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType"]),void this.webMessageHandler.run(params,wrapCallback(cb,{forceLegacyError:!0,ignoreCasing:!0}))):cb({error:"error",error_description:"redirectUri can't be empty"}))},WebAuth.prototype.changePassword=function(options,cb){return this.client.dbConnection.changePassword(options,cb)},WebAuth.prototype.passwordlessStart=function(options,cb){var authParams=objectHelper.merge(this.baseOptions,["responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options.authParams);return options.authParams=this.transactionManager.process(authParams),this.client.passwordless.start(options,cb)},WebAuth.prototype.signup=function(options,cb){return this.client.dbConnection.signup(options,cb)},WebAuth.prototype.authorize=function(options){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",windowHelper.redirect(this.client.buildAuthorizeUrl(params))},WebAuth.prototype.signupAndAuthorize=function(options,cb){var _this=this;return this.client.dbConnection.signup(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.realm=options.connection,options.username||(options.username=options.email),_this.client.login(options,cb)}))},WebAuth.prototype.login=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain?(params.connection=params.realm,delete params.realm,this._universalLogin.login(params,cb)):this.crossOriginAuthentication.login(params,cb)},WebAuth.prototype.passwordlessLogin=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);if(params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain)this.passwordlessVerify(params,cb);else{var crossOriginOptions=objectHelper.extend({credentialType:"http://auth0.com/oauth/grant-type/passwordless/otp",realm:params.connection,username:params.email||params.phoneNumber,otp:params.verificationCode},objectHelper.blacklist(params,["connection","email","phoneNumber","verificationCode"]));this.crossOriginAuthentication.login(crossOriginOptions,cb)}},WebAuth.prototype.crossOriginAuthenticationCallback=function(){this.crossOriginVerification()},WebAuth.prototype.crossOriginVerification=function(){this.crossOriginAuthentication.callback()},WebAuth.prototype.logout=function(options){windowHelper.redirect(this.client.buildLogoutUrl(options))},WebAuth.prototype.passwordlessVerify=function(options,cb){var _this=this,params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),params=this.transactionManager.process(params),this.client.passwordless.verify(params,(function(err){return err?cb(err):windowHelper.redirect(_this.client.passwordless.buildVerifyUrl(params))}))},WebAuth.prototype.renderCaptcha=function(element,options,callback){return captcha.render(this.client,element,options,callback)},PasswordlessAuthentication.prototype.buildVerifyUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","protocol","nonce"]).with(options),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client"]),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"passwordless","verify_redirect","?"+qString)},PasswordlessAuthentication.prototype.start=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},send:{type:"string",message:"send option is required",values:["link","code"],value_message:"send is not valid ([link, code])"},phoneNumber:{optional:!0,type:"string",message:"phoneNumber option is required",condition:function(o){return"code"===o.send||!o.email}},email:{optional:!0,type:"string",message:"email option is required",condition:function(o){return"link"===o.send||!o.phoneNumber}},authParams:{optional:!0,type:"object",message:"authParams option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"passwordless","start"),(body=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope"]).with(options)).scope&&(body.authParams=body.authParams||{},body.authParams.scope=body.authParams.scope||body.scope),body.redirectUri&&(body.authParams=body.authParams||{},body.authParams.redirect_uri=body.authParams.redirectUri||body.redirectUri),body.responseType&&(body.authParams=body.authParams||{},body.authParams.response_type=body.authParams.responseType||body.responseType),delete body.redirectUri,delete body.responseType,delete body.scope,body=objectHelper.toSnakeCase(body,["auth0Client","authParams"]),this.request.post(url).send(body).end(wrapCallback(cb))},PasswordlessAuthentication.prototype.verify=function(options,cb){var url,cleanOption;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),cleanOption=objectHelper.pick(options,["connection","verificationCode","phoneNumber","email","auth0Client"]),cleanOption=objectHelper.toSnakeCase(cleanOption,["auth0Client"]),url=urlJoin(this.baseOptions.rootUrl,"passwordless","verify"),this.request.post(url).send(cleanOption).end(wrapCallback(cb))},DBConnection.prototype.signup=function(options,cb){var url,body,metadata;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"},password:{type:"string",message:"password option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","signup"),metadata=(body=objectHelper.merge(this.baseOptions,["clientID","state"]).with(options)).user_metadata||body.userMetadata,body=objectHelper.blacklist(body,["scope","userMetadata","user_metadata"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),metadata&&(body.user_metadata=metadata),this.request.post(url).send(body).end(wrapCallback(cb))},DBConnection.prototype.changePassword=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","change_password"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options,["email","connection"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.buildAuthorizeUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience"]).with(options),assert.check(params,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},redirectUri:{optional:!0,type:"string",message:"redirectUri option is required"},responseType:{type:"string",message:"responseType option is required"},nonce:{type:"string",message:"nonce option is required",condition:function(o){return-1===o.responseType.indexOf("code")&&-1!==o.responseType.indexOf("id_token")}},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params.connection_scope&&assert.isArray(params.connection_scope)&&(params.connection_scope=params.connection_scope.join(",")),params=objectHelper.blacklist(params,["username","popupOptions","domain","tenant","timeout","appState"]),params=objectHelper.toSnakeCase(params,["auth0Client"]),params=parametersWhitelist.oauthAuthorizeParams(this.warn,params),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"authorize","?"+qString)},Authentication.prototype.buildLogoutUrl=function(options){var params,qString;return assert.check(options,{optional:!0,type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID"]).with(options||{}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client","returnTo"]),qString=lib_stringify(objectHelper.blacklist(params,["federated"])),options&&void 0!==options.federated&&!1!==options.federated&&"false"!==options.federated&&(qString+="&federated"),urlJoin(this.baseOptions.rootUrl,"v2","logout","?"+qString)},Authentication.prototype.loginWithDefaultDirectory=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="password",this.oauthToken(options,cb)},Authentication.prototype.login=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},realm:{type:"string",message:"realm option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="http://auth0.com/oauth/grant-type/password-realm",this.oauthToken(options,cb)},Authentication.prototype.oauthToken=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","token"),body=objectHelper.merge(this.baseOptions,["clientID","scope","audience"]).with(options),assert.check(body,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},grantType:{type:"string",message:"grantType option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),body=objectHelper.toSnakeCase(body,["auth0Client"]),body=parametersWhitelist.oauthTokenParams(this.warn,body),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.loginWithResourceOwner=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},connection:{type:"string",message:"connection option is required"},scope:{optional:!0,type:"string",message:"scope option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","ro"),body=objectHelper.merge(this.baseOptions,["clientID","scope"]).with(options,["username","password","scope","connection","device"]),(body=objectHelper.toSnakeCase(body,["auth0Client"])).grant_type=body.grant_type||"password",this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getSSOData=function(withActiveDirectories,cb){if(this.auth0||(this.auth0=new WebAuth(this.baseOptions)),windowHelper.getWindow().location.host===this.baseOptions.domain)return this.auth0._universalLogin.getSSOData(withActiveDirectories,cb);"function"==typeof withActiveDirectories&&(cb=withActiveDirectories),assert.check(cb,{type:"function",message:"cb parameter is not valid"});var clientId=this.baseOptions.clientID,ssodataInformation=this.ssodataStorage.get()||{};this.auth0.checkSession({responseType:"token id_token",scope:"openid profile email",connection:ssodataInformation.lastUsedConnection,timeout:5e3},(function(err,result){return err?"login_required"===err.error?cb(null,{sso:!1}):("consent_required"===err.error&&(err.error_description="Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`."),cb(err,{sso:!1})):ssodataInformation.lastUsedSub&&ssodataInformation.lastUsedSub!==result.idTokenPayload.sub?cb(err,{sso:!1}):cb(null,{lastUsedConnection:{name:ssodataInformation.lastUsedConnection},lastUsedUserID:result.idTokenPayload.sub,lastUsedUsername:result.idTokenPayload.email||result.idTokenPayload.name,lastUsedClientID:clientId,sessionClients:[clientId],sso:!0})}))},Authentication.prototype.userInfo=function(accessToken,cb){var url;return assert.check(accessToken,{type:"string",message:"accessToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"userinfo"),this.request.get(url).set("Authorization","Bearer "+accessToken).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.getChallenge=function(cb){if(assert.check(cb,{type:"function",message:"cb parameter is not valid"}),!this.baseOptions.state)return cb();var url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","challenge");return this.request.post(url).send({state:this.baseOptions.state}).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.delegation=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{grant_type:{type:"string",message:"grant_type option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"delegation"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getUserCountry=function(cb){var url;return assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"user","geoloc","country"),this.request.get(url).end(wrapCallback(cb))},Management.prototype.getUser=function(userId,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.get(url).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserMetadata=function(userId,userMetadata,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(userMetadata,{type:"object",message:"userMetadata parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send({user_metadata:userMetadata}).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserAttributes=function(userId,user,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(user,{type:"object",message:"user parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send(user).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.linkUser=function(userId,secondaryUserToken,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(secondaryUserToken,{type:"string",message:"secondaryUserToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId,"identities"),this.request.post(url).send({link_with:secondaryUserToken}).end(wrapCallback(cb,{ignoreCasing:!0}))};var index={Authentication:Authentication,Management:Management,WebAuth:WebAuth,version:version};export default index;export{Authentication,Management,WebAuth,version}; +//# sourceMappingURL=auth0.min.esm.js.map diff --git a/dist/auth0.min.esm.js.map b/dist/auth0.min.esm.js.map new file mode 100644 index 00000000..1cc8fbfa --- /dev/null +++ b/dist/auth0.min.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"auth0.min.esm.js","sources":["../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../node_modules/component-emitter/index.js","../node_modules/fast-safe-stringify/index.js","../node_modules/superagent/lib/is-object.js","../node_modules/superagent/lib/request-base.js","../node_modules/superagent/lib/utils.js","../node_modules/superagent/lib/response-base.js","../node_modules/superagent/lib/agent-base.js","../node_modules/base64-js/index.js","../node_modules/superagent/lib/client.js","../src/helper/base64_url.js","../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/request-builder.js","../src/helper/window.js","../src/helper/storage/dummy.js","../node_modules/js-cookie/src/js.cookie.js","../src/helper/storage/cookie.js","../src/helper/warn.js","../src/helper/storage/handler.js","../src/helper/storage.js","../src/helper/ssodata.js","../src/helper/error.js","../src/helper/response-handler.js","../src/helper/parameters-whitelist.js","../node_modules/idtoken-verifier/build/idtoken-verifier.esm.js","../src/helper/plugins.js","../src/helper/random.js","../src/web-auth/transaction-manager.js","../src/helper/iframe-handler.js","../src/web-auth/web-message-handler.js","../src/web-auth/cross-origin-authentication.js","../src/web-auth/redirect.js","../src/helper/times.js","../node_modules/winchan/winchan.js","../src/helper/url.js","../src/helper/popup-handler.js","../src/web-auth/popup.js","../src/web-auth/silent-authentication-handler.js","../src/web-auth/username-password.js","../src/web-auth/hosted-pages.js","../src/web-auth/captcha.js","../src/web-auth/index.js","../src/authentication/passwordless-authentication.js","../src/authentication/db-connection.js","../src/authentication/index.js","../src/management/index.js","../src/index.js"],"sourcesContent":["(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","\r\n/**\r\n * Expose `Emitter`.\r\n */\r\n\r\nif (typeof module !== 'undefined') {\r\n module.exports = Emitter;\r\n}\r\n\r\n/**\r\n * Initialize a new `Emitter`.\r\n *\r\n * @api public\r\n */\r\n\r\nfunction Emitter(obj) {\r\n if (obj) return mixin(obj);\r\n};\r\n\r\n/**\r\n * Mixin the emitter properties.\r\n *\r\n * @param {Object} obj\r\n * @return {Object}\r\n * @api private\r\n */\r\n\r\nfunction mixin(obj) {\r\n for (var key in Emitter.prototype) {\r\n obj[key] = Emitter.prototype[key];\r\n }\r\n return obj;\r\n}\r\n\r\n/**\r\n * Listen on the given `event` with `fn`.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.on =\r\nEmitter.prototype.addEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\r\n .push(fn);\r\n return this;\r\n};\r\n\r\n/**\r\n * Adds an `event` listener that will be invoked a single\r\n * time then automatically removed.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.once = function(event, fn){\r\n function on() {\r\n this.off(event, on);\r\n fn.apply(this, arguments);\r\n }\r\n\r\n on.fn = fn;\r\n this.on(event, on);\r\n return this;\r\n};\r\n\r\n/**\r\n * Remove the given callback for `event` or all\r\n * registered callbacks.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.off =\r\nEmitter.prototype.removeListener =\r\nEmitter.prototype.removeAllListeners =\r\nEmitter.prototype.removeEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n\r\n // all\r\n if (0 == arguments.length) {\r\n this._callbacks = {};\r\n return this;\r\n }\r\n\r\n // specific event\r\n var callbacks = this._callbacks['$' + event];\r\n if (!callbacks) return this;\r\n\r\n // remove all handlers\r\n if (1 == arguments.length) {\r\n delete this._callbacks['$' + event];\r\n return this;\r\n }\r\n\r\n // remove specific handler\r\n var cb;\r\n for (var i = 0; i < callbacks.length; i++) {\r\n cb = callbacks[i];\r\n if (cb === fn || cb.fn === fn) {\r\n callbacks.splice(i, 1);\r\n break;\r\n }\r\n }\r\n\r\n // Remove event specific arrays for event types that no\r\n // one is subscribed for to avoid memory leak.\r\n if (callbacks.length === 0) {\r\n delete this._callbacks['$' + event];\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Emit `event` with the given args.\r\n *\r\n * @param {String} event\r\n * @param {Mixed} ...\r\n * @return {Emitter}\r\n */\r\n\r\nEmitter.prototype.emit = function(event){\r\n this._callbacks = this._callbacks || {};\r\n\r\n var args = new Array(arguments.length - 1)\r\n , callbacks = this._callbacks['$' + event];\r\n\r\n for (var i = 1; i < arguments.length; i++) {\r\n args[i - 1] = arguments[i];\r\n }\r\n\r\n if (callbacks) {\r\n callbacks = callbacks.slice(0);\r\n for (var i = 0, len = callbacks.length; i < len; ++i) {\r\n callbacks[i].apply(this, args);\r\n }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Return array of callbacks for `event`.\r\n *\r\n * @param {String} event\r\n * @return {Array}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.listeners = function(event){\r\n this._callbacks = this._callbacks || {};\r\n return this._callbacks['$' + event] || [];\r\n};\r\n\r\n/**\r\n * Check if this emitter has `event` handlers.\r\n *\r\n * @param {String} event\r\n * @return {Boolean}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.hasListeners = function(event){\r\n return !! this.listeners(event).length;\r\n};\r\n","module.exports = stringify\nstringify.default = stringify\nstringify.stable = deterministicStringify\nstringify.stableStringify = deterministicStringify\n\nvar arr = []\nvar replacerStack = []\n\n// Regular stringify\nfunction stringify (obj, replacer, spacer) {\n decirc(obj, '', [], undefined)\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer)\n } else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\nfunction decirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, stack, val)\n }\n } else {\n var keys = Object.keys(val)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n decirc(val[key], key, stack, val)\n }\n }\n stack.pop()\n }\n}\n\n// Stable-stringify\nfunction compareFunction (a, b) {\n if (a < b) {\n return -1\n }\n if (a > b) {\n return 1\n }\n return 0\n}\n\nfunction deterministicStringify (obj, replacer, spacer) {\n var tmp = deterministicDecirc(obj, '', [], undefined) || obj\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer)\n } else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\n\nfunction deterministicDecirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n if (typeof val.toJSON === 'function') {\n return\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, stack, val)\n }\n } else {\n // Create a temporary object in the required way\n var tmp = {}\n var keys = Object.keys(val).sort(compareFunction)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n deterministicDecirc(val[key], key, stack, val)\n tmp[key] = val[key]\n }\n if (parent !== undefined) {\n arr.push([parent, k, val])\n parent[k] = tmp\n } else {\n return tmp\n }\n }\n stack.pop()\n }\n}\n\n// wraps replacer function to handle values we couldn't replace\n// and mark them as [Circular]\nfunction replaceGetterValues (replacer) {\n replacer = replacer !== undefined ? replacer : function (k, v) { return v }\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i]\n if (part[1] === key && part[0] === val) {\n val = '[Circular]'\n replacerStack.splice(i, 1)\n break\n }\n }\n }\n return replacer.call(this, key, val)\n }\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\nfunction isObject(obj) {\n return obj !== null && _typeof(obj) === 'object';\n}\n\nmodule.exports = isObject;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pcy1vYmplY3QuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJvYmoiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7Ozs7Ozs7QUFRQSxTQUFTQSxRQUFULENBQWtCQyxHQUFsQixFQUF1QjtBQUNyQixTQUFPQSxHQUFHLEtBQUssSUFBUixJQUFnQixRQUFPQSxHQUFQLE1BQWUsUUFBdEM7QUFDRDs7QUFFREMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCSCxRQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYW4gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge0Jvb2xlYW59XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBpc09iamVjdChvYmopIHtcbiAgcmV0dXJuIG9iaiAhPT0gbnVsbCAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0Jztcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBpc09iamVjdDtcbiJdfQ==","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Module of mixed-in functions shared between node and client code\n */\nvar isObject = require('./is-object');\n/**\n * Expose `RequestBase`.\n */\n\n\nmodule.exports = RequestBase;\n/**\n * Initialize a new `RequestBase`.\n *\n * @api public\n */\n\nfunction RequestBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in RequestBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.clearTimeout = function () {\n clearTimeout(this._timer);\n clearTimeout(this._responseTimeoutTimer);\n clearTimeout(this._uploadTimeoutTimer);\n delete this._timer;\n delete this._responseTimeoutTimer;\n delete this._uploadTimeoutTimer;\n return this;\n};\n/**\n * Override default response body parser\n *\n * This function will be called to convert incoming data into request.body\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.parse = function (fn) {\n this._parser = fn;\n return this;\n};\n/**\n * Set format of binary response body.\n * In browser valid formats are 'blob' and 'arraybuffer',\n * which return Blob and ArrayBuffer, respectively.\n *\n * In Node all values result in Buffer.\n *\n * Examples:\n *\n * req.get('/')\n * .responseType('blob')\n * .end(callback);\n *\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.responseType = function (val) {\n this._responseType = val;\n return this;\n};\n/**\n * Override default request body serializer\n *\n * This function will be called to convert data set via .send or .attach into payload to send\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.serialize = function (fn) {\n this._serializer = fn;\n return this;\n};\n/**\n * Set timeouts.\n *\n * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time.\n * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections.\n * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off\n *\n * Value of 0 or false means no timeout.\n *\n * @param {Number|Object} ms or {response, deadline}\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.timeout = function (options) {\n if (!options || _typeof(options) !== 'object') {\n this._timeout = options;\n this._responseTimeout = 0;\n this._uploadTimeout = 0;\n return this;\n }\n\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option)) {\n switch (option) {\n case 'deadline':\n this._timeout = options.deadline;\n break;\n\n case 'response':\n this._responseTimeout = options.response;\n break;\n\n case 'upload':\n this._uploadTimeout = options.upload;\n break;\n\n default:\n console.warn('Unknown timeout option', option);\n }\n }\n }\n\n return this;\n};\n/**\n * Set number of retry attempts on error.\n *\n * Failed requests will be retried 'count' times if timeout or err.code >= 500.\n *\n * @param {Number} count\n * @param {Function} [fn]\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.retry = function (count, fn) {\n // Default to 1 if no count passed or true\n if (arguments.length === 0 || count === true) count = 1;\n if (count <= 0) count = 0;\n this._maxRetries = count;\n this._retries = 0;\n this._retryCallback = fn;\n return this;\n};\n\nvar ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT'];\n/**\n * Determine if a request should be retried.\n * (Borrowed from segmentio/superagent-retry)\n *\n * @param {Error} err an error\n * @param {Response} [res] response\n * @returns {Boolean} if segment should be retried\n */\n\nRequestBase.prototype._shouldRetry = function (err, res) {\n if (!this._maxRetries || this._retries++ >= this._maxRetries) {\n return false;\n }\n\n if (this._retryCallback) {\n try {\n var override = this._retryCallback(err, res);\n\n if (override === true) return true;\n if (override === false) return false; // undefined falls back to defaults\n } catch (err_) {\n console.error(err_);\n }\n }\n\n if (res && res.status && res.status >= 500 && res.status !== 501) return true;\n\n if (err) {\n if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout\n\n if (err.timeout && err.code === 'ECONNABORTED') return true;\n if (err.crossDomain) return true;\n }\n\n return false;\n};\n/**\n * Retry request\n *\n * @return {Request} for chaining\n * @api private\n */\n\n\nRequestBase.prototype._retry = function () {\n this.clearTimeout(); // node\n\n if (this.req) {\n this.req = null;\n this.req = this.request();\n }\n\n this._aborted = false;\n this.timedout = false;\n this.timedoutError = null;\n return this._end();\n};\n/**\n * Promise support\n *\n * @param {Function} resolve\n * @param {Function} [reject]\n * @return {Request}\n */\n\n\nRequestBase.prototype.then = function (resolve, reject) {\n var _this = this;\n\n if (!this._fullfilledPromise) {\n var self = this;\n\n if (this._endCalled) {\n console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises');\n }\n\n this._fullfilledPromise = new Promise(function (resolve, reject) {\n self.on('abort', function () {\n if (_this._maxRetries && _this._maxRetries > _this._retries) {\n return;\n }\n\n if (_this.timedout && _this.timedoutError) {\n reject(_this.timedoutError);\n return;\n }\n\n var err = new Error('Aborted');\n err.code = 'ABORTED';\n err.status = _this.status;\n err.method = _this.method;\n err.url = _this.url;\n reject(err);\n });\n self.end(function (err, res) {\n if (err) reject(err);else resolve(res);\n });\n });\n }\n\n return this._fullfilledPromise.then(resolve, reject);\n};\n\nRequestBase.prototype.catch = function (cb) {\n return this.then(undefined, cb);\n};\n/**\n * Allow for extension\n */\n\n\nRequestBase.prototype.use = function (fn) {\n fn(this);\n return this;\n};\n\nRequestBase.prototype.ok = function (cb) {\n if (typeof cb !== 'function') throw new Error('Callback required');\n this._okCallback = cb;\n return this;\n};\n\nRequestBase.prototype._isResponseOK = function (res) {\n if (!res) {\n return false;\n }\n\n if (this._okCallback) {\n return this._okCallback(res);\n }\n\n return res.status >= 200 && res.status < 300;\n};\n/**\n * Get request header `field`.\n * Case-insensitive.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nRequestBase.prototype.get = function (field) {\n return this._header[field.toLowerCase()];\n};\n/**\n * Get case-insensitive header `field` value.\n * This is a deprecated internal API. Use `.get(field)` instead.\n *\n * (getHeader is no longer used internally by the superagent code base)\n *\n * @param {String} field\n * @return {String}\n * @api private\n * @deprecated\n */\n\n\nRequestBase.prototype.getHeader = RequestBase.prototype.get;\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n * Case-insensitive.\n *\n * Examples:\n *\n * req.get('/')\n * .set('Accept', 'application/json')\n * .set('X-API-Key', 'foobar')\n * .end(callback);\n *\n * req.get('/')\n * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n * .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequestBase.prototype.set = function (field, val) {\n if (isObject(field)) {\n for (var key in field) {\n if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]);\n }\n\n return this;\n }\n\n this._header[field.toLowerCase()] = val;\n this.header[field] = val;\n return this;\n};\n/**\n * Remove header `field`.\n * Case-insensitive.\n *\n * Example:\n *\n * req.get('/')\n * .unset('User-Agent')\n * .end(callback);\n *\n * @param {String} field field name\n */\n\n\nRequestBase.prototype.unset = function (field) {\n delete this._header[field.toLowerCase()];\n delete this.header[field];\n return this;\n};\n/**\n * Write the field `name` and `val`, or multiple fields with one object\n * for \"multipart/form-data\" request bodies.\n *\n * ``` js\n * request.post('/upload')\n * .field('foo', 'bar')\n * .end(callback);\n *\n * request.post('/upload')\n * .field({ foo: 'bar', baz: 'qux' })\n * .end(callback);\n * ```\n *\n * @param {String|Object} name name of field\n * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.field = function (name, val) {\n // name should be either a string or an object.\n if (name === null || undefined === name) {\n throw new Error('.field(name, val) name can not be empty');\n }\n\n if (this._data) {\n throw new Error(\".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObject(name)) {\n for (var key in name) {\n if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]);\n }\n\n return this;\n }\n\n if (Array.isArray(val)) {\n for (var i in val) {\n if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]);\n }\n\n return this;\n } // val should be defined now\n\n\n if (val === null || undefined === val) {\n throw new Error('.field(name, val) val can not be empty');\n }\n\n if (typeof val === 'boolean') {\n val = String(val);\n }\n\n this._getFormData().append(name, val);\n\n return this;\n};\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request} request\n * @api public\n */\n\n\nRequestBase.prototype.abort = function () {\n if (this._aborted) {\n return this;\n }\n\n this._aborted = true;\n if (this.xhr) this.xhr.abort(); // browser\n\n if (this.req) this.req.abort(); // node\n\n this.clearTimeout();\n this.emit('abort');\n return this;\n};\n\nRequestBase.prototype._auth = function (user, pass, options, base64Encoder) {\n switch (options.type) {\n case 'basic':\n this.set('Authorization', \"Basic \".concat(base64Encoder(\"\".concat(user, \":\").concat(pass))));\n break;\n\n case 'auto':\n this.username = user;\n this.password = pass;\n break;\n\n case 'bearer':\n // usage would be .auth(accessToken, { type: 'bearer' })\n this.set('Authorization', \"Bearer \".concat(user));\n break;\n\n default:\n break;\n }\n\n return this;\n};\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\n\nRequestBase.prototype.withCredentials = function (on) {\n // This is browser-only functionality. Node side is no-op.\n if (on === undefined) on = true;\n this._withCredentials = on;\n return this;\n};\n/**\n * Set the max redirects to `n`. Does nothing in browser XHR implementation.\n *\n * @param {Number} n\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.redirects = function (n) {\n this._maxRedirects = n;\n return this;\n};\n/**\n * Maximum size of buffered response body, in bytes. Counts uncompressed size.\n * Default 200MB.\n *\n * @param {Number} n number of bytes\n * @return {Request} for chaining\n */\n\n\nRequestBase.prototype.maxResponseSize = function (n) {\n if (typeof n !== 'number') {\n throw new TypeError('Invalid argument');\n }\n\n this._maxResponseSize = n;\n return this;\n};\n/**\n * Convert to a plain javascript object (not JSON string) of scalar properties.\n * Note as this method is designed to return a useful non-this value,\n * it cannot be chained.\n *\n * @return {Object} describing method, url, and data of this request\n * @api public\n */\n\n\nRequestBase.prototype.toJSON = function () {\n return {\n method: this.method,\n url: this.url,\n data: this._data,\n headers: this._header\n };\n};\n/**\n * Send `data` as the request body, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n * // manual json\n * request.post('/user')\n * .type('json')\n * .send('{\"name\":\"tj\"}')\n * .end(callback)\n *\n * // auto json\n * request.post('/user')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // manual x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send('name=tj')\n * .end(callback)\n *\n * // auto x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // defaults to x-www-form-urlencoded\n * request.post('/user')\n * .send('name=tobi')\n * .send('species=ferret')\n * .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n// eslint-disable-next-line complexity\n\n\nRequestBase.prototype.send = function (data) {\n var isObj = isObject(data);\n var type = this._header['content-type'];\n\n if (this._formData) {\n throw new Error(\".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObj && !this._data) {\n if (Array.isArray(data)) {\n this._data = [];\n } else if (!this._isHost(data)) {\n this._data = {};\n }\n } else if (data && this._data && this._isHost(this._data)) {\n throw new Error(\"Can't merge these send calls\");\n } // merge\n\n\n if (isObj && isObject(this._data)) {\n for (var key in data) {\n if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key];\n }\n } else if (typeof data === 'string') {\n // default to x-www-form-urlencoded\n if (!type) this.type('form');\n type = this._header['content-type'];\n\n if (type === 'application/x-www-form-urlencoded') {\n this._data = this._data ? \"\".concat(this._data, \"&\").concat(data) : data;\n } else {\n this._data = (this._data || '') + data;\n }\n } else {\n this._data = data;\n }\n\n if (!isObj || this._isHost(data)) {\n return this;\n } // default to json\n\n\n if (!type) this.type('json');\n return this;\n};\n/**\n * Sort `querystring` by the sort function\n *\n *\n * Examples:\n *\n * // default order\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery()\n * .end(callback)\n *\n * // customized sort function\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery(function(a, b){\n * return a.length - b.length;\n * })\n * .end(callback)\n *\n *\n * @param {Function} sort\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.sortQuery = function (sort) {\n // _sort default to true but otherwise can be a function or boolean\n this._sort = typeof sort === 'undefined' ? true : sort;\n return this;\n};\n/**\n * Compose querystring to append to req.url\n *\n * @api private\n */\n\n\nRequestBase.prototype._finalizeQueryString = function () {\n var query = this._query.join('&');\n\n if (query) {\n this.url += (this.url.includes('?') ? '&' : '?') + query;\n }\n\n this._query.length = 0; // Makes the call idempotent\n\n if (this._sort) {\n var index = this.url.indexOf('?');\n\n if (index >= 0) {\n var queryArr = this.url.slice(index + 1).split('&');\n\n if (typeof this._sort === 'function') {\n queryArr.sort(this._sort);\n } else {\n queryArr.sort();\n }\n\n this.url = this.url.slice(0, index) + '?' + queryArr.join('&');\n }\n }\n}; // For backwards compat only\n\n\nRequestBase.prototype._appendQueryString = function () {\n console.warn('Unsupported');\n};\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\n\nRequestBase.prototype._timeoutError = function (reason, timeout, errno) {\n if (this._aborted) {\n return;\n }\n\n var err = new Error(\"\".concat(reason + timeout, \"ms exceeded\"));\n err.timeout = timeout;\n err.code = 'ECONNABORTED';\n err.errno = errno;\n this.timedout = true;\n this.timedoutError = err;\n this.abort();\n this.callback(err);\n};\n\nRequestBase.prototype._setTimeouts = function () {\n var self = this; // deadline\n\n if (this._timeout && !this._timer) {\n this._timer = setTimeout(function () {\n self._timeoutError('Timeout of ', self._timeout, 'ETIME');\n }, this._timeout);\n } // response timeout\n\n\n if (this._responseTimeout && !this._responseTimeoutTimer) {\n this._responseTimeoutTimer = setTimeout(function () {\n self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT');\n }, this._responseTimeout);\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXF1ZXN0LWJhc2UuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJyZXF1aXJlIiwibW9kdWxlIiwiZXhwb3J0cyIsIlJlcXVlc3RCYXNlIiwib2JqIiwibWl4aW4iLCJrZXkiLCJwcm90b3R5cGUiLCJPYmplY3QiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJjbGVhclRpbWVvdXQiLCJfdGltZXIiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJfdXBsb2FkVGltZW91dFRpbWVyIiwicGFyc2UiLCJmbiIsIl9wYXJzZXIiLCJyZXNwb25zZVR5cGUiLCJ2YWwiLCJfcmVzcG9uc2VUeXBlIiwic2VyaWFsaXplIiwiX3NlcmlhbGl6ZXIiLCJ0aW1lb3V0Iiwib3B0aW9ucyIsIl90aW1lb3V0IiwiX3Jlc3BvbnNlVGltZW91dCIsIl91cGxvYWRUaW1lb3V0Iiwib3B0aW9uIiwiZGVhZGxpbmUiLCJyZXNwb25zZSIsInVwbG9hZCIsImNvbnNvbGUiLCJ3YXJuIiwicmV0cnkiLCJjb3VudCIsImFyZ3VtZW50cyIsImxlbmd0aCIsIl9tYXhSZXRyaWVzIiwiX3JldHJpZXMiLCJfcmV0cnlDYWxsYmFjayIsIkVSUk9SX0NPREVTIiwiX3Nob3VsZFJldHJ5IiwiZXJyIiwicmVzIiwib3ZlcnJpZGUiLCJlcnJfIiwiZXJyb3IiLCJzdGF0dXMiLCJjb2RlIiwiaW5jbHVkZXMiLCJjcm9zc0RvbWFpbiIsIl9yZXRyeSIsInJlcSIsInJlcXVlc3QiLCJfYWJvcnRlZCIsInRpbWVkb3V0IiwidGltZWRvdXRFcnJvciIsIl9lbmQiLCJ0aGVuIiwicmVzb2x2ZSIsInJlamVjdCIsIl9mdWxsZmlsbGVkUHJvbWlzZSIsInNlbGYiLCJfZW5kQ2FsbGVkIiwiUHJvbWlzZSIsIm9uIiwiRXJyb3IiLCJtZXRob2QiLCJ1cmwiLCJlbmQiLCJjYXRjaCIsImNiIiwidW5kZWZpbmVkIiwidXNlIiwib2siLCJfb2tDYWxsYmFjayIsIl9pc1Jlc3BvbnNlT0siLCJnZXQiLCJmaWVsZCIsIl9oZWFkZXIiLCJ0b0xvd2VyQ2FzZSIsImdldEhlYWRlciIsInNldCIsImhlYWRlciIsInVuc2V0IiwibmFtZSIsIl9kYXRhIiwiQXJyYXkiLCJpc0FycmF5IiwiaSIsIlN0cmluZyIsIl9nZXRGb3JtRGF0YSIsImFwcGVuZCIsImFib3J0IiwieGhyIiwiZW1pdCIsIl9hdXRoIiwidXNlciIsInBhc3MiLCJiYXNlNjRFbmNvZGVyIiwidHlwZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJ3aXRoQ3JlZGVudGlhbHMiLCJfd2l0aENyZWRlbnRpYWxzIiwicmVkaXJlY3RzIiwibiIsIl9tYXhSZWRpcmVjdHMiLCJtYXhSZXNwb25zZVNpemUiLCJUeXBlRXJyb3IiLCJfbWF4UmVzcG9uc2VTaXplIiwidG9KU09OIiwiZGF0YSIsImhlYWRlcnMiLCJzZW5kIiwiaXNPYmoiLCJfZm9ybURhdGEiLCJfaXNIb3N0Iiwic29ydFF1ZXJ5Iiwic29ydCIsIl9zb3J0IiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJxdWVyeSIsIl9xdWVyeSIsImpvaW4iLCJpbmRleCIsImluZGV4T2YiLCJxdWVyeUFyciIsInNsaWNlIiwic3BsaXQiLCJfYXBwZW5kUXVlcnlTdHJpbmciLCJfdGltZW91dEVycm9yIiwicmVhc29uIiwiZXJybm8iLCJjYWxsYmFjayIsIl9zZXRUaW1lb3V0cyIsInNldFRpbWVvdXQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7O0FBR0EsSUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsYUFBRCxDQUF4QjtBQUVBOzs7OztBQUlBQyxNQUFNLENBQUNDLE9BQVAsR0FBaUJDLFdBQWpCO0FBRUE7Ozs7OztBQU1BLFNBQVNBLFdBQVQsQ0FBcUJDLEdBQXJCLEVBQTBCO0FBQ3hCLE1BQUlBLEdBQUosRUFBUyxPQUFPQyxLQUFLLENBQUNELEdBQUQsQ0FBWjtBQUNWO0FBRUQ7Ozs7Ozs7OztBQVFBLFNBQVNDLEtBQVQsQ0FBZUQsR0FBZixFQUFvQjtBQUNsQixPQUFLLElBQU1FLEdBQVgsSUFBa0JI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LEVBRXJCLEtBQUtBLFFBRmdCLENBQXhCO0FBR0QsR0FSNkMsQ0FVOUM7OztBQUNBLE1BQUksS0FBS0MsZ0JBQUwsSUFBeUIsQ0FBQyxLQUFLYixxQkFBbkMsRUFBMEQ7QUFDeEQsU0FBS0EscUJBQUwsR0FBNkI0SCxVQUFVLENBQUMsWUFBTTtBQUM1QzFFLE1BQUFBLElBQUksQ0FBQ3FFLGFBQUwsQ0FDRSxzQkFERixFQUVFckUsSUFBSSxDQUFDckMsZ0JBRlAsRUFHRSxXQUhGO0FBS0QsS0FOc0MsRUFNcEMsS0FBS0EsZ0JBTitCLENBQXZDO0FBT0Q7QUFDRixDQXBCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTW9kdWxlIG9mIG1peGVkLWluIGZ1bmN0aW9ucyBzaGFyZWQgYmV0d2VlbiBub2RlIGFuZCBjbGllbnQgY29kZVxuICovXG5jb25zdCBpc09iamVjdCA9IHJlcXVpcmUoJy4vaXMtb2JqZWN0Jyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXF1ZXN0QmFzZWAuXG4gKi9cblxubW9kdWxlLmV4cG9ydHMgPSBSZXF1ZXN0QmFzZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0QmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0QmFzZShvYmopIHtcbiAgaWYgKG9iaikgcmV0dXJuIG1peGluKG9iaik7XG59XG5cbi8qKlxuICogTWl4aW4gdGhlIHByb3RvdHlwZSBwcm9wZXJ0aWVzLlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIG1peGluKG9iaikge1xuICBmb3IgKGNvbnN0IGtleSBpbiBSZXF1ZXN0QmFzZS5wcm90b3R5cGUpIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKFJlcXVlc3RCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVxdWVzdEJhc2UucHJvdG90eXBlW2tleV07XG4gIH1cblxuICByZXR1cm4gb2JqO1xufVxuXG4vKipcbiAqIENsZWFyIHByZXZpb3VzIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5jbGVhclRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3RpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3VwbG9hZFRpbWVvdXRUaW1lcik7XG4gIGRlbGV0ZSB0aGlzLl90aW1lcjtcbiAgZGVsZXRlIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyO1xuICBkZWxldGUgdGhpcy5fdXBsb2FkVGltZW91dFRpbWVyO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogT3ZlcnJpZGUgZGVmYXVsdCByZXNwb25zZSBib2R5IHBhcnNlclxuICpcbiAqIFRoaXMgZnVuY3Rpb24gd2lsbCBiZSBjYWxsZWQgdG8gY29udmVydCBpbmNvbWluZyBkYXRhIGludG8gcmVxdWVzdC5ib2R5XG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnBhcnNlID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fcGFyc2VyID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgZm9ybWF0IG9mIGJpbmFyeSByZXNwb25zZSBib2R5LlxuICogSW4gYnJvd3NlciB2YWxpZCBmb3JtYXRzIGFyZSAnYmxvYicgYW5kICdhcnJheWJ1ZmZlcicsXG4gKiB3aGljaCByZXR1cm4gQmxvYiBhbmQgQXJyYXlCdWZmZXIsIHJlc3BlY3RpdmVseS5cbiAqXG4gKiBJbiBOb2RlIGFsbCB2YWx1ZXMgcmVzdWx0IGluIEJ1ZmZlci5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5yZXNwb25zZVR5cGUoJ2Jsb2InKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB2YWxcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVzcG9uc2VUeXBlID0gZnVuY3Rpb24odmFsKSB7XG4gIHRoaXMuX3Jlc3BvbnNlVHlwZSA9IHZhbDtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIE92ZXJyaWRlIGRlZmF1bHQgcmVxdWVzdCBib2R5IHNlcmlhbGl6ZXJcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYmUgY2FsbGVkIHRvIGNvbnZlcnQgZGF0YSBzZXQgdmlhIC5zZW5kIG9yIC5hdHRhY2ggaW50byBwYXlsb2FkIHRvIHNlbmRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VyaWFsaXplID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fc2VyaWFsaXplciA9IGZuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IHRpbWVvdXRzLlxuICpcbiAqIC0gcmVzcG9uc2UgdGltZW91dCBpcyB0aW1lIGJldHdlZW4gc2VuZGluZyByZXF1ZXN0IGFuZCByZWNlaXZpbmcgdGhlIGZpcnN0IGJ5dGUgb2YgdGhlIHJlc3BvbnNlLiBJbmNsdWRlcyBETlMgYW5kIGNvbm5lY3Rpb24gdGltZS5cbiAqIC0gZGVhZGxpbmUgaXMgdGhlIHRpbWUgZnJvbSBzdGFydCBvZiB0aGUgcmVxdWVzdCB0byByZWNlaXZpbmcgcmVzcG9uc2UgYm9keSBpbiBmdWxsLiBJZiB0aGUgZGVhZGxpbmUgaXMgdG9vIHNob3J0IGxhcmdlIGZpbGVzIG1heSBub3QgbG9hZCBhdCBhbGwgb24gc2xvdyBjb25uZWN0aW9ucy5cbiAqIC0gdXBsb2FkIGlzIHRoZSB0aW1lICBzaW5jZSBsYXN0IGJpdCBvZiBkYXRhIHdhcyBzZW50IG9yIHJlY2VpdmVkLiBUaGlzIHRpbWVvdXQgd29ya3Mgb25seSBpZiBkZWFkbGluZSB0aW1lb3V0IGlzIG9mZlxuICpcbiAqIFZhbHVlIG9mIDAgb3IgZmFsc2UgbWVhbnMgbm8gdGltZW91dC5cbiAqXG4gKiBAcGFyYW0ge051bWJlcnxPYmplY3R9IG1zIG9yIHtyZXNwb25zZSwgZGVhZGxpbmV9XG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnRpbWVvdXQgPSBmdW5jdGlvbihvcHRpb25zKSB7XG4gIGlmICghb3B0aW9ucyB8fCB0eXBlb2Ygb3B0aW9ucyAhPT0gJ29iamVjdCcpIHtcbiAgICB0aGlzLl90aW1lb3V0ID0gb3B0aW9ucztcbiAgICB0aGlzLl9yZXNwb25zZVRpbWVvdXQgPSAwO1xuICAgIHRoaXMuX3VwbG9hZFRpbWVvdXQgPSAwO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZm9yIChjb25zdCBvcHRpb24gaW4gb3B0aW9ucykge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob3B0aW9ucywgb3B0aW9uKSkge1xuICAgICAgc3dpdGNoIChvcHRpb24pIHtcbiAgICAgICAgY2FzZSAnZGVhZGxpbmUnOlxuICAgICAgICAgIHRoaXMuX3RpbWVvdXQgPSBvcHRpb25zLmRlYWRsaW5lO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdyZXNwb25zZSc6XG4gICAgICAgICAgdGhpcy5fcmVzcG9uc2VUaW1lb3V0ID0gb3B0aW9ucy5yZXNwb25zZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAndXBsb2FkJzpcbiAgICAgICAgICB0aGlzLl91cGxvYWRUaW1lb3V0ID0gb3B0aW9ucy51cGxvYWQ7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgY29uc29sZS53YXJuKCdVbmtub3duIHRpbWVvdXQgb3B0aW9uJywgb3B0aW9uKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IG51bWJlciBvZiByZXRyeSBhdHRlbXB0cyBvbiBlcnJvci5cbiAqXG4gKiBGYWlsZWQgcmVxdWVzdHMgd2lsbCBiZSByZXRyaWVkICdjb3VudCcgdGltZXMgaWYgdGltZW91dCBvciBlcnIuY29kZSA+PSA1MDAuXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IGNvdW50XG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnJldHJ5ID0gZnVuY3Rpb24oY291bnQsIGZuKSB7XG4gIC8vIERlZmF1bHQgdG8gMSBpZiBubyBjb3VudCBwYXNzZWQgb3IgdHJ1ZVxuICBpZiAoYXJndW1lbnRzLmxlbmd0aCA9PT0gMCB8fCBjb3VudCA9PT0gdHJ1ZSkgY291bnQgPSAxO1xuICBpZiAoY291bnQgPD0gMCkgY291bnQgPSAwO1xuICB0aGlzLl9tYXhSZXRyaWVzID0gY291bnQ7XG4gIHRoaXMuX3JldHJpZXMgPSAwO1xuICB0aGlzLl9yZXRyeUNhbGxiYWNrID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuY29uc3QgRVJST1JfQ09ERVMgPSBbJ0VDT05OUkVTRVQnLCAnRVRJTUVET1VUJywgJ0VBRERSSU5GTycsICdFU09DS0VUVElNRURPVVQnXTtcblxuLyoqXG4gKiBEZXRlcm1pbmUgaWYgYSByZXF1ZXN0IHNob3VsZCBiZSByZXRyaWVkLlxuICogKEJvcnJvd2VkIGZyb20gc2VnbWVudGlvL3N1cGVyYWdlbnQtcmV0cnkpXG4gKlxuICogQHBhcmFtIHtFcnJvcn0gZXJyIGFuIGVycm9yXG4gKiBAcGFyYW0ge1Jlc3BvbnNlfSBbcmVzXSByZXNwb25zZVxuICogQHJldHVybnMge0Jvb2xlYW59IGlmIHNlZ21lbnQgc2hvdWxkIGJlIHJldHJpZWRcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zaG91bGRSZXRyeSA9IGZ1bmN0aW9uKGVyciwgcmVzKSB7XG4gIGlmICghdGhpcy5fbWF4UmV0cmllcyB8fCB0aGlzLl9yZXRyaWVzKysgPj0gdGhpcy5fbWF4UmV0cmllcykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICh0aGlzLl9yZXRyeUNhbGxiYWNrKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IG92ZXJyaWRlID0gdGhpcy5fcmV0cnlDYWxsYmFjayhlcnIsIHJlcyk7XG4gICAgICBpZiAob3ZlcnJpZGUgPT09IHRydWUpIHJldHVybiB0cnVlO1xuICAgICAgaWYgKG92ZXJyaWRlID09PSBmYWxzZSkgcmV0dXJuIGZhbHNlO1xuICAgICAgLy8gdW5kZWZpbmVkIGZhbGxzIGJhY2sgdG8gZGVmYXVsdHNcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycl8pO1xuICAgIH1cbiAgfVxuXG4gIGlmIChyZXMgJiYgcmVzLnN0YXR1cyAmJiByZXMuc3RhdHVzID49IDUwMCAmJiByZXMuc3RhdHVzICE9PSA1MDEpIHJldHVybiB0cnVlO1xuICBpZiAoZXJyKSB7XG4gICAgaWYgKGVyci5jb2RlICYmIEVSUk9SX0NPREVTLmluY2x1ZGVzKGVyci5jb2RlKSkgcmV0dXJuIHRydWU7XG4gICAgLy8gU3VwZXJhZ2VudCB0aW1lb3V0XG4gICAgaWYgKGVyci50aW1lb3V0ICYmIGVyci5jb2RlID09PSAnRUNPTk5BQk9SVEVEJykgcmV0dXJuIHRydWU7XG4gICAgaWYgKGVyci5jcm9zc0RvbWFpbikgcmV0dXJuIHRydWU7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59O1xuXG4vKipcbiAqIFJldHJ5IHJlcXVlc3RcbiAqXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fcmV0cnkgPSBmdW5jdGlvbigpIHtcbiAgdGhpcy5jbGVhclRpbWVvdXQoKTtcblxuICAvLyBub2RlXG4gIGlmICh0aGlzLnJlcSkge1xuICAgIHRoaXMucmVxID0gbnVsbDtcbiAgICB0aGlzLnJlcSA9IHRoaXMucmVxdWVzdCgpO1xuICB9XG5cbiAgdGhpcy5fYWJvcnRlZCA9IGZhbHNlO1xuICB0aGlzLnRpbWVkb3V0ID0gZmFsc2U7XG4gIHRoaXMudGltZWRvdXRFcnJvciA9IG51bGw7XG5cbiAgcmV0dXJuIHRoaXMuX2VuZCgpO1xufTtcblxuLyoqXG4gKiBQcm9taXNlIHN1cHBvcnRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSByZXNvbHZlXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbcmVqZWN0XVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudGhlbiA9IGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkge1xuICBpZiAoIXRoaXMuX2Z1bGxmaWxsZWRQcm9taXNlKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgaWYgKHRoaXMuX2VuZENhbGxlZCkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnV2FybmluZzogc3VwZXJhZ2VudCByZXF1ZXN0IHdhcyBzZW50IHR3aWNlLCBiZWNhdXNlIGJvdGggLmVuZCgpIGFuZCAudGhlbigpIHdlcmUgY2FsbGVkLiBOZXZlciBjYWxsIC5lbmQoKSBpZiB5b3UgdXNlIHByb21pc2VzJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHNlbGYub24oJ2Fib3J0JywgKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5fbWF4UmV0cmllcyAmJiB0aGlzLl9tYXhSZXRyaWVzID4gdGhpcy5fcmV0cmllcykge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLnRpbWVkb3V0ICYmIHRoaXMudGltZWRvdXRFcnJvcikge1xuICAgICAgICAgIHJlamVjdCh0aGlzLnRpbWVkb3V0RXJyb3IpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGVyciA9IG5ldyBFcnJvcignQWJvcnRlZCcpO1xuICAgICAgICBlcnIuY29kZSA9ICdBQk9SVEVEJztcbiAgICAgICAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICAgICAgICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gICAgICAgIGVyci51cmwgPSB0aGlzLnVybDtcbiAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICB9KTtcbiAgICAgIHNlbGYuZW5kKChlcnIsIHJlcykgPT4ge1xuICAgICAgICBpZiAoZXJyKSByZWplY3QoZXJyKTtcbiAgICAgICAgZWxzZSByZXNvbHZlKHJlcyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZS50aGVuKHJlc29sdmUsIHJlamVjdCk7XG59O1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuY2F0Y2ggPSBmdW5jdGlvbihjYikge1xuICByZXR1cm4gdGhpcy50aGVuKHVuZGVmaW5lZCwgY2IpO1xufTtcblxuLyoqXG4gKiBBbGxvdyBmb3IgZXh0ZW5zaW9uXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnVzZSA9IGZ1bmN0aW9uKGZuKSB7XG4gIGZuKHRoaXMpO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5vayA9IGZ1bmN0aW9uKGNiKSB7XG4gIGlmICh0eXBlb2YgY2IgIT09ICdmdW5jdGlvbicpIHRocm93IG5ldyBFcnJvcignQ2FsbGJhY2sgcmVxdWlyZWQnKTtcbiAgdGhpcy5fb2tDYWxsYmFjayA9IGNiO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5faXNSZXNwb25zZU9LID0gZnVuY3Rpb24ocmVzKSB7XG4gIGlmICghcmVzKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKHRoaXMuX29rQ2FsbGJhY2spIHtcbiAgICByZXR1cm4gdGhpcy5fb2tDYWxsYmFjayhyZXMpO1xuICB9XG5cbiAgcmV0dXJuIHJlcy5zdGF0dXMgPj0gMjAwICYmIHJlcy5zdGF0dXMgPCAzMDA7XG59O1xuXG4vKipcbiAqIEdldCByZXF1ZXN0IGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGRcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLl9oZWFkZXJbZmllbGQudG9Mb3dlckNhc2UoKV07XG59O1xuXG4vKipcbiAqIEdldCBjYXNlLWluc2Vuc2l0aXZlIGhlYWRlciBgZmllbGRgIHZhbHVlLlxuICogVGhpcyBpcyBhIGRlcHJlY2F0ZWQgaW50ZXJuYWwgQVBJLiBVc2UgYC5nZXQoZmllbGQpYCBpbnN0ZWFkLlxuICpcbiAqIChnZXRIZWFkZXIgaXMgbm8gbG9uZ2VyIHVzZWQgaW50ZXJuYWxseSBieSB0aGUgc3VwZXJhZ2VudCBjb2RlIGJhc2UpXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGZpZWxkXG4gKiBAcmV0dXJuIHtTdHJpbmd9XG4gKiBAYXBpIHByaXZhdGVcbiAqIEBkZXByZWNhdGVkXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldEhlYWRlciA9IFJlcXVlc3RCYXNlLnByb3RvdHlwZS5nZXQ7XG5cbi8qKlxuICogU2V0IGhlYWRlciBgZmllbGRgIHRvIGB2YWxgLCBvciBtdWx0aXBsZSBmaWVsZHMgd2l0aCBvbmUgb2JqZWN0LlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoJ0FjY2VwdCcsICdhcHBsaWNhdGlvbi9qc29uJylcbiAqICAgICAgICAuc2V0KCdYLUFQSS1LZXknLCAnZm9vYmFyJylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoeyBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJywgJ1gtQVBJLUtleSc6ICdmb29iYXInIH0pXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd8T2JqZWN0fSBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zZXQgPSBmdW5jdGlvbihmaWVsZCwgdmFsKSB7XG4gIGlmIChpc09iamVjdChmaWVsZCkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBmaWVsZCkge1xuICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChmaWVsZCwga2V5KSlcbiAgICAgICAgdGhpcy5zZXQoa2V5LCBmaWVsZFtrZXldKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRoaXMuX2hlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXSA9IHZhbDtcbiAgdGhpcy5oZWFkZXJbZmllbGRdID0gdmFsO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogUmVtb3ZlIGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlOlxuICpcbiAqICAgICAgcmVxLmdldCgnLycpXG4gKiAgICAgICAgLnVuc2V0KCdVc2VyLUFnZW50JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGQgZmllbGQgbmFtZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudW5zZXQgPSBmdW5jdGlvbihmaWVsZCkge1xuICBkZWxldGUgdGhpcy5faGVhZGVyW2ZpZWxkLnRvTG93ZXJDYXNlKCldO1xuICBkZWxldGUgdGhpcy5oZWFkZXJbZmllbGRdO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogV3JpdGUgdGhlIGZpZWxkIGBuYW1lYCBhbmQgYHZhbGAsIG9yIG11bHRpcGxlIGZpZWxkcyB3aXRoIG9uZSBvYmplY3RcbiAqIGZvciBcIm11bHRpcGFydC9mb3JtLWRhdGFcIiByZXF1ZXN0IGJvZGllcy5cbiAqXG4gKiBgYGAganNcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCgnZm9vJywgJ2JhcicpXG4gKiAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCh7IGZvbzogJ2JhcicsIGJhejogJ3F1eCcgfSlcbiAqICAgLmVuZChjYWxsYmFjayk7XG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ3xPYmplY3R9IG5hbWUgbmFtZSBvZiBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd8QmxvYnxGaWxlfEJ1ZmZlcnxmcy5SZWFkU3RyZWFtfSB2YWwgdmFsdWUgb2YgZmllbGRcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmZpZWxkID0gZnVuY3Rpb24obmFtZSwgdmFsKSB7XG4gIC8vIG5hbWUgc2hvdWxkIGJlIGVpdGhlciBhIHN0cmluZyBvciBhbiBvYmplY3QuXG4gIGlmIChuYW1lID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gbmFtZSkge1xuICAgIHRocm93IG5ldyBFcnJvcignLmZpZWxkKG5hbWUsIHZhbCkgbmFtZSBjYW4gbm90IGJlIGVtcHR5Jyk7XG4gIH1cblxuICBpZiAodGhpcy5fZGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLmZpZWxkKCkgY2FuJ3QgYmUgdXNlZCBpZiAuc2VuZCgpIGlzIHVzZWQuIFBsZWFzZSB1c2Ugb25seSAuc2VuZCgpIG9yIG9ubHkgLmZpZWxkKCkgJiAuYXR0YWNoKClcIlxuICAgICk7XG4gIH1cblxuICBpZiAoaXNPYmplY3QobmFtZSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBuYW1lKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG5hbWUsIGtleSkpXG4gICAgICAgIHRoaXMuZmllbGQoa2V5LCBuYW1lW2tleV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkodmFsKSkge1xuICAgIGZvciAoY29uc3QgaSBpbiB2YWwpIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmFsLCBpKSlcbiAgICAgICAgdGhpcy5maWVsZChuYW1lLCB2YWxbaV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLy8gdmFsIHNob3VsZCBiZSBkZWZpbmVkIG5vd1xuICBpZiAodmFsID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gdmFsKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCcuZmllbGQobmFtZSwgdmFsKSB2YWwgY2FuIG5vdCBiZSBlbXB0eScpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiB2YWwgPT09ICdib29sZWFuJykge1xuICAgIHZhbCA9IFN0cmluZyh2YWwpO1xuICB9XG5cbiAgdGhpcy5fZ2V0Rm9ybURhdGEoKS5hcHBlbmQobmFtZSwgdmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIEFib3J0IHRoZSByZXF1ZXN0LCBhbmQgY2xlYXIgcG90ZW50aWFsIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmFib3J0ID0gZnVuY3Rpb24oKSB7XG4gIGlmICh0aGlzLl9hYm9ydGVkKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICB0aGlzLl9hYm9ydGVkID0gdHJ1ZTtcbiAgaWYgKHRoaXMueGhyKSB0aGlzLnhoci5hYm9ydCgpOyAvLyBicm93c2VyXG4gIGlmICh0aGlzLnJlcSkgdGhpcy5yZXEuYWJvcnQoKTsgLy8gbm9kZVxuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuICB0aGlzLmVtaXQoJ2Fib3J0Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hdXRoID0gZnVuY3Rpb24odXNlciwgcGFzcywgb3B0aW9ucywgYmFzZTY0RW5jb2Rlcikge1xuICBzd2l0Y2ggKG9wdGlvbnMudHlwZSkge1xuICAgIGNhc2UgJ2Jhc2ljJzpcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJhc2ljICR7YmFzZTY0RW5jb2RlcihgJHt1c2VyfToke3Bhc3N9YCl9YCk7XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2F1dG8nOlxuICAgICAgdGhpcy51c2VybmFtZSA9IHVzZXI7XG4gICAgICB0aGlzLnBhc3N3b3JkID0gcGFzcztcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnYmVhcmVyJzogLy8gdXNhZ2Ugd291bGQgYmUgLmF1dGgoYWNjZXNzVG9rZW4sIHsgdHlwZTogJ2JlYXJlcicgfSlcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3VzZXJ9YCk7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgYnJlYWs7XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogRW5hYmxlIHRyYW5zbWlzc2lvbiBvZiBjb29raWVzIHdpdGggeC1kb21haW4gcmVxdWVzdHMuXG4gKlxuICogTm90ZSB0aGF0IGZvciB0aGlzIHRvIHdvcmsgdGhlIG9yaWdpbiBtdXN0IG5vdCBiZVxuICogdXNpbmcgXCJBY2Nlc3MtQ29udHJvbC1BbGxvdy1PcmlnaW5cIiB3aXRoIGEgd2lsZGNhcmQsXG4gKiBhbmQgYWxzbyBtdXN0IHNldCBcIkFjY2Vzcy1Db250cm9sLUFsbG93LUNyZWRlbnRpYWxzXCJcbiAqIHRvIFwidHJ1ZVwiLlxuICpcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLndpdGhDcmVkZW50aWFscyA9IGZ1bmN0aW9uKG9uKSB7XG4gIC8vIFRoaXMgaXMgYnJvd3Nlci1vbmx5IGZ1bmN0aW9uYWxpdHkuIE5vZGUgc2lkZSBpcyBuby1vcC5cbiAgaWYgKG9uID09PSB1bmRlZmluZWQpIG9uID0gdHJ1ZTtcbiAgdGhpcy5fd2l0aENyZWRlbnRpYWxzID0gb247XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgdGhlIG1heCByZWRpcmVjdHMgdG8gYG5gLiBEb2VzIG5vdGhpbmcgaW4gYnJvd3NlciBYSFIgaW1wbGVtZW50YXRpb24uXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IG5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVkaXJlY3RzID0gZnVuY3Rpb24obikge1xuICB0aGlzLl9tYXhSZWRpcmVjdHMgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogTWF4aW11bSBzaXplIG9mIGJ1ZmZlcmVkIHJlc3BvbnNlIGJvZHksIGluIGJ5dGVzLiBDb3VudHMgdW5jb21wcmVzc2VkIHNpemUuXG4gKiBEZWZhdWx0IDIwME1CLlxuICpcbiAqIEBwYXJhbSB7TnVtYmVyfSBuIG51bWJlciBvZiBieXRlc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKi9cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5tYXhSZXNwb25zZVNpemUgPSBmdW5jdGlvbihuKSB7XG4gIGlmICh0eXBlb2YgbiAhPT0gJ251bWJlcicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdJbnZhbGlkIGFyZ3VtZW50Jyk7XG4gIH1cblxuICB0aGlzLl9tYXhSZXNwb25zZVNpemUgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29udmVydCB0byBhIHBsYWluIGphdmFzY3JpcHQgb2JqZWN0IChub3QgSlNPTiBzdHJpbmcpIG9mIHNjYWxhciBwcm9wZXJ0aWVzLlxuICogTm90ZSBhcyB0aGlzIG1ldGhvZCBpcyBkZXNpZ25lZCB0byByZXR1cm4gYSB1c2VmdWwgbm9uLXRoaXMgdmFsdWUsXG4gKiBpdCBjYW5ub3QgYmUgY2hhaW5lZC5cbiAqXG4gKiBAcmV0dXJuIHtPYmplY3R9IGRlc2NyaWJpbmcgbWV0aG9kLCB1cmwsIGFuZCBkYXRhIG9mIHRoaXMgcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudG9KU09OID0gZnVuY3Rpb24oKSB7XG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiB0aGlzLm1ldGhvZCxcbiAgICB1cmw6IHRoaXMudXJsLFxuICAgIGRhdGE6IHRoaXMuX2RhdGEsXG4gICAgaGVhZGVyczogdGhpcy5faGVhZGVyXG4gIH07XG59O1xuXG4vKipcbiAqIFNlbmQgYGRhdGFgIGFzIHRoZSByZXF1ZXN0IGJvZHksIGRlZmF1bHRpbmcgdGhlIGAudHlwZSgpYCB0byBcImpzb25cIiB3aGVuXG4gKiBhbiBvYmplY3QgaXMgZ2l2ZW4uXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICAgICAgLy8gbWFudWFsIGpzb25cbiAqICAgICAgIHJlcXVlc3QucG9zdCgnL3VzZXInKVxuICogICAgICAgICAudHlwZSgnanNvbicpXG4gKiAgICAgICAgIC5zZW5kKCd7XCJuYW1lXCI6XCJ0alwifScpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gYXV0byBqc29uXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gbWFudWFsIHgtd3d3LWZvcm0tdXJsZW5jb2RlZFxuICogICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgIC50eXBlKCdmb3JtJylcbiAqICAgICAgICAgLnNlbmQoJ25hbWU9dGonKVxuICogICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqICAgICAgIC8vIGF1dG8geC13d3ctZm9ybS11cmxlbmNvZGVkXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnR5cGUoJ2Zvcm0nKVxuICogICAgICAgICAuc2VuZCh7IG5hbWU6ICd0aicgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0cyB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoJ25hbWU9dG9iaScpXG4gKiAgICAgICAgLnNlbmQoJ3NwZWNpZXM9ZmVycmV0JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gZGF0YVxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VuZCA9IGZ1bmN0aW9uKGRhdGEpIHtcbiAgY29uc3QgaXNPYmogPSBpc09iamVjdChkYXRhKTtcbiAgbGV0IHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuXG4gIGlmICh0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLnNlbmQoKSBjYW4ndCBiZSB1c2VkIGlmIC5hdHRhY2goKSBvciAuZmllbGQoKSBpcyB1c2VkLiBQbGVhc2UgdXNlIG9ubHkgLnNlbmQoKSBvciBvbmx5IC5maWVsZCgpICYgLmF0dGFjaCgpXCJcbiAgICApO1xuICB9XG5cbiAgaWYgKGlzT2JqICYmICF0aGlzLl9kYXRhKSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSBbXTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLl9pc0hvc3QoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSB7fTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoZGF0YSAmJiB0aGlzLl9kYXRhICYmIHRoaXMuX2lzSG9zdCh0aGlzLl9kYXRhKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIkNhbid0IG1lcmdlIHRoZXNlIHNlbmQgY2FsbHNcIik7XG4gIH1cblxuICAvLyBtZXJnZVxuICBpZiAoaXNPYmogJiYgaXNPYmplY3QodGhpcy5fZGF0YSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGRhdGEsIGtleSkpXG4gICAgICAgIHRoaXMuX2RhdGFba2V5XSA9IGRhdGFba2V5XTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodHlwZW9mIGRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgLy8gZGVmYXVsdCB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAgICBpZiAoIXR5cGUpIHRoaXMudHlwZSgnZm9ybScpO1xuICAgIHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGlmICh0eXBlID09PSAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJykge1xuICAgICAgdGhpcy5fZGF0YSA9IHRoaXMuX2RhdGEgPyBgJHt0aGlzLl9kYXRhfSYke2RhdGF9YCA6IGRhdGE7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2RhdGEgPSAodGhpcy5fZGF0YSB8fCAnJykgKyBkYXRhO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICB0aGlzLl9kYXRhID0gZGF0YTtcbiAgfVxuXG4gIGlmICghaXNPYmogfHwgdGhpcy5faXNIb3N0KGRhdGEpKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvLyBkZWZhdWx0IHRvIGpzb25cbiAgaWYgKCF0eXBlKSB0aGlzLnR5cGUoJ2pzb24nKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNvcnQgYHF1ZXJ5c3RyaW5nYCBieSB0aGUgc29ydCBmdW5jdGlvblxuICpcbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0IG9yZGVyXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeSgpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gY3VzdG9taXplZCBzb3J0IGZ1bmN0aW9uXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeShmdW5jdGlvbihhLCBiKXtcbiAqICAgICAgICAgICByZXR1cm4gYS5sZW5ndGggLSBiLmxlbmd0aDtcbiAqICAgICAgICAgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gc29ydFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zb3J0UXVlcnkgPSBmdW5jdGlvbihzb3J0KSB7XG4gIC8vIF9zb3J0IGRlZmF1bHQgdG8gdHJ1ZSBidXQgb3RoZXJ3aXNlIGNhbiBiZSBhIGZ1bmN0aW9uIG9yIGJvb2xlYW5cbiAgdGhpcy5fc29ydCA9IHR5cGVvZiBzb3J0ID09PSAndW5kZWZpbmVkJyA/IHRydWUgOiBzb3J0O1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29tcG9zZSBxdWVyeXN0cmluZyB0byBhcHBlbmQgdG8gcmVxLnVybFxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuX2ZpbmFsaXplUXVlcnlTdHJpbmcgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgcXVlcnkgPSB0aGlzLl9xdWVyeS5qb2luKCcmJyk7XG4gIGlmIChxdWVyeSkge1xuICAgIHRoaXMudXJsICs9ICh0aGlzLnVybC5pbmNsdWRlcygnPycpID8gJyYnIDogJz8nKSArIHF1ZXJ5O1xuICB9XG5cbiAgdGhpcy5fcXVlcnkubGVuZ3RoID0gMDsgLy8gTWFrZXMgdGhlIGNhbGwgaWRlbXBvdGVudFxuXG4gIGlmICh0aGlzLl9zb3J0KSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLnVybC5pbmRleE9mKCc/Jyk7XG4gICAgaWYgKGluZGV4ID49IDApIHtcbiAgICAgIGNvbnN0IHF1ZXJ5QXJyID0gdGhpcy51cmwuc2xpY2UoaW5kZXggKyAxKS5zcGxpdCgnJicpO1xuICAgICAgaWYgKHR5cGVvZiB0aGlzLl9zb3J0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHF1ZXJ5QXJyLnNvcnQodGhpcy5fc29ydCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBxdWVyeUFyci5zb3J0KCk7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudXJsID0gdGhpcy51cmwuc2xpY2UoMCwgaW5kZXgpICsgJz8nICsgcXVlcnlBcnIuam9pbignJicpO1xuICAgIH1cbiAgfVxufTtcblxuLy8gRm9yIGJhY2t3YXJkcyBjb21wYXQgb25seVxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hcHBlbmRRdWVyeVN0cmluZyA9ICgpID0+IHtcbiAgY29uc29sZS53YXJuKCdVbnN1cHBvcnRlZCcpO1xufTtcblxuLyoqXG4gKiBJbnZva2UgY2FsbGJhY2sgd2l0aCB0aW1lb3V0IGVycm9yLlxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fdGltZW91dEVycm9yID0gZnVuY3Rpb24ocmVhc29uLCB0aW1lb3V0LCBlcnJubykge1xuICBpZiAodGhpcy5fYWJvcnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGVyciA9IG5ldyBFcnJvcihgJHtyZWFzb24gKyB0aW1lb3V0fW1zIGV4Y2VlZGVkYCk7XG4gIGVyci50aW1lb3V0ID0gdGltZW91dDtcbiAgZXJyLmNvZGUgPSAnRUNPTk5BQk9SVEVEJztcbiAgZXJyLmVycm5vID0gZXJybm87XG4gIHRoaXMudGltZWRvdXQgPSB0cnVlO1xuICB0aGlzLnRpbWVkb3V0RXJyb3IgPSBlcnI7XG4gIHRoaXMuYWJvcnQoKTtcbiAgdGhpcy5jYWxsYmFjayhlcnIpO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zZXRUaW1lb3V0cyA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBzZWxmID0gdGhpcztcblxuICAvLyBkZWFkbGluZVxuICBpZiAodGhpcy5fdGltZW91dCAmJiAhdGhpcy5fdGltZXIpIHtcbiAgICB0aGlzLl90aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2VsZi5fdGltZW91dEVycm9yKCdUaW1lb3V0IG9mICcsIHNlbGYuX3RpbWVvdXQsICdFVElNRScpO1xuICAgIH0sIHRoaXMuX3RpbWVvdXQpO1xuICB9XG5cbiAgLy8gcmVzcG9uc2UgdGltZW91dFxuICBpZiAodGhpcy5fcmVzcG9uc2VUaW1lb3V0ICYmICF0aGlzLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZWxmLl90aW1lb3V0RXJyb3IoXG4gICAgICAgICdSZXNwb25zZSB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3Jlc3BvbnNlVGltZW91dCxcbiAgICAgICAgJ0VUSU1FRE9VVCdcbiAgICAgICk7XG4gICAgfSwgdGhpcy5fcmVzcG9uc2VUaW1lb3V0KTtcbiAgfVxufTtcbiJdfQ==","\"use strict\";\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\nexports.type = function (str) {\n return str.split(/ *; */).shift();\n};\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.params = function (str) {\n return str.split(/ *; */).reduce(function (obj, str) {\n var parts = str.split(/ *= */);\n var key = parts.shift();\n var val = parts.shift();\n if (key && val) obj[key] = val;\n return obj;\n }, {});\n};\n/**\n * Parse Link header fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.parseLinks = function (str) {\n return str.split(/ *, */).reduce(function (obj, str) {\n var parts = str.split(/ *; */);\n var url = parts[0].slice(1, -1);\n var rel = parts[1].split(/ *= */)[1].slice(1, -1);\n obj[rel] = url;\n return obj;\n }, {});\n};\n/**\n * Strip content related fields from `header`.\n *\n * @param {Object} header\n * @return {Object} header\n * @api private\n */\n\n\nexports.cleanHeader = function (header, changesOrigin) {\n delete header['content-type'];\n delete header['content-length'];\n delete header['transfer-encoding'];\n delete header.host; // secuirty\n\n if (changesOrigin) {\n delete header.authorization;\n delete header.cookie;\n }\n\n return header;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJleHBvcnRzIiwidHlwZSIsInN0ciIsInNwbGl0Iiwic2hpZnQiLCJwYXJhbXMiLCJyZWR1Y2UiLCJvYmoiLCJwYXJ0cyIsImtleSIsInZhbCIsInBhcnNlTGlua3MiLCJ1cmwiLCJzbGljZSIsInJlbCIsImNsZWFuSGVhZGVyIiwiaGVhZGVyIiwiY2hhbmdlc09yaWdpbiIsImhvc3QiLCJhdXRob3JpemF0aW9uIiwiY29va2llIl0sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7O0FBUUFBLE9BQU8sQ0FBQ0MsSUFBUixHQUFlLFVBQUFDLEdBQUc7QUFBQSxTQUFJQSxHQUFHLENBQUNDLEtBQUosQ0FBVSxPQUFWLEVBQW1CQyxLQUFuQixFQUFKO0FBQUEsQ0FBbEI7QUFFQTs7Ozs7Ozs7O0FBUUFKLE9BQU8sQ0FBQ0ssTUFBUixHQUFpQixVQUFBSCxHQUFHO0FBQUEsU0FDbEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTU0sR0FBRyxHQUFHRCxLQUFLLENBQUNKLEtBQU4sRUFBWjtBQUNBLFFBQU1NLEdBQUcsR0FBR0YsS0FBSyxDQUFDSixLQUFOLEVBQVo7QUFFQSxRQUFJSyxHQUFHLElBQUlDLEdBQVgsRUFBZ0JILEdBQUcsQ0FBQ0UsR0FBRCxDQUFILEdBQVdDLEdBQVg7QUFDaEIsV0FBT0gsR0FBUDtBQUNELEdBUEQsRUFPRyxFQVBILENBRGtCO0FBQUEsQ0FBcEI7QUFVQTs7Ozs7Ozs7O0FBUUFQLE9BQU8sQ0FBQ1csVUFBUixHQUFxQixVQUFBVCxHQUFHO0FBQUEsU0FDdEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTVMsR0FBRyxHQUFHSixLQUFLLENBQUMsQ0FBRCxDQUFMLENBQVNLLEtBQVQsQ0FBZSxDQUFmLEVBQWtCLENBQUMsQ0FBbkIsQ0FBWjtBQUNBLFFBQU1DLEdBQUcsR0FBR04sS0FBSyxDQUFDLENBQUQsQ0FBTCxDQUFTTCxLQUFULENBQWUsT0FBZixFQUF3QixDQUF4QixFQUEyQlUsS0FBM0IsQ0FBaUMsQ0FBakMsRUFBb0MsQ0FBQyxDQUFyQyxDQUFaO0FBQ0FOLElBQUFBLEdBQUcsQ0FBQ08sR0FBRCxDQUFILEdBQVdGLEdBQVg7QUFDQSxXQUFPTCxHQUFQO0FBQ0QsR0FORCxFQU1HLEVBTkgsQ0FEc0I7QUFBQSxDQUF4QjtBQVNBOzs7Ozs7Ozs7QUFRQVAsT0FBTyxDQUFDZSxXQUFSLEdBQXNCLFVBQUNDLE1BQUQsRUFBU0MsYUFBVCxFQUEyQjtBQUMvQyxTQUFPRCxNQUFNLENBQUMsY0FBRCxDQUFiO0FBQ0EsU0FBT0EsTUFBTSxDQUFDLGdCQUFELENBQWI7QUFDQSxTQUFPQSxNQUFNLENBQUMsbUJBQUQsQ0FBYjtBQUNBLFNBQU9BLE1BQU0sQ0FBQ0UsSUFBZCxDQUorQyxDQUsvQzs7QUFDQSxNQUFJRCxhQUFKLEVBQW1CO0FBQ2pCLFdBQU9ELE1BQU0sQ0FBQ0csYUFBZDtBQUNBLFdBQU9ILE1BQU0sQ0FBQ0ksTUFBZDtBQUNEOztBQUVELFNBQU9KLE1BQVA7QUFDRCxDQVpEIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXR1cm4gdGhlIG1pbWUgdHlwZSBmb3IgdGhlIGdpdmVuIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMudHlwZSA9IHN0ciA9PiBzdHIuc3BsaXQoLyAqOyAqLykuc2hpZnQoKTtcblxuLyoqXG4gKiBSZXR1cm4gaGVhZGVyIGZpZWxkIHBhcmFtZXRlcnMuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHN0clxuICogQHJldHVybiB7T2JqZWN0fVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZXhwb3J0cy5wYXJhbXMgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKjsgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo9ICovKTtcbiAgICBjb25zdCBrZXkgPSBwYXJ0cy5zaGlmdCgpO1xuICAgIGNvbnN0IHZhbCA9IHBhcnRzLnNoaWZ0KCk7XG5cbiAgICBpZiAoa2V5ICYmIHZhbCkgb2JqW2tleV0gPSB2YWw7XG4gICAgcmV0dXJuIG9iajtcbiAgfSwge30pO1xuXG4vKipcbiAqIFBhcnNlIExpbmsgaGVhZGVyIGZpZWxkcy5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5leHBvcnRzLnBhcnNlTGlua3MgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKiwgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo7ICovKTtcbiAgICBjb25zdCB1cmwgPSBwYXJ0c1swXS5zbGljZSgxLCAtMSk7XG4gICAgY29uc3QgcmVsID0gcGFydHNbMV0uc3BsaXQoLyAqPSAqLylbMV0uc2xpY2UoMSwgLTEpO1xuICAgIG9ialtyZWxdID0gdXJsO1xuICAgIHJldHVybiBvYmo7XG4gIH0sIHt9KTtcblxuLyoqXG4gKiBTdHJpcCBjb250ZW50IHJlbGF0ZWQgZmllbGRzIGZyb20gYGhlYWRlcmAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IGhlYWRlclxuICogQHJldHVybiB7T2JqZWN0fSBoZWFkZXJcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMuY2xlYW5IZWFkZXIgPSAoaGVhZGVyLCBjaGFuZ2VzT3JpZ2luKSA9PiB7XG4gIGRlbGV0ZSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICBkZWxldGUgaGVhZGVyWydjb250ZW50LWxlbmd0aCddO1xuICBkZWxldGUgaGVhZGVyWyd0cmFuc2Zlci1lbmNvZGluZyddO1xuICBkZWxldGUgaGVhZGVyLmhvc3Q7XG4gIC8vIHNlY3VpcnR5XG4gIGlmIChjaGFuZ2VzT3JpZ2luKSB7XG4gICAgZGVsZXRlIGhlYWRlci5hdXRob3JpemF0aW9uO1xuICAgIGRlbGV0ZSBoZWFkZXIuY29va2llO1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcjtcbn07XG4iXX0=","\"use strict\";\n\n/**\n * Module dependencies.\n */\nvar utils = require('./utils');\n/**\n * Expose `ResponseBase`.\n */\n\n\nmodule.exports = ResponseBase;\n/**\n * Initialize a new `ResponseBase`.\n *\n * @api public\n */\n\nfunction ResponseBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in ResponseBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nResponseBase.prototype.get = function (field) {\n return this.header[field.toLowerCase()];\n};\n/**\n * Set header related properties:\n *\n * - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\n\nResponseBase.prototype._setHeaderProperties = function (header) {\n // TODO: moar!\n // TODO: make this a util\n // content-type\n var ct = header['content-type'] || '';\n this.type = utils.type(ct); // params\n\n var params = utils.params(ct);\n\n for (var key in params) {\n if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key];\n }\n\n this.links = {}; // links\n\n try {\n if (header.link) {\n this.links = utils.parseLinks(header.link);\n }\n } catch (_unused) {// ignore\n }\n};\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n * - .noContent\n * - .badRequest\n * - .unauthorized\n * - .notAcceptable\n * - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\n\nResponseBase.prototype._setStatusProperties = function (status) {\n var type = status / 100 | 0; // status / class\n\n this.statusCode = status;\n this.status = this.statusCode;\n this.statusType = type; // basics\n\n this.info = type === 1;\n this.ok = type === 2;\n this.redirect = type === 3;\n this.clientError = type === 4;\n this.serverError = type === 5;\n this.error = type === 4 || type === 5 ? this.toError() : false; // sugar\n\n this.created = status === 201;\n this.accepted = status === 202;\n this.noContent = status === 204;\n this.badRequest = status === 400;\n this.unauthorized = status === 401;\n this.notAcceptable = status === 406;\n this.forbidden = status === 403;\n this.notFound = status === 404;\n this.unprocessableEntity = status === 422;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS1iYXNlLmpzIl0sIm5hbWVzIjpbInV0aWxzIiwicmVxdWlyZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJSZXNwb25zZUJhc2UiLCJvYmoiLCJtaXhpbiIsImtleSIsInByb3RvdHlwZSIsIk9iamVjdCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImdldCIsImZpZWxkIiwiaGVhZGVyIiwidG9Mb3dlckNhc2UiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsImN0IiwidHlwZSIsInBhcmFtcyIsImxpbmtzIiwibGluayIsInBhcnNlTGlua3MiLCJfc2V0U3RhdHVzUHJvcGVydGllcyIsInN0YXR1cyIsInN0YXR1c0NvZGUiLCJzdGF0dXNUeXBlIiwiaW5mbyIsIm9rIiwicmVkaXJlY3QiLCJjbGllbnRFcnJvciIsInNlcnZlckVycm9yIiwiZXJyb3IiLCJ0b0Vycm9yIiwiY3JlYXRlZCIsImFjY2VwdGVkIiwibm9Db250ZW50IiwiYmFkUmVxdWVzdCIsInVuYXV0aG9yaXplZCIsIm5vdEFjY2VwdGFibGUiLCJmb3JiaWRkZW4iLCJub3RGb3VuZCIsInVucHJvY2Vzc2FibGVFbnRpdHkiXSwibWFwcGluZ3MiOiI7O0FBQUE7OztBQUlBLElBQU1BLEtBQUssR0FBR0MsT0FBTyxDQUFDLFNBQUQsQ0FBckI7QUFFQTs7Ozs7QUFJQUMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCQyxZQUFqQjtBQUVBOzs7Ozs7QUFNQSxTQUFTQSxZQUFULENBQXNCQyxHQUF0QixFQUEyQjtBQUN6QixNQUFJQSxHQUFKLEVBQVMsT0FBT0MsS0FBSyxDQUFDRCxHQUFELENBQVo7QUFDVjtBQUVEOzs7Ozs7Ozs7QUFRQSxTQUFTQyxLQUFULENBQWVELEdBQWYsRUFBb0I7QUFDbEIsT0FBSyxJQUFNRSxHQUFYLElBQWtCSCxZQUFZLENBQUNJLFNBQS9CLEVBQTBDO0FBQ3hDLFFBQUlDLE1BQU0sQ0FBQ0QsU0FBUCxDQUFpQkUsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFD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LEdBQTJCbEIsTUFBTSxLQUFLLEdBQXRDO0FBQ0QsQ0ExQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1vZHVsZSBkZXBlbmRlbmNpZXMuXG4gKi9cblxuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzJyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXNwb25zZUJhc2VgLlxuICovXG5cbm1vZHVsZS5leHBvcnRzID0gUmVzcG9uc2VCYXNlO1xuXG4vKipcbiAqIEluaXRpYWxpemUgYSBuZXcgYFJlc3BvbnNlQmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXNwb25zZUJhc2Uob2JqKSB7XG4gIGlmIChvYmopIHJldHVybiBtaXhpbihvYmopO1xufVxuXG4vKipcbiAqIE1peGluIHRoZSBwcm90b3R5cGUgcHJvcGVydGllcy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBtaXhpbihvYmopIHtcbiAgZm9yIChjb25zdCBrZXkgaW4gUmVzcG9uc2VCYXNlLnByb3RvdHlwZSkge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoUmVzcG9uc2VCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVzcG9uc2VCYXNlLnByb3RvdHlwZVtrZXldO1xuICB9XG5cbiAgcmV0dXJuIG9iajtcbn1cblxuLyoqXG4gKiBHZXQgY2FzZS1pbnNlbnNpdGl2ZSBgZmllbGRgIHZhbHVlLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLmhlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXTtcbn07XG5cbi8qKlxuICogU2V0IGhlYWRlciByZWxhdGVkIHByb3BlcnRpZXM6XG4gKlxuICogICAtIGAudHlwZWAgdGhlIGNvbnRlbnQgdHlwZSB3aXRob3V0IHBhcmFtc1xuICpcbiAqIEEgcmVzcG9uc2Ugb2YgXCJDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9dXRmLThcIlxuICogd2lsbCBwcm92aWRlIHlvdSB3aXRoIGEgYC50eXBlYCBvZiBcInRleHQvcGxhaW5cIi5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gaGVhZGVyXG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLl9zZXRIZWFkZXJQcm9wZXJ0aWVzID0gZnVuY3Rpb24oaGVhZGVyKSB7XG4gIC8vIFRPRE86IG1vYXIhXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIHV0aWxcblxuICAvLyBjb250ZW50LXR5cGVcbiAgY29uc3QgY3QgPSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddIHx8ICcnO1xuICB0aGlzLnR5cGUgPSB1dGlscy50eXBlKGN0KTtcblxuICAvLyBwYXJhbXNcbiAgY29uc3QgcGFyYW1zID0gdXRpbHMucGFyYW1zKGN0KTtcbiAgZm9yIChjb25zdCBrZXkgaW4gcGFyYW1zKSB7XG4gICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChwYXJhbXMsIGtleSkpXG4gICAgICB0aGlzW2tleV0gPSBwYXJhbXNba2V5XTtcbiAgfVxuXG4gIHRoaXMubGlua3MgPSB7fTtcblxuICAvLyBsaW5rc1xuICB0cnkge1xuICAgIGlmIChoZWFkZXIubGluaykge1xuICAgICAgdGhpcy5saW5rcyA9IHV0aWxzLnBhcnNlTGlua3MoaGVhZGVyLmxpbmspO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlXG4gIH1cbn07XG5cbi8qKlxuICogU2V0IGZsYWdzIHN1Y2ggYXMgYC5va2AgYmFzZWQgb24gYHN0YXR1c2AuXG4gKlxuICogRm9yIGV4YW1wbGUgYSAyeHggcmVzcG9uc2Ugd2lsbCBnaXZlIHlvdSBhIGAub2tgIG9mIF9fdHJ1ZV9fXG4gKiB3aGVyZWFzIDV4eCB3aWxsIGJlIF9fZmFsc2VfXyBhbmQgYC5lcnJvcmAgd2lsbCBiZSBfX3RydWVfXy4gVGhlXG4gKiBgLmNsaWVudEVycm9yYCBhbmQgYC5zZXJ2ZXJFcnJvcmAgYXJlIGFsc28gYXZhaWxhYmxlIHRvIGJlIG1vcmVcbiAqIHNwZWNpZmljLCBhbmQgYC5zdGF0dXNUeXBlYCBpcyB0aGUgY2xhc3Mgb2YgZXJyb3IgcmFuZ2luZyBmcm9tIDEuLjVcbiAqIHNvbWV0aW1lcyB1c2VmdWwgZm9yIG1hcHBpbmcgcmVzcG9uZCBjb2xvcnMgZXRjLlxuICpcbiAqIFwic3VnYXJcIiBwcm9wZXJ0aWVzIGFyZSBhbHNvIGRlZmluZWQgZm9yIGNvbW1vbiBjYXNlcy4gQ3VycmVudGx5IHByb3ZpZGluZzpcbiAqXG4gKiAgIC0gLm5vQ29udGVudFxuICogICAtIC5iYWRSZXF1ZXN0XG4gKiAgIC0gLnVuYXV0aG9yaXplZFxuICogICAtIC5ub3RBY2NlcHRhYmxlXG4gKiAgIC0gLm5vdEZvdW5kXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IHN0YXR1c1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVzcG9uc2VCYXNlLnByb3RvdHlwZS5fc2V0U3RhdHVzUHJvcGVydGllcyA9IGZ1bmN0aW9uKHN0YXR1cykge1xuICBjb25zdCB0eXBlID0gKHN0YXR1cyAvIDEwMCkgfCAwO1xuXG4gIC8vIHN0YXR1cyAvIGNsYXNzXG4gIHRoaXMuc3RhdHVzQ29kZSA9IHN0YXR1cztcbiAgdGhpcy5zdGF0dXMgPSB0aGlzLnN0YXR1c0NvZGU7XG4gIHRoaXMuc3RhdHVzVHlwZSA9IHR5cGU7XG5cbiAgLy8gYmFzaWNzXG4gIHRoaXMuaW5mbyA9IHR5cGUgPT09IDE7XG4gIHRoaXMub2sgPSB0eXBlID09PSAyO1xuICB0aGlzLnJlZGlyZWN0ID0gdHlwZSA9PT0gMztcbiAgdGhpcy5jbGllbnRFcnJvciA9IHR5cGUgPT09IDQ7XG4gIHRoaXMuc2VydmVyRXJyb3IgPSB0eXBlID09PSA1O1xuICB0aGlzLmVycm9yID0gdHlwZSA9PT0gNCB8fCB0eXBlID09PSA1ID8gdGhpcy50b0Vycm9yKCkgOiBmYWxzZTtcblxuICAvLyBzdWdhclxuICB0aGlzLmNyZWF0ZWQgPSBzdGF0dXMgPT09IDIwMTtcbiAgdGhpcy5hY2NlcHRlZCA9IHN0YXR1cyA9PT0gMjAyO1xuICB0aGlzLm5vQ29udGVudCA9IHN0YXR1cyA9PT0gMjA0O1xuICB0aGlzLmJhZFJlcXVlc3QgPSBzdGF0dXMgPT09IDQwMDtcbiAgdGhpcy51bmF1dGhvcml6ZWQgPSBzdGF0dXMgPT09IDQwMTtcbiAgdGhpcy5ub3RBY2NlcHRhYmxlID0gc3RhdHVzID09PSA0MDY7XG4gIHRoaXMuZm9yYmlkZGVuID0gc3RhdHVzID09PSA0MDM7XG4gIHRoaXMubm90Rm91bmQgPSBzdGF0dXMgPT09IDQwNDtcbiAgdGhpcy51bnByb2Nlc3NhYmxlRW50aXR5ID0gc3RhdHVzID09PSA0MjI7XG59O1xuIl19","\"use strict\";\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction Agent() {\n this._defaults = [];\n}\n\n['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) {\n // Default setting for all requests from this agent\n Agent.prototype[fn] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this._defaults.push({\n fn: fn,\n args: args\n });\n\n return this;\n };\n});\n\nAgent.prototype._setDefaults = function (req) {\n this._defaults.forEach(function (def) {\n req[def.fn].apply(req, _toConsumableArray(def.args));\n });\n};\n\nmodule.exports = Agent;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hZ2VudC1iYXNlLmpzIl0sIm5hbWVzIjpbIkFnZW50IiwiX2RlZmF1bHRzIiwiZm9yRWFjaCIsImZuIiwicHJvdG90eXBlIiwiYXJncyIsInB1c2giLCJfc2V0RGVmYXVsdHMiLCJyZXEiLCJkZWYiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7OztBQUFBLFNBQVNBLEtBQVQsR0FBaUI7QUFDZixPQUFLQyxTQUFMLEdBQWlCLEVBQWpCO0FBQ0Q7O0FBRUQsQ0FDRSxLQURGLEVBRUUsSUFGRixFQUdFLE1BSEYsRUFJRSxLQUpGLEVBS0UsT0FMRixFQU1FLE1BTkYsRUFPRSxRQVBGLEVBUUUsTUFSRixFQVNFLGlCQVRGLEVBVUUsV0FWRixFQVdFLE9BWEYsRUFZRSxJQVpGLEVBYUUsV0FiRixFQWNFLFNBZEYsRUFlRSxRQWZGLEVBZ0JFLFdBaEJGLEVBaUJFLE9BakJGLEVBa0JFLElBbEJGLEVBbUJFLEtBbkJGLEVBb0JFLEtBcEJGLEVBcUJFLE1BckJGLEVBc0JFLGlCQXRCRixFQXVCRUMsT0F2QkYsQ0F1QlUsVUFBQUMsRUFBRSxFQUFJO0FBQ2Q7QUFDQUgsRUFBQUEsS0FBSyxDQUFDSSxTQUFOLENBQWdCRCxFQUFoQixJQUFzQixZQUFrQjtBQUFBLHNDQUFORSxJQUFNO0FBQU5BLE1BQUFBLElBQU07QUFBQTs7QUFDdEMsU0FBS0osU0FBTCxDQUFlSyxJQUFmLENBQW9CO0FBQUVILE1BQUFBLEVBQUUsRUFBRkEsRUFBRjtBQUFNRSxNQUFBQSxJQUFJLEVBQUpBO0FBQU4sS0FBcEI7O0FBQ0EsV0FBTyxJQUFQO0FBQ0QsR0FIRDtBQUlELENBN0JEOztBQStCQUwsS0FBSyxDQUFDSSxTQUFOLENBQWdCRyxZQUFoQixHQUErQixVQUFTQyxHQUFULEVBQWM7QUFDM0MsT0FBS1AsU0FBTCxDQUFlQyxPQUFmLENBQXVCLFVBQUFPLEdBQUcsRUFBSTtBQUM1QkQsSUFBQUEsR0FBRyxDQUFDQyxHQUFHLENBQUNOLEVBQUwsQ0FBSCxPQUFBSyxHQUFHLHFCQUFZQyxHQUFHLENBQUNKLElBQWhCLEVBQUg7QUFDRCxHQUZEO0FBR0QsQ0FKRDs7QUFNQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxLQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIEFnZW50KCkge1xuICB0aGlzLl9kZWZhdWx0cyA9IFtdO1xufVxuXG5bXG4gICd1c2UnLFxuICAnb24nLFxuICAnb25jZScsXG4gICdzZXQnLFxuICAncXVlcnknLFxuICAndHlwZScsXG4gICdhY2NlcHQnLFxuICAnYXV0aCcsXG4gICd3aXRoQ3JlZGVudGlhbHMnLFxuICAnc29ydFF1ZXJ5JyxcbiAgJ3JldHJ5JyxcbiAgJ29rJyxcbiAgJ3JlZGlyZWN0cycsXG4gICd0aW1lb3V0JyxcbiAgJ2J1ZmZlcicsXG4gICdzZXJpYWxpemUnLFxuICAncGFyc2UnLFxuICAnY2EnLFxuICAna2V5JyxcbiAgJ3BmeCcsXG4gICdjZXJ0JyxcbiAgJ2Rpc2FibGVUTFNDZXJ0cydcbl0uZm9yRWFjaChmbiA9PiB7XG4gIC8vIERlZmF1bHQgc2V0dGluZyBmb3IgYWxsIHJlcXVlc3RzIGZyb20gdGhpcyBhZ2VudFxuICBBZ2VudC5wcm90b3R5cGVbZm5dID0gZnVuY3Rpb24oLi4uYXJncykge1xuICAgIHRoaXMuX2RlZmF1bHRzLnB1c2goeyBmbiwgYXJncyB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbn0pO1xuXG5BZ2VudC5wcm90b3R5cGUuX3NldERlZmF1bHRzID0gZnVuY3Rpb24ocmVxKSB7XG4gIHRoaXMuX2RlZmF1bHRzLmZvckVhY2goZGVmID0+IHtcbiAgICByZXFbZGVmLmZuXSguLi5kZWYuYXJncyk7XG4gIH0pO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSBBZ2VudDtcbiJdfQ==","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Root reference for iframes.\n */\nvar root;\n\nif (typeof window !== 'undefined') {\n // Browser window\n root = window;\n} else if (typeof self === 'undefined') {\n // Other environments\n console.warn('Using browser-only version of superagent in non-browser environment');\n root = void 0;\n} else {\n // Web Worker\n root = self;\n}\n\nvar Emitter = require('component-emitter');\n\nvar safeStringify = require('fast-safe-stringify');\n\nvar RequestBase = require('./request-base');\n\nvar isObject = require('./is-object');\n\nvar ResponseBase = require('./response-base');\n\nvar Agent = require('./agent-base');\n/**\n * Noop.\n */\n\n\nfunction noop() {}\n/**\n * Expose `request`.\n */\n\n\nmodule.exports = function (method, url) {\n // callback\n if (typeof url === 'function') {\n return new exports.Request('GET', method).end(url);\n } // url first\n\n\n if (arguments.length === 1) {\n return new exports.Request('GET', method);\n }\n\n return new exports.Request(method, url);\n};\n\nexports = module.exports;\nvar request = exports;\nexports.Request = Request;\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) {\n return new XMLHttpRequest();\n }\n\n try {\n return new ActiveXObject('Microsoft.XMLHTTP');\n } catch (_unused) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.6.0');\n } catch (_unused2) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.3.0');\n } catch (_unused3) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP');\n } catch (_unused4) {}\n\n throw new Error('Browser-only version of superagent could not find XHR');\n};\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\n\nvar trim = ''.trim ? function (s) {\n return s.trim();\n} : function (s) {\n return s.replace(/(^\\s*|\\s*$)/g, '');\n};\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n if (!isObject(obj)) return obj;\n var pairs = [];\n\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]);\n }\n\n return pairs.join('&');\n}\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n if (val === undefined) return;\n\n if (val === null) {\n pairs.push(encodeURI(key));\n return;\n }\n\n if (Array.isArray(val)) {\n val.forEach(function (v) {\n pushEncodedKeyValuePair(pairs, key, v);\n });\n } else if (isObject(val)) {\n for (var subkey in val) {\n if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, \"\".concat(key, \"[\").concat(subkey, \"]\"), val[subkey]);\n }\n } else {\n pairs.push(encodeURI(key) + '=' + encodeURIComponent(val));\n }\n}\n/**\n * Expose serialization method.\n */\n\n\nrequest.serializeObject = serialize;\n/**\n * Parse the given x-www-form-urlencoded `str`.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseString(str) {\n var obj = {};\n var pairs = str.split('&');\n var pair;\n var pos;\n\n for (var i = 0, len = pairs.length; i < len; ++i) {\n pair = pairs[i];\n pos = pair.indexOf('=');\n\n if (pos === -1) {\n obj[decodeURIComponent(pair)] = '';\n } else {\n obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1));\n }\n }\n\n return obj;\n}\n/**\n * Expose parser.\n */\n\n\nrequest.parseString = parseString;\n/**\n * Default MIME type map.\n *\n * superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n html: 'text/html',\n json: 'application/json',\n xml: 'text/xml',\n urlencoded: 'application/x-www-form-urlencoded',\n form: 'application/x-www-form-urlencoded',\n 'form-data': 'application/x-www-form-urlencoded'\n};\n/**\n * Default serialization map.\n *\n * superagent.serialize['application/xml'] = function(obj){\n * return 'generated xml here';\n * };\n *\n */\n\nrequest.serialize = {\n 'application/x-www-form-urlencoded': serialize,\n 'application/json': safeStringify\n};\n/**\n * Default parsers.\n *\n * superagent.parse['application/xml'] = function(str){\n * return { object parsed from str };\n * };\n *\n */\n\nrequest.parse = {\n 'application/x-www-form-urlencoded': parseString,\n 'application/json': JSON.parse\n};\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n var lines = str.split(/\\r?\\n/);\n var fields = {};\n var index;\n var line;\n var field;\n var val;\n\n for (var i = 0, len = lines.length; i < len; ++i) {\n line = lines[i];\n index = line.indexOf(':');\n\n if (index === -1) {\n // could be empty line, just skip it\n continue;\n }\n\n field = line.slice(0, index).toLowerCase();\n val = trim(line.slice(index + 1));\n fields[field] = val;\n }\n\n return fields;\n}\n/**\n * Check if `mime` is json or has +json structured syntax suffix.\n *\n * @param {String} mime\n * @return {Boolean}\n * @api private\n */\n\n\nfunction isJSON(mime) {\n // should match /json or +json\n // but not /json-seq\n return /[/+]json($|[^-\\w])/.test(mime);\n}\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n * - set flags (.ok, .error, etc)\n * - parse header\n *\n * Examples:\n *\n * Aliasing `superagent` as `request` is nice:\n *\n * request = superagent;\n *\n * We can use the promise-like API, or pass callbacks:\n *\n * request.get('/').end(function(res){});\n * request.get('/', function(res){});\n *\n * Sending data can be chained:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' })\n * .end(function(res){});\n *\n * Or passed to `.send()`:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' }, function(res){});\n *\n * Or passed to `.post()`:\n *\n * request\n * .post('/user', { name: 'tj' })\n * .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n * request\n * .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\n\nfunction Response(req) {\n this.req = req;\n this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers\n\n this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null;\n this.statusText = this.req.xhr.statusText;\n var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n\n if (status === 1223) {\n status = 204;\n }\n\n this._setStatusProperties(status);\n\n this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n this.header = this.headers; // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n // getResponseHeader still works. so we get content-type even if getting\n // other headers fails.\n\n this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n\n this._setHeaderProperties(this.header);\n\n if (this.text === null && req._responseType) {\n this.body = this.xhr.response;\n } else {\n this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response);\n }\n} // eslint-disable-next-line new-cap\n\n\nResponseBase(Response.prototype);\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype._parseBody = function (str) {\n var parse = request.parse[this.type];\n\n if (this.req._parser) {\n return this.req._parser(this, str);\n }\n\n if (!parse && isJSON(this.type)) {\n parse = request.parse['application/json'];\n }\n\n return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null;\n};\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\n\nResponse.prototype.toError = function () {\n var req = this.req;\n var method = req.method;\n var url = req.url;\n var msg = \"cannot \".concat(method, \" \").concat(url, \" (\").concat(this.status, \")\");\n var err = new Error(msg);\n err.status = this.status;\n err.method = method;\n err.url = url;\n return err;\n};\n/**\n * Expose `Response`.\n */\n\n\nrequest.Response = Response;\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n var self = this;\n this._query = this._query || [];\n this.method = method;\n this.url = url;\n this.header = {}; // preserves header name case\n\n this._header = {}; // coerces header names to lowercase\n\n this.on('end', function () {\n var err = null;\n var res = null;\n\n try {\n res = new Response(self);\n } catch (err_) {\n err = new Error('Parser is unable to parse the response');\n err.parse = true;\n err.original = err_; // issue #675: return the raw response if the response parsing fails\n\n if (self.xhr) {\n // ie9 doesn't have 'response' property\n err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails\n\n err.status = self.xhr.status ? self.xhr.status : null;\n err.statusCode = err.status; // backwards-compat only\n } else {\n err.rawResponse = null;\n err.status = null;\n }\n\n return self.callback(err);\n }\n\n self.emit('response', res);\n var new_err;\n\n try {\n if (!self._isResponseOK(res)) {\n new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response');\n }\n } catch (err_) {\n new_err = err_; // ok() callback can throw\n } // #1000 don't catch errors from the callback to avoid double calling it\n\n\n if (new_err) {\n new_err.original = err;\n new_err.response = res;\n new_err.status = res.status;\n self.callback(new_err, res);\n } else {\n self.callback(null, res);\n }\n });\n}\n/**\n * Mixin `Emitter` and `RequestBase`.\n */\n// eslint-disable-next-line new-cap\n\n\nEmitter(Request.prototype); // eslint-disable-next-line new-cap\n\nRequestBase(Request.prototype);\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.xml = 'application/xml';\n *\n * request.post('/')\n * .type('xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * request.post('/')\n * .type('application/xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function (type) {\n this.set('Content-Type', request.types[type] || type);\n return this;\n};\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.json = 'application/json';\n *\n * request.get('/agent')\n * .accept('json')\n * .end(callback);\n *\n * request.get('/agent')\n * .accept('application/json')\n * .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.accept = function (type) {\n this.set('Accept', request.types[type] || type);\n return this;\n};\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} [pass] optional in case of using 'bearer' as type\n * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic')\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.auth = function (user, pass, options) {\n if (arguments.length === 1) pass = '';\n\n if (_typeof(pass) === 'object' && pass !== null) {\n // pass is optional and can be replaced with options\n options = pass;\n pass = '';\n }\n\n if (!options) {\n options = {\n type: typeof btoa === 'function' ? 'basic' : 'auto'\n };\n }\n\n var encoder = function encoder(string) {\n if (typeof btoa === 'function') {\n return btoa(string);\n }\n\n throw new Error('Cannot use basic auth, btoa is not a function');\n };\n\n return this._auth(user, pass, options, encoder);\n};\n/**\n * Add query-string `val`.\n *\n * Examples:\n *\n * request.get('/shoes')\n * .query('size=10')\n * .query({ color: 'blue' })\n *\n * @param {Object|String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.query = function (val) {\n if (typeof val !== 'string') val = serialize(val);\n if (val) this._query.push(val);\n return this;\n};\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `options` (or filename).\n *\n * ``` js\n * request.post('/upload')\n * .attach('content', new Blob(['hey!'], { type: \"text/html\"}))\n * .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String|Object} options\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.attach = function (field, file, options) {\n if (file) {\n if (this._data) {\n throw new Error(\"superagent can't mix .send() and .attach()\");\n }\n\n this._getFormData().append(field, file, options || file.name);\n }\n\n return this;\n};\n\nRequest.prototype._getFormData = function () {\n if (!this._formData) {\n this._formData = new root.FormData();\n }\n\n return this._formData;\n};\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\n\nRequest.prototype.callback = function (err, res) {\n if (this._shouldRetry(err, res)) {\n return this._retry();\n }\n\n var fn = this._callback;\n this.clearTimeout();\n\n if (err) {\n if (this._maxRetries) err.retries = this._retries - 1;\n this.emit('error', err);\n }\n\n fn(err, res);\n};\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\n\nRequest.prototype.crossDomainError = function () {\n var err = new Error('Request has been terminated\\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.');\n err.crossDomain = true;\n err.status = this.status;\n err.method = this.method;\n err.url = this.url;\n this.callback(err);\n}; // This only warns, because the request is still likely to work\n\n\nRequest.prototype.agent = function () {\n console.warn('This is not supported in browser version of superagent');\n return this;\n};\n\nRequest.prototype.ca = Request.prototype.agent;\nRequest.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected\n\nRequest.prototype.write = function () {\n throw new Error('Streaming is not supported in browser version of superagent');\n};\n\nRequest.prototype.pipe = Request.prototype.write;\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * @param {Object} obj host object\n * @return {Boolean} is a host object\n * @api private\n */\n\nRequest.prototype._isHost = function (obj) {\n // Native objects stringify to [object File], [object Blob], [object FormData], etc.\n return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]';\n};\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.end = function (fn) {\n if (this._endCalled) {\n console.warn('Warning: .end() was called twice. This is not supported in superagent');\n }\n\n this._endCalled = true; // store callback\n\n this._callback = fn || noop; // querystring\n\n this._finalizeQueryString();\n\n this._end();\n};\n\nRequest.prototype._setUploadTimeout = function () {\n var self = this; // upload timeout it's wokrs only if deadline timeout is off\n\n if (this._uploadTimeout && !this._uploadTimeoutTimer) {\n this._uploadTimeoutTimer = setTimeout(function () {\n self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT');\n }, this._uploadTimeout);\n }\n}; // eslint-disable-next-line complexity\n\n\nRequest.prototype._end = function () {\n if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called'));\n var self = this;\n this.xhr = request.getXHR();\n var xhr = this.xhr;\n var data = this._formData || this._data;\n\n this._setTimeouts(); // state change\n\n\n xhr.onreadystatechange = function () {\n var readyState = xhr.readyState;\n\n if (readyState >= 2 && self._responseTimeoutTimer) {\n clearTimeout(self._responseTimeoutTimer);\n }\n\n if (readyState !== 4) {\n return;\n } // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n // result in the error \"Could not complete the operation due to error c00c023f\"\n\n\n var status;\n\n try {\n status = xhr.status;\n } catch (_unused5) {\n status = 0;\n }\n\n if (!status) {\n if (self.timedout || self._aborted) return;\n return self.crossDomainError();\n }\n\n self.emit('end');\n }; // progress\n\n\n var handleProgress = function handleProgress(direction, e) {\n if (e.total > 0) {\n e.percent = e.loaded / e.total * 100;\n\n if (e.percent === 100) {\n clearTimeout(self._uploadTimeoutTimer);\n }\n }\n\n e.direction = direction;\n self.emit('progress', e);\n };\n\n if (this.hasListeners('progress')) {\n try {\n xhr.addEventListener('progress', handleProgress.bind(null, 'download'));\n\n if (xhr.upload) {\n xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload'));\n }\n } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n // Reported here:\n // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n }\n }\n\n if (xhr.upload) {\n this._setUploadTimeout();\n } // initiate request\n\n\n try {\n if (this.username && this.password) {\n xhr.open(this.method, this.url, true, this.username, this.password);\n } else {\n xhr.open(this.method, this.url, true);\n }\n } catch (err) {\n // see #1149\n return this.callback(err);\n } // CORS\n\n\n if (this._withCredentials) xhr.withCredentials = true; // body\n\n if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) {\n // serialize stuff\n var contentType = this._header['content-type'];\n\n var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : ''];\n\n if (!_serialize && isJSON(contentType)) {\n _serialize = request.serialize['application/json'];\n }\n\n if (_serialize) data = _serialize(data);\n } // set header fields\n\n\n for (var field in this.header) {\n if (this.header[field] === null) continue;\n if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]);\n }\n\n if (this._responseType) {\n xhr.responseType = this._responseType;\n } // send stuff\n\n\n this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n // We need null here if data is undefined\n\n xhr.send(typeof data === 'undefined' ? null : data);\n};\n\nrequest.agent = function () {\n return new Agent();\n};\n\n['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) {\n Agent.prototype[method.toLowerCase()] = function (url, fn) {\n var req = new request.Request(method, url);\n\n this._setDefaults(req);\n\n if (fn) {\n req.end(fn);\n }\n\n return req;\n };\n});\nAgent.prototype.del = Agent.prototype.delete;\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.get = function (url, data, fn) {\n var req = request('GET', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.head = function (url, data, fn) {\n var req = request('HEAD', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * OPTIONS query to `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.options = function (url, data, fn) {\n var req = request('OPTIONS', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * DELETE `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nfunction del(url, data, fn) {\n var req = request('DELETE', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n}\n\nrequest.del = del;\nrequest.delete = del;\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function (url, data, fn) {\n var req = request('PATCH', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.post = function (url, data, fn) {\n var req = request('POST', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.put = function (url, data, fn) {\n var req = request('PUT', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jbGllbnQuanMiXSwibmFtZXMiOlsicm9vdCIsIndpbmRvdyIsInNlbGYiLCJjb25zb2xlIiwid2FybiIsIkVtaXR0ZXIiLCJyZXF1aXJlIiwic2FmZVN0cmluZ2lmeSIsIlJlcXVlc3RCYXNlIiwiaXNPYmplY3QiLCJSZXNwb25zZUJhc2UiLCJBZ2VudCIsIm5vb3AiLCJtb2R1bGUiLCJleHBvcnRzIiwibWV0aG9kIiwidXJsIiwiUmVxdWVzdCIsImVuZCIsImFyZ3VtZW50cyIsImxlbmd0aCIsInJlcXVlc3QiLCJnZXRYSFIiLCJYTUxIdHRwUmVxdWVzdCIsImxvY2F0aW9uIiwicHJvdG9jb2wiLCJBY3RpdmVYT2JqZWN0IiwiRXJyb3IiLCJ0cmltIiwicyIsInJlcGxhY2UiLCJzZXJpYWxpemUiLCJvYmoiLCJwYWlycyIsImtleSIsIk9iamVjdCIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsInB1c2hFbmNvZGVkS2V5VmFsdWVQYWlyIiwiam9pbiIsInZhbCIsInVuZGVmaW5lZCIsInB1c2giLCJlbmNvZGVVUkkiLCJBcnJheSIsImlzQXJyYXkiLCJmb3JFYWNoIiwidiIsInN1YmtleSIsImVuY29kZVVSSUNvbXBvbmVudCIsInNlcmlhbGl6ZU9iamVjdCIsInBhcnNlU3RyaW5nIiwic3RyIiwic3BsaXQiLCJwYWlyIiwicG9zIiwiaSIsImxlbiIsImluZGV4T2YiLCJkZWNvZGVVUklDb21wb25lbnQiLCJzbGljZSIsInR5cGVzIiwiaHRtbCIsImpzb24iLCJ4bWwiLCJ1cmxlbmNvZGVkIiwiZm9ybSIsInBhcnNlIiwiSlNPTiIsInBhcnNlSGVhZGVyIiwibGluZXMiLCJmaWVsZHMiLCJpbmRleCIsImxpbmUiLCJmaWVsZCIsInRvTG93ZXJDYXNlIiwiaXNKU09OIiwibWltZSIsInRlc3QiLCJSZXNwb25zZSIsInJlcSIsInhociIsInRleHQiLCJyZXNwb25zZVR5cGUiLCJyZXNwb25zZVRleHQiLCJzdGF0dXNUZXh0Iiwic3RhdHVzIiwiX3NldFN0YXR1c1Byb3BlcnRpZXMiLCJoZWFkZXJzIiwiZ2V0QWxsUmVzcG9uc2VIZWFkZXJzIiwiaGVhZGVyIiwiZ2V0UmVzcG9uc2VIZWFkZXIiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsIl9yZXNwb25zZVR5cGUiLCJib2R5IiwicmVzcG9uc2UiLCJfcGFyc2VCb2R5IiwidHlwZSIsIl9wYXJzZXIiLCJ0b0Vycm9yIiwibXNnIiwiZXJyIiwiX3F1ZXJ5IiwiX2hlYWRlciIsIm9uIiwicmVzIiwiZXJyXyIsIm9yaWdpbmFsIiwicmF3UmVzcG9uc2UiLCJzdGF0dXNDb2RlIiwiY2FsbGJhY2siLCJlbWl0IiwibmV3X2VyciIsIl9pc1Jlc3BvbnNlT0siLCJzZXQiLCJhY2NlcHQiLCJhdXRoIiwidXNlciIsInBhc3MiLCJvcHRpb25zIiwiYnRvYSIsImVuY29kZXIiLCJzdHJpbmciLCJfYXV0aCIsInF1ZXJ5IiwiYXR0YWNoIiwiZmlsZSIsIl9kYXRhIiwiX2dldEZvcm1EYXRhIiwiYXBwZW5kIiwibmFtZSIsIl9mb3JtRGF0YSIsIkZvcm1EYXRhIiwiX3Nob3VsZFJldHJ5IiwiX3JldHJ5IiwiZm4iLCJfY2FsbGJhY2siLCJjbGVhclRpbWVvdXQiLCJfbWF4UmV0cmllcyIsInJldHJpZXMiLCJfcmV0cmllcyIsImNyb3NzRG9tYWluRXJyb3IiLCJjcm9zc0RvbWFpbiIsImFnZW50IiwiY2EiLCJidWZmZXIiLCJ3cml0ZSIsInBpcGUiLCJfaXNIb3N0IiwidG9TdHJpbmciLCJfZW5kQ2FsbGVkIiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJfZW5kIiwiX3NldFVwbG9hZFRpbWVvdXQiLCJfdXBsb2FkVGltZW91dCIsIl91cGxvYWRUaW1lb3V0VGltZXIiLCJzZXRUaW1lb3V0IiwiX3RpbWVvdXRFcnJvciIsIl9hYm9ydGVkIiwiZGF0YSIsIl9zZXRUaW1lb3V0cyIsIm9ucmVhZHlzdGF0ZWNoYW5nZSIsInJlYWR5U3RhdGUiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJ0aW1lZG91dCIsImhhbmRsZVByb2dyZXNzIiwiZGlyZWN0aW9uIiwiZSIsInRvdGFsIiwicGVyY2VudCIsImxvYWRlZCIsImhhc0xpc3RlbmVycyIsImFkZEV2ZW50TGlzdGVuZXIiLCJiaW5kIiwidXBsb2FkIiwidXNlcm5hbWUiLCJwYXNzd29yZCIsIm9wZW4iLCJfd2l0aENyZWRlbnRpYWxzIiwid2l0aENyZWRlbnRpYWxzIiwiY29udGVudFR5cGUiLCJfc2VyaWFsaXplciIsInNldFJlcXVlc3RIZWFkZXIiLCJzZW5kIiwiX3NldERlZmF1bHRzIiwiZGVsIiwiZGVsZXRlIiwiZ2V0IiwiaGVhZCIsInBhdGNoIiwicG9zdCIsInB1dCJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7QUFJQSxJQUFJQSxJQUFKOztBQUNBLElBQUksT0FBT0MsTUFBUCxLQUFrQixXQUF0QixFQUFtQztBQUNqQztBQUNBRCxFQUFBQSxJQUFJLEdBQUdDLE1BQVA7QUFDRCxDQUhELE1BR08sSUFBSSxPQUFPQyxJQUFQLEtBQWdCLFdBQXBCLEVBQWlDO0FBQ3RDO0FBQ0FDLEVBQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUNFLHFFQURGO0FBR0FKLEVBQUFBLElBQUksU0FBSjtBQUNELENBTk0sTUFNQTtBQUNMO0FBQ0FBLEVBQUFBLElBQUksR0FBR0UsSUFBUDtBQUNEOztBQUVELElBQU1HLE9BQU8sR0FBR0MsT0FBTyxDQUFDLG1CQUFELENBQXZCOztBQUNBLElBQU1DLGFBQWEsR0FBR0QsT0FBTyxDQUFDLHFCQUFELENBQTdCOztBQUNBLElBQU1FLFdBQVcsR0FBR0YsT0FBTyxDQUFDLGdCQUFELENBQTNCOztBQUNBLElBQU1HLFFBQVEsR0FBR0gsT0FBTyxDQUFDLGFBQUQsQ0FBeEI7O0FBQ0EsSUFBTUksWUFBWSxHQUFHSixPQUFPLENBQUMsaUJBQUQsQ0FBNUI7O0FBQ0EsSUFBTUssS0FBSyxHQUFHTCxPQUFPLENBQUMsY0FBRCxDQUFyQjtBQUVBOzs7OztBQUlBLFNBQVNNLElBQVQsR0FBZ0IsQ0FBRTtBQUVsQjs7Ozs7QUFJ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cmVuY2UgZm9yIGlmcmFtZXMuXG4gKi9cblxubGV0IHJvb3Q7XG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgLy8gQnJvd3NlciB3aW5kb3dcbiAgcm9vdCA9IHdpbmRvdztcbn0gZWxzZSBpZiAodHlwZW9mIHNlbGYgPT09ICd1bmRlZmluZWQnKSB7XG4gIC8vIE90aGVyIGVudmlyb25tZW50c1xuICBjb25zb2xlLndhcm4oXG4gICAgJ1VzaW5nIGJyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgaW4gbm9uLWJyb3dzZXIgZW52aXJvbm1lbnQnXG4gICk7XG4gIHJvb3QgPSB0aGlzO1xufSBlbHNlIHtcbiAgLy8gV2ViIFdvcmtlclxuICByb290ID0gc2VsZjtcbn1cblxuY29uc3QgRW1pdHRlciA9IHJlcXVpcmUoJ2NvbXBvbmVudC1lbWl0dGVyJyk7XG5jb25zdCBzYWZlU3RyaW5naWZ5ID0gcmVxdWlyZSgnZmFzdC1zYWZlLXN0cmluZ2lmeScpO1xuY29uc3QgUmVxdWVzdEJhc2UgPSByZXF1aXJlKCcuL3JlcXVlc3QtYmFzZScpO1xuY29uc3QgaXNPYmplY3QgPSByZXF1aXJlKCcuL2lzLW9iamVjdCcpO1xuY29uc3QgUmVzcG9uc2VCYXNlID0gcmVxdWlyZSgnLi9yZXNwb25zZS1iYXNlJyk7XG5jb25zdCBBZ2VudCA9IHJlcXVpcmUoJy4vYWdlbnQtYmFzZScpO1xuXG4vKipcbiAqIE5vb3AuXG4gKi9cblxuZnVuY3Rpb24gbm9vcCgpIHt9XG5cbi8qKlxuICogRXhwb3NlIGByZXF1ZXN0YC5cbiAqL1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKG1ldGhvZCwgdXJsKSB7XG4gIC8vIGNhbGxiYWNrXG4gIGlmICh0eXBlb2YgdXJsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIG5ldyBleHBvcnRzLlJlcXVlc3QoJ0dFVCcsIG1ldGhvZCkuZW5kKHVybCk7XG4gIH1cblxuICAvLyB1cmwgZmlyc3RcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHtcbiAgICByZXR1cm4gbmV3IGV4cG9ydHMuUmVxdWVzdCgnR0VUJywgbWV0aG9kKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgZXhwb3J0cy5SZXF1ZXN0KG1ldGhvZCwgdXJsKTtcbn07XG5cbmV4cG9ydHMgPSBtb2R1bGUuZXhwb3J0cztcblxuY29uc3QgcmVxdWVzdCA9IGV4cG9ydHM7XG5cbmV4cG9ydHMuUmVxdWVzdCA9IFJlcXVlc3Q7XG5cbi8qKlxuICogRGV0ZXJtaW5lIFhIUi5cbiAqL1xuXG5yZXF1ZXN0LmdldFhIUiA9ICgpID0+IHtcbiAgaWYgKFxuICAgIHJvb3QuWE1MSHR0cFJlcXVlc3QgJiZcbiAgICAoIXJvb3QubG9jYXRpb24gfHxcbiAgICAgIHJvb3QubG9jYXRpb24ucHJvdG9jb2wgIT09ICdmaWxlOicgfHxcbiAgICAgICFyb290LkFjdGl2ZVhPYmplY3QpXG4gICkge1xuICAgIHJldHVybiBuZXcgWE1MSHR0cFJlcXVlc3QoKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgcmV0dXJuIG5ldyBBY3RpdmVYT2JqZWN0KCdNaWNyb3NvZnQuWE1MSFRUUCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjYuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjMuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQJyk7XG4gIH0gY2F0Y2gge31cblxuICB0aHJvdyBuZXcgRXJyb3IoJ0Jyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgY291bGQgbm90IGZpbmQgWEhSJyk7XG59O1xuXG4vKipcbiAqIFJlbW92ZXMgbGVhZGluZyBhbmQgdHJhaWxpbmcgd2hpdGVzcGFjZSwgYWRkZWQgdG8gc3VwcG9ydCBJRS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc1xuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuY29uc3QgdHJpbSA9ICcnLnRyaW0gPyBzID0+IHMudHJpbSgpIDogcyA9PiBzLnJlcGxhY2UoLyheXFxzKnxcXHMqJCkvZywgJycpO1xuXG4vKipcbiAqIFNlcmlhbGl6ZSB0aGUgZ2l2ZW4gYG9iamAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9ialxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gc2VyaWFsaXplKG9iaikge1xuICBpZiAoIWlzT2JqZWN0KG9iaikpIHJldHVybiBvYmo7XG4gIGNvbnN0IHBhaXJzID0gW107XG4gIGZvciAoY29uc3Qga2V5IGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBrZXkpKVxuICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGtleSwgb2JqW2tleV0pO1xuICB9XG5cbiAgcmV0dXJuIHBhaXJzLmpvaW4oJyYnKTtcbn1cblxuLyoqXG4gKiBIZWxwcyAnc2VyaWFsaXplJyB3aXRoIHNlcmlhbGl6aW5nIGFycmF5cy5cbiAqIE11dGF0ZXMgdGhlIHBhaXJzIGFycmF5LlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IHBhaXJzXG4gKiBAcGFyYW0ge1N0cmluZ30ga2V5XG4gKiBAcGFyYW0ge01peGVkfSB2YWxcbiAqL1xuXG5mdW5jdGlvbiBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2YWwpIHtcbiAgaWYgKHZhbCA9PT0gdW5kZWZpbmVkKSByZXR1cm47XG4gIGlmICh2YWwgPT09IG51bGwpIHtcbiAgICBwYWlycy5wdXNoKGVuY29kZVVSSShrZXkpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheSh2YWwpKSB7XG4gICAgdmFsLmZvckVhY2godiA9PiB7XG4gICAgICBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2KTtcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc09iamVjdCh2YWwpKSB7XG4gICAgZm9yIChjb25zdCBzdWJrZXkgaW4gdmFsKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHZhbCwgc3Via2V5KSlcbiAgICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGAke2tleX1bJHtzdWJrZXl9XWAsIHZhbFtzdWJrZXldKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcGFpcnMucHVzaChlbmNvZGVVUkkoa2V5KSArICc9JyArIGVuY29kZVVSSUNvbXBvbmVudCh2YWwpKTtcbiAgfVxufVxuXG4vKipcbiAqIEV4cG9zZSBzZXJpYWxpemF0aW9uIG1ldGhvZC5cbiAqL1xuXG5yZXF1ZXN0LnNlcmlhbGl6ZU9iamVjdCA9IHNlcmlhbGl6ZTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4geC13d3ctZm9ybS11cmxlbmNvZGVkIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgY29uc3QgcGFpcnMgPSBzdHIuc3BsaXQoJyYnKTtcbiAgbGV0IHBhaXI7XG4gIGxldCBwb3M7XG5cbiAgZm9yIChsZXQgaSA9IDAsIGxlbiA9IHBhaXJzLmxlbmd0aDsgaSA8IGxlbjsgKytpKSB7XG4gICAgcGFpciA9IHBhaXJzW2ldO1xuICAgIHBvcyA9IHBhaXIuaW5kZXhPZignPScpO1xuICAgIGlmIChwb3MgPT09IC0xKSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIpXSA9ICcnO1xuICAgIH0gZWxzZSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIuc2xpY2UoMCwgcG9zKSldID0gZGVjb2RlVVJJQ29tcG9uZW50KFxuICAgICAgICBwYWlyLnNsaWNlKHBvcyArIDEpXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbi8qKlxuICogRXhwb3NlIHBhcnNlci5cbiAqL1xuXG5yZXF1ZXN0LnBhcnNlU3RyaW5nID0gcGFyc2VTdHJpbmc7XG5cbi8qKlxuICogRGVmYXVsdCBNSU1FIHR5cGUgbWFwLlxuICpcbiAqICAgICBzdXBlcmFnZW50LnR5cGVzLnhtbCA9ICdhcHBsaWNhdGlvbi94bWwnO1xuICpcbiAqL1xuXG5yZXF1ZXN0LnR5cGVzID0ge1xuICBodG1sOiAndGV4dC9odG1sJyxcbiAganNvbjogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICB4bWw6ICd0ZXh0L3htbCcsXG4gIHVybGVuY29kZWQ6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnLFxuICBmb3JtOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyxcbiAgJ2Zvcm0tZGF0YSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG59O1xuXG4vKipcbiAqIERlZmF1bHQgc2VyaWFsaXphdGlvbiBtYXAuXG4gKlxuICogICAgIHN1cGVyYWdlbnQuc2VyaWFsaXplWydhcHBsaWNhdGlvbi94bWwnXSA9IGZ1bmN0aW9uKG9iail7XG4gKiAgICAgICByZXR1cm4gJ2dlbmVyYXRlZCB4bWwgaGVyZSc7XG4gKiAgICAgfTtcbiAqXG4gKi9cblxucmVxdWVzdC5zZXJpYWxpemUgPSB7XG4gICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnOiBzZXJpYWxpemUsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogc2FmZVN0cmluZ2lmeVxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcnNlcnMuXG4gKlxuICogICAgIHN1cGVyYWdlbnQucGFyc2VbJ2FwcGxpY2F0aW9uL3htbCddID0gZnVuY3Rpb24oc3RyKXtcbiAqICAgICAgIHJldHVybiB7IG9iamVjdCBwYXJzZWQgZnJvbSBzdHIgfTtcbiAqICAgICB9O1xuICpcbiAqL1xuXG5yZXF1ZXN0LnBhcnNlID0ge1xuICAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJzogcGFyc2VTdHJpbmcsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogSlNPTi5wYXJzZVxufTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gaGVhZGVyIGBzdHJgIGludG9cbiAqIGFuIG9iamVjdCBjb250YWluaW5nIHRoZSBtYXBwZWQgZmllbGRzLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlSGVhZGVyKHN0cikge1xuICBjb25zdCBsaW5lcyA9IHN0ci5zcGxpdCgvXFxyP1xcbi8pO1xuICBjb25zdCBmaWVsZHMgPSB7fTtcbiAgbGV0IGluZGV4O1xuICBsZXQgbGluZTtcbiAgbGV0IGZpZWxkO1xuICBsZXQgdmFsO1xuXG4gIGZvciAobGV0IGkgPSAwLCBsZW4gPSBsaW5lcy5sZW5ndGg7IGkgPCBsZW47ICsraSkge1xuICAgIGxpbmUgPSBsaW5lc1tpXTtcbiAgICBpbmRleCA9IGxpbmUuaW5kZXhPZignOicpO1xuICAgIGlmIChpbmRleCA9PT0gLTEpIHtcbiAgICAgIC8vIGNvdWxkIGJlIGVtcHR5IGxpbmUsIGp1c3Qgc2tpcCBpdFxuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgZmllbGQgPSBsaW5lLnNsaWNlKDAsIGluZGV4KS50b0xvd2VyQ2FzZSgpO1xuICAgIHZhbCA9IHRyaW0obGluZS5zbGljZShpbmRleCArIDEpKTtcbiAgICBmaWVsZHNbZmllbGRdID0gdmFsO1xuICB9XG5cbiAgcmV0dXJuIGZpZWxkcztcbn1cblxuLyoqXG4gKiBDaGVjayBpZiBgbWltZWAgaXMganNvbiBvciBoYXMgK2pzb24gc3RydWN0dXJlZCBzeW50YXggc3VmZml4LlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBtaW1lXG4gKiBAcmV0dXJuIHtCb29sZWFufVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gaXNKU09OKG1pbWUpIHtcbiAgLy8gc2hvdWxkIG1hdGNoIC9qc29uIG9yICtqc29uXG4gIC8vIGJ1dCBub3QgL2pzb24tc2VxXG4gIHJldHVybiAvWy8rXWpzb24oJHxbXi1cXHddKS8udGVzdChtaW1lKTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXNwb25zZWAgd2l0aCB0aGUgZ2l2ZW4gYHhocmAuXG4gKlxuICogIC0gc2V0IGZsYWdzICgub2ssIC5lcnJvciwgZXRjKVxuICogIC0gcGFyc2UgaGVhZGVyXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogIEFsaWFzaW5nIGBzdXBlcmFnZW50YCBhcyBgcmVxdWVzdGAgaXMgbmljZTpcbiAqXG4gKiAgICAgIHJlcXVlc3QgPSBzdXBlcmFnZW50O1xuICpcbiAqICBXZSBjYW4gdXNlIHRoZSBwcm9taXNlLWxpa2UgQVBJLCBvciBwYXNzIGNhbGxiYWNrczpcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJykuZW5kKGZ1bmN0aW9uKHJlcyl7fSk7XG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJywgZnVuY3Rpb24ocmVzKXt9KTtcbiAqXG4gKiAgU2VuZGluZyBkYXRhIGNhbiBiZSBjaGFpbmVkOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqICBPciBwYXNzZWQgdG8gYC5zZW5kKClgOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogIE9yIHBhc3NlZCB0byBgLnBvc3QoKWA6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqIE9yIGZ1cnRoZXIgcmVkdWNlZCB0byBhIHNpbmdsZSBjYWxsIGZvciBzaW1wbGUgY2FzZXM6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogQHBhcmFtIHtYTUxIVFRQUmVxdWVzdH0geGhyXG4gKiBAcGFyYW0ge09iamVjdH0gb3B0aW9uc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gUmVzcG9uc2UocmVxKSB7XG4gIHRoaXMucmVxID0gcmVxO1xuICB0aGlzLnhociA9IHRoaXMucmVxLnhocjtcbiAgLy8gcmVzcG9uc2VUZXh0IGlzIGFjY2Vzc2libGUgb25seSBpZiByZXNwb25zZVR5cGUgaXMgJycgb3IgJ3RleHQnIGFuZCBvbiBvbGRlciBicm93c2Vyc1xuICB0aGlzLnRleHQgPVxuICAgICh0aGlzLnJlcS5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgICAgKHRoaXMueGhyLnJlc3BvbnNlVHlwZSA9PT0gJycgfHwgdGhpcy54aHIucmVzcG9uc2VUeXBlID09PSAndGV4dCcpKSB8fFxuICAgIHR5cGVvZiB0aGlzLnhoci5yZXNwb25zZVR5cGUgPT09ICd1bmRlZmluZWQnXG4gICAgICA/IHRoaXMueGhyLnJlc3BvbnNlVGV4dFxuICAgICAgOiBudWxsO1xuICB0aGlzLnN0YXR1c1RleHQgPSB0aGlzLnJlcS54aHIuc3RhdHVzVGV4dDtcbiAgbGV0IHsgc3RhdHVzIH0gPSB0aGlzLnhocjtcbiAgLy8gaGFuZGxlIElFOSBidWc6IGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTAwNDY5NzIvbXNpZS1yZXR1cm5zLXN0YXR1cy1jb2RlLW9mLTEyMjMtZm9yLWFqYXgtcmVxdWVzdFxuICBpZiAoc3RhdHVzID09PSAxMjIzKSB7XG4gICAgc3RhdHVzID0gMjA0O1xuICB9XG5cbiAgdGhpcy5fc2V0U3RhdHVzUHJvcGVydGllcyhzdGF0dXMpO1xuICB0aGlzLmhlYWRlcnMgPSBwYXJzZUhlYWRlcih0aGlzLnhoci5nZXRBbGxSZXNwb25zZUhlYWRlcnMoKSk7XG4gIHRoaXMuaGVhZGVyID0gdGhpcy5oZWFkZXJzO1xuICAvLyBnZXRBbGxSZXNwb25zZUhlYWRlcnMgc29tZXRpbWVzIGZhbHNlbHkgcmV0dXJucyBcIlwiIGZvciBDT1JTIHJlcXVlc3RzLCBidXRcbiAgLy8gZ2V0UmVzcG9uc2VIZWFkZXIgc3RpbGwgd29ya3MuIHNvIHdlIGdldCBjb250ZW50LXR5cGUgZXZlbiBpZiBnZXR0aW5nXG4gIC8vIG90aGVyIGhlYWRlcnMgZmFpbHMuXG4gIHRoaXMuaGVhZGVyWydjb250ZW50LXR5cGUnXSA9IHRoaXMueGhyLmdldFJlc3BvbnNlSGVhZGVyKCdjb250ZW50LXR5cGUnKTtcbiAgdGhpcy5fc2V0SGVhZGVyUHJvcGVydGllcyh0aGlzLmhlYWRlcik7XG5cbiAgaWYgKHRoaXMudGV4dCA9PT0gbnVsbCAmJiByZXEuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHRoaXMuYm9keSA9IHRoaXMueGhyLnJlc3BvbnNlO1xuICB9IGVsc2Uge1xuICAgIHRoaXMuYm9keSA9XG4gICAgICB0aGlzLnJlcS5tZXRob2QgPT09ICdIRUFEJ1xuICAgICAgICA/IG51bGxcbiAgICAgICAgOiB0aGlzLl9wYXJzZUJvZHkodGhpcy50ZXh0ID8gdGhpcy50ZXh0IDogdGhpcy54aHIucmVzcG9uc2UpO1xuICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXNwb25zZUJhc2UoUmVzcG9uc2UucHJvdG90eXBlKTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gYm9keSBgc3RyYC5cbiAqXG4gKiBVc2VkIGZvciBhdXRvLXBhcnNpbmcgb2YgYm9kaWVzLiBQYXJzZXJzXG4gKiBhcmUgZGVmaW5lZCBvbiB0aGUgYHN1cGVyYWdlbnQucGFyc2VgIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtNaXhlZH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlc3BvbnNlLnByb3RvdHlwZS5fcGFyc2VCb2R5ID0gZnVuY3Rpb24oc3RyKSB7XG4gIGxldCBwYXJzZSA9IHJlcXVlc3QucGFyc2VbdGhpcy50eXBlXTtcbiAgaWYgKHRoaXMucmVxLl9wYXJzZXIpIHtcbiAgICByZXR1cm4gdGhpcy5yZXEuX3BhcnNlcih0aGlzLCBzdHIpO1xuICB9XG5cbiAgaWYgKCFwYXJzZSAmJiBpc0pTT04odGhpcy50eXBlKSkge1xuICAgIHBhcnNlID0gcmVxdWVzdC5wYXJzZVsnYXBwbGljYXRpb24vanNvbiddO1xuICB9XG5cbiAgcmV0dXJuIHBhcnNlICYmIHN0ciAmJiAoc3RyLmxlbmd0aCA+IDAgfHwgc3RyIGluc3RhbmNlb2YgT2JqZWN0KVxuICAgID8gcGFyc2Uoc3RyKVxuICAgIDogbnVsbDtcbn07XG5cbi8qKlxuICogUmV0dXJuIGFuIGBFcnJvcmAgcmVwcmVzZW50YXRpdmUgb2YgdGhpcyByZXNwb25zZS5cbiAqXG4gKiBAcmV0dXJuIHtFcnJvcn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVzcG9uc2UucHJvdG90eXBlLnRvRXJyb3IgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgeyByZXEgfSA9IHRoaXM7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSByZXE7XG4gIGNvbnN0IHsgdXJsIH0gPSByZXE7XG5cbiAgY29uc3QgbXNnID0gYGNhbm5vdCAke21ldGhvZH0gJHt1cmx9ICgke3RoaXMuc3RhdHVzfSlgO1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IobXNnKTtcbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gbWV0aG9kO1xuICBlcnIudXJsID0gdXJsO1xuXG4gIHJldHVybiBlcnI7XG59O1xuXG4vKipcbiAqIEV4cG9zZSBgUmVzcG9uc2VgLlxuICovXG5cbnJlcXVlc3QuUmVzcG9uc2UgPSBSZXNwb25zZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0YCB3aXRoIHRoZSBnaXZlbiBgbWV0aG9kYCBhbmQgYHVybGAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IG1ldGhvZFxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0KG1ldGhvZCwgdXJsKSB7XG4gIGNvbnN0IHNlbGYgPSB0aGlzO1xuICB0aGlzLl9xdWVyeSA9IHRoaXMuX3F1ZXJ5IHx8IFtdO1xuICB0aGlzLm1ldGhvZCA9IG1ldGhvZDtcbiAgdGhpcy51cmwgPSB1cmw7XG4gIHRoaXMuaGVhZGVyID0ge307IC8vIHByZXNlcnZlcyBoZWFkZXIgbmFtZSBjYXNlXG4gIHRoaXMuX2hlYWRlciA9IHt9OyAvLyBjb2VyY2VzIGhlYWRlciBuYW1lcyB0byBsb3dlcmNhc2VcbiAgdGhpcy5vbignZW5kJywgKCkgPT4ge1xuICAgIGxldCBlcnIgPSBudWxsO1xuICAgIGxldCByZXMgPSBudWxsO1xuXG4gICAgdHJ5IHtcbiAgICAgIHJlcyA9IG5ldyBSZXNwb25zZShzZWxmKTtcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBlcnIgPSBuZXcgRXJyb3IoJ1BhcnNlciBpcyB1bmFibGUgdG8gcGFyc2UgdGhlIHJlc3BvbnNlJyk7XG4gICAgICBlcnIucGFyc2UgPSB0cnVlO1xuICAgICAgZXJyLm9yaWdpbmFsID0gZXJyXztcbiAgICAgIC8vIGlzc3VlICM2NzU6IHJldHVybiB0aGUgcmF3IHJlc3BvbnNlIGlmIHRoZSByZXNwb25zZSBwYXJzaW5nIGZhaWxzXG4gICAgICBpZiAoc2VsZi54aHIpIHtcbiAgICAgICAgLy8gaWU5IGRvZXNuJ3QgaGF2ZSAncmVzcG9uc2UnIHByb3BlcnR5XG4gICAgICAgIGVyci5yYXdSZXNwb25zZSA9XG4gICAgICAgICAgdHlwZW9mIHNlbGYueGhyLnJlc3BvbnNlVHlwZSA9PT0gJ3VuZGVmaW5lZCdcbiAgICAgICAgICAgID8gc2VsZi54aHIucmVzcG9uc2VUZXh0XG4gICAgICAgICAgICA6IHNlbGYueGhyLnJlc3BvbnNlO1xuICAgICAgICAvLyBpc3N1ZSAjODc2OiByZXR1cm4gdGhlIGh0dHAgc3RhdHVzIGNvZGUgaWYgdGhlIHJlc3BvbnNlIHBhcnNpbmcgZmFpbHNcbiAgICAgICAgZXJyLnN0YXR1cyA9IHNlbGYueGhyLnN0YXR1cyA/IHNlbGYueGhyLnN0YXR1cyA6IG51bGw7XG4gICAgICAgIGVyci5zdGF0dXNDb2RlID0gZXJyLnN0YXR1czsgLy8gYmFja3dhcmRzLWNvbXBhdCBvbmx5XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBlcnIucmF3UmVzcG9uc2UgPSBudWxsO1xuICAgICAgICBlcnIuc3RhdHVzID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNlbGYuY2FsbGJhY2soZXJyKTtcbiAgICB9XG5cbiAgICBzZWxmLmVtaXQoJ3Jlc3BvbnNlJywgcmVzKTtcblxuICAgIGxldCBuZXdfZXJyO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXNlbGYuX2lzUmVzcG9uc2VPSyhyZXMpKSB7XG4gICAgICAgIG5ld19lcnIgPSBuZXcgRXJyb3IoXG4gICAgICAgICAgcmVzLnN0YXR1c1RleHQgfHwgcmVzLnRleHQgfHwgJ1Vuc3VjY2Vzc2Z1bCBIVFRQIHJlc3BvbnNlJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycl8pIHtcbiAgICAgIG5ld19lcnIgPSBlcnJfOyAvLyBvaygpIGNhbGxiYWNrIGNhbiB0aHJvd1xuICAgIH1cblxuICAgIC8vICMxMDAwIGRvbid0IGNhdGNoIGVycm9ycyBmcm9tIHRoZSBjYWxsYmFjayB0byBhdm9pZCBkb3VibGUgY2FsbGluZyBpdFxuICAgIGlmIChuZXdfZXJyKSB7XG4gICAgICBuZXdfZXJyLm9yaWdpbmFsID0gZXJyO1xuICAgICAgbmV3X2Vyci5yZXNwb25zZSA9IHJlcztcbiAgICAgIG5ld19lcnIuc3RhdHVzID0gcmVzLnN0YXR1cztcbiAgICAgIHNlbGYuY2FsbGJhY2sobmV3X2VyciwgcmVzKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2VsZi5jYWxsYmFjayhudWxsLCByZXMpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogTWl4aW4gYEVtaXR0ZXJgIGFuZCBgUmVxdWVzdEJhc2VgLlxuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5FbWl0dGVyKFJlcXVlc3QucHJvdG90eXBlKTtcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXF1ZXN0QmFzZShSZXF1ZXN0LnByb3RvdHlwZSk7XG5cbi8qKlxuICogU2V0IENvbnRlbnQtVHlwZSB0byBgdHlwZWAsIG1hcHBpbmcgdmFsdWVzIGZyb20gYHJlcXVlc3QudHlwZXNgLlxuICpcbiAqIEV4YW1wbGVzOlxuICpcbiAqICAgICAgc3VwZXJhZ2VudC50eXBlcy54bWwgPSAnYXBwbGljYXRpb24veG1sJztcbiAqXG4gKiAgICAgIHJlcXVlc3QucG9zdCgnLycpXG4gKiAgICAgICAgLnR5cGUoJ3htbCcpXG4gKiAgICAgICAgLnNlbmQoeG1sc3RyaW5nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvJylcbiAqICAgICAgICAudHlwZSgnYXBwbGljYXRpb24veG1sJylcbiAqICAgICAgICAuc2VuZCh4bWxzdHJpbmcpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHR5cGVcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS50eXBlID0gZnVuY3Rpb24odHlwZSkge1xuICB0aGlzLnNldCgnQ29udGVudC1UeXBlJywgcmVxdWVzdC50eXBlc1t0eXBlXSB8fCB0eXBlKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNldCBBY2NlcHQgdG8gYHR5cGVgLCBtYXBwaW5nIHZhbHVlcyBmcm9tIGByZXF1ZXN0LnR5cGVzYC5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHN1cGVyYWdlbnQudHlwZXMuanNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJztcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvYWdlbnQnKVxuICogICAgICAgIC5hY2NlcHQoJ2pzb24nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5nZXQoJy9hZ2VudCcpXG4gKiAgICAgICAgLmFjY2VwdCgnYXBwbGljYXRpb24vanNvbicpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGFjY2VwdFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmFjY2VwdCA9IGZ1bmN0aW9uKHR5cGUpIHtcbiAgdGhpcy5zZXQoJ0FjY2VwdCcsIHJlcXVlc3QudHlwZXNbdHlwZV0gfHwgdHlwZSk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgQXV0aG9yaXphdGlvbiBmaWVsZCB2YWx1ZSB3aXRoIGB1c2VyYCBhbmQgYHBhc3NgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1c2VyXG4gKiBAcGFyYW0ge1N0cmluZ30gW3Bhc3NdIG9wdGlvbmFsIGluIGNhc2Ugb2YgdXNpbmcgJ2JlYXJlcicgYXMgdHlwZVxuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMgd2l0aCAndHlwZScgcHJvcGVydHkgJ2F1dG8nLCAnYmFzaWMnIG9yICdiZWFyZXInIChkZWZhdWx0ICdiYXNpYycpXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuYXV0aCA9IGZ1bmN0aW9uKHVzZXIsIHBhc3MsIG9wdGlvbnMpIHtcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHBhc3MgPSAnJztcbiAgaWYgKHR5cGVvZiBwYXNzID09PSAnb2JqZWN0JyAmJiBwYXNzICE9PSBudWxsKSB7XG4gICAgLy8gcGFzcyBpcyBvcHRpb25hbCBhbmQgY2FuIGJlIHJlcGxhY2VkIHdpdGggb3B0aW9uc1xuICAgIG9wdGlvbnMgPSBwYXNzO1xuICAgIHBhc3MgPSAnJztcbiAgfVxuXG4gIGlmICghb3B0aW9ucykge1xuICAgIG9wdGlvbnMgPSB7XG4gICAgICB0eXBlOiB0eXBlb2YgYnRvYSA9PT0gJ2Z1bmN0aW9uJyA/ICdiYXNpYycgOiAnYXV0bydcbiAgICB9O1xuICB9XG5cbiAgY29uc3QgZW5jb2RlciA9IHN0cmluZyA9PiB7XG4gICAgaWYgKHR5cGVvZiBidG9hID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYnRvYShzdHJpbmcpO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IHVzZSBiYXNpYyBhdXRoLCBidG9hIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gIH07XG5cbiAgcmV0dXJuIHRoaXMuX2F1dGgodXNlciwgcGFzcywgb3B0aW9ucywgZW5jb2Rlcik7XG59O1xuXG4vKipcbiAqIEFkZCBxdWVyeS1zdHJpbmcgYHZhbGAuXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICByZXF1ZXN0LmdldCgnL3Nob2VzJylcbiAqICAgICAucXVlcnkoJ3NpemU9MTAnKVxuICogICAgIC5xdWVyeSh7IGNvbG9yOiAnYmx1ZScgfSlcbiAqXG4gKiBAcGFyYW0ge09iamVjdHxTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLnF1ZXJ5ID0gZnVuY3Rpb24odmFsKSB7XG4gIGlmICh0eXBlb2YgdmFsICE9PSAnc3RyaW5nJykgdmFsID0gc2VyaWFsaXplKHZhbCk7XG4gIGlmICh2YWwpIHRoaXMuX3F1ZXJ5LnB1c2godmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFF1ZXVlIHRoZSBnaXZlbiBgZmlsZWAgYXMgYW4gYXR0YWNobWVudCB0byB0aGUgc3BlY2lmaWVkIGBmaWVsZGAsXG4gKiB3aXRoIG9wdGlvbmFsIGBvcHRpb25zYCAob3IgZmlsZW5hbWUpLlxuICpcbiAqIGBgYCBqc1xuICogcmVxdWVzdC5wb3N0KCcvdXBsb2FkJylcbiAqICAgLmF0dGFjaCgnY29udGVudCcsIG5ldyBCbG9iKFsnPGEgaWQ9XCJhXCI+PGIgaWQ9XCJiXCI+aGV5ITwvYj48L2E+J10sIHsgdHlwZTogXCJ0ZXh0L2h0bWxcIn0pKVxuICogICAuZW5kKGNhbGxiYWNrKTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHBhcmFtIHtCbG9ifEZpbGV9IGZpbGVcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gb3B0aW9uc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmF0dGFjaCA9IGZ1bmN0aW9uKGZpZWxkLCBmaWxlLCBvcHRpb25zKSB7XG4gIGlmIChmaWxlKSB7XG4gICAgaWYgKHRoaXMuX2RhdGEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInN1cGVyYWdlbnQgY2FuJ3QgbWl4IC5zZW5kKCkgYW5kIC5hdHRhY2goKVwiKTtcbiAgICB9XG5cbiAgICB0aGlzLl9nZXRGb3JtRGF0YSgpLmFwcGVuZChmaWVsZCwgZmlsZSwgb3B0aW9ucyB8fCBmaWxlLm5hbWUpO1xuICB9XG5cbiAgcmV0dXJuIHRoaXM7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5fZ2V0Rm9ybURhdGEgPSBmdW5jdGlvbigpIHtcbiAgaWYgKCF0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRoaXMuX2Zvcm1EYXRhID0gbmV3IHJvb3QuRm9ybURhdGEoKTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mb3JtRGF0YTtcbn07XG5cbi8qKlxuICogSW52b2tlIHRoZSBjYWxsYmFjayB3aXRoIGBlcnJgIGFuZCBgcmVzYFxuICogYW5kIGhhbmRsZSBhcml0eSBjaGVjay5cbiAqXG4gKiBAcGFyYW0ge0Vycm9yfSBlcnJcbiAqIEBwYXJhbSB7UmVzcG9uc2V9IHJlc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY2FsbGJhY2sgPSBmdW5jdGlvbihlcnIsIHJlcykge1xuICBpZiAodGhpcy5fc2hvdWxkUmV0cnkoZXJyLCByZXMpKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JldHJ5KCk7XG4gIH1cblxuICBjb25zdCBmbiA9IHRoaXMuX2NhbGxiYWNrO1xuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuXG4gIGlmIChlcnIpIHtcbiAgICBpZiAodGhpcy5fbWF4UmV0cmllcykgZXJyLnJldHJpZXMgPSB0aGlzLl9yZXRyaWVzIC0gMTtcbiAgICB0aGlzLmVtaXQoJ2Vycm9yJywgZXJyKTtcbiAgfVxuXG4gIGZuKGVyciwgcmVzKTtcbn07XG5cbi8qKlxuICogSW52b2tlIGNhbGxiYWNrIHdpdGggeC1kb21haW4gZXJyb3IuXG4gKlxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY3Jvc3NEb21haW5FcnJvciA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IoXG4gICAgJ1JlcXVlc3QgaGFzIGJlZW4gdGVybWluYXRlZFxcblBvc3NpYmxlIGNhdXNlczogdGhlIG5ldHdvcmsgaXMgb2ZmbGluZSwgT3JpZ2luIGlzIG5vdCBhbGxvd2VkIGJ5IEFjY2Vzcy1Db250cm9sLUFsbG93LU9yaWdpbiwgdGhlIHBhZ2UgaXMgYmVpbmcgdW5sb2FkZWQsIGV0Yy4nXG4gICk7XG4gIGVyci5jcm9zc0RvbWFpbiA9IHRydWU7XG5cbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gIGVyci51cmwgPSB0aGlzLnVybDtcblxuICB0aGlzLmNhbGxiYWNrKGVycik7XG59O1xuXG4vLyBUaGlzIG9ubHkgd2FybnMsIGJlY2F1c2UgdGhlIHJlcXVlc3QgaXMgc3RpbGwgbGlrZWx5IHRvIHdvcmtcblJlcXVlc3QucHJvdG90eXBlLmFnZW50ID0gZnVuY3Rpb24oKSB7XG4gIGNvbnNvbGUud2FybignVGhpcyBpcyBub3Qgc3VwcG9ydGVkIGluIGJyb3dzZXIgdmVyc2lvbiBvZiBzdXBlcmFnZW50Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuY2EgPSBSZXF1ZXN0LnByb3RvdHlwZS5hZ2VudDtcblJlcXVlc3QucHJvdG90eXBlLmJ1ZmZlciA9IFJlcXVlc3QucHJvdG90eXBlLmNhO1xuXG4vLyBUaGlzIHRocm93cywgYmVjYXVzZSBpdCBjYW4ndCBzZW5kL3JlY2VpdmUgZGF0YSBhcyBleHBlY3RlZFxuUmVxdWVzdC5wcm90b3R5cGUud3JpdGUgPSAoKSA9PiB7XG4gIHRocm93IG5ldyBFcnJvcihcbiAgICAnU3RyZWFtaW5nIGlzIG5vdCBzdXBwb3J0ZWQgaW4gYnJvd3NlciB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQnXG4gICk7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5waXBlID0gUmVxdWVzdC5wcm90b3R5cGUud3JpdGU7XG5cbi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYSBob3N0IG9iamVjdCxcbiAqIHdlIGRvbid0IHdhbnQgdG8gc2VyaWFsaXplIHRoZXNlIDopXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9iaiBob3N0IG9iamVjdFxuICogQHJldHVybiB7Qm9vbGVhbn0gaXMgYSBob3N0IG9iamVjdFxuICogQGFwaSBwcml2YXRlXG4gKi9cblJlcXVlc3QucHJvdG90eXBlLl9pc0hvc3QgPSBmdW5jdGlvbihvYmopIHtcbiAgLy8gTmF0aXZlIG9iamVjdHMgc3RyaW5naWZ5IHRvIFtvYmplY3QgRmlsZV0sIFtvYmplY3QgQmxvYl0sIFtvYmplY3QgRm9ybURhdGFdLCBldGMuXG4gIHJldHVybiAoXG4gICAgb2JqICYmXG4gICAgdHlwZW9mIG9iaiA9PT0gJ29iamVjdCcgJiZcbiAgICAhQXJyYXkuaXNBcnJheShvYmopICYmXG4gICAgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKG9iaikgIT09ICdbb2JqZWN0IE9iamVjdF0nXG4gICk7XG59O1xuXG4vKipcbiAqIEluaXRpYXRlIHJlcXVlc3QsIGludm9raW5nIGNhbGxiYWNrIGBmbihyZXMpYFxuICogd2l0aCBhbiBpbnN0YW5jZW9mIGBSZXNwb25zZWAuXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gZm5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5lbmQgPSBmdW5jdGlvbihmbikge1xuICBpZiAodGhpcy5fZW5kQ2FsbGVkKSB7XG4gICAgY29uc29sZS53YXJuKFxuICAgICAgJ1dhcm5pbmc6IC5lbmQoKSB3YXMgY2FsbGVkIHR3aWNlLiBUaGlzIGlzIG5vdCBzdXBwb3J0ZWQgaW4gc3VwZXJhZ2VudCdcbiAgICApO1xuICB9XG5cbiAgdGhpcy5fZW5kQ2FsbGVkID0gdHJ1ZTtcblxuICAvLyBzdG9yZSBjYWxsYmFja1xuICB0aGlzLl9jYWxsYmFjayA9IGZuIHx8IG5vb3A7XG5cbiAgLy8gcXVlcnlzdHJpbmdcbiAgdGhpcy5fZmluYWxpemVRdWVyeVN0cmluZygpO1xuXG4gIHRoaXMuX2VuZCgpO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuX3NldFVwbG9hZFRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY29uc3Qgc2VsZiA9IHRoaXM7XG5cbiAgLy8gdXBsb2FkIHRpbWVvdXQgaXQncyB3b2tycyBvbmx5IGlmIGRlYWRsaW5lIHRpbWVvdXQgaXMgb2ZmXG4gIGlmICh0aGlzLl91cGxvYWRUaW1lb3V0ICYmICF0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIpIHtcbiAgICB0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlbGYuX3RpbWVvdXRFcnJvcihcbiAgICAgICAgJ1VwbG9hZCB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3VwbG9hZFRpbWVvdXQsXG4gICAgICAgICdFVElNRURPVVQnXG4gICAgICApO1xuICAgIH0sIHRoaXMuX3VwbG9hZFRpbWVvdXQpO1xuICB9XG59O1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29tcGxleGl0eVxuUmVxdWVzdC5wcm90b3R5cGUuX2VuZCA9IGZ1bmN0aW9uKCkge1xuICBpZiAodGhpcy5fYWJvcnRlZClcbiAgICByZXR1cm4gdGhpcy5jYWxsYmFjayhcbiAgICAgIG5ldyBFcnJvcignVGhlIHJlcXVlc3QgaGFzIGJlZW4gYWJvcnRlZCBldmVuIGJlZm9yZSAuZW5kKCkgd2FzIGNhbGxlZCcpXG4gICAgKTtcblxuICBjb25zdCBzZWxmID0gdGhpcztcbiAgdGhpcy54aHIgPSByZXF1ZXN0LmdldFhIUigpO1xuICBjb25zdCB7IHhociB9ID0gdGhpcztcbiAgbGV0IGRhdGEgPSB0aGlzLl9mb3JtRGF0YSB8fCB0aGlzLl9kYXRhO1xuXG4gIHRoaXMuX3NldFRpbWVvdXRzKCk7XG5cbiAgLy8gc3RhdGUgY2hhbmdlXG4gIHhoci5vbnJlYWR5c3RhdGVjaGFuZ2UgPSAoKSA9PiB7XG4gICAgY29uc3QgeyByZWFkeVN0YXRlIH0gPSB4aHI7XG4gICAgaWYgKHJlYWR5U3RhdGUgPj0gMiAmJiBzZWxmLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgICAgY2xlYXJUaW1lb3V0KHNlbGYuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgICB9XG5cbiAgICBpZiAocmVhZHlTdGF0ZSAhPT0gNCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIEluIElFOSwgcmVhZHMgdG8gYW55IHByb3BlcnR5IChlLmcuIHN0YXR1cykgb2ZmIG9mIGFuIGFib3J0ZWQgWEhSIHdpbGxcbiAgICAvLyByZXN1bHQgaW4gdGhlIGVycm9yIFwiQ291bGQgbm90IGNvbXBsZXRlIHRoZSBvcGVyYXRpb24gZHVlIHRvIGVycm9yIGMwMGMwMjNmXCJcbiAgICBsZXQgc3RhdHVzO1xuICAgIHRyeSB7XG4gICAgICBzdGF0dXMgPSB4aHIuc3RhdHVzO1xuICAgIH0gY2F0Y2gge1xuICAgICAgc3RhdHVzID0gMDtcbiAgICB9XG5cbiAgICBpZiAoIXN0YXR1cykge1xuICAgICAgaWYgKHNlbGYudGltZWRvdXQgfHwgc2VsZi5fYWJvcnRlZCkgcmV0dXJuO1xuICAgICAgcmV0dXJuIHNlbGYuY3Jvc3NEb21haW5FcnJvcigpO1xuICAgIH1cblxuICAgIHNlbGYuZW1pdCgnZW5kJyk7XG4gIH07XG5cbiAgLy8gcHJvZ3Jlc3NcbiAgY29uc3QgaGFuZGxlUHJvZ3Jlc3MgPSAoZGlyZWN0aW9uLCBlKSA9PiB7XG4gICAgaWYgKGUudG90YWwgPiAwKSB7XG4gICAgICBlLnBlcmNlbnQgPSAoZS5sb2FkZWQgLyBlLnRvdGFsKSAqIDEwMDtcblxuICAgICAgaWYgKGUucGVyY2VudCA9PT0gMTAwKSB7XG4gICAgICAgIGNsZWFyVGltZW91dChzZWxmLl91cGxvYWRUaW1lb3V0VGltZXIpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGUuZGlyZWN0aW9uID0gZGlyZWN0aW9uO1xuICAgIHNlbGYuZW1pdCgncHJvZ3Jlc3MnLCBlKTtcbiAgfTtcblxuICBpZiAodGhpcy5oYXNMaXN0ZW5lcnMoJ3Byb2dyZXNzJykpIHtcbiAgICB0cnkge1xuICAgICAgeGhyLmFkZEV2ZW50TGlzdGVuZXIoJ3Byb2dyZXNzJywgaGFuZGxlUHJvZ3Jlc3MuYmluZChudWxsLCAnZG93bmxvYWQnKSk7XG4gICAgICBpZiAoeGhyLnVwbG9hZCkge1xuICAgICAgICB4aHIudXBsb2FkLmFkZEV2ZW50TGlzdGVuZXIoXG4gICAgICAgICAgJ3Byb2dyZXNzJyxcbiAgICAgICAgICBoYW5kbGVQcm9ncmVzcy5iaW5kKG51bGwsICd1cGxvYWQnKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gQWNjZXNzaW5nIHhoci51cGxvYWQgZmFpbHMgaW4gSUUgZnJvbSBhIHdlYiB3b3JrZXIsIHNvIGp1c3QgcHJldGVuZCBpdCBkb2Vzbid0IGV4aXN0LlxuICAgICAgLy8gUmVwb3J0ZWQgaGVyZTpcbiAgICAgIC8vIGh0dHBzOi8vY29ubmVjdC5taWNyb3NvZnQuY29tL0lFL2ZlZWRiYWNrL2RldGFpbHMvODM3MjQ1L3htbGh0dHByZXF1ZXN0LXVwbG9hZC10aHJvd3MtaW52YWxpZC1hcmd1bWVudC13aGVuLXVzZWQtZnJvbS13ZWItd29ya2VyLWNvbnRleHRcbiAgICB9XG4gIH1cblxuICBpZiAoeGhyLnVwbG9hZCkge1xuICAgIHRoaXMuX3NldFVwbG9hZFRpbWVvdXQoKTtcbiAgfVxuXG4gIC8vIGluaXRpYXRlIHJlcXVlc3RcbiAgdHJ5IHtcbiAgICBpZiAodGhpcy51c2VybmFtZSAmJiB0aGlzLnBhc3N3b3JkKSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUsIHRoaXMudXNlcm5hbWUsIHRoaXMucGFzc3dvcmQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUpO1xuICAgIH1cbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgLy8gc2VlICMxMTQ5XG4gICAgcmV0dXJuIHRoaXMuY2FsbGJhY2soZXJyKTtcbiAgfVxuXG4gIC8vIENPUlNcbiAgaWYgKHRoaXMuX3dpdGhDcmVkZW50aWFscykgeGhyLndpdGhDcmVkZW50aWFscyA9IHRydWU7XG5cbiAgLy8gYm9keVxuICBpZiAoXG4gICAgIXRoaXMuX2Zvcm1EYXRhICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdHRVQnICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgIHR5cGVvZiBkYXRhICE9PSAnc3RyaW5nJyAmJlxuICAgICF0aGlzLl9pc0hvc3QoZGF0YSlcbiAgKSB7XG4gICAgLy8gc2VyaWFsaXplIHN0dWZmXG4gICAgY29uc3QgY29udGVudFR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGxldCBzZXJpYWxpemUgPVxuICAgICAgdGhpcy5fc2VyaWFsaXplciB8fFxuICAgICAgcmVxdWVzdC5zZXJpYWxpemVbY29udGVudFR5cGUgPyBjb250ZW50VHlwZS5zcGxpdCgnOycpWzBdIDogJyddO1xuICAgIGlmICghc2VyaWFsaXplICYmIGlzSlNPTihjb250ZW50VHlwZSkpIHtcbiAgICAgIHNlcmlhbGl6ZSA9IHJlcXVlc3Quc2VyaWFsaXplWydhcHBsaWNhdGlvbi9qc29uJ107XG4gICAgfVxuXG4gICAgaWYgKHNlcmlhbGl6ZSkgZGF0YSA9IHNlcmlhbGl6ZShkYXRhKTtcbiAgfVxuXG4gIC8vIHNldCBoZWFkZXIgZmllbGRzXG4gIGZvciAoY29uc3QgZmllbGQgaW4gdGhpcy5oZWFkZXIpIHtcbiAgICBpZiAodGhpcy5oZWFkZXJbZmllbGRdID09PSBudWxsKSBjb250aW51ZTtcblxuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodGhpcy5oZWFkZXIsIGZpZWxkKSlcbiAgICAgIHhoci5zZXRSZXF1ZXN0SGVhZGVyKGZpZWxkLCB0aGlzLmhlYWRlcltmaWVsZF0pO1xuICB9XG5cbiAgaWYgKHRoaXMuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHhoci5yZXNwb25zZVR5cGUgPSB0aGlzLl9yZXNwb25zZVR5cGU7XG4gIH1cblxuICAvLyBzZW5kIHN0dWZmXG4gIHRoaXMuZW1pdCgncmVxdWVzdCcsIHRoaXMpO1xuXG4gIC8vIElFMTEgeGhyLnNlbmQodW5kZWZpbmVkKSBzZW5kcyAndW5kZWZpbmVkJyBzdHJpbmcgYXMgUE9TVCBwYXlsb2FkIChpbnN0ZWFkIG9mIG5vdGhpbmcpXG4gIC8vIFdlIG5lZWQgbnVsbCBoZXJlIGlmIGRhdGEgaXMgdW5kZWZpbmVkXG4gIHhoci5zZW5kKHR5cGVvZiBkYXRhID09PSAndW5kZWZpbmVkJyA/IG51bGwgOiBkYXRhKTtcbn07XG5cbnJlcXVlc3QuYWdlbnQgPSAoKSA9PiBuZXcgQWdlbnQoKTtcblxuWydHRVQnLCAnUE9TVCcsICdPUFRJT05TJywgJ1BBVENIJywgJ1BVVCcsICdERUxFVEUnXS5mb3JFYWNoKG1ldGhvZCA9PiB7XG4gIEFnZW50LnByb3RvdHlwZVttZXRob2QudG9Mb3dlckNhc2UoKV0gPSBmdW5jdGlvbih1cmwsIGZuKSB7XG4gICAgY29uc3QgcmVxID0gbmV3IHJlcXVlc3QuUmVxdWVzdChtZXRob2QsIHVybCk7XG4gICAgdGhpcy5fc2V0RGVmYXVsdHMocmVxKTtcbiAgICBpZiAoZm4pIHtcbiAgICAgIHJlcS5lbmQoZm4pO1xuICAgIH1cblxuICAgIHJldHVybiByZXE7XG4gIH07XG59KTtcblxuQWdlbnQucHJvdG90eXBlLmRlbCA9IEFnZW50LnByb3RvdHlwZS5kZWxldGU7XG5cbi8qKlxuICogR0VUIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5nZXQgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdHRVQnLCB1cmwpO1xuICBpZiAodHlwZW9mIGRhdGEgPT09ICdmdW5jdGlvbicpIHtcbiAgICBmbiA9IGRhdGE7XG4gICAgZGF0YSA9IG51bGw7XG4gIH1cblxuICBpZiAoZGF0YSkgcmVxLnF1ZXJ5KGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBIRUFEIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5oZWFkID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnSEVBRCcsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEucXVlcnkoZGF0YSk7XG4gIGlmIChmbikgcmVxLmVuZChmbik7XG4gIHJldHVybiByZXE7XG59O1xuXG4vKipcbiAqIE9QVElPTlMgcXVlcnkgdG8gYHVybGAgd2l0aCBvcHRpb25hbCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZHxGdW5jdGlvbn0gW2RhdGFdIG9yIGZuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0Lm9wdGlvbnMgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdPUFRJT05TJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBERUxFVEUgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfSBbZGF0YV1cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbmZ1bmN0aW9uIGRlbCh1cmwsIGRhdGEsIGZuKSB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ0RFTEVURScsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEuc2VuZChkYXRhKTtcbiAgaWYgKGZuKSByZXEuZW5kKGZuKTtcbiAgcmV0dXJuIHJlcTtcbn1cblxucmVxdWVzdC5kZWwgPSBkZWw7XG5yZXF1ZXN0LmRlbGV0ZSA9IGRlbDtcblxuLyoqXG4gKiBQQVRDSCBgdXJsYCB3aXRoIG9wdGlvbmFsIGBkYXRhYCBhbmQgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR9IFtkYXRhXVxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5wYXRjaCA9ICh1cmwsIGRhdGEsIGZuKSA9PiB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ1BBVENIJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQT1NUIGB1cmxgIHdpdGggb3B0aW9uYWwgYGRhdGFgIGFuZCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZH0gW2RhdGFdXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0LnBvc3QgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdQT1NUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQVVQgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfEZ1bmN0aW9ufSBbZGF0YV0gb3IgZm5cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbnJlcXVlc3QucHV0ID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnUFVUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcbiJdfQ==","import base64 from 'base64-js';\n\nfunction padding(str) {\n var mod = str.length % 4;\n var pad = 4 - mod;\n\n if (mod === 0) {\n return str;\n }\n\n return str + new Array(1 + pad).join('=');\n}\n\nfunction stringToByteArray(str) {\n var arr = new Array(str.length);\n for (var a = 0; a < str.length; a++) {\n arr[a] = str.charCodeAt(a);\n }\n return arr;\n}\n\nfunction byteArrayToString(array) {\n var result = '';\n for (var i = 0; i < array.length; i++) {\n result += String.fromCharCode(array[i]);\n }\n return result;\n}\n\nfunction encode(str) {\n return base64\n .fromByteArray(stringToByteArray(str))\n .replace(/\\+/g, '-') // Convert '+' to '-'\n .replace(/\\//g, '_'); // Convert '/' to '_'\n}\n\nfunction decode(str) {\n str = padding(str)\n .replace(/-/g, '+') // Convert '-' to '+'\n .replace(/_/g, '/'); // Convert '_' to '/'\n\n return byteArrayToString(base64.toByteArray(str));\n}\n\nexport default {\n encode: encode,\n decode: decode\n};\n","module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","/* eslint-disable no-param-reassign */\nimport request from 'superagent';\nimport base64Url from './base64_url';\nimport version from '../version';\nimport objectHelper from './object';\n\n// ------------------------------------------------ RequestWrapper\n\nfunction RequestWrapper(req) {\n this.request = req;\n this.method = req.method;\n this.url = req.url;\n this.body = req._data;\n this.headers = req._header;\n}\n\nRequestWrapper.prototype.abort = function() {\n this.request.abort();\n};\n\nRequestWrapper.prototype.getMethod = function() {\n return this.method;\n};\n\nRequestWrapper.prototype.getBody = function() {\n return this.body;\n};\n\nRequestWrapper.prototype.getUrl = function() {\n return this.url;\n};\n\nRequestWrapper.prototype.getHeaders = function() {\n return this.headers;\n};\n\n// ------------------------------------------------ RequestObj\n\nfunction RequestObj(req) {\n this.request = req;\n}\n\nRequestObj.prototype.set = function(key, value) {\n this.request = this.request.set(key, value);\n return this;\n};\n\nRequestObj.prototype.send = function(body) {\n this.request = this.request.send(objectHelper.trimUserDetails(body));\n return this;\n};\n\nRequestObj.prototype.withCredentials = function() {\n this.request = this.request.withCredentials();\n return this;\n};\n\nRequestObj.prototype.end = function(cb) {\n this.request.end(cb);\n return new RequestWrapper(this.request);\n};\n\n// ------------------------------------------------ RequestBuilder\n\nfunction RequestBuilder(options) {\n this._sendTelemetry =\n options._sendTelemetry === false ? options._sendTelemetry : true;\n this._telemetryInfo = options._telemetryInfo || null;\n this._timesToRetryFailedRequests = options._timesToRetryFailedRequests;\n this.headers = options.headers || {};\n this._universalLoginPage = options.universalLoginPage;\n}\n\nRequestBuilder.prototype.setCommonConfiguration = function(\n ongoingRequest,\n options\n) {\n options = options || {};\n\n if (this._timesToRetryFailedRequests > 0) {\n ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests);\n }\n\n if (options.noHeaders) {\n return ongoingRequest;\n }\n\n var headers = this.headers;\n ongoingRequest = ongoingRequest.set('Content-Type', 'application/json');\n\n var keys = Object.keys(this.headers);\n\n for (var a = 0; a < keys.length; a++) {\n ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]);\n }\n\n if (this._sendTelemetry) {\n ongoingRequest = ongoingRequest.set(\n 'Auth0-Client',\n this.getTelemetryData()\n );\n }\n\n return ongoingRequest;\n};\n\nRequestBuilder.prototype.getTelemetryData = function() {\n var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js';\n var clientInfo = { name: telemetryName, version: version.raw };\n if (this._telemetryInfo) {\n clientInfo = objectHelper.extend({}, this._telemetryInfo);\n clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env);\n clientInfo.env[telemetryName] = version.raw;\n }\n var jsonClientInfo = JSON.stringify(clientInfo);\n return base64Url.encode(jsonClientInfo);\n};\n\nRequestBuilder.prototype.get = function(url, options) {\n return new RequestObj(this.setCommonConfiguration(request.get(url), options));\n};\n\nRequestBuilder.prototype.post = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.post(url), options)\n );\n};\n\nRequestBuilder.prototype.patch = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.patch(url), options)\n );\n};\n\nexport default RequestBuilder;\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","function DummyStorage() {}\n\nDummyStorage.prototype.getItem = function() {\n return null;\n};\n\nDummyStorage.prototype.removeItem = function() {};\n\nDummyStorage.prototype.setItem = function() {};\n\nexport default DummyStorage;\n","/*!\n * JavaScript Cookie v2.2.1\n * https://github.com/js-cookie/js-cookie\n *\n * Copyright 2006, 2015 Klaus Hartl & Fagner Brack\n * Released under the MIT license\n */\n;(function (factory) {\n\tvar registeredInModuleLoader;\n\tif (typeof define === 'function' && define.amd) {\n\t\tdefine(factory);\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (typeof exports === 'object') {\n\t\tmodule.exports = factory();\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (!registeredInModuleLoader) {\n\t\tvar OldCookies = window.Cookies;\n\t\tvar api = window.Cookies = factory();\n\t\tapi.noConflict = function () {\n\t\t\twindow.Cookies = OldCookies;\n\t\t\treturn api;\n\t\t};\n\t}\n}(function () {\n\tfunction extend () {\n\t\tvar i = 0;\n\t\tvar result = {};\n\t\tfor (; i < arguments.length; i++) {\n\t\t\tvar attributes = arguments[ i ];\n\t\t\tfor (var key in attributes) {\n\t\t\t\tresult[key] = attributes[key];\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction decode (s) {\n\t\treturn s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent);\n\t}\n\n\tfunction init (converter) {\n\t\tfunction api() {}\n\n\t\tfunction set (key, value, attributes) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tattributes = extend({\n\t\t\t\tpath: '/'\n\t\t\t}, api.defaults, attributes);\n\n\t\t\tif (typeof attributes.expires === 'number') {\n\t\t\t\tattributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5);\n\t\t\t}\n\n\t\t\t// We're using \"expires\" because \"max-age\" is not supported by IE\n\t\t\tattributes.expires = attributes.expires ? attributes.expires.toUTCString() : '';\n\n\t\t\ttry {\n\t\t\t\tvar result = JSON.stringify(value);\n\t\t\t\tif (/^[\\{\\[]/.test(result)) {\n\t\t\t\t\tvalue = result;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\n\t\t\tvalue = converter.write ?\n\t\t\t\tconverter.write(value, key) :\n\t\t\t\tencodeURIComponent(String(value))\n\t\t\t\t\t.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n\t\t\tkey = encodeURIComponent(String(key))\n\t\t\t\t.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n\t\t\t\t.replace(/[\\(\\)]/g, escape);\n\n\t\t\tvar stringifiedAttributes = '';\n\t\t\tfor (var attributeName in attributes) {\n\t\t\t\tif (!attributes[attributeName]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tstringifiedAttributes += '; ' + attributeName;\n\t\t\t\tif (attributes[attributeName] === true) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Considers RFC 6265 section 5.2:\n\t\t\t\t// ...\n\t\t\t\t// 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n\t\t\t\t// character:\n\t\t\t\t// Consume the characters of the unparsed-attributes up to,\n\t\t\t\t// not including, the first %x3B (\";\") character.\n\t\t\t\t// ...\n\t\t\t\tstringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n\t\t\t}\n\n\t\t\treturn (document.cookie = key + '=' + value + stringifiedAttributes);\n\t\t}\n\n\t\tfunction get (key, json) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar jar = {};\n\t\t\t// To prevent the for loop in the first place assign an empty array\n\t\t\t// in case there are no cookies at all.\n\t\t\tvar cookies = document.cookie ? document.cookie.split('; ') : [];\n\t\t\tvar i = 0;\n\n\t\t\tfor (; i < cookies.length; i++) {\n\t\t\t\tvar parts = cookies[i].split('=');\n\t\t\t\tvar cookie = parts.slice(1).join('=');\n\n\t\t\t\tif (!json && cookie.charAt(0) === '\"') {\n\t\t\t\t\tcookie = cookie.slice(1, -1);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tvar name = decode(parts[0]);\n\t\t\t\t\tcookie = (converter.read || converter)(cookie, name) ||\n\t\t\t\t\t\tdecode(cookie);\n\n\t\t\t\t\tif (json) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tcookie = JSON.parse(cookie);\n\t\t\t\t\t\t} catch (e) {}\n\t\t\t\t\t}\n\n\t\t\t\t\tjar[name] = cookie;\n\n\t\t\t\t\tif (key === name) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\t\t\t}\n\n\t\t\treturn key ? jar[key] : jar;\n\t\t}\n\n\t\tapi.set = set;\n\t\tapi.get = function (key) {\n\t\t\treturn get(key, false /* read as raw */);\n\t\t};\n\t\tapi.getJSON = function (key) {\n\t\t\treturn get(key, true /* read as json */);\n\t\t};\n\t\tapi.remove = function (key, attributes) {\n\t\t\tset(key, '', extend(attributes, {\n\t\t\t\texpires: -1\n\t\t\t}));\n\t\t};\n\n\t\tapi.defaults = {};\n\n\t\tapi.withConverter = init;\n\n\t\treturn api;\n\t}\n\n\treturn init(function () {});\n}));\n","import Cookie from 'js-cookie';\nimport objectHelper from '../object';\nfunction CookieStorage() {}\n\nCookieStorage.prototype.getItem = function(key) {\n return Cookie.get(key);\n};\n\nCookieStorage.prototype.removeItem = function(key) {\n Cookie.remove(key);\n};\n\nCookieStorage.prototype.setItem = function(key, value, options) {\n var params = objectHelper.extend(\n {\n expires: 1 // 1 day\n },\n options\n );\n Cookie.set(key, value, params);\n};\n\nexport default CookieStorage;\n","/* eslint-disable no-console */\n\nfunction Warn(options) {\n this.disableWarnings = options.disableWarnings;\n}\n\nWarn.prototype.warning = function(message) {\n if (this.disableWarnings) {\n return;\n }\n\n console.warn(message);\n};\n\nexport default Warn;\n","import windowHandler from '../window';\nimport DummyStorage from './dummy';\nimport CookieStorage from './cookie';\nimport Warn from '../warn';\n\nfunction StorageHandler(options) {\n this.warn = new Warn({});\n this.storage = new CookieStorage();\n if (options.__tryLocalStorageFirst !== true) {\n return;\n }\n try {\n // some browsers throw an error when trying to access localStorage\n // when localStorage is disabled.\n var localStorage = windowHandler.getWindow().localStorage;\n if (localStorage) {\n this.storage = localStorage;\n }\n } catch (e) {\n this.warn.warning(e);\n this.warn.warning(\"Can't use localStorage. Using CookieStorage instead.\");\n }\n}\n\nStorageHandler.prototype.failover = function() {\n if (this.storage instanceof DummyStorage) {\n this.warn.warning('DummyStorage: ignore failover');\n return;\n } else if (this.storage instanceof CookieStorage) {\n this.warn.warning('CookieStorage: failing over DummyStorage');\n this.storage = new DummyStorage();\n } else {\n this.warn.warning('LocalStorage: failing over CookieStorage');\n this.storage = new CookieStorage();\n }\n};\n\nStorageHandler.prototype.getItem = function(key) {\n try {\n return this.storage.getItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.getItem(key);\n }\n};\n\nStorageHandler.prototype.removeItem = function(key) {\n try {\n return this.storage.removeItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.removeItem(key);\n }\n};\n\nStorageHandler.prototype.setItem = function(key, value, options) {\n try {\n return this.storage.setItem(key, value, options);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.setItem(key, value, options);\n }\n};\n\nexport default StorageHandler;\n","import StorageHandler from './storage/handler';\n\nfunction Storage(options) {\n this.handler = new StorageHandler(options);\n}\n\nStorage.prototype.getItem = function(key) {\n var value = this.handler.getItem(key);\n try {\n return JSON.parse(value);\n } catch (_) {\n return value;\n }\n};\nStorage.prototype.removeItem = function(key) {\n return this.handler.removeItem(key);\n};\nStorage.prototype.setItem = function(key, value, options) {\n var json = JSON.stringify(value);\n return this.handler.setItem(key, json, options);\n};\n\nexport default Storage;\n","import Storage from './storage';\n\nfunction SSODataStorage(options) {\n this.storage = new Storage(options);\n}\n\nSSODataStorage.prototype.set = function(connection, sub) {\n var ssodata = {\n lastUsedConnection: connection,\n lastUsedSub: sub\n };\n this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata));\n};\nSSODataStorage.prototype.get = function() {\n var ssodata = this.storage.getItem('auth0.ssodata');\n if (!ssodata) {\n return;\n }\n return JSON.parse(ssodata);\n};\n\nexport default SSODataStorage;\n","function buildResponse(error, description) {\n return {\n error: error,\n errorDescription: description\n };\n}\n\nfunction invalidToken(description) {\n return buildResponse('invalid_token', description);\n}\n\nexport default {\n buildResponse: buildResponse,\n invalidToken: invalidToken\n};\n","import error from './error';\nimport objectHelper from './object';\n\nfunction wrapCallback(cb, options) {\n options = options || {};\n options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false;\n\n return function(err, data) {\n var errObj;\n\n if (!err && !data) {\n return cb(error.buildResponse('generic_error', 'Something went wrong'));\n }\n\n if (!err && data.err) {\n err = data.err;\n data = null;\n }\n\n if (!err && data.error) {\n err = data;\n data = null;\n }\n\n if (err) {\n errObj = {\n original: err\n };\n\n objectHelper.updatePropertyOn(\n errObj,\n 'original.response.req._data.password',\n '*****'\n );\n\n if (err.response && err.response.statusCode) {\n errObj.statusCode = err.response.statusCode;\n }\n\n if (err.response && err.response.statusText) {\n errObj.statusText = err.response.statusText;\n }\n\n if (err.response && err.response.body) {\n err = err.response.body;\n }\n\n if (err.err) {\n err = err.err;\n }\n\n errObj.code =\n err.code || err.error || err.error_code || err.status || null;\n\n errObj.description =\n err.errorDescription ||\n err.error_description ||\n err.description ||\n err.error ||\n err.details ||\n err.err ||\n null;\n\n if (options.forceLegacyError) {\n errObj.error = errObj.code;\n errObj.error_description = errObj.description;\n }\n\n if (err.error_codes && err.error_details) {\n errObj.errorDetails = {\n codes: err.error_codes,\n details: err.error_details\n };\n }\n\n if (err.name) {\n errObj.name = err.name;\n }\n\n if (err.policy) {\n errObj.policy = err.policy;\n }\n\n return cb(errObj);\n }\n\n if (\n data.type &&\n (data.type === 'text/html' || data.type === 'text/plain')\n ) {\n return cb(null, data.text);\n }\n\n if (options.ignoreCasing) {\n return cb(null, data.body || data);\n }\n\n return cb(\n null,\n objectHelper.toCamelCase(data.body || data, [], {\n keepOriginal: options.keepOriginalCasing\n })\n );\n };\n}\n\nexport default wrapCallback;\n","// For future reference:,\n// The only parameters that should be allowed are parameters\n// defined by the specification, or existing parameters that we\n// need for compatibility\n\nimport objectHelper from './object';\n\nvar tokenParams = [\n // auth0\n 'realm',\n 'audience',\n 'otp',\n // oauth2\n 'client_id',\n 'client_secret',\n 'redirect_uri',\n 'scope',\n 'code',\n 'grant_type',\n 'username',\n 'password',\n 'refresh_token',\n 'assertion',\n 'client_assertion',\n 'client_assertion_type',\n 'code_verifier'\n];\n\nvar authorizeParams = [\n // auth0\n 'connection',\n 'connection_scope',\n 'auth0Client',\n 'owp',\n 'device',\n 'realm',\n\n 'protocol',\n '_csrf',\n '_intstate',\n 'login_ticket',\n\n // oauth2\n 'client_id',\n 'response_type',\n 'response_mode',\n 'redirect_uri',\n 'audience',\n 'scope',\n 'state',\n 'nonce',\n 'display',\n 'prompt',\n 'screen_hint',\n 'max_age',\n 'ui_locales',\n 'claims_locales',\n 'id_token_hint',\n 'login_hint',\n 'acr_values',\n 'claims',\n 'registration',\n 'request',\n 'request_uri',\n 'code_challenge',\n 'code_challenge_method',\n\n // ADDITIONAL_PARAMETERS:\n // https://auth0.com/docs/api/authentication?javascript#social\n 'access_type',\n 'display'\n];\n\nfunction oauthAuthorizeParams(warn, params) {\n var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams);\n\n if (notAllowed.length > 0) {\n warn.warning(\n 'Following parameters are not allowed on the `/authorize` endpoint: [' +\n notAllowed.join(',') +\n ']'\n );\n }\n\n return params;\n}\n\nfunction oauthTokenParams(warn, params) {\n return objectHelper.pick(params, tokenParams);\n}\n\nexport default {\n oauthTokenParams: oauthTokenParams,\n oauthAuthorizeParams: oauthAuthorizeParams\n};\n","var t=\"undefined\"!=typeof globalThis?globalThis:\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error(\"Dynamic requires are not currently supported by @rollup/plugin-commonjs\")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return\"function\"==typeof t}var r=Array.isArray?Array.isArray:function(t){return\"[object Array]\"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h=\"undefined\"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f=\"undefined\"==typeof self&&\"undefined\"!=typeof process&&\"[object process]\"==={}.toString.call(process),c=\"undefined\"!=typeof Uint8ClampedArray&&\"undefined\"!=typeof importScripts&&\"undefined\"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error(\"Malformed UTF-8 data\")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){\"string\"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)}),o=e(function(t,e){var r,n;t.exports=(r=(n=i).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join(\"\")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\"},n.enc.Base64)}),s=e(function(t,e){t.exports=i.enc.Hex}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&(\"number\"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&\"string\"!=typeof t?256:e))}function i(){return new r(null)}var n=\"undefined\"!=typeof navigator;n&&\"Microsoft Internet Explorer\"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&\"Netscape\"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?\"-\"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return\"-\"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:\"0\"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return\"0\";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h=\"\";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if(\"number\"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error(\"Invalid key data\");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\\s\\n]]/gi,\"\");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error(\"Signature does not match with the key modulus.\");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,\"\"));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error(\"Hashing algorithm is not supported.\");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,d=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",m=0,v=d.length;m0)throw new Error(\"Invalid string. Length must be a multiple of 4\");var r=t.indexOf(\"=\");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join(\"=\")}function w(t){return t=g(t).replace(/\\-/g,\"+\").replace(/_/g,\"/\"),decodeURIComponent(function(t){for(var e=\"\",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\\/\\/\\//)?t[0].replace(/^([^/:]+):\\/*/,\"$1:///\"):t[0].replace(/^([^/:]+):\\/*/,\"$1://\");for(var i=0;i0&&(n=n.replace(/^[\\/]+/,\"\")),n=n.replace(/[\\/]+$/,i0?\"?\":\"\")+s.join(\"&\")}return function(){return t(\"object\"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||\"get\",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\\S\\n]*([\\s\\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+\",\"+r:r}),r(a())},n.onerror=i,n.withCredentials=\"include\"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name=\"ConfigurationError\",this.message=t||\"\"}function A(t){this.name=\"TokenValidationError\",this.message=t||\"\"}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return\"number\"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||\"RS256\",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock=\"function\"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D(\"The leeway should be positive and lower than five minutes.\");if(\"RS256\"!==this.expectedAlg)throw new D('Signature algorithm of \"'+this.expectedAlg+'\" is not supported. Expected the ID token to be signed with \"RS256\".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A(\"ID token is required but missing\"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A(\"ID token could not be decoded\"),!1);var n=i.encoded.header+\".\"+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of \"'+s+'\" is not supported. Expected the ID token to be signed with \"RS256\".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A(\"Invalid ID token signature.\"));if(!f||\"string\"!=typeof f)return r(new A(\"Issuer (iss) claim must be a string present in the ID token\",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected \"'+g.issuer+'\", found \"'+f+'\"'),!1);if(!u||\"string\"!=typeof u)return r(new A(\"Subject (sub) claim must be a string present in the ID token\"),!1);if(!a||\"string\"!=typeof a&&!Array.isArray(a))return r(new A(\"Audience (aud) claim must be a string or array of strings present in the ID token\"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but was not one of \"'+a.join(\", \")+'\"'));if(\"string\"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but found \"'+a+'\"'),!1);if(e){if(!v||\"string\"!=typeof v)return r(new A(\"Nonce (nonce) claim must be a string present in the ID token\"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected \"'+e+'\", found \"'+v+'\"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||\"string\"!=typeof d)return r(new A(\"Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values\",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected \"'+g.audience+'\", found \"'+d+'\"',!1))}if(!c||!x(c))return r(new A(\"Expiration Time (exp) claim must be a number present in the ID token\",!1));if(!l||!x(l))return r(new A(\"Issued At (iat) claim must be a number present in the ID token\"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time \"'+y+'\" is after expiration time \"'+w+'\"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time \"'+y+'\" is after last auth time at \"'+S+'\"'))}return r(null,i.payload)})},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},(\"undefined\"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,\".well-known\",\"jwks.json\")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11\n else if (ua.indexOf(\"Trident\") > -1) {\n var re = new RegExp(\"rv:([0-9]{2,2}[\\.0-9]{0,})\");\n if (re.exec(ua) !== null) {\n rv = parseFloat(RegExp.$1);\n }\n }\n\n return rv >= 8;\n }\n\n // checking Mobile Firefox (Fennec)\n function isFennec() {\n try {\n // We must check for both XUL and Java versions of Fennec. Both have\n // distinct UA strings.\n var userAgent = navigator.userAgent;\n return (userAgent.indexOf('Fennec/') != -1) || // XUL\n (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java\n } catch(e) {}\n return false;\n }\n\n // feature checking to see if this platform is supported at all\n function isSupported() {\n return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify &&\n window.JSON.parse && window.postMessage);\n }\n\n // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\n function extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[\\-_a-zA-Z\\.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n }\n\n // find the relay iframe in the opener\n function findRelay() {\n var loc = window.location;\n var frames = window.opener.frames;\n for (var i = frames.length - 1; i >= 0; i--) {\n try {\n if (frames[i].location.protocol === window.location.protocol &&\n frames[i].location.host === window.location.host &&\n frames[i].name === RELAY_FRAME_NAME)\n {\n return frames[i];\n }\n } catch(e) { }\n }\n return;\n }\n\n var isIE = isInternetExplorer();\n\n if (isSupported()) {\n /* General flow:\n * 0. user clicks\n * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM\n * 2. caller opens window (with content from trusted domain)\n * 3. window on opening adds a listener to 'message'\n * (IE SPECIFIC) 4. window on opening finds iframe\n * 5. window checks if iframe is \"loaded\" - has a 'doPost' function yet\n * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller\n * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready\n * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event\n * 6. caller upon reciept of 'ready', sends args\n */\n return {\n open: function(opts, cb) {\n if (!cb) throw \"missing required callback argument\";\n\n // test required options\n var err;\n if (!opts.url) err = \"missing required 'url' parameter\";\n if (!opts.relay_url) err = \"missing required 'relay_url' parameter\";\n if (err) setTimeout(function() { cb(err); }, 0);\n\n // supply default options\n if (!opts.window_name) opts.window_name = null;\n if (!opts.window_features || isFennec()) opts.window_features = undefined;\n\n // opts.params may be undefined\n\n var iframe;\n\n // sanity check, are url and relay_url the same origin?\n var origin = opts.origin || extractOrigin(opts.url);\n if (origin !== extractOrigin(opts.relay_url)) {\n return setTimeout(function() {\n cb('invalid arguments: origin of url and relay_url must match');\n }, 0);\n }\n\n var messageTarget;\n\n if (isIE) {\n // first we need to add a \"relay\" iframe to the document that's served\n // from the target domain. We can postmessage into a iframe, but not a\n // window\n iframe = document.createElement(\"iframe\");\n // iframe.setAttribute('name', framename);\n iframe.setAttribute('src', opts.relay_url);\n iframe.style.display = \"none\";\n iframe.setAttribute('name', RELAY_FRAME_NAME);\n document.body.appendChild(iframe);\n messageTarget = iframe.contentWindow;\n }\n\n var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features);\n if (opts.popup) {\n w.location.href = opts.url;\n }\n\n if (!messageTarget) messageTarget = w;\n\n // lets listen in case the window blows up before telling us\n var closeInterval = setInterval(function() {\n if (w && w.closed) {\n cleanup();\n if (cb) {\n cb('User closed the popup window');\n cb = null;\n }\n }\n }, 500);\n\n var req = JSON.stringify({a: 'request', d: opts.params});\n\n // cleanup on unload\n function cleanup() {\n if (iframe) document.body.removeChild(iframe);\n iframe = undefined;\n if (closeInterval) closeInterval = clearInterval(closeInterval);\n removeListener(window, 'message', onMessage);\n removeListener(window, 'unload', cleanup);\n if (w) {\n try {\n w.close();\n } catch (securityViolation) {\n // This happens in Opera 12 sometimes\n // see https://github.com/mozilla/browserid/issues/1844\n messageTarget.postMessage(CLOSE_CMD, origin);\n }\n }\n w = messageTarget = undefined;\n }\n\n addListener(window, 'unload', cleanup);\n\n function onMessage(e) {\n if (e.origin !== origin) { return; }\n try {\n var d = JSON.parse(e.data);\n } catch(err) {\n if (cb) {\n return cb(err);\n } else {\n throw err;\n }\n }\n\n if (d.a === 'ready') {\n messageTarget.postMessage(req, origin);\n } else if (d.a === 'error') {\n cleanup();\n if (cb) {\n cb(d.d);\n cb = null;\n }\n } else if (d.a === 'response') {\n cleanup();\n if (cb) {\n cb(null, d.d);\n cb = null;\n }\n }\n }\n\n addListener(window, 'message', onMessage);\n\n return {\n originalPopup: w,\n close: cleanup,\n focus: function() {\n if (w) {\n try {\n w.focus();\n } catch (e) {\n // IE7 blows up here, do nothing\n }\n }\n }\n };\n },\n onOpen: function(cb) {\n var o = \"*\";\n var msgTarget = isIE ? findRelay() : window.opener;\n if (!msgTarget) throw \"can't find relay frame\";\n function doPost(msg) {\n msg = JSON.stringify(msg);\n if (isIE) msgTarget.doPost(msg, o);\n else msgTarget.postMessage(msg, o);\n }\n\n function onMessage(e) {\n // only one message gets through, but let's make sure it's actually\n // the message we're looking for (other code may be using\n // postmessage) - we do this by ensuring the payload can\n // be parsed, and it's got an 'a' (action) value of 'request'.\n var d;\n try {\n d = JSON.parse(e.data);\n } catch(err) { }\n if (!d || d.a !== 'request') return;\n removeListener(window, 'message', onMessage);\n o = e.origin;\n if (cb) {\n // this setTimeout is critically important for IE8 -\n // in ie8 sometimes addListener for 'message' can synchronously\n // cause your callback to be invoked. awesome.\n setTimeout(function() {\n cb(o, d.d, function(r) {\n cb = undefined;\n doPost({a: 'response', d: r});\n });\n }, 0);\n }\n }\n\n function onDie(e) {\n if (e.data === CLOSE_CMD) {\n try { window.close(); } catch (o_O) {}\n }\n }\n addListener(isIE ? msgTarget : window, 'message', onMessage);\n addListener(isIE ? msgTarget : window, 'message', onDie);\n\n // we cannot post to our parent that we're ready before the iframe\n // is loaded. (IE specific possible failure)\n try {\n doPost({a: \"ready\"});\n } catch(e) {\n // this code should never be exectued outside IE\n addListener(msgTarget, 'load', function(e) {\n doPost({a: \"ready\"});\n });\n }\n\n // if window is unloaded and the client hasn't called cb, it's an error\n var onUnload = function() {\n try {\n // IE8 doesn't like this...\n removeListener(isIE ? msgTarget : window, 'message', onDie);\n } catch (ohWell) { }\n if (cb) doPost({ a: 'error', d: 'client closed window' });\n cb = undefined;\n // explicitly close the window, in case the client is trying to reload or nav\n try { window.close(); } catch (e) { }\n };\n addListener(window, 'unload', onUnload);\n return {\n detach: function() {\n removeListener(window, 'unload', onUnload);\n }\n };\n }\n };\n } else {\n return {\n open: function(url, winopts, arg, cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n },\n onOpen: function(cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n }\n };\n }\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n module.exports = WinChan;\n}\n","// given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\nfunction extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[-_a-zA-Z.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n}\n\nexport default {\n extractOrigin: extractOrigin\n};\n","/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\nimport WinChan from 'winchan';\n\nimport windowHandler from './window';\nimport objectHelper from './object';\nimport qs from 'qs';\n\nfunction PopupHandler() {\n this._current_popup = null;\n}\n\nPopupHandler.prototype.calculatePosition = function(options) {\n var width = options.width || 500;\n var height = options.height || 600;\n var _window = windowHandler.getWindow();\n\n var screenX =\n typeof _window.screenX !== 'undefined'\n ? _window.screenX\n : _window.screenLeft;\n var screenY =\n typeof _window.screenY !== 'undefined'\n ? _window.screenY\n : _window.screenTop;\n\n var outerWidth =\n typeof _window.outerWidth !== 'undefined'\n ? _window.outerWidth\n : _window.document.body.clientWidth;\n\n var outerHeight =\n typeof _window.outerHeight !== 'undefined'\n ? _window.outerHeight\n : _window.document.body.clientHeight;\n\n var left = options.left || screenX + (outerWidth - width) / 2;\n var top = options.top || screenY + (outerHeight - height) / 2;\n\n return { width: width, height: height, left: left, top: top };\n};\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n var url = options.url || 'about:blank';\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures);\n\n this._current_popup.kill = function() {\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, relayUrl, options, cb) {\n var _this = this;\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n\n var winchanOptions = objectHelper\n .merge({\n url: url,\n relay_url: relayUrl,\n window_features: qs.stringify(popupOptions, {\n delimiter: ',',\n encode: false\n }),\n popup: this._current_popup\n })\n .with(options);\n\n var popup = WinChan.open(winchanOptions, function(err, data) {\n // Ignores messages sent by browser extensions.\n if (err && err.name === 'SyntaxError') {\n return;\n }\n _this._current_popup = null;\n return cb(err, data);\n });\n\n popup.focus();\n\n return popup;\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport WinChan from 'winchan';\n\nimport urlHelper from '../helper/url';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\nimport PopupHandler from '../helper/popup-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport TransactionManager from './transaction-manager';\nimport CrossOriginAuthentication from './cross-origin-authentication';\n\nfunction Popup(webAuth, options) {\n this.baseOptions = options;\n this.baseOptions.popupOrigin = options.popupOrigin;\n this.client = webAuth.client;\n this.webAuth = webAuth;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n webAuth,\n this.baseOptions\n );\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * Returns a new instance of the popup handler\n *\n * @method buildPopupHandler\n * @private\n */\nPopup.prototype.buildPopupHandler = function() {\n var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler');\n\n if (pluginHandler) {\n return pluginHandler.getPopupHandler();\n }\n\n return new PopupHandler();\n};\n\n/**\n * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser.\n *\n * @method preload\n * @param {Object} options receives the window height and width and any other window feature to be sent to window.open\n */\nPopup.prototype.preload = function(options) {\n options = options || {};\n\n var popup = this.buildPopupHandler();\n\n popup.preload(options);\n return popup;\n};\n\n/**\n * Internal use.\n *\n * @method getPopupHandler\n * @private\n */\nPopup.prototype.getPopupHandler = function(options, preload) {\n if (options.popupHandler) {\n return options.popupHandler;\n }\n\n if (preload) {\n return this.preload(options);\n }\n\n return this.buildPopupHandler();\n};\n\n/**\n * Handles the popup logic for the callback page.\n *\n * @method callback\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @see {@link parseHash}\n */\nPopup.prototype.callback = function(options) {\n var _this = this;\n var theWindow = windowHelper.getWindow();\n options = options || {};\n var originUrl =\n options.popupOrigin ||\n this.baseOptions.popupOrigin ||\n windowHelper.getOrigin();\n\n /*\n in IE 11, there's a bug that makes window.opener return undefined.\n The callback page will still call `popup.callback()` which will run this method\n in the relay page. WinChan expects the relay page to have a global `doPost` function,\n which will be called with the response.\n\n IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/\n */\n if (!theWindow.opener) {\n theWindow.doPost = function(msg) {\n if (theWindow.parent) {\n theWindow.parent.postMessage(msg, originUrl);\n }\n };\n return;\n }\n\n WinChan.onOpen(function(popupOrigin, r, cb) {\n if (popupOrigin !== originUrl) {\n return cb({\n error: 'origin_mismatch',\n error_description:\n \"The popup's origin (\" +\n popupOrigin +\n ') should match the `popupOrigin` parameter (' +\n originUrl +\n ').'\n });\n }\n _this.webAuth.parseHash(options || {}, function(err, data) {\n return cb(err || data);\n });\n });\n};\n\n/**\n * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`.\n *\n * @method authorize\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response.\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nPopup.prototype.authorize = function(options, cb) {\n var popup;\n var url;\n var relayUrl;\n var popOpts = {};\n\n var pluginHandler = this.baseOptions.plugins.get('popup.authorize');\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'scope',\n 'domain',\n 'audience',\n 'tenant',\n 'responseType',\n 'redirectUri',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(objectHelper.blacklist(options, ['popupHandler']));\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n // the relay page should not be necessary as long it happens in the same domain\n // (a redirectUri shoul be provided). It is necessary when using OWP\n relayUrl = urljoin(this.baseOptions.rootUrl, 'relay.html');\n\n // if a owp is enabled, it should use the owp flag\n if (options.owp) {\n // used by server to render the relay page instead of sending the chunk in the\n // url to the callback\n params.owp = true;\n } else {\n popOpts.origin = urlHelper.extractOrigin(params.redirectUri);\n relayUrl = params.redirectUri;\n }\n\n if (options.popupOptions) {\n popOpts.popupOptions = objectHelper.pick(options.popupOptions, [\n 'width',\n 'height',\n 'top',\n 'left'\n ]);\n }\n\n if (pluginHandler) {\n params = pluginHandler.processParams(params);\n }\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n delete params.domain;\n\n url = this.client.buildAuthorizeUrl(params);\n\n popup = this.getPopupHandler(options);\n\n return popup.load(\n url,\n relayUrl,\n popOpts,\n responseHandler(cb, { keepOriginalCasing: true })\n );\n};\n\n/**\n * Performs authentication with username/email and password with a database connection inside a new window\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method loginWithCredentials\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`.\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nPopup.prototype.loginWithCredentials = function(options, cb) {\n options.realm = options.realm || options.connection;\n options.popup = true;\n options = objectHelper\n .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce'])\n .with(objectHelper.blacklist(options, ['popupHandler', 'connection']));\n options = this.transactionManager.process(options);\n this.crossOriginAuthentication.login(options, cb);\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nPopup.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n return this.client.passwordless.verify(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n\n options.username = options.phoneNumber || options.email;\n options.password = options.verificationCode;\n\n delete options.email;\n delete options.phoneNumber;\n delete options.verificationCode;\n delete options.type;\n\n _this.client.loginWithResourceOwner(options, cb);\n }\n );\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link signupAndAuthorize}.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nPopup.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n _this.loginWithCredentials(options, cb);\n });\n};\n\nexport default Popup;\n","import IframeHandler from '../helper/iframe-handler';\nimport windowHelper from '../helper/window';\n\nfunction SilentAuthenticationHandler(options) {\n this.authenticationUrl = options.authenticationUrl;\n this.timeout = options.timeout || 60 * 1000;\n this.handler = null;\n this.postMessageDataType = options.postMessageDataType || false;\n\n // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually\n this.postMessageOrigin =\n options.postMessageOrigin ||\n windowHelper.getWindow().location.origin ||\n windowHelper.getWindow().location.protocol +\n '//' +\n windowHelper.getWindow().location.hostname +\n (windowHelper.getWindow().location.port\n ? ':' + windowHelper.getWindow().location.port\n : '');\n}\n\nSilentAuthenticationHandler.create = function(options) {\n return new SilentAuthenticationHandler(options);\n};\n\nSilentAuthenticationHandler.prototype.login = function(\n usePostMessage,\n callback\n) {\n this.handler = new IframeHandler({\n auth0: this.auth0,\n url: this.authenticationUrl,\n eventListenerType: usePostMessage ? 'message' : 'load',\n callback: this.getCallbackHandler(callback, usePostMessage),\n timeout: this.timeout,\n eventValidator: this.getEventValidator(),\n timeoutCallback: function() {\n callback(\n null,\n '#error=timeout&error_description=Timeout+during+authentication+renew.'\n );\n },\n usePostMessage: usePostMessage || false\n });\n\n this.handler.init();\n};\n\nSilentAuthenticationHandler.prototype.getEventValidator = function() {\n var _this = this;\n return {\n isValid: function(eventData) {\n switch (eventData.event.type) {\n case 'message':\n // Message must come from the expected origin and iframe window.\n if (\n eventData.event.origin !== _this.postMessageOrigin ||\n eventData.event.source !== _this.handler.iframe.contentWindow\n ) {\n return false;\n }\n\n // Default behaviour, return all message events from the iframe.\n if (_this.postMessageDataType === false) {\n return true;\n }\n\n return (\n eventData.event.data.type &&\n eventData.event.data.type === _this.postMessageDataType\n );\n\n case 'load':\n if (\n eventData.sourceObject.contentWindow.location.protocol === 'about:'\n ) {\n // Chrome is automatically loading the about:blank page, we ignore this.\n return false;\n }\n // Fall through to default\n default:\n return true;\n }\n }\n };\n};\n\nSilentAuthenticationHandler.prototype.getCallbackHandler = function(\n callback,\n usePostMessage\n) {\n return function(eventData) {\n var callbackValue;\n if (!usePostMessage) {\n callbackValue = eventData.sourceObject.contentWindow.location.hash;\n } else if (\n typeof eventData.event.data === 'object' &&\n eventData.event.data.hash\n ) {\n callbackValue = eventData.event.data.hash;\n } else {\n callbackValue = eventData.event.data;\n }\n callback(null, callbackValue);\n };\n};\n\nexport default SilentAuthenticationHandler;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport windowHelper from '../helper/window';\nimport TransactionManager from './transaction-manager';\n\nfunction UsernamePassword(options) {\n this.baseOptions = options;\n this.request = new RequestBuilder(options);\n this.transactionManager = new TransactionManager(this.baseOptions);\n}\n\nUsernamePassword.prototype.login = function(options, cb) {\n var url;\n var body;\n\n url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'login');\n\n options.username = options.username || options.email; // eslint-disable-line\n\n options = objectHelper.blacklist(options, ['email']); // eslint-disable-line\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience'\n ])\n .with(options);\n body = this.transactionManager.process(body);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nUsernamePassword.prototype.callback = function(formHtml) {\n var div;\n var form;\n var _document = windowHelper.getDocument();\n\n div = _document.createElement('div');\n div.innerHTML = formHtml;\n form = _document.body.appendChild(div).children[0];\n\n form.submit();\n};\n\nexport default UsernamePassword;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport UsernamePassword from './username-password';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport assert from '../helper/assert';\n\nfunction HostedPages(client, options) {\n this.baseOptions = options;\n this.client = client;\n this.baseOptions.universalLoginPage = true;\n this.request = new RequestBuilder(this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * @callback credentialsCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the AuthN request\n * @param {String} result.accessToken token that can be used with {@link userinfo}\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Performs authentication with username/email and password with a database connection\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method login\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.login = function(options, cb) {\n if (windowHelper.getWindow().location.host !== this.baseOptions.domain) {\n throw new Error(\n 'This method is meant to be used only inside the Universal Login Page.'\n );\n }\n var usernamePassword;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n usernamePassword = new UsernamePassword(this.baseOptions);\n return usernamePassword.login(params, function(err, data) {\n if (err) {\n return cb(err);\n }\n return usernamePassword.callback(data);\n });\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n return _this.client.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n return _this.login(options, cb);\n });\n};\n\nHostedPages.prototype.getSSOData = function(withActiveDirectories, cb) {\n var url;\n var params = '';\n\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n withActiveDirectories = false;\n }\n\n assert.check(withActiveDirectories, {\n type: 'boolean',\n message: 'withActiveDirectories parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (withActiveDirectories) {\n params =\n '?' +\n qs.stringify({\n ldaps: 1,\n client_id: this.baseOptions.clientID\n });\n }\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'ssodata', params);\n\n return this.request\n .get(url, { noHeaders: true })\n .withCredentials()\n .end(responseHandler(cb));\n};\n\nexport default HostedPages;\n","// eslint-disable-next-line no-unused-vars\nimport Authentication from '../authentication';\nimport object from '../helper/object';\n\nvar noop = function () { };\n\nvar defaults = {\n lang: 'en',\n templates: {\n 'auth0': function (challenge) {\n var message = challenge.type === 'code' ?\n 'Enter the code shown above' :\n 'Solve the formula shown above';\n return '
\\n' +\n ' \\n' +\n ' \\n' +\n '
\\n' +\n '';\n }\n ,\n 'recaptcha_v2': function () {\n return '
';\n }\n ,\n 'error': function () {\n return '
Error getting the bot detection challenge. Please contact the system administrator.
'\n }\n }\n};\n\nfunction handleAuth0Provider(element, options, challenge, load) {\n element.innerHTML = options.templates[challenge.provider](challenge);\n element.querySelector('.captcha-reload').addEventListener('click', function (e) {\n e.preventDefault();\n load();\n });\n}\n\nfunction injectRecaptchaScript(element, lang, callback) {\n var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001);\n window[callbackName] = function () {\n delete window[callbackName];\n callback();\n };\n var script = window.document.createElement('script');\n script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName;\n script.async = true;\n window.document.body.appendChild(script);\n}\n\nfunction handleRecaptchaProvider(element, options, challenge) {\n var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid');\n\n function setValue(value) {\n var input = element.querySelector('input[name=\"captcha\"]');\n input.value = value || '';\n }\n\n if (widgetId) {\n setValue();\n window.grecaptcha.reset(widgetId);\n return;\n }\n\n element.innerHTML = options.templates[challenge.provider](challenge);\n\n var recaptchaDiv = element.querySelector('.recaptcha');\n\n injectRecaptchaScript(element, options.lang, function () {\n widgetId = window.grecaptcha.render(recaptchaDiv, {\n callback: setValue,\n 'expired-callback': function () { setValue(); },\n 'error-callback': function () { setValue(); },\n sitekey: challenge.siteKey\n });\n element.setAttribute('data-wid', widgetId)\n });\n}\n\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n *\n * @param {Authentication} auth0Client The challenge response from the authentication server\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha*\n * @param {Function} [callback] an optional callback function\n */\nfunction render(auth0Client, element, options, callback) {\n options = object.merge(defaults).with(options || {});\n\n function load(done) {\n done = done || noop;\n auth0Client.getChallenge(function (err, challenge) {\n if (err) {\n element.innerHTML = options.templates.error(err);\n return done(err);\n }\n if (!challenge.required) {\n element.style.display = 'none';\n element.innerHTML = '';\n return;\n }\n element.style.display = '';\n if (challenge.provider === 'auth0') {\n handleAuth0Provider(element, options, challenge, load);\n } else if (challenge.provider === 'recaptcha_v2') {\n handleRecaptchaProvider(element, options, challenge);\n }\n done();\n });\n }\n\n function getValue() {\n var captchaInput = element.querySelector('input[name=\"captcha\"]');\n if (!captchaInput) { return; }\n return captchaInput.value;\n }\n\n load(callback);\n\n return {\n reload: load,\n getValue: getValue\n };\n}\n\nexport default { render: render };\n","import IdTokenVerifier from 'idtoken-verifier';\nimport qs from 'qs';\n\nimport assert from '../helper/assert';\nimport error from '../helper/error';\nimport PluginHandler from '../helper/plugins';\nimport windowHelper from '../helper/window';\nimport objectHelper from '../helper/object';\nimport SSODataStorage from '../helper/ssodata';\nimport responseHandler from '../helper/response-handler';\nimport TransactionManager from './transaction-manager';\nimport Authentication from '../authentication';\nimport Redirect from './redirect';\nimport Popup from './popup';\nimport SilentAuthenticationHandler from './silent-authentication-handler';\nimport CrossOriginAuthentication from './cross-origin-authentication';\nimport WebMessageHandler from './web-message-handler';\nimport HostedPages from './hosted-pages';\nimport captcha from './captcha';\n\nfunction defaultClock() {\n return new Date();\n}\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds.\n * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server.\n * @param {Array} [options.plugins]\n * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js}\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction WebAuth(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n popupOrigin: {\n optional: true,\n type: 'string',\n message: 'popupOrigin is not valid'\n },\n leeway: {\n optional: true,\n type: 'number',\n message: 'leeway is not valid'\n },\n plugins: {\n optional: true,\n type: 'array',\n message: 'plugins is not valid'\n },\n maxAge: {\n optional: true,\n type: 'number',\n message: 'maxAge is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n _timesToRetryFailedRequests: {\n optional: true,\n type: 'number',\n message: '_timesToRetryFailedRequests option is not valid'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(\n options.overrides,\n { type: 'object', message: 'overrides option is not valid' },\n {\n __tenant: {\n optional: true,\n type: 'string',\n message: '__tenant option is required'\n },\n __token_issuer: {\n optional: true,\n type: 'string',\n message: '__token_issuer option is required'\n },\n __jwks_uri: {\n optional: true,\n type: 'string',\n message: '__jwks_uri is required'\n }\n }\n );\n }\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions.plugins = new PluginHandler(\n this,\n this.baseOptions.plugins || []\n );\n\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n\n this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests\n ? parseInt(options._timesToRetryFailedRequests, 0)\n : 0;\n\n this.baseOptions.tenant =\n (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) ||\n this.baseOptions.domain.split('.')[0];\n\n this.baseOptions.token_issuer =\n (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) ||\n 'https://' + this.baseOptions.domain + '/';\n\n this.baseOptions.jwksURI =\n this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n\n this.client = new Authentication(this.baseOptions);\n this.redirect = new Redirect(this, this.baseOptions);\n this.popup = new Popup(this, this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n this,\n this.baseOptions\n );\n this.webMessageHandler = new WebMessageHandler(this);\n this._universalLogin = new HostedPages(this, this.baseOptions);\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method parseHash\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType.\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.parseHash = function(options, cb) {\n var parsedQs;\n var err;\n\n if (!cb && typeof options === 'function') {\n cb = options;\n options = {};\n } else {\n options = options || {};\n }\n\n var _window = windowHelper.getWindow();\n\n var hashStr =\n options.hash === undefined ? _window.location.hash : options.hash;\n hashStr = hashStr.replace(/^#?\\/?/, '');\n\n parsedQs = qs.parse(hashStr);\n\n if (parsedQs.hasOwnProperty('error')) {\n err = error.buildResponse(parsedQs.error, parsedQs.error_description);\n\n if (parsedQs.state) {\n err.state = parsedQs.state;\n }\n\n return cb(err);\n }\n\n if (\n !parsedQs.hasOwnProperty('access_token') &&\n !parsedQs.hasOwnProperty('id_token') &&\n !parsedQs.hasOwnProperty('refresh_token')\n ) {\n return cb(null, null);\n }\n var responseTypes = (\n this.baseOptions.responseType ||\n options.responseType ||\n ''\n ).split(' ');\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('token') !== -1 &&\n !parsedQs.hasOwnProperty('access_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `token`, but the parsed hash does not contain an `access_token` property'\n )\n );\n }\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('id_token') !== -1 &&\n !parsedQs.hasOwnProperty('id_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property'\n )\n );\n }\n return this.validateAuthenticationResponse(options, parsedQs, cb);\n};\n\n/**\n * Validates an Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method validateAuthenticationResponse\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {Object} parsedHash an object that represents the parsed hash\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.validateAuthenticationResponse = function(\n options,\n parsedHash,\n cb\n) {\n var _this = this;\n options.__enableIdPInitiatedLogin =\n options.__enableIdPInitiatedLogin || options.__enableImpersonation;\n var state = parsedHash.state;\n var transaction = this.transactionManager.getStoredTransaction(state);\n var transactionState =\n options.state || (transaction && transaction.state) || null;\n\n var transactionStateMatchesState = transactionState === state;\n var shouldBypassStateChecking =\n !state && !transactionState && options.__enableIdPInitiatedLogin;\n\n if (!shouldBypassStateChecking && !transactionStateMatchesState) {\n return cb({\n error: 'invalid_token',\n errorDescription: '`state` does not match.'\n });\n }\n var transactionNonce =\n options.nonce || (transaction && transaction.nonce) || null;\n\n var appState = options.state || (transaction && transaction.appState) || null;\n\n var callback = function(err, payload) {\n if (err) {\n return cb(err);\n }\n if (transaction && transaction.lastUsedConnection) {\n var sub;\n if (payload) {\n sub = payload.sub;\n }\n _this.ssodataStorage.set(transaction.lastUsedConnection, sub);\n }\n return cb(null, buildParseHashResponse(parsedHash, appState, payload));\n };\n\n if (!parsedHash.id_token) {\n return callback(null, null);\n }\n return this.validateToken(parsedHash.id_token, transactionNonce, function(\n validationError,\n payload\n ) {\n if (!validationError) {\n if (!parsedHash.access_token) {\n return callback(null, payload);\n }\n // id_token's generated by non-oidc applications don't have at_hash\n if (!payload.at_hash) {\n return callback(null, payload);\n }\n // here we're absolutely sure that the id_token's alg is RS256\n // and that the id_token is valid, so we can check the access_token\n return new IdTokenVerifier().validateAccessToken(\n parsedHash.access_token,\n 'RS256',\n payload.at_hash,\n function(err) {\n if (err) {\n return callback(error.invalidToken(err.message));\n }\n return callback(null, payload);\n }\n );\n }\n\n if (\n validationError.error !== 'invalid_token' ||\n (validationError.errorDescription &&\n validationError.errorDescription.indexOf(\n 'Nonce (nonce) claim value mismatch in the ID token'\n ) > -1)\n ) {\n return callback(validationError);\n }\n\n // if it's an invalid_token error, decode the token\n var decodedToken = new IdTokenVerifier().decode(parsedHash.id_token);\n\n // if the alg is not HS256, return the raw error\n if (decodedToken.header.alg !== 'HS256') {\n return callback(validationError);\n }\n\n if ((decodedToken.payload.nonce || null) !== transactionNonce) {\n return callback({\n error: 'invalid_token',\n errorDescription:\n 'Nonce (nonce) claim value mismatch in the ID token; expected \"' +\n transactionNonce +\n '\", found \"' +\n decodedToken.payload.nonce +\n '\"'\n });\n }\n\n if (!parsedHash.access_token) {\n var noAccessTokenError = {\n error: 'invalid_token',\n description:\n 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token'\n };\n return callback(noAccessTokenError);\n }\n\n // if the alg is HS256, use the /userinfo endpoint to build the payload\n return _this.client.userInfo(parsedHash.access_token, function(\n errUserInfo,\n profile\n ) {\n // if the /userinfo request fails, use the validationError instead\n if (errUserInfo) {\n return callback(errUserInfo);\n }\n return callback(null, profile);\n });\n });\n};\n\nfunction buildParseHashResponse(qsParams, appState, token) {\n return {\n accessToken: qsParams.access_token || null,\n idToken: qsParams.id_token || null,\n idTokenPayload: token || null,\n appState: appState || null,\n refreshToken: qsParams.refresh_token || null,\n state: qsParams.state || null,\n expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null,\n tokenType: qsParams.token_type || null,\n scope: qsParams.scope || null\n };\n}\n\n/**\n * @callback validateTokenCallback\n * @param {Error} [err] error returned by while validating the token\n * @param {Object} [payload] claims stored in the token\n */\n\n/**\n * Decodes the a JWT and verifies its nonce value\n *\n * @method validateToken\n * @private\n * @param {String} token\n * @param {String} nonce\n * @param {validateTokenCallback} cb\n */\nWebAuth.prototype.validateToken = function(token, nonce, cb) {\n var verifier = new IdTokenVerifier({\n issuer: this.baseOptions.token_issuer,\n jwksURI: this.baseOptions.jwksURI,\n audience: this.baseOptions.clientID,\n leeway: this.baseOptions.leeway || 60,\n maxAge: this.baseOptions.maxAge,\n __clock: this.baseOptions.__clock || defaultClock\n });\n\n verifier.verify(token, nonce, function(err, payload) {\n if (err) {\n return cb(error.invalidToken(err.message));\n }\n\n cb(null, payload);\n });\n};\n\n/**\n * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session.\n * This method requires that all Auth is performed with {@link authorize}\n * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method.\n *\n * @method renewAuth\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback.\n * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy.\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.renewAuth = function(options, cb) {\n var handler;\n var usePostMessage = !!options.usePostMessage;\n var postMessageDataType = options.postMessageDataType || false;\n var postMessageOrigin =\n options.postMessageOrigin || windowHelper.getWindow().origin;\n var timeout = options.timeout;\n var _this = this;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'responseType',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n params.responseType = params.responseType || 'token';\n params.responseMode = params.responseMode || 'fragment';\n params = this.transactionManager.process(params);\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params.prompt = 'none';\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType',\n 'postMessageOrigin'\n ]);\n\n handler = SilentAuthenticationHandler.create({\n authenticationUrl: this.client.buildAuthorizeUrl(params),\n postMessageDataType: postMessageDataType,\n postMessageOrigin: postMessageOrigin,\n timeout: timeout\n });\n\n handler.login(usePostMessage, function(err, hash) {\n if (typeof hash === 'object') {\n // hash was already parsed, so we just return it.\n // it's here to be backwards compatible and should be removed in the next major version.\n return cb(err, hash);\n }\n _this.parseHash({ hash: hash }, cb);\n });\n};\n\n/**\n * Renews an existing session on Auth0's servers using `response_mode=web_message`\n *\n * @method checkSession\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {checkSessionCallback} cb\n * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens}\n */\nWebAuth.prototype.checkSession = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n if (params.responseType === 'code') {\n return cb({\n error: 'error',\n error_description: \"responseType can't be `code`\"\n });\n }\n\n if (!options.nonce) {\n params = this.transactionManager.process(params);\n }\n\n if (!params.redirectUri) {\n return cb({\n error: 'error',\n error_description: \"redirectUri can't be empty\"\n });\n }\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType'\n ]);\n this.webMessageHandler.run(\n params,\n responseHandler(cb, { forceLegacyError: true, ignoreCasing: true })\n );\n};\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nWebAuth.prototype.changePassword = function(options, cb) {\n return this.client.dbConnection.changePassword(options, cb);\n};\n\n/**\n * Starts a passwordless authentication transaction.\n *\n * @method passwordlessStart\n * @param {Object} options\n * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid\n * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email`\n * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber`\n * @param {String} options.connection name of the passwordless connection\n * @param {Object} [options.authParams] additional Auth parameters when using `link`\n * @param {Function} cb\n * @see {@link https://auth0.com/docs/api/authentication#passwordless}\n */\nWebAuth.prototype.passwordlessStart = function(options, cb) {\n var authParams = objectHelper\n .merge(this.baseOptions, [\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options.authParams);\n\n options.authParams = this.transactionManager.process(authParams);\n return this.client.passwordless.start(options, cb);\n};\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nWebAuth.prototype.signup = function(options, cb) {\n return this.client.dbConnection.signup(options, cb);\n};\n\n/**\n * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction.\n * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`.\n *\n * @method authorize\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} [options.appState] any values that you want back on the authentication response\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.authorize = function(options) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n\n windowHelper.redirect(this.client.buildAuthorizeUrl(params));\n};\n\n/**\n * Signs up a new user, automatically logs the user in after the signup and returns the user token.\n * The login will be done using /oauth/token with password-realm grant type.\n *\n * @method signupAndAuthorize\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {tokenCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n * @see {@link https://auth0.com/docs/api-auth/grant/password}\n */\nWebAuth.prototype.signupAndAuthorize = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n options.realm = options.connection;\n if (!options.username) {\n options.username = options.email;\n }\n _this.client.login(options, cb);\n }\n );\n};\n\n/**\n * @callback crossOriginLoginCallback\n * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Logs the user in with username and password using the correct flow based on where it's called from:\n * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint\n * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow\n * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`.\n * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data.\n * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.**\n *\n * @method login\n * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.username] Username (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.password Password\n * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.login = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n params.connection = params.realm;\n delete params.realm;\n this._universalLogin.login(params, cb);\n } else {\n this.crossOriginAuthentication.login(params, cb);\n }\n};\n\n/**\n * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user.\n * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor.\n *\n * @method passwordlessLogin\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.verificationCode Verification Code (OTP)\n * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'.\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.passwordlessLogin = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n this.passwordlessVerify(params, cb);\n } else {\n var crossOriginOptions = objectHelper.extend(\n {\n credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp',\n realm: params.connection,\n username: params.email || params.phoneNumber,\n otp: params.verificationCode\n },\n objectHelper.blacklist(params, [\n 'connection',\n 'email',\n 'phoneNumber',\n 'verificationCode'\n ])\n );\n this.crossOriginAuthentication.login(crossOriginOptions, cb);\n }\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginAuthenticationCallback\n * @deprecated Use {@link crossOriginVerification} instead.\n */\nWebAuth.prototype.crossOriginAuthenticationCallback = function() {\n this.crossOriginVerification();\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginVerification\n */\nWebAuth.prototype.crossOriginVerification = function() {\n this.crossOriginAuthentication.callback();\n};\n\n/**\n * Redirects to the auth0 logout endpoint\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n *\n * @method logout\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nWebAuth.prototype.logout = function(options) {\n windowHelper.redirect(this.client.buildLogoutUrl(options));\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nWebAuth.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n return this.client.passwordless.verify(params, function(err) {\n if (err) {\n return cb(err);\n }\n return windowHelper.redirect(\n _this.client.passwordless.buildVerifyUrl(params)\n );\n });\n};\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n * This function can only be used in the context of a Classic Universal Login Page.\n *\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha\n * @param {Function} [callback] An optional completion callback\n */\nWebAuth.prototype.renderCaptcha = function(element, options, callback) {\n return captcha.render(this.client, element, options, callback);\n};\n\nexport default WebAuth;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport qs from 'qs';\nimport responseHandler from '../helper/response-handler';\n\nfunction PasswordlessAuthentication(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\nPasswordlessAuthentication.prototype.buildVerifyUrl = function(options) {\n var params;\n var qString;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'protocol',\n 'nonce'\n ])\n .with(options);\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n\n qString = qs.stringify(params);\n\n return urljoin(\n this.baseOptions.rootUrl,\n 'passwordless',\n 'verify_redirect',\n '?' + qString\n );\n};\n\nPasswordlessAuthentication.prototype.start = function(options, cb) {\n var url;\n var body;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n send: {\n type: 'string',\n message: 'send option is required',\n values: ['link', 'code'],\n value_message: 'send is not valid ([link, code])'\n },\n phoneNumber: {\n optional: true,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return o.send === 'code' || !o.email;\n }\n },\n email: {\n optional: true,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return o.send === 'link' || !o.phoneNumber;\n }\n },\n authParams: {\n optional: true,\n type: 'object',\n message: 'authParams option is required'\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'start');\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope'\n ])\n .with(options);\n\n if (body.scope) {\n body.authParams = body.authParams || {};\n body.authParams.scope = body.authParams.scope || body.scope;\n }\n\n if (body.redirectUri) {\n body.authParams = body.authParams || {};\n body.authParams.redirect_uri =\n body.authParams.redirectUri || body.redirectUri;\n }\n\n if (body.responseType) {\n body.authParams = body.authParams || {};\n body.authParams.response_type =\n body.authParams.responseType || body.responseType;\n }\n\n delete body.redirectUri;\n delete body.responseType;\n delete body.scope;\n\n body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nPasswordlessAuthentication.prototype.verify = function(options, cb) {\n var url;\n var cleanOption;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n cleanOption = objectHelper.pick(options, [\n 'connection',\n 'verificationCode',\n 'phoneNumber',\n 'email',\n 'auth0Client'\n ]);\n cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']);\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'verify');\n\n return this.request\n .post(url)\n .send(cleanOption)\n .end(responseHandler(cb));\n};\n\nexport default PasswordlessAuthentication;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\nfunction DBConnection(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\n/**\n * @callback signUpCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the signup failed\n * @param {Object} [result] result of the signup request\n * @param {Object} result.email user's email\n * @param {Object} result.emailVerified if the user's email was verified\n */\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username`\n * @param {String} options.connection name of the connection where the user will be created\n * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata`\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nDBConnection.prototype.signup = function(options, cb) {\n var url;\n var body;\n var metadata;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' },\n password: { type: 'string', message: 'password option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'signup');\n\n body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options);\n\n metadata = body.user_metadata || body.userMetadata;\n\n body = objectHelper.blacklist(body, [\n 'scope',\n 'userMetadata',\n 'user_metadata'\n ]);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n if (metadata) {\n body.user_metadata = metadata;\n }\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * @callback changePasswordCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nDBConnection.prototype.changePassword = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options, ['email', 'connection']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nexport default DBConnection;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport RequestBuilder from '../helper/request-builder';\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport SSODataStorage from '../helper/ssodata';\nimport windowHelper from '../helper/window';\nimport responseHandler from '../helper/response-handler';\nimport parametersWhitelist from '../helper/parameters-whitelist';\nimport Warn from '../helper/warn';\nimport WebAuth from '../web-auth/index';\nimport PasswordlessAuthentication from './passwordless-authentication';\nimport DBConnection from './db-connection';\n\n/**\n * Creates a new Auth0 Authentication API client\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction Authentication(auth0, options) {\n // If we have two arguments, the first one is a WebAuth instance, so we assign that\n // if not, it's an options object and then we should use that as options instead\n // this is here because we don't want to break people coming from v8\n if (arguments.length === 2) {\n this.auth0 = auth0;\n } else {\n options = auth0;\n }\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n \n this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0)\n ? this.baseOptions.domain\n : 'https://' + this.baseOptions.domain;\n \n this.request = new RequestBuilder(this.baseOptions);\n\n this.passwordless = new PasswordlessAuthentication(\n this.request,\n this.baseOptions\n );\n this.dbConnection = new DBConnection(this.request, this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction\n *\n * @method buildAuthorizeUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n * @see {@link https://auth0.com/docs/api/authentication#social}\n */\nAuthentication.prototype.buildAuthorizeUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience'\n ])\n .with(options);\n\n /* eslint-disable */\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri option is required'\n },\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n },\n nonce: {\n type: 'string',\n message: 'nonce option is required',\n condition: function(o) {\n return (\n o.responseType.indexOf('code') === -1 &&\n o.responseType.indexOf('id_token') !== -1\n );\n }\n },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n /* eslint-enable */\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n if (params.connection_scope && assert.isArray(params.connection_scope)) {\n params.connection_scope = params.connection_scope.join(',');\n }\n\n params = objectHelper.blacklist(params, [\n 'username',\n 'popupOptions',\n 'domain',\n 'tenant',\n 'timeout',\n 'appState'\n ]);\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n params = parametersWhitelist.oauthAuthorizeParams(this.warn, params);\n\n qString = qs.stringify(params);\n\n return urljoin(this.baseOptions.rootUrl, 'authorize', '?' + qString);\n};\n\n/**\n * Builds and returns the Logout url in order to initialize a new authN/authZ transaction\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n * @method buildLogoutUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nAuthentication.prototype.buildLogoutUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n optional: true,\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options || {});\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']);\n\n qString = qs.stringify(objectHelper.blacklist(params, ['federated']));\n if (\n options &&\n options.federated !== undefined &&\n options.federated !== false &&\n options.federated !== 'false'\n ) {\n qString += '&federated';\n }\n\n return urljoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString);\n};\n\n/**\n * @callback authorizeCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null.\n * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} [result.expiresIn] number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n * @param {Object} [result.appState] values that you receive back on the authentication response\n */\n\n/**\n * @callback tokenCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request\n * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} result.expiresIn number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory.\n *\n * @method loginWithDefaultDirectory\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.loginWithDefaultDirectory = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'password';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password-realm` grant type\n *\n * @method login\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.login = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n realm: { type: 'string', message: 'realm option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'http://auth0.com/oauth/grant-type/password-realm';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint\n *\n * @method oauthToken\n * @private\n */\nAuthentication.prototype.oauthToken = function(options, cb) {\n var url;\n var body;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'token');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope', 'audience'])\n .with(options);\n\n assert.check(\n body,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n grantType: { type: 'string', message: 'grantType option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n body = parametersWhitelist.oauthTokenParams(this.warn, body);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Performs authentication calling `/oauth/ro` endpoint with username\n * and password for a given connection name.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link login} or {@link loginWithDefaultDirectory}.\n *\n * @method loginWithResourceOwner\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.device] name of the device/browser where the Auth was requested\n * @param {tokenCallback} cb function called with the result of the request\n */\nAuthentication.prototype.loginWithResourceOwner = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n connection: { type: 'string', message: 'connection option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'ro');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope'])\n .with(options, ['username', 'password', 'scope', 'connection', 'device']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n body.grant_type = body.grant_type || 'password';\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Uses {@link checkSession} and localStorage to return data from the last successful authentication request.\n *\n * @method getSSOData\n * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible\n * @param {Function} cb\n */\nAuthentication.prototype.getSSOData = function(withActiveDirectories, cb) {\n /* istanbul ignore if */\n if (!this.auth0) {\n this.auth0 = new WebAuth(this.baseOptions);\n }\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb);\n }\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n }\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n var clientId = this.baseOptions.clientID;\n var ssodataInformation = this.ssodataStorage.get() || {};\n\n this.auth0.checkSession(\n {\n responseType: 'token id_token',\n scope: 'openid profile email',\n connection: ssodataInformation.lastUsedConnection,\n timeout: 5000\n },\n function(err, result) {\n if (err) {\n if (err.error === 'login_required') {\n return cb(null, { sso: false });\n }\n if (err.error === 'consent_required') {\n err.error_description =\n 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.';\n }\n return cb(err, { sso: false });\n }\n if (\n ssodataInformation.lastUsedSub &&\n ssodataInformation.lastUsedSub !== result.idTokenPayload.sub\n ) {\n return cb(err, { sso: false });\n }\n return cb(null, {\n lastUsedConnection: {\n name: ssodataInformation.lastUsedConnection\n },\n lastUsedUserID: result.idTokenPayload.sub,\n lastUsedUsername:\n result.idTokenPayload.email || result.idTokenPayload.name,\n lastUsedClientID: clientId,\n sessionClients: [clientId],\n sso: true\n });\n }\n );\n};\n\n/**\n * @callback userInfoCallback\n * @param {Error} [err] error returned by Auth0\n * @param {Object} [userInfo] user information\n */\n\n/**\n * Makes a call to the `/userinfo` endpoint and returns the user profile\n *\n * @method userInfo\n * @param {String} accessToken token issued to a user after Auth\n * @param {userInfoCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#get-user-info}\n */\nAuthentication.prototype.userInfo = function(accessToken, cb) {\n var url;\n\n assert.check(accessToken, {\n type: 'string',\n message: 'accessToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'userinfo');\n\n return this.request\n .get(url)\n .set('Authorization', 'Bearer ' + accessToken)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Makes a call to the `/usernamepassword/challenge` endpoint\n * and returns the challenge (captcha) if necessary.\n *\n * @method getChallenge\n * @param {callback} cb\n */\nAuthentication.prototype.getChallenge = function(cb) {\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (!this.baseOptions.state) {\n return cb();\n }\n\n var url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge');\n\n return this.request\n .post(url)\n .send({ state: this.baseOptions.state })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * @callback delegationCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed\n * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used\n */\n\n/**\n * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token`\n *\n * @method delegation\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer`\n * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required\n * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required\n * @param {String} [options.target] the target ClientID of the delegation\n * @param {String} [options.scope] either `openid` or `openid profile email`\n * @param {String} [options.apiType] the api to be called\n * @param {delegationCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#delegation}\n * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.delegation = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n grant_type: { type: 'string', message: 'grant_type option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'delegation');\n\n body = objectHelper.merge(this.baseOptions, ['clientID']).with(options);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Fetches the user country based on the ip.\n *\n * @method getUserCountry\n * @private\n * @param {Function} cb\n */\nAuthentication.prototype.getUserCountry = function(cb) {\n var url;\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country');\n\n return this.request.get(url).end(responseHandler(cb));\n};\n\nexport default Authentication;\n","import urljoin from 'url-join';\n\nimport RequestBuilder from '../helper/request-builder';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\n/**\n * Auth0 Management API Client (methods allowed to be called from the browser only)\n * @constructor\n * @param {Object} options\n * @param {Object} options.domain your Auth0 acount domain\n * @param {Object} options.token a valid API token\n */\nfunction Management(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n token: { type: 'string', message: 'token option is required' },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n }\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n\n this.baseOptions.headers = {\n Authorization: 'Bearer ' + this.baseOptions.token\n };\n\n this.request = new RequestBuilder(this.baseOptions);\n this.baseOptions.rootUrl = urljoin(\n 'https://' + this.baseOptions.domain,\n 'api',\n 'v2'\n );\n}\n\n/**\n * @callback userCallback\n * @param {Error} [err] failure reason for the failed request to Management API\n * @param {Object} [result] user profile\n */\n\n/**\n * Returns the user profile\n *\n * @method getUser\n * @param {String} userId identifier of the user to retrieve\n * @param {userCallback} cb\n * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id\n */\nManagement.prototype.getUser = function(userId, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request.get(url).end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user metdata. It will patch the user metdata with the attributes sent.\n *\n *\n * @method patchUserMetadata\n * @param {String} userId\n * @param {Object} userMetadata\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserMetadata = function(userId, userMetadata, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(userMetadata, {\n type: 'object',\n message: 'userMetadata parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send({ user_metadata: userMetadata })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user attributes. It will patch the user attributes that the server allows it.\n *\n * @method patchUserAttributes\n * @param {String} userId\n * @param {Object} user\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserAttributes = function(userId, user, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(user, {\n type: 'object',\n message: 'user parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send(user)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Link two users\n *\n * @method linkUser\n * @param {String} userId\n * @param {String} secondaryUserToken\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities}\n */\nManagement.prototype.linkUser = function(userId, secondaryUserToken, cb) {\n var url;\n /* eslint-disable */\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(secondaryUserToken, {\n type: 'string',\n message: 'secondaryUserToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n /* eslint-enable */\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId, 'identities');\n\n return this.request\n .post(url)\n .send({ link_with: secondaryUserToken })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\nexport default Management;\n","import Authentication from './authentication';\nimport Management from './management';\nimport WebAuth from './web-auth';\nimport version from './version';\n\nexport { Authentication, Management, WebAuth, version };\n\nexport default {\n Authentication: Authentication,\n Management: Management,\n WebAuth: WebAuth,\n version: version\n};\n"],"names":["context","definition","this","normalize","strArray","resultArray","length","TypeError","match","first","shift","replace","i","component","push","str","join","parts","split","arguments","slice","call","module","exports","has","Object","prototype","hasOwnProperty","isArray","Array","hexTable","array","toString","toUpperCase","arrayToObject","source","options","obj","plainObjects","create","assign","target","keys","reduce","acc","key","combine","a","b","concat","compact","value","queue","o","prop","refs","item","j","val","indexOf","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","c","charCodeAt","charAt","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","merge","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","apply","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","object","generateArrayPrefix","filter","sort","v","isNonNullishPrimitive","objKeys","values","keyPrefix","arrayLimit","depth","ignoreQueryPrefix","interpretNumericEntities","parameterLimit","parseArrays","numberStr","fromCharCode","parseArrayValue","parseKeys","givenKey","valuesParsed","child","segment","exec","parent","index","chain","leaf","root","cleanRoot","isNaN","0","parseObject","opts","undefined","normalizeParseOptions","tempObj","cleanStr","limit","Infinity","skipIndex","part","bracketEqualsPos","pos","encodedVal","parseValues","newObj","normalizeStringifyOptions","arrayFormat","joined","Emitter","mixin","on","addEventListener","event","_callbacks","once","off","removeListener","removeAllListeners","removeEventListener","cb","callbacks","splice","emit","args","len","listeners","hasListeners","stable","deterministicStringify","stableStringify","replacerStack","replacer","spacer","res","decirc","k","stack","propertyDescriptor","getOwnPropertyDescriptor","get","configurable","defineProperty","JSON","replaceGetterValues","compareFunction","tmp","deterministicDecirc","toJSON","_typeof","iterator","RequestBase","clearTimeout","_timer","_responseTimeoutTimer","_uploadTimeoutTimer","parse","_parser","responseType","_responseType","serialize","_serializer","timeout","_timeout","_responseTimeout","_uploadTimeout","option","deadline","response","upload","console","warn","retry","count","_maxRetries","_retries","_retryCallback","ERROR_CODES","_shouldRetry","err","override","err_","error","status","code","includes","crossDomain","_retry","req","request","_aborted","timedout","timedoutError","_end","then","resolve","reject","_this","_fullfilledPromise","self","_endCalled","Promise","Error","method","url","end","catch","use","ok","_okCallback","_isResponseOK","field","_header","toLowerCase","getHeader","set","isObject","header","unset","name","_data","_getFormData","append","abort","xhr","_auth","user","pass","base64Encoder","type","username","password","withCredentials","_withCredentials","redirects","n","_maxRedirects","maxResponseSize","_maxResponseSize","data","headers","send","isObj","_formData","_isHost","sortQuery","_sort","_finalizeQueryString","query","_query","queryArr","_appendQueryString","_timeoutError","reason","errno","callback","_setTimeouts","setTimeout","ResponseBase","_toConsumableArray","_arrayLikeToArray","_arrayWithoutHoles","iter","from","_iterableToArray","minLen","test","_unsupportedIterableToArray","_nonIterableSpread","arr2","Agent","_defaults","_setHeaderProperties","ct","params","links","link","_unused","_setStatusProperties","statusCode","statusType","info","redirect","clientError","serverError","toError","created","accepted","noContent","badRequest","unauthorized","notAcceptable","forbidden","notFound","unprocessableEntity","_len","_key","_setDefaults","def","noop","window","Request","getXHR","XMLHttpRequest","location","protocol","ActiveXObject","_unused2","_unused3","_unused4","trim","s","pairs","pushEncodedKeyValuePair","subkey","encodeURI","encodeURIComponent","parseString","pair","isJSON","mime","Response","text","responseText","statusText","line","lines","fields","parseHeader","getAllResponseHeaders","getResponseHeader","body","_parseBody","new_err","original","rawResponse","del","serializeObject","types","html","json","xml","urlencoded","form","form-data","application/x-www-form-urlencoded","application/json","safeStringify","msg","accept","auth","btoa","attach","file","FormData","_callback","retries","crossDomainError","agent","ca","buffer","write","pipe","_setUploadTimeout","onreadystatechange","readyState","_unused5","handleProgress","direction","total","percent","loaded","bind","_unused6","open","contentType","_serialize","setRequestHeader","delete","head","patch","post","put","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","lookup","Uint8Array","start","num","output","base64","fromByteArray","stringToByteArray","mod","padding","result","byteArrayToString","toByteArray","raw","attribute","attr","variable","check","config","attributes","optional","message","condition","value_message","supportsIsArray","objectAssignPolyfill","to","nextSource","keysArray","nextIndex","nextKey","desc","enumerable","pick","prev","objectValues","extend","unshift","objectAssign","getLocationFromUrl","href","host","hostname","port","pathname","search","hash","trimmed","toSnakeCase","exceptions","assert","p","newKey","wasPrevNumber","wasPrevUppercase","camelToSnake","toCamelCase","keepOriginal","blacklist","blacklistedKeys","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","RequestWrapper","RequestObj","RequestBuilder","_sendTelemetry","_telemetryInfo","_timesToRetryFailedRequests","_universalLoginPage","universalLoginPage","getWindow","getMethod","getBody","getUrl","getHeaders","objectHelper","setCommonConfiguration","ongoingRequest","noHeaders","getTelemetryData","telemetryName","clientInfo","version","env","jsonClientInfo","base64Url","getDocument","document","getOrigin","DummyStorage","getItem","removeItem","setItem","factory","init","converter","api","expires","toUTCString","stringifiedAttributes","attributeName","cookie","jar","cookies","read","getJSON","remove","withConverter","CookieStorage","Warn","disableWarnings","StorageHandler","storage","__tryLocalStorageFirst","localStorage","windowHandler","warning","Storage","handler","SSODataStorage","buildResponse","description","errorDescription","Cookie","failover","_","connection","sub","ssodata","lastUsedConnection","lastUsedSub","invalidToken","wrapCallback","ignoreCasing","errObj","error_code","error_description","details","forceLegacyError","error_codes","error_details","errorDetails","codes","policy","keepOriginalCasing","tokenParams","authorizeParams","oauthTokenParams","oauthAuthorizeParams","t","globalThis","global","r","require","l","d","w","h","u","MutationObserver","WebKitMutationObserver","f","process","Uint8ClampedArray","importScripts","MessageChannel","m","y","g","T","S","C","_state","I","_result","A","nextTick","createTextNode","observe","characterData","port1","onmessage","port2","postMessage","Function","runOnLoop","runOnContext","Math","random","substring","D","x","E","B","_onerror","M","_subscribers","R","_instanceConstructor","promise","_remaining","_enumerate","_eachEntry","_settledAt","O","_willSettleAt","finally","all","race","_setScheduler","_setAsap","_asap","polyfill","cast","lib","Base","mixIn","$super","clone","WordArray","words","sigBytes","clamp","ceil","enc","Hex","substr","Latin1","Utf8","BufferedBlockAlgorithm","reset","_nDataBytes","_append","_process","blockSize","max","_minBufferSize","min","_doProcessBlock","Hasher","cfg","_doReset","update","finalize","_doFinalize","_createHelper","_createHmacHelper","HMAC","algo","sqrt","pow","SHA256","_hash","floor","HmacSHA256","Base64","_map","_reverseMap","fromNumber","fromString","navigator","appName","am","DB","DM","DV","FV","F1","F2","fromInt","mp","invDigit","mpl","mph","um","mt2","r2","q3","ONE","dlShiftTo","mu","divide","convert","compareTo","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","abs","ZERO","subTo","copyTo","drShiftTo","fromRadix","lShiftTo","rShiftTo","isEven","exp","negate","toRadix","bitLength","modPowInt","multiplyUpperTo","multiplyLowerTo","dAddOffset","getTime","chunkSize","LN2","log","signum","intValue","dMultiply","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","changeBit","addTo","modInt","millerRabin","subtract","getLowestSetBit","shiftRight","modPow","byteValue","shortValue","equals","and","or","xor","andNot","not","bitCount","setBit","clearBit","flipBit","add","multiply","remainder","divideAndRemainder","modInverse","gcd","square","Barrett","crypto","getRandomValues","appVersion","BigInteger","SecureRandom","sha1","sha224","sha256","sha384","sha512","md2","md5","ripemd160","verify","alg","map","urljoin","responseURL","blob","Blob","entries","onload","onerror","credentials","jwksCache","expectedAlg","issuer","audience","leeway","jwksURI","maxAge","__clock","PluginHandler","webAuth","plugins","pluginName","setWebAuth","encoded","payload","signature","kid","aud","iss","nbf","iat","azp","auth_time","nonce","getRsaVerifier","setUTCSeconds","fetch","modulus","validateAccessToken","+","/","=","extensibilityPoint","supports","randomString","bytes","cryptoObj","windowHelper","msCrypto","TransactionManager","transaction","namespace","keyLength","IframeHandler","timeoutCallback","eventListenerType","iframe","timeoutHandle","_destroyTimeout","transientMessageEventListener","proxyEventListener","eventValidator","isValid","WebMessageHandler","baseOptions","CrossOriginAuthentication","webMessageHandler","createKey","coId","Redirect","auth0","crossOriginAuthentication","_disableDeprecationWarnings","realm","responseTypeIncludesIdToken","generateTransaction","appState","state","generateNonce","domain","getStoredTransaction","transactionData","clearTransaction","_window","createElement","style","display","eventListener","eventSourceObject","appendChild","src","timeoutHandler","eventData","sourceObject","destroy","parentNode","removeChild","run","responseMode","prompt","currentOrigin","redirectUriOrigin","redirectUri","authorizeUrl","runWebMessageFlow","client","buildAuthorizeUrl","parsedHash","validateAuthenticationResponse","transactionManager","login","rootUrl","email","authenticateBody","client_id","clientID","otp","credentialType","credential_type","errorObject","responseHandler","popupMode","popup","authorizeOptions","loginTicket","login_ticket","co_id","co_verifier","authorize","targetOrigin","getFragment","theWindow","evt","id","verifier","tryGetVerifier","loginWithCredentials","signupAndLogin","dbConnection","signup","WinChan","addListener","attachEvent","detachEvent","extractOrigin","isIE","rv","ua","userAgent","RegExp","parseFloat","$1","isInternetExplorer","relay_url","window_name","window_features","isFennec","messageTarget","setAttribute","contentWindow","closeInterval","setInterval","closed","cleanup","clearInterval","onMessage","close","securityViolation","originalPopup","focus","onOpen","msgTarget","frames","opener","findRelay","doPost","onDie","o_O","onUnload","ohWell","detach","winopts","arg","PopupHandler","_current_popup","Popup","popupOrigin","SilentAuthenticationHandler","authenticationUrl","postMessageDataType","postMessageOrigin","UsernamePassword","HostedPages","calculatePosition","width","height","screenX","screenLeft","screenY","screenTop","outerWidth","clientWidth","outerHeight","clientHeight","left","top","preload","popupPosition","popupOptions","windowFeatures","qs","kill","load","relayUrl","winchanOptions","buildPopupHandler","pluginHandler","getPopupHandler","popupHandler","originUrl","parseHash","popOpts","owp","urlHelper","processParams","scope","passwordlessVerify","passwordless","phoneNumber","verificationCode","loginWithResourceOwner","usePostMessage","getCallbackHandler","getEventValidator","callbackValue","formHtml","div","_document","innerHTML","children","submit","usernamePassword","getSSOData","withActiveDirectories","ldaps","lang","templates","challenge","image","recaptcha_v2","handleRecaptchaProvider","element","widgetId","hasAttribute","getAttribute","setValue","querySelector","grecaptcha","provider","recaptchaDiv","callbackName","script","async","injectRecaptchaScript","render","expired-callback","error-callback","sitekey","siteKey","auth0Client","done","getChallenge","required","preventDefault","handleAuth0Provider","reload","getValue","captchaInput","defaultClock","WebAuth","overrides","__tenant","__token_issuer","__jwks_uri","tenant","token_issuer","Authentication","_universalLogin","ssodataStorage","PasswordlessAuthentication","DBConnection","Management","token","Authorization","parsedQs","hashStr","responseTypes","__enableIdPInitiatedLogin","__enableImpersonation","transactionState","transactionStateMatchesState","transactionNonce","qsParams","accessToken","access_token","idToken","id_token","idTokenPayload","refreshToken","refresh_token","expiresIn","expires_in","tokenType","token_type","buildParseHashResponse","validateToken","validationError","at_hash","IdTokenVerifier","decodedToken","userInfo","errUserInfo","profile","renewAuth","checkSession","changePassword","passwordlessStart","authParams","signupAndAuthorize","passwordlessLogin","crossOriginOptions","crossOriginAuthenticationCallback","crossOriginVerification","logout","buildLogoutUrl","buildVerifyUrl","renderCaptcha","captcha","qString","redirect_uri","response_type","cleanOption","metadata","user_metadata","userMetadata","connection_scope","parametersWhitelist","federated","loginWithDefaultDirectory","grantType","oauthToken","grant_type","clientId","ssodataInformation","sso","lastUsedUserID","lastUsedUsername","lastUsedClientID","sessionClients","delegation","getUserCountry","getUser","userId","patchUserMetadata","patchUserAttributes","linkUser","secondaryUserToken","link_with"],"mappings":"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"} \ No newline at end of file diff --git a/dist/auth0.min.js b/dist/auth0.min.js new file mode 100644 index 00000000..d13cbfc7 --- /dev/null +++ b/dist/auth0.min.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +!function(global,factory){"object"==typeof exports&&"undefined"!=typeof module?factory(exports):"function"==typeof define&&define.amd?define(["exports"],factory):factory((global=global||self).auth0={})}(this,(function(exports){"use strict";var commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function createCommonjsModule(fn,module){return fn(module={exports:{}},module.exports),module.exports}var urlJoin=createCommonjsModule((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray(val)){for(var mapped=[],i=0;i-1?val.split(","):val},parseKeys=function(givenKey,val,options,valuesParsed){if(givenKey){var key=options.allowDots?givenKey.replace(/\.([^.[]+)/g,"[$1]"):givenKey,child=/(\[[^[\]]*])/g,segment=options.depth>0&&/(\[[^[\]]*])/.exec(key),parent=segment?key.slice(0,segment.index):key,keys=[];if(parent){if(!options.plainObjects&&has$2.call(Object.prototype,parent)&&!options.allowPrototypes)return;keys.push(parent)}for(var i=0;options.depth>0&&null!==(segment=child.exec(key))&&i=0;--i){var obj,root=chain[i];if("[]"===root&&options.parseArrays)obj=[].concat(leaf);else{obj=options.plainObjects?Object.create(null):{};var cleanRoot="["===root.charAt(0)&&"]"===root.charAt(root.length-1)?root.slice(1,-1):root,index=parseInt(cleanRoot,10);options.parseArrays||""!==cleanRoot?!isNaN(index)&&root!==cleanRoot&&String(index)===cleanRoot&&index>=0&&options.parseArrays&&index<=options.arrayLimit?(obj=[])[index]=leaf:obj[cleanRoot]=leaf:obj={0:leaf}}leaf=obj}return leaf}(keys,val,options,valuesParsed)}},lib_parse=function(str,opts){var options=function(opts){if(!opts)return defaults$1;if(null!==opts.decoder&&void 0!==opts.decoder&&"function"!=typeof opts.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==opts.charset&&"utf-8"!==opts.charset&&"iso-8859-1"!==opts.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var charset=void 0===opts.charset?defaults$1.charset:opts.charset;return{allowDots:void 0===opts.allowDots?defaults$1.allowDots:!!opts.allowDots,allowPrototypes:"boolean"==typeof opts.allowPrototypes?opts.allowPrototypes:defaults$1.allowPrototypes,arrayLimit:"number"==typeof opts.arrayLimit?opts.arrayLimit:defaults$1.arrayLimit,charset:charset,charsetSentinel:"boolean"==typeof opts.charsetSentinel?opts.charsetSentinel:defaults$1.charsetSentinel,comma:"boolean"==typeof opts.comma?opts.comma:defaults$1.comma,decoder:"function"==typeof opts.decoder?opts.decoder:defaults$1.decoder,delimiter:"string"==typeof opts.delimiter||utils.isRegExp(opts.delimiter)?opts.delimiter:defaults$1.delimiter,depth:"number"==typeof opts.depth||!1===opts.depth?+opts.depth:defaults$1.depth,ignoreQueryPrefix:!0===opts.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof opts.interpretNumericEntities?opts.interpretNumericEntities:defaults$1.interpretNumericEntities,parameterLimit:"number"==typeof opts.parameterLimit?opts.parameterLimit:defaults$1.parameterLimit,parseArrays:!1!==opts.parseArrays,plainObjects:"boolean"==typeof opts.plainObjects?opts.plainObjects:defaults$1.plainObjects,strictNullHandling:"boolean"==typeof opts.strictNullHandling?opts.strictNullHandling:defaults$1.strictNullHandling}}(opts);if(""===str||null==str)return options.plainObjects?Object.create(null):{};for(var tempObj="string"==typeof str?function(str,options){var i,obj={},cleanStr=options.ignoreQueryPrefix?str.replace(/^\?/,""):str,limit=options.parameterLimit===1/0?void 0:options.parameterLimit,parts=cleanStr.split(options.delimiter,limit),skipIndex=-1,charset=options.charset;if(options.charsetSentinel)for(i=0;i-1&&(val=isArray$2(val)?[val]:val),has$2.call(obj,key)?obj[key]=utils.combine(obj[key],val):obj[key]=val}return obj}(str,options):str,obj=options.plainObjects?Object.create(null):{},keys=Object.keys(tempObj),i=0;i0?prefix+joined:""},componentEmitter=createCommonjsModule((function(module){function Emitter(obj){if(obj)return function(obj){for(var key in Emitter.prototype)obj[key]=Emitter.prototype[key];return obj}(obj)}module.exports=Emitter,Emitter.prototype.on=Emitter.prototype.addEventListener=function(event,fn){return this._callbacks=this._callbacks||{},(this._callbacks["$"+event]=this._callbacks["$"+event]||[]).push(fn),this},Emitter.prototype.once=function(event,fn){function on(){this.off(event,on),fn.apply(this,arguments)}return on.fn=fn,this.on(event,on),this},Emitter.prototype.off=Emitter.prototype.removeListener=Emitter.prototype.removeAllListeners=Emitter.prototype.removeEventListener=function(event,fn){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var cb,callbacks=this._callbacks["$"+event];if(!callbacks)return this;if(1==arguments.length)return delete this._callbacks["$"+event],this;for(var i=0;ib?1:0}function deterministicStringify(obj,replacer,spacer){var res,tmp=function deterministicDecirc(val,k,stack,parent){var i;if("object"==typeof val&&null!==val){for(i=0;i0)for(var i=0;i=this._maxRetries)return!1;if(this._retryCallback)try{var override=this._retryCallback(err,res);if(!0===override)return!0;if(!1===override)return!1}catch(err_){console.error(err_)}if(res&&res.status&&res.status>=500&&501!==res.status)return!0;if(err){if(err.code&&ERROR_CODES.includes(err.code))return!0;if(err.timeout&&"ECONNABORTED"===err.code)return!0;if(err.crossDomain)return!0}return!1},RequestBase.prototype._retry=function(){return this.clearTimeout(),this.req&&(this.req=null,this.req=this.request()),this._aborted=!1,this.timedout=!1,this.timedoutError=null,this._end()},RequestBase.prototype.then=function(resolve,reject){var _this=this;if(!this._fullfilledPromise){var self=this;this._endCalled&&console.warn("Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises"),this._fullfilledPromise=new Promise((function(resolve,reject){self.on("abort",(function(){if(!(_this._maxRetries&&_this._maxRetries>_this._retries))if(_this.timedout&&_this.timedoutError)reject(_this.timedoutError);else{var err=new Error("Aborted");err.code="ABORTED",err.status=_this.status,err.method=_this.method,err.url=_this.url,reject(err)}})),self.end((function(err,res){err?reject(err):resolve(res)}))}))}return this._fullfilledPromise.then(resolve,reject)},RequestBase.prototype.catch=function(cb){return this.then(void 0,cb)},RequestBase.prototype.use=function(fn){return fn(this),this},RequestBase.prototype.ok=function(cb){if("function"!=typeof cb)throw new Error("Callback required");return this._okCallback=cb,this},RequestBase.prototype._isResponseOK=function(res){return!!res&&(this._okCallback?this._okCallback(res):res.status>=200&&res.status<300)},RequestBase.prototype.get=function(field){return this._header[field.toLowerCase()]},RequestBase.prototype.getHeader=RequestBase.prototype.get,RequestBase.prototype.set=function(field,val){if(isObject_1(field)){for(var key in field)Object.prototype.hasOwnProperty.call(field,key)&&this.set(key,field[key]);return this}return this._header[field.toLowerCase()]=val,this.header[field]=val,this},RequestBase.prototype.unset=function(field){return delete this._header[field.toLowerCase()],delete this.header[field],this},RequestBase.prototype.field=function(name,val){if(null==name)throw new Error(".field(name, val) name can not be empty");if(this._data)throw new Error(".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()");if(isObject_1(name)){for(var key in name)Object.prototype.hasOwnProperty.call(name,key)&&this.field(key,name[key]);return this}if(Array.isArray(val)){for(var i in val)Object.prototype.hasOwnProperty.call(val,i)&&this.field(name,val[i]);return this}if(null==val)throw new Error(".field(name, val) val can not be empty");return"boolean"==typeof val&&(val=String(val)),this._getFormData().append(name,val),this},RequestBase.prototype.abort=function(){return this._aborted||(this._aborted=!0,this.xhr&&this.xhr.abort(),this.req&&this.req.abort(),this.clearTimeout(),this.emit("abort")),this},RequestBase.prototype._auth=function(user,pass,options,base64Encoder){switch(options.type){case"basic":this.set("Authorization","Basic ".concat(base64Encoder("".concat(user,":").concat(pass))));break;case"auto":this.username=user,this.password=pass;break;case"bearer":this.set("Authorization","Bearer ".concat(user))}return this},RequestBase.prototype.withCredentials=function(on){return void 0===on&&(on=!0),this._withCredentials=on,this},RequestBase.prototype.redirects=function(n){return this._maxRedirects=n,this},RequestBase.prototype.maxResponseSize=function(n){if("number"!=typeof n)throw new TypeError("Invalid argument");return this._maxResponseSize=n,this},RequestBase.prototype.toJSON=function(){return{method:this.method,url:this.url,data:this._data,headers:this._header}},RequestBase.prototype.send=function(data){var isObj=isObject_1(data),type=this._header["content-type"];if(this._formData)throw new Error(".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()");if(isObj&&!this._data)Array.isArray(data)?this._data=[]:this._isHost(data)||(this._data={});else if(data&&this._data&&this._isHost(this._data))throw new Error("Can't merge these send calls");if(isObj&&isObject_1(this._data))for(var key in data)Object.prototype.hasOwnProperty.call(data,key)&&(this._data[key]=data[key]);else"string"==typeof data?(type||this.type("form"),type=this._header["content-type"],this._data="application/x-www-form-urlencoded"===type?this._data?"".concat(this._data,"&").concat(data):data:(this._data||"")+data):this._data=data;return!isObj||this._isHost(data)||type||this.type("json"),this},RequestBase.prototype.sortQuery=function(sort){return this._sort=void 0===sort||sort,this},RequestBase.prototype._finalizeQueryString=function(){var query=this._query.join("&");if(query&&(this.url+=(this.url.includes("?")?"&":"?")+query),this._query.length=0,this._sort){var index=this.url.indexOf("?");if(index>=0){var queryArr=this.url.slice(index+1).split("&");"function"==typeof this._sort?queryArr.sort(this._sort):queryArr.sort(),this.url=this.url.slice(0,index)+"?"+queryArr.join("&")}}},RequestBase.prototype._appendQueryString=function(){console.warn("Unsupported")},RequestBase.prototype._timeoutError=function(reason,timeout,errno){if(!this._aborted){var err=new Error("".concat(reason+timeout,"ms exceeded"));err.timeout=timeout,err.code="ECONNABORTED",err.errno=errno,this.timedout=!0,this.timedoutError=err,this.abort(),this.callback(err)}},RequestBase.prototype._setTimeouts=function(){var self=this;this._timeout&&!this._timer&&(this._timer=setTimeout((function(){self._timeoutError("Timeout of ",self._timeout,"ETIME")}),this._timeout)),this._responseTimeout&&!this._responseTimeoutTimer&&(this._responseTimeoutTimer=setTimeout((function(){self._timeoutError("Response timeout of ",self._responseTimeout,"ETIMEDOUT")}),this._responseTimeout))};var utils$1_type=function(str){return str.split(/ *; */).shift()},utils$1_params=function(str){return str.split(/ *; */).reduce((function(obj,str){var parts=str.split(/ *= */),key=parts.shift(),val=parts.shift();return key&&val&&(obj[key]=val),obj}),{})},utils$1_parseLinks=function(str){return str.split(/ *, */).reduce((function(obj,str){var parts=str.split(/ *; */),url=parts[0].slice(1,-1);return obj[parts[1].split(/ *= */)[1].slice(1,-1)]=url,obj}),{})},responseBase=ResponseBase;function ResponseBase(obj){if(obj)return function(obj){for(var key in ResponseBase.prototype)Object.prototype.hasOwnProperty.call(ResponseBase.prototype,key)&&(obj[key]=ResponseBase.prototype[key]);return obj}(obj)}function _toConsumableArray(arr){return function(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}(arr)||function(iter){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(iter))return Array.from(iter)}(arr)||function(o,minLen){if(!o)return;if("string"==typeof o)return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);"Object"===n&&o.constructor&&(n=o.constructor.name);if("Map"===n||"Set"===n)return Array.from(o);if("Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}(arr)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _arrayLikeToArray(arr,len){(null==len||len>arr.length)&&(len=arr.length);for(var i=0,arr2=new Array(len);i0||str instanceof Object)?parse(str):null)},Response.prototype.toError=function(){var req=this.req,method=req.method,url=req.url,msg="cannot ".concat(method," ").concat(url," (").concat(this.status,")"),err=new Error(msg);return err.status=this.status,err.method=method,err.url=url,err},request.Response=Response,componentEmitter(Request.prototype),requestBase(Request.prototype),Request.prototype.type=function(type){return this.set("Content-Type",request.types[type]||type),this},Request.prototype.accept=function(type){return this.set("Accept",request.types[type]||type),this},Request.prototype.auth=function(user,pass,options){1===arguments.length&&(pass=""),"object"===_typeof(pass)&&null!==pass&&(options=pass,pass=""),options||(options={type:"function"==typeof btoa?"basic":"auto"});var encoder=function(string){if("function"==typeof btoa)return btoa(string);throw new Error("Cannot use basic auth, btoa is not a function")};return this._auth(user,pass,options,encoder)},Request.prototype.query=function(val){return"string"!=typeof val&&(val=serialize(val)),val&&this._query.push(val),this},Request.prototype.attach=function(field,file,options){if(file){if(this._data)throw new Error("superagent can't mix .send() and .attach()");this._getFormData().append(field,file,options||file.name)}return this},Request.prototype._getFormData=function(){return this._formData||(this._formData=new root.FormData),this._formData},Request.prototype.callback=function(err,res){if(this._shouldRetry(err,res))return this._retry();var fn=this._callback;this.clearTimeout(),err&&(this._maxRetries&&(err.retries=this._retries-1),this.emit("error",err)),fn(err,res)},Request.prototype.crossDomainError=function(){var err=new Error("Request has been terminated\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.");err.crossDomain=!0,err.status=this.status,err.method=this.method,err.url=this.url,this.callback(err)},Request.prototype.agent=function(){return console.warn("This is not supported in browser version of superagent"),this},Request.prototype.ca=Request.prototype.agent,Request.prototype.buffer=Request.prototype.ca,Request.prototype.write=function(){throw new Error("Streaming is not supported in browser version of superagent")},Request.prototype.pipe=Request.prototype.write,Request.prototype._isHost=function(obj){return obj&&"object"===_typeof(obj)&&!Array.isArray(obj)&&"[object Object]"!==Object.prototype.toString.call(obj)},Request.prototype.end=function(fn){this._endCalled&&console.warn("Warning: .end() was called twice. This is not supported in superagent"),this._endCalled=!0,this._callback=fn||noop,this._finalizeQueryString(),this._end()},Request.prototype._setUploadTimeout=function(){var self=this;this._uploadTimeout&&!this._uploadTimeoutTimer&&(this._uploadTimeoutTimer=setTimeout((function(){self._timeoutError("Upload timeout of ",self._uploadTimeout,"ETIMEDOUT")}),this._uploadTimeout))},Request.prototype._end=function(){if(this._aborted)return this.callback(new Error("The request has been aborted even before .end() was called"));var self=this;this.xhr=request.getXHR();var xhr=this.xhr,data=this._formData||this._data;this._setTimeouts(),xhr.onreadystatechange=function(){var readyState=xhr.readyState;if(readyState>=2&&self._responseTimeoutTimer&&clearTimeout(self._responseTimeoutTimer),4===readyState){var status;try{status=xhr.status}catch(_unused5){status=0}if(!status){if(self.timedout||self._aborted)return;return self.crossDomainError()}self.emit("end")}};var handleProgress=function(direction,e){e.total>0&&(e.percent=e.loaded/e.total*100,100===e.percent&&clearTimeout(self._uploadTimeoutTimer)),e.direction=direction,self.emit("progress",e)};if(this.hasListeners("progress"))try{xhr.addEventListener("progress",handleProgress.bind(null,"download")),xhr.upload&&xhr.upload.addEventListener("progress",handleProgress.bind(null,"upload"))}catch(_unused6){}xhr.upload&&this._setUploadTimeout();try{this.username&&this.password?xhr.open(this.method,this.url,!0,this.username,this.password):xhr.open(this.method,this.url,!0)}catch(err){return this.callback(err)}if(this._withCredentials&&(xhr.withCredentials=!0),!this._formData&&"GET"!==this.method&&"HEAD"!==this.method&&"string"!=typeof data&&!this._isHost(data)){var contentType=this._header["content-type"],_serialize=this._serializer||request.serialize[contentType?contentType.split(";")[0]:""];!_serialize&&isJSON(contentType)&&(_serialize=request.serialize["application/json"]),_serialize&&(data=_serialize(data))}for(var field in this.header)null!==this.header[field]&&Object.prototype.hasOwnProperty.call(this.header,field)&&xhr.setRequestHeader(field,this.header[field]);this._responseType&&(xhr.responseType=this._responseType),this.emit("request",this),xhr.send(void 0===data?null:data)},request.agent=function(){return new agentBase},["GET","POST","OPTIONS","PATCH","PUT","DELETE"].forEach((function(method){agentBase.prototype[method.toLowerCase()]=function(url,fn){var req=new request.Request(method,url);return this._setDefaults(req),fn&&req.end(fn),req}})),agentBase.prototype.del=agentBase.prototype.delete,request.get=function(url,data,fn){var req=request("GET",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.head=function(url,data,fn){var req=request("HEAD",url);return"function"==typeof data&&(fn=data,data=null),data&&req.query(data),fn&&req.end(fn),req},request.options=function(url,data,fn){var req=request("OPTIONS",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.del=del,request.delete=del,request.patch=function(url,data,fn){var req=request("PATCH",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.post=function(url,data,fn){var req=request("POST",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req},request.put=function(url,data,fn){var req=request("PUT",url);return"function"==typeof data&&(fn=data,data=null),data&&req.send(data),fn&&req.end(fn),req}})),byteLength_1=(client.Request,function(b64){var lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1];return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}),toByteArray_1=function(b64){var tmp,i,lens=getLens(b64),validLen=lens[0],placeHoldersLen=lens[1],arr=new Arr(function(b64,validLen,placeHoldersLen){return 3*(validLen+placeHoldersLen)/4-placeHoldersLen}(0,validLen,placeHoldersLen)),curByte=0,len=placeHoldersLen>0?validLen-4:validLen;for(i=0;i>16&255,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp;2===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<2|revLookup[b64.charCodeAt(i+1)]>>4,arr[curByte++]=255&tmp);1===placeHoldersLen&&(tmp=revLookup[b64.charCodeAt(i)]<<10|revLookup[b64.charCodeAt(i+1)]<<4|revLookup[b64.charCodeAt(i+2)]>>2,arr[curByte++]=tmp>>8&255,arr[curByte++]=255&tmp);return arr},fromByteArray_1=function(uint8){for(var tmp,len=uint8.length,extraBytes=len%3,parts=[],i=0,len2=len-extraBytes;ilen2?len2:i+16383));1===extraBytes?(tmp=uint8[len-1],parts.push(lookup[tmp>>2]+lookup[tmp<<4&63]+"==")):2===extraBytes&&(tmp=(uint8[len-2]<<8)+uint8[len-1],parts.push(lookup[tmp>>10]+lookup[tmp>>4&63]+lookup[tmp<<2&63]+"="));return parts.join("")},lookup=[],revLookup=[],Arr="undefined"!=typeof Uint8Array?Uint8Array:Array,code="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=0,len=code.length;i0)throw new Error("Invalid string. Length must be a multiple of 4");var validLen=b64.indexOf("=");return-1===validLen&&(validLen=len),[validLen,validLen===len?0:4-validLen%4]}function encodeChunk(uint8,start,end){for(var tmp,num,output=[],i=start;i>18&63]+lookup[num>>12&63]+lookup[num>>6&63]+lookup[63&num]);return output.join("")}revLookup["-".charCodeAt(0)]=62,revLookup["_".charCodeAt(0)]=63;var base64Js={byteLength:byteLength_1,toByteArray:toByteArray_1,fromByteArray:fromByteArray_1};var base64Url={encode:function(str){return base64Js.fromByteArray(function(str){for(var arr=new Array(str.length),a=0;a=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function RequestWrapper(req){this.request=req,this.method=req.method,this.url=req.url,this.body=req._data,this.headers=req._header}function RequestObj(req){this.request=req}function RequestBuilder(options){this._sendTelemetry=!1!==options._sendTelemetry||options._sendTelemetry,this._telemetryInfo=options._telemetryInfo||null,this._timesToRetryFailedRequests=options._timesToRetryFailedRequests,this.headers=options.headers||{},this._universalLoginPage=options.universalLoginPage}function getWindow(){return window}RequestWrapper.prototype.abort=function(){this.request.abort()},RequestWrapper.prototype.getMethod=function(){return this.method},RequestWrapper.prototype.getBody=function(){return this.body},RequestWrapper.prototype.getUrl=function(){return this.url},RequestWrapper.prototype.getHeaders=function(){return this.headers},RequestObj.prototype.set=function(key,value){return this.request=this.request.set(key,value),this},RequestObj.prototype.send=function(body){return this.request=this.request.send(objectHelper.trimUserDetails(body)),this},RequestObj.prototype.withCredentials=function(){return this.request=this.request.withCredentials(),this},RequestObj.prototype.end=function(cb){return this.request.end(cb),new RequestWrapper(this.request)},RequestBuilder.prototype.setCommonConfiguration=function(ongoingRequest,options){if(options=options||{},this._timesToRetryFailedRequests>0&&(ongoingRequest=ongoingRequest.retry(this._timesToRetryFailedRequests)),options.noHeaders)return ongoingRequest;var headers=this.headers;ongoingRequest=ongoingRequest.set("Content-Type","application/json");for(var keys=Object.keys(this.headers),a=0;a0&&warn.warning("Following parameters are not allowed on the `/authorize` endpoint: ["+notAllowed.join(",")+"]"),params}},t="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs")}()}},r.exports),r.exports}var r=e((function(e,r){e.exports=function(){function e(t){return"function"==typeof t}var r=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h="undefined"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f="undefined"==typeof self&&"undefined"!=typeof process&&"[object process]"==={}.toString.call(process),c="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join("")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){"string"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)})),o=e((function(t,e){var r,n;t.exports=(r=(n=i$1).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join("")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},n.enc.Base64)})),s=e((function(t,e){t.exports=i$1.enc.Hex})),h=e((function(e,r){(function(){var t;function r(t,e,r){null!=t&&("number"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&"string"!=typeof t?256:e))}function i(){return new r(null)}var n="undefined"!=typeof navigator;n&&"Microsoft Internet Explorer"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&"Netscape"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?"-"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return"-"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:"0"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return"0";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h="";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if("number"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error("Invalid key data");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\s\n]]/gi,"");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error("Signature does not match with the key modulus.");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,""));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error("Hashing algorithm is not supported.");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l="undefined"!=typeof Uint8Array?Uint8Array:Array,d="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",m=0,v=d.length;m0)throw new Error("Invalid string. Length must be a multiple of 4");var r=t.indexOf("=");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join("=")}function w(t){return t=g(t).replace(/\-/g,"+").replace(/_/g,"/"),decodeURIComponent(function(t){for(var e="",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\/\/\//)?t[0].replace(/^([^/:]+):\/*/,"$1:///"):t[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(n=n.replace(/^[\/]+/,"")),n=n.replace(/[\/]+$/,i0?"?":"")+s.join("&")}return function(){return t("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()}));function _(t,e){return e=e||{},new Promise((function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||"get",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,(function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+","+r:r})),r(a())},n.onerror=i,n.withCredentials="include"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)}))}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name="ConfigurationError",this.message=t||""}function A(t){this.name="TokenValidationError",this.message=t||""}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return"number"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||"RS256",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock="function"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D("The leeway should be positive and lower than five minutes.");if("RS256"!==this.expectedAlg)throw new D('Signature algorithm of "'+this.expectedAlg+'" is not supported. Expected the ID token to be signed with "RS256".')}function PluginHandler(webAuth,plugins){this.plugins=plugins;for(var a=0;a1){if(!d||"string"!=typeof d)return r(new A("Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected "'+g.audience+'", found "'+d+'"',!1))}if(!c||!x(c))return r(new A("Expiration Time (exp) claim must be a number present in the ID token",!1));if(!l||!x(l))return r(new A("Issued At (iat) claim must be a number present in the ID token"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time "'+y+'" is after expiration time "'+w+'"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time "'+y+'" is after last auth time at "'+S+'"'))}return r(null,i.payload)}))},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then((function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},("undefined"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,".well-known","jwks.json")).then(S).then((function(t){var e,r,i,n=null;for(e=0;e-1){null!==new RegExp("rv:([0-9]{2,2}[.0-9]{0,})").exec(ua)&&(rv=parseFloat(RegExp.$1))}return rv>=8}();return"undefined"!=typeof window&&window.JSON&&window.JSON.stringify&&window.JSON.parse&&window.postMessage?{open:function(opts,cb){if(!cb)throw"missing required callback argument";var err,iframe;opts.url||(err="missing required 'url' parameter"),opts.relay_url||(err="missing required 'relay_url' parameter"),err&&setTimeout((function(){cb(err)}),0),opts.window_name||(opts.window_name=null),opts.window_features&&!function(){try{var userAgent=navigator.userAgent;return-1!=userAgent.indexOf("Fennec/")||-1!=userAgent.indexOf("Firefox/")&&-1!=userAgent.indexOf("Android")}catch(e){}return!1}()||(opts.window_features=void 0);var messageTarget,origin=opts.origin||extractOrigin(opts.url);if(origin!==extractOrigin(opts.relay_url))return setTimeout((function(){cb("invalid arguments: origin of url and relay_url must match")}),0);isIE&&((iframe=document.createElement("iframe")).setAttribute("src",opts.relay_url),iframe.style.display="none",iframe.setAttribute("name","__winchan_relay_frame"),document.body.appendChild(iframe),messageTarget=iframe.contentWindow);var w=opts.popup||window.open(opts.url,opts.window_name,opts.window_features);opts.popup&&(w.location.href=opts.url),messageTarget||(messageTarget=w);var closeInterval=setInterval((function(){w&&w.closed&&(cleanup(),cb&&(cb("User closed the popup window"),cb=null))}),500),req=JSON.stringify({a:"request",d:opts.params});function cleanup(){if(iframe&&document.body.removeChild(iframe),iframe=void 0,closeInterval&&(closeInterval=clearInterval(closeInterval)),removeListener(window,"message",onMessage),removeListener(window,"unload",cleanup),w)try{w.close()}catch(securityViolation){messageTarget.postMessage("die",origin)}w=messageTarget=void 0}function onMessage(e){if(e.origin===origin){try{var d=JSON.parse(e.data)}catch(err){if(cb)return cb(err);throw err}"ready"===d.a?messageTarget.postMessage(req,origin):"error"===d.a?(cleanup(),cb&&(cb(d.d),cb=null)):"response"===d.a&&(cleanup(),cb&&(cb(null,d.d),cb=null))}}return addListener(window,"unload",cleanup),addListener(window,"message",onMessage),{originalPopup:w,close:cleanup,focus:function(){if(w)try{w.focus()}catch(e){}}}},onOpen:function(cb){var o="*",msgTarget=isIE?function(){for(var frames=window.opener.frames,i=frames.length-1;i>=0;i--)try{if(frames[i].location.protocol===window.location.protocol&&frames[i].location.host===window.location.host&&"__winchan_relay_frame"===frames[i].name)return frames[i]}catch(e){}}():window.opener;if(!msgTarget)throw"can't find relay frame";function doPost(msg){msg=JSON.stringify(msg),isIE?msgTarget.doPost(msg,o):msgTarget.postMessage(msg,o)}function onDie(e){if("die"===e.data)try{window.close()}catch(o_O){}}addListener(isIE?msgTarget:window,"message",(function onMessage(e){var d;try{d=JSON.parse(e.data)}catch(err){}d&&"request"===d.a&&(removeListener(window,"message",onMessage),o=e.origin,cb&&setTimeout((function(){cb(o,d.d,(function(r){cb=void 0,doPost({a:"response",d:r})}))}),0))})),addListener(isIE?msgTarget:window,"message",onDie);try{doPost({a:"ready"})}catch(e){addListener(msgTarget,"load",(function(e){doPost({a:"ready"})}))}var onUnload=function(){try{removeListener(isIE?msgTarget:window,"message",onDie)}catch(ohWell){}cb&&doPost({a:"error",d:"client closed window"}),cb=void 0;try{window.close()}catch(e){}};return addListener(window,"unload",onUnload),{detach:function(){removeListener(window,"unload",onUnload)}}}}:{open:function(url,winopts,arg,cb){setTimeout((function(){cb("unsupported browser")}),0)},onOpen:function(cb){setTimeout((function(){cb("unsupported browser")}),0)}}}();module.exports&&(module.exports=WinChan)}));var urlHelper={extractOrigin:function(url){/^https?:\/\//.test(url)||(url=window.location.href);var m=/^(https?:\/\/[-_a-zA-Z.0-9:]+)/.exec(url);return m?m[1]:url}};function PopupHandler(){this._current_popup=null}function Popup(webAuth,options){this.baseOptions=options,this.baseOptions.popupOrigin=options.popupOrigin,this.client=webAuth.client,this.webAuth=webAuth,this.transactionManager=new TransactionManager(this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(webAuth,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}function SilentAuthenticationHandler(options){this.authenticationUrl=options.authenticationUrl,this.timeout=options.timeout||6e4,this.handler=null,this.postMessageDataType=options.postMessageDataType||!1,this.postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().location.origin||windowHelper.getWindow().location.protocol+"//"+windowHelper.getWindow().location.hostname+(windowHelper.getWindow().location.port?":"+windowHelper.getWindow().location.port:"")}function UsernamePassword(options){this.baseOptions=options,this.request=new RequestBuilder(options),this.transactionManager=new TransactionManager(this.baseOptions)}function HostedPages(client,options){this.baseOptions=options,this.client=client,this.baseOptions.universalLoginPage=!0,this.request=new RequestBuilder(this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings})}PopupHandler.prototype.calculatePosition=function(options){var width=options.width||500,height=options.height||600,_window=windowHelper.getWindow(),screenX=void 0!==_window.screenX?_window.screenX:_window.screenLeft,screenY=void 0!==_window.screenY?_window.screenY:_window.screenTop,outerWidth=void 0!==_window.outerWidth?_window.outerWidth:_window.document.body.clientWidth,outerHeight=void 0!==_window.outerHeight?_window.outerHeight:_window.document.body.clientHeight;return{width:width,height:height,left:options.left||screenX+(outerWidth-width)/2,top:options.top||screenY+(outerHeight-height)/2}},PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHelper.getWindow(),popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),url=options.url||"about:blank",windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"auth0_signup_popup",windowFeatures),this._current_popup.kill=function(){this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,relayUrl,options,cb){var _this=this,popupPosition=this.calculatePosition(options.popupOptions||{}),popupOptions=objectHelper.merge(popupPosition).with(options.popupOptions),winchanOptions=objectHelper.merge({url:url,relay_url:relayUrl,window_features:lib_stringify(popupOptions,{delimiter:",",encode:!1}),popup:this._current_popup}).with(options),popup=winchan.open(winchanOptions,(function(err,data){if(!err||"SyntaxError"!==err.name)return _this._current_popup=null,cb(err,data)}));return popup.focus(),popup},Popup.prototype.buildPopupHandler=function(){var pluginHandler=this.baseOptions.plugins.get("popup.getPopupHandler");return pluginHandler?pluginHandler.getPopupHandler():new PopupHandler},Popup.prototype.preload=function(options){options=options||{};var popup=this.buildPopupHandler();return popup.preload(options),popup},Popup.prototype.getPopupHandler=function(options,preload){return options.popupHandler?options.popupHandler:preload?this.preload(options):this.buildPopupHandler()},Popup.prototype.callback=function(options){var _this=this,theWindow=windowHelper.getWindow(),originUrl=(options=options||{}).popupOrigin||this.baseOptions.popupOrigin||windowHelper.getOrigin();theWindow.opener?winchan.onOpen((function(popupOrigin,r,cb){if(popupOrigin!==originUrl)return cb({error:"origin_mismatch",error_description:"The popup's origin ("+popupOrigin+") should match the `popupOrigin` parameter ("+originUrl+")."});_this.webAuth.parseHash(options||{},(function(err,data){return cb(err||data)}))})):theWindow.doPost=function(msg){theWindow.parent&&theWindow.parent.postMessage(msg,originUrl)}},Popup.prototype.authorize=function(options,cb){var url,relayUrl,popOpts={},pluginHandler=this.baseOptions.plugins.get("popup.authorize"),params=objectHelper.merge(this.baseOptions,["clientID","scope","domain","audience","tenant","responseType","redirectUri","_csrf","state","_intstate","nonce"]).with(objectHelper.blacklist(options,["popupHandler"]));return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),relayUrl=urlJoin(this.baseOptions.rootUrl,"relay.html"),options.owp?params.owp=!0:(popOpts.origin=urlHelper.extractOrigin(params.redirectUri),relayUrl=params.redirectUri),options.popupOptions&&(popOpts.popupOptions=objectHelper.pick(options.popupOptions,["width","height","top","left"])),pluginHandler&&(params=pluginHandler.processParams(params)),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",delete params.domain,url=this.client.buildAuthorizeUrl(params),this.getPopupHandler(options).load(url,relayUrl,popOpts,wrapCallback(cb,{keepOriginalCasing:!0}))},Popup.prototype.loginWithCredentials=function(options,cb){options.realm=options.realm||options.connection,options.popup=!0,options=objectHelper.merge(this.baseOptions,["redirectUri","responseType","state","nonce"]).with(objectHelper.blacklist(options,["popupHandler","connection"])),options=this.transactionManager.process(options),this.crossOriginAuthentication.login(options,cb)},Popup.prototype.passwordlessVerify=function(options,cb){var _this=this;return this.client.passwordless.verify(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.username=options.phoneNumber||options.email,options.password=options.verificationCode,delete options.email,delete options.phoneNumber,delete options.verificationCode,delete options.type,_this.client.loginWithResourceOwner(options,cb)}))},Popup.prototype.signupAndLogin=function(options,cb){var _this=this;return this.client.dbConnection.signup(options,(function(err){if(err)return cb(err);_this.loginWithCredentials(options,cb)}))},SilentAuthenticationHandler.create=function(options){return new SilentAuthenticationHandler(options)},SilentAuthenticationHandler.prototype.login=function(usePostMessage,callback){this.handler=new IframeHandler({auth0:this.auth0,url:this.authenticationUrl,eventListenerType:usePostMessage?"message":"load",callback:this.getCallbackHandler(callback,usePostMessage),timeout:this.timeout,eventValidator:this.getEventValidator(),timeoutCallback:function(){callback(null,"#error=timeout&error_description=Timeout+during+authentication+renew.")},usePostMessage:usePostMessage||!1}),this.handler.init()},SilentAuthenticationHandler.prototype.getEventValidator=function(){var _this=this;return{isValid:function(eventData){switch(eventData.event.type){case"message":return eventData.event.origin===_this.postMessageOrigin&&eventData.event.source===_this.handler.iframe.contentWindow&&(!1===_this.postMessageDataType||eventData.event.data.type&&eventData.event.data.type===_this.postMessageDataType);case"load":if("about:"===eventData.sourceObject.contentWindow.location.protocol)return!1;default:return!0}}}},SilentAuthenticationHandler.prototype.getCallbackHandler=function(callback,usePostMessage){return function(eventData){var callbackValue;callbackValue=usePostMessage?"object"==typeof eventData.event.data&&eventData.event.data.hash?eventData.event.data.hash:eventData.event.data:eventData.sourceObject.contentWindow.location.hash,callback(null,callbackValue)}},UsernamePassword.prototype.login=function(options,cb){var url,body;return url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","login"),options.username=options.username||options.email,options=objectHelper.blacklist(options,["email"]),body=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience"]).with(options),body=this.transactionManager.process(body),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},UsernamePassword.prototype.callback=function(formHtml){var div,_document=windowHelper.getDocument();(div=_document.createElement("div")).innerHTML=formHtml,_document.body.appendChild(div).children[0].submit()},HostedPages.prototype.login=function(options,cb){if(windowHelper.getWindow().location.host!==this.baseOptions.domain)throw new Error("This method is meant to be used only inside the Universal Login Page.");var usernamePassword,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","tenant","responseType","responseMode","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(usernamePassword=new UsernamePassword(this.baseOptions)).login(params,(function(err,data){return err?cb(err):usernamePassword.callback(data)}))},HostedPages.prototype.signupAndLogin=function(options,cb){var _this=this;return _this.client.client.dbConnection.signup(options,(function(err){return err?cb(err):_this.login(options,cb)}))},HostedPages.prototype.getSSOData=function(withActiveDirectories,cb){var url,params="";return"function"==typeof withActiveDirectories&&(cb=withActiveDirectories,withActiveDirectories=!1),assert.check(withActiveDirectories,{type:"boolean",message:"withActiveDirectories parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),withActiveDirectories&&(params="?"+lib_stringify({ldaps:1,client_id:this.baseOptions.clientID})),url=urlJoin(this.baseOptions.rootUrl,"user","ssodata",params),this.request.get(url,{noHeaders:!0}).withCredentials().end(wrapCallback(cb))};var noop=function(){},defaults$2={lang:"en",templates:{auth0:function(challenge){var message="code"===challenge.type?"Enter the code shown above":"Solve the formula shown above";return'
\n \n \n
\n'},recaptcha_v2:function(){return'
'},error:function(){return'
Error getting the bot detection challenge. Please contact the system administrator.
'}}};function handleRecaptchaProvider(element,options,challenge){var widgetId=element.hasAttribute("data-wid")&&element.getAttribute("data-wid");function setValue(value){element.querySelector('input[name="captcha"]').value=value||""}if(widgetId)return setValue(),void window.grecaptcha.reset(widgetId);element.innerHTML=options.templates[challenge.provider](challenge);var recaptchaDiv=element.querySelector(".recaptcha");!function(element,lang,callback){var callbackName="recaptchaCallback_"+Math.floor(1000001*Math.random());window[callbackName]=function(){delete window[callbackName],callback()};var script=window.document.createElement("script");script.src="https://www.google.com/recaptcha/api.js?hl="+lang+"&onload="+callbackName,script.async=!0,window.document.body.appendChild(script)}(0,options.lang,(function(){widgetId=window.grecaptcha.render(recaptchaDiv,{callback:setValue,"expired-callback":function(){setValue()},"error-callback":function(){setValue()},sitekey:challenge.siteKey}),element.setAttribute("data-wid",widgetId)}))}var captcha={render:function(auth0Client,element,options,callback){function load(done){done=done||noop,auth0Client.getChallenge((function(err,challenge){return err?(element.innerHTML=options.templates.error(err),done(err)):challenge.required?(element.style.display="","auth0"===challenge.provider?function(element,options,challenge,load){element.innerHTML=options.templates[challenge.provider](challenge),element.querySelector(".captcha-reload").addEventListener("click",(function(e){e.preventDefault(),load()}))}(element,options,challenge,load):"recaptcha_v2"===challenge.provider&&handleRecaptchaProvider(element,options,challenge),void done()):(element.style.display="none",void(element.innerHTML=""))}))}return options=objectHelper.merge(defaults$2).with(options||{}),load(callback),{reload:load,getValue:function(){var captchaInput=element.querySelector('input[name="captcha"]');if(captchaInput)return captchaInput.value}}}};function defaultClock(){return new Date}function WebAuth(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},popupOrigin:{optional:!0,type:"string",message:"popupOrigin is not valid"},leeway:{optional:!0,type:"number",message:"leeway is not valid"},plugins:{optional:!0,type:"array",message:"plugins is not valid"},maxAge:{optional:!0,type:"number",message:"maxAge is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"},_timesToRetryFailedRequests:{optional:!0,type:"number",message:"_timesToRetryFailedRequests option is not valid"}}),options.overrides&&assert.check(options.overrides,{type:"object",message:"overrides option is not valid"},{__tenant:{optional:!0,type:"string",message:"__tenant option is required"},__token_issuer:{optional:!0,type:"string",message:"__token_issuer option is required"},__jwks_uri:{optional:!0,type:"string",message:"__jwks_uri is required"}}),this.baseOptions=options,this.baseOptions.plugins=new PluginHandler(this,this.baseOptions.plugins||[]),this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions._timesToRetryFailedRequests=options._timesToRetryFailedRequests?parseInt(options._timesToRetryFailedRequests,0):0,this.baseOptions.tenant=this.baseOptions.overrides&&this.baseOptions.overrides.__tenant||this.baseOptions.domain.split(".")[0],this.baseOptions.token_issuer=this.baseOptions.overrides&&this.baseOptions.overrides.__token_issuer||"https://"+this.baseOptions.domain+"/",this.baseOptions.jwksURI=this.baseOptions.overrides&&this.baseOptions.overrides.__jwks_uri,this.transactionManager=new TransactionManager(this.baseOptions),this.client=new Authentication(this.baseOptions),this.redirect=new Redirect(this,this.baseOptions),this.popup=new Popup(this,this.baseOptions),this.crossOriginAuthentication=new CrossOriginAuthentication(this,this.baseOptions),this.webMessageHandler=new WebMessageHandler(this),this._universalLogin=new HostedPages(this,this.baseOptions),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function PasswordlessAuthentication(request,options){this.baseOptions=options,this.request=request}function DBConnection(request,options){this.baseOptions=options,this.request=request}function Authentication(auth0,options){2===arguments.length?this.auth0=auth0:options=auth0,assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},clientID:{type:"string",message:"clientID option is required"},responseType:{optional:!0,type:"string",message:"responseType is not valid"},responseMode:{optional:!0,type:"string",message:"responseMode is not valid"},redirectUri:{optional:!0,type:"string",message:"redirectUri is not valid"},scope:{optional:!0,type:"string",message:"scope is not valid"},audience:{optional:!0,type:"string",message:"audience is not valid"},_disableDeprecationWarnings:{optional:!0,type:"boolean",message:"_disableDeprecationWarnings option is not valid"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions._sendTelemetry=!1!==this.baseOptions._sendTelemetry||this.baseOptions._sendTelemetry,this.baseOptions.rootUrl=this.baseOptions.domain&&0===this.baseOptions.domain.toLowerCase().indexOf("http")?this.baseOptions.domain:"https://"+this.baseOptions.domain,this.request=new RequestBuilder(this.baseOptions),this.passwordless=new PasswordlessAuthentication(this.request,this.baseOptions),this.dbConnection=new DBConnection(this.request,this.baseOptions),this.warn=new Warn({disableWarnings:!!options._disableDeprecationWarnings}),this.ssodataStorage=new SSODataStorage(this.baseOptions)}function Management(options){assert.check(options,{type:"object",message:"options parameter is not valid"},{domain:{type:"string",message:"domain option is required"},token:{type:"string",message:"token option is required"},_sendTelemetry:{optional:!0,type:"boolean",message:"_sendTelemetry option is not valid"},_telemetryInfo:{optional:!0,type:"object",message:"_telemetryInfo option is not valid"}}),this.baseOptions=options,this.baseOptions.headers={Authorization:"Bearer "+this.baseOptions.token},this.request=new RequestBuilder(this.baseOptions),this.baseOptions.rootUrl=urlJoin("https://"+this.baseOptions.domain,"api","v2")}WebAuth.prototype.parseHash=function(options,cb){var parsedQs,err;cb||"function"!=typeof options?options=options||{}:(cb=options,options={});var _window=windowHelper.getWindow(),hashStr=void 0===options.hash?_window.location.hash:options.hash;if(hashStr=hashStr.replace(/^#?\/?/,""),(parsedQs=lib_parse(hashStr)).hasOwnProperty("error"))return err=error.buildResponse(parsedQs.error,parsedQs.error_description),parsedQs.state&&(err.state=parsedQs.state),cb(err);if(!parsedQs.hasOwnProperty("access_token")&&!parsedQs.hasOwnProperty("id_token")&&!parsedQs.hasOwnProperty("refresh_token"))return cb(null,null);var responseTypes=(this.baseOptions.responseType||options.responseType||"").split(" ");return responseTypes.length>0&&-1!==responseTypes.indexOf("token")&&!parsedQs.hasOwnProperty("access_token")?cb(error.buildResponse("invalid_hash","response_type contains `token`, but the parsed hash does not contain an `access_token` property")):responseTypes.length>0&&-1!==responseTypes.indexOf("id_token")&&!parsedQs.hasOwnProperty("id_token")?cb(error.buildResponse("invalid_hash","response_type contains `id_token`, but the parsed hash does not contain an `id_token` property")):this.validateAuthenticationResponse(options,parsedQs,cb)},WebAuth.prototype.validateAuthenticationResponse=function(options,parsedHash,cb){var _this=this;options.__enableIdPInitiatedLogin=options.__enableIdPInitiatedLogin||options.__enableImpersonation;var state=parsedHash.state,transaction=this.transactionManager.getStoredTransaction(state),transactionState=options.state||transaction&&transaction.state||null,transactionStateMatchesState=transactionState===state;if(!(!state&&!transactionState&&options.__enableIdPInitiatedLogin)&&!transactionStateMatchesState)return cb({error:"invalid_token",errorDescription:"`state` does not match."});var transactionNonce=options.nonce||transaction&&transaction.nonce||null,appState=options.state||transaction&&transaction.appState||null,callback=function(err,payload){if(err)return cb(err);var sub;transaction&&transaction.lastUsedConnection&&(payload&&(sub=payload.sub),_this.ssodataStorage.set(transaction.lastUsedConnection,sub));return cb(null,function(qsParams,appState,token){return{accessToken:qsParams.access_token||null,idToken:qsParams.id_token||null,idTokenPayload:token||null,appState:appState||null,refreshToken:qsParams.refresh_token||null,state:qsParams.state||null,expiresIn:qsParams.expires_in?parseInt(qsParams.expires_in,10):null,tokenType:qsParams.token_type||null,scope:qsParams.scope||null}}(parsedHash,appState,payload))};return parsedHash.id_token?this.validateToken(parsedHash.id_token,transactionNonce,(function(validationError,payload){if(!validationError)return parsedHash.access_token&&payload.at_hash?(new k).validateAccessToken(parsedHash.access_token,"RS256",payload.at_hash,(function(err){return err?callback(error.invalidToken(err.message)):callback(null,payload)})):callback(null,payload);if("invalid_token"!==validationError.error||validationError.errorDescription&&validationError.errorDescription.indexOf("Nonce (nonce) claim value mismatch in the ID token")>-1)return callback(validationError);var decodedToken=(new k).decode(parsedHash.id_token);if("HS256"!==decodedToken.header.alg)return callback(validationError);if((decodedToken.payload.nonce||null)!==transactionNonce)return callback({error:"invalid_token",errorDescription:'Nonce (nonce) claim value mismatch in the ID token; expected "'+transactionNonce+'", found "'+decodedToken.payload.nonce+'"'});if(!parsedHash.access_token){return callback({error:"invalid_token",description:"The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token"})}return _this.client.userInfo(parsedHash.access_token,(function(errUserInfo,profile){return errUserInfo?callback(errUserInfo):callback(null,profile)}))})):callback(null,null)},WebAuth.prototype.validateToken=function(token,nonce,cb){new k({issuer:this.baseOptions.token_issuer,jwksURI:this.baseOptions.jwksURI,audience:this.baseOptions.clientID,leeway:this.baseOptions.leeway||60,maxAge:this.baseOptions.maxAge,__clock:this.baseOptions.__clock||defaultClock}).verify(token,nonce,(function(err,payload){if(err)return cb(error.invalidToken(err.message));cb(null,payload)}))},WebAuth.prototype.renewAuth=function(options,cb){var usePostMessage=!!options.usePostMessage,postMessageDataType=options.postMessageDataType||!1,postMessageOrigin=options.postMessageOrigin||windowHelper.getWindow().origin,timeout=options.timeout,_this=this,params=objectHelper.merge(this.baseOptions,["clientID","redirectUri","responseType","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params.responseType=params.responseType||"token",params.responseMode=params.responseMode||"fragment",params=this.transactionManager.process(params),assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params.prompt="none",params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType","postMessageOrigin"]),SilentAuthenticationHandler.create({authenticationUrl:this.client.buildAuthorizeUrl(params),postMessageDataType:postMessageDataType,postMessageOrigin:postMessageOrigin,timeout:timeout}).login(usePostMessage,(function(err,hash){if("object"==typeof hash)return cb(err,hash);_this.parseHash({hash:hash},cb)}))},WebAuth.prototype.checkSession=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return"code"===params.responseType?cb({error:"error",error_description:"responseType can't be `code`"}):(options.nonce||(params=this.transactionManager.process(params)),params.redirectUri?(assert.check(params,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),params=objectHelper.blacklist(params,["usePostMessage","tenant","postMessageDataType"]),void this.webMessageHandler.run(params,wrapCallback(cb,{forceLegacyError:!0,ignoreCasing:!0}))):cb({error:"error",error_description:"redirectUri can't be empty"}))},WebAuth.prototype.changePassword=function(options,cb){return this.client.dbConnection.changePassword(options,cb)},WebAuth.prototype.passwordlessStart=function(options,cb){var authParams=objectHelper.merge(this.baseOptions,["responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options.authParams);return options.authParams=this.transactionManager.process(authParams),this.client.passwordless.start(options,cb)},WebAuth.prototype.signup=function(options,cb){return this.client.dbConnection.signup(options,cb)},WebAuth.prototype.authorize=function(options){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),(params=this.transactionManager.process(params)).scope=params.scope||"openid profile email",windowHelper.redirect(this.client.buildAuthorizeUrl(params))},WebAuth.prototype.signupAndAuthorize=function(options,cb){var _this=this;return this.client.dbConnection.signup(objectHelper.blacklist(options,["popupHandler"]),(function(err){if(err)return cb(err);options.realm=options.connection,options.username||(options.username=options.email),_this.client.login(options,cb)}))},WebAuth.prototype.login=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain?(params.connection=params.realm,delete params.realm,this._universalLogin.login(params,cb)):this.crossOriginAuthentication.login(params,cb)},WebAuth.prototype.passwordlessLogin=function(options,cb){var params=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);if(params=this.transactionManager.process(params),windowHelper.getWindow().location.host===this.baseOptions.domain)this.passwordlessVerify(params,cb);else{var crossOriginOptions=objectHelper.extend({credentialType:"http://auth0.com/oauth/grant-type/passwordless/otp",realm:params.connection,username:params.email||params.phoneNumber,otp:params.verificationCode},objectHelper.blacklist(params,["connection","email","phoneNumber","verificationCode"]));this.crossOriginAuthentication.login(crossOriginOptions,cb)}},WebAuth.prototype.crossOriginAuthenticationCallback=function(){this.crossOriginVerification()},WebAuth.prototype.crossOriginVerification=function(){this.crossOriginAuthentication.callback()},WebAuth.prototype.logout=function(options){windowHelper.redirect(this.client.buildLogoutUrl(options))},WebAuth.prototype.passwordlessVerify=function(options,cb){var _this=this,params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","nonce"]).with(options);return assert.check(params,{type:"object",message:"options parameter is not valid"},{responseType:{type:"string",message:"responseType option is required"}}),params=this.transactionManager.process(params),this.client.passwordless.verify(params,(function(err){return err?cb(err):windowHelper.redirect(_this.client.passwordless.buildVerifyUrl(params))}))},WebAuth.prototype.renderCaptcha=function(element,options,callback){return captcha.render(this.client,element,options,callback)},PasswordlessAuthentication.prototype.buildVerifyUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience","_csrf","state","_intstate","protocol","nonce"]).with(options),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client"]),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"passwordless","verify_redirect","?"+qString)},PasswordlessAuthentication.prototype.start=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},send:{type:"string",message:"send option is required",values:["link","code"],value_message:"send is not valid ([link, code])"},phoneNumber:{optional:!0,type:"string",message:"phoneNumber option is required",condition:function(o){return"code"===o.send||!o.email}},email:{optional:!0,type:"string",message:"email option is required",condition:function(o){return"link"===o.send||!o.phoneNumber}},authParams:{optional:!0,type:"object",message:"authParams option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"passwordless","start"),(body=objectHelper.merge(this.baseOptions,["clientID","responseType","redirectUri","scope"]).with(options)).scope&&(body.authParams=body.authParams||{},body.authParams.scope=body.authParams.scope||body.scope),body.redirectUri&&(body.authParams=body.authParams||{},body.authParams.redirect_uri=body.authParams.redirectUri||body.redirectUri),body.responseType&&(body.authParams=body.authParams||{},body.authParams.response_type=body.authParams.responseType||body.responseType),delete body.redirectUri,delete body.responseType,delete body.scope,body=objectHelper.toSnakeCase(body,["auth0Client","authParams"]),this.request.post(url).send(body).end(wrapCallback(cb))},PasswordlessAuthentication.prototype.verify=function(options,cb){var url,cleanOption;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},verificationCode:{type:"string",message:"verificationCode option is required"},phoneNumber:{optional:!1,type:"string",message:"phoneNumber option is required",condition:function(o){return!o.email}},email:{optional:!1,type:"string",message:"email option is required",condition:function(o){return!o.phoneNumber}}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),cleanOption=objectHelper.pick(options,["connection","verificationCode","phoneNumber","email","auth0Client"]),cleanOption=objectHelper.toSnakeCase(cleanOption,["auth0Client"]),url=urlJoin(this.baseOptions.rootUrl,"passwordless","verify"),this.request.post(url).send(cleanOption).end(wrapCallback(cb))},DBConnection.prototype.signup=function(options,cb){var url,body,metadata;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"},password:{type:"string",message:"password option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","signup"),metadata=(body=objectHelper.merge(this.baseOptions,["clientID","state"]).with(options)).user_metadata||body.userMetadata,body=objectHelper.blacklist(body,["scope","userMetadata","user_metadata"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),metadata&&(body.user_metadata=metadata),this.request.post(url).send(body).end(wrapCallback(cb))},DBConnection.prototype.changePassword=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{connection:{type:"string",message:"connection option is required"},email:{type:"string",message:"email option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"dbconnections","change_password"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options,["email","connection"]),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.buildAuthorizeUrl=function(options){var params,qString;return assert.check(options,{type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID","responseType","responseMode","redirectUri","scope","audience"]).with(options),assert.check(params,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},redirectUri:{optional:!0,type:"string",message:"redirectUri option is required"},responseType:{type:"string",message:"responseType option is required"},nonce:{type:"string",message:"nonce option is required",condition:function(o){return-1===o.responseType.indexOf("code")&&-1!==o.responseType.indexOf("id_token")}},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params.connection_scope&&assert.isArray(params.connection_scope)&&(params.connection_scope=params.connection_scope.join(",")),params=objectHelper.blacklist(params,["username","popupOptions","domain","tenant","timeout","appState"]),params=objectHelper.toSnakeCase(params,["auth0Client"]),params=parametersWhitelist.oauthAuthorizeParams(this.warn,params),qString=lib_stringify(params),urlJoin(this.baseOptions.rootUrl,"authorize","?"+qString)},Authentication.prototype.buildLogoutUrl=function(options){var params,qString;return assert.check(options,{optional:!0,type:"object",message:"options parameter is not valid"}),params=objectHelper.merge(this.baseOptions,["clientID"]).with(options||{}),this.baseOptions._sendTelemetry&&(params.auth0Client=this.request.getTelemetryData()),params=objectHelper.toSnakeCase(params,["auth0Client","returnTo"]),qString=lib_stringify(objectHelper.blacklist(params,["federated"])),options&&void 0!==options.federated&&!1!==options.federated&&"false"!==options.federated&&(qString+="&federated"),urlJoin(this.baseOptions.rootUrl,"v2","logout","?"+qString)},Authentication.prototype.loginWithDefaultDirectory=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="password",this.oauthToken(options,cb)},Authentication.prototype.login=function(options,cb){return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},realm:{type:"string",message:"realm option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),options.grantType="http://auth0.com/oauth/grant-type/password-realm",this.oauthToken(options,cb)},Authentication.prototype.oauthToken=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","token"),body=objectHelper.merge(this.baseOptions,["clientID","scope","audience"]).with(options),assert.check(body,{type:"object",message:"options parameter is not valid"},{clientID:{type:"string",message:"clientID option is required"},grantType:{type:"string",message:"grantType option is required"},scope:{optional:!0,type:"string",message:"scope option is required"},audience:{optional:!0,type:"string",message:"audience option is required"}}),body=objectHelper.toSnakeCase(body,["auth0Client"]),body=parametersWhitelist.oauthTokenParams(this.warn,body),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.loginWithResourceOwner=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{username:{type:"string",message:"username option is required"},password:{type:"string",message:"password option is required"},connection:{type:"string",message:"connection option is required"},scope:{optional:!0,type:"string",message:"scope option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"oauth","ro"),body=objectHelper.merge(this.baseOptions,["clientID","scope"]).with(options,["username","password","scope","connection","device"]),(body=objectHelper.toSnakeCase(body,["auth0Client"])).grant_type=body.grant_type||"password",this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getSSOData=function(withActiveDirectories,cb){if(this.auth0||(this.auth0=new WebAuth(this.baseOptions)),windowHelper.getWindow().location.host===this.baseOptions.domain)return this.auth0._universalLogin.getSSOData(withActiveDirectories,cb);"function"==typeof withActiveDirectories&&(cb=withActiveDirectories),assert.check(cb,{type:"function",message:"cb parameter is not valid"});var clientId=this.baseOptions.clientID,ssodataInformation=this.ssodataStorage.get()||{};this.auth0.checkSession({responseType:"token id_token",scope:"openid profile email",connection:ssodataInformation.lastUsedConnection,timeout:5e3},(function(err,result){return err?"login_required"===err.error?cb(null,{sso:!1}):("consent_required"===err.error&&(err.error_description="Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`."),cb(err,{sso:!1})):ssodataInformation.lastUsedSub&&ssodataInformation.lastUsedSub!==result.idTokenPayload.sub?cb(err,{sso:!1}):cb(null,{lastUsedConnection:{name:ssodataInformation.lastUsedConnection},lastUsedUserID:result.idTokenPayload.sub,lastUsedUsername:result.idTokenPayload.email||result.idTokenPayload.name,lastUsedClientID:clientId,sessionClients:[clientId],sso:!0})}))},Authentication.prototype.userInfo=function(accessToken,cb){var url;return assert.check(accessToken,{type:"string",message:"accessToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"userinfo"),this.request.get(url).set("Authorization","Bearer "+accessToken).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.getChallenge=function(cb){if(assert.check(cb,{type:"function",message:"cb parameter is not valid"}),!this.baseOptions.state)return cb();var url=urlJoin(this.baseOptions.rootUrl,"usernamepassword","challenge");return this.request.post(url).send({state:this.baseOptions.state}).end(wrapCallback(cb,{ignoreCasing:!0}))},Authentication.prototype.delegation=function(options,cb){var url,body;return assert.check(options,{type:"object",message:"options parameter is not valid"},{grant_type:{type:"string",message:"grant_type option is required"}}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"delegation"),body=objectHelper.merge(this.baseOptions,["clientID"]).with(options),body=objectHelper.toSnakeCase(body,["auth0Client"]),this.request.post(url).send(body).end(wrapCallback(cb))},Authentication.prototype.getUserCountry=function(cb){var url;return assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"user","geoloc","country"),this.request.get(url).end(wrapCallback(cb))},Management.prototype.getUser=function(userId,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.get(url).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserMetadata=function(userId,userMetadata,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(userMetadata,{type:"object",message:"userMetadata parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send({user_metadata:userMetadata}).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.patchUserAttributes=function(userId,user,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(user,{type:"object",message:"user parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId),this.request.patch(url).send(user).end(wrapCallback(cb,{ignoreCasing:!0}))},Management.prototype.linkUser=function(userId,secondaryUserToken,cb){var url;return assert.check(userId,{type:"string",message:"userId parameter is not valid"}),assert.check(secondaryUserToken,{type:"string",message:"secondaryUserToken parameter is not valid"}),assert.check(cb,{type:"function",message:"cb parameter is not valid"}),url=urlJoin(this.baseOptions.rootUrl,"users",userId,"identities"),this.request.post(url).send({link_with:secondaryUserToken}).end(wrapCallback(cb,{ignoreCasing:!0}))};var index={Authentication:Authentication,Management:Management,WebAuth:WebAuth,version:version};exports.Authentication=Authentication,exports.Management=Management,exports.WebAuth=WebAuth,exports.default=index,exports.version=version,Object.defineProperty(exports,"__esModule",{value:!0})})); +//# sourceMappingURL=auth0.min.js.map diff --git a/dist/auth0.min.js.map b/dist/auth0.min.js.map new file mode 100644 index 00000000..61f47e35 --- /dev/null +++ b/dist/auth0.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"auth0.min.js","sources":["../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../node_modules/component-emitter/index.js","../node_modules/fast-safe-stringify/index.js","../node_modules/superagent/lib/is-object.js","../node_modules/superagent/lib/request-base.js","../node_modules/superagent/lib/utils.js","../node_modules/superagent/lib/response-base.js","../node_modules/superagent/lib/agent-base.js","../node_modules/base64-js/index.js","../node_modules/superagent/lib/client.js","../src/helper/base64_url.js","../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/request-builder.js","../src/helper/window.js","../src/helper/storage/dummy.js","../node_modules/js-cookie/src/js.cookie.js","../src/helper/storage/cookie.js","../src/helper/warn.js","../src/helper/storage/handler.js","../src/helper/storage.js","../src/helper/ssodata.js","../src/helper/error.js","../src/helper/response-handler.js","../src/helper/parameters-whitelist.js","../node_modules/idtoken-verifier/build/idtoken-verifier.esm.js","../src/helper/plugins.js","../src/helper/random.js","../src/web-auth/transaction-manager.js","../src/helper/iframe-handler.js","../src/web-auth/web-message-handler.js","../src/web-auth/cross-origin-authentication.js","../src/web-auth/redirect.js","../src/helper/times.js","../node_modules/winchan/winchan.js","../src/helper/url.js","../src/helper/popup-handler.js","../src/web-auth/popup.js","../src/web-auth/silent-authentication-handler.js","../src/web-auth/username-password.js","../src/web-auth/hosted-pages.js","../src/web-auth/captcha.js","../src/web-auth/index.js","../src/authentication/passwordless-authentication.js","../src/authentication/db-connection.js","../src/authentication/index.js","../src/management/index.js","../src/index.js"],"sourcesContent":["(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","\r\n/**\r\n * Expose `Emitter`.\r\n */\r\n\r\nif (typeof module !== 'undefined') {\r\n module.exports = Emitter;\r\n}\r\n\r\n/**\r\n * Initialize a new `Emitter`.\r\n *\r\n * @api public\r\n */\r\n\r\nfunction Emitter(obj) {\r\n if (obj) return mixin(obj);\r\n};\r\n\r\n/**\r\n * Mixin the emitter properties.\r\n *\r\n * @param {Object} obj\r\n * @return {Object}\r\n * @api private\r\n */\r\n\r\nfunction mixin(obj) {\r\n for (var key in Emitter.prototype) {\r\n obj[key] = Emitter.prototype[key];\r\n }\r\n return obj;\r\n}\r\n\r\n/**\r\n * Listen on the given `event` with `fn`.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.on =\r\nEmitter.prototype.addEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\r\n .push(fn);\r\n return this;\r\n};\r\n\r\n/**\r\n * Adds an `event` listener that will be invoked a single\r\n * time then automatically removed.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.once = function(event, fn){\r\n function on() {\r\n this.off(event, on);\r\n fn.apply(this, arguments);\r\n }\r\n\r\n on.fn = fn;\r\n this.on(event, on);\r\n return this;\r\n};\r\n\r\n/**\r\n * Remove the given callback for `event` or all\r\n * registered callbacks.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.off =\r\nEmitter.prototype.removeListener =\r\nEmitter.prototype.removeAllListeners =\r\nEmitter.prototype.removeEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n\r\n // all\r\n if (0 == arguments.length) {\r\n this._callbacks = {};\r\n return this;\r\n }\r\n\r\n // specific event\r\n var callbacks = this._callbacks['$' + event];\r\n if (!callbacks) return this;\r\n\r\n // remove all handlers\r\n if (1 == arguments.length) {\r\n delete this._callbacks['$' + event];\r\n return this;\r\n }\r\n\r\n // remove specific handler\r\n var cb;\r\n for (var i = 0; i < callbacks.length; i++) {\r\n cb = callbacks[i];\r\n if (cb === fn || cb.fn === fn) {\r\n callbacks.splice(i, 1);\r\n break;\r\n }\r\n }\r\n\r\n // Remove event specific arrays for event types that no\r\n // one is subscribed for to avoid memory leak.\r\n if (callbacks.length === 0) {\r\n delete this._callbacks['$' + event];\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Emit `event` with the given args.\r\n *\r\n * @param {String} event\r\n * @param {Mixed} ...\r\n * @return {Emitter}\r\n */\r\n\r\nEmitter.prototype.emit = function(event){\r\n this._callbacks = this._callbacks || {};\r\n\r\n var args = new Array(arguments.length - 1)\r\n , callbacks = this._callbacks['$' + event];\r\n\r\n for (var i = 1; i < arguments.length; i++) {\r\n args[i - 1] = arguments[i];\r\n }\r\n\r\n if (callbacks) {\r\n callbacks = callbacks.slice(0);\r\n for (var i = 0, len = callbacks.length; i < len; ++i) {\r\n callbacks[i].apply(this, args);\r\n }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Return array of callbacks for `event`.\r\n *\r\n * @param {String} event\r\n * @return {Array}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.listeners = function(event){\r\n this._callbacks = this._callbacks || {};\r\n return this._callbacks['$' + event] || [];\r\n};\r\n\r\n/**\r\n * Check if this emitter has `event` handlers.\r\n *\r\n * @param {String} event\r\n * @return {Boolean}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.hasListeners = function(event){\r\n return !! this.listeners(event).length;\r\n};\r\n","module.exports = stringify\nstringify.default = stringify\nstringify.stable = deterministicStringify\nstringify.stableStringify = deterministicStringify\n\nvar arr = []\nvar replacerStack = []\n\n// Regular stringify\nfunction stringify (obj, replacer, spacer) {\n decirc(obj, '', [], undefined)\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer)\n } else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\nfunction decirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, stack, val)\n }\n } else {\n var keys = Object.keys(val)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n decirc(val[key], key, stack, val)\n }\n }\n stack.pop()\n }\n}\n\n// Stable-stringify\nfunction compareFunction (a, b) {\n if (a < b) {\n return -1\n }\n if (a > b) {\n return 1\n }\n return 0\n}\n\nfunction deterministicStringify (obj, replacer, spacer) {\n var tmp = deterministicDecirc(obj, '', [], undefined) || obj\n var res\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer)\n } else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer)\n }\n while (arr.length !== 0) {\n var part = arr.pop()\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3])\n } else {\n part[0][part[1]] = part[2]\n }\n }\n return res\n}\n\nfunction deterministicDecirc (val, k, stack, parent) {\n var i\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k)\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: '[Circular]' })\n arr.push([parent, k, val, propertyDescriptor])\n } else {\n replacerStack.push([val, k])\n }\n } else {\n parent[k] = '[Circular]'\n arr.push([parent, k, val])\n }\n return\n }\n }\n if (typeof val.toJSON === 'function') {\n return\n }\n stack.push(val)\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, stack, val)\n }\n } else {\n // Create a temporary object in the required way\n var tmp = {}\n var keys = Object.keys(val).sort(compareFunction)\n for (i = 0; i < keys.length; i++) {\n var key = keys[i]\n deterministicDecirc(val[key], key, stack, val)\n tmp[key] = val[key]\n }\n if (parent !== undefined) {\n arr.push([parent, k, val])\n parent[k] = tmp\n } else {\n return tmp\n }\n }\n stack.pop()\n }\n}\n\n// wraps replacer function to handle values we couldn't replace\n// and mark them as [Circular]\nfunction replaceGetterValues (replacer) {\n replacer = replacer !== undefined ? replacer : function (k, v) { return v }\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i]\n if (part[1] === key && part[0] === val) {\n val = '[Circular]'\n replacerStack.splice(i, 1)\n break\n }\n }\n }\n return replacer.call(this, key, val)\n }\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\nfunction isObject(obj) {\n return obj !== null && _typeof(obj) === 'object';\n}\n\nmodule.exports = isObject;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pcy1vYmplY3QuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJvYmoiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7Ozs7Ozs7QUFRQSxTQUFTQSxRQUFULENBQWtCQyxHQUFsQixFQUF1QjtBQUNyQixTQUFPQSxHQUFHLEtBQUssSUFBUixJQUFnQixRQUFPQSxHQUFQLE1BQWUsUUFBdEM7QUFDRDs7QUFFREMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCSCxRQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYW4gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge0Jvb2xlYW59XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBpc09iamVjdChvYmopIHtcbiAgcmV0dXJuIG9iaiAhPT0gbnVsbCAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0Jztcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBpc09iamVjdDtcbiJdfQ==","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Module of mixed-in functions shared between node and client code\n */\nvar isObject = require('./is-object');\n/**\n * Expose `RequestBase`.\n */\n\n\nmodule.exports = RequestBase;\n/**\n * Initialize a new `RequestBase`.\n *\n * @api public\n */\n\nfunction RequestBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in RequestBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(RequestBase.prototype, key)) obj[key] = RequestBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.clearTimeout = function () {\n clearTimeout(this._timer);\n clearTimeout(this._responseTimeoutTimer);\n clearTimeout(this._uploadTimeoutTimer);\n delete this._timer;\n delete this._responseTimeoutTimer;\n delete this._uploadTimeoutTimer;\n return this;\n};\n/**\n * Override default response body parser\n *\n * This function will be called to convert incoming data into request.body\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.parse = function (fn) {\n this._parser = fn;\n return this;\n};\n/**\n * Set format of binary response body.\n * In browser valid formats are 'blob' and 'arraybuffer',\n * which return Blob and ArrayBuffer, respectively.\n *\n * In Node all values result in Buffer.\n *\n * Examples:\n *\n * req.get('/')\n * .responseType('blob')\n * .end(callback);\n *\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.responseType = function (val) {\n this._responseType = val;\n return this;\n};\n/**\n * Override default request body serializer\n *\n * This function will be called to convert data set via .send or .attach into payload to send\n *\n * @param {Function}\n * @api public\n */\n\n\nRequestBase.prototype.serialize = function (fn) {\n this._serializer = fn;\n return this;\n};\n/**\n * Set timeouts.\n *\n * - response timeout is time between sending request and receiving the first byte of the response. Includes DNS and connection time.\n * - deadline is the time from start of the request to receiving response body in full. If the deadline is too short large files may not load at all on slow connections.\n * - upload is the time since last bit of data was sent or received. This timeout works only if deadline timeout is off\n *\n * Value of 0 or false means no timeout.\n *\n * @param {Number|Object} ms or {response, deadline}\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.timeout = function (options) {\n if (!options || _typeof(options) !== 'object') {\n this._timeout = options;\n this._responseTimeout = 0;\n this._uploadTimeout = 0;\n return this;\n }\n\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option)) {\n switch (option) {\n case 'deadline':\n this._timeout = options.deadline;\n break;\n\n case 'response':\n this._responseTimeout = options.response;\n break;\n\n case 'upload':\n this._uploadTimeout = options.upload;\n break;\n\n default:\n console.warn('Unknown timeout option', option);\n }\n }\n }\n\n return this;\n};\n/**\n * Set number of retry attempts on error.\n *\n * Failed requests will be retried 'count' times if timeout or err.code >= 500.\n *\n * @param {Number} count\n * @param {Function} [fn]\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.retry = function (count, fn) {\n // Default to 1 if no count passed or true\n if (arguments.length === 0 || count === true) count = 1;\n if (count <= 0) count = 0;\n this._maxRetries = count;\n this._retries = 0;\n this._retryCallback = fn;\n return this;\n};\n\nvar ERROR_CODES = ['ECONNRESET', 'ETIMEDOUT', 'EADDRINFO', 'ESOCKETTIMEDOUT'];\n/**\n * Determine if a request should be retried.\n * (Borrowed from segmentio/superagent-retry)\n *\n * @param {Error} err an error\n * @param {Response} [res] response\n * @returns {Boolean} if segment should be retried\n */\n\nRequestBase.prototype._shouldRetry = function (err, res) {\n if (!this._maxRetries || this._retries++ >= this._maxRetries) {\n return false;\n }\n\n if (this._retryCallback) {\n try {\n var override = this._retryCallback(err, res);\n\n if (override === true) return true;\n if (override === false) return false; // undefined falls back to defaults\n } catch (err_) {\n console.error(err_);\n }\n }\n\n if (res && res.status && res.status >= 500 && res.status !== 501) return true;\n\n if (err) {\n if (err.code && ERROR_CODES.includes(err.code)) return true; // Superagent timeout\n\n if (err.timeout && err.code === 'ECONNABORTED') return true;\n if (err.crossDomain) return true;\n }\n\n return false;\n};\n/**\n * Retry request\n *\n * @return {Request} for chaining\n * @api private\n */\n\n\nRequestBase.prototype._retry = function () {\n this.clearTimeout(); // node\n\n if (this.req) {\n this.req = null;\n this.req = this.request();\n }\n\n this._aborted = false;\n this.timedout = false;\n this.timedoutError = null;\n return this._end();\n};\n/**\n * Promise support\n *\n * @param {Function} resolve\n * @param {Function} [reject]\n * @return {Request}\n */\n\n\nRequestBase.prototype.then = function (resolve, reject) {\n var _this = this;\n\n if (!this._fullfilledPromise) {\n var self = this;\n\n if (this._endCalled) {\n console.warn('Warning: superagent request was sent twice, because both .end() and .then() were called. Never call .end() if you use promises');\n }\n\n this._fullfilledPromise = new Promise(function (resolve, reject) {\n self.on('abort', function () {\n if (_this._maxRetries && _this._maxRetries > _this._retries) {\n return;\n }\n\n if (_this.timedout && _this.timedoutError) {\n reject(_this.timedoutError);\n return;\n }\n\n var err = new Error('Aborted');\n err.code = 'ABORTED';\n err.status = _this.status;\n err.method = _this.method;\n err.url = _this.url;\n reject(err);\n });\n self.end(function (err, res) {\n if (err) reject(err);else resolve(res);\n });\n });\n }\n\n return this._fullfilledPromise.then(resolve, reject);\n};\n\nRequestBase.prototype.catch = function (cb) {\n return this.then(undefined, cb);\n};\n/**\n * Allow for extension\n */\n\n\nRequestBase.prototype.use = function (fn) {\n fn(this);\n return this;\n};\n\nRequestBase.prototype.ok = function (cb) {\n if (typeof cb !== 'function') throw new Error('Callback required');\n this._okCallback = cb;\n return this;\n};\n\nRequestBase.prototype._isResponseOK = function (res) {\n if (!res) {\n return false;\n }\n\n if (this._okCallback) {\n return this._okCallback(res);\n }\n\n return res.status >= 200 && res.status < 300;\n};\n/**\n * Get request header `field`.\n * Case-insensitive.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nRequestBase.prototype.get = function (field) {\n return this._header[field.toLowerCase()];\n};\n/**\n * Get case-insensitive header `field` value.\n * This is a deprecated internal API. Use `.get(field)` instead.\n *\n * (getHeader is no longer used internally by the superagent code base)\n *\n * @param {String} field\n * @return {String}\n * @api private\n * @deprecated\n */\n\n\nRequestBase.prototype.getHeader = RequestBase.prototype.get;\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n * Case-insensitive.\n *\n * Examples:\n *\n * req.get('/')\n * .set('Accept', 'application/json')\n * .set('X-API-Key', 'foobar')\n * .end(callback);\n *\n * req.get('/')\n * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n * .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequestBase.prototype.set = function (field, val) {\n if (isObject(field)) {\n for (var key in field) {\n if (Object.prototype.hasOwnProperty.call(field, key)) this.set(key, field[key]);\n }\n\n return this;\n }\n\n this._header[field.toLowerCase()] = val;\n this.header[field] = val;\n return this;\n};\n/**\n * Remove header `field`.\n * Case-insensitive.\n *\n * Example:\n *\n * req.get('/')\n * .unset('User-Agent')\n * .end(callback);\n *\n * @param {String} field field name\n */\n\n\nRequestBase.prototype.unset = function (field) {\n delete this._header[field.toLowerCase()];\n delete this.header[field];\n return this;\n};\n/**\n * Write the field `name` and `val`, or multiple fields with one object\n * for \"multipart/form-data\" request bodies.\n *\n * ``` js\n * request.post('/upload')\n * .field('foo', 'bar')\n * .end(callback);\n *\n * request.post('/upload')\n * .field({ foo: 'bar', baz: 'qux' })\n * .end(callback);\n * ```\n *\n * @param {String|Object} name name of field\n * @param {String|Blob|File|Buffer|fs.ReadStream} val value of field\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.field = function (name, val) {\n // name should be either a string or an object.\n if (name === null || undefined === name) {\n throw new Error('.field(name, val) name can not be empty');\n }\n\n if (this._data) {\n throw new Error(\".field() can't be used if .send() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObject(name)) {\n for (var key in name) {\n if (Object.prototype.hasOwnProperty.call(name, key)) this.field(key, name[key]);\n }\n\n return this;\n }\n\n if (Array.isArray(val)) {\n for (var i in val) {\n if (Object.prototype.hasOwnProperty.call(val, i)) this.field(name, val[i]);\n }\n\n return this;\n } // val should be defined now\n\n\n if (val === null || undefined === val) {\n throw new Error('.field(name, val) val can not be empty');\n }\n\n if (typeof val === 'boolean') {\n val = String(val);\n }\n\n this._getFormData().append(name, val);\n\n return this;\n};\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request} request\n * @api public\n */\n\n\nRequestBase.prototype.abort = function () {\n if (this._aborted) {\n return this;\n }\n\n this._aborted = true;\n if (this.xhr) this.xhr.abort(); // browser\n\n if (this.req) this.req.abort(); // node\n\n this.clearTimeout();\n this.emit('abort');\n return this;\n};\n\nRequestBase.prototype._auth = function (user, pass, options, base64Encoder) {\n switch (options.type) {\n case 'basic':\n this.set('Authorization', \"Basic \".concat(base64Encoder(\"\".concat(user, \":\").concat(pass))));\n break;\n\n case 'auto':\n this.username = user;\n this.password = pass;\n break;\n\n case 'bearer':\n // usage would be .auth(accessToken, { type: 'bearer' })\n this.set('Authorization', \"Bearer \".concat(user));\n break;\n\n default:\n break;\n }\n\n return this;\n};\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\n\nRequestBase.prototype.withCredentials = function (on) {\n // This is browser-only functionality. Node side is no-op.\n if (on === undefined) on = true;\n this._withCredentials = on;\n return this;\n};\n/**\n * Set the max redirects to `n`. Does nothing in browser XHR implementation.\n *\n * @param {Number} n\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.redirects = function (n) {\n this._maxRedirects = n;\n return this;\n};\n/**\n * Maximum size of buffered response body, in bytes. Counts uncompressed size.\n * Default 200MB.\n *\n * @param {Number} n number of bytes\n * @return {Request} for chaining\n */\n\n\nRequestBase.prototype.maxResponseSize = function (n) {\n if (typeof n !== 'number') {\n throw new TypeError('Invalid argument');\n }\n\n this._maxResponseSize = n;\n return this;\n};\n/**\n * Convert to a plain javascript object (not JSON string) of scalar properties.\n * Note as this method is designed to return a useful non-this value,\n * it cannot be chained.\n *\n * @return {Object} describing method, url, and data of this request\n * @api public\n */\n\n\nRequestBase.prototype.toJSON = function () {\n return {\n method: this.method,\n url: this.url,\n data: this._data,\n headers: this._header\n };\n};\n/**\n * Send `data` as the request body, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n * // manual json\n * request.post('/user')\n * .type('json')\n * .send('{\"name\":\"tj\"}')\n * .end(callback)\n *\n * // auto json\n * request.post('/user')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // manual x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send('name=tj')\n * .end(callback)\n *\n * // auto x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // defaults to x-www-form-urlencoded\n * request.post('/user')\n * .send('name=tobi')\n * .send('species=ferret')\n * .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n// eslint-disable-next-line complexity\n\n\nRequestBase.prototype.send = function (data) {\n var isObj = isObject(data);\n var type = this._header['content-type'];\n\n if (this._formData) {\n throw new Error(\".send() can't be used if .attach() or .field() is used. Please use only .send() or only .field() & .attach()\");\n }\n\n if (isObj && !this._data) {\n if (Array.isArray(data)) {\n this._data = [];\n } else if (!this._isHost(data)) {\n this._data = {};\n }\n } else if (data && this._data && this._isHost(this._data)) {\n throw new Error(\"Can't merge these send calls\");\n } // merge\n\n\n if (isObj && isObject(this._data)) {\n for (var key in data) {\n if (Object.prototype.hasOwnProperty.call(data, key)) this._data[key] = data[key];\n }\n } else if (typeof data === 'string') {\n // default to x-www-form-urlencoded\n if (!type) this.type('form');\n type = this._header['content-type'];\n\n if (type === 'application/x-www-form-urlencoded') {\n this._data = this._data ? \"\".concat(this._data, \"&\").concat(data) : data;\n } else {\n this._data = (this._data || '') + data;\n }\n } else {\n this._data = data;\n }\n\n if (!isObj || this._isHost(data)) {\n return this;\n } // default to json\n\n\n if (!type) this.type('json');\n return this;\n};\n/**\n * Sort `querystring` by the sort function\n *\n *\n * Examples:\n *\n * // default order\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery()\n * .end(callback)\n *\n * // customized sort function\n * request.get('/user')\n * .query('name=Nick')\n * .query('search=Manny')\n * .sortQuery(function(a, b){\n * return a.length - b.length;\n * })\n * .end(callback)\n *\n *\n * @param {Function} sort\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequestBase.prototype.sortQuery = function (sort) {\n // _sort default to true but otherwise can be a function or boolean\n this._sort = typeof sort === 'undefined' ? true : sort;\n return this;\n};\n/**\n * Compose querystring to append to req.url\n *\n * @api private\n */\n\n\nRequestBase.prototype._finalizeQueryString = function () {\n var query = this._query.join('&');\n\n if (query) {\n this.url += (this.url.includes('?') ? '&' : '?') + query;\n }\n\n this._query.length = 0; // Makes the call idempotent\n\n if (this._sort) {\n var index = this.url.indexOf('?');\n\n if (index >= 0) {\n var queryArr = this.url.slice(index + 1).split('&');\n\n if (typeof this._sort === 'function') {\n queryArr.sort(this._sort);\n } else {\n queryArr.sort();\n }\n\n this.url = this.url.slice(0, index) + '?' + queryArr.join('&');\n }\n }\n}; // For backwards compat only\n\n\nRequestBase.prototype._appendQueryString = function () {\n console.warn('Unsupported');\n};\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\n\nRequestBase.prototype._timeoutError = function (reason, timeout, errno) {\n if (this._aborted) {\n return;\n }\n\n var err = new Error(\"\".concat(reason + timeout, \"ms exceeded\"));\n err.timeout = timeout;\n err.code = 'ECONNABORTED';\n err.errno = errno;\n this.timedout = true;\n this.timedoutError = err;\n this.abort();\n this.callback(err);\n};\n\nRequestBase.prototype._setTimeouts = function () {\n var self = this; // deadline\n\n if (this._timeout && !this._timer) {\n this._timer = setTimeout(function () {\n self._timeoutError('Timeout of ', self._timeout, 'ETIME');\n }, this._timeout);\n } // response timeout\n\n\n if (this._responseTimeout && !this._responseTimeoutTimer) {\n this._responseTimeoutTimer = setTimeout(function () {\n self._timeoutError('Response timeout of ', self._responseTimeout, 'ETIMEDOUT');\n }, this._responseTimeout);\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXF1ZXN0LWJhc2UuanMiXSwibmFtZXMiOlsiaXNPYmplY3QiLCJyZXF1aXJlIiwibW9kdWxlIiwiZXhwb3J0cyIsIlJlcXVlc3RCYXNlIiwib2JqIiwibWl4aW4iLCJrZXkiLCJwcm90b3R5cGUiLCJPYmplY3QiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJjbGVhclRpbWVvdXQiLCJfdGltZXIiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJfdXBsb2FkVGltZW91dFRpbWVyIiwicGFyc2UiLCJmbiIsIl9wYXJzZXIiLCJyZXNwb25zZVR5cGUiLCJ2YWwiLCJfcmVzcG9uc2VUeXBlIiwic2VyaWFsaXplIiwiX3NlcmlhbGl6ZXIiLCJ0aW1lb3V0Iiwib3B0aW9ucyIsIl90aW1lb3V0IiwiX3Jlc3BvbnNlVGltZW91dCIsIl91cGxvYWRUaW1lb3V0Iiwib3B0aW9uIiwiZGVhZGxpbmUiLCJyZXNwb25zZSIsInVwbG9hZCIsImNvbnNvbGUiLCJ3YXJuIiwicmV0cnkiLCJjb3VudCIsImFyZ3VtZW50cyIsImxlbmd0aCIsIl9tYXhSZXRyaWVzIiwiX3JldHJpZXMiLCJfcmV0cnlDYWxsYmFjayIsIkVSUk9SX0NPREVTIiwiX3Nob3VsZFJldHJ5IiwiZXJyIiwicmVzIiwib3ZlcnJpZGUiLCJlcnJfIiwiZXJyb3IiLCJzdGF0dXMiLCJjb2RlIiwiaW5jbHVkZXMiLCJjcm9zc0RvbWFpbiIsIl9yZXRyeSIsInJlcSIsInJlcXVlc3QiLCJfYWJvcnRlZCIsInRpbWVkb3V0IiwidGltZWRvdXRFcnJvciIsIl9lbmQiLCJ0aGVuIiwicmVzb2x2ZSIsInJlamVjdCIsIl9mdWxsZmlsbGVkUHJvbWlzZSIsInNlbGYiLCJfZW5kQ2FsbGVkIiwiUHJvbWlzZSIsIm9uIiwiRXJyb3IiLCJtZXRob2QiLCJ1cmwiLCJlbmQiLCJjYXRjaCIsImNiIiwidW5kZWZpbmVkIiwidXNlIiwib2siLCJfb2tDYWxsYmFjayIsIl9pc1Jlc3BvbnNlT0siLCJnZXQiLCJmaWVsZCIsIl9oZWFkZXIiLCJ0b0xvd2VyQ2FzZSIsImdldEhlYWRlciIsInNldCIsImhlYWRlciIsInVuc2V0IiwibmFtZSIsIl9kYXRhIiwiQXJyYXkiLCJpc0FycmF5IiwiaSIsIlN0cmluZyIsIl9nZXRGb3JtRGF0YSIsImFwcGVuZCIsImFib3J0IiwieGhyIiwiZW1pdCIsIl9hdXRoIiwidXNlciIsInBhc3MiLCJiYXNlNjRFbmNvZGVyIiwidHlwZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJ3aXRoQ3JlZGVudGlhbHMiLCJfd2l0aENyZWRlbnRpYWxzIiwicmVkaXJlY3RzIiwibiIsIl9tYXhSZWRpcmVjdHMiLCJtYXhSZXNwb25zZVNpemUiLCJUeXBlRXJyb3IiLCJfbWF4UmVzcG9uc2VTaXplIiwidG9KU09OIiwiZGF0YSIsImhlYWRlcnMiLCJzZW5kIiwiaXNPYmoiLCJfZm9ybURhdGEiLCJfaXNIb3N0Iiwic29ydFF1ZXJ5Iiwic29ydCIsIl9zb3J0IiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJxdWVyeSIsIl9xdWVyeSIsImpvaW4iLCJpbmRleCIsImluZGV4T2YiLCJxdWVyeUFyciIsInNsaWNlIiwic3BsaXQiLCJfYXBwZW5kUXVlcnlTdHJpbmciLCJfdGltZW91dEVycm9yIiwicmVhc29uIiwiZXJybm8iLCJjYWxsYmFjayIsIl9zZXRUaW1lb3V0cyIsInNldFRpbWVvdXQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7O0FBR0EsSUFBTUEsUUFBUSxHQUFHQyxPQUFPLENBQUMsYUFBRCxDQUF4QjtBQUVBOzs7OztBQUlBQyxNQUFNLENBQUNDLE9BQVAsR0FBaUJDLFdBQWpCO0FBRUE7Ozs7OztBQU1BLFNBQVNBLFdBQVQsQ0FBcUJDLEdBQXJCLEVBQTBCO0FBQ3hCLE1BQUlBLEdBQUosRUFBUyxPQUFPQyxLQUFLLENBQUNELEdBQUQsQ0FBWjtBQUNWO0FBRUQ7Ozs7Ozs7OztBQVFBLFNBQVNDLEtBQVQsQ0FBZUQsR0FBZixFQUFvQjtBQUNsQixPQUFLLElBQU1FLEdBQVgsSUFBa0JI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LEVBRXJCLEtBQUtBLFFBRmdCLENBQXhCO0FBR0QsR0FSNkMsQ0FVOUM7OztBQUNBLE1BQUksS0FBS0MsZ0JBQUwsSUFBeUIsQ0FBQyxLQUFLYixxQkFBbkMsRUFBMEQ7QUFDeEQsU0FBS0EscUJBQUwsR0FBNkI0SCxVQUFVLENBQUMsWUFBTTtBQUM1QzFFLE1BQUFBLElBQUksQ0FBQ3FFLGFBQUwsQ0FDRSxzQkFERixFQUVFckUsSUFBSSxDQUFDckMsZ0JBRlAsRUFHRSxXQUhGO0FBS0QsS0FOc0MsRUFNcEMsS0FBS0EsZ0JBTitCLENBQXZDO0FBT0Q7QUFDRixDQXBCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTW9kdWxlIG9mIG1peGVkLWluIGZ1bmN0aW9ucyBzaGFyZWQgYmV0d2VlbiBub2RlIGFuZCBjbGllbnQgY29kZVxuICovXG5jb25zdCBpc09iamVjdCA9IHJlcXVpcmUoJy4vaXMtb2JqZWN0Jyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXF1ZXN0QmFzZWAuXG4gKi9cblxubW9kdWxlLmV4cG9ydHMgPSBSZXF1ZXN0QmFzZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0QmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0QmFzZShvYmopIHtcbiAgaWYgKG9iaikgcmV0dXJuIG1peGluKG9iaik7XG59XG5cbi8qKlxuICogTWl4aW4gdGhlIHByb3RvdHlwZSBwcm9wZXJ0aWVzLlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmpcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIG1peGluKG9iaikge1xuICBmb3IgKGNvbnN0IGtleSBpbiBSZXF1ZXN0QmFzZS5wcm90b3R5cGUpIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKFJlcXVlc3RCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVxdWVzdEJhc2UucHJvdG90eXBlW2tleV07XG4gIH1cblxuICByZXR1cm4gb2JqO1xufVxuXG4vKipcbiAqIENsZWFyIHByZXZpb3VzIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5jbGVhclRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3RpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgY2xlYXJUaW1lb3V0KHRoaXMuX3VwbG9hZFRpbWVvdXRUaW1lcik7XG4gIGRlbGV0ZSB0aGlzLl90aW1lcjtcbiAgZGVsZXRlIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyO1xuICBkZWxldGUgdGhpcy5fdXBsb2FkVGltZW91dFRpbWVyO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogT3ZlcnJpZGUgZGVmYXVsdCByZXNwb25zZSBib2R5IHBhcnNlclxuICpcbiAqIFRoaXMgZnVuY3Rpb24gd2lsbCBiZSBjYWxsZWQgdG8gY29udmVydCBpbmNvbWluZyBkYXRhIGludG8gcmVxdWVzdC5ib2R5XG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnBhcnNlID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fcGFyc2VyID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgZm9ybWF0IG9mIGJpbmFyeSByZXNwb25zZSBib2R5LlxuICogSW4gYnJvd3NlciB2YWxpZCBmb3JtYXRzIGFyZSAnYmxvYicgYW5kICdhcnJheWJ1ZmZlcicsXG4gKiB3aGljaCByZXR1cm4gQmxvYiBhbmQgQXJyYXlCdWZmZXIsIHJlc3BlY3RpdmVseS5cbiAqXG4gKiBJbiBOb2RlIGFsbCB2YWx1ZXMgcmVzdWx0IGluIEJ1ZmZlci5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5yZXNwb25zZVR5cGUoJ2Jsb2InKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB2YWxcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVzcG9uc2VUeXBlID0gZnVuY3Rpb24odmFsKSB7XG4gIHRoaXMuX3Jlc3BvbnNlVHlwZSA9IHZhbDtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIE92ZXJyaWRlIGRlZmF1bHQgcmVxdWVzdCBib2R5IHNlcmlhbGl6ZXJcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYmUgY2FsbGVkIHRvIGNvbnZlcnQgZGF0YSBzZXQgdmlhIC5zZW5kIG9yIC5hdHRhY2ggaW50byBwYXlsb2FkIHRvIHNlbmRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VyaWFsaXplID0gZnVuY3Rpb24oZm4pIHtcbiAgdGhpcy5fc2VyaWFsaXplciA9IGZuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IHRpbWVvdXRzLlxuICpcbiAqIC0gcmVzcG9uc2UgdGltZW91dCBpcyB0aW1lIGJldHdlZW4gc2VuZGluZyByZXF1ZXN0IGFuZCByZWNlaXZpbmcgdGhlIGZpcnN0IGJ5dGUgb2YgdGhlIHJlc3BvbnNlLiBJbmNsdWRlcyBETlMgYW5kIGNvbm5lY3Rpb24gdGltZS5cbiAqIC0gZGVhZGxpbmUgaXMgdGhlIHRpbWUgZnJvbSBzdGFydCBvZiB0aGUgcmVxdWVzdCB0byByZWNlaXZpbmcgcmVzcG9uc2UgYm9keSBpbiBmdWxsLiBJZiB0aGUgZGVhZGxpbmUgaXMgdG9vIHNob3J0IGxhcmdlIGZpbGVzIG1heSBub3QgbG9hZCBhdCBhbGwgb24gc2xvdyBjb25uZWN0aW9ucy5cbiAqIC0gdXBsb2FkIGlzIHRoZSB0aW1lICBzaW5jZSBsYXN0IGJpdCBvZiBkYXRhIHdhcyBzZW50IG9yIHJlY2VpdmVkLiBUaGlzIHRpbWVvdXQgd29ya3Mgb25seSBpZiBkZWFkbGluZSB0aW1lb3V0IGlzIG9mZlxuICpcbiAqIFZhbHVlIG9mIDAgb3IgZmFsc2UgbWVhbnMgbm8gdGltZW91dC5cbiAqXG4gKiBAcGFyYW0ge051bWJlcnxPYmplY3R9IG1zIG9yIHtyZXNwb25zZSwgZGVhZGxpbmV9XG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnRpbWVvdXQgPSBmdW5jdGlvbihvcHRpb25zKSB7XG4gIGlmICghb3B0aW9ucyB8fCB0eXBlb2Ygb3B0aW9ucyAhPT0gJ29iamVjdCcpIHtcbiAgICB0aGlzLl90aW1lb3V0ID0gb3B0aW9ucztcbiAgICB0aGlzLl9yZXNwb25zZVRpbWVvdXQgPSAwO1xuICAgIHRoaXMuX3VwbG9hZFRpbWVvdXQgPSAwO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZm9yIChjb25zdCBvcHRpb24gaW4gb3B0aW9ucykge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob3B0aW9ucywgb3B0aW9uKSkge1xuICAgICAgc3dpdGNoIChvcHRpb24pIHtcbiAgICAgICAgY2FzZSAnZGVhZGxpbmUnOlxuICAgICAgICAgIHRoaXMuX3RpbWVvdXQgPSBvcHRpb25zLmRlYWRsaW5lO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdyZXNwb25zZSc6XG4gICAgICAgICAgdGhpcy5fcmVzcG9uc2VUaW1lb3V0ID0gb3B0aW9ucy5yZXNwb25zZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAndXBsb2FkJzpcbiAgICAgICAgICB0aGlzLl91cGxvYWRUaW1lb3V0ID0gb3B0aW9ucy51cGxvYWQ7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgY29uc29sZS53YXJuKCdVbmtub3duIHRpbWVvdXQgb3B0aW9uJywgb3B0aW9uKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogU2V0IG51bWJlciBvZiByZXRyeSBhdHRlbXB0cyBvbiBlcnJvci5cbiAqXG4gKiBGYWlsZWQgcmVxdWVzdHMgd2lsbCBiZSByZXRyaWVkICdjb3VudCcgdGltZXMgaWYgdGltZW91dCBvciBlcnIuY29kZSA+PSA1MDAuXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IGNvdW50XG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnJldHJ5ID0gZnVuY3Rpb24oY291bnQsIGZuKSB7XG4gIC8vIERlZmF1bHQgdG8gMSBpZiBubyBjb3VudCBwYXNzZWQgb3IgdHJ1ZVxuICBpZiAoYXJndW1lbnRzLmxlbmd0aCA9PT0gMCB8fCBjb3VudCA9PT0gdHJ1ZSkgY291bnQgPSAxO1xuICBpZiAoY291bnQgPD0gMCkgY291bnQgPSAwO1xuICB0aGlzLl9tYXhSZXRyaWVzID0gY291bnQ7XG4gIHRoaXMuX3JldHJpZXMgPSAwO1xuICB0aGlzLl9yZXRyeUNhbGxiYWNrID0gZm47XG4gIHJldHVybiB0aGlzO1xufTtcblxuY29uc3QgRVJST1JfQ09ERVMgPSBbJ0VDT05OUkVTRVQnLCAnRVRJTUVET1VUJywgJ0VBRERSSU5GTycsICdFU09DS0VUVElNRURPVVQnXTtcblxuLyoqXG4gKiBEZXRlcm1pbmUgaWYgYSByZXF1ZXN0IHNob3VsZCBiZSByZXRyaWVkLlxuICogKEJvcnJvd2VkIGZyb20gc2VnbWVudGlvL3N1cGVyYWdlbnQtcmV0cnkpXG4gKlxuICogQHBhcmFtIHtFcnJvcn0gZXJyIGFuIGVycm9yXG4gKiBAcGFyYW0ge1Jlc3BvbnNlfSBbcmVzXSByZXNwb25zZVxuICogQHJldHVybnMge0Jvb2xlYW59IGlmIHNlZ21lbnQgc2hvdWxkIGJlIHJldHJpZWRcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zaG91bGRSZXRyeSA9IGZ1bmN0aW9uKGVyciwgcmVzKSB7XG4gIGlmICghdGhpcy5fbWF4UmV0cmllcyB8fCB0aGlzLl9yZXRyaWVzKysgPj0gdGhpcy5fbWF4UmV0cmllcykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICh0aGlzLl9yZXRyeUNhbGxiYWNrKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IG92ZXJyaWRlID0gdGhpcy5fcmV0cnlDYWxsYmFjayhlcnIsIHJlcyk7XG4gICAgICBpZiAob3ZlcnJpZGUgPT09IHRydWUpIHJldHVybiB0cnVlO1xuICAgICAgaWYgKG92ZXJyaWRlID09PSBmYWxzZSkgcmV0dXJuIGZhbHNlO1xuICAgICAgLy8gdW5kZWZpbmVkIGZhbGxzIGJhY2sgdG8gZGVmYXVsdHNcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycl8pO1xuICAgIH1cbiAgfVxuXG4gIGlmIChyZXMgJiYgcmVzLnN0YXR1cyAmJiByZXMuc3RhdHVzID49IDUwMCAmJiByZXMuc3RhdHVzICE9PSA1MDEpIHJldHVybiB0cnVlO1xuICBpZiAoZXJyKSB7XG4gICAgaWYgKGVyci5jb2RlICYmIEVSUk9SX0NPREVTLmluY2x1ZGVzKGVyci5jb2RlKSkgcmV0dXJuIHRydWU7XG4gICAgLy8gU3VwZXJhZ2VudCB0aW1lb3V0XG4gICAgaWYgKGVyci50aW1lb3V0ICYmIGVyci5jb2RlID09PSAnRUNPTk5BQk9SVEVEJykgcmV0dXJuIHRydWU7XG4gICAgaWYgKGVyci5jcm9zc0RvbWFpbikgcmV0dXJuIHRydWU7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59O1xuXG4vKipcbiAqIFJldHJ5IHJlcXVlc3RcbiAqXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fcmV0cnkgPSBmdW5jdGlvbigpIHtcbiAgdGhpcy5jbGVhclRpbWVvdXQoKTtcblxuICAvLyBub2RlXG4gIGlmICh0aGlzLnJlcSkge1xuICAgIHRoaXMucmVxID0gbnVsbDtcbiAgICB0aGlzLnJlcSA9IHRoaXMucmVxdWVzdCgpO1xuICB9XG5cbiAgdGhpcy5fYWJvcnRlZCA9IGZhbHNlO1xuICB0aGlzLnRpbWVkb3V0ID0gZmFsc2U7XG4gIHRoaXMudGltZWRvdXRFcnJvciA9IG51bGw7XG5cbiAgcmV0dXJuIHRoaXMuX2VuZCgpO1xufTtcblxuLyoqXG4gKiBQcm9taXNlIHN1cHBvcnRcbiAqXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSByZXNvbHZlXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbcmVqZWN0XVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudGhlbiA9IGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkge1xuICBpZiAoIXRoaXMuX2Z1bGxmaWxsZWRQcm9taXNlKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgaWYgKHRoaXMuX2VuZENhbGxlZCkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnV2FybmluZzogc3VwZXJhZ2VudCByZXF1ZXN0IHdhcyBzZW50IHR3aWNlLCBiZWNhdXNlIGJvdGggLmVuZCgpIGFuZCAudGhlbigpIHdlcmUgY2FsbGVkLiBOZXZlciBjYWxsIC5lbmQoKSBpZiB5b3UgdXNlIHByb21pc2VzJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHNlbGYub24oJ2Fib3J0JywgKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5fbWF4UmV0cmllcyAmJiB0aGlzLl9tYXhSZXRyaWVzID4gdGhpcy5fcmV0cmllcykge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLnRpbWVkb3V0ICYmIHRoaXMudGltZWRvdXRFcnJvcikge1xuICAgICAgICAgIHJlamVjdCh0aGlzLnRpbWVkb3V0RXJyb3IpO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGVyciA9IG5ldyBFcnJvcignQWJvcnRlZCcpO1xuICAgICAgICBlcnIuY29kZSA9ICdBQk9SVEVEJztcbiAgICAgICAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICAgICAgICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gICAgICAgIGVyci51cmwgPSB0aGlzLnVybDtcbiAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICB9KTtcbiAgICAgIHNlbGYuZW5kKChlcnIsIHJlcykgPT4ge1xuICAgICAgICBpZiAoZXJyKSByZWplY3QoZXJyKTtcbiAgICAgICAgZWxzZSByZXNvbHZlKHJlcyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mdWxsZmlsbGVkUHJvbWlzZS50aGVuKHJlc29sdmUsIHJlamVjdCk7XG59O1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuY2F0Y2ggPSBmdW5jdGlvbihjYikge1xuICByZXR1cm4gdGhpcy50aGVuKHVuZGVmaW5lZCwgY2IpO1xufTtcblxuLyoqXG4gKiBBbGxvdyBmb3IgZXh0ZW5zaW9uXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLnVzZSA9IGZ1bmN0aW9uKGZuKSB7XG4gIGZuKHRoaXMpO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5vayA9IGZ1bmN0aW9uKGNiKSB7XG4gIGlmICh0eXBlb2YgY2IgIT09ICdmdW5jdGlvbicpIHRocm93IG5ldyBFcnJvcignQ2FsbGJhY2sgcmVxdWlyZWQnKTtcbiAgdGhpcy5fb2tDYWxsYmFjayA9IGNiO1xuICByZXR1cm4gdGhpcztcbn07XG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5faXNSZXNwb25zZU9LID0gZnVuY3Rpb24ocmVzKSB7XG4gIGlmICghcmVzKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKHRoaXMuX29rQ2FsbGJhY2spIHtcbiAgICByZXR1cm4gdGhpcy5fb2tDYWxsYmFjayhyZXMpO1xuICB9XG5cbiAgcmV0dXJuIHJlcy5zdGF0dXMgPj0gMjAwICYmIHJlcy5zdGF0dXMgPCAzMDA7XG59O1xuXG4vKipcbiAqIEdldCByZXF1ZXN0IGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGRcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLl9oZWFkZXJbZmllbGQudG9Mb3dlckNhc2UoKV07XG59O1xuXG4vKipcbiAqIEdldCBjYXNlLWluc2Vuc2l0aXZlIGhlYWRlciBgZmllbGRgIHZhbHVlLlxuICogVGhpcyBpcyBhIGRlcHJlY2F0ZWQgaW50ZXJuYWwgQVBJLiBVc2UgYC5nZXQoZmllbGQpYCBpbnN0ZWFkLlxuICpcbiAqIChnZXRIZWFkZXIgaXMgbm8gbG9uZ2VyIHVzZWQgaW50ZXJuYWxseSBieSB0aGUgc3VwZXJhZ2VudCBjb2RlIGJhc2UpXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGZpZWxkXG4gKiBAcmV0dXJuIHtTdHJpbmd9XG4gKiBAYXBpIHByaXZhdGVcbiAqIEBkZXByZWNhdGVkXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLmdldEhlYWRlciA9IFJlcXVlc3RCYXNlLnByb3RvdHlwZS5nZXQ7XG5cbi8qKlxuICogU2V0IGhlYWRlciBgZmllbGRgIHRvIGB2YWxgLCBvciBtdWx0aXBsZSBmaWVsZHMgd2l0aCBvbmUgb2JqZWN0LlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoJ0FjY2VwdCcsICdhcHBsaWNhdGlvbi9qc29uJylcbiAqICAgICAgICAuc2V0KCdYLUFQSS1LZXknLCAnZm9vYmFyJylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiAgICAgIHJlcS5nZXQoJy8nKVxuICogICAgICAgIC5zZXQoeyBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJywgJ1gtQVBJLUtleSc6ICdmb29iYXInIH0pXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd8T2JqZWN0fSBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zZXQgPSBmdW5jdGlvbihmaWVsZCwgdmFsKSB7XG4gIGlmIChpc09iamVjdChmaWVsZCkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBmaWVsZCkge1xuICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChmaWVsZCwga2V5KSlcbiAgICAgICAgdGhpcy5zZXQoa2V5LCBmaWVsZFtrZXldKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRoaXMuX2hlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXSA9IHZhbDtcbiAgdGhpcy5oZWFkZXJbZmllbGRdID0gdmFsO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogUmVtb3ZlIGhlYWRlciBgZmllbGRgLlxuICogQ2FzZS1pbnNlbnNpdGl2ZS5cbiAqXG4gKiBFeGFtcGxlOlxuICpcbiAqICAgICAgcmVxLmdldCgnLycpXG4gKiAgICAgICAgLnVuc2V0KCdVc2VyLUFnZW50JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKTtcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gZmllbGQgZmllbGQgbmFtZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudW5zZXQgPSBmdW5jdGlvbihmaWVsZCkge1xuICBkZWxldGUgdGhpcy5faGVhZGVyW2ZpZWxkLnRvTG93ZXJDYXNlKCldO1xuICBkZWxldGUgdGhpcy5oZWFkZXJbZmllbGRdO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogV3JpdGUgdGhlIGZpZWxkIGBuYW1lYCBhbmQgYHZhbGAsIG9yIG11bHRpcGxlIGZpZWxkcyB3aXRoIG9uZSBvYmplY3RcbiAqIGZvciBcIm11bHRpcGFydC9mb3JtLWRhdGFcIiByZXF1ZXN0IGJvZGllcy5cbiAqXG4gKiBgYGAganNcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCgnZm9vJywgJ2JhcicpXG4gKiAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqIHJlcXVlc3QucG9zdCgnL3VwbG9hZCcpXG4gKiAgIC5maWVsZCh7IGZvbzogJ2JhcicsIGJhejogJ3F1eCcgfSlcbiAqICAgLmVuZChjYWxsYmFjayk7XG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0ge1N0cmluZ3xPYmplY3R9IG5hbWUgbmFtZSBvZiBmaWVsZFxuICogQHBhcmFtIHtTdHJpbmd8QmxvYnxGaWxlfEJ1ZmZlcnxmcy5SZWFkU3RyZWFtfSB2YWwgdmFsdWUgb2YgZmllbGRcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmZpZWxkID0gZnVuY3Rpb24obmFtZSwgdmFsKSB7XG4gIC8vIG5hbWUgc2hvdWxkIGJlIGVpdGhlciBhIHN0cmluZyBvciBhbiBvYmplY3QuXG4gIGlmIChuYW1lID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gbmFtZSkge1xuICAgIHRocm93IG5ldyBFcnJvcignLmZpZWxkKG5hbWUsIHZhbCkgbmFtZSBjYW4gbm90IGJlIGVtcHR5Jyk7XG4gIH1cblxuICBpZiAodGhpcy5fZGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLmZpZWxkKCkgY2FuJ3QgYmUgdXNlZCBpZiAuc2VuZCgpIGlzIHVzZWQuIFBsZWFzZSB1c2Ugb25seSAuc2VuZCgpIG9yIG9ubHkgLmZpZWxkKCkgJiAuYXR0YWNoKClcIlxuICAgICk7XG4gIH1cblxuICBpZiAoaXNPYmplY3QobmFtZSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBuYW1lKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG5hbWUsIGtleSkpXG4gICAgICAgIHRoaXMuZmllbGQoa2V5LCBuYW1lW2tleV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkodmFsKSkge1xuICAgIGZvciAoY29uc3QgaSBpbiB2YWwpIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmFsLCBpKSlcbiAgICAgICAgdGhpcy5maWVsZChuYW1lLCB2YWxbaV0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLy8gdmFsIHNob3VsZCBiZSBkZWZpbmVkIG5vd1xuICBpZiAodmFsID09PSBudWxsIHx8IHVuZGVmaW5lZCA9PT0gdmFsKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCcuZmllbGQobmFtZSwgdmFsKSB2YWwgY2FuIG5vdCBiZSBlbXB0eScpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiB2YWwgPT09ICdib29sZWFuJykge1xuICAgIHZhbCA9IFN0cmluZyh2YWwpO1xuICB9XG5cbiAgdGhpcy5fZ2V0Rm9ybURhdGEoKS5hcHBlbmQobmFtZSwgdmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIEFib3J0IHRoZSByZXF1ZXN0LCBhbmQgY2xlYXIgcG90ZW50aWFsIHRpbWVvdXQuXG4gKlxuICogQHJldHVybiB7UmVxdWVzdH0gcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuUmVxdWVzdEJhc2UucHJvdG90eXBlLmFib3J0ID0gZnVuY3Rpb24oKSB7XG4gIGlmICh0aGlzLl9hYm9ydGVkKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICB0aGlzLl9hYm9ydGVkID0gdHJ1ZTtcbiAgaWYgKHRoaXMueGhyKSB0aGlzLnhoci5hYm9ydCgpOyAvLyBicm93c2VyXG4gIGlmICh0aGlzLnJlcSkgdGhpcy5yZXEuYWJvcnQoKTsgLy8gbm9kZVxuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuICB0aGlzLmVtaXQoJ2Fib3J0Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hdXRoID0gZnVuY3Rpb24odXNlciwgcGFzcywgb3B0aW9ucywgYmFzZTY0RW5jb2Rlcikge1xuICBzd2l0Y2ggKG9wdGlvbnMudHlwZSkge1xuICAgIGNhc2UgJ2Jhc2ljJzpcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJhc2ljICR7YmFzZTY0RW5jb2RlcihgJHt1c2VyfToke3Bhc3N9YCl9YCk7XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2F1dG8nOlxuICAgICAgdGhpcy51c2VybmFtZSA9IHVzZXI7XG4gICAgICB0aGlzLnBhc3N3b3JkID0gcGFzcztcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnYmVhcmVyJzogLy8gdXNhZ2Ugd291bGQgYmUgLmF1dGgoYWNjZXNzVG9rZW4sIHsgdHlwZTogJ2JlYXJlcicgfSlcbiAgICAgIHRoaXMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3VzZXJ9YCk7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgYnJlYWs7XG4gIH1cblxuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogRW5hYmxlIHRyYW5zbWlzc2lvbiBvZiBjb29raWVzIHdpdGggeC1kb21haW4gcmVxdWVzdHMuXG4gKlxuICogTm90ZSB0aGF0IGZvciB0aGlzIHRvIHdvcmsgdGhlIG9yaWdpbiBtdXN0IG5vdCBiZVxuICogdXNpbmcgXCJBY2Nlc3MtQ29udHJvbC1BbGxvdy1PcmlnaW5cIiB3aXRoIGEgd2lsZGNhcmQsXG4gKiBhbmQgYWxzbyBtdXN0IHNldCBcIkFjY2Vzcy1Db250cm9sLUFsbG93LUNyZWRlbnRpYWxzXCJcbiAqIHRvIFwidHJ1ZVwiLlxuICpcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLndpdGhDcmVkZW50aWFscyA9IGZ1bmN0aW9uKG9uKSB7XG4gIC8vIFRoaXMgaXMgYnJvd3Nlci1vbmx5IGZ1bmN0aW9uYWxpdHkuIE5vZGUgc2lkZSBpcyBuby1vcC5cbiAgaWYgKG9uID09PSB1bmRlZmluZWQpIG9uID0gdHJ1ZTtcbiAgdGhpcy5fd2l0aENyZWRlbnRpYWxzID0gb247XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgdGhlIG1heCByZWRpcmVjdHMgdG8gYG5gLiBEb2VzIG5vdGhpbmcgaW4gYnJvd3NlciBYSFIgaW1wbGVtZW50YXRpb24uXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IG5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUucmVkaXJlY3RzID0gZnVuY3Rpb24obikge1xuICB0aGlzLl9tYXhSZWRpcmVjdHMgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogTWF4aW11bSBzaXplIG9mIGJ1ZmZlcmVkIHJlc3BvbnNlIGJvZHksIGluIGJ5dGVzLiBDb3VudHMgdW5jb21wcmVzc2VkIHNpemUuXG4gKiBEZWZhdWx0IDIwME1CLlxuICpcbiAqIEBwYXJhbSB7TnVtYmVyfSBuIG51bWJlciBvZiBieXRlc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKi9cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5tYXhSZXNwb25zZVNpemUgPSBmdW5jdGlvbihuKSB7XG4gIGlmICh0eXBlb2YgbiAhPT0gJ251bWJlcicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdJbnZhbGlkIGFyZ3VtZW50Jyk7XG4gIH1cblxuICB0aGlzLl9tYXhSZXNwb25zZVNpemUgPSBuO1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29udmVydCB0byBhIHBsYWluIGphdmFzY3JpcHQgb2JqZWN0IChub3QgSlNPTiBzdHJpbmcpIG9mIHNjYWxhciBwcm9wZXJ0aWVzLlxuICogTm90ZSBhcyB0aGlzIG1ldGhvZCBpcyBkZXNpZ25lZCB0byByZXR1cm4gYSB1c2VmdWwgbm9uLXRoaXMgdmFsdWUsXG4gKiBpdCBjYW5ub3QgYmUgY2hhaW5lZC5cbiAqXG4gKiBAcmV0dXJuIHtPYmplY3R9IGRlc2NyaWJpbmcgbWV0aG9kLCB1cmwsIGFuZCBkYXRhIG9mIHRoaXMgcmVxdWVzdFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUudG9KU09OID0gZnVuY3Rpb24oKSB7XG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiB0aGlzLm1ldGhvZCxcbiAgICB1cmw6IHRoaXMudXJsLFxuICAgIGRhdGE6IHRoaXMuX2RhdGEsXG4gICAgaGVhZGVyczogdGhpcy5faGVhZGVyXG4gIH07XG59O1xuXG4vKipcbiAqIFNlbmQgYGRhdGFgIGFzIHRoZSByZXF1ZXN0IGJvZHksIGRlZmF1bHRpbmcgdGhlIGAudHlwZSgpYCB0byBcImpzb25cIiB3aGVuXG4gKiBhbiBvYmplY3QgaXMgZ2l2ZW4uXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICAgICAgLy8gbWFudWFsIGpzb25cbiAqICAgICAgIHJlcXVlc3QucG9zdCgnL3VzZXInKVxuICogICAgICAgICAudHlwZSgnanNvbicpXG4gKiAgICAgICAgIC5zZW5kKCd7XCJuYW1lXCI6XCJ0alwifScpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gYXV0byBqc29uXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gbWFudWFsIHgtd3d3LWZvcm0tdXJsZW5jb2RlZFxuICogICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgIC50eXBlKCdmb3JtJylcbiAqICAgICAgICAgLnNlbmQoJ25hbWU9dGonKVxuICogICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqICAgICAgIC8vIGF1dG8geC13d3ctZm9ybS11cmxlbmNvZGVkXG4gKiAgICAgICByZXF1ZXN0LnBvc3QoJy91c2VyJylcbiAqICAgICAgICAgLnR5cGUoJ2Zvcm0nKVxuICogICAgICAgICAuc2VuZCh7IG5hbWU6ICd0aicgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0cyB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoJ25hbWU9dG9iaScpXG4gKiAgICAgICAgLnNlbmQoJ3NwZWNpZXM9ZmVycmV0JylcbiAqICAgICAgICAuZW5kKGNhbGxiYWNrKVxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gZGF0YVxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuc2VuZCA9IGZ1bmN0aW9uKGRhdGEpIHtcbiAgY29uc3QgaXNPYmogPSBpc09iamVjdChkYXRhKTtcbiAgbGV0IHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuXG4gIGlmICh0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiLnNlbmQoKSBjYW4ndCBiZSB1c2VkIGlmIC5hdHRhY2goKSBvciAuZmllbGQoKSBpcyB1c2VkLiBQbGVhc2UgdXNlIG9ubHkgLnNlbmQoKSBvciBvbmx5IC5maWVsZCgpICYgLmF0dGFjaCgpXCJcbiAgICApO1xuICB9XG5cbiAgaWYgKGlzT2JqICYmICF0aGlzLl9kYXRhKSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSBbXTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLl9pc0hvc3QoZGF0YSkpIHtcbiAgICAgIHRoaXMuX2RhdGEgPSB7fTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoZGF0YSAmJiB0aGlzLl9kYXRhICYmIHRoaXMuX2lzSG9zdCh0aGlzLl9kYXRhKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIkNhbid0IG1lcmdlIHRoZXNlIHNlbmQgY2FsbHNcIik7XG4gIH1cblxuICAvLyBtZXJnZVxuICBpZiAoaXNPYmogJiYgaXNPYmplY3QodGhpcy5fZGF0YSkpIHtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGRhdGEsIGtleSkpXG4gICAgICAgIHRoaXMuX2RhdGFba2V5XSA9IGRhdGFba2V5XTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodHlwZW9mIGRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgLy8gZGVmYXVsdCB0byB4LXd3dy1mb3JtLXVybGVuY29kZWRcbiAgICBpZiAoIXR5cGUpIHRoaXMudHlwZSgnZm9ybScpO1xuICAgIHR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGlmICh0eXBlID09PSAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJykge1xuICAgICAgdGhpcy5fZGF0YSA9IHRoaXMuX2RhdGEgPyBgJHt0aGlzLl9kYXRhfSYke2RhdGF9YCA6IGRhdGE7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2RhdGEgPSAodGhpcy5fZGF0YSB8fCAnJykgKyBkYXRhO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICB0aGlzLl9kYXRhID0gZGF0YTtcbiAgfVxuXG4gIGlmICghaXNPYmogfHwgdGhpcy5faXNIb3N0KGRhdGEpKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvLyBkZWZhdWx0IHRvIGpzb25cbiAgaWYgKCF0eXBlKSB0aGlzLnR5cGUoJ2pzb24nKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNvcnQgYHF1ZXJ5c3RyaW5nYCBieSB0aGUgc29ydCBmdW5jdGlvblxuICpcbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgICAvLyBkZWZhdWx0IG9yZGVyXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeSgpXG4gKiAgICAgICAgIC5lbmQoY2FsbGJhY2spXG4gKlxuICogICAgICAgLy8gY3VzdG9taXplZCBzb3J0IGZ1bmN0aW9uXG4gKiAgICAgICByZXF1ZXN0LmdldCgnL3VzZXInKVxuICogICAgICAgICAucXVlcnkoJ25hbWU9TmljaycpXG4gKiAgICAgICAgIC5xdWVyeSgnc2VhcmNoPU1hbm55JylcbiAqICAgICAgICAgLnNvcnRRdWVyeShmdW5jdGlvbihhLCBiKXtcbiAqICAgICAgICAgICByZXR1cm4gYS5sZW5ndGggLSBiLmxlbmd0aDtcbiAqICAgICAgICAgfSlcbiAqICAgICAgICAgLmVuZChjYWxsYmFjaylcbiAqXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gc29ydFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5zb3J0UXVlcnkgPSBmdW5jdGlvbihzb3J0KSB7XG4gIC8vIF9zb3J0IGRlZmF1bHQgdG8gdHJ1ZSBidXQgb3RoZXJ3aXNlIGNhbiBiZSBhIGZ1bmN0aW9uIG9yIGJvb2xlYW5cbiAgdGhpcy5fc29ydCA9IHR5cGVvZiBzb3J0ID09PSAndW5kZWZpbmVkJyA/IHRydWUgOiBzb3J0O1xuICByZXR1cm4gdGhpcztcbn07XG5cbi8qKlxuICogQ29tcG9zZSBxdWVyeXN0cmluZyB0byBhcHBlbmQgdG8gcmVxLnVybFxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5SZXF1ZXN0QmFzZS5wcm90b3R5cGUuX2ZpbmFsaXplUXVlcnlTdHJpbmcgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgcXVlcnkgPSB0aGlzLl9xdWVyeS5qb2luKCcmJyk7XG4gIGlmIChxdWVyeSkge1xuICAgIHRoaXMudXJsICs9ICh0aGlzLnVybC5pbmNsdWRlcygnPycpID8gJyYnIDogJz8nKSArIHF1ZXJ5O1xuICB9XG5cbiAgdGhpcy5fcXVlcnkubGVuZ3RoID0gMDsgLy8gTWFrZXMgdGhlIGNhbGwgaWRlbXBvdGVudFxuXG4gIGlmICh0aGlzLl9zb3J0KSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLnVybC5pbmRleE9mKCc/Jyk7XG4gICAgaWYgKGluZGV4ID49IDApIHtcbiAgICAgIGNvbnN0IHF1ZXJ5QXJyID0gdGhpcy51cmwuc2xpY2UoaW5kZXggKyAxKS5zcGxpdCgnJicpO1xuICAgICAgaWYgKHR5cGVvZiB0aGlzLl9zb3J0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHF1ZXJ5QXJyLnNvcnQodGhpcy5fc29ydCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBxdWVyeUFyci5zb3J0KCk7XG4gICAgICB9XG5cbiAgICAgIHRoaXMudXJsID0gdGhpcy51cmwuc2xpY2UoMCwgaW5kZXgpICsgJz8nICsgcXVlcnlBcnIuam9pbignJicpO1xuICAgIH1cbiAgfVxufTtcblxuLy8gRm9yIGJhY2t3YXJkcyBjb21wYXQgb25seVxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9hcHBlbmRRdWVyeVN0cmluZyA9ICgpID0+IHtcbiAgY29uc29sZS53YXJuKCdVbnN1cHBvcnRlZCcpO1xufTtcblxuLyoqXG4gKiBJbnZva2UgY2FsbGJhY2sgd2l0aCB0aW1lb3V0IGVycm9yLlxuICpcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlcXVlc3RCYXNlLnByb3RvdHlwZS5fdGltZW91dEVycm9yID0gZnVuY3Rpb24ocmVhc29uLCB0aW1lb3V0LCBlcnJubykge1xuICBpZiAodGhpcy5fYWJvcnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGVyciA9IG5ldyBFcnJvcihgJHtyZWFzb24gKyB0aW1lb3V0fW1zIGV4Y2VlZGVkYCk7XG4gIGVyci50aW1lb3V0ID0gdGltZW91dDtcbiAgZXJyLmNvZGUgPSAnRUNPTk5BQk9SVEVEJztcbiAgZXJyLmVycm5vID0gZXJybm87XG4gIHRoaXMudGltZWRvdXQgPSB0cnVlO1xuICB0aGlzLnRpbWVkb3V0RXJyb3IgPSBlcnI7XG4gIHRoaXMuYWJvcnQoKTtcbiAgdGhpcy5jYWxsYmFjayhlcnIpO1xufTtcblxuUmVxdWVzdEJhc2UucHJvdG90eXBlLl9zZXRUaW1lb3V0cyA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBzZWxmID0gdGhpcztcblxuICAvLyBkZWFkbGluZVxuICBpZiAodGhpcy5fdGltZW91dCAmJiAhdGhpcy5fdGltZXIpIHtcbiAgICB0aGlzLl90aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2VsZi5fdGltZW91dEVycm9yKCdUaW1lb3V0IG9mICcsIHNlbGYuX3RpbWVvdXQsICdFVElNRScpO1xuICAgIH0sIHRoaXMuX3RpbWVvdXQpO1xuICB9XG5cbiAgLy8gcmVzcG9uc2UgdGltZW91dFxuICBpZiAodGhpcy5fcmVzcG9uc2VUaW1lb3V0ICYmICF0aGlzLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgIHRoaXMuX3Jlc3BvbnNlVGltZW91dFRpbWVyID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZWxmLl90aW1lb3V0RXJyb3IoXG4gICAgICAgICdSZXNwb25zZSB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3Jlc3BvbnNlVGltZW91dCxcbiAgICAgICAgJ0VUSU1FRE9VVCdcbiAgICAgICk7XG4gICAgfSwgdGhpcy5fcmVzcG9uc2VUaW1lb3V0KTtcbiAgfVxufTtcbiJdfQ==","\"use strict\";\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\nexports.type = function (str) {\n return str.split(/ *; */).shift();\n};\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.params = function (str) {\n return str.split(/ *; */).reduce(function (obj, str) {\n var parts = str.split(/ *= */);\n var key = parts.shift();\n var val = parts.shift();\n if (key && val) obj[key] = val;\n return obj;\n }, {});\n};\n/**\n * Parse Link header fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\n\nexports.parseLinks = function (str) {\n return str.split(/ *, */).reduce(function (obj, str) {\n var parts = str.split(/ *; */);\n var url = parts[0].slice(1, -1);\n var rel = parts[1].split(/ *= */)[1].slice(1, -1);\n obj[rel] = url;\n return obj;\n }, {});\n};\n/**\n * Strip content related fields from `header`.\n *\n * @param {Object} header\n * @return {Object} header\n * @api private\n */\n\n\nexports.cleanHeader = function (header, changesOrigin) {\n delete header['content-type'];\n delete header['content-length'];\n delete header['transfer-encoding'];\n delete header.host; // secuirty\n\n if (changesOrigin) {\n delete header.authorization;\n delete header.cookie;\n }\n\n return header;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6WyJleHBvcnRzIiwidHlwZSIsInN0ciIsInNwbGl0Iiwic2hpZnQiLCJwYXJhbXMiLCJyZWR1Y2UiLCJvYmoiLCJwYXJ0cyIsImtleSIsInZhbCIsInBhcnNlTGlua3MiLCJ1cmwiLCJzbGljZSIsInJlbCIsImNsZWFuSGVhZGVyIiwiaGVhZGVyIiwiY2hhbmdlc09yaWdpbiIsImhvc3QiLCJhdXRob3JpemF0aW9uIiwiY29va2llIl0sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7O0FBUUFBLE9BQU8sQ0FBQ0MsSUFBUixHQUFlLFVBQUFDLEdBQUc7QUFBQSxTQUFJQSxHQUFHLENBQUNDLEtBQUosQ0FBVSxPQUFWLEVBQW1CQyxLQUFuQixFQUFKO0FBQUEsQ0FBbEI7QUFFQTs7Ozs7Ozs7O0FBUUFKLE9BQU8sQ0FBQ0ssTUFBUixHQUFpQixVQUFBSCxHQUFHO0FBQUEsU0FDbEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTU0sR0FBRyxHQUFHRCxLQUFLLENBQUNKLEtBQU4sRUFBWjtBQUNBLFFBQU1NLEdBQUcsR0FBR0YsS0FBSyxDQUFDSixLQUFOLEVBQVo7QUFFQSxRQUFJSyxHQUFHLElBQUlDLEdBQVgsRUFBZ0JILEdBQUcsQ0FBQ0UsR0FBRCxDQUFILEdBQVdDLEdBQVg7QUFDaEIsV0FBT0gsR0FBUDtBQUNELEdBUEQsRUFPRyxFQVBILENBRGtCO0FBQUEsQ0FBcEI7QUFVQTs7Ozs7Ozs7O0FBUUFQLE9BQU8sQ0FBQ1csVUFBUixHQUFxQixVQUFBVCxHQUFHO0FBQUEsU0FDdEJBLEdBQUcsQ0FBQ0MsS0FBSixDQUFVLE9BQVYsRUFBbUJHLE1BQW5CLENBQTBCLFVBQUNDLEdBQUQsRUFBTUwsR0FBTixFQUFjO0FBQ3RDLFFBQU1NLEtBQUssR0FBR04sR0FBRyxDQUFDQyxLQUFKLENBQVUsT0FBVixDQUFkO0FBQ0EsUUFBTVMsR0FBRyxHQUFHSixLQUFLLENBQUMsQ0FBRCxDQUFMLENBQVNLLEtBQVQsQ0FBZSxDQUFmLEVBQWtCLENBQUMsQ0FBbkIsQ0FBWjtBQUNBLFFBQU1DLEdBQUcsR0FBR04sS0FBSyxDQUFDLENBQUQsQ0FBTCxDQUFTTCxLQUFULENBQWUsT0FBZixFQUF3QixDQUF4QixFQUEyQlUsS0FBM0IsQ0FBaUMsQ0FBakMsRUFBb0MsQ0FBQyxDQUFyQyxDQUFaO0FBQ0FOLElBQUFBLEdBQUcsQ0FBQ08sR0FBRCxDQUFILEdBQVdGLEdBQVg7QUFDQSxXQUFPTCxHQUFQO0FBQ0QsR0FORCxFQU1HLEVBTkgsQ0FEc0I7QUFBQSxDQUF4QjtBQVNBOzs7Ozs7Ozs7QUFRQVAsT0FBTyxDQUFDZSxXQUFSLEdBQXNCLFVBQUNDLE1BQUQsRUFBU0MsYUFBVCxFQUEyQjtBQUMvQyxTQUFPRCxNQUFNLENBQUMsY0FBRCxDQUFiO0FBQ0EsU0FBT0EsTUFBTSxDQUFDLGdCQUFELENBQWI7QUFDQSxTQUFPQSxNQUFNLENBQUMsbUJBQUQsQ0FBYjtBQUNBLFNBQU9BLE1BQU0sQ0FBQ0UsSUFBZCxDQUorQyxDQUsvQzs7QUFDQSxNQUFJRCxhQUFKLEVBQW1CO0FBQ2pCLFdBQU9ELE1BQU0sQ0FBQ0csYUFBZDtBQUNBLFdBQU9ILE1BQU0sQ0FBQ0ksTUFBZDtBQUNEOztBQUVELFNBQU9KLE1BQVA7QUFDRCxDQVpEIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXR1cm4gdGhlIG1pbWUgdHlwZSBmb3IgdGhlIGdpdmVuIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge1N0cmluZ31cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMudHlwZSA9IHN0ciA9PiBzdHIuc3BsaXQoLyAqOyAqLykuc2hpZnQoKTtcblxuLyoqXG4gKiBSZXR1cm4gaGVhZGVyIGZpZWxkIHBhcmFtZXRlcnMuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHN0clxuICogQHJldHVybiB7T2JqZWN0fVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZXhwb3J0cy5wYXJhbXMgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKjsgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo9ICovKTtcbiAgICBjb25zdCBrZXkgPSBwYXJ0cy5zaGlmdCgpO1xuICAgIGNvbnN0IHZhbCA9IHBhcnRzLnNoaWZ0KCk7XG5cbiAgICBpZiAoa2V5ICYmIHZhbCkgb2JqW2tleV0gPSB2YWw7XG4gICAgcmV0dXJuIG9iajtcbiAgfSwge30pO1xuXG4vKipcbiAqIFBhcnNlIExpbmsgaGVhZGVyIGZpZWxkcy5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5leHBvcnRzLnBhcnNlTGlua3MgPSBzdHIgPT5cbiAgc3RyLnNwbGl0KC8gKiwgKi8pLnJlZHVjZSgob2JqLCBzdHIpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IHN0ci5zcGxpdCgvICo7ICovKTtcbiAgICBjb25zdCB1cmwgPSBwYXJ0c1swXS5zbGljZSgxLCAtMSk7XG4gICAgY29uc3QgcmVsID0gcGFydHNbMV0uc3BsaXQoLyAqPSAqLylbMV0uc2xpY2UoMSwgLTEpO1xuICAgIG9ialtyZWxdID0gdXJsO1xuICAgIHJldHVybiBvYmo7XG4gIH0sIHt9KTtcblxuLyoqXG4gKiBTdHJpcCBjb250ZW50IHJlbGF0ZWQgZmllbGRzIGZyb20gYGhlYWRlcmAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IGhlYWRlclxuICogQHJldHVybiB7T2JqZWN0fSBoZWFkZXJcbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmV4cG9ydHMuY2xlYW5IZWFkZXIgPSAoaGVhZGVyLCBjaGFuZ2VzT3JpZ2luKSA9PiB7XG4gIGRlbGV0ZSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICBkZWxldGUgaGVhZGVyWydjb250ZW50LWxlbmd0aCddO1xuICBkZWxldGUgaGVhZGVyWyd0cmFuc2Zlci1lbmNvZGluZyddO1xuICBkZWxldGUgaGVhZGVyLmhvc3Q7XG4gIC8vIHNlY3VpcnR5XG4gIGlmIChjaGFuZ2VzT3JpZ2luKSB7XG4gICAgZGVsZXRlIGhlYWRlci5hdXRob3JpemF0aW9uO1xuICAgIGRlbGV0ZSBoZWFkZXIuY29va2llO1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcjtcbn07XG4iXX0=","\"use strict\";\n\n/**\n * Module dependencies.\n */\nvar utils = require('./utils');\n/**\n * Expose `ResponseBase`.\n */\n\n\nmodule.exports = ResponseBase;\n/**\n * Initialize a new `ResponseBase`.\n *\n * @api public\n */\n\nfunction ResponseBase(obj) {\n if (obj) return mixin(obj);\n}\n/**\n * Mixin the prototype properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\n\nfunction mixin(obj) {\n for (var key in ResponseBase.prototype) {\n if (Object.prototype.hasOwnProperty.call(ResponseBase.prototype, key)) obj[key] = ResponseBase.prototype[key];\n }\n\n return obj;\n}\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\n\nResponseBase.prototype.get = function (field) {\n return this.header[field.toLowerCase()];\n};\n/**\n * Set header related properties:\n *\n * - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\n\nResponseBase.prototype._setHeaderProperties = function (header) {\n // TODO: moar!\n // TODO: make this a util\n // content-type\n var ct = header['content-type'] || '';\n this.type = utils.type(ct); // params\n\n var params = utils.params(ct);\n\n for (var key in params) {\n if (Object.prototype.hasOwnProperty.call(params, key)) this[key] = params[key];\n }\n\n this.links = {}; // links\n\n try {\n if (header.link) {\n this.links = utils.parseLinks(header.link);\n }\n } catch (_unused) {// ignore\n }\n};\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n * - .noContent\n * - .badRequest\n * - .unauthorized\n * - .notAcceptable\n * - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\n\nResponseBase.prototype._setStatusProperties = function (status) {\n var type = status / 100 | 0; // status / class\n\n this.statusCode = status;\n this.status = this.statusCode;\n this.statusType = type; // basics\n\n this.info = type === 1;\n this.ok = type === 2;\n this.redirect = type === 3;\n this.clientError = type === 4;\n this.serverError = type === 5;\n this.error = type === 4 || type === 5 ? this.toError() : false; // sugar\n\n this.created = status === 201;\n this.accepted = status === 202;\n this.noContent = status === 204;\n this.badRequest = status === 400;\n this.unauthorized = status === 401;\n this.notAcceptable = status === 406;\n this.forbidden = status === 403;\n this.notFound = status === 404;\n this.unprocessableEntity = status === 422;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS1iYXNlLmpzIl0sIm5hbWVzIjpbInV0aWxzIiwicmVxdWlyZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJSZXNwb25zZUJhc2UiLCJvYmoiLCJtaXhpbiIsImtleSIsInByb3RvdHlwZSIsIk9iamVjdCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImdldCIsImZpZWxkIiwiaGVhZGVyIiwidG9Mb3dlckNhc2UiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsImN0IiwidHlwZSIsInBhcmFtcyIsImxpbmtzIiwibGluayIsInBhcnNlTGlua3MiLCJfc2V0U3RhdHVzUHJvcGVydGllcyIsInN0YXR1cyIsInN0YXR1c0NvZGUiLCJzdGF0dXNUeXBlIiwiaW5mbyIsIm9rIiwicmVkaXJlY3QiLCJjbGllbnRFcnJvciIsInNlcnZlckVycm9yIiwiZXJyb3IiLCJ0b0Vycm9yIiwiY3JlYXRlZCIsImFjY2VwdGVkIiwibm9Db250ZW50IiwiYmFkUmVxdWVzdCIsInVuYXV0aG9yaXplZCIsIm5vdEFjY2VwdGFibGUiLCJmb3JiaWRkZW4iLCJub3RGb3VuZCIsInVucHJvY2Vzc2FibGVFbnRpdHkiXSwibWFwcGluZ3MiOiI7O0FBQUE7OztBQUlBLElBQU1BLEtBQUssR0FBR0MsT0FBTyxDQUFDLFNBQUQsQ0FBckI7QUFFQTs7Ozs7QUFJQUMsTUFBTSxDQUFDQyxPQUFQLEdBQWlCQyxZQUFqQjtBQUVBOzs7Ozs7QUFNQSxTQUFTQSxZQUFULENBQXNCQyxHQUF0QixFQUEyQjtBQUN6QixNQUFJQSxHQUFKLEVBQVMsT0FBT0MsS0FBSyxDQUFDRCxHQUFELENBQVo7QUFDVjtBQUVEOzs7Ozs7Ozs7QUFRQSxTQUFTQyxLQUFULENBQWVELEdBQWYsRUFBb0I7QUFDbEIsT0FBSyxJQUFNRSxHQUFYLElBQWtCSCxZQUFZLENBQUNJLFNBQS9CLEVBQTBDO0FBQ3hDLFFBQUlDLE1BQU0sQ0FBQ0QsU0FBUCxDQUFpQkUsY0FBakIsQ0FBZ0NDLElBQWhDLENBQXFD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LEdBQTJCbEIsTUFBTSxLQUFLLEdBQXRDO0FBQ0QsQ0ExQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1vZHVsZSBkZXBlbmRlbmNpZXMuXG4gKi9cblxuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzJyk7XG5cbi8qKlxuICogRXhwb3NlIGBSZXNwb25zZUJhc2VgLlxuICovXG5cbm1vZHVsZS5leHBvcnRzID0gUmVzcG9uc2VCYXNlO1xuXG4vKipcbiAqIEluaXRpYWxpemUgYSBuZXcgYFJlc3BvbnNlQmFzZWAuXG4gKlxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXNwb25zZUJhc2Uob2JqKSB7XG4gIGlmIChvYmopIHJldHVybiBtaXhpbihvYmopO1xufVxuXG4vKipcbiAqIE1peGluIHRoZSBwcm90b3R5cGUgcHJvcGVydGllcy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqXG4gKiBAcmV0dXJuIHtPYmplY3R9XG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5mdW5jdGlvbiBtaXhpbihvYmopIHtcbiAgZm9yIChjb25zdCBrZXkgaW4gUmVzcG9uc2VCYXNlLnByb3RvdHlwZSkge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoUmVzcG9uc2VCYXNlLnByb3RvdHlwZSwga2V5KSlcbiAgICAgIG9ialtrZXldID0gUmVzcG9uc2VCYXNlLnByb3RvdHlwZVtrZXldO1xuICB9XG5cbiAgcmV0dXJuIG9iajtcbn1cblxuLyoqXG4gKiBHZXQgY2FzZS1pbnNlbnNpdGl2ZSBgZmllbGRgIHZhbHVlLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLmdldCA9IGZ1bmN0aW9uKGZpZWxkKSB7XG4gIHJldHVybiB0aGlzLmhlYWRlcltmaWVsZC50b0xvd2VyQ2FzZSgpXTtcbn07XG5cbi8qKlxuICogU2V0IGhlYWRlciByZWxhdGVkIHByb3BlcnRpZXM6XG4gKlxuICogICAtIGAudHlwZWAgdGhlIGNvbnRlbnQgdHlwZSB3aXRob3V0IHBhcmFtc1xuICpcbiAqIEEgcmVzcG9uc2Ugb2YgXCJDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9dXRmLThcIlxuICogd2lsbCBwcm92aWRlIHlvdSB3aXRoIGEgYC50eXBlYCBvZiBcInRleHQvcGxhaW5cIi5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gaGVhZGVyXG4gKiBAYXBpIHByaXZhdGVcbiAqL1xuXG5SZXNwb25zZUJhc2UucHJvdG90eXBlLl9zZXRIZWFkZXJQcm9wZXJ0aWVzID0gZnVuY3Rpb24oaGVhZGVyKSB7XG4gIC8vIFRPRE86IG1vYXIhXG4gIC8vIFRPRE86IG1ha2UgdGhpcyBhIHV0aWxcblxuICAvLyBjb250ZW50LXR5cGVcbiAgY29uc3QgY3QgPSBoZWFkZXJbJ2NvbnRlbnQtdHlwZSddIHx8ICcnO1xuICB0aGlzLnR5cGUgPSB1dGlscy50eXBlKGN0KTtcblxuICAvLyBwYXJhbXNcbiAgY29uc3QgcGFyYW1zID0gdXRpbHMucGFyYW1zKGN0KTtcbiAgZm9yIChjb25zdCBrZXkgaW4gcGFyYW1zKSB7XG4gICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChwYXJhbXMsIGtleSkpXG4gICAgICB0aGlzW2tleV0gPSBwYXJhbXNba2V5XTtcbiAgfVxuXG4gIHRoaXMubGlua3MgPSB7fTtcblxuICAvLyBsaW5rc1xuICB0cnkge1xuICAgIGlmIChoZWFkZXIubGluaykge1xuICAgICAgdGhpcy5saW5rcyA9IHV0aWxzLnBhcnNlTGlua3MoaGVhZGVyLmxpbmspO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlXG4gIH1cbn07XG5cbi8qKlxuICogU2V0IGZsYWdzIHN1Y2ggYXMgYC5va2AgYmFzZWQgb24gYHN0YXR1c2AuXG4gKlxuICogRm9yIGV4YW1wbGUgYSAyeHggcmVzcG9uc2Ugd2lsbCBnaXZlIHlvdSBhIGAub2tgIG9mIF9fdHJ1ZV9fXG4gKiB3aGVyZWFzIDV4eCB3aWxsIGJlIF9fZmFsc2VfXyBhbmQgYC5lcnJvcmAgd2lsbCBiZSBfX3RydWVfXy4gVGhlXG4gKiBgLmNsaWVudEVycm9yYCBhbmQgYC5zZXJ2ZXJFcnJvcmAgYXJlIGFsc28gYXZhaWxhYmxlIHRvIGJlIG1vcmVcbiAqIHNwZWNpZmljLCBhbmQgYC5zdGF0dXNUeXBlYCBpcyB0aGUgY2xhc3Mgb2YgZXJyb3IgcmFuZ2luZyBmcm9tIDEuLjVcbiAqIHNvbWV0aW1lcyB1c2VmdWwgZm9yIG1hcHBpbmcgcmVzcG9uZCBjb2xvcnMgZXRjLlxuICpcbiAqIFwic3VnYXJcIiBwcm9wZXJ0aWVzIGFyZSBhbHNvIGRlZmluZWQgZm9yIGNvbW1vbiBjYXNlcy4gQ3VycmVudGx5IHByb3ZpZGluZzpcbiAqXG4gKiAgIC0gLm5vQ29udGVudFxuICogICAtIC5iYWRSZXF1ZXN0XG4gKiAgIC0gLnVuYXV0aG9yaXplZFxuICogICAtIC5ub3RBY2NlcHRhYmxlXG4gKiAgIC0gLm5vdEZvdW5kXG4gKlxuICogQHBhcmFtIHtOdW1iZXJ9IHN0YXR1c1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVzcG9uc2VCYXNlLnByb3RvdHlwZS5fc2V0U3RhdHVzUHJvcGVydGllcyA9IGZ1bmN0aW9uKHN0YXR1cykge1xuICBjb25zdCB0eXBlID0gKHN0YXR1cyAvIDEwMCkgfCAwO1xuXG4gIC8vIHN0YXR1cyAvIGNsYXNzXG4gIHRoaXMuc3RhdHVzQ29kZSA9IHN0YXR1cztcbiAgdGhpcy5zdGF0dXMgPSB0aGlzLnN0YXR1c0NvZGU7XG4gIHRoaXMuc3RhdHVzVHlwZSA9IHR5cGU7XG5cbiAgLy8gYmFzaWNzXG4gIHRoaXMuaW5mbyA9IHR5cGUgPT09IDE7XG4gIHRoaXMub2sgPSB0eXBlID09PSAyO1xuICB0aGlzLnJlZGlyZWN0ID0gdHlwZSA9PT0gMztcbiAgdGhpcy5jbGllbnRFcnJvciA9IHR5cGUgPT09IDQ7XG4gIHRoaXMuc2VydmVyRXJyb3IgPSB0eXBlID09PSA1O1xuICB0aGlzLmVycm9yID0gdHlwZSA9PT0gNCB8fCB0eXBlID09PSA1ID8gdGhpcy50b0Vycm9yKCkgOiBmYWxzZTtcblxuICAvLyBzdWdhclxuICB0aGlzLmNyZWF0ZWQgPSBzdGF0dXMgPT09IDIwMTtcbiAgdGhpcy5hY2NlcHRlZCA9IHN0YXR1cyA9PT0gMjAyO1xuICB0aGlzLm5vQ29udGVudCA9IHN0YXR1cyA9PT0gMjA0O1xuICB0aGlzLmJhZFJlcXVlc3QgPSBzdGF0dXMgPT09IDQwMDtcbiAgdGhpcy51bmF1dGhvcml6ZWQgPSBzdGF0dXMgPT09IDQwMTtcbiAgdGhpcy5ub3RBY2NlcHRhYmxlID0gc3RhdHVzID09PSA0MDY7XG4gIHRoaXMuZm9yYmlkZGVuID0gc3RhdHVzID09PSA0MDM7XG4gIHRoaXMubm90Rm91bmQgPSBzdGF0dXMgPT09IDQwNDtcbiAgdGhpcy51bnByb2Nlc3NhYmxlRW50aXR5ID0gc3RhdHVzID09PSA0MjI7XG59O1xuIl19","\"use strict\";\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction Agent() {\n this._defaults = [];\n}\n\n['use', 'on', 'once', 'set', 'query', 'type', 'accept', 'auth', 'withCredentials', 'sortQuery', 'retry', 'ok', 'redirects', 'timeout', 'buffer', 'serialize', 'parse', 'ca', 'key', 'pfx', 'cert', 'disableTLSCerts'].forEach(function (fn) {\n // Default setting for all requests from this agent\n Agent.prototype[fn] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this._defaults.push({\n fn: fn,\n args: args\n });\n\n return this;\n };\n});\n\nAgent.prototype._setDefaults = function (req) {\n this._defaults.forEach(function (def) {\n req[def.fn].apply(req, _toConsumableArray(def.args));\n });\n};\n\nmodule.exports = Agent;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hZ2VudC1iYXNlLmpzIl0sIm5hbWVzIjpbIkFnZW50IiwiX2RlZmF1bHRzIiwiZm9yRWFjaCIsImZuIiwicHJvdG90eXBlIiwiYXJncyIsInB1c2giLCJfc2V0RGVmYXVsdHMiLCJyZXEiLCJkZWYiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7OztBQUFBLFNBQVNBLEtBQVQsR0FBaUI7QUFDZixPQUFLQyxTQUFMLEdBQWlCLEVBQWpCO0FBQ0Q7O0FBRUQsQ0FDRSxLQURGLEVBRUUsSUFGRixFQUdFLE1BSEYsRUFJRSxLQUpGLEVBS0UsT0FMRixFQU1FLE1BTkYsRUFPRSxRQVBGLEVBUUUsTUFSRixFQVNFLGlCQVRGLEVBVUUsV0FWRixFQVdFLE9BWEYsRUFZRSxJQVpGLEVBYUUsV0FiRixFQWNFLFNBZEYsRUFlRSxRQWZGLEVBZ0JFLFdBaEJGLEVBaUJFLE9BakJGLEVBa0JFLElBbEJGLEVBbUJFLEtBbkJGLEVBb0JFLEtBcEJGLEVBcUJFLE1BckJGLEVBc0JFLGlCQXRCRixFQXVCRUMsT0F2QkYsQ0F1QlUsVUFBQUMsRUFBRSxFQUFJO0FBQ2Q7QUFDQUgsRUFBQUEsS0FBSyxDQUFDSSxTQUFOLENBQWdCRCxFQUFoQixJQUFzQixZQUFrQjtBQUFBLHNDQUFORSxJQUFNO0FBQU5BLE1BQUFBLElBQU07QUFBQTs7QUFDdEMsU0FBS0osU0FBTCxDQUFlSyxJQUFmLENBQW9CO0FBQUVILE1BQUFBLEVBQUUsRUFBRkEsRUFBRjtBQUFNRSxNQUFBQSxJQUFJLEVBQUpBO0FBQU4sS0FBcEI7O0FBQ0EsV0FBTyxJQUFQO0FBQ0QsR0FIRDtBQUlELENBN0JEOztBQStCQUwsS0FBSyxDQUFDSSxTQUFOLENBQWdCRyxZQUFoQixHQUErQixVQUFTQyxHQUFULEVBQWM7QUFDM0MsT0FBS1AsU0FBTCxDQUFlQyxPQUFmLENBQXVCLFVBQUFPLEdBQUcsRUFBSTtBQUM1QkQsSUFBQUEsR0FBRyxDQUFDQyxHQUFHLENBQUNOLEVBQUwsQ0FBSCxPQUFBSyxHQUFHLHFCQUFZQyxHQUFHLENBQUNKLElBQWhCLEVBQUg7QUFDRCxHQUZEO0FBR0QsQ0FKRDs7QUFNQUssTUFBTSxDQUFDQyxPQUFQLEdBQWlCWCxLQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIEFnZW50KCkge1xuICB0aGlzLl9kZWZhdWx0cyA9IFtdO1xufVxuXG5bXG4gICd1c2UnLFxuICAnb24nLFxuICAnb25jZScsXG4gICdzZXQnLFxuICAncXVlcnknLFxuICAndHlwZScsXG4gICdhY2NlcHQnLFxuICAnYXV0aCcsXG4gICd3aXRoQ3JlZGVudGlhbHMnLFxuICAnc29ydFF1ZXJ5JyxcbiAgJ3JldHJ5JyxcbiAgJ29rJyxcbiAgJ3JlZGlyZWN0cycsXG4gICd0aW1lb3V0JyxcbiAgJ2J1ZmZlcicsXG4gICdzZXJpYWxpemUnLFxuICAncGFyc2UnLFxuICAnY2EnLFxuICAna2V5JyxcbiAgJ3BmeCcsXG4gICdjZXJ0JyxcbiAgJ2Rpc2FibGVUTFNDZXJ0cydcbl0uZm9yRWFjaChmbiA9PiB7XG4gIC8vIERlZmF1bHQgc2V0dGluZyBmb3IgYWxsIHJlcXVlc3RzIGZyb20gdGhpcyBhZ2VudFxuICBBZ2VudC5wcm90b3R5cGVbZm5dID0gZnVuY3Rpb24oLi4uYXJncykge1xuICAgIHRoaXMuX2RlZmF1bHRzLnB1c2goeyBmbiwgYXJncyB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcbn0pO1xuXG5BZ2VudC5wcm90b3R5cGUuX3NldERlZmF1bHRzID0gZnVuY3Rpb24ocmVxKSB7XG4gIHRoaXMuX2RlZmF1bHRzLmZvckVhY2goZGVmID0+IHtcbiAgICByZXFbZGVmLmZuXSguLi5kZWYuYXJncyk7XG4gIH0pO1xufTtcblxubW9kdWxlLmV4cG9ydHMgPSBBZ2VudDtcbiJdfQ==","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Root reference for iframes.\n */\nvar root;\n\nif (typeof window !== 'undefined') {\n // Browser window\n root = window;\n} else if (typeof self === 'undefined') {\n // Other environments\n console.warn('Using browser-only version of superagent in non-browser environment');\n root = void 0;\n} else {\n // Web Worker\n root = self;\n}\n\nvar Emitter = require('component-emitter');\n\nvar safeStringify = require('fast-safe-stringify');\n\nvar RequestBase = require('./request-base');\n\nvar isObject = require('./is-object');\n\nvar ResponseBase = require('./response-base');\n\nvar Agent = require('./agent-base');\n/**\n * Noop.\n */\n\n\nfunction noop() {}\n/**\n * Expose `request`.\n */\n\n\nmodule.exports = function (method, url) {\n // callback\n if (typeof url === 'function') {\n return new exports.Request('GET', method).end(url);\n } // url first\n\n\n if (arguments.length === 1) {\n return new exports.Request('GET', method);\n }\n\n return new exports.Request(method, url);\n};\n\nexports = module.exports;\nvar request = exports;\nexports.Request = Request;\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n if (root.XMLHttpRequest && (!root.location || root.location.protocol !== 'file:' || !root.ActiveXObject)) {\n return new XMLHttpRequest();\n }\n\n try {\n return new ActiveXObject('Microsoft.XMLHTTP');\n } catch (_unused) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.6.0');\n } catch (_unused2) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP.3.0');\n } catch (_unused3) {}\n\n try {\n return new ActiveXObject('Msxml2.XMLHTTP');\n } catch (_unused4) {}\n\n throw new Error('Browser-only version of superagent could not find XHR');\n};\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\n\nvar trim = ''.trim ? function (s) {\n return s.trim();\n} : function (s) {\n return s.replace(/(^\\s*|\\s*$)/g, '');\n};\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n if (!isObject(obj)) return obj;\n var pairs = [];\n\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) pushEncodedKeyValuePair(pairs, key, obj[key]);\n }\n\n return pairs.join('&');\n}\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n if (val === undefined) return;\n\n if (val === null) {\n pairs.push(encodeURI(key));\n return;\n }\n\n if (Array.isArray(val)) {\n val.forEach(function (v) {\n pushEncodedKeyValuePair(pairs, key, v);\n });\n } else if (isObject(val)) {\n for (var subkey in val) {\n if (Object.prototype.hasOwnProperty.call(val, subkey)) pushEncodedKeyValuePair(pairs, \"\".concat(key, \"[\").concat(subkey, \"]\"), val[subkey]);\n }\n } else {\n pairs.push(encodeURI(key) + '=' + encodeURIComponent(val));\n }\n}\n/**\n * Expose serialization method.\n */\n\n\nrequest.serializeObject = serialize;\n/**\n * Parse the given x-www-form-urlencoded `str`.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseString(str) {\n var obj = {};\n var pairs = str.split('&');\n var pair;\n var pos;\n\n for (var i = 0, len = pairs.length; i < len; ++i) {\n pair = pairs[i];\n pos = pair.indexOf('=');\n\n if (pos === -1) {\n obj[decodeURIComponent(pair)] = '';\n } else {\n obj[decodeURIComponent(pair.slice(0, pos))] = decodeURIComponent(pair.slice(pos + 1));\n }\n }\n\n return obj;\n}\n/**\n * Expose parser.\n */\n\n\nrequest.parseString = parseString;\n/**\n * Default MIME type map.\n *\n * superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n html: 'text/html',\n json: 'application/json',\n xml: 'text/xml',\n urlencoded: 'application/x-www-form-urlencoded',\n form: 'application/x-www-form-urlencoded',\n 'form-data': 'application/x-www-form-urlencoded'\n};\n/**\n * Default serialization map.\n *\n * superagent.serialize['application/xml'] = function(obj){\n * return 'generated xml here';\n * };\n *\n */\n\nrequest.serialize = {\n 'application/x-www-form-urlencoded': serialize,\n 'application/json': safeStringify\n};\n/**\n * Default parsers.\n *\n * superagent.parse['application/xml'] = function(str){\n * return { object parsed from str };\n * };\n *\n */\n\nrequest.parse = {\n 'application/x-www-form-urlencoded': parseString,\n 'application/json': JSON.parse\n};\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n var lines = str.split(/\\r?\\n/);\n var fields = {};\n var index;\n var line;\n var field;\n var val;\n\n for (var i = 0, len = lines.length; i < len; ++i) {\n line = lines[i];\n index = line.indexOf(':');\n\n if (index === -1) {\n // could be empty line, just skip it\n continue;\n }\n\n field = line.slice(0, index).toLowerCase();\n val = trim(line.slice(index + 1));\n fields[field] = val;\n }\n\n return fields;\n}\n/**\n * Check if `mime` is json or has +json structured syntax suffix.\n *\n * @param {String} mime\n * @return {Boolean}\n * @api private\n */\n\n\nfunction isJSON(mime) {\n // should match /json or +json\n // but not /json-seq\n return /[/+]json($|[^-\\w])/.test(mime);\n}\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n * - set flags (.ok, .error, etc)\n * - parse header\n *\n * Examples:\n *\n * Aliasing `superagent` as `request` is nice:\n *\n * request = superagent;\n *\n * We can use the promise-like API, or pass callbacks:\n *\n * request.get('/').end(function(res){});\n * request.get('/', function(res){});\n *\n * Sending data can be chained:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' })\n * .end(function(res){});\n *\n * Or passed to `.send()`:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' }, function(res){});\n *\n * Or passed to `.post()`:\n *\n * request\n * .post('/user', { name: 'tj' })\n * .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n * request\n * .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\n\nfunction Response(req) {\n this.req = req;\n this.xhr = this.req.xhr; // responseText is accessible only if responseType is '' or 'text' and on older browsers\n\n this.text = this.req.method !== 'HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text') || typeof this.xhr.responseType === 'undefined' ? this.xhr.responseText : null;\n this.statusText = this.req.xhr.statusText;\n var status = this.xhr.status; // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n\n if (status === 1223) {\n status = 204;\n }\n\n this._setStatusProperties(status);\n\n this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n this.header = this.headers; // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n // getResponseHeader still works. so we get content-type even if getting\n // other headers fails.\n\n this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n\n this._setHeaderProperties(this.header);\n\n if (this.text === null && req._responseType) {\n this.body = this.xhr.response;\n } else {\n this.body = this.req.method === 'HEAD' ? null : this._parseBody(this.text ? this.text : this.xhr.response);\n }\n} // eslint-disable-next-line new-cap\n\n\nResponseBase(Response.prototype);\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype._parseBody = function (str) {\n var parse = request.parse[this.type];\n\n if (this.req._parser) {\n return this.req._parser(this, str);\n }\n\n if (!parse && isJSON(this.type)) {\n parse = request.parse['application/json'];\n }\n\n return parse && str && (str.length > 0 || str instanceof Object) ? parse(str) : null;\n};\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\n\nResponse.prototype.toError = function () {\n var req = this.req;\n var method = req.method;\n var url = req.url;\n var msg = \"cannot \".concat(method, \" \").concat(url, \" (\").concat(this.status, \")\");\n var err = new Error(msg);\n err.status = this.status;\n err.method = method;\n err.url = url;\n return err;\n};\n/**\n * Expose `Response`.\n */\n\n\nrequest.Response = Response;\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n var self = this;\n this._query = this._query || [];\n this.method = method;\n this.url = url;\n this.header = {}; // preserves header name case\n\n this._header = {}; // coerces header names to lowercase\n\n this.on('end', function () {\n var err = null;\n var res = null;\n\n try {\n res = new Response(self);\n } catch (err_) {\n err = new Error('Parser is unable to parse the response');\n err.parse = true;\n err.original = err_; // issue #675: return the raw response if the response parsing fails\n\n if (self.xhr) {\n // ie9 doesn't have 'response' property\n err.rawResponse = typeof self.xhr.responseType === 'undefined' ? self.xhr.responseText : self.xhr.response; // issue #876: return the http status code if the response parsing fails\n\n err.status = self.xhr.status ? self.xhr.status : null;\n err.statusCode = err.status; // backwards-compat only\n } else {\n err.rawResponse = null;\n err.status = null;\n }\n\n return self.callback(err);\n }\n\n self.emit('response', res);\n var new_err;\n\n try {\n if (!self._isResponseOK(res)) {\n new_err = new Error(res.statusText || res.text || 'Unsuccessful HTTP response');\n }\n } catch (err_) {\n new_err = err_; // ok() callback can throw\n } // #1000 don't catch errors from the callback to avoid double calling it\n\n\n if (new_err) {\n new_err.original = err;\n new_err.response = res;\n new_err.status = res.status;\n self.callback(new_err, res);\n } else {\n self.callback(null, res);\n }\n });\n}\n/**\n * Mixin `Emitter` and `RequestBase`.\n */\n// eslint-disable-next-line new-cap\n\n\nEmitter(Request.prototype); // eslint-disable-next-line new-cap\n\nRequestBase(Request.prototype);\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.xml = 'application/xml';\n *\n * request.post('/')\n * .type('xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * request.post('/')\n * .type('application/xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function (type) {\n this.set('Content-Type', request.types[type] || type);\n return this;\n};\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.json = 'application/json';\n *\n * request.get('/agent')\n * .accept('json')\n * .end(callback);\n *\n * request.get('/agent')\n * .accept('application/json')\n * .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.accept = function (type) {\n this.set('Accept', request.types[type] || type);\n return this;\n};\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} [pass] optional in case of using 'bearer' as type\n * @param {Object} options with 'type' property 'auto', 'basic' or 'bearer' (default 'basic')\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.auth = function (user, pass, options) {\n if (arguments.length === 1) pass = '';\n\n if (_typeof(pass) === 'object' && pass !== null) {\n // pass is optional and can be replaced with options\n options = pass;\n pass = '';\n }\n\n if (!options) {\n options = {\n type: typeof btoa === 'function' ? 'basic' : 'auto'\n };\n }\n\n var encoder = function encoder(string) {\n if (typeof btoa === 'function') {\n return btoa(string);\n }\n\n throw new Error('Cannot use basic auth, btoa is not a function');\n };\n\n return this._auth(user, pass, options, encoder);\n};\n/**\n * Add query-string `val`.\n *\n * Examples:\n *\n * request.get('/shoes')\n * .query('size=10')\n * .query({ color: 'blue' })\n *\n * @param {Object|String} val\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.query = function (val) {\n if (typeof val !== 'string') val = serialize(val);\n if (val) this._query.push(val);\n return this;\n};\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `options` (or filename).\n *\n * ``` js\n * request.post('/upload')\n * .attach('content', new Blob(['hey!'], { type: \"text/html\"}))\n * .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String|Object} options\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.attach = function (field, file, options) {\n if (file) {\n if (this._data) {\n throw new Error(\"superagent can't mix .send() and .attach()\");\n }\n\n this._getFormData().append(field, file, options || file.name);\n }\n\n return this;\n};\n\nRequest.prototype._getFormData = function () {\n if (!this._formData) {\n this._formData = new root.FormData();\n }\n\n return this._formData;\n};\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\n\nRequest.prototype.callback = function (err, res) {\n if (this._shouldRetry(err, res)) {\n return this._retry();\n }\n\n var fn = this._callback;\n this.clearTimeout();\n\n if (err) {\n if (this._maxRetries) err.retries = this._retries - 1;\n this.emit('error', err);\n }\n\n fn(err, res);\n};\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\n\nRequest.prototype.crossDomainError = function () {\n var err = new Error('Request has been terminated\\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.');\n err.crossDomain = true;\n err.status = this.status;\n err.method = this.method;\n err.url = this.url;\n this.callback(err);\n}; // This only warns, because the request is still likely to work\n\n\nRequest.prototype.agent = function () {\n console.warn('This is not supported in browser version of superagent');\n return this;\n};\n\nRequest.prototype.ca = Request.prototype.agent;\nRequest.prototype.buffer = Request.prototype.ca; // This throws, because it can't send/receive data as expected\n\nRequest.prototype.write = function () {\n throw new Error('Streaming is not supported in browser version of superagent');\n};\n\nRequest.prototype.pipe = Request.prototype.write;\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * @param {Object} obj host object\n * @return {Boolean} is a host object\n * @api private\n */\n\nRequest.prototype._isHost = function (obj) {\n // Native objects stringify to [object File], [object Blob], [object FormData], etc.\n return obj && _typeof(obj) === 'object' && !Array.isArray(obj) && Object.prototype.toString.call(obj) !== '[object Object]';\n};\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\n\nRequest.prototype.end = function (fn) {\n if (this._endCalled) {\n console.warn('Warning: .end() was called twice. This is not supported in superagent');\n }\n\n this._endCalled = true; // store callback\n\n this._callback = fn || noop; // querystring\n\n this._finalizeQueryString();\n\n this._end();\n};\n\nRequest.prototype._setUploadTimeout = function () {\n var self = this; // upload timeout it's wokrs only if deadline timeout is off\n\n if (this._uploadTimeout && !this._uploadTimeoutTimer) {\n this._uploadTimeoutTimer = setTimeout(function () {\n self._timeoutError('Upload timeout of ', self._uploadTimeout, 'ETIMEDOUT');\n }, this._uploadTimeout);\n }\n}; // eslint-disable-next-line complexity\n\n\nRequest.prototype._end = function () {\n if (this._aborted) return this.callback(new Error('The request has been aborted even before .end() was called'));\n var self = this;\n this.xhr = request.getXHR();\n var xhr = this.xhr;\n var data = this._formData || this._data;\n\n this._setTimeouts(); // state change\n\n\n xhr.onreadystatechange = function () {\n var readyState = xhr.readyState;\n\n if (readyState >= 2 && self._responseTimeoutTimer) {\n clearTimeout(self._responseTimeoutTimer);\n }\n\n if (readyState !== 4) {\n return;\n } // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n // result in the error \"Could not complete the operation due to error c00c023f\"\n\n\n var status;\n\n try {\n status = xhr.status;\n } catch (_unused5) {\n status = 0;\n }\n\n if (!status) {\n if (self.timedout || self._aborted) return;\n return self.crossDomainError();\n }\n\n self.emit('end');\n }; // progress\n\n\n var handleProgress = function handleProgress(direction, e) {\n if (e.total > 0) {\n e.percent = e.loaded / e.total * 100;\n\n if (e.percent === 100) {\n clearTimeout(self._uploadTimeoutTimer);\n }\n }\n\n e.direction = direction;\n self.emit('progress', e);\n };\n\n if (this.hasListeners('progress')) {\n try {\n xhr.addEventListener('progress', handleProgress.bind(null, 'download'));\n\n if (xhr.upload) {\n xhr.upload.addEventListener('progress', handleProgress.bind(null, 'upload'));\n }\n } catch (_unused6) {// Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n // Reported here:\n // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n }\n }\n\n if (xhr.upload) {\n this._setUploadTimeout();\n } // initiate request\n\n\n try {\n if (this.username && this.password) {\n xhr.open(this.method, this.url, true, this.username, this.password);\n } else {\n xhr.open(this.method, this.url, true);\n }\n } catch (err) {\n // see #1149\n return this.callback(err);\n } // CORS\n\n\n if (this._withCredentials) xhr.withCredentials = true; // body\n\n if (!this._formData && this.method !== 'GET' && this.method !== 'HEAD' && typeof data !== 'string' && !this._isHost(data)) {\n // serialize stuff\n var contentType = this._header['content-type'];\n\n var _serialize = this._serializer || request.serialize[contentType ? contentType.split(';')[0] : ''];\n\n if (!_serialize && isJSON(contentType)) {\n _serialize = request.serialize['application/json'];\n }\n\n if (_serialize) data = _serialize(data);\n } // set header fields\n\n\n for (var field in this.header) {\n if (this.header[field] === null) continue;\n if (Object.prototype.hasOwnProperty.call(this.header, field)) xhr.setRequestHeader(field, this.header[field]);\n }\n\n if (this._responseType) {\n xhr.responseType = this._responseType;\n } // send stuff\n\n\n this.emit('request', this); // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n // We need null here if data is undefined\n\n xhr.send(typeof data === 'undefined' ? null : data);\n};\n\nrequest.agent = function () {\n return new Agent();\n};\n\n['GET', 'POST', 'OPTIONS', 'PATCH', 'PUT', 'DELETE'].forEach(function (method) {\n Agent.prototype[method.toLowerCase()] = function (url, fn) {\n var req = new request.Request(method, url);\n\n this._setDefaults(req);\n\n if (fn) {\n req.end(fn);\n }\n\n return req;\n };\n});\nAgent.prototype.del = Agent.prototype.delete;\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.get = function (url, data, fn) {\n var req = request('GET', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.head = function (url, data, fn) {\n var req = request('HEAD', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * OPTIONS query to `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.options = function (url, data, fn) {\n var req = request('OPTIONS', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * DELETE `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nfunction del(url, data, fn) {\n var req = request('DELETE', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n}\n\nrequest.del = del;\nrequest.delete = del;\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function (url, data, fn) {\n var req = request('PATCH', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} [data]\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.post = function (url, data, fn) {\n var req = request('POST', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} [data] or fn\n * @param {Function} [fn]\n * @return {Request}\n * @api public\n */\n\n\nrequest.put = function (url, data, fn) {\n var req = request('PUT', url);\n\n if (typeof data === 'function') {\n fn = data;\n data = null;\n }\n\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jbGllbnQuanMiXSwibmFtZXMiOlsicm9vdCIsIndpbmRvdyIsInNlbGYiLCJjb25zb2xlIiwid2FybiIsIkVtaXR0ZXIiLCJyZXF1aXJlIiwic2FmZVN0cmluZ2lmeSIsIlJlcXVlc3RCYXNlIiwiaXNPYmplY3QiLCJSZXNwb25zZUJhc2UiLCJBZ2VudCIsIm5vb3AiLCJtb2R1bGUiLCJleHBvcnRzIiwibWV0aG9kIiwidXJsIiwiUmVxdWVzdCIsImVuZCIsImFyZ3VtZW50cyIsImxlbmd0aCIsInJlcXVlc3QiLCJnZXRYSFIiLCJYTUxIdHRwUmVxdWVzdCIsImxvY2F0aW9uIiwicHJvdG9jb2wiLCJBY3RpdmVYT2JqZWN0IiwiRXJyb3IiLCJ0cmltIiwicyIsInJlcGxhY2UiLCJzZXJpYWxpemUiLCJvYmoiLCJwYWlycyIsImtleSIsIk9iamVjdCIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsInB1c2hFbmNvZGVkS2V5VmFsdWVQYWlyIiwiam9pbiIsInZhbCIsInVuZGVmaW5lZCIsInB1c2giLCJlbmNvZGVVUkkiLCJBcnJheSIsImlzQXJyYXkiLCJmb3JFYWNoIiwidiIsInN1YmtleSIsImVuY29kZVVSSUNvbXBvbmVudCIsInNlcmlhbGl6ZU9iamVjdCIsInBhcnNlU3RyaW5nIiwic3RyIiwic3BsaXQiLCJwYWlyIiwicG9zIiwiaSIsImxlbiIsImluZGV4T2YiLCJkZWNvZGVVUklDb21wb25lbnQiLCJzbGljZSIsInR5cGVzIiwiaHRtbCIsImpzb24iLCJ4bWwiLCJ1cmxlbmNvZGVkIiwiZm9ybSIsInBhcnNlIiwiSlNPTiIsInBhcnNlSGVhZGVyIiwibGluZXMiLCJmaWVsZHMiLCJpbmRleCIsImxpbmUiLCJmaWVsZCIsInRvTG93ZXJDYXNlIiwiaXNKU09OIiwibWltZSIsInRlc3QiLCJSZXNwb25zZSIsInJlcSIsInhociIsInRleHQiLCJyZXNwb25zZVR5cGUiLCJyZXNwb25zZVRleHQiLCJzdGF0dXNUZXh0Iiwic3RhdHVzIiwiX3NldFN0YXR1c1Byb3BlcnRpZXMiLCJoZWFkZXJzIiwiZ2V0QWxsUmVzcG9uc2VIZWFkZXJzIiwiaGVhZGVyIiwiZ2V0UmVzcG9uc2VIZWFkZXIiLCJfc2V0SGVhZGVyUHJvcGVydGllcyIsIl9yZXNwb25zZVR5cGUiLCJib2R5IiwicmVzcG9uc2UiLCJfcGFyc2VCb2R5IiwidHlwZSIsIl9wYXJzZXIiLCJ0b0Vycm9yIiwibXNnIiwiZXJyIiwiX3F1ZXJ5IiwiX2hlYWRlciIsIm9uIiwicmVzIiwiZXJyXyIsIm9yaWdpbmFsIiwicmF3UmVzcG9uc2UiLCJzdGF0dXNDb2RlIiwiY2FsbGJhY2siLCJlbWl0IiwibmV3X2VyciIsIl9pc1Jlc3BvbnNlT0siLCJzZXQiLCJhY2NlcHQiLCJhdXRoIiwidXNlciIsInBhc3MiLCJvcHRpb25zIiwiYnRvYSIsImVuY29kZXIiLCJzdHJpbmciLCJfYXV0aCIsInF1ZXJ5IiwiYXR0YWNoIiwiZmlsZSIsIl9kYXRhIiwiX2dldEZvcm1EYXRhIiwiYXBwZW5kIiwibmFtZSIsIl9mb3JtRGF0YSIsIkZvcm1EYXRhIiwiX3Nob3VsZFJldHJ5IiwiX3JldHJ5IiwiZm4iLCJfY2FsbGJhY2siLCJjbGVhclRpbWVvdXQiLCJfbWF4UmV0cmllcyIsInJldHJpZXMiLCJfcmV0cmllcyIsImNyb3NzRG9tYWluRXJyb3IiLCJjcm9zc0RvbWFpbiIsImFnZW50IiwiY2EiLCJidWZmZXIiLCJ3cml0ZSIsInBpcGUiLCJfaXNIb3N0IiwidG9TdHJpbmciLCJfZW5kQ2FsbGVkIiwiX2ZpbmFsaXplUXVlcnlTdHJpbmciLCJfZW5kIiwiX3NldFVwbG9hZFRpbWVvdXQiLCJfdXBsb2FkVGltZW91dCIsIl91cGxvYWRUaW1lb3V0VGltZXIiLCJzZXRUaW1lb3V0IiwiX3RpbWVvdXRFcnJvciIsIl9hYm9ydGVkIiwiZGF0YSIsIl9zZXRUaW1lb3V0cyIsIm9ucmVhZHlzdGF0ZWNoYW5nZSIsInJlYWR5U3RhdGUiLCJfcmVzcG9uc2VUaW1lb3V0VGltZXIiLCJ0aW1lZG91dCIsImhhbmRsZVByb2dyZXNzIiwiZGlyZWN0aW9uIiwiZSIsInRvdGFsIiwicGVyY2VudCIsImxvYWRlZCIsImhhc0xpc3RlbmVycyIsImFkZEV2ZW50TGlzdGVuZXIiLCJiaW5kIiwidXBsb2FkIiwidXNlcm5hbWUiLCJwYXNzd29yZCIsIm9wZW4iLCJfd2l0aENyZWRlbnRpYWxzIiwid2l0aENyZWRlbnRpYWxzIiwiY29udGVudFR5cGUiLCJfc2VyaWFsaXplciIsInNldFJlcXVlc3RIZWFkZXIiLCJzZW5kIiwiX3NldERlZmF1bHRzIiwiZGVsIiwiZGVsZXRlIiwiZ2V0IiwiaGVhZCIsInBhdGNoIiwicG9zdCIsInB1dCJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7QUFJQSxJQUFJQSxJQUFKOztBQUNBLElBQUksT0FBT0MsTUFBUCxLQUFrQixXQUF0QixFQUFtQztBQUNqQztBQUNBRCxFQUFBQSxJQUFJLEdBQUdDLE1BQVA7QUFDRCxDQUhELE1BR08sSUFBSSxPQUFPQyxJQUFQLEtBQWdCLFdBQXBCLEVBQWlDO0FBQ3RDO0FBQ0FDLEVBQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUNFLHFFQURGO0FBR0FKLEVBQUFBLElBQUksU0FBSjtBQUNELENBTk0sTUFNQTtBQUNMO0FBQ0FBLEVBQUFBLElBQUksR0FBR0UsSUFBUDtBQUNEOztBQUVELElBQU1HLE9BQU8sR0FBR0MsT0FBTyxDQUFDLG1CQUFELENBQXZCOztBQUNBLElBQU1DLGFBQWEsR0FBR0QsT0FBTyxDQUFDLHFCQUFELENBQTdCOztBQUNBLElBQU1FLFdBQVcsR0FBR0YsT0FBTyxDQUFDLGdCQUFELENBQTNCOztBQUNBLElBQU1HLFFBQVEsR0FBR0gsT0FBTyxDQUFDLGFBQUQsQ0FBeEI7O0FBQ0EsSUFBTUksWUFBWSxHQUFHSixPQUFPLENBQUMsaUJBQUQsQ0FBNUI7O0FBQ0EsSUFBTUssS0FBSyxHQUFHTCxPQUFPLENBQUMsY0FBRCxDQUFyQjtBQUVBOzs7OztBQUlBLFNBQVNNLElBQVQsR0FBZ0IsQ0FBRTtBQUVsQjs7Ozs7QUFJ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cmVuY2UgZm9yIGlmcmFtZXMuXG4gKi9cblxubGV0IHJvb3Q7XG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgLy8gQnJvd3NlciB3aW5kb3dcbiAgcm9vdCA9IHdpbmRvdztcbn0gZWxzZSBpZiAodHlwZW9mIHNlbGYgPT09ICd1bmRlZmluZWQnKSB7XG4gIC8vIE90aGVyIGVudmlyb25tZW50c1xuICBjb25zb2xlLndhcm4oXG4gICAgJ1VzaW5nIGJyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgaW4gbm9uLWJyb3dzZXIgZW52aXJvbm1lbnQnXG4gICk7XG4gIHJvb3QgPSB0aGlzO1xufSBlbHNlIHtcbiAgLy8gV2ViIFdvcmtlclxuICByb290ID0gc2VsZjtcbn1cblxuY29uc3QgRW1pdHRlciA9IHJlcXVpcmUoJ2NvbXBvbmVudC1lbWl0dGVyJyk7XG5jb25zdCBzYWZlU3RyaW5naWZ5ID0gcmVxdWlyZSgnZmFzdC1zYWZlLXN0cmluZ2lmeScpO1xuY29uc3QgUmVxdWVzdEJhc2UgPSByZXF1aXJlKCcuL3JlcXVlc3QtYmFzZScpO1xuY29uc3QgaXNPYmplY3QgPSByZXF1aXJlKCcuL2lzLW9iamVjdCcpO1xuY29uc3QgUmVzcG9uc2VCYXNlID0gcmVxdWlyZSgnLi9yZXNwb25zZS1iYXNlJyk7XG5jb25zdCBBZ2VudCA9IHJlcXVpcmUoJy4vYWdlbnQtYmFzZScpO1xuXG4vKipcbiAqIE5vb3AuXG4gKi9cblxuZnVuY3Rpb24gbm9vcCgpIHt9XG5cbi8qKlxuICogRXhwb3NlIGByZXF1ZXN0YC5cbiAqL1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKG1ldGhvZCwgdXJsKSB7XG4gIC8vIGNhbGxiYWNrXG4gIGlmICh0eXBlb2YgdXJsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIG5ldyBleHBvcnRzLlJlcXVlc3QoJ0dFVCcsIG1ldGhvZCkuZW5kKHVybCk7XG4gIH1cblxuICAvLyB1cmwgZmlyc3RcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHtcbiAgICByZXR1cm4gbmV3IGV4cG9ydHMuUmVxdWVzdCgnR0VUJywgbWV0aG9kKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgZXhwb3J0cy5SZXF1ZXN0KG1ldGhvZCwgdXJsKTtcbn07XG5cbmV4cG9ydHMgPSBtb2R1bGUuZXhwb3J0cztcblxuY29uc3QgcmVxdWVzdCA9IGV4cG9ydHM7XG5cbmV4cG9ydHMuUmVxdWVzdCA9IFJlcXVlc3Q7XG5cbi8qKlxuICogRGV0ZXJtaW5lIFhIUi5cbiAqL1xuXG5yZXF1ZXN0LmdldFhIUiA9ICgpID0+IHtcbiAgaWYgKFxuICAgIHJvb3QuWE1MSHR0cFJlcXVlc3QgJiZcbiAgICAoIXJvb3QubG9jYXRpb24gfHxcbiAgICAgIHJvb3QubG9jYXRpb24ucHJvdG9jb2wgIT09ICdmaWxlOicgfHxcbiAgICAgICFyb290LkFjdGl2ZVhPYmplY3QpXG4gICkge1xuICAgIHJldHVybiBuZXcgWE1MSHR0cFJlcXVlc3QoKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgcmV0dXJuIG5ldyBBY3RpdmVYT2JqZWN0KCdNaWNyb3NvZnQuWE1MSFRUUCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjYuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQLjMuMCcpO1xuICB9IGNhdGNoIHt9XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gbmV3IEFjdGl2ZVhPYmplY3QoJ01zeG1sMi5YTUxIVFRQJyk7XG4gIH0gY2F0Y2gge31cblxuICB0aHJvdyBuZXcgRXJyb3IoJ0Jyb3dzZXItb25seSB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQgY291bGQgbm90IGZpbmQgWEhSJyk7XG59O1xuXG4vKipcbiAqIFJlbW92ZXMgbGVhZGluZyBhbmQgdHJhaWxpbmcgd2hpdGVzcGFjZSwgYWRkZWQgdG8gc3VwcG9ydCBJRS5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc1xuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuY29uc3QgdHJpbSA9ICcnLnRyaW0gPyBzID0+IHMudHJpbSgpIDogcyA9PiBzLnJlcGxhY2UoLyheXFxzKnxcXHMqJCkvZywgJycpO1xuXG4vKipcbiAqIFNlcmlhbGl6ZSB0aGUgZ2l2ZW4gYG9iamAuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9ialxuICogQHJldHVybiB7U3RyaW5nfVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gc2VyaWFsaXplKG9iaikge1xuICBpZiAoIWlzT2JqZWN0KG9iaikpIHJldHVybiBvYmo7XG4gIGNvbnN0IHBhaXJzID0gW107XG4gIGZvciAoY29uc3Qga2V5IGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBrZXkpKVxuICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGtleSwgb2JqW2tleV0pO1xuICB9XG5cbiAgcmV0dXJuIHBhaXJzLmpvaW4oJyYnKTtcbn1cblxuLyoqXG4gKiBIZWxwcyAnc2VyaWFsaXplJyB3aXRoIHNlcmlhbGl6aW5nIGFycmF5cy5cbiAqIE11dGF0ZXMgdGhlIHBhaXJzIGFycmF5LlxuICpcbiAqIEBwYXJhbSB7QXJyYXl9IHBhaXJzXG4gKiBAcGFyYW0ge1N0cmluZ30ga2V5XG4gKiBAcGFyYW0ge01peGVkfSB2YWxcbiAqL1xuXG5mdW5jdGlvbiBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2YWwpIHtcbiAgaWYgKHZhbCA9PT0gdW5kZWZpbmVkKSByZXR1cm47XG4gIGlmICh2YWwgPT09IG51bGwpIHtcbiAgICBwYWlycy5wdXNoKGVuY29kZVVSSShrZXkpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheSh2YWwpKSB7XG4gICAgdmFsLmZvckVhY2godiA9PiB7XG4gICAgICBwdXNoRW5jb2RlZEtleVZhbHVlUGFpcihwYWlycywga2V5LCB2KTtcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc09iamVjdCh2YWwpKSB7XG4gICAgZm9yIChjb25zdCBzdWJrZXkgaW4gdmFsKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHZhbCwgc3Via2V5KSlcbiAgICAgICAgcHVzaEVuY29kZWRLZXlWYWx1ZVBhaXIocGFpcnMsIGAke2tleX1bJHtzdWJrZXl9XWAsIHZhbFtzdWJrZXldKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcGFpcnMucHVzaChlbmNvZGVVUkkoa2V5KSArICc9JyArIGVuY29kZVVSSUNvbXBvbmVudCh2YWwpKTtcbiAgfVxufVxuXG4vKipcbiAqIEV4cG9zZSBzZXJpYWxpemF0aW9uIG1ldGhvZC5cbiAqL1xuXG5yZXF1ZXN0LnNlcmlhbGl6ZU9iamVjdCA9IHNlcmlhbGl6ZTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4geC13d3ctZm9ybS11cmxlbmNvZGVkIGBzdHJgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgY29uc3QgcGFpcnMgPSBzdHIuc3BsaXQoJyYnKTtcbiAgbGV0IHBhaXI7XG4gIGxldCBwb3M7XG5cbiAgZm9yIChsZXQgaSA9IDAsIGxlbiA9IHBhaXJzLmxlbmd0aDsgaSA8IGxlbjsgKytpKSB7XG4gICAgcGFpciA9IHBhaXJzW2ldO1xuICAgIHBvcyA9IHBhaXIuaW5kZXhPZignPScpO1xuICAgIGlmIChwb3MgPT09IC0xKSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIpXSA9ICcnO1xuICAgIH0gZWxzZSB7XG4gICAgICBvYmpbZGVjb2RlVVJJQ29tcG9uZW50KHBhaXIuc2xpY2UoMCwgcG9zKSldID0gZGVjb2RlVVJJQ29tcG9uZW50KFxuICAgICAgICBwYWlyLnNsaWNlKHBvcyArIDEpXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbi8qKlxuICogRXhwb3NlIHBhcnNlci5cbiAqL1xuXG5yZXF1ZXN0LnBhcnNlU3RyaW5nID0gcGFyc2VTdHJpbmc7XG5cbi8qKlxuICogRGVmYXVsdCBNSU1FIHR5cGUgbWFwLlxuICpcbiAqICAgICBzdXBlcmFnZW50LnR5cGVzLnhtbCA9ICdhcHBsaWNhdGlvbi94bWwnO1xuICpcbiAqL1xuXG5yZXF1ZXN0LnR5cGVzID0ge1xuICBodG1sOiAndGV4dC9odG1sJyxcbiAganNvbjogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICB4bWw6ICd0ZXh0L3htbCcsXG4gIHVybGVuY29kZWQ6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnLFxuICBmb3JtOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyxcbiAgJ2Zvcm0tZGF0YSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG59O1xuXG4vKipcbiAqIERlZmF1bHQgc2VyaWFsaXphdGlvbiBtYXAuXG4gKlxuICogICAgIHN1cGVyYWdlbnQuc2VyaWFsaXplWydhcHBsaWNhdGlvbi94bWwnXSA9IGZ1bmN0aW9uKG9iail7XG4gKiAgICAgICByZXR1cm4gJ2dlbmVyYXRlZCB4bWwgaGVyZSc7XG4gKiAgICAgfTtcbiAqXG4gKi9cblxucmVxdWVzdC5zZXJpYWxpemUgPSB7XG4gICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnOiBzZXJpYWxpemUsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogc2FmZVN0cmluZ2lmeVxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcnNlcnMuXG4gKlxuICogICAgIHN1cGVyYWdlbnQucGFyc2VbJ2FwcGxpY2F0aW9uL3htbCddID0gZnVuY3Rpb24oc3RyKXtcbiAqICAgICAgIHJldHVybiB7IG9iamVjdCBwYXJzZWQgZnJvbSBzdHIgfTtcbiAqICAgICB9O1xuICpcbiAqL1xuXG5yZXF1ZXN0LnBhcnNlID0ge1xuICAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJzogcGFyc2VTdHJpbmcsXG4gICdhcHBsaWNhdGlvbi9qc29uJzogSlNPTi5wYXJzZVxufTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gaGVhZGVyIGBzdHJgIGludG9cbiAqIGFuIG9iamVjdCBjb250YWluaW5nIHRoZSBtYXBwZWQgZmllbGRzLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHJcbiAqIEByZXR1cm4ge09iamVjdH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cbmZ1bmN0aW9uIHBhcnNlSGVhZGVyKHN0cikge1xuICBjb25zdCBsaW5lcyA9IHN0ci5zcGxpdCgvXFxyP1xcbi8pO1xuICBjb25zdCBmaWVsZHMgPSB7fTtcbiAgbGV0IGluZGV4O1xuICBsZXQgbGluZTtcbiAgbGV0IGZpZWxkO1xuICBsZXQgdmFsO1xuXG4gIGZvciAobGV0IGkgPSAwLCBsZW4gPSBsaW5lcy5sZW5ndGg7IGkgPCBsZW47ICsraSkge1xuICAgIGxpbmUgPSBsaW5lc1tpXTtcbiAgICBpbmRleCA9IGxpbmUuaW5kZXhPZignOicpO1xuICAgIGlmIChpbmRleCA9PT0gLTEpIHtcbiAgICAgIC8vIGNvdWxkIGJlIGVtcHR5IGxpbmUsIGp1c3Qgc2tpcCBpdFxuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgZmllbGQgPSBsaW5lLnNsaWNlKDAsIGluZGV4KS50b0xvd2VyQ2FzZSgpO1xuICAgIHZhbCA9IHRyaW0obGluZS5zbGljZShpbmRleCArIDEpKTtcbiAgICBmaWVsZHNbZmllbGRdID0gdmFsO1xuICB9XG5cbiAgcmV0dXJuIGZpZWxkcztcbn1cblxuLyoqXG4gKiBDaGVjayBpZiBgbWltZWAgaXMganNvbiBvciBoYXMgK2pzb24gc3RydWN0dXJlZCBzeW50YXggc3VmZml4LlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBtaW1lXG4gKiBAcmV0dXJuIHtCb29sZWFufVxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gaXNKU09OKG1pbWUpIHtcbiAgLy8gc2hvdWxkIG1hdGNoIC9qc29uIG9yICtqc29uXG4gIC8vIGJ1dCBub3QgL2pzb24tc2VxXG4gIHJldHVybiAvWy8rXWpzb24oJHxbXi1cXHddKS8udGVzdChtaW1lKTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXNwb25zZWAgd2l0aCB0aGUgZ2l2ZW4gYHhocmAuXG4gKlxuICogIC0gc2V0IGZsYWdzICgub2ssIC5lcnJvciwgZXRjKVxuICogIC0gcGFyc2UgaGVhZGVyXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogIEFsaWFzaW5nIGBzdXBlcmFnZW50YCBhcyBgcmVxdWVzdGAgaXMgbmljZTpcbiAqXG4gKiAgICAgIHJlcXVlc3QgPSBzdXBlcmFnZW50O1xuICpcbiAqICBXZSBjYW4gdXNlIHRoZSBwcm9taXNlLWxpa2UgQVBJLCBvciBwYXNzIGNhbGxiYWNrczpcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJykuZW5kKGZ1bmN0aW9uKHJlcyl7fSk7XG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvJywgZnVuY3Rpb24ocmVzKXt9KTtcbiAqXG4gKiAgU2VuZGluZyBkYXRhIGNhbiBiZSBjaGFpbmVkOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqICBPciBwYXNzZWQgdG8gYC5zZW5kKClgOlxuICpcbiAqICAgICAgcmVxdWVzdFxuICogICAgICAgIC5wb3N0KCcvdXNlcicpXG4gKiAgICAgICAgLnNlbmQoeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogIE9yIHBhc3NlZCB0byBgLnBvc3QoKWA6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0pXG4gKiAgICAgICAgLmVuZChmdW5jdGlvbihyZXMpe30pO1xuICpcbiAqIE9yIGZ1cnRoZXIgcmVkdWNlZCB0byBhIHNpbmdsZSBjYWxsIGZvciBzaW1wbGUgY2FzZXM6XG4gKlxuICogICAgICByZXF1ZXN0XG4gKiAgICAgICAgLnBvc3QoJy91c2VyJywgeyBuYW1lOiAndGonIH0sIGZ1bmN0aW9uKHJlcyl7fSk7XG4gKlxuICogQHBhcmFtIHtYTUxIVFRQUmVxdWVzdH0geGhyXG4gKiBAcGFyYW0ge09iamVjdH0gb3B0aW9uc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuZnVuY3Rpb24gUmVzcG9uc2UocmVxKSB7XG4gIHRoaXMucmVxID0gcmVxO1xuICB0aGlzLnhociA9IHRoaXMucmVxLnhocjtcbiAgLy8gcmVzcG9uc2VUZXh0IGlzIGFjY2Vzc2libGUgb25seSBpZiByZXNwb25zZVR5cGUgaXMgJycgb3IgJ3RleHQnIGFuZCBvbiBvbGRlciBicm93c2Vyc1xuICB0aGlzLnRleHQgPVxuICAgICh0aGlzLnJlcS5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgICAgKHRoaXMueGhyLnJlc3BvbnNlVHlwZSA9PT0gJycgfHwgdGhpcy54aHIucmVzcG9uc2VUeXBlID09PSAndGV4dCcpKSB8fFxuICAgIHR5cGVvZiB0aGlzLnhoci5yZXNwb25zZVR5cGUgPT09ICd1bmRlZmluZWQnXG4gICAgICA/IHRoaXMueGhyLnJlc3BvbnNlVGV4dFxuICAgICAgOiBudWxsO1xuICB0aGlzLnN0YXR1c1RleHQgPSB0aGlzLnJlcS54aHIuc3RhdHVzVGV4dDtcbiAgbGV0IHsgc3RhdHVzIH0gPSB0aGlzLnhocjtcbiAgLy8gaGFuZGxlIElFOSBidWc6IGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTAwNDY5NzIvbXNpZS1yZXR1cm5zLXN0YXR1cy1jb2RlLW9mLTEyMjMtZm9yLWFqYXgtcmVxdWVzdFxuICBpZiAoc3RhdHVzID09PSAxMjIzKSB7XG4gICAgc3RhdHVzID0gMjA0O1xuICB9XG5cbiAgdGhpcy5fc2V0U3RhdHVzUHJvcGVydGllcyhzdGF0dXMpO1xuICB0aGlzLmhlYWRlcnMgPSBwYXJzZUhlYWRlcih0aGlzLnhoci5nZXRBbGxSZXNwb25zZUhlYWRlcnMoKSk7XG4gIHRoaXMuaGVhZGVyID0gdGhpcy5oZWFkZXJzO1xuICAvLyBnZXRBbGxSZXNwb25zZUhlYWRlcnMgc29tZXRpbWVzIGZhbHNlbHkgcmV0dXJucyBcIlwiIGZvciBDT1JTIHJlcXVlc3RzLCBidXRcbiAgLy8gZ2V0UmVzcG9uc2VIZWFkZXIgc3RpbGwgd29ya3MuIHNvIHdlIGdldCBjb250ZW50LXR5cGUgZXZlbiBpZiBnZXR0aW5nXG4gIC8vIG90aGVyIGhlYWRlcnMgZmFpbHMuXG4gIHRoaXMuaGVhZGVyWydjb250ZW50LXR5cGUnXSA9IHRoaXMueGhyLmdldFJlc3BvbnNlSGVhZGVyKCdjb250ZW50LXR5cGUnKTtcbiAgdGhpcy5fc2V0SGVhZGVyUHJvcGVydGllcyh0aGlzLmhlYWRlcik7XG5cbiAgaWYgKHRoaXMudGV4dCA9PT0gbnVsbCAmJiByZXEuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHRoaXMuYm9keSA9IHRoaXMueGhyLnJlc3BvbnNlO1xuICB9IGVsc2Uge1xuICAgIHRoaXMuYm9keSA9XG4gICAgICB0aGlzLnJlcS5tZXRob2QgPT09ICdIRUFEJ1xuICAgICAgICA/IG51bGxcbiAgICAgICAgOiB0aGlzLl9wYXJzZUJvZHkodGhpcy50ZXh0ID8gdGhpcy50ZXh0IDogdGhpcy54aHIucmVzcG9uc2UpO1xuICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXNwb25zZUJhc2UoUmVzcG9uc2UucHJvdG90eXBlKTtcblxuLyoqXG4gKiBQYXJzZSB0aGUgZ2l2ZW4gYm9keSBgc3RyYC5cbiAqXG4gKiBVc2VkIGZvciBhdXRvLXBhcnNpbmcgb2YgYm9kaWVzLiBQYXJzZXJzXG4gKiBhcmUgZGVmaW5lZCBvbiB0aGUgYHN1cGVyYWdlbnQucGFyc2VgIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gc3RyXG4gKiBAcmV0dXJuIHtNaXhlZH1cbiAqIEBhcGkgcHJpdmF0ZVxuICovXG5cblJlc3BvbnNlLnByb3RvdHlwZS5fcGFyc2VCb2R5ID0gZnVuY3Rpb24oc3RyKSB7XG4gIGxldCBwYXJzZSA9IHJlcXVlc3QucGFyc2VbdGhpcy50eXBlXTtcbiAgaWYgKHRoaXMucmVxLl9wYXJzZXIpIHtcbiAgICByZXR1cm4gdGhpcy5yZXEuX3BhcnNlcih0aGlzLCBzdHIpO1xuICB9XG5cbiAgaWYgKCFwYXJzZSAmJiBpc0pTT04odGhpcy50eXBlKSkge1xuICAgIHBhcnNlID0gcmVxdWVzdC5wYXJzZVsnYXBwbGljYXRpb24vanNvbiddO1xuICB9XG5cbiAgcmV0dXJuIHBhcnNlICYmIHN0ciAmJiAoc3RyLmxlbmd0aCA+IDAgfHwgc3RyIGluc3RhbmNlb2YgT2JqZWN0KVxuICAgID8gcGFyc2Uoc3RyKVxuICAgIDogbnVsbDtcbn07XG5cbi8qKlxuICogUmV0dXJuIGFuIGBFcnJvcmAgcmVwcmVzZW50YXRpdmUgb2YgdGhpcyByZXNwb25zZS5cbiAqXG4gKiBAcmV0dXJuIHtFcnJvcn1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVzcG9uc2UucHJvdG90eXBlLnRvRXJyb3IgPSBmdW5jdGlvbigpIHtcbiAgY29uc3QgeyByZXEgfSA9IHRoaXM7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSByZXE7XG4gIGNvbnN0IHsgdXJsIH0gPSByZXE7XG5cbiAgY29uc3QgbXNnID0gYGNhbm5vdCAke21ldGhvZH0gJHt1cmx9ICgke3RoaXMuc3RhdHVzfSlgO1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IobXNnKTtcbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gbWV0aG9kO1xuICBlcnIudXJsID0gdXJsO1xuXG4gIHJldHVybiBlcnI7XG59O1xuXG4vKipcbiAqIEV4cG9zZSBgUmVzcG9uc2VgLlxuICovXG5cbnJlcXVlc3QuUmVzcG9uc2UgPSBSZXNwb25zZTtcblxuLyoqXG4gKiBJbml0aWFsaXplIGEgbmV3IGBSZXF1ZXN0YCB3aXRoIHRoZSBnaXZlbiBgbWV0aG9kYCBhbmQgYHVybGAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IG1ldGhvZFxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5mdW5jdGlvbiBSZXF1ZXN0KG1ldGhvZCwgdXJsKSB7XG4gIGNvbnN0IHNlbGYgPSB0aGlzO1xuICB0aGlzLl9xdWVyeSA9IHRoaXMuX3F1ZXJ5IHx8IFtdO1xuICB0aGlzLm1ldGhvZCA9IG1ldGhvZDtcbiAgdGhpcy51cmwgPSB1cmw7XG4gIHRoaXMuaGVhZGVyID0ge307IC8vIHByZXNlcnZlcyBoZWFkZXIgbmFtZSBjYXNlXG4gIHRoaXMuX2hlYWRlciA9IHt9OyAvLyBjb2VyY2VzIGhlYWRlciBuYW1lcyB0byBsb3dlcmNhc2VcbiAgdGhpcy5vbignZW5kJywgKCkgPT4ge1xuICAgIGxldCBlcnIgPSBudWxsO1xuICAgIGxldCByZXMgPSBudWxsO1xuXG4gICAgdHJ5IHtcbiAgICAgIHJlcyA9IG5ldyBSZXNwb25zZShzZWxmKTtcbiAgICB9IGNhdGNoIChlcnJfKSB7XG4gICAgICBlcnIgPSBuZXcgRXJyb3IoJ1BhcnNlciBpcyB1bmFibGUgdG8gcGFyc2UgdGhlIHJlc3BvbnNlJyk7XG4gICAgICBlcnIucGFyc2UgPSB0cnVlO1xuICAgICAgZXJyLm9yaWdpbmFsID0gZXJyXztcbiAgICAgIC8vIGlzc3VlICM2NzU6IHJldHVybiB0aGUgcmF3IHJlc3BvbnNlIGlmIHRoZSByZXNwb25zZSBwYXJzaW5nIGZhaWxzXG4gICAgICBpZiAoc2VsZi54aHIpIHtcbiAgICAgICAgLy8gaWU5IGRvZXNuJ3QgaGF2ZSAncmVzcG9uc2UnIHByb3BlcnR5XG4gICAgICAgIGVyci5yYXdSZXNwb25zZSA9XG4gICAgICAgICAgdHlwZW9mIHNlbGYueGhyLnJlc3BvbnNlVHlwZSA9PT0gJ3VuZGVmaW5lZCdcbiAgICAgICAgICAgID8gc2VsZi54aHIucmVzcG9uc2VUZXh0XG4gICAgICAgICAgICA6IHNlbGYueGhyLnJlc3BvbnNlO1xuICAgICAgICAvLyBpc3N1ZSAjODc2OiByZXR1cm4gdGhlIGh0dHAgc3RhdHVzIGNvZGUgaWYgdGhlIHJlc3BvbnNlIHBhcnNpbmcgZmFpbHNcbiAgICAgICAgZXJyLnN0YXR1cyA9IHNlbGYueGhyLnN0YXR1cyA/IHNlbGYueGhyLnN0YXR1cyA6IG51bGw7XG4gICAgICAgIGVyci5zdGF0dXNDb2RlID0gZXJyLnN0YXR1czsgLy8gYmFja3dhcmRzLWNvbXBhdCBvbmx5XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBlcnIucmF3UmVzcG9uc2UgPSBudWxsO1xuICAgICAgICBlcnIuc3RhdHVzID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNlbGYuY2FsbGJhY2soZXJyKTtcbiAgICB9XG5cbiAgICBzZWxmLmVtaXQoJ3Jlc3BvbnNlJywgcmVzKTtcblxuICAgIGxldCBuZXdfZXJyO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXNlbGYuX2lzUmVzcG9uc2VPSyhyZXMpKSB7XG4gICAgICAgIG5ld19lcnIgPSBuZXcgRXJyb3IoXG4gICAgICAgICAgcmVzLnN0YXR1c1RleHQgfHwgcmVzLnRleHQgfHwgJ1Vuc3VjY2Vzc2Z1bCBIVFRQIHJlc3BvbnNlJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycl8pIHtcbiAgICAgIG5ld19lcnIgPSBlcnJfOyAvLyBvaygpIGNhbGxiYWNrIGNhbiB0aHJvd1xuICAgIH1cblxuICAgIC8vICMxMDAwIGRvbid0IGNhdGNoIGVycm9ycyBmcm9tIHRoZSBjYWxsYmFjayB0byBhdm9pZCBkb3VibGUgY2FsbGluZyBpdFxuICAgIGlmIChuZXdfZXJyKSB7XG4gICAgICBuZXdfZXJyLm9yaWdpbmFsID0gZXJyO1xuICAgICAgbmV3X2Vyci5yZXNwb25zZSA9IHJlcztcbiAgICAgIG5ld19lcnIuc3RhdHVzID0gcmVzLnN0YXR1cztcbiAgICAgIHNlbGYuY2FsbGJhY2sobmV3X2VyciwgcmVzKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2VsZi5jYWxsYmFjayhudWxsLCByZXMpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogTWl4aW4gYEVtaXR0ZXJgIGFuZCBgUmVxdWVzdEJhc2VgLlxuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5FbWl0dGVyKFJlcXVlc3QucHJvdG90eXBlKTtcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuZXctY2FwXG5SZXF1ZXN0QmFzZShSZXF1ZXN0LnByb3RvdHlwZSk7XG5cbi8qKlxuICogU2V0IENvbnRlbnQtVHlwZSB0byBgdHlwZWAsIG1hcHBpbmcgdmFsdWVzIGZyb20gYHJlcXVlc3QudHlwZXNgLlxuICpcbiAqIEV4YW1wbGVzOlxuICpcbiAqICAgICAgc3VwZXJhZ2VudC50eXBlcy54bWwgPSAnYXBwbGljYXRpb24veG1sJztcbiAqXG4gKiAgICAgIHJlcXVlc3QucG9zdCgnLycpXG4gKiAgICAgICAgLnR5cGUoJ3htbCcpXG4gKiAgICAgICAgLnNlbmQoeG1sc3RyaW5nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5wb3N0KCcvJylcbiAqICAgICAgICAudHlwZSgnYXBwbGljYXRpb24veG1sJylcbiAqICAgICAgICAuc2VuZCh4bWxzdHJpbmcpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHR5cGVcbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS50eXBlID0gZnVuY3Rpb24odHlwZSkge1xuICB0aGlzLnNldCgnQ29udGVudC1UeXBlJywgcmVxdWVzdC50eXBlc1t0eXBlXSB8fCB0eXBlKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFNldCBBY2NlcHQgdG8gYHR5cGVgLCBtYXBwaW5nIHZhbHVlcyBmcm9tIGByZXF1ZXN0LnR5cGVzYC5cbiAqXG4gKiBFeGFtcGxlczpcbiAqXG4gKiAgICAgIHN1cGVyYWdlbnQudHlwZXMuanNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJztcbiAqXG4gKiAgICAgIHJlcXVlc3QuZ2V0KCcvYWdlbnQnKVxuICogICAgICAgIC5hY2NlcHQoJ2pzb24nKVxuICogICAgICAgIC5lbmQoY2FsbGJhY2spO1xuICpcbiAqICAgICAgcmVxdWVzdC5nZXQoJy9hZ2VudCcpXG4gKiAgICAgICAgLmFjY2VwdCgnYXBwbGljYXRpb24vanNvbicpXG4gKiAgICAgICAgLmVuZChjYWxsYmFjayk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IGFjY2VwdFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmFjY2VwdCA9IGZ1bmN0aW9uKHR5cGUpIHtcbiAgdGhpcy5zZXQoJ0FjY2VwdCcsIHJlcXVlc3QudHlwZXNbdHlwZV0gfHwgdHlwZSk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuLyoqXG4gKiBTZXQgQXV0aG9yaXphdGlvbiBmaWVsZCB2YWx1ZSB3aXRoIGB1c2VyYCBhbmQgYHBhc3NgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1c2VyXG4gKiBAcGFyYW0ge1N0cmluZ30gW3Bhc3NdIG9wdGlvbmFsIGluIGNhc2Ugb2YgdXNpbmcgJ2JlYXJlcicgYXMgdHlwZVxuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMgd2l0aCAndHlwZScgcHJvcGVydHkgJ2F1dG8nLCAnYmFzaWMnIG9yICdiZWFyZXInIChkZWZhdWx0ICdiYXNpYycpXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fSBmb3IgY2hhaW5pbmdcbiAqIEBhcGkgcHVibGljXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuYXV0aCA9IGZ1bmN0aW9uKHVzZXIsIHBhc3MsIG9wdGlvbnMpIHtcbiAgaWYgKGFyZ3VtZW50cy5sZW5ndGggPT09IDEpIHBhc3MgPSAnJztcbiAgaWYgKHR5cGVvZiBwYXNzID09PSAnb2JqZWN0JyAmJiBwYXNzICE9PSBudWxsKSB7XG4gICAgLy8gcGFzcyBpcyBvcHRpb25hbCBhbmQgY2FuIGJlIHJlcGxhY2VkIHdpdGggb3B0aW9uc1xuICAgIG9wdGlvbnMgPSBwYXNzO1xuICAgIHBhc3MgPSAnJztcbiAgfVxuXG4gIGlmICghb3B0aW9ucykge1xuICAgIG9wdGlvbnMgPSB7XG4gICAgICB0eXBlOiB0eXBlb2YgYnRvYSA9PT0gJ2Z1bmN0aW9uJyA/ICdiYXNpYycgOiAnYXV0bydcbiAgICB9O1xuICB9XG5cbiAgY29uc3QgZW5jb2RlciA9IHN0cmluZyA9PiB7XG4gICAgaWYgKHR5cGVvZiBidG9hID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYnRvYShzdHJpbmcpO1xuICAgIH1cblxuICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IHVzZSBiYXNpYyBhdXRoLCBidG9hIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gIH07XG5cbiAgcmV0dXJuIHRoaXMuX2F1dGgodXNlciwgcGFzcywgb3B0aW9ucywgZW5jb2Rlcik7XG59O1xuXG4vKipcbiAqIEFkZCBxdWVyeS1zdHJpbmcgYHZhbGAuXG4gKlxuICogRXhhbXBsZXM6XG4gKlxuICogICByZXF1ZXN0LmdldCgnL3Nob2VzJylcbiAqICAgICAucXVlcnkoJ3NpemU9MTAnKVxuICogICAgIC5xdWVyeSh7IGNvbG9yOiAnYmx1ZScgfSlcbiAqXG4gKiBAcGFyYW0ge09iamVjdHxTdHJpbmd9IHZhbFxuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLnF1ZXJ5ID0gZnVuY3Rpb24odmFsKSB7XG4gIGlmICh0eXBlb2YgdmFsICE9PSAnc3RyaW5nJykgdmFsID0gc2VyaWFsaXplKHZhbCk7XG4gIGlmICh2YWwpIHRoaXMuX3F1ZXJ5LnB1c2godmFsKTtcbiAgcmV0dXJuIHRoaXM7XG59O1xuXG4vKipcbiAqIFF1ZXVlIHRoZSBnaXZlbiBgZmlsZWAgYXMgYW4gYXR0YWNobWVudCB0byB0aGUgc3BlY2lmaWVkIGBmaWVsZGAsXG4gKiB3aXRoIG9wdGlvbmFsIGBvcHRpb25zYCAob3IgZmlsZW5hbWUpLlxuICpcbiAqIGBgYCBqc1xuICogcmVxdWVzdC5wb3N0KCcvdXBsb2FkJylcbiAqICAgLmF0dGFjaCgnY29udGVudCcsIG5ldyBCbG9iKFsnPGEgaWQ9XCJhXCI+PGIgaWQ9XCJiXCI+aGV5ITwvYj48L2E+J10sIHsgdHlwZTogXCJ0ZXh0L2h0bWxcIn0pKVxuICogICAuZW5kKGNhbGxiYWNrKTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBmaWVsZFxuICogQHBhcmFtIHtCbG9ifEZpbGV9IGZpbGVcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gb3B0aW9uc1xuICogQHJldHVybiB7UmVxdWVzdH0gZm9yIGNoYWluaW5nXG4gKiBAYXBpIHB1YmxpY1xuICovXG5cblJlcXVlc3QucHJvdG90eXBlLmF0dGFjaCA9IGZ1bmN0aW9uKGZpZWxkLCBmaWxlLCBvcHRpb25zKSB7XG4gIGlmIChmaWxlKSB7XG4gICAgaWYgKHRoaXMuX2RhdGEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInN1cGVyYWdlbnQgY2FuJ3QgbWl4IC5zZW5kKCkgYW5kIC5hdHRhY2goKVwiKTtcbiAgICB9XG5cbiAgICB0aGlzLl9nZXRGb3JtRGF0YSgpLmFwcGVuZChmaWVsZCwgZmlsZSwgb3B0aW9ucyB8fCBmaWxlLm5hbWUpO1xuICB9XG5cbiAgcmV0dXJuIHRoaXM7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5fZ2V0Rm9ybURhdGEgPSBmdW5jdGlvbigpIHtcbiAgaWYgKCF0aGlzLl9mb3JtRGF0YSkge1xuICAgIHRoaXMuX2Zvcm1EYXRhID0gbmV3IHJvb3QuRm9ybURhdGEoKTtcbiAgfVxuXG4gIHJldHVybiB0aGlzLl9mb3JtRGF0YTtcbn07XG5cbi8qKlxuICogSW52b2tlIHRoZSBjYWxsYmFjayB3aXRoIGBlcnJgIGFuZCBgcmVzYFxuICogYW5kIGhhbmRsZSBhcml0eSBjaGVjay5cbiAqXG4gKiBAcGFyYW0ge0Vycm9yfSBlcnJcbiAqIEBwYXJhbSB7UmVzcG9uc2V9IHJlc1xuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY2FsbGJhY2sgPSBmdW5jdGlvbihlcnIsIHJlcykge1xuICBpZiAodGhpcy5fc2hvdWxkUmV0cnkoZXJyLCByZXMpKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JldHJ5KCk7XG4gIH1cblxuICBjb25zdCBmbiA9IHRoaXMuX2NhbGxiYWNrO1xuICB0aGlzLmNsZWFyVGltZW91dCgpO1xuXG4gIGlmIChlcnIpIHtcbiAgICBpZiAodGhpcy5fbWF4UmV0cmllcykgZXJyLnJldHJpZXMgPSB0aGlzLl9yZXRyaWVzIC0gMTtcbiAgICB0aGlzLmVtaXQoJ2Vycm9yJywgZXJyKTtcbiAgfVxuXG4gIGZuKGVyciwgcmVzKTtcbn07XG5cbi8qKlxuICogSW52b2tlIGNhbGxiYWNrIHdpdGggeC1kb21haW4gZXJyb3IuXG4gKlxuICogQGFwaSBwcml2YXRlXG4gKi9cblxuUmVxdWVzdC5wcm90b3R5cGUuY3Jvc3NEb21haW5FcnJvciA9IGZ1bmN0aW9uKCkge1xuICBjb25zdCBlcnIgPSBuZXcgRXJyb3IoXG4gICAgJ1JlcXVlc3QgaGFzIGJlZW4gdGVybWluYXRlZFxcblBvc3NpYmxlIGNhdXNlczogdGhlIG5ldHdvcmsgaXMgb2ZmbGluZSwgT3JpZ2luIGlzIG5vdCBhbGxvd2VkIGJ5IEFjY2Vzcy1Db250cm9sLUFsbG93LU9yaWdpbiwgdGhlIHBhZ2UgaXMgYmVpbmcgdW5sb2FkZWQsIGV0Yy4nXG4gICk7XG4gIGVyci5jcm9zc0RvbWFpbiA9IHRydWU7XG5cbiAgZXJyLnN0YXR1cyA9IHRoaXMuc3RhdHVzO1xuICBlcnIubWV0aG9kID0gdGhpcy5tZXRob2Q7XG4gIGVyci51cmwgPSB0aGlzLnVybDtcblxuICB0aGlzLmNhbGxiYWNrKGVycik7XG59O1xuXG4vLyBUaGlzIG9ubHkgd2FybnMsIGJlY2F1c2UgdGhlIHJlcXVlc3QgaXMgc3RpbGwgbGlrZWx5IHRvIHdvcmtcblJlcXVlc3QucHJvdG90eXBlLmFnZW50ID0gZnVuY3Rpb24oKSB7XG4gIGNvbnNvbGUud2FybignVGhpcyBpcyBub3Qgc3VwcG9ydGVkIGluIGJyb3dzZXIgdmVyc2lvbiBvZiBzdXBlcmFnZW50Jyk7XG4gIHJldHVybiB0aGlzO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuY2EgPSBSZXF1ZXN0LnByb3RvdHlwZS5hZ2VudDtcblJlcXVlc3QucHJvdG90eXBlLmJ1ZmZlciA9IFJlcXVlc3QucHJvdG90eXBlLmNhO1xuXG4vLyBUaGlzIHRocm93cywgYmVjYXVzZSBpdCBjYW4ndCBzZW5kL3JlY2VpdmUgZGF0YSBhcyBleHBlY3RlZFxuUmVxdWVzdC5wcm90b3R5cGUud3JpdGUgPSAoKSA9PiB7XG4gIHRocm93IG5ldyBFcnJvcihcbiAgICAnU3RyZWFtaW5nIGlzIG5vdCBzdXBwb3J0ZWQgaW4gYnJvd3NlciB2ZXJzaW9uIG9mIHN1cGVyYWdlbnQnXG4gICk7XG59O1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5waXBlID0gUmVxdWVzdC5wcm90b3R5cGUud3JpdGU7XG5cbi8qKlxuICogQ2hlY2sgaWYgYG9iamAgaXMgYSBob3N0IG9iamVjdCxcbiAqIHdlIGRvbid0IHdhbnQgdG8gc2VyaWFsaXplIHRoZXNlIDopXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IG9iaiBob3N0IG9iamVjdFxuICogQHJldHVybiB7Qm9vbGVhbn0gaXMgYSBob3N0IG9iamVjdFxuICogQGFwaSBwcml2YXRlXG4gKi9cblJlcXVlc3QucHJvdG90eXBlLl9pc0hvc3QgPSBmdW5jdGlvbihvYmopIHtcbiAgLy8gTmF0aXZlIG9iamVjdHMgc3RyaW5naWZ5IHRvIFtvYmplY3QgRmlsZV0sIFtvYmplY3QgQmxvYl0sIFtvYmplY3QgRm9ybURhdGFdLCBldGMuXG4gIHJldHVybiAoXG4gICAgb2JqICYmXG4gICAgdHlwZW9mIG9iaiA9PT0gJ29iamVjdCcgJiZcbiAgICAhQXJyYXkuaXNBcnJheShvYmopICYmXG4gICAgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKG9iaikgIT09ICdbb2JqZWN0IE9iamVjdF0nXG4gICk7XG59O1xuXG4vKipcbiAqIEluaXRpYXRlIHJlcXVlc3QsIGludm9raW5nIGNhbGxiYWNrIGBmbihyZXMpYFxuICogd2l0aCBhbiBpbnN0YW5jZW9mIGBSZXNwb25zZWAuXG4gKlxuICogQHBhcmFtIHtGdW5jdGlvbn0gZm5cbiAqIEByZXR1cm4ge1JlcXVlc3R9IGZvciBjaGFpbmluZ1xuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5SZXF1ZXN0LnByb3RvdHlwZS5lbmQgPSBmdW5jdGlvbihmbikge1xuICBpZiAodGhpcy5fZW5kQ2FsbGVkKSB7XG4gICAgY29uc29sZS53YXJuKFxuICAgICAgJ1dhcm5pbmc6IC5lbmQoKSB3YXMgY2FsbGVkIHR3aWNlLiBUaGlzIGlzIG5vdCBzdXBwb3J0ZWQgaW4gc3VwZXJhZ2VudCdcbiAgICApO1xuICB9XG5cbiAgdGhpcy5fZW5kQ2FsbGVkID0gdHJ1ZTtcblxuICAvLyBzdG9yZSBjYWxsYmFja1xuICB0aGlzLl9jYWxsYmFjayA9IGZuIHx8IG5vb3A7XG5cbiAgLy8gcXVlcnlzdHJpbmdcbiAgdGhpcy5fZmluYWxpemVRdWVyeVN0cmluZygpO1xuXG4gIHRoaXMuX2VuZCgpO1xufTtcblxuUmVxdWVzdC5wcm90b3R5cGUuX3NldFVwbG9hZFRpbWVvdXQgPSBmdW5jdGlvbigpIHtcbiAgY29uc3Qgc2VsZiA9IHRoaXM7XG5cbiAgLy8gdXBsb2FkIHRpbWVvdXQgaXQncyB3b2tycyBvbmx5IGlmIGRlYWRsaW5lIHRpbWVvdXQgaXMgb2ZmXG4gIGlmICh0aGlzLl91cGxvYWRUaW1lb3V0ICYmICF0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIpIHtcbiAgICB0aGlzLl91cGxvYWRUaW1lb3V0VGltZXIgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNlbGYuX3RpbWVvdXRFcnJvcihcbiAgICAgICAgJ1VwbG9hZCB0aW1lb3V0IG9mICcsXG4gICAgICAgIHNlbGYuX3VwbG9hZFRpbWVvdXQsXG4gICAgICAgICdFVElNRURPVVQnXG4gICAgICApO1xuICAgIH0sIHRoaXMuX3VwbG9hZFRpbWVvdXQpO1xuICB9XG59O1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29tcGxleGl0eVxuUmVxdWVzdC5wcm90b3R5cGUuX2VuZCA9IGZ1bmN0aW9uKCkge1xuICBpZiAodGhpcy5fYWJvcnRlZClcbiAgICByZXR1cm4gdGhpcy5jYWxsYmFjayhcbiAgICAgIG5ldyBFcnJvcignVGhlIHJlcXVlc3QgaGFzIGJlZW4gYWJvcnRlZCBldmVuIGJlZm9yZSAuZW5kKCkgd2FzIGNhbGxlZCcpXG4gICAgKTtcblxuICBjb25zdCBzZWxmID0gdGhpcztcbiAgdGhpcy54aHIgPSByZXF1ZXN0LmdldFhIUigpO1xuICBjb25zdCB7IHhociB9ID0gdGhpcztcbiAgbGV0IGRhdGEgPSB0aGlzLl9mb3JtRGF0YSB8fCB0aGlzLl9kYXRhO1xuXG4gIHRoaXMuX3NldFRpbWVvdXRzKCk7XG5cbiAgLy8gc3RhdGUgY2hhbmdlXG4gIHhoci5vbnJlYWR5c3RhdGVjaGFuZ2UgPSAoKSA9PiB7XG4gICAgY29uc3QgeyByZWFkeVN0YXRlIH0gPSB4aHI7XG4gICAgaWYgKHJlYWR5U3RhdGUgPj0gMiAmJiBzZWxmLl9yZXNwb25zZVRpbWVvdXRUaW1lcikge1xuICAgICAgY2xlYXJUaW1lb3V0KHNlbGYuX3Jlc3BvbnNlVGltZW91dFRpbWVyKTtcbiAgICB9XG5cbiAgICBpZiAocmVhZHlTdGF0ZSAhPT0gNCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIEluIElFOSwgcmVhZHMgdG8gYW55IHByb3BlcnR5IChlLmcuIHN0YXR1cykgb2ZmIG9mIGFuIGFib3J0ZWQgWEhSIHdpbGxcbiAgICAvLyByZXN1bHQgaW4gdGhlIGVycm9yIFwiQ291bGQgbm90IGNvbXBsZXRlIHRoZSBvcGVyYXRpb24gZHVlIHRvIGVycm9yIGMwMGMwMjNmXCJcbiAgICBsZXQgc3RhdHVzO1xuICAgIHRyeSB7XG4gICAgICBzdGF0dXMgPSB4aHIuc3RhdHVzO1xuICAgIH0gY2F0Y2gge1xuICAgICAgc3RhdHVzID0gMDtcbiAgICB9XG5cbiAgICBpZiAoIXN0YXR1cykge1xuICAgICAgaWYgKHNlbGYudGltZWRvdXQgfHwgc2VsZi5fYWJvcnRlZCkgcmV0dXJuO1xuICAgICAgcmV0dXJuIHNlbGYuY3Jvc3NEb21haW5FcnJvcigpO1xuICAgIH1cblxuICAgIHNlbGYuZW1pdCgnZW5kJyk7XG4gIH07XG5cbiAgLy8gcHJvZ3Jlc3NcbiAgY29uc3QgaGFuZGxlUHJvZ3Jlc3MgPSAoZGlyZWN0aW9uLCBlKSA9PiB7XG4gICAgaWYgKGUudG90YWwgPiAwKSB7XG4gICAgICBlLnBlcmNlbnQgPSAoZS5sb2FkZWQgLyBlLnRvdGFsKSAqIDEwMDtcblxuICAgICAgaWYgKGUucGVyY2VudCA9PT0gMTAwKSB7XG4gICAgICAgIGNsZWFyVGltZW91dChzZWxmLl91cGxvYWRUaW1lb3V0VGltZXIpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGUuZGlyZWN0aW9uID0gZGlyZWN0aW9uO1xuICAgIHNlbGYuZW1pdCgncHJvZ3Jlc3MnLCBlKTtcbiAgfTtcblxuICBpZiAodGhpcy5oYXNMaXN0ZW5lcnMoJ3Byb2dyZXNzJykpIHtcbiAgICB0cnkge1xuICAgICAgeGhyLmFkZEV2ZW50TGlzdGVuZXIoJ3Byb2dyZXNzJywgaGFuZGxlUHJvZ3Jlc3MuYmluZChudWxsLCAnZG93bmxvYWQnKSk7XG4gICAgICBpZiAoeGhyLnVwbG9hZCkge1xuICAgICAgICB4aHIudXBsb2FkLmFkZEV2ZW50TGlzdGVuZXIoXG4gICAgICAgICAgJ3Byb2dyZXNzJyxcbiAgICAgICAgICBoYW5kbGVQcm9ncmVzcy5iaW5kKG51bGwsICd1cGxvYWQnKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gQWNjZXNzaW5nIHhoci51cGxvYWQgZmFpbHMgaW4gSUUgZnJvbSBhIHdlYiB3b3JrZXIsIHNvIGp1c3QgcHJldGVuZCBpdCBkb2Vzbid0IGV4aXN0LlxuICAgICAgLy8gUmVwb3J0ZWQgaGVyZTpcbiAgICAgIC8vIGh0dHBzOi8vY29ubmVjdC5taWNyb3NvZnQuY29tL0lFL2ZlZWRiYWNrL2RldGFpbHMvODM3MjQ1L3htbGh0dHByZXF1ZXN0LXVwbG9hZC10aHJvd3MtaW52YWxpZC1hcmd1bWVudC13aGVuLXVzZWQtZnJvbS13ZWItd29ya2VyLWNvbnRleHRcbiAgICB9XG4gIH1cblxuICBpZiAoeGhyLnVwbG9hZCkge1xuICAgIHRoaXMuX3NldFVwbG9hZFRpbWVvdXQoKTtcbiAgfVxuXG4gIC8vIGluaXRpYXRlIHJlcXVlc3RcbiAgdHJ5IHtcbiAgICBpZiAodGhpcy51c2VybmFtZSAmJiB0aGlzLnBhc3N3b3JkKSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUsIHRoaXMudXNlcm5hbWUsIHRoaXMucGFzc3dvcmQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB4aHIub3Blbih0aGlzLm1ldGhvZCwgdGhpcy51cmwsIHRydWUpO1xuICAgIH1cbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgLy8gc2VlICMxMTQ5XG4gICAgcmV0dXJuIHRoaXMuY2FsbGJhY2soZXJyKTtcbiAgfVxuXG4gIC8vIENPUlNcbiAgaWYgKHRoaXMuX3dpdGhDcmVkZW50aWFscykgeGhyLndpdGhDcmVkZW50aWFscyA9IHRydWU7XG5cbiAgLy8gYm9keVxuICBpZiAoXG4gICAgIXRoaXMuX2Zvcm1EYXRhICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdHRVQnICYmXG4gICAgdGhpcy5tZXRob2QgIT09ICdIRUFEJyAmJlxuICAgIHR5cGVvZiBkYXRhICE9PSAnc3RyaW5nJyAmJlxuICAgICF0aGlzLl9pc0hvc3QoZGF0YSlcbiAgKSB7XG4gICAgLy8gc2VyaWFsaXplIHN0dWZmXG4gICAgY29uc3QgY29udGVudFR5cGUgPSB0aGlzLl9oZWFkZXJbJ2NvbnRlbnQtdHlwZSddO1xuICAgIGxldCBzZXJpYWxpemUgPVxuICAgICAgdGhpcy5fc2VyaWFsaXplciB8fFxuICAgICAgcmVxdWVzdC5zZXJpYWxpemVbY29udGVudFR5cGUgPyBjb250ZW50VHlwZS5zcGxpdCgnOycpWzBdIDogJyddO1xuICAgIGlmICghc2VyaWFsaXplICYmIGlzSlNPTihjb250ZW50VHlwZSkpIHtcbiAgICAgIHNlcmlhbGl6ZSA9IHJlcXVlc3Quc2VyaWFsaXplWydhcHBsaWNhdGlvbi9qc29uJ107XG4gICAgfVxuXG4gICAgaWYgKHNlcmlhbGl6ZSkgZGF0YSA9IHNlcmlhbGl6ZShkYXRhKTtcbiAgfVxuXG4gIC8vIHNldCBoZWFkZXIgZmllbGRzXG4gIGZvciAoY29uc3QgZmllbGQgaW4gdGhpcy5oZWFkZXIpIHtcbiAgICBpZiAodGhpcy5oZWFkZXJbZmllbGRdID09PSBudWxsKSBjb250aW51ZTtcblxuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodGhpcy5oZWFkZXIsIGZpZWxkKSlcbiAgICAgIHhoci5zZXRSZXF1ZXN0SGVhZGVyKGZpZWxkLCB0aGlzLmhlYWRlcltmaWVsZF0pO1xuICB9XG5cbiAgaWYgKHRoaXMuX3Jlc3BvbnNlVHlwZSkge1xuICAgIHhoci5yZXNwb25zZVR5cGUgPSB0aGlzLl9yZXNwb25zZVR5cGU7XG4gIH1cblxuICAvLyBzZW5kIHN0dWZmXG4gIHRoaXMuZW1pdCgncmVxdWVzdCcsIHRoaXMpO1xuXG4gIC8vIElFMTEgeGhyLnNlbmQodW5kZWZpbmVkKSBzZW5kcyAndW5kZWZpbmVkJyBzdHJpbmcgYXMgUE9TVCBwYXlsb2FkIChpbnN0ZWFkIG9mIG5vdGhpbmcpXG4gIC8vIFdlIG5lZWQgbnVsbCBoZXJlIGlmIGRhdGEgaXMgdW5kZWZpbmVkXG4gIHhoci5zZW5kKHR5cGVvZiBkYXRhID09PSAndW5kZWZpbmVkJyA/IG51bGwgOiBkYXRhKTtcbn07XG5cbnJlcXVlc3QuYWdlbnQgPSAoKSA9PiBuZXcgQWdlbnQoKTtcblxuWydHRVQnLCAnUE9TVCcsICdPUFRJT05TJywgJ1BBVENIJywgJ1BVVCcsICdERUxFVEUnXS5mb3JFYWNoKG1ldGhvZCA9PiB7XG4gIEFnZW50LnByb3RvdHlwZVttZXRob2QudG9Mb3dlckNhc2UoKV0gPSBmdW5jdGlvbih1cmwsIGZuKSB7XG4gICAgY29uc3QgcmVxID0gbmV3IHJlcXVlc3QuUmVxdWVzdChtZXRob2QsIHVybCk7XG4gICAgdGhpcy5fc2V0RGVmYXVsdHMocmVxKTtcbiAgICBpZiAoZm4pIHtcbiAgICAgIHJlcS5lbmQoZm4pO1xuICAgIH1cblxuICAgIHJldHVybiByZXE7XG4gIH07XG59KTtcblxuQWdlbnQucHJvdG90eXBlLmRlbCA9IEFnZW50LnByb3RvdHlwZS5kZWxldGU7XG5cbi8qKlxuICogR0VUIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5nZXQgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdHRVQnLCB1cmwpO1xuICBpZiAodHlwZW9mIGRhdGEgPT09ICdmdW5jdGlvbicpIHtcbiAgICBmbiA9IGRhdGE7XG4gICAgZGF0YSA9IG51bGw7XG4gIH1cblxuICBpZiAoZGF0YSkgcmVxLnF1ZXJ5KGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBIRUFEIGB1cmxgIHdpdGggb3B0aW9uYWwgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR8RnVuY3Rpb259IFtkYXRhXSBvciBmblxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5oZWFkID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnSEVBRCcsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEucXVlcnkoZGF0YSk7XG4gIGlmIChmbikgcmVxLmVuZChmbik7XG4gIHJldHVybiByZXE7XG59O1xuXG4vKipcbiAqIE9QVElPTlMgcXVlcnkgdG8gYHVybGAgd2l0aCBvcHRpb25hbCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZHxGdW5jdGlvbn0gW2RhdGFdIG9yIGZuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0Lm9wdGlvbnMgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdPUFRJT05TJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBERUxFVEUgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfSBbZGF0YV1cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbmZ1bmN0aW9uIGRlbCh1cmwsIGRhdGEsIGZuKSB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ0RFTEVURScsIHVybCk7XG4gIGlmICh0eXBlb2YgZGF0YSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGZuID0gZGF0YTtcbiAgICBkYXRhID0gbnVsbDtcbiAgfVxuXG4gIGlmIChkYXRhKSByZXEuc2VuZChkYXRhKTtcbiAgaWYgKGZuKSByZXEuZW5kKGZuKTtcbiAgcmV0dXJuIHJlcTtcbn1cblxucmVxdWVzdC5kZWwgPSBkZWw7XG5yZXF1ZXN0LmRlbGV0ZSA9IGRlbDtcblxuLyoqXG4gKiBQQVRDSCBgdXJsYCB3aXRoIG9wdGlvbmFsIGBkYXRhYCBhbmQgY2FsbGJhY2sgYGZuKHJlcylgLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB1cmxcbiAqIEBwYXJhbSB7TWl4ZWR9IFtkYXRhXVxuICogQHBhcmFtIHtGdW5jdGlvbn0gW2ZuXVxuICogQHJldHVybiB7UmVxdWVzdH1cbiAqIEBhcGkgcHVibGljXG4gKi9cblxucmVxdWVzdC5wYXRjaCA9ICh1cmwsIGRhdGEsIGZuKSA9PiB7XG4gIGNvbnN0IHJlcSA9IHJlcXVlc3QoJ1BBVENIJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQT1NUIGB1cmxgIHdpdGggb3B0aW9uYWwgYGRhdGFgIGFuZCBjYWxsYmFjayBgZm4ocmVzKWAuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHVybFxuICogQHBhcmFtIHtNaXhlZH0gW2RhdGFdXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBbZm5dXG4gKiBAcmV0dXJuIHtSZXF1ZXN0fVxuICogQGFwaSBwdWJsaWNcbiAqL1xuXG5yZXF1ZXN0LnBvc3QgPSAodXJsLCBkYXRhLCBmbikgPT4ge1xuICBjb25zdCByZXEgPSByZXF1ZXN0KCdQT1NUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcblxuLyoqXG4gKiBQVVQgYHVybGAgd2l0aCBvcHRpb25hbCBgZGF0YWAgYW5kIGNhbGxiYWNrIGBmbihyZXMpYC5cbiAqXG4gKiBAcGFyYW0ge1N0cmluZ30gdXJsXG4gKiBAcGFyYW0ge01peGVkfEZ1bmN0aW9ufSBbZGF0YV0gb3IgZm5cbiAqIEBwYXJhbSB7RnVuY3Rpb259IFtmbl1cbiAqIEByZXR1cm4ge1JlcXVlc3R9XG4gKiBAYXBpIHB1YmxpY1xuICovXG5cbnJlcXVlc3QucHV0ID0gKHVybCwgZGF0YSwgZm4pID0+IHtcbiAgY29uc3QgcmVxID0gcmVxdWVzdCgnUFVUJywgdXJsKTtcbiAgaWYgKHR5cGVvZiBkYXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZm4gPSBkYXRhO1xuICAgIGRhdGEgPSBudWxsO1xuICB9XG5cbiAgaWYgKGRhdGEpIHJlcS5zZW5kKGRhdGEpO1xuICBpZiAoZm4pIHJlcS5lbmQoZm4pO1xuICByZXR1cm4gcmVxO1xufTtcbiJdfQ==","import base64 from 'base64-js';\n\nfunction padding(str) {\n var mod = str.length % 4;\n var pad = 4 - mod;\n\n if (mod === 0) {\n return str;\n }\n\n return str + new Array(1 + pad).join('=');\n}\n\nfunction stringToByteArray(str) {\n var arr = new Array(str.length);\n for (var a = 0; a < str.length; a++) {\n arr[a] = str.charCodeAt(a);\n }\n return arr;\n}\n\nfunction byteArrayToString(array) {\n var result = '';\n for (var i = 0; i < array.length; i++) {\n result += String.fromCharCode(array[i]);\n }\n return result;\n}\n\nfunction encode(str) {\n return base64\n .fromByteArray(stringToByteArray(str))\n .replace(/\\+/g, '-') // Convert '+' to '-'\n .replace(/\\//g, '_'); // Convert '/' to '_'\n}\n\nfunction decode(str) {\n str = padding(str)\n .replace(/-/g, '+') // Convert '-' to '+'\n .replace(/_/g, '/'); // Convert '_' to '/'\n\n return byteArrayToString(base64.toByteArray(str));\n}\n\nexport default {\n encode: encode,\n decode: decode\n};\n","module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","/* eslint-disable no-param-reassign */\nimport request from 'superagent';\nimport base64Url from './base64_url';\nimport version from '../version';\nimport objectHelper from './object';\n\n// ------------------------------------------------ RequestWrapper\n\nfunction RequestWrapper(req) {\n this.request = req;\n this.method = req.method;\n this.url = req.url;\n this.body = req._data;\n this.headers = req._header;\n}\n\nRequestWrapper.prototype.abort = function() {\n this.request.abort();\n};\n\nRequestWrapper.prototype.getMethod = function() {\n return this.method;\n};\n\nRequestWrapper.prototype.getBody = function() {\n return this.body;\n};\n\nRequestWrapper.prototype.getUrl = function() {\n return this.url;\n};\n\nRequestWrapper.prototype.getHeaders = function() {\n return this.headers;\n};\n\n// ------------------------------------------------ RequestObj\n\nfunction RequestObj(req) {\n this.request = req;\n}\n\nRequestObj.prototype.set = function(key, value) {\n this.request = this.request.set(key, value);\n return this;\n};\n\nRequestObj.prototype.send = function(body) {\n this.request = this.request.send(objectHelper.trimUserDetails(body));\n return this;\n};\n\nRequestObj.prototype.withCredentials = function() {\n this.request = this.request.withCredentials();\n return this;\n};\n\nRequestObj.prototype.end = function(cb) {\n this.request.end(cb);\n return new RequestWrapper(this.request);\n};\n\n// ------------------------------------------------ RequestBuilder\n\nfunction RequestBuilder(options) {\n this._sendTelemetry =\n options._sendTelemetry === false ? options._sendTelemetry : true;\n this._telemetryInfo = options._telemetryInfo || null;\n this._timesToRetryFailedRequests = options._timesToRetryFailedRequests;\n this.headers = options.headers || {};\n this._universalLoginPage = options.universalLoginPage;\n}\n\nRequestBuilder.prototype.setCommonConfiguration = function(\n ongoingRequest,\n options\n) {\n options = options || {};\n\n if (this._timesToRetryFailedRequests > 0) {\n ongoingRequest = ongoingRequest.retry(this._timesToRetryFailedRequests);\n }\n\n if (options.noHeaders) {\n return ongoingRequest;\n }\n\n var headers = this.headers;\n ongoingRequest = ongoingRequest.set('Content-Type', 'application/json');\n\n var keys = Object.keys(this.headers);\n\n for (var a = 0; a < keys.length; a++) {\n ongoingRequest = ongoingRequest.set(keys[a], headers[keys[a]]);\n }\n\n if (this._sendTelemetry) {\n ongoingRequest = ongoingRequest.set(\n 'Auth0-Client',\n this.getTelemetryData()\n );\n }\n\n return ongoingRequest;\n};\n\nRequestBuilder.prototype.getTelemetryData = function() {\n var telemetryName = this._universalLoginPage ? 'auth0.js-ulp' : 'auth0.js';\n var clientInfo = { name: telemetryName, version: version.raw };\n if (this._telemetryInfo) {\n clientInfo = objectHelper.extend({}, this._telemetryInfo);\n clientInfo.env = objectHelper.extend({}, this._telemetryInfo.env);\n clientInfo.env[telemetryName] = version.raw;\n }\n var jsonClientInfo = JSON.stringify(clientInfo);\n return base64Url.encode(jsonClientInfo);\n};\n\nRequestBuilder.prototype.get = function(url, options) {\n return new RequestObj(this.setCommonConfiguration(request.get(url), options));\n};\n\nRequestBuilder.prototype.post = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.post(url), options)\n );\n};\n\nRequestBuilder.prototype.patch = function(url, options) {\n return new RequestObj(\n this.setCommonConfiguration(request.patch(url), options)\n );\n};\n\nexport default RequestBuilder;\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","function DummyStorage() {}\n\nDummyStorage.prototype.getItem = function() {\n return null;\n};\n\nDummyStorage.prototype.removeItem = function() {};\n\nDummyStorage.prototype.setItem = function() {};\n\nexport default DummyStorage;\n","/*!\n * JavaScript Cookie v2.2.1\n * https://github.com/js-cookie/js-cookie\n *\n * Copyright 2006, 2015 Klaus Hartl & Fagner Brack\n * Released under the MIT license\n */\n;(function (factory) {\n\tvar registeredInModuleLoader;\n\tif (typeof define === 'function' && define.amd) {\n\t\tdefine(factory);\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (typeof exports === 'object') {\n\t\tmodule.exports = factory();\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (!registeredInModuleLoader) {\n\t\tvar OldCookies = window.Cookies;\n\t\tvar api = window.Cookies = factory();\n\t\tapi.noConflict = function () {\n\t\t\twindow.Cookies = OldCookies;\n\t\t\treturn api;\n\t\t};\n\t}\n}(function () {\n\tfunction extend () {\n\t\tvar i = 0;\n\t\tvar result = {};\n\t\tfor (; i < arguments.length; i++) {\n\t\t\tvar attributes = arguments[ i ];\n\t\t\tfor (var key in attributes) {\n\t\t\t\tresult[key] = attributes[key];\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction decode (s) {\n\t\treturn s.replace(/(%[0-9A-Z]{2})+/g, decodeURIComponent);\n\t}\n\n\tfunction init (converter) {\n\t\tfunction api() {}\n\n\t\tfunction set (key, value, attributes) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tattributes = extend({\n\t\t\t\tpath: '/'\n\t\t\t}, api.defaults, attributes);\n\n\t\t\tif (typeof attributes.expires === 'number') {\n\t\t\t\tattributes.expires = new Date(new Date() * 1 + attributes.expires * 864e+5);\n\t\t\t}\n\n\t\t\t// We're using \"expires\" because \"max-age\" is not supported by IE\n\t\t\tattributes.expires = attributes.expires ? attributes.expires.toUTCString() : '';\n\n\t\t\ttry {\n\t\t\t\tvar result = JSON.stringify(value);\n\t\t\t\tif (/^[\\{\\[]/.test(result)) {\n\t\t\t\t\tvalue = result;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\n\t\t\tvalue = converter.write ?\n\t\t\t\tconverter.write(value, key) :\n\t\t\t\tencodeURIComponent(String(value))\n\t\t\t\t\t.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n\t\t\tkey = encodeURIComponent(String(key))\n\t\t\t\t.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n\t\t\t\t.replace(/[\\(\\)]/g, escape);\n\n\t\t\tvar stringifiedAttributes = '';\n\t\t\tfor (var attributeName in attributes) {\n\t\t\t\tif (!attributes[attributeName]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tstringifiedAttributes += '; ' + attributeName;\n\t\t\t\tif (attributes[attributeName] === true) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Considers RFC 6265 section 5.2:\n\t\t\t\t// ...\n\t\t\t\t// 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n\t\t\t\t// character:\n\t\t\t\t// Consume the characters of the unparsed-attributes up to,\n\t\t\t\t// not including, the first %x3B (\";\") character.\n\t\t\t\t// ...\n\t\t\t\tstringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n\t\t\t}\n\n\t\t\treturn (document.cookie = key + '=' + value + stringifiedAttributes);\n\t\t}\n\n\t\tfunction get (key, json) {\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar jar = {};\n\t\t\t// To prevent the for loop in the first place assign an empty array\n\t\t\t// in case there are no cookies at all.\n\t\t\tvar cookies = document.cookie ? document.cookie.split('; ') : [];\n\t\t\tvar i = 0;\n\n\t\t\tfor (; i < cookies.length; i++) {\n\t\t\t\tvar parts = cookies[i].split('=');\n\t\t\t\tvar cookie = parts.slice(1).join('=');\n\n\t\t\t\tif (!json && cookie.charAt(0) === '\"') {\n\t\t\t\t\tcookie = cookie.slice(1, -1);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tvar name = decode(parts[0]);\n\t\t\t\t\tcookie = (converter.read || converter)(cookie, name) ||\n\t\t\t\t\t\tdecode(cookie);\n\n\t\t\t\t\tif (json) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tcookie = JSON.parse(cookie);\n\t\t\t\t\t\t} catch (e) {}\n\t\t\t\t\t}\n\n\t\t\t\t\tjar[name] = cookie;\n\n\t\t\t\t\tif (key === name) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\t\t\t}\n\n\t\t\treturn key ? jar[key] : jar;\n\t\t}\n\n\t\tapi.set = set;\n\t\tapi.get = function (key) {\n\t\t\treturn get(key, false /* read as raw */);\n\t\t};\n\t\tapi.getJSON = function (key) {\n\t\t\treturn get(key, true /* read as json */);\n\t\t};\n\t\tapi.remove = function (key, attributes) {\n\t\t\tset(key, '', extend(attributes, {\n\t\t\t\texpires: -1\n\t\t\t}));\n\t\t};\n\n\t\tapi.defaults = {};\n\n\t\tapi.withConverter = init;\n\n\t\treturn api;\n\t}\n\n\treturn init(function () {});\n}));\n","import Cookie from 'js-cookie';\nimport objectHelper from '../object';\nfunction CookieStorage() {}\n\nCookieStorage.prototype.getItem = function(key) {\n return Cookie.get(key);\n};\n\nCookieStorage.prototype.removeItem = function(key) {\n Cookie.remove(key);\n};\n\nCookieStorage.prototype.setItem = function(key, value, options) {\n var params = objectHelper.extend(\n {\n expires: 1 // 1 day\n },\n options\n );\n Cookie.set(key, value, params);\n};\n\nexport default CookieStorage;\n","/* eslint-disable no-console */\n\nfunction Warn(options) {\n this.disableWarnings = options.disableWarnings;\n}\n\nWarn.prototype.warning = function(message) {\n if (this.disableWarnings) {\n return;\n }\n\n console.warn(message);\n};\n\nexport default Warn;\n","import windowHandler from '../window';\nimport DummyStorage from './dummy';\nimport CookieStorage from './cookie';\nimport Warn from '../warn';\n\nfunction StorageHandler(options) {\n this.warn = new Warn({});\n this.storage = new CookieStorage();\n if (options.__tryLocalStorageFirst !== true) {\n return;\n }\n try {\n // some browsers throw an error when trying to access localStorage\n // when localStorage is disabled.\n var localStorage = windowHandler.getWindow().localStorage;\n if (localStorage) {\n this.storage = localStorage;\n }\n } catch (e) {\n this.warn.warning(e);\n this.warn.warning(\"Can't use localStorage. Using CookieStorage instead.\");\n }\n}\n\nStorageHandler.prototype.failover = function() {\n if (this.storage instanceof DummyStorage) {\n this.warn.warning('DummyStorage: ignore failover');\n return;\n } else if (this.storage instanceof CookieStorage) {\n this.warn.warning('CookieStorage: failing over DummyStorage');\n this.storage = new DummyStorage();\n } else {\n this.warn.warning('LocalStorage: failing over CookieStorage');\n this.storage = new CookieStorage();\n }\n};\n\nStorageHandler.prototype.getItem = function(key) {\n try {\n return this.storage.getItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.getItem(key);\n }\n};\n\nStorageHandler.prototype.removeItem = function(key) {\n try {\n return this.storage.removeItem(key);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.removeItem(key);\n }\n};\n\nStorageHandler.prototype.setItem = function(key, value, options) {\n try {\n return this.storage.setItem(key, value, options);\n } catch (e) {\n this.warn.warning(e);\n this.failover();\n return this.setItem(key, value, options);\n }\n};\n\nexport default StorageHandler;\n","import StorageHandler from './storage/handler';\n\nfunction Storage(options) {\n this.handler = new StorageHandler(options);\n}\n\nStorage.prototype.getItem = function(key) {\n var value = this.handler.getItem(key);\n try {\n return JSON.parse(value);\n } catch (_) {\n return value;\n }\n};\nStorage.prototype.removeItem = function(key) {\n return this.handler.removeItem(key);\n};\nStorage.prototype.setItem = function(key, value, options) {\n var json = JSON.stringify(value);\n return this.handler.setItem(key, json, options);\n};\n\nexport default Storage;\n","import Storage from './storage';\n\nfunction SSODataStorage(options) {\n this.storage = new Storage(options);\n}\n\nSSODataStorage.prototype.set = function(connection, sub) {\n var ssodata = {\n lastUsedConnection: connection,\n lastUsedSub: sub\n };\n this.storage.setItem('auth0.ssodata', JSON.stringify(ssodata));\n};\nSSODataStorage.prototype.get = function() {\n var ssodata = this.storage.getItem('auth0.ssodata');\n if (!ssodata) {\n return;\n }\n return JSON.parse(ssodata);\n};\n\nexport default SSODataStorage;\n","function buildResponse(error, description) {\n return {\n error: error,\n errorDescription: description\n };\n}\n\nfunction invalidToken(description) {\n return buildResponse('invalid_token', description);\n}\n\nexport default {\n buildResponse: buildResponse,\n invalidToken: invalidToken\n};\n","import error from './error';\nimport objectHelper from './object';\n\nfunction wrapCallback(cb, options) {\n options = options || {};\n options.ignoreCasing = options.ignoreCasing ? options.ignoreCasing : false;\n\n return function(err, data) {\n var errObj;\n\n if (!err && !data) {\n return cb(error.buildResponse('generic_error', 'Something went wrong'));\n }\n\n if (!err && data.err) {\n err = data.err;\n data = null;\n }\n\n if (!err && data.error) {\n err = data;\n data = null;\n }\n\n if (err) {\n errObj = {\n original: err\n };\n\n objectHelper.updatePropertyOn(\n errObj,\n 'original.response.req._data.password',\n '*****'\n );\n\n if (err.response && err.response.statusCode) {\n errObj.statusCode = err.response.statusCode;\n }\n\n if (err.response && err.response.statusText) {\n errObj.statusText = err.response.statusText;\n }\n\n if (err.response && err.response.body) {\n err = err.response.body;\n }\n\n if (err.err) {\n err = err.err;\n }\n\n errObj.code =\n err.code || err.error || err.error_code || err.status || null;\n\n errObj.description =\n err.errorDescription ||\n err.error_description ||\n err.description ||\n err.error ||\n err.details ||\n err.err ||\n null;\n\n if (options.forceLegacyError) {\n errObj.error = errObj.code;\n errObj.error_description = errObj.description;\n }\n\n if (err.error_codes && err.error_details) {\n errObj.errorDetails = {\n codes: err.error_codes,\n details: err.error_details\n };\n }\n\n if (err.name) {\n errObj.name = err.name;\n }\n\n if (err.policy) {\n errObj.policy = err.policy;\n }\n\n return cb(errObj);\n }\n\n if (\n data.type &&\n (data.type === 'text/html' || data.type === 'text/plain')\n ) {\n return cb(null, data.text);\n }\n\n if (options.ignoreCasing) {\n return cb(null, data.body || data);\n }\n\n return cb(\n null,\n objectHelper.toCamelCase(data.body || data, [], {\n keepOriginal: options.keepOriginalCasing\n })\n );\n };\n}\n\nexport default wrapCallback;\n","// For future reference:,\n// The only parameters that should be allowed are parameters\n// defined by the specification, or existing parameters that we\n// need for compatibility\n\nimport objectHelper from './object';\n\nvar tokenParams = [\n // auth0\n 'realm',\n 'audience',\n 'otp',\n // oauth2\n 'client_id',\n 'client_secret',\n 'redirect_uri',\n 'scope',\n 'code',\n 'grant_type',\n 'username',\n 'password',\n 'refresh_token',\n 'assertion',\n 'client_assertion',\n 'client_assertion_type',\n 'code_verifier'\n];\n\nvar authorizeParams = [\n // auth0\n 'connection',\n 'connection_scope',\n 'auth0Client',\n 'owp',\n 'device',\n 'realm',\n\n 'protocol',\n '_csrf',\n '_intstate',\n 'login_ticket',\n\n // oauth2\n 'client_id',\n 'response_type',\n 'response_mode',\n 'redirect_uri',\n 'audience',\n 'scope',\n 'state',\n 'nonce',\n 'display',\n 'prompt',\n 'screen_hint',\n 'max_age',\n 'ui_locales',\n 'claims_locales',\n 'id_token_hint',\n 'login_hint',\n 'acr_values',\n 'claims',\n 'registration',\n 'request',\n 'request_uri',\n 'code_challenge',\n 'code_challenge_method',\n\n // ADDITIONAL_PARAMETERS:\n // https://auth0.com/docs/api/authentication?javascript#social\n 'access_type',\n 'display'\n];\n\nfunction oauthAuthorizeParams(warn, params) {\n var notAllowed = objectHelper.getKeysNotIn(params, authorizeParams);\n\n if (notAllowed.length > 0) {\n warn.warning(\n 'Following parameters are not allowed on the `/authorize` endpoint: [' +\n notAllowed.join(',') +\n ']'\n );\n }\n\n return params;\n}\n\nfunction oauthTokenParams(warn, params) {\n return objectHelper.pick(params, tokenParams);\n}\n\nexport default {\n oauthTokenParams: oauthTokenParams,\n oauthAuthorizeParams: oauthAuthorizeParams\n};\n","var t=\"undefined\"!=typeof globalThis?globalThis:\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:{};function e(t,e,r){return t(r={path:e,exports:{},require:function(t,e){return function(){throw new Error(\"Dynamic requires are not currently supported by @rollup/plugin-commonjs\")}()}},r.exports),r.exports}var r=e(function(e,r){e.exports=function(){function e(t){return\"function\"==typeof t}var r=Array.isArray?Array.isArray:function(t){return\"[object Array]\"===Object.prototype.toString.call(t)},i=0,n=void 0,o=void 0,s=function(t,e){l[i]=t,l[i+1]=e,2===(i+=2)&&(o?o(d):w())},h=\"undefined\"!=typeof window?window:void 0,a=h||{},u=a.MutationObserver||a.WebKitMutationObserver,f=\"undefined\"==typeof self&&\"undefined\"!=typeof process&&\"[object process]\"==={}.toString.call(process),c=\"undefined\"!=typeof Uint8ClampedArray&&\"undefined\"!=typeof importScripts&&\"undefined\"!=typeof MessageChannel;function p(){var t=setTimeout;return function(){return t(d,1)}}var l=new Array(1e3);function d(){for(var t=0;t>>2]|=(r[o>>>2]>>>24-o%4*8&255)<<24-(i+o)%4*8;else for(o=0;o>>2]=r[o>>>2];return this.sigBytes+=n,this},clamp:function(){var e=this.words,r=this.sigBytes;e[r>>>2]&=4294967295<<32-r%4*8,e.length=t.ceil(r/4)},clone:function(){var t=o.clone.call(this);return t.words=this.words.slice(0),t},random:function(e){for(var r,i=[],n=function(e){e=e;var r=987654321,i=4294967295;return function(){var n=((r=36969*(65535&r)+(r>>16)&i)<<16)+(e=18e3*(65535&e)+(e>>16)&i)&i;return n/=4294967296,(n+=.5)*(t.random()>.5?1:-1)}},o=0;o>>2]>>>24-n%4*8&255;i.push((o>>>4).toString(16)),i.push((15&o).toString(16))}return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>3]|=parseInt(t.substr(i,2),16)<<24-i%8*4;return new s.init(r,e/2)}},u=h.Latin1={stringify:function(t){for(var e=t.words,r=t.sigBytes,i=[],n=0;n>>2]>>>24-n%4*8&255));return i.join(\"\")},parse:function(t){for(var e=t.length,r=[],i=0;i>>2]|=(255&t.charCodeAt(i))<<24-i%4*8;return new s.init(r,e)}},f=h.Utf8={stringify:function(t){try{return decodeURIComponent(escape(u.stringify(t)))}catch(t){throw new Error(\"Malformed UTF-8 data\")}},parse:function(t){return u.parse(unescape(encodeURIComponent(t)))}},c=n.BufferedBlockAlgorithm=o.extend({reset:function(){this._data=new s.init,this._nDataBytes=0},_append:function(t){\"string\"==typeof t&&(t=f.parse(t)),this._data.concat(t),this._nDataBytes+=t.sigBytes},_process:function(e){var r=this._data,i=r.words,n=r.sigBytes,o=this.blockSize,h=n/(4*o),a=(h=e?t.ceil(h):t.max((0|h)-this._minBufferSize,0))*o,u=t.min(4*a,n);if(a){for(var f=0;f>>7)^(d<<14|d>>>18)^d>>>3)+u[l-7]+((m<<15|m>>>17)^(m<<13|m>>>19)^m>>>10)+u[l-16]}var v=i&n^i&o^n&o,y=p+((h<<26|h>>>6)^(h<<21|h>>>11)^(h<<7|h>>>25))+(h&f^~h&c)+a[l]+u[l];p=c,c=f,f=h,h=s+y|0,s=o,o=n,n=i,i=y+(((i<<30|i>>>2)^(i<<19|i>>>13)^(i<<10|i>>>22))+v)|0}r[0]=r[0]+i|0,r[1]=r[1]+n|0,r[2]=r[2]+o|0,r[3]=r[3]+s|0,r[4]=r[4]+h|0,r[5]=r[5]+f|0,r[6]=r[6]+c|0,r[7]=r[7]+p|0},_doFinalize:function(){var e=this._data,r=e.words,i=8*this._nDataBytes,n=8*e.sigBytes;return r[n>>>5]|=128<<24-n%32,r[14+(n+64>>>9<<4)]=t.floor(i/4294967296),r[15+(n+64>>>9<<4)]=i,e.sigBytes=4*r.length,this._process(),this._hash},clone:function(){var t=o.clone.call(this);return t._hash=this._hash.clone(),t}});e.SHA256=o._createHelper(f),e.HmacSHA256=o._createHmacHelper(f)}(Math),r.SHA256)}),o=e(function(t,e){var r,n;t.exports=(r=(n=i).lib.WordArray,n.enc.Base64={stringify:function(t){var e=t.words,r=t.sigBytes,i=this._map;t.clamp();for(var n=[],o=0;o>>2]>>>24-o%4*8&255)<<16|(e[o+1>>>2]>>>24-(o+1)%4*8&255)<<8|e[o+2>>>2]>>>24-(o+2)%4*8&255,h=0;h<4&&o+.75*h>>6*(3-h)&63));var a=i.charAt(64);if(a)for(;n.length%4;)n.push(a);return n.join(\"\")},parse:function(t){var e=t.length,i=this._map,n=this._reverseMap;if(!n){n=this._reverseMap=[];for(var o=0;o>>6-s%4*2;n[o>>>2]|=(h|a)<<24-o%4*8,o++}return r.create(n,o)}(t,e,n)},_map:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\"},n.enc.Base64)}),s=e(function(t,e){t.exports=i.enc.Hex}),h=e(function(e,r){(function(){var t;function r(t,e,r){null!=t&&(\"number\"==typeof t?this.fromNumber(t,e,r):this.fromString(t,null==e&&\"string\"!=typeof t?256:e))}function i(){return new r(null)}var n=\"undefined\"!=typeof navigator;n&&\"Microsoft Internet Explorer\"==navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(var s=32767&e,h=e>>15;--o>=0;){var a=32767&this[t],u=this[t++]>>15,f=h*a+u*s;n=((a=s*a+((32767&f)<<15)+r[i]+(1073741823&n))>>>30)+(f>>>15)+h*u+(n>>>30),r[i++]=1073741823&a}return n},t=30):n&&\"Netscape\"!=navigator.appName?(r.prototype.am=function(t,e,r,i,n,o){for(;--o>=0;){var s=e*this[t++]+r[i]+n;n=Math.floor(s/67108864),r[i++]=67108863&s}return n},t=26):(r.prototype.am=function(t,e,r,i,n,o){for(var s=16383&e,h=e>>14;--o>=0;){var a=16383&this[t],u=this[t++]>>14,f=h*a+u*s;n=((a=s*a+((16383&f)<<14)+r[i]+n)>>28)+(f>>14)+h*u,r[i++]=268435455&a}return n},t=28),r.prototype.DB=t,r.prototype.DM=(1<>>16)&&(t=e,r+=16),0!=(e=t>>8)&&(t=e,r+=8),0!=(e=t>>4)&&(t=e,r+=4),0!=(e=t>>2)&&(t=e,r+=2),0!=(e=t>>1)&&(t=e,r+=1),r}function p(t){this.m=t}function l(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,e+=16),0==(255&t)&&(t>>=8,e+=8),0==(15&t)&&(t>>=4,e+=4),0==(3&t)&&(t>>=2,e+=2),0==(1&t)&&++e,e}function w(t){for(var e=0;0!=t;)t&=t-1,++e;return e}function T(){}function b(t){return t}function _(t){this.r2=i(),this.q3=i(),r.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t),this.m=t}p.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},p.prototype.revert=function(t){return t},p.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},p.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},p.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},l.prototype.convert=function(t){var e=i();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(r.ZERO)>0&&this.m.subTo(e,e),e},l.prototype.revert=function(t){var e=i();return t.copyTo(e),this.reduce(e),e},l.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e>15)*this.mpl&this.um)<<15)&t.DM;for(t[r=e+this.m.t]+=this.m.am(0,i,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},l.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},l.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},r.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},r.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},r.prototype.fromString=function(t,e){var i;if(16==e)i=4;else if(8==e)i=3;else if(256==e)i=8;else if(2==e)i=1;else if(32==e)i=5;else{if(4!=e)return void this.fromRadix(t,e);i=2}this.t=0,this.s=0;for(var n=t.length,o=!1,s=0;--n>=0;){var h=8==i?255&t[n]:u(t,n);h<0?\"-\"==t.charAt(n)&&(o=!0):(o=!1,0==s?this[this.t++]=h:s+i>this.DB?(this[this.t-1]|=(h&(1<>this.DB-s):this[this.t-1]|=h<=this.DB&&(s-=this.DB))}8==i&&0!=(128&t[0])&&(this.s=-1,s>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==t;)--this.t},r.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},r.prototype.drShiftTo=function(t,e){for(var r=t;r=0;--r)e[r+s+1]=this[r]>>n|h,h=(this[r]&o)<=0;--r)e[r]=0;e[s]=h,e.t=this.t+s+1,e.s=this.s,e.clamp()},r.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t)e.t=0;else{var i=t%this.DB,n=this.DB-i,o=(1<>i;for(var s=r+1;s>i;i>0&&(e[this.t-r-1]|=(this.s&o)<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=t.s}e.s=i<0?-1:0,i<-1?e[r++]=this.DV+i:i>0&&(e[r++]=i),e.t=r,e.clamp()},r.prototype.multiplyTo=function(t,e){var i=this.abs(),n=t.abs(),o=i.t;for(e.t=o+n.t;--o>=0;)e[o]=0;for(o=0;o=0;)t[r]=0;for(r=0;r=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},r.prototype.divRemTo=function(t,e,n){var o=t.abs();if(!(o.t<=0)){var s=this.abs();if(s.t0?(o.lShiftTo(f,h),s.lShiftTo(f,n)):(o.copyTo(h),s.copyTo(n));var p=h.t,l=h[p-1];if(0!=l){var d=l*(1<1?h[p-2]>>this.F2:0),m=this.FV/d,v=(1<=0&&(n[n.t++]=1,n.subTo(T,n)),r.ONE.dlShiftTo(p,T),T.subTo(h,h);h.t=0;){var b=n[--g]==l?this.DM:Math.floor(n[g]*m+(n[g-1]+y)*v);if((n[g]+=h.am(0,b,n,w,0,p))0&&n.rShiftTo(f,n),a<0&&r.ZERO.subTo(n,n)}}},r.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(0==(1&t))return 0;var e=3&t;return(e=(e=(e=(e=e*(2-(15&t)*e)&15)*(2-(255&t)*e)&255)*(2-((65535&t)*e&65535))&65535)*(2-t*e%this.DV)%this.DV)>0?this.DV-e:-e},r.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},r.prototype.exp=function(t,e){if(t>4294967295||t<1)return r.ONE;var n=i(),o=i(),s=e.convert(this),h=c(t)-1;for(s.copyTo(n);--h>=0;)if(e.sqrTo(n,o),(t&1<0)e.mulTo(o,s,n);else{var a=n;n=o,o=a}return e.revert(n)},r.prototype.toString=function(t){if(this.s<0)return\"-\"+this.negate().toString(t);var e;if(16==t)e=4;else if(8==t)e=3;else if(2==t)e=1;else if(32==t)e=5;else{if(4!=t)return this.toRadix(t);e=2}var r,i=(1<0)for(h>h)>0&&(n=!0,o=a(r));s>=0;)h>(h+=this.DB-e)):(r=this[s]>>(h-=e)&i,h<=0&&(h+=this.DB,--s)),r>0&&(n=!0),n&&(o+=a(r));return n?o:\"0\"},r.prototype.negate=function(){var t=i();return r.ZERO.subTo(this,t),t},r.prototype.abs=function(){return this.s<0?this.negate():this},r.prototype.compareTo=function(t){var e=this.s-t.s;if(0!=e)return e;var r=this.t;if(0!=(e=r-t.t))return this.s<0?-e:e;for(;--r>=0;)if(0!=(e=this[r]-t[r]))return e;return 0},r.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+c(this[this.t-1]^this.s&this.DM)},r.prototype.mod=function(t){var e=i();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(r.ZERO)>0&&t.subTo(e,e),e},r.prototype.modPowInt=function(t,e){var r;return r=t<256||e.isEven()?new p(e):new l(e),this.exp(t,r)},r.ZERO=f(0),r.ONE=f(1),T.prototype.convert=b,T.prototype.revert=b,T.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},T.prototype.sqrTo=function(t,e){t.squareTo(e)},_.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=i();return t.copyTo(e),this.reduce(e),e},_.prototype.revert=function(t){return t},_.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},_.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},_.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)};var S,D,A,B=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],x=(1<<26)/B[B.length-1];function E(){var t;t=(new Date).getTime(),D[A++]^=255&t,D[A++]^=t>>8&255,D[A++]^=t>>16&255,D[A++]^=t>>24&255,A>=O&&(A-=O)}if(r.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},r.prototype.toRadix=function(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return\"0\";var e=this.chunkSize(t),r=Math.pow(t,e),n=f(r),o=i(),s=i(),h=\"\";for(this.divRemTo(n,o,s);o.signum()>0;)h=(r+s.intValue()).toString(t).substr(1)+h,o.divRemTo(n,o,s);return s.intValue().toString(t)+h},r.prototype.fromRadix=function(t,e){this.fromInt(0),null==e&&(e=10);for(var i=this.chunkSize(e),n=Math.pow(e,i),o=!1,s=0,h=0,a=0;a=i&&(this.dMultiply(n),this.dAddOffset(h,0),s=0,h=0))}s>0&&(this.dMultiply(Math.pow(e,s)),this.dAddOffset(h,0)),o&&r.ZERO.subTo(this,this)},r.prototype.fromNumber=function(t,e,i){if(\"number\"==typeof e)if(t<2)this.fromInt(1);else for(this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(r.ONE.shiftLeft(t-1),m,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(r.ONE.shiftLeft(t-1),this);else{var n=new Array,o=7&t;n.length=1+(t>>3),e.nextBytes(n),o>0?n[0]&=(1<>=this.DB;if(t.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=t.s}e.s=i<0?-1:0,i>0?e[r++]=i:i<-1&&(e[r++]=this.DV+i),e.t=r,e.clamp()},r.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},r.prototype.dAddOffset=function(t,e){if(0!=t){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},r.prototype.multiplyLowerTo=function(t,e,r){var i,n=Math.min(this.t+t.t,e);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(e-this.t,0);i0)if(0==e)r=this[0]%t;else for(var i=this.t-1;i>=0;--i)r=(e*r+this[i])%t;return r},r.prototype.millerRabin=function(t){var e=this.subtract(r.ONE),n=e.getLowestSetBit();if(n<=0)return!1;var o=e.shiftRight(n);(t=t+1>>1)>B.length&&(t=B.length);for(var s=i(),h=0;h>24},r.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},r.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},r.prototype.toByteArray=function(){var t=this.t,e=new Array;e[0]=this.s;var r,i=this.DB-t*this.DB%8,n=0;if(t-- >0)for(i>i)!=(this.s&this.DM)>>i&&(e[n++]=r|this.s<=0;)i<8?(r=(this[t]&(1<>(i+=this.DB-8)):(r=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(e[n++]=r);return e},r.prototype.equals=function(t){return 0==this.compareTo(t)},r.prototype.min=function(t){return this.compareTo(t)<0?this:t},r.prototype.max=function(t){return this.compareTo(t)>0?this:t},r.prototype.and=function(t){var e=i();return this.bitwiseTo(t,d,e),e},r.prototype.or=function(t){var e=i();return this.bitwiseTo(t,m,e),e},r.prototype.xor=function(t){var e=i();return this.bitwiseTo(t,v,e),e},r.prototype.andNot=function(t){var e=i();return this.bitwiseTo(t,y,e),e},r.prototype.not=function(){for(var t=i(),e=0;e=this.t?0!=this.s:0!=(this[e]&1<1){var m=i();for(n.sqrTo(h[1],m);a<=d;)h[a]=i(),n.mulTo(m,h[a-2],h[a]),a+=2}var v,y,g=t.t-1,w=!0,T=i();for(o=c(t[g])-1;g>=0;){for(o>=u?v=t[g]>>o-u&d:(v=(t[g]&(1<0&&(v|=t[g-1]>>this.DB+o-u)),a=r;0==(1&v);)v>>=1,--a;if((o-=a)<0&&(o+=this.DB,--g),w)h[v].copyTo(s),w=!1;else{for(;a>1;)n.sqrTo(s,T),n.sqrTo(T,s),a-=2;a>0?n.sqrTo(s,T):(y=s,s=T,T=y),n.mulTo(T,h[v],s)}for(;g>=0&&0==(t[g]&1<=0?(i.subTo(n,i),e&&o.subTo(h,o),s.subTo(a,s)):(n.subTo(i,n),e&&h.subTo(o,h),a.subTo(s,a))}return 0!=n.compareTo(r.ONE)?r.ZERO:a.compareTo(t)>=0?a.subtract(t):a.signum()<0?(a.addTo(t,a),a.signum()<0?a.add(t):a):a},r.prototype.pow=function(t){return this.exp(t,new T)},r.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var i=e;e=r,r=i}var n=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(n0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(n=e.getLowestSetBit())>0&&e.rShiftTo(n,e),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},r.prototype.isProbablePrime=function(t){var e,r=this.abs();if(1==r.t&&r[0]<=B[B.length-1]){for(e=0;e>>8,D[A++]=255&k;A=0,E()}function R(){if(null==S){for(E(),(S=new j).init(D),A=0;A0&&e.length>0))throw new Error(\"Invalid key data\");this.n=new h.BigInteger(t,16),this.e=parseInt(e,16)}f.prototype.verify=function(t,e){e=e.replace(/[^0-9a-f]|[\\s\\n]]/gi,\"\");var r=new h.BigInteger(e,16);if(r.bitLength()>this.n.bitLength())throw new Error(\"Signature does not match with the key modulus.\");var i=function(t){for(var e in a){var r=a[e],i=r.length;if(t.substring(0,i)===r)return{alg:e,hash:t.substring(i)}}return[]}(r.modPowInt(this.e,this.n).toString(16).replace(/^1f+00/,\"\"));if(0===i.length)return!1;if(!u.hasOwnProperty(i.alg))throw new Error(\"Hashing algorithm is not supported.\");var n=u[i.alg](t).toString();return i.hash===n};for(var c=[],p=[],l=\"undefined\"!=typeof Uint8Array?Uint8Array:Array,d=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",m=0,v=d.length;m0)throw new Error(\"Invalid string. Length must be a multiple of 4\");var r=t.indexOf(\"=\");return-1===r&&(r=e),[r,r===e?0:4-r%4]}(t),n=i[0],o=i[1],s=new l(function(t,e,r){return 3*(e+r)/4-r}(0,n,o)),h=0,a=o>0?n-4:n;for(r=0;r>16&255,s[h++]=e>>8&255,s[h++]=255&e;return 2===o&&(e=p[t.charCodeAt(r)]<<2|p[t.charCodeAt(r+1)]>>4,s[h++]=255&e),1===o&&(e=p[t.charCodeAt(r)]<<10|p[t.charCodeAt(r+1)]<<4|p[t.charCodeAt(r+2)]>>2,s[h++]=e>>8&255,s[h++]=255&e),s};function g(t){var e=t.length%4;return 0===e?t:t+new Array(4-e+1).join(\"=\")}function w(t){return t=g(t).replace(/\\-/g,\"+\").replace(/_/g,\"/\"),decodeURIComponent(function(t){for(var e=\"\",r=0;r1){var r=t.shift();t[0]=r+t[0]}t[0]=t[0].match(/^file:\\/\\/\\//)?t[0].replace(/^([^/:]+):\\/*/,\"$1:///\"):t[0].replace(/^([^/:]+):\\/*/,\"$1://\");for(var i=0;i0&&(n=n.replace(/^[\\/]+/,\"\")),n=n.replace(/[\\/]+$/,i0?\"?\":\"\")+s.join(\"&\")}return function(){return t(\"object\"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},e.exports?e.exports=i():r.urljoin=i()});function _(t,e){return e=e||{},new Promise(function(r,i){var n=new XMLHttpRequest,o=[],s=[],h={},a=function(){return{ok:2==(n.status/100|0),statusText:n.statusText,status:n.status,url:n.responseURL,text:function(){return Promise.resolve(n.responseText)},json:function(){return Promise.resolve(JSON.parse(n.responseText))},blob:function(){return Promise.resolve(new Blob([n.response]))},clone:a,headers:{keys:function(){return o},entries:function(){return s},get:function(t){return h[t.toLowerCase()]},has:function(t){return t.toLowerCase()in h}}}};for(var u in n.open(e.method||\"get\",t,!0),n.onload=function(){n.getAllResponseHeaders().replace(/^(.*?):[^\\S\\n]*([\\s\\S]*?)$/gm,function(t,e,r){o.push(e=e.toLowerCase()),s.push([e,r]),h[e]=h[e]?h[e]+\",\"+r:r}),r(a())},n.onerror=i,n.withCredentials=\"include\"==e.credentials,e.headers)n.setRequestHeader(u,e.headers[u]);n.send(e.body||null)})}function S(t){if(t.ok)return t.json();var e=new Error(t.statusText);return e.response=t,Promise.reject(e)}function D(t){this.name=\"ConfigurationError\",this.message=t||\"\"}function A(t){this.name=\"TokenValidationError\",this.message=t||\"\"}D.prototype=Error.prototype,A.prototype=Error.prototype;var B=function(){function t(){}var e=t.prototype;return e.get=function(){return null},e.has=function(){return null},e.set=function(){return null},t}();r.polyfill();var x=function(t){return\"number\"==typeof t},E=function(){return new Date};function k(t){var e=t||{};if(this.jwksCache=e.jwksCache||new B,this.expectedAlg=e.expectedAlg||\"RS256\",this.issuer=e.issuer,this.audience=e.audience,this.leeway=0===e.leeway?0:e.leeway||60,this.jwksURI=e.jwksURI,this.maxAge=e.maxAge,this.__clock=\"function\"==typeof e.__clock?e.__clock:E,this.leeway<0||this.leeway>300)throw new D(\"The leeway should be positive and lower than five minutes.\");if(\"RS256\"!==this.expectedAlg)throw new D('Signature algorithm of \"'+this.expectedAlg+'\" is not supported. Expected the ID token to be signed with \"RS256\".')}k.prototype.verify=function(t,e,r){if(!t)return r(new A(\"ID token is required but missing\"),!1);var i=this.decode(t);if(i instanceof Error)return r(new A(\"ID token could not be decoded\"),!1);var n=i.encoded.header+\".\"+i.encoded.payload,o=T(i.encoded.signature),s=i.header.alg,h=i.header.kid,a=i.payload.aud,u=i.payload.sub,f=i.payload.iss,c=i.payload.exp,p=i.payload.nbf,l=i.payload.iat,d=i.payload.azp,m=i.payload.auth_time,v=i.payload.nonce,y=this.__clock(),g=this;if(g.expectedAlg!==s)return r(new A('Signature algorithm of \"'+s+'\" is not supported. Expected the ID token to be signed with \"RS256\".'),!1);this.getRsaVerifier(f,h,function(t,s){if(t)return r(t);if(!s.verify(n,o))return r(new A(\"Invalid ID token signature.\"));if(!f||\"string\"!=typeof f)return r(new A(\"Issuer (iss) claim must be a string present in the ID token\",!1));if(g.issuer!==f)return r(new A('Issuer (iss) claim mismatch in the ID token, expected \"'+g.issuer+'\", found \"'+f+'\"'),!1);if(!u||\"string\"!=typeof u)return r(new A(\"Subject (sub) claim must be a string present in the ID token\"),!1);if(!a||\"string\"!=typeof a&&!Array.isArray(a))return r(new A(\"Audience (aud) claim must be a string or array of strings present in the ID token\"));if(Array.isArray(a)&&!a.includes(g.audience))return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but was not one of \"'+a.join(\", \")+'\"'));if(\"string\"==typeof a&&g.audience!==a)return r(new A('Audience (aud) claim mismatch in the ID token; expected \"'+g.audience+'\" but found \"'+a+'\"'),!1);if(e){if(!v||\"string\"!=typeof v)return r(new A(\"Nonce (nonce) claim must be a string present in the ID token\"),!1);if(v!==e)return r(new A('Nonce (nonce) claim value mismatch in the ID token; expected \"'+e+'\", found \"'+v+'\"'),!1)}if(Array.isArray(a)&&a.length>1){if(!d||\"string\"!=typeof d)return r(new A(\"Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values\",!1));if(d!==g.audience)return r(new A('Authorized Party (azp) claim mismatch in the ID token; expected \"'+g.audience+'\", found \"'+d+'\"',!1))}if(!c||!x(c))return r(new A(\"Expiration Time (exp) claim must be a number present in the ID token\",!1));if(!l||!x(l))return r(new A(\"Issued At (iat) claim must be a number present in the ID token\"));var h=c+g.leeway,w=new Date(0);if(w.setUTCSeconds(h),y>w)return r(new A('Expiration Time (exp) claim error in the ID token; current time \"'+y+'\" is after expiration time \"'+w+'\"',!1));if(p&&x(p)){var T=p-g.leeway,b=new Date(0);if(b.setUTCSeconds(T),yS)return r(new A('Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Current time \"'+y+'\" is after last auth time at \"'+S+'\"'))}return r(null,i.payload)})},k.prototype.getRsaVerifier=function(t,e,r){var i=this,n=t+e;Promise.resolve(this.jwksCache.has(n)).then(function(r){return r?i.jwksCache.get(n):(o={jwksURI:i.jwksURI,iss:t,kid:e},(\"undefined\"==typeof fetch?_:fetch)(o.jwksURI||b(o.iss,\".well-known\",\"jwks.json\")).then(S).then(function(t){var e,r,i,n=null;for(e=0;e 11\n else if (ua.indexOf(\"Trident\") > -1) {\n var re = new RegExp(\"rv:([0-9]{2,2}[\\.0-9]{0,})\");\n if (re.exec(ua) !== null) {\n rv = parseFloat(RegExp.$1);\n }\n }\n\n return rv >= 8;\n }\n\n // checking Mobile Firefox (Fennec)\n function isFennec() {\n try {\n // We must check for both XUL and Java versions of Fennec. Both have\n // distinct UA strings.\n var userAgent = navigator.userAgent;\n return (userAgent.indexOf('Fennec/') != -1) || // XUL\n (userAgent.indexOf('Firefox/') != -1 && userAgent.indexOf('Android') != -1); // Java\n } catch(e) {}\n return false;\n }\n\n // feature checking to see if this platform is supported at all\n function isSupported() {\n return (typeof window !== 'undefined' && window.JSON && window.JSON.stringify &&\n window.JSON.parse && window.postMessage);\n }\n\n // given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\n function extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[\\-_a-zA-Z\\.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n }\n\n // find the relay iframe in the opener\n function findRelay() {\n var loc = window.location;\n var frames = window.opener.frames;\n for (var i = frames.length - 1; i >= 0; i--) {\n try {\n if (frames[i].location.protocol === window.location.protocol &&\n frames[i].location.host === window.location.host &&\n frames[i].name === RELAY_FRAME_NAME)\n {\n return frames[i];\n }\n } catch(e) { }\n }\n return;\n }\n\n var isIE = isInternetExplorer();\n\n if (isSupported()) {\n /* General flow:\n * 0. user clicks\n * (IE SPECIFIC) 1. caller adds relay iframe (served from trusted domain) to DOM\n * 2. caller opens window (with content from trusted domain)\n * 3. window on opening adds a listener to 'message'\n * (IE SPECIFIC) 4. window on opening finds iframe\n * 5. window checks if iframe is \"loaded\" - has a 'doPost' function yet\n * (IE SPECIFIC5) 5a. if iframe.doPost exists, window uses it to send ready event to caller\n * (IE SPECIFIC5) 5b. if iframe.doPost doesn't exist, window waits for frame ready\n * (IE SPECIFIC5) 5bi. once ready, window calls iframe.doPost to send ready event\n * 6. caller upon reciept of 'ready', sends args\n */\n return {\n open: function(opts, cb) {\n if (!cb) throw \"missing required callback argument\";\n\n // test required options\n var err;\n if (!opts.url) err = \"missing required 'url' parameter\";\n if (!opts.relay_url) err = \"missing required 'relay_url' parameter\";\n if (err) setTimeout(function() { cb(err); }, 0);\n\n // supply default options\n if (!opts.window_name) opts.window_name = null;\n if (!opts.window_features || isFennec()) opts.window_features = undefined;\n\n // opts.params may be undefined\n\n var iframe;\n\n // sanity check, are url and relay_url the same origin?\n var origin = opts.origin || extractOrigin(opts.url);\n if (origin !== extractOrigin(opts.relay_url)) {\n return setTimeout(function() {\n cb('invalid arguments: origin of url and relay_url must match');\n }, 0);\n }\n\n var messageTarget;\n\n if (isIE) {\n // first we need to add a \"relay\" iframe to the document that's served\n // from the target domain. We can postmessage into a iframe, but not a\n // window\n iframe = document.createElement(\"iframe\");\n // iframe.setAttribute('name', framename);\n iframe.setAttribute('src', opts.relay_url);\n iframe.style.display = \"none\";\n iframe.setAttribute('name', RELAY_FRAME_NAME);\n document.body.appendChild(iframe);\n messageTarget = iframe.contentWindow;\n }\n\n var w = opts.popup || window.open(opts.url, opts.window_name, opts.window_features);\n if (opts.popup) {\n w.location.href = opts.url;\n }\n\n if (!messageTarget) messageTarget = w;\n\n // lets listen in case the window blows up before telling us\n var closeInterval = setInterval(function() {\n if (w && w.closed) {\n cleanup();\n if (cb) {\n cb('User closed the popup window');\n cb = null;\n }\n }\n }, 500);\n\n var req = JSON.stringify({a: 'request', d: opts.params});\n\n // cleanup on unload\n function cleanup() {\n if (iframe) document.body.removeChild(iframe);\n iframe = undefined;\n if (closeInterval) closeInterval = clearInterval(closeInterval);\n removeListener(window, 'message', onMessage);\n removeListener(window, 'unload', cleanup);\n if (w) {\n try {\n w.close();\n } catch (securityViolation) {\n // This happens in Opera 12 sometimes\n // see https://github.com/mozilla/browserid/issues/1844\n messageTarget.postMessage(CLOSE_CMD, origin);\n }\n }\n w = messageTarget = undefined;\n }\n\n addListener(window, 'unload', cleanup);\n\n function onMessage(e) {\n if (e.origin !== origin) { return; }\n try {\n var d = JSON.parse(e.data);\n } catch(err) {\n if (cb) {\n return cb(err);\n } else {\n throw err;\n }\n }\n\n if (d.a === 'ready') {\n messageTarget.postMessage(req, origin);\n } else if (d.a === 'error') {\n cleanup();\n if (cb) {\n cb(d.d);\n cb = null;\n }\n } else if (d.a === 'response') {\n cleanup();\n if (cb) {\n cb(null, d.d);\n cb = null;\n }\n }\n }\n\n addListener(window, 'message', onMessage);\n\n return {\n originalPopup: w,\n close: cleanup,\n focus: function() {\n if (w) {\n try {\n w.focus();\n } catch (e) {\n // IE7 blows up here, do nothing\n }\n }\n }\n };\n },\n onOpen: function(cb) {\n var o = \"*\";\n var msgTarget = isIE ? findRelay() : window.opener;\n if (!msgTarget) throw \"can't find relay frame\";\n function doPost(msg) {\n msg = JSON.stringify(msg);\n if (isIE) msgTarget.doPost(msg, o);\n else msgTarget.postMessage(msg, o);\n }\n\n function onMessage(e) {\n // only one message gets through, but let's make sure it's actually\n // the message we're looking for (other code may be using\n // postmessage) - we do this by ensuring the payload can\n // be parsed, and it's got an 'a' (action) value of 'request'.\n var d;\n try {\n d = JSON.parse(e.data);\n } catch(err) { }\n if (!d || d.a !== 'request') return;\n removeListener(window, 'message', onMessage);\n o = e.origin;\n if (cb) {\n // this setTimeout is critically important for IE8 -\n // in ie8 sometimes addListener for 'message' can synchronously\n // cause your callback to be invoked. awesome.\n setTimeout(function() {\n cb(o, d.d, function(r) {\n cb = undefined;\n doPost({a: 'response', d: r});\n });\n }, 0);\n }\n }\n\n function onDie(e) {\n if (e.data === CLOSE_CMD) {\n try { window.close(); } catch (o_O) {}\n }\n }\n addListener(isIE ? msgTarget : window, 'message', onMessage);\n addListener(isIE ? msgTarget : window, 'message', onDie);\n\n // we cannot post to our parent that we're ready before the iframe\n // is loaded. (IE specific possible failure)\n try {\n doPost({a: \"ready\"});\n } catch(e) {\n // this code should never be exectued outside IE\n addListener(msgTarget, 'load', function(e) {\n doPost({a: \"ready\"});\n });\n }\n\n // if window is unloaded and the client hasn't called cb, it's an error\n var onUnload = function() {\n try {\n // IE8 doesn't like this...\n removeListener(isIE ? msgTarget : window, 'message', onDie);\n } catch (ohWell) { }\n if (cb) doPost({ a: 'error', d: 'client closed window' });\n cb = undefined;\n // explicitly close the window, in case the client is trying to reload or nav\n try { window.close(); } catch (e) { }\n };\n addListener(window, 'unload', onUnload);\n return {\n detach: function() {\n removeListener(window, 'unload', onUnload);\n }\n };\n }\n };\n } else {\n return {\n open: function(url, winopts, arg, cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n },\n onOpen: function(cb) {\n setTimeout(function() { cb(\"unsupported browser\"); }, 0);\n }\n };\n }\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n module.exports = WinChan;\n}\n","// given a URL, extract the origin. Taken from: https://github.com/firebase/firebase-simple-login/blob/d2cb95b9f812d8488bdbfba51c3a7c153ba1a074/js/src/simple-login/transports/WinChan.js#L25-L30\nfunction extractOrigin(url) {\n if (!/^https?:\\/\\//.test(url)) url = window.location.href;\n var m = /^(https?:\\/\\/[-_a-zA-Z.0-9:]+)/.exec(url);\n if (m) return m[1];\n return url;\n}\n\nexport default {\n extractOrigin: extractOrigin\n};\n","/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\nimport WinChan from 'winchan';\n\nimport windowHandler from './window';\nimport objectHelper from './object';\nimport qs from 'qs';\n\nfunction PopupHandler() {\n this._current_popup = null;\n}\n\nPopupHandler.prototype.calculatePosition = function(options) {\n var width = options.width || 500;\n var height = options.height || 600;\n var _window = windowHandler.getWindow();\n\n var screenX =\n typeof _window.screenX !== 'undefined'\n ? _window.screenX\n : _window.screenLeft;\n var screenY =\n typeof _window.screenY !== 'undefined'\n ? _window.screenY\n : _window.screenTop;\n\n var outerWidth =\n typeof _window.outerWidth !== 'undefined'\n ? _window.outerWidth\n : _window.document.body.clientWidth;\n\n var outerHeight =\n typeof _window.outerHeight !== 'undefined'\n ? _window.outerHeight\n : _window.document.body.clientHeight;\n\n var left = options.left || screenX + (outerWidth - width) / 2;\n var top = options.top || screenY + (outerHeight - height) / 2;\n\n return { width: width, height: height, left: left, top: top };\n};\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n var url = options.url || 'about:blank';\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, 'auth0_signup_popup', windowFeatures);\n\n this._current_popup.kill = function() {\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, relayUrl, options, cb) {\n var _this = this;\n var popupPosition = this.calculatePosition(options.popupOptions || {});\n var popupOptions = objectHelper\n .merge(popupPosition)\n .with(options.popupOptions);\n\n var winchanOptions = objectHelper\n .merge({\n url: url,\n relay_url: relayUrl,\n window_features: qs.stringify(popupOptions, {\n delimiter: ',',\n encode: false\n }),\n popup: this._current_popup\n })\n .with(options);\n\n var popup = WinChan.open(winchanOptions, function(err, data) {\n // Ignores messages sent by browser extensions.\n if (err && err.name === 'SyntaxError') {\n return;\n }\n _this._current_popup = null;\n return cb(err, data);\n });\n\n popup.focus();\n\n return popup;\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport WinChan from 'winchan';\n\nimport urlHelper from '../helper/url';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\nimport PopupHandler from '../helper/popup-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport TransactionManager from './transaction-manager';\nimport CrossOriginAuthentication from './cross-origin-authentication';\n\nfunction Popup(webAuth, options) {\n this.baseOptions = options;\n this.baseOptions.popupOrigin = options.popupOrigin;\n this.client = webAuth.client;\n this.webAuth = webAuth;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n webAuth,\n this.baseOptions\n );\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * Returns a new instance of the popup handler\n *\n * @method buildPopupHandler\n * @private\n */\nPopup.prototype.buildPopupHandler = function() {\n var pluginHandler = this.baseOptions.plugins.get('popup.getPopupHandler');\n\n if (pluginHandler) {\n return pluginHandler.getPopupHandler();\n }\n\n return new PopupHandler();\n};\n\n/**\n * Initializes the popup window and returns the instance to be used later in order to avoid being blocked by the browser.\n *\n * @method preload\n * @param {Object} options receives the window height and width and any other window feature to be sent to window.open\n */\nPopup.prototype.preload = function(options) {\n options = options || {};\n\n var popup = this.buildPopupHandler();\n\n popup.preload(options);\n return popup;\n};\n\n/**\n * Internal use.\n *\n * @method getPopupHandler\n * @private\n */\nPopup.prototype.getPopupHandler = function(options, preload) {\n if (options.popupHandler) {\n return options.popupHandler;\n }\n\n if (preload) {\n return this.preload(options);\n }\n\n return this.buildPopupHandler();\n};\n\n/**\n * Handles the popup logic for the callback page.\n *\n * @method callback\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @see {@link parseHash}\n */\nPopup.prototype.callback = function(options) {\n var _this = this;\n var theWindow = windowHelper.getWindow();\n options = options || {};\n var originUrl =\n options.popupOrigin ||\n this.baseOptions.popupOrigin ||\n windowHelper.getOrigin();\n\n /*\n in IE 11, there's a bug that makes window.opener return undefined.\n The callback page will still call `popup.callback()` which will run this method\n in the relay page. WinChan expects the relay page to have a global `doPost` function,\n which will be called with the response.\n\n IE11 Bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/110920/\n */\n if (!theWindow.opener) {\n theWindow.doPost = function(msg) {\n if (theWindow.parent) {\n theWindow.parent.postMessage(msg, originUrl);\n }\n };\n return;\n }\n\n WinChan.onOpen(function(popupOrigin, r, cb) {\n if (popupOrigin !== originUrl) {\n return cb({\n error: 'origin_mismatch',\n error_description:\n \"The popup's origin (\" +\n popupOrigin +\n ') should match the `popupOrigin` parameter (' +\n originUrl +\n ').'\n });\n }\n _this.webAuth.parseHash(options || {}, function(err, data) {\n return cb(err || data);\n });\n });\n};\n\n/**\n * Shows inside a new window the hosted login page (`/authorize`) in order to start a new authN/authZ transaction and post its result using `postMessage`.\n *\n * @method authorize\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Boolean} [options.owp] determines if Auth0 should render the relay page or not and the caller is responsible of handling the response.\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nPopup.prototype.authorize = function(options, cb) {\n var popup;\n var url;\n var relayUrl;\n var popOpts = {};\n\n var pluginHandler = this.baseOptions.plugins.get('popup.authorize');\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'scope',\n 'domain',\n 'audience',\n 'tenant',\n 'responseType',\n 'redirectUri',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(objectHelper.blacklist(options, ['popupHandler']));\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n // the relay page should not be necessary as long it happens in the same domain\n // (a redirectUri shoul be provided). It is necessary when using OWP\n relayUrl = urljoin(this.baseOptions.rootUrl, 'relay.html');\n\n // if a owp is enabled, it should use the owp flag\n if (options.owp) {\n // used by server to render the relay page instead of sending the chunk in the\n // url to the callback\n params.owp = true;\n } else {\n popOpts.origin = urlHelper.extractOrigin(params.redirectUri);\n relayUrl = params.redirectUri;\n }\n\n if (options.popupOptions) {\n popOpts.popupOptions = objectHelper.pick(options.popupOptions, [\n 'width',\n 'height',\n 'top',\n 'left'\n ]);\n }\n\n if (pluginHandler) {\n params = pluginHandler.processParams(params);\n }\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n delete params.domain;\n\n url = this.client.buildAuthorizeUrl(params);\n\n popup = this.getPopupHandler(options);\n\n return popup.load(\n url,\n relayUrl,\n popOpts,\n responseHandler(cb, { keepOriginalCasing: true })\n );\n};\n\n/**\n * Performs authentication with username/email and password with a database connection inside a new window\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method loginWithCredentials\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`. The `query` value is only supported when `responseType` is `code`.\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nPopup.prototype.loginWithCredentials = function(options, cb) {\n options.realm = options.realm || options.connection;\n options.popup = true;\n options = objectHelper\n .merge(this.baseOptions, ['redirectUri', 'responseType', 'state', 'nonce'])\n .with(objectHelper.blacklist(options, ['popupHandler', 'connection']));\n options = this.transactionManager.process(options);\n this.crossOriginAuthentication.login(options, cb);\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nPopup.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n return this.client.passwordless.verify(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n\n options.username = options.phoneNumber || options.email;\n options.password = options.verificationCode;\n\n delete options.email;\n delete options.phoneNumber;\n delete options.verificationCode;\n delete options.type;\n\n _this.client.loginWithResourceOwner(options, cb);\n }\n );\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link signupAndAuthorize}.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nPopup.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n _this.loginWithCredentials(options, cb);\n });\n};\n\nexport default Popup;\n","import IframeHandler from '../helper/iframe-handler';\nimport windowHelper from '../helper/window';\n\nfunction SilentAuthenticationHandler(options) {\n this.authenticationUrl = options.authenticationUrl;\n this.timeout = options.timeout || 60 * 1000;\n this.handler = null;\n this.postMessageDataType = options.postMessageDataType || false;\n\n // prefer origin from options, fallback to origin from browser, and some browsers (for example MS Edge) don't support origin; fallback to construct origin manually\n this.postMessageOrigin =\n options.postMessageOrigin ||\n windowHelper.getWindow().location.origin ||\n windowHelper.getWindow().location.protocol +\n '//' +\n windowHelper.getWindow().location.hostname +\n (windowHelper.getWindow().location.port\n ? ':' + windowHelper.getWindow().location.port\n : '');\n}\n\nSilentAuthenticationHandler.create = function(options) {\n return new SilentAuthenticationHandler(options);\n};\n\nSilentAuthenticationHandler.prototype.login = function(\n usePostMessage,\n callback\n) {\n this.handler = new IframeHandler({\n auth0: this.auth0,\n url: this.authenticationUrl,\n eventListenerType: usePostMessage ? 'message' : 'load',\n callback: this.getCallbackHandler(callback, usePostMessage),\n timeout: this.timeout,\n eventValidator: this.getEventValidator(),\n timeoutCallback: function() {\n callback(\n null,\n '#error=timeout&error_description=Timeout+during+authentication+renew.'\n );\n },\n usePostMessage: usePostMessage || false\n });\n\n this.handler.init();\n};\n\nSilentAuthenticationHandler.prototype.getEventValidator = function() {\n var _this = this;\n return {\n isValid: function(eventData) {\n switch (eventData.event.type) {\n case 'message':\n // Message must come from the expected origin and iframe window.\n if (\n eventData.event.origin !== _this.postMessageOrigin ||\n eventData.event.source !== _this.handler.iframe.contentWindow\n ) {\n return false;\n }\n\n // Default behaviour, return all message events from the iframe.\n if (_this.postMessageDataType === false) {\n return true;\n }\n\n return (\n eventData.event.data.type &&\n eventData.event.data.type === _this.postMessageDataType\n );\n\n case 'load':\n if (\n eventData.sourceObject.contentWindow.location.protocol === 'about:'\n ) {\n // Chrome is automatically loading the about:blank page, we ignore this.\n return false;\n }\n // Fall through to default\n default:\n return true;\n }\n }\n };\n};\n\nSilentAuthenticationHandler.prototype.getCallbackHandler = function(\n callback,\n usePostMessage\n) {\n return function(eventData) {\n var callbackValue;\n if (!usePostMessage) {\n callbackValue = eventData.sourceObject.contentWindow.location.hash;\n } else if (\n typeof eventData.event.data === 'object' &&\n eventData.event.data.hash\n ) {\n callbackValue = eventData.event.data.hash;\n } else {\n callbackValue = eventData.event.data;\n }\n callback(null, callbackValue);\n };\n};\n\nexport default SilentAuthenticationHandler;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport windowHelper from '../helper/window';\nimport TransactionManager from './transaction-manager';\n\nfunction UsernamePassword(options) {\n this.baseOptions = options;\n this.request = new RequestBuilder(options);\n this.transactionManager = new TransactionManager(this.baseOptions);\n}\n\nUsernamePassword.prototype.login = function(options, cb) {\n var url;\n var body;\n\n url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'login');\n\n options.username = options.username || options.email; // eslint-disable-line\n\n options = objectHelper.blacklist(options, ['email']); // eslint-disable-line\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience'\n ])\n .with(options);\n body = this.transactionManager.process(body);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nUsernamePassword.prototype.callback = function(formHtml) {\n var div;\n var form;\n var _document = windowHelper.getDocument();\n\n div = _document.createElement('div');\n div.innerHTML = formHtml;\n form = _document.body.appendChild(div).children[0];\n\n form.submit();\n};\n\nexport default UsernamePassword;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport UsernamePassword from './username-password';\nimport RequestBuilder from '../helper/request-builder';\nimport responseHandler from '../helper/response-handler';\nimport objectHelper from '../helper/object';\nimport windowHelper from '../helper/window';\nimport Warn from '../helper/warn';\nimport assert from '../helper/assert';\n\nfunction HostedPages(client, options) {\n this.baseOptions = options;\n this.client = client;\n this.baseOptions.universalLoginPage = true;\n this.request = new RequestBuilder(this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n}\n\n/**\n * @callback credentialsCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the AuthN request\n * @param {String} result.accessToken token that can be used with {@link userinfo}\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Performs authentication with username/email and password with a database connection\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link authorize} or {@link login}.\n *\n * @method login\n * @param {Object} options\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used. It can be any of the values `code` and `token`\n * @param {String} [options.responseMode] how the AuthN response is encoded and redirected back to the client. Supported values are `query` and `fragment`\n * @param {String} [options.scope] scopes to be requested during AuthN. e.g. `openid email`\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.login = function(options, cb) {\n if (windowHelper.getWindow().location.host !== this.baseOptions.domain) {\n throw new Error(\n 'This method is meant to be used only inside the Universal Login Page.'\n );\n }\n var usernamePassword;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'tenant',\n 'responseType',\n 'responseMode',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n usernamePassword = new UsernamePassword(this.baseOptions);\n return usernamePassword.login(params, function(err, data) {\n if (err) {\n return cb(err);\n }\n return usernamePassword.callback(data);\n });\n};\n\n/**\n * Signs up a new user and automatically logs the user in after the signup.\n *\n * @method signupAndLogin\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {credentialsCallback} cb\n */\nHostedPages.prototype.signupAndLogin = function(options, cb) {\n var _this = this;\n return _this.client.client.dbConnection.signup(options, function(err) {\n if (err) {\n return cb(err);\n }\n return _this.login(options, cb);\n });\n};\n\nHostedPages.prototype.getSSOData = function(withActiveDirectories, cb) {\n var url;\n var params = '';\n\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n withActiveDirectories = false;\n }\n\n assert.check(withActiveDirectories, {\n type: 'boolean',\n message: 'withActiveDirectories parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (withActiveDirectories) {\n params =\n '?' +\n qs.stringify({\n ldaps: 1,\n client_id: this.baseOptions.clientID\n });\n }\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'ssodata', params);\n\n return this.request\n .get(url, { noHeaders: true })\n .withCredentials()\n .end(responseHandler(cb));\n};\n\nexport default HostedPages;\n","// eslint-disable-next-line no-unused-vars\nimport Authentication from '../authentication';\nimport object from '../helper/object';\n\nvar noop = function () { };\n\nvar defaults = {\n lang: 'en',\n templates: {\n 'auth0': function (challenge) {\n var message = challenge.type === 'code' ?\n 'Enter the code shown above' :\n 'Solve the formula shown above';\n return '
\\n' +\n ' \\n' +\n ' \\n' +\n '
\\n' +\n '';\n }\n ,\n 'recaptcha_v2': function () {\n return '
';\n }\n ,\n 'error': function () {\n return '
Error getting the bot detection challenge. Please contact the system administrator.
'\n }\n }\n};\n\nfunction handleAuth0Provider(element, options, challenge, load) {\n element.innerHTML = options.templates[challenge.provider](challenge);\n element.querySelector('.captcha-reload').addEventListener('click', function (e) {\n e.preventDefault();\n load();\n });\n}\n\nfunction injectRecaptchaScript(element, lang, callback) {\n var callbackName = 'recaptchaCallback_' + Math.floor(Math.random() * 1000001);\n window[callbackName] = function () {\n delete window[callbackName];\n callback();\n };\n var script = window.document.createElement('script');\n script.src = 'https://www.google.com/recaptcha/api.js?hl=' + lang + '&onload=' + callbackName;\n script.async = true;\n window.document.body.appendChild(script);\n}\n\nfunction handleRecaptchaProvider(element, options, challenge) {\n var widgetId = element.hasAttribute('data-wid') && element.getAttribute('data-wid');\n\n function setValue(value) {\n var input = element.querySelector('input[name=\"captcha\"]');\n input.value = value || '';\n }\n\n if (widgetId) {\n setValue();\n window.grecaptcha.reset(widgetId);\n return;\n }\n\n element.innerHTML = options.templates[challenge.provider](challenge);\n\n var recaptchaDiv = element.querySelector('.recaptcha');\n\n injectRecaptchaScript(element, options.lang, function () {\n widgetId = window.grecaptcha.render(recaptchaDiv, {\n callback: setValue,\n 'expired-callback': function () { setValue(); },\n 'error-callback': function () { setValue(); },\n sitekey: challenge.siteKey\n });\n element.setAttribute('data-wid', widgetId)\n });\n}\n\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n *\n * @param {Authentication} auth0Client The challenge response from the authentication server\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha*\n * @param {Function} [callback] an optional callback function\n */\nfunction render(auth0Client, element, options, callback) {\n options = object.merge(defaults).with(options || {});\n\n function load(done) {\n done = done || noop;\n auth0Client.getChallenge(function (err, challenge) {\n if (err) {\n element.innerHTML = options.templates.error(err);\n return done(err);\n }\n if (!challenge.required) {\n element.style.display = 'none';\n element.innerHTML = '';\n return;\n }\n element.style.display = '';\n if (challenge.provider === 'auth0') {\n handleAuth0Provider(element, options, challenge, load);\n } else if (challenge.provider === 'recaptcha_v2') {\n handleRecaptchaProvider(element, options, challenge);\n }\n done();\n });\n }\n\n function getValue() {\n var captchaInput = element.querySelector('input[name=\"captcha\"]');\n if (!captchaInput) { return; }\n return captchaInput.value;\n }\n\n load(callback);\n\n return {\n reload: load,\n getValue: getValue\n };\n}\n\nexport default { render: render };\n","import IdTokenVerifier from 'idtoken-verifier';\nimport qs from 'qs';\n\nimport assert from '../helper/assert';\nimport error from '../helper/error';\nimport PluginHandler from '../helper/plugins';\nimport windowHelper from '../helper/window';\nimport objectHelper from '../helper/object';\nimport SSODataStorage from '../helper/ssodata';\nimport responseHandler from '../helper/response-handler';\nimport TransactionManager from './transaction-manager';\nimport Authentication from '../authentication';\nimport Redirect from './redirect';\nimport Popup from './popup';\nimport SilentAuthenticationHandler from './silent-authentication-handler';\nimport CrossOriginAuthentication from './cross-origin-authentication';\nimport WebMessageHandler from './web-message-handler';\nimport HostedPages from './hosted-pages';\nimport captcha from './captcha';\n\nfunction defaultClock() {\n return new Date();\n}\n\n/**\n * Handles all the browser's AuthN/AuthZ flows\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Number} [options.leeway] number of seconds to account for clock skew when validating time-based claims in ID tokens. Defaults to 60 seconds.\n * @param {Number} [options.maxAge] maximum elapsed time in seconds since the last time the user was actively authenticated by the authorization server.\n * @param {Array} [options.plugins]\n * @param {Number} [options._timesToRetryFailedRequests] Number of times to retry a failed request, according to {@link https://github.com/visionmedia/superagent/blob/master/lib/request-base.js}\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction WebAuth(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n popupOrigin: {\n optional: true,\n type: 'string',\n message: 'popupOrigin is not valid'\n },\n leeway: {\n optional: true,\n type: 'number',\n message: 'leeway is not valid'\n },\n plugins: {\n optional: true,\n type: 'array',\n message: 'plugins is not valid'\n },\n maxAge: {\n optional: true,\n type: 'number',\n message: 'maxAge is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n _timesToRetryFailedRequests: {\n optional: true,\n type: 'number',\n message: '_timesToRetryFailedRequests option is not valid'\n }\n }\n );\n\n if (options.overrides) {\n assert.check(\n options.overrides,\n { type: 'object', message: 'overrides option is not valid' },\n {\n __tenant: {\n optional: true,\n type: 'string',\n message: '__tenant option is required'\n },\n __token_issuer: {\n optional: true,\n type: 'string',\n message: '__token_issuer option is required'\n },\n __jwks_uri: {\n optional: true,\n type: 'string',\n message: '__jwks_uri is required'\n }\n }\n );\n }\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions.plugins = new PluginHandler(\n this,\n this.baseOptions.plugins || []\n );\n\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n\n this.baseOptions._timesToRetryFailedRequests = options._timesToRetryFailedRequests\n ? parseInt(options._timesToRetryFailedRequests, 0)\n : 0;\n\n this.baseOptions.tenant =\n (this.baseOptions.overrides && this.baseOptions.overrides.__tenant) ||\n this.baseOptions.domain.split('.')[0];\n\n this.baseOptions.token_issuer =\n (this.baseOptions.overrides && this.baseOptions.overrides.__token_issuer) ||\n 'https://' + this.baseOptions.domain + '/';\n\n this.baseOptions.jwksURI =\n this.baseOptions.overrides && this.baseOptions.overrides.__jwks_uri;\n\n this.transactionManager = new TransactionManager(this.baseOptions);\n\n this.client = new Authentication(this.baseOptions);\n this.redirect = new Redirect(this, this.baseOptions);\n this.popup = new Popup(this, this.baseOptions);\n this.crossOriginAuthentication = new CrossOriginAuthentication(\n this,\n this.baseOptions\n );\n this.webMessageHandler = new WebMessageHandler(this);\n this._universalLogin = new HostedPages(this, this.baseOptions);\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Parse the url hash and extract the Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method parseHash\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `token`, `id_token`. For this specific method, we'll only use this value to check if the hash contains the tokens requested in the responseType.\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.parseHash = function(options, cb) {\n var parsedQs;\n var err;\n\n if (!cb && typeof options === 'function') {\n cb = options;\n options = {};\n } else {\n options = options || {};\n }\n\n var _window = windowHelper.getWindow();\n\n var hashStr =\n options.hash === undefined ? _window.location.hash : options.hash;\n hashStr = hashStr.replace(/^#?\\/?/, '');\n\n parsedQs = qs.parse(hashStr);\n\n if (parsedQs.hasOwnProperty('error')) {\n err = error.buildResponse(parsedQs.error, parsedQs.error_description);\n\n if (parsedQs.state) {\n err.state = parsedQs.state;\n }\n\n return cb(err);\n }\n\n if (\n !parsedQs.hasOwnProperty('access_token') &&\n !parsedQs.hasOwnProperty('id_token') &&\n !parsedQs.hasOwnProperty('refresh_token')\n ) {\n return cb(null, null);\n }\n var responseTypes = (\n this.baseOptions.responseType ||\n options.responseType ||\n ''\n ).split(' ');\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('token') !== -1 &&\n !parsedQs.hasOwnProperty('access_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `token`, but the parsed hash does not contain an `access_token` property'\n )\n );\n }\n if (\n responseTypes.length > 0 &&\n responseTypes.indexOf('id_token') !== -1 &&\n !parsedQs.hasOwnProperty('id_token')\n ) {\n return cb(\n error.buildResponse(\n 'invalid_hash',\n 'response_type contains `id_token`, but the parsed hash does not contain an `id_token` property'\n )\n );\n }\n return this.validateAuthenticationResponse(options, parsedQs, cb);\n};\n\n/**\n * Validates an Auth response from a Auth flow started with {@link authorize}\n *\n * Only validates id_tokens signed by Auth0 using the RS256 algorithm using the public key exposed\n * by the `/.well-known/jwks.json` endpoint of your account.\n * Tokens signed with the HS256 algorithm cannot be properly validated.\n * Instead, a call to {@link userInfo} will be made with the parsed `access_token`.\n * If the {@link userInfo} call fails, the {@link userInfo} error will be passed to the callback.\n * Tokens signed with other algorithms will not be accepted.\n *\n * @method validateAuthenticationResponse\n * @param {Object} options\n * @param {String} options.hash the url hash. If not provided it will extract from window.location.hash\n * @param {String} [options.state] value originally sent in `state` parameter to {@link authorize} to mitigate XSRF\n * @param {String} [options.nonce] value originally sent in `nonce` parameter to {@link authorize} to prevent replay attacks\n * @param {Object} parsedHash an object that represents the parsed hash\n * @param {authorizeCallback} cb\n */\nWebAuth.prototype.validateAuthenticationResponse = function(\n options,\n parsedHash,\n cb\n) {\n var _this = this;\n options.__enableIdPInitiatedLogin =\n options.__enableIdPInitiatedLogin || options.__enableImpersonation;\n var state = parsedHash.state;\n var transaction = this.transactionManager.getStoredTransaction(state);\n var transactionState =\n options.state || (transaction && transaction.state) || null;\n\n var transactionStateMatchesState = transactionState === state;\n var shouldBypassStateChecking =\n !state && !transactionState && options.__enableIdPInitiatedLogin;\n\n if (!shouldBypassStateChecking && !transactionStateMatchesState) {\n return cb({\n error: 'invalid_token',\n errorDescription: '`state` does not match.'\n });\n }\n var transactionNonce =\n options.nonce || (transaction && transaction.nonce) || null;\n\n var appState = options.state || (transaction && transaction.appState) || null;\n\n var callback = function(err, payload) {\n if (err) {\n return cb(err);\n }\n if (transaction && transaction.lastUsedConnection) {\n var sub;\n if (payload) {\n sub = payload.sub;\n }\n _this.ssodataStorage.set(transaction.lastUsedConnection, sub);\n }\n return cb(null, buildParseHashResponse(parsedHash, appState, payload));\n };\n\n if (!parsedHash.id_token) {\n return callback(null, null);\n }\n return this.validateToken(parsedHash.id_token, transactionNonce, function(\n validationError,\n payload\n ) {\n if (!validationError) {\n if (!parsedHash.access_token) {\n return callback(null, payload);\n }\n // id_token's generated by non-oidc applications don't have at_hash\n if (!payload.at_hash) {\n return callback(null, payload);\n }\n // here we're absolutely sure that the id_token's alg is RS256\n // and that the id_token is valid, so we can check the access_token\n return new IdTokenVerifier().validateAccessToken(\n parsedHash.access_token,\n 'RS256',\n payload.at_hash,\n function(err) {\n if (err) {\n return callback(error.invalidToken(err.message));\n }\n return callback(null, payload);\n }\n );\n }\n\n if (\n validationError.error !== 'invalid_token' ||\n (validationError.errorDescription &&\n validationError.errorDescription.indexOf(\n 'Nonce (nonce) claim value mismatch in the ID token'\n ) > -1)\n ) {\n return callback(validationError);\n }\n\n // if it's an invalid_token error, decode the token\n var decodedToken = new IdTokenVerifier().decode(parsedHash.id_token);\n\n // if the alg is not HS256, return the raw error\n if (decodedToken.header.alg !== 'HS256') {\n return callback(validationError);\n }\n\n if ((decodedToken.payload.nonce || null) !== transactionNonce) {\n return callback({\n error: 'invalid_token',\n errorDescription:\n 'Nonce (nonce) claim value mismatch in the ID token; expected \"' +\n transactionNonce +\n '\", found \"' +\n decodedToken.payload.nonce +\n '\"'\n });\n }\n\n if (!parsedHash.access_token) {\n var noAccessTokenError = {\n error: 'invalid_token',\n description:\n 'The id_token cannot be validated because it was signed with the HS256 algorithm and public clients (like a browser) can’t store secrets. Please read the associated doc for possible ways to fix this. Read more: https://auth0.com/docs/errors/libraries/auth0-js/invalid-token#parsing-an-hs256-signed-id-token-without-an-access-token'\n };\n return callback(noAccessTokenError);\n }\n\n // if the alg is HS256, use the /userinfo endpoint to build the payload\n return _this.client.userInfo(parsedHash.access_token, function(\n errUserInfo,\n profile\n ) {\n // if the /userinfo request fails, use the validationError instead\n if (errUserInfo) {\n return callback(errUserInfo);\n }\n return callback(null, profile);\n });\n });\n};\n\nfunction buildParseHashResponse(qsParams, appState, token) {\n return {\n accessToken: qsParams.access_token || null,\n idToken: qsParams.id_token || null,\n idTokenPayload: token || null,\n appState: appState || null,\n refreshToken: qsParams.refresh_token || null,\n state: qsParams.state || null,\n expiresIn: qsParams.expires_in ? parseInt(qsParams.expires_in, 10) : null,\n tokenType: qsParams.token_type || null,\n scope: qsParams.scope || null\n };\n}\n\n/**\n * @callback validateTokenCallback\n * @param {Error} [err] error returned by while validating the token\n * @param {Object} [payload] claims stored in the token\n */\n\n/**\n * Decodes the a JWT and verifies its nonce value\n *\n * @method validateToken\n * @private\n * @param {String} token\n * @param {String} nonce\n * @param {validateTokenCallback} cb\n */\nWebAuth.prototype.validateToken = function(token, nonce, cb) {\n var verifier = new IdTokenVerifier({\n issuer: this.baseOptions.token_issuer,\n jwksURI: this.baseOptions.jwksURI,\n audience: this.baseOptions.clientID,\n leeway: this.baseOptions.leeway || 60,\n maxAge: this.baseOptions.maxAge,\n __clock: this.baseOptions.__clock || defaultClock\n });\n\n verifier.verify(token, nonce, function(err, payload) {\n if (err) {\n return cb(error.invalidToken(err.message));\n }\n\n cb(null, payload);\n });\n};\n\n/**\n * Executes a silent authentication transaction under the hood in order to fetch a new tokens for the current session.\n * This method requires that all Auth is performed with {@link authorize}\n * Watch out! If you're not using the hosted login page to do social logins, you have to use your own [social connection keys](https://manage.auth0.com/#/connections/social). If you use Auth0's dev keys, you'll always get `login_required` as an error when calling this method.\n *\n * @method renewAuth\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.postMessageDataType] identifier data type to look for in postMessage event data, where events are initiated from silent callback urls, before accepting a message event is the event expected. A value of false means any postMessage event will trigger a callback.\n * @param {String} [options.postMessageOrigin] origin of redirectUri to expect postMessage response from. Defaults to the origin of the receiving window. Only used if usePostMessage is truthy.\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {Boolean} [options.usePostMessage] use postMessage to comunicate between the silent callback and the SPA. When false the SDK will attempt to parse the url hash should ignore the url hash and no extra behaviour is needed\n * @param {authorizeCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.renewAuth = function(options, cb) {\n var handler;\n var usePostMessage = !!options.usePostMessage;\n var postMessageDataType = options.postMessageDataType || false;\n var postMessageOrigin =\n options.postMessageOrigin || windowHelper.getWindow().origin;\n var timeout = options.timeout;\n var _this = this;\n\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'redirectUri',\n 'responseType',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n params.responseType = params.responseType || 'token';\n params.responseMode = params.responseMode || 'fragment';\n params = this.transactionManager.process(params);\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params.prompt = 'none';\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType',\n 'postMessageOrigin'\n ]);\n\n handler = SilentAuthenticationHandler.create({\n authenticationUrl: this.client.buildAuthorizeUrl(params),\n postMessageDataType: postMessageDataType,\n postMessageOrigin: postMessageOrigin,\n timeout: timeout\n });\n\n handler.login(usePostMessage, function(err, hash) {\n if (typeof hash === 'object') {\n // hash was already parsed, so we just return it.\n // it's here to be backwards compatible and should be removed in the next major version.\n return cb(err, hash);\n }\n _this.parseHash({ hash: hash }, cb);\n });\n};\n\n/**\n * Renews an existing session on Auth0's servers using `response_mode=web_message`\n *\n * @method checkSession\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {String} [options.timeout] value in milliseconds used to timeout when the `/authorize` call is failing as part of the silent authentication with postmessage enabled due to a configuration.\n * @param {checkSessionCallback} cb\n * @see {@link https://auth0.com/docs/libraries/auth0js/v9#using-checksession-to-acquire-new-tokens}\n */\nWebAuth.prototype.checkSession = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n if (params.responseType === 'code') {\n return cb({\n error: 'error',\n error_description: \"responseType can't be `code`\"\n });\n }\n\n if (!options.nonce) {\n params = this.transactionManager.process(params);\n }\n\n if (!params.redirectUri) {\n return cb({\n error: 'error',\n error_description: \"redirectUri can't be empty\"\n });\n }\n\n assert.check(params, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n params = objectHelper.blacklist(params, [\n 'usePostMessage',\n 'tenant',\n 'postMessageDataType'\n ]);\n this.webMessageHandler.run(\n params,\n responseHandler(cb, { forceLegacyError: true, ignoreCasing: true })\n );\n};\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nWebAuth.prototype.changePassword = function(options, cb) {\n return this.client.dbConnection.changePassword(options, cb);\n};\n\n/**\n * Starts a passwordless authentication transaction.\n *\n * @method passwordlessStart\n * @param {Object} options\n * @param {String} options.send what will be sent via email which could be `link` or `code`. For SMS `code` is the only one valid\n * @param {String} [options.phoneNumber] phone number where to send the `code`. This parameter is mutually exclusive with `email`\n * @param {String} [options.email] email where to send the `code` or `link`. This parameter is mutually exclusive with `phoneNumber`\n * @param {String} options.connection name of the passwordless connection\n * @param {Object} [options.authParams] additional Auth parameters when using `link`\n * @param {Function} cb\n * @see {@link https://auth0.com/docs/api/authentication#passwordless}\n */\nWebAuth.prototype.passwordlessStart = function(options, cb) {\n var authParams = objectHelper\n .merge(this.baseOptions, [\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options.authParams);\n\n options.authParams = this.transactionManager.process(authParams);\n return this.client.passwordless.start(options, cb);\n};\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nWebAuth.prototype.signup = function(options, cb) {\n return this.client.dbConnection.signup(options, cb);\n};\n\n/**\n * Redirects to the hosted login page (`/authorize`) in order to start a new authN/authZ transaction.\n * After that, you'll have to use the {@link parseHash} function at the specified `redirectUri`.\n *\n * @method authorize\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. The `query` value is only supported when `responseType` is `code`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} [options.appState] any values that you want back on the authentication response\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n */\nWebAuth.prototype.authorize = function(options) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n params.scope = params.scope || 'openid profile email';\n\n windowHelper.redirect(this.client.buildAuthorizeUrl(params));\n};\n\n/**\n * Signs up a new user, automatically logs the user in after the signup and returns the user token.\n * The login will be done using /oauth/token with password-realm grant type.\n *\n * @method signupAndAuthorize\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} options.connection name of the connection where the user will be created\n * @param {tokenCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n * @see {@link https://auth0.com/docs/api-auth/grant/password}\n */\nWebAuth.prototype.signupAndAuthorize = function(options, cb) {\n var _this = this;\n\n return this.client.dbConnection.signup(\n objectHelper.blacklist(options, ['popupHandler']),\n function(err) {\n if (err) {\n return cb(err);\n }\n options.realm = options.connection;\n if (!options.username) {\n options.username = options.email;\n }\n _this.client.login(options, cb);\n }\n );\n};\n\n/**\n * @callback crossOriginLoginCallback\n * @param {Error} [err] Authentication error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Logs the user in with username and password using the correct flow based on where it's called from:\n * - If you're calling this method from the Universal Login Page, it will use the usernamepassword/login endpoint\n * - If you're calling this method outside the Universal Login Page, it will use the cross origin authentication (/co/authenticate) flow\n * You can use either `username` or `email` to identify the user, but `username` will take precedence over `email`.\n * After the redirect to `redirectUri`, use {@link parseHash} to retrieve the authentication data.\n * **Notice that when using the cross origin authentication flow, some browsers might not be able to successfully authenticate if 3rd party cookies are disabled. [See here for more information.]{@link https://auth0.com/docs/cross-origin-authentication}.**\n *\n * @method login\n * @see Requires [`Implicit` grant]{@link https://auth0.com/docs/api-auth/grant/implicit}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.username] Username (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.password Password\n * @param {String} [options.realm] Realm used to authenticate the user, it can be a realm name or a database connection name\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.login = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n params.connection = params.realm;\n delete params.realm;\n this._universalLogin.login(params, cb);\n } else {\n this.crossOriginAuthentication.login(params, cb);\n }\n};\n\n/**\n * Logs in the user by verifying the verification code (OTP) using the cross origin authentication (/co/authenticate) flow. You can use either `phoneNumber` or `email` to identify the user.\n * This only works when 3rd party cookies are enabled in the browser. After the /co/authenticate call, you'll have to use the {@link parseHash} function at the `redirectUri` specified in the constructor.\n *\n * @method passwordlessLogin\n * @param {Object} options options used in the {@link authorize} call after the login_ticket is acquired\n * @param {String} [options.phoneNumber] Phone Number (mutually exclusive with email)\n * @param {String} [options.email] Email (mutually exclusive with username)\n * @param {String} options.verificationCode Verification Code (OTP)\n * @param {String} options.connection Passwordless connection to use. It can either be 'sms' or 'email'.\n * @param {crossOriginLoginCallback} cb Callback function called only when an authentication error, like invalid username or password, occurs. For other types of errors, there will be a redirect to the `redirectUri`.\n */\nWebAuth.prototype.passwordlessLogin = function(options, cb) {\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n params = this.transactionManager.process(params);\n\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n this.passwordlessVerify(params, cb);\n } else {\n var crossOriginOptions = objectHelper.extend(\n {\n credentialType: 'http://auth0.com/oauth/grant-type/passwordless/otp',\n realm: params.connection,\n username: params.email || params.phoneNumber,\n otp: params.verificationCode\n },\n objectHelper.blacklist(params, [\n 'connection',\n 'email',\n 'phoneNumber',\n 'verificationCode'\n ])\n );\n this.crossOriginAuthentication.login(crossOriginOptions, cb);\n }\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginAuthenticationCallback\n * @deprecated Use {@link crossOriginVerification} instead.\n */\nWebAuth.prototype.crossOriginAuthenticationCallback = function() {\n this.crossOriginVerification();\n};\n\n/**\n * Runs the callback code for the cross origin authentication call. This method is meant to be called by the cross origin authentication callback url.\n *\n * @method crossOriginVerification\n */\nWebAuth.prototype.crossOriginVerification = function() {\n this.crossOriginAuthentication.callback();\n};\n\n/**\n * Redirects to the auth0 logout endpoint\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n *\n * @method logout\n * @param {Object} [options]\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nWebAuth.prototype.logout = function(options) {\n windowHelper.redirect(this.client.buildLogoutUrl(options));\n};\n\n/**\n * Verifies the passwordless TOTP and redirects to finish the passwordless transaction\n *\n * @method passwordlessVerify\n * @param {Object} options\n * @param {String} options.type `sms` or `email`\n * @param {String} options.phoneNumber only if type = sms\n * @param {String} options.email only if type = email\n * @param {String} options.connection the connection name\n * @param {String} options.verificationCode the TOTP code\n * @param {Function} cb\n */\nWebAuth.prototype.passwordlessVerify = function(options, cb) {\n var _this = this;\n var params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'nonce'\n ])\n .with(options);\n\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n }\n }\n );\n\n params = this.transactionManager.process(params);\n return this.client.passwordless.verify(params, function(err) {\n if (err) {\n return cb(err);\n }\n return windowHelper.redirect(\n _this.client.passwordless.buildVerifyUrl(params)\n );\n });\n};\n\n/**\n *\n * Renders the captcha challenge in the provided element.\n * This function can only be used in the context of a Classic Universal Login Page.\n *\n * @param {HTMLElement} element The element where the captcha needs to be rendered\n * @param {Object} options The configuration options for the captcha\n * @param {Object} [options.templates] An object containaing templates for each captcha provider\n * @param {Function} [options.templates.auth0] template function receiving the challenge and returning an string\n * @param {Function} [options.templates.recaptcha_v2] template function receiving the challenge and returning an string\n * @param {String} [options.lang=en] the ISO code of the language for recaptcha\n * @param {Function} [callback] An optional completion callback\n */\nWebAuth.prototype.renderCaptcha = function(element, options, callback) {\n return captcha.render(this.client, element, options, callback);\n};\n\nexport default WebAuth;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport qs from 'qs';\nimport responseHandler from '../helper/response-handler';\n\nfunction PasswordlessAuthentication(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\nPasswordlessAuthentication.prototype.buildVerifyUrl = function(options) {\n var params;\n var qString;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience',\n '_csrf',\n 'state',\n '_intstate',\n 'protocol',\n 'nonce'\n ])\n .with(options);\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n\n qString = qs.stringify(params);\n\n return urljoin(\n this.baseOptions.rootUrl,\n 'passwordless',\n 'verify_redirect',\n '?' + qString\n );\n};\n\nPasswordlessAuthentication.prototype.start = function(options, cb) {\n var url;\n var body;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n send: {\n type: 'string',\n message: 'send option is required',\n values: ['link', 'code'],\n value_message: 'send is not valid ([link, code])'\n },\n phoneNumber: {\n optional: true,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return o.send === 'code' || !o.email;\n }\n },\n email: {\n optional: true,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return o.send === 'link' || !o.phoneNumber;\n }\n },\n authParams: {\n optional: true,\n type: 'object',\n message: 'authParams option is required'\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'start');\n\n body = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'redirectUri',\n 'scope'\n ])\n .with(options);\n\n if (body.scope) {\n body.authParams = body.authParams || {};\n body.authParams.scope = body.authParams.scope || body.scope;\n }\n\n if (body.redirectUri) {\n body.authParams = body.authParams || {};\n body.authParams.redirect_uri =\n body.authParams.redirectUri || body.redirectUri;\n }\n\n if (body.responseType) {\n body.authParams = body.authParams || {};\n body.authParams.response_type =\n body.authParams.responseType || body.responseType;\n }\n\n delete body.redirectUri;\n delete body.responseType;\n delete body.scope;\n\n body = objectHelper.toSnakeCase(body, ['auth0Client', 'authParams']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nPasswordlessAuthentication.prototype.verify = function(options, cb) {\n var url;\n var cleanOption;\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n verificationCode: {\n type: 'string',\n message: 'verificationCode option is required'\n },\n phoneNumber: {\n optional: false,\n type: 'string',\n message: 'phoneNumber option is required',\n condition: function(o) {\n return !o.email;\n }\n },\n email: {\n optional: false,\n type: 'string',\n message: 'email option is required',\n condition: function(o) {\n return !o.phoneNumber;\n }\n }\n }\n );\n /* eslint-enable */\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n cleanOption = objectHelper.pick(options, [\n 'connection',\n 'verificationCode',\n 'phoneNumber',\n 'email',\n 'auth0Client'\n ]);\n cleanOption = objectHelper.toSnakeCase(cleanOption, ['auth0Client']);\n\n url = urljoin(this.baseOptions.rootUrl, 'passwordless', 'verify');\n\n return this.request\n .post(url)\n .send(cleanOption)\n .end(responseHandler(cb));\n};\n\nexport default PasswordlessAuthentication;\n","import urljoin from 'url-join';\n\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\nfunction DBConnection(request, options) {\n this.baseOptions = options;\n this.request = request;\n}\n\n/**\n * @callback signUpCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the signup failed\n * @param {Object} [result] result of the signup request\n * @param {Object} result.email user's email\n * @param {Object} result.emailVerified if the user's email was verified\n */\n\n/**\n * Creates a new user in a Auth0 Database connection\n *\n * @method signup\n * @param {Object} options\n * @param {String} options.email user email address\n * @param {String} options.password user password\n * @param {String} [options.username] user desired username. Required if you use a database connection and you have enabled `Requires Username`\n * @param {String} options.connection name of the connection where the user will be created\n * @param {Object} [options.user_metadata] additional signup attributes used for creating the user. Will be stored in `user_metadata`\n * @param {signUpCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#signup}\n */\nDBConnection.prototype.signup = function(options, cb) {\n var url;\n var body;\n var metadata;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' },\n password: { type: 'string', message: 'password option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'signup');\n\n body = objectHelper.merge(this.baseOptions, ['clientID', 'state']).with(options);\n\n metadata = body.user_metadata || body.userMetadata;\n\n body = objectHelper.blacklist(body, [\n 'scope',\n 'userMetadata',\n 'user_metadata'\n ]);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n if (metadata) {\n body.user_metadata = metadata;\n }\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * @callback changePasswordCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the request failed\n */\n\n/**\n * Request an email with instruction to change a user's password\n *\n * @method changePassword\n * @param {Object} options\n * @param {String} options.email address where the user will receive the change password email. It should match the user's email in Auth0\n * @param {String} options.connection name of the connection where the user was created\n * @param {changePasswordCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#change-password}\n */\nDBConnection.prototype.changePassword = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n connection: { type: 'string', message: 'connection option is required' },\n email: { type: 'string', message: 'email option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'dbconnections', 'change_password');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options, ['email', 'connection']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\nexport default DBConnection;\n","import urljoin from 'url-join';\nimport qs from 'qs';\n\nimport RequestBuilder from '../helper/request-builder';\nimport objectHelper from '../helper/object';\nimport assert from '../helper/assert';\nimport SSODataStorage from '../helper/ssodata';\nimport windowHelper from '../helper/window';\nimport responseHandler from '../helper/response-handler';\nimport parametersWhitelist from '../helper/parameters-whitelist';\nimport Warn from '../helper/warn';\nimport WebAuth from '../web-auth/index';\nimport PasswordlessAuthentication from './passwordless-authentication';\nimport DBConnection from './db-connection';\n\n/**\n * Creates a new Auth0 Authentication API client\n * @constructor\n * @param {Object} options\n * @param {String} options.domain your Auth0 domain\n * @param {String} options.clientID the Client ID found on your Application settings page\n * @param {String} [options.redirectUri] url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} [options.responseType] type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication}\n */\nfunction Authentication(auth0, options) {\n // If we have two arguments, the first one is a WebAuth instance, so we assign that\n // if not, it's an options object and then we should use that as options instead\n // this is here because we don't want to break people coming from v8\n if (arguments.length === 2) {\n this.auth0 = auth0;\n } else {\n options = auth0;\n }\n\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n clientID: { type: 'string', message: 'clientID option is required' },\n responseType: {\n optional: true,\n type: 'string',\n message: 'responseType is not valid'\n },\n responseMode: {\n optional: true,\n type: 'string',\n message: 'responseMode is not valid'\n },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri is not valid'\n },\n scope: { optional: true, type: 'string', message: 'scope is not valid' },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience is not valid'\n },\n _disableDeprecationWarnings: {\n optional: true,\n type: 'boolean',\n message: '_disableDeprecationWarnings option is not valid'\n },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n },\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n this.baseOptions._sendTelemetry =\n this.baseOptions._sendTelemetry === false\n ? this.baseOptions._sendTelemetry\n : true;\n \n this.baseOptions.rootUrl = (this.baseOptions.domain && this.baseOptions.domain.toLowerCase().indexOf('http') === 0)\n ? this.baseOptions.domain\n : 'https://' + this.baseOptions.domain;\n \n this.request = new RequestBuilder(this.baseOptions);\n\n this.passwordless = new PasswordlessAuthentication(\n this.request,\n this.baseOptions\n );\n this.dbConnection = new DBConnection(this.request, this.baseOptions);\n\n this.warn = new Warn({\n disableWarnings: !!options._disableDeprecationWarnings\n });\n this.ssodataStorage = new SSODataStorage(this.baseOptions);\n}\n\n/**\n * Builds and returns the `/authorize` url in order to initialize a new authN/authZ transaction\n *\n * @method buildAuthorizeUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.redirectUri url that the Auth0 will redirect after Auth with the Authorization Response\n * @param {String} options.responseType type of the response used by OAuth 2.0 flow. It can be any space separated list of the values `code`, `token`, `id_token`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html}\n * @param {String} [options.responseMode] how the Auth response is encoded and redirected back to the client. Supported values are `query`, `fragment` and `form_post`. {@link https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#ResponseModes}\n * @param {String} [options.state] value used to mitigate XSRF attacks. {@link https://auth0.com/docs/protocols/oauth2/oauth-state}\n * @param {String} [options.nonce] value used to mitigate replay attacks when using Implicit Grant. {@link https://auth0.com/docs/api-auth/tutorials/nonce}\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @see {@link https://auth0.com/docs/api/authentication#authorize-client}\n * @see {@link https://auth0.com/docs/api/authentication#social}\n */\nAuthentication.prototype.buildAuthorizeUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, [\n 'clientID',\n 'responseType',\n 'responseMode',\n 'redirectUri',\n 'scope',\n 'audience'\n ])\n .with(options);\n\n /* eslint-disable */\n assert.check(\n params,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n redirectUri: {\n optional: true,\n type: 'string',\n message: 'redirectUri option is required'\n },\n responseType: {\n type: 'string',\n message: 'responseType option is required'\n },\n nonce: {\n type: 'string',\n message: 'nonce option is required',\n condition: function(o) {\n return (\n o.responseType.indexOf('code') === -1 &&\n o.responseType.indexOf('id_token') !== -1\n );\n }\n },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n /* eslint-enable */\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n if (params.connection_scope && assert.isArray(params.connection_scope)) {\n params.connection_scope = params.connection_scope.join(',');\n }\n\n params = objectHelper.blacklist(params, [\n 'username',\n 'popupOptions',\n 'domain',\n 'tenant',\n 'timeout',\n 'appState'\n ]);\n params = objectHelper.toSnakeCase(params, ['auth0Client']);\n params = parametersWhitelist.oauthAuthorizeParams(this.warn, params);\n\n qString = qs.stringify(params);\n\n return urljoin(this.baseOptions.rootUrl, 'authorize', '?' + qString);\n};\n\n/**\n * Builds and returns the Logout url in order to initialize a new authN/authZ transaction\n *\n * If you want to navigate the user to a specific URL after the logout, set that URL at the returnTo parameter. The URL should be included in any the appropriate Allowed Logout URLs list:\n *\n * - If the client_id parameter is included, the returnTo URL must be listed in the Allowed Logout URLs set at the Auth0 Application level (see Setting Allowed Logout URLs at the App Level).\n * - If the client_id parameter is NOT included, the returnTo URL must be listed in the Allowed Logout URLs set at the account level (see Setting Allowed Logout URLs at the Account Level).\n * @method buildLogoutUrl\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} [options.returnTo] URL to be redirected after the logout\n * @param {Boolean} [options.federated] tells Auth0 if it should logout the user also from the IdP.\n * @see {@link https://auth0.com/docs/api/authentication#logout}\n */\nAuthentication.prototype.buildLogoutUrl = function(options) {\n var params;\n var qString;\n\n assert.check(options, {\n optional: true,\n type: 'object',\n message: 'options parameter is not valid'\n });\n\n params = objectHelper\n .merge(this.baseOptions, ['clientID'])\n .with(options || {});\n\n // eslint-disable-next-line\n if (this.baseOptions._sendTelemetry) {\n params.auth0Client = this.request.getTelemetryData();\n }\n\n params = objectHelper.toSnakeCase(params, ['auth0Client', 'returnTo']);\n\n qString = qs.stringify(objectHelper.blacklist(params, ['federated']));\n if (\n options &&\n options.federated !== undefined &&\n options.federated !== false &&\n options.federated !== 'false'\n ) {\n qString += '&federated';\n }\n\n return urljoin(this.baseOptions.rootUrl, 'v2', 'logout', '?' + qString);\n};\n\n/**\n * @callback authorizeCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request. If there is no token available, this value will be null.\n * @param {String} [result.accessToken] token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} [result.expiresIn] number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n * @param {Object} [result.appState] values that you receive back on the authentication response\n */\n\n/**\n * @callback tokenCallback\n * @param {Error} [err] error returned by Auth0 with the reason of the Auth failure\n * @param {Object} [result] result of the Auth request\n * @param {String} result.accessToken token that allows access to the specified resource server (identified by the audience parameter or by default Auth0's /userinfo endpoint)\n * @param {Number} result.expiresIn number of seconds until the access token expires\n * @param {String} [result.idToken] token that identifies the user\n * @param {String} [result.refreshToken] token that can be used to get new access tokens from Auth0. Note that not all Auth0 Applications can request them or the resource server might not allow them.\n */\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password` grant type to login to the default directory.\n *\n * @method loginWithDefaultDirectory\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`password` grant]{@link https://auth0.com/docs/api-auth/grant/password}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.loginWithDefaultDirectory = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'password';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint with `password-realm` grant type\n *\n * @method login\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.audience] identifier of the resource server who will consume the access token issued after Auth\n * @param {Object} options.realm the HRD domain or the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {tokenCallback} cb function called with the result of the request\n * @see Requires [`http://auth0.com/oauth/grant-type/password-realm` grant]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.login = function(options, cb) {\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n realm: { type: 'string', message: 'realm option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n options.grantType = 'http://auth0.com/oauth/grant-type/password-realm';\n\n return this.oauthToken(options, cb);\n};\n\n/**\n * Makes a call to the `oauth/token` endpoint\n *\n * @method oauthToken\n * @private\n */\nAuthentication.prototype.oauthToken = function(options, cb) {\n var url;\n var body;\n\n assert.check(options, {\n type: 'object',\n message: 'options parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'token');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope', 'audience'])\n .with(options);\n\n assert.check(\n body,\n { type: 'object', message: 'options parameter is not valid' },\n {\n clientID: { type: 'string', message: 'clientID option is required' },\n grantType: { type: 'string', message: 'grantType option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n },\n audience: {\n optional: true,\n type: 'string',\n message: 'audience option is required'\n }\n }\n );\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n body = parametersWhitelist.oauthTokenParams(this.warn, body);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Performs authentication calling `/oauth/ro` endpoint with username\n * and password for a given connection name.\n *\n * This method is not compatible with API Auth so if you need to fetch API tokens with audience\n * you should use {@link login} or {@link loginWithDefaultDirectory}.\n *\n * @method loginWithResourceOwner\n * @param {Object} options\n * @param {String} options.username email or username of the user that will perform Auth\n * @param {String} options.password the password of the user that will perform Auth\n * @param {Object} options.connection the connection name where the user belongs to. e.g. `Username-Password-Authentication`\n * @param {String} [options.scope] scopes to be requested during Auth. e.g. `openid email`\n * @param {String} [options.device] name of the device/browser where the Auth was requested\n * @param {tokenCallback} cb function called with the result of the request\n */\nAuthentication.prototype.loginWithResourceOwner = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n username: { type: 'string', message: 'username option is required' },\n password: { type: 'string', message: 'password option is required' },\n connection: { type: 'string', message: 'connection option is required' },\n scope: {\n optional: true,\n type: 'string',\n message: 'scope option is required'\n }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'oauth', 'ro');\n\n body = objectHelper\n .merge(this.baseOptions, ['clientID', 'scope'])\n .with(options, ['username', 'password', 'scope', 'connection', 'device']);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n body.grant_type = body.grant_type || 'password';\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Uses {@link checkSession} and localStorage to return data from the last successful authentication request.\n *\n * @method getSSOData\n * @param {Boolean} withActiveDirectories this parameter is not used anymore. It's here to be backward compatible\n * @param {Function} cb\n */\nAuthentication.prototype.getSSOData = function(withActiveDirectories, cb) {\n /* istanbul ignore if */\n if (!this.auth0) {\n this.auth0 = new WebAuth(this.baseOptions);\n }\n var isHostedLoginPage =\n windowHelper.getWindow().location.host === this.baseOptions.domain;\n if (isHostedLoginPage) {\n return this.auth0._universalLogin.getSSOData(withActiveDirectories, cb);\n }\n if (typeof withActiveDirectories === 'function') {\n cb = withActiveDirectories;\n }\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n var clientId = this.baseOptions.clientID;\n var ssodataInformation = this.ssodataStorage.get() || {};\n\n this.auth0.checkSession(\n {\n responseType: 'token id_token',\n scope: 'openid profile email',\n connection: ssodataInformation.lastUsedConnection,\n timeout: 5000\n },\n function(err, result) {\n if (err) {\n if (err.error === 'login_required') {\n return cb(null, { sso: false });\n }\n if (err.error === 'consent_required') {\n err.error_description =\n 'Consent required. When using `getSSOData`, the user has to be authenticated with the following scope: `openid profile email`.';\n }\n return cb(err, { sso: false });\n }\n if (\n ssodataInformation.lastUsedSub &&\n ssodataInformation.lastUsedSub !== result.idTokenPayload.sub\n ) {\n return cb(err, { sso: false });\n }\n return cb(null, {\n lastUsedConnection: {\n name: ssodataInformation.lastUsedConnection\n },\n lastUsedUserID: result.idTokenPayload.sub,\n lastUsedUsername:\n result.idTokenPayload.email || result.idTokenPayload.name,\n lastUsedClientID: clientId,\n sessionClients: [clientId],\n sso: true\n });\n }\n );\n};\n\n/**\n * @callback userInfoCallback\n * @param {Error} [err] error returned by Auth0\n * @param {Object} [userInfo] user information\n */\n\n/**\n * Makes a call to the `/userinfo` endpoint and returns the user profile\n *\n * @method userInfo\n * @param {String} accessToken token issued to a user after Auth\n * @param {userInfoCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#get-user-info}\n */\nAuthentication.prototype.userInfo = function(accessToken, cb) {\n var url;\n\n assert.check(accessToken, {\n type: 'string',\n message: 'accessToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'userinfo');\n\n return this.request\n .get(url)\n .set('Authorization', 'Bearer ' + accessToken)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Makes a call to the `/usernamepassword/challenge` endpoint\n * and returns the challenge (captcha) if necessary.\n *\n * @method getChallenge\n * @param {callback} cb\n */\nAuthentication.prototype.getChallenge = function(cb) {\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n if (!this.baseOptions.state) {\n return cb();\n }\n\n var url = urljoin(this.baseOptions.rootUrl, 'usernamepassword', 'challenge');\n\n return this.request\n .post(url)\n .send({ state: this.baseOptions.state })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * @callback delegationCallback\n * @param {Error} [err] error returned by Auth0 with the reason why the delegation failed\n * @param {Object} [result] result of the delegation request. The payload depends on what ai type was used\n */\n\n/**\n * Makes a call to the `/delegation` endpoint with either an `id_token` or `refresh_token`\n *\n * @method delegation\n * @param {Object} options\n * @param {String} [options.clientID] the Client ID found on your Application settings page\n * @param {String} options.grantType grant type used for delegation. The only valid value is `urn:ietf:params:oauth:grant-type:jwt-bearer`\n * @param {String} [options.idToken] valid token of the user issued after Auth. If no `refresh_token` is provided this parameter is required\n * @param {String} [options.refreshToken] valid refresh token of the user issued after Auth. If no `id_token` is provided this parameter is required\n * @param {String} [options.target] the target ClientID of the delegation\n * @param {String} [options.scope] either `openid` or `openid profile email`\n * @param {String} [options.apiType] the api to be called\n * @param {delegationCallback} cb\n * @see {@link https://auth0.com/docs/api/authentication#delegation}\n * @see Requires [http://auth0.com/oauth/grant-type/password-realm]{@link https://auth0.com/docs/api-auth/grant/password#realm-support}. For more information, read {@link https://auth0.com/docs/clients/client-grant-types}.\n */\nAuthentication.prototype.delegation = function(options, cb) {\n var url;\n var body;\n\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n grant_type: { type: 'string', message: 'grant_type option is required' }\n }\n );\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'delegation');\n\n body = objectHelper.merge(this.baseOptions, ['clientID']).with(options);\n\n body = objectHelper.toSnakeCase(body, ['auth0Client']);\n\n return this.request\n .post(url)\n .send(body)\n .end(responseHandler(cb));\n};\n\n/**\n * Fetches the user country based on the ip.\n *\n * @method getUserCountry\n * @private\n * @param {Function} cb\n */\nAuthentication.prototype.getUserCountry = function(cb) {\n var url;\n\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'user', 'geoloc', 'country');\n\n return this.request.get(url).end(responseHandler(cb));\n};\n\nexport default Authentication;\n","import urljoin from 'url-join';\n\nimport RequestBuilder from '../helper/request-builder';\nimport assert from '../helper/assert';\nimport responseHandler from '../helper/response-handler';\n\n/**\n * Auth0 Management API Client (methods allowed to be called from the browser only)\n * @constructor\n * @param {Object} options\n * @param {Object} options.domain your Auth0 acount domain\n * @param {Object} options.token a valid API token\n */\nfunction Management(options) {\n /* eslint-disable */\n assert.check(\n options,\n { type: 'object', message: 'options parameter is not valid' },\n {\n domain: { type: 'string', message: 'domain option is required' },\n token: { type: 'string', message: 'token option is required' },\n _sendTelemetry: {\n optional: true,\n type: 'boolean',\n message: '_sendTelemetry option is not valid'\n },\n _telemetryInfo: {\n optional: true,\n type: 'object',\n message: '_telemetryInfo option is not valid'\n }\n }\n );\n /* eslint-enable */\n\n this.baseOptions = options;\n\n this.baseOptions.headers = {\n Authorization: 'Bearer ' + this.baseOptions.token\n };\n\n this.request = new RequestBuilder(this.baseOptions);\n this.baseOptions.rootUrl = urljoin(\n 'https://' + this.baseOptions.domain,\n 'api',\n 'v2'\n );\n}\n\n/**\n * @callback userCallback\n * @param {Error} [err] failure reason for the failed request to Management API\n * @param {Object} [result] user profile\n */\n\n/**\n * Returns the user profile\n *\n * @method getUser\n * @param {String} userId identifier of the user to retrieve\n * @param {userCallback} cb\n * @see https://auth0.com/docs/api/management/v2#!/Users/get_users_by_id\n */\nManagement.prototype.getUser = function(userId, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request.get(url).end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user metdata. It will patch the user metdata with the attributes sent.\n *\n *\n * @method patchUserMetadata\n * @param {String} userId\n * @param {Object} userMetadata\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserMetadata = function(userId, userMetadata, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(userMetadata, {\n type: 'object',\n message: 'userMetadata parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send({ user_metadata: userMetadata })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Updates the user attributes. It will patch the user attributes that the server allows it.\n *\n * @method patchUserAttributes\n * @param {String} userId\n * @param {Object} user\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/patch_users_by_id}\n */\nManagement.prototype.patchUserAttributes = function(userId, user, cb) {\n var url;\n\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(user, {\n type: 'object',\n message: 'user parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId);\n\n return this.request\n .patch(url)\n .send(user)\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\n/**\n * Link two users\n *\n * @method linkUser\n * @param {String} userId\n * @param {String} secondaryUserToken\n * @param {userCallback} cb\n * @see {@link https://auth0.com/docs/api/management/v2#!/Users/post_identities}\n */\nManagement.prototype.linkUser = function(userId, secondaryUserToken, cb) {\n var url;\n /* eslint-disable */\n assert.check(userId, {\n type: 'string',\n message: 'userId parameter is not valid'\n });\n assert.check(secondaryUserToken, {\n type: 'string',\n message: 'secondaryUserToken parameter is not valid'\n });\n assert.check(cb, { type: 'function', message: 'cb parameter is not valid' });\n /* eslint-enable */\n\n url = urljoin(this.baseOptions.rootUrl, 'users', userId, 'identities');\n\n return this.request\n .post(url)\n .send({ link_with: secondaryUserToken })\n .end(responseHandler(cb, { ignoreCasing: true }));\n};\n\nexport default Management;\n","import Authentication from './authentication';\nimport Management from './management';\nimport WebAuth from './web-auth';\nimport version from './version';\n\nexport { Authentication, Management, WebAuth, version };\n\nexport default {\n Authentication: Authentication,\n Management: Management,\n WebAuth: WebAuth,\n version: version\n};\n"],"names":["context","definition","this","normalize","strArray","resultArray","length","TypeError","match","first","shift","replace","i","component","push","str","join","parts","split","arguments","slice","call","module","exports","has","Object","prototype","hasOwnProperty","isArray","Array","hexTable","array","toString","toUpperCase","arrayToObject","source","options","obj","plainObjects","create","assign","target","keys","reduce","acc","key","combine","a","b","concat","compact","value","queue","o","prop","refs","item","j","val","indexOf","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","c","charCodeAt","charAt","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","merge","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","apply","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","object","generateArrayPrefix","filter","sort","v","isNonNullishPrimitive","objKeys","values","keyPrefix","arrayLimit","depth","ignoreQueryPrefix","interpretNumericEntities","parameterLimit","parseArrays","numberStr","fromCharCode","parseArrayValue","parseKeys","givenKey","valuesParsed","child","segment","exec","parent","index","chain","leaf","root","cleanRoot","isNaN","0","parseObject","opts","undefined","normalizeParseOptions","tempObj","cleanStr","limit","Infinity","skipIndex","part","bracketEqualsPos","pos","encodedVal","parseValues","newObj","normalizeStringifyOptions","arrayFormat","joined","Emitter","mixin","on","addEventListener","event","_callbacks","once","off","removeListener","removeAllListeners","removeEventListener","cb","callbacks","splice","emit","args","len","listeners","hasListeners","stable","deterministicStringify","stableStringify","replacerStack","replacer","spacer","res","decirc","k","stack","propertyDescriptor","getOwnPropertyDescriptor","get","configurable","defineProperty","JSON","replaceGetterValues","compareFunction","tmp","deterministicDecirc","toJSON","_typeof","iterator","RequestBase","clearTimeout","_timer","_responseTimeoutTimer","_uploadTimeoutTimer","parse","_parser","responseType","_responseType","serialize","_serializer","timeout","_timeout","_responseTimeout","_uploadTimeout","option","deadline","response","upload","console","warn","retry","count","_maxRetries","_retries","_retryCallback","ERROR_CODES","_shouldRetry","err","override","err_","error","status","code","includes","crossDomain","_retry","req","request","_aborted","timedout","timedoutError","_end","then","resolve","reject","_this","_fullfilledPromise","self","_endCalled","Promise","Error","method","url","end","catch","use","ok","_okCallback","_isResponseOK","field","_header","toLowerCase","getHeader","set","isObject","header","unset","name","_data","_getFormData","append","abort","xhr","_auth","user","pass","base64Encoder","type","username","password","withCredentials","_withCredentials","redirects","n","_maxRedirects","maxResponseSize","_maxResponseSize","data","headers","send","isObj","_formData","_isHost","sortQuery","_sort","_finalizeQueryString","query","_query","queryArr","_appendQueryString","_timeoutError","reason","errno","callback","_setTimeouts","setTimeout","ResponseBase","_toConsumableArray","_arrayLikeToArray","_arrayWithoutHoles","iter","from","_iterableToArray","minLen","test","_unsupportedIterableToArray","_nonIterableSpread","arr2","Agent","_defaults","_setHeaderProperties","ct","params","links","link","_unused","_setStatusProperties","statusCode","statusType","info","redirect","clientError","serverError","toError","created","accepted","noContent","badRequest","unauthorized","notAcceptable","forbidden","notFound","unprocessableEntity","_len","_key","_setDefaults","def","noop","window","Request","getXHR","XMLHttpRequest","location","protocol","ActiveXObject","_unused2","_unused3","_unused4","trim","s","pairs","pushEncodedKeyValuePair","subkey","encodeURI","encodeURIComponent","parseString","pair","isJSON","mime","Response","text","responseText","statusText","line","lines","fields","parseHeader","getAllResponseHeaders","getResponseHeader","body","_parseBody","new_err","original","rawResponse","del","serializeObject","types","html","json","xml","urlencoded","form","form-data","application/x-www-form-urlencoded","application/json","safeStringify","msg","accept","auth","btoa","attach","file","FormData","_callback","retries","crossDomainError","agent","ca","buffer","write","pipe","_setUploadTimeout","onreadystatechange","readyState","_unused5","handleProgress","direction","total","percent","loaded","bind","_unused6","open","contentType","_serialize","setRequestHeader","delete","head","patch","post","put","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","lookup","Uint8Array","start","num","output","base64","fromByteArray","stringToByteArray","mod","padding","result","byteArrayToString","toByteArray","raw","attribute","attr","variable","check","config","attributes","optional","message","condition","value_message","supportsIsArray","objectAssignPolyfill","to","nextSource","keysArray","nextIndex","nextKey","desc","enumerable","pick","prev","objectValues","extend","unshift","objectAssign","getLocationFromUrl","href","host","hostname","port","pathname","search","hash","trimmed","toSnakeCase","exceptions","assert","p","newKey","wasPrevNumber","wasPrevUppercase","camelToSnake","toCamelCase","keepOriginal","blacklist","blacklistedKeys","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","RequestWrapper","RequestObj","RequestBuilder","_sendTelemetry","_telemetryInfo","_timesToRetryFailedRequests","_universalLoginPage","universalLoginPage","getWindow","getMethod","getBody","getUrl","getHeaders","objectHelper","setCommonConfiguration","ongoingRequest","noHeaders","getTelemetryData","telemetryName","clientInfo","version","env","jsonClientInfo","base64Url","getDocument","document","getOrigin","DummyStorage","getItem","removeItem","setItem","factory","init","converter","api","expires","toUTCString","stringifiedAttributes","attributeName","cookie","jar","cookies","read","getJSON","remove","withConverter","CookieStorage","Warn","disableWarnings","StorageHandler","storage","__tryLocalStorageFirst","localStorage","windowHandler","warning","Storage","handler","SSODataStorage","buildResponse","description","errorDescription","Cookie","failover","_","connection","sub","ssodata","lastUsedConnection","lastUsedSub","invalidToken","wrapCallback","ignoreCasing","errObj","error_code","error_description","details","forceLegacyError","error_codes","error_details","errorDetails","codes","policy","keepOriginalCasing","tokenParams","authorizeParams","oauthTokenParams","oauthAuthorizeParams","t","globalThis","global","r","require","l","d","w","h","u","MutationObserver","WebKitMutationObserver","f","process","Uint8ClampedArray","importScripts","MessageChannel","m","y","g","T","S","C","_state","I","_result","A","nextTick","createTextNode","observe","characterData","port1","onmessage","port2","postMessage","Function","runOnLoop","runOnContext","Math","random","substring","D","x","E","B","_onerror","M","_subscribers","R","_instanceConstructor","promise","_remaining","_enumerate","_eachEntry","_settledAt","O","_willSettleAt","finally","all","race","_setScheduler","_setAsap","_asap","polyfill","cast","lib","Base","mixIn","$super","clone","WordArray","words","sigBytes","clamp","ceil","enc","Hex","substr","Latin1","Utf8","BufferedBlockAlgorithm","reset","_nDataBytes","_append","_process","blockSize","max","_minBufferSize","min","_doProcessBlock","Hasher","cfg","_doReset","update","finalize","_doFinalize","_createHelper","_createHmacHelper","HMAC","algo","sqrt","pow","SHA256","_hash","floor","HmacSHA256","Base64","_map","_reverseMap","fromNumber","fromString","navigator","appName","am","DB","DM","DV","FV","F1","F2","fromInt","mp","invDigit","mpl","mph","um","mt2","r2","q3","ONE","dlShiftTo","mu","divide","convert","compareTo","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","abs","ZERO","subTo","copyTo","drShiftTo","fromRadix","lShiftTo","rShiftTo","isEven","exp","negate","toRadix","bitLength","modPowInt","multiplyUpperTo","multiplyLowerTo","dAddOffset","getTime","chunkSize","LN2","log","signum","intValue","dMultiply","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","changeBit","addTo","modInt","millerRabin","subtract","getLowestSetBit","shiftRight","modPow","byteValue","shortValue","equals","and","or","xor","andNot","not","bitCount","setBit","clearBit","flipBit","add","multiply","remainder","divideAndRemainder","modInverse","gcd","square","Barrett","crypto","getRandomValues","appVersion","BigInteger","SecureRandom","sha1","sha224","sha256","sha384","sha512","md2","md5","ripemd160","verify","alg","map","urljoin","responseURL","blob","Blob","entries","onload","onerror","credentials","jwksCache","expectedAlg","issuer","audience","leeway","jwksURI","maxAge","__clock","PluginHandler","webAuth","plugins","pluginName","setWebAuth","encoded","payload","signature","kid","aud","iss","nbf","iat","azp","auth_time","nonce","getRsaVerifier","setUTCSeconds","fetch","modulus","validateAccessToken","+","/","=","extensibilityPoint","supports","randomString","bytes","cryptoObj","windowHelper","msCrypto","TransactionManager","transaction","namespace","keyLength","IframeHandler","timeoutCallback","eventListenerType","iframe","timeoutHandle","_destroyTimeout","transientMessageEventListener","proxyEventListener","eventValidator","isValid","WebMessageHandler","baseOptions","CrossOriginAuthentication","webMessageHandler","createKey","coId","Redirect","auth0","crossOriginAuthentication","_disableDeprecationWarnings","realm","responseTypeIncludesIdToken","generateTransaction","appState","state","generateNonce","domain","getStoredTransaction","transactionData","clearTransaction","_window","createElement","style","display","eventListener","eventSourceObject","appendChild","src","timeoutHandler","eventData","sourceObject","destroy","parentNode","removeChild","run","responseMode","prompt","currentOrigin","redirectUriOrigin","redirectUri","authorizeUrl","runWebMessageFlow","client","buildAuthorizeUrl","parsedHash","validateAuthenticationResponse","transactionManager","login","rootUrl","email","authenticateBody","client_id","clientID","otp","credentialType","credential_type","errorObject","responseHandler","popupMode","popup","authorizeOptions","loginTicket","login_ticket","co_id","co_verifier","authorize","targetOrigin","getFragment","theWindow","evt","id","verifier","tryGetVerifier","loginWithCredentials","signupAndLogin","dbConnection","signup","WinChan","addListener","attachEvent","detachEvent","extractOrigin","isIE","rv","ua","userAgent","RegExp","parseFloat","$1","isInternetExplorer","relay_url","window_name","window_features","isFennec","messageTarget","setAttribute","contentWindow","closeInterval","setInterval","closed","cleanup","clearInterval","onMessage","close","securityViolation","originalPopup","focus","onOpen","msgTarget","frames","opener","findRelay","doPost","onDie","o_O","onUnload","ohWell","detach","winopts","arg","PopupHandler","_current_popup","Popup","popupOrigin","SilentAuthenticationHandler","authenticationUrl","postMessageDataType","postMessageOrigin","UsernamePassword","HostedPages","calculatePosition","width","height","screenX","screenLeft","screenY","screenTop","outerWidth","clientWidth","outerHeight","clientHeight","left","top","preload","popupPosition","popupOptions","windowFeatures","qs","kill","load","relayUrl","winchanOptions","buildPopupHandler","pluginHandler","getPopupHandler","popupHandler","originUrl","parseHash","popOpts","owp","urlHelper","processParams","scope","passwordlessVerify","passwordless","phoneNumber","verificationCode","loginWithResourceOwner","usePostMessage","getCallbackHandler","getEventValidator","callbackValue","formHtml","div","_document","innerHTML","children","submit","usernamePassword","getSSOData","withActiveDirectories","ldaps","lang","templates","challenge","image","recaptcha_v2","handleRecaptchaProvider","element","widgetId","hasAttribute","getAttribute","setValue","querySelector","grecaptcha","provider","recaptchaDiv","callbackName","script","async","injectRecaptchaScript","render","expired-callback","error-callback","sitekey","siteKey","auth0Client","done","getChallenge","required","preventDefault","handleAuth0Provider","reload","getValue","captchaInput","defaultClock","WebAuth","overrides","__tenant","__token_issuer","__jwks_uri","tenant","token_issuer","Authentication","_universalLogin","ssodataStorage","PasswordlessAuthentication","DBConnection","Management","token","Authorization","parsedQs","hashStr","responseTypes","__enableIdPInitiatedLogin","__enableImpersonation","transactionState","transactionStateMatchesState","transactionNonce","qsParams","accessToken","access_token","idToken","id_token","idTokenPayload","refreshToken","refresh_token","expiresIn","expires_in","tokenType","token_type","buildParseHashResponse","validateToken","validationError","at_hash","IdTokenVerifier","decodedToken","userInfo","errUserInfo","profile","renewAuth","checkSession","changePassword","passwordlessStart","authParams","signupAndAuthorize","passwordlessLogin","crossOriginOptions","crossOriginAuthenticationCallback","crossOriginVerification","logout","buildLogoutUrl","buildVerifyUrl","renderCaptcha","captcha","qString","redirect_uri","response_type","cleanOption","metadata","user_metadata","userMetadata","connection_scope","parametersWhitelist","federated","loginWithDefaultDirectory","grantType","oauthToken","grant_type","clientId","ssodataInformation","sso","lastUsedUserID","lastUsedUsername","lastUsedClientID","sessionClients","delegation","getUserCountry","getUser","userId","patchUserMetadata","patchUserAttributes","linkUser","secondaryUserToken","link_with"],"mappings":"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"} \ No newline at end of file diff --git a/dist/cordova-auth0-plugin.js b/dist/cordova-auth0-plugin.js new file mode 100644 index 00000000..3a10c723 --- /dev/null +++ b/dist/cordova-auth0-plugin.js @@ -0,0 +1,1426 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.CordovaAuth0Plugin = factory()); +}(this, (function () { 'use strict'; + + var version = { raw: '9.14.3' }; + + var toString = Object.prototype.toString; + + function attribute(o, attr, type, text) { + type = type === 'array' ? 'object' : type; + if (o && typeof o[attr] !== type) { + throw new Error(text); + } + } + + function variable(o, type, text) { + if (typeof o !== type) { + throw new Error(text); + } + } + + function value(o, values, text) { + if (values.indexOf(o) === -1) { + throw new Error(text); + } + } + + function check(o, config, attributes) { + if (!config.optional || o) { + variable(o, config.type, config.message); + } + if (config.type === 'object' && attributes) { + var keys = Object.keys(attributes); + + for (var index = 0; index < keys.length; index++) { + var a = keys[index]; + if (!attributes[a].optional || o[a]) { + if (!attributes[a].condition || attributes[a].condition(o)) { + attribute(o, a, attributes[a].type, attributes[a].message); + if (attributes[a].values) { + value(o[a], attributes[a].values, attributes[a].value_message); + } + } + } + } + } + } + + /** + * Wrap `Array.isArray` Polyfill for IE9 + * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray + * + * @param {Array} array + * @private + */ + function isArray(array) { + if (this.supportsIsArray()) { + return Array.isArray(array); + } + + return toString.call(array) === '[object Array]'; + } + + function supportsIsArray() { + return Array.isArray != null; + } + + var assert = { + check: check, + attribute: attribute, + variable: variable, + value: value, + isArray: isArray, + supportsIsArray: supportsIsArray + }; + + /* eslint-disable no-continue */ + + function get() { + if (!Object.assign) { + return objectAssignPolyfill; + } + + return Object.assign; + } + + function objectAssignPolyfill(target) { + if (target === undefined || target === null) { + throw new TypeError('Cannot convert first argument to object'); + } + + var to = Object(target); + for (var i = 1; i < arguments.length; i++) { + var nextSource = arguments[i]; + if (nextSource === undefined || nextSource === null) { + continue; + } + + var keysArray = Object.keys(Object(nextSource)); + for ( + var nextIndex = 0, len = keysArray.length; + nextIndex < len; + nextIndex++ + ) { + var nextKey = keysArray[nextIndex]; + var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); + if (desc !== undefined && desc.enumerable) { + to[nextKey] = nextSource[nextKey]; + } + } + } + return to; + } + + var objectAssign = { + get: get, + objectAssignPolyfill: objectAssignPolyfill + }; + + /* eslint-disable no-param-reassign */ + + function pick(object, keys) { + return keys.reduce(function(prev, key) { + if (object[key]) { + prev[key] = object[key]; + } + return prev; + }, {}); + } + + function getKeysNotIn(obj, allowedKeys) { + var notAllowed = []; + for (var key in obj) { + if (allowedKeys.indexOf(key) === -1) { + notAllowed.push(key); + } + } + return notAllowed; + } + + function objectValues(obj) { + var values = []; + for (var key in obj) { + values.push(obj[key]); + } + return values; + } + + function extend() { + var params = objectValues(arguments); + params.unshift({}); + return objectAssign.get().apply(undefined, params); + } + + function merge(object, keys) { + return { + base: keys ? pick(object, keys) : object, + with: function(object2, keys2) { + object2 = keys2 ? pick(object2, keys2) : object2; + return extend(this.base, object2); + } + }; + } + + function blacklist(object, blacklistedKeys) { + return Object.keys(object).reduce(function(p, key) { + if (blacklistedKeys.indexOf(key) === -1) { + p[key] = object[key]; + } + return p; + }, {}); + } + + function camelToSnake(str) { + var newKey = ''; + var index = 0; + var code; + var wasPrevNumber = true; + var wasPrevUppercase = true; + + while (index < str.length) { + code = str.charCodeAt(index); + if ( + (!wasPrevUppercase && code >= 65 && code <= 90) || + (!wasPrevNumber && code >= 48 && code <= 57) + ) { + newKey += '_'; + newKey += str[index].toLowerCase(); + } else { + newKey += str[index].toLowerCase(); + } + wasPrevNumber = code >= 48 && code <= 57; + wasPrevUppercase = code >= 65 && code <= 90; + index++; + } + + return newKey; + } + + function snakeToCamel(str) { + var parts = str.split('_'); + return parts.reduce(function(p, c) { + return p + c.charAt(0).toUpperCase() + c.slice(1); + }, parts.shift()); + } + + function toSnakeCase(object, exceptions) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + exceptions = exceptions || []; + + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key; + p[newKey] = toSnakeCase(object[key]); + return p; + }, {}); + } + + function toCamelCase(object, exceptions, options) { + if (typeof object !== 'object' || assert.isArray(object) || object === null) { + return object; + } + + exceptions = exceptions || []; + options = options || {}; + return Object.keys(object).reduce(function(p, key) { + var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key; + + p[newKey] = toCamelCase(object[newKey] || object[key], [], options); + + if (options.keepOriginal) { + p[key] = toCamelCase(object[key], [], options); + } + return p; + }, {}); + } + + function getLocationFromUrl(href) { + var match = href.match( + /^(https?:|file:|chrome-extension:)\/\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\?[^#]*|)(#.*|)$/ + ); + return ( + match && { + href: href, + protocol: match[1], + host: match[2], + hostname: match[3], + port: match[4], + pathname: match[5], + search: match[6], + hash: match[7] + } + ); + } + + function getOriginFromUrl(url) { + if (!url) { + return undefined; + } + var parsed = getLocationFromUrl(url); + if (!parsed) { + return null; + } + var origin = parsed.protocol + '//' + parsed.hostname; + if (parsed.port) { + origin += ':' + parsed.port; + } + return origin; + } + + function trim(options, key) { + var trimmed = extend(options); + if (options[key]) { + trimmed[key] = options[key].trim(); + } + return trimmed; + } + + function trimMultiple(options, keys) { + return keys.reduce(trim, options); + } + + function trimUserDetails(options) { + return trimMultiple(options, ['username', 'email', 'phoneNumber']); + } + + /** + * Updates the value of a property on the given object, using a deep path selector. + * @param {object} obj The object to set the property value on + * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3'] + * @param {any} value The value to set + */ + function updatePropertyOn(obj, path, value) { + if (typeof path === 'string') { + path = path.split('.'); + } + + var next = path[0]; + + if (obj.hasOwnProperty(next)) { + if (path.length === 1) { + obj[next] = value; + } else { + updatePropertyOn(obj[next], path.slice(1), value); + } + } + } + + var objectHelper = { + toSnakeCase: toSnakeCase, + toCamelCase: toCamelCase, + blacklist: blacklist, + merge: merge, + pick: pick, + getKeysNotIn: getKeysNotIn, + extend: extend, + getOriginFromUrl: getOriginFromUrl, + getLocationFromUrl: getLocationFromUrl, + trimUserDetails: trimUserDetails, + updatePropertyOn: updatePropertyOn + }; + + function redirect(url) { + getWindow().location = url; + } + + function getDocument() { + return getWindow().document; + } + + function getWindow() { + return window; + } + + function getOrigin() { + var location = getWindow().location; + var origin = location.origin; + + if (!origin) { + origin = objectHelper.getOriginFromUrl(location.href); + } + + return origin; + } + + var windowHandler = { + redirect: redirect, + getDocument: getDocument, + getWindow: getWindow, + getOrigin: getOrigin + }; + + var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + var urlJoin = createCommonjsModule(function (module) { + (function (name, context, definition) { + if ( module.exports) module.exports = definition(); + else context[name] = definition(); + })('urljoin', commonjsGlobal, function () { + + function normalize (strArray) { + var resultArray = []; + if (strArray.length === 0) { return ''; } + + if (typeof strArray[0] !== 'string') { + throw new TypeError('Url must be a string. Received ' + strArray[0]); + } + + // If the first part is a plain protocol, we combine it with the next part. + if (strArray[0].match(/^[^/:]+:\/*$/) && strArray.length > 1) { + var first = strArray.shift(); + strArray[0] = first + strArray[0]; + } + + // There must be two or three slashes in the file protocol, two slashes in anything else. + if (strArray[0].match(/^file:\/\/\//)) { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1:///'); + } else { + strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, '$1://'); + } + + for (var i = 0; i < strArray.length; i++) { + var component = strArray[i]; + + if (typeof component !== 'string') { + throw new TypeError('Url must be a string. Received ' + component); + } + + if (component === '') { continue; } + + if (i > 0) { + // Removing the starting slashes for each component but the first. + component = component.replace(/^[\/]+/, ''); + } + if (i < strArray.length - 1) { + // Removing the ending slashes for each component but the last. + component = component.replace(/[\/]+$/, ''); + } else { + // For the last component we will combine multiple slashes to a single one. + component = component.replace(/[\/]+$/, '/'); + } + + resultArray.push(component); + + } + + var str = resultArray.join('/'); + // Each input component is now separated by a single slash except the possible first plain protocol part. + + // remove trailing slash before parameters or hash + str = str.replace(/\/(\?|&|#[^!])/g, '$1'); + + // replace ? in parameters with & + var parts = str.split('?'); + str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&'); + + return str; + } + + return function () { + var input; + + if (typeof arguments[0] === 'object') { + input = arguments[0]; + } else { + input = [].slice.call(arguments); + } + + return normalize(input); + }; + + }); + }); + + var has = Object.prototype.hasOwnProperty; + var isArray$1 = Array.isArray; + + var hexTable = (function () { + var array = []; + for (var i = 0; i < 256; ++i) { + array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase()); + } + + return array; + }()); + + var compactQueue = function compactQueue(queue) { + while (queue.length > 1) { + var item = queue.pop(); + var obj = item.obj[item.prop]; + + if (isArray$1(obj)) { + var compacted = []; + + for (var j = 0; j < obj.length; ++j) { + if (typeof obj[j] !== 'undefined') { + compacted.push(obj[j]); + } + } + + item.obj[item.prop] = compacted; + } + } + }; + + var arrayToObject = function arrayToObject(source, options) { + var obj = options && options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; + }; + + var merge$1 = function merge(target, source, options) { + /* eslint no-param-reassign: 0 */ + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (isArray$1(target)) { + target.push(source); + } else if (target && typeof target === 'object') { + if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) { + target[source] = true; + } + } else { + return [target, source]; + } + + return target; + } + + if (!target || typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (isArray$1(target) && !isArray$1(source)) { + mergeTarget = arrayToObject(target, options); + } + + if (isArray$1(target) && isArray$1(source)) { + source.forEach(function (item, i) { + if (has.call(target, i)) { + var targetItem = target[i]; + if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') { + target[i] = merge(targetItem, item, options); + } else { + target.push(item); + } + } else { + target[i] = item; + } + }); + return target; + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (has.call(acc, key)) { + acc[key] = merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); + }; + + var assign = function assignSingleSource(target, source) { + return Object.keys(source).reduce(function (acc, key) { + acc[key] = source[key]; + return acc; + }, target); + }; + + var decode = function (str, decoder, charset) { + var strWithoutPlus = str.replace(/\+/g, ' '); + if (charset === 'iso-8859-1') { + // unescape never throws, no try...catch needed: + return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape); + } + // utf-8 + try { + return decodeURIComponent(strWithoutPlus); + } catch (e) { + return strWithoutPlus; + } + }; + + var encode = function encode(str, defaultEncoder, charset) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = str; + if (typeof str === 'symbol') { + string = Symbol.prototype.toString.call(str); + } else if (typeof str !== 'string') { + string = String(str); + } + + if (charset === 'iso-8859-1') { + return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) { + return '%26%23' + parseInt($0.slice(2), 16) + '%3B'; + }); + } + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D // - + || c === 0x2E // . + || c === 0x5F // _ + || c === 0x7E // ~ + || (c >= 0x30 && c <= 0x39) // 0-9 + || (c >= 0x41 && c <= 0x5A) // a-z + || (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + + hexTable[0x80 | ((c >> 12) & 0x3F)] + + hexTable[0x80 | ((c >> 6) & 0x3F)] + + hexTable[0x80 | (c & 0x3F)]; + } + + return out; + }; + + var compact = function compact(value) { + var queue = [{ obj: { o: value }, prop: 'o' }]; + var refs = []; + + for (var i = 0; i < queue.length; ++i) { + var item = queue[i]; + var obj = item.obj[item.prop]; + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + var val = obj[key]; + if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) { + queue.push({ obj: obj, prop: key }); + refs.push(val); + } + } + } + + compactQueue(queue); + + return value; + }; + + var isRegExp = function isRegExp(obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; + }; + + var isBuffer = function isBuffer(obj) { + if (!obj || typeof obj !== 'object') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); + }; + + var combine = function combine(a, b) { + return [].concat(a, b); + }; + + var maybeMap = function maybeMap(val, fn) { + if (isArray$1(val)) { + var mapped = []; + for (var i = 0; i < val.length; i += 1) { + mapped.push(fn(val[i])); + } + return mapped; + } + return fn(val); + }; + + var utils = { + arrayToObject: arrayToObject, + assign: assign, + combine: combine, + compact: compact, + decode: decode, + encode: encode, + isBuffer: isBuffer, + isRegExp: isRegExp, + maybeMap: maybeMap, + merge: merge$1 + }; + + var replace = String.prototype.replace; + var percentTwenties = /%20/g; + + + + var Format = { + RFC1738: 'RFC1738', + RFC3986: 'RFC3986' + }; + + var formats = utils.assign( + { + 'default': Format.RFC3986, + formatters: { + RFC1738: function (value) { + return replace.call(value, percentTwenties, '+'); + }, + RFC3986: function (value) { + return String(value); + } + } + }, + Format + ); + + var has$1 = Object.prototype.hasOwnProperty; + + var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + comma: 'comma', + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } + }; + + var isArray$2 = Array.isArray; + var push = Array.prototype.push; + var pushToArray = function (arr, valueOrArray) { + push.apply(arr, isArray$2(valueOrArray) ? valueOrArray : [valueOrArray]); + }; + + var toISO = Date.prototype.toISOString; + + var defaultFormat = formats['default']; + var defaults = { + addQueryPrefix: false, + allowDots: false, + charset: 'utf-8', + charsetSentinel: false, + delimiter: '&', + encode: true, + encoder: utils.encode, + encodeValuesOnly: false, + format: defaultFormat, + formatter: formats.formatters[defaultFormat], + // deprecated + indices: false, + serializeDate: function serializeDate(date) { + return toISO.call(date); + }, + skipNulls: false, + strictNullHandling: false + }; + + var isNonNullishPrimitive = function isNonNullishPrimitive(v) { + return typeof v === 'string' + || typeof v === 'number' + || typeof v === 'boolean' + || typeof v === 'symbol' + || typeof v === 'bigint'; + }; + + var stringify = function stringify( + object, + prefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + ) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = serializeDate(obj); + } else if (generateArrayPrefix === 'comma' && isArray$2(obj)) { + obj = utils.maybeMap(obj, function (value) { + if (value instanceof Date) { + return serializeDate(value); + } + return value; + }).join(','); + } + + if (obj === null) { + if (strictNullHandling) { + return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix; + } + + obj = ''; + } + + if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) { + if (encoder) { + var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key'); + return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))]; + } + return [formatter(prefix) + '=' + formatter(String(obj))]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (isArray$2(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + var value = obj[key]; + + if (skipNulls && value === null) { + continue; + } + + var keyPrefix = isArray$2(obj) + ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix + : prefix + (allowDots ? '.' + key : '[' + key + ']'); + + pushToArray(values, stringify( + value, + keyPrefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + formatter, + encodeValuesOnly, + charset + )); + } + + return values; + }; + + var normalizeStringifyOptions = function normalizeStringifyOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + var charset = opts.charset || defaults.charset; + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + + var format = formats['default']; + if (typeof opts.format !== 'undefined') { + if (!has$1.call(formats.formatters, opts.format)) { + throw new TypeError('Unknown format option provided.'); + } + format = opts.format; + } + var formatter = formats.formatters[format]; + + var filter = defaults.filter; + if (typeof opts.filter === 'function' || isArray$2(opts.filter)) { + filter = opts.filter; + } + + return { + addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix, + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter, + encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode, + encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder, + encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly, + filter: filter, + formatter: formatter, + serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate, + skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls, + sort: typeof opts.sort === 'function' ? opts.sort : null, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; + }; + + var stringify_1 = function (object, opts) { + var obj = object; + var options = normalizeStringifyOptions(opts); + + var objKeys; + var filter; + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (isArray$2(options.filter)) { + filter = options.filter; + objKeys = filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (opts && opts.arrayFormat in arrayPrefixGenerators) { + arrayFormat = opts.arrayFormat; + } else if (opts && 'indices' in opts) { + arrayFormat = opts.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (options.sort) { + objKeys.sort(options.sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (options.skipNulls && obj[key] === null) { + continue; + } + pushToArray(keys, stringify( + obj[key], + key, + generateArrayPrefix, + options.strictNullHandling, + options.skipNulls, + options.encode ? options.encoder : null, + options.filter, + options.sort, + options.allowDots, + options.serializeDate, + options.formatter, + options.encodeValuesOnly, + options.charset + )); + } + + var joined = keys.join(options.delimiter); + var prefix = options.addQueryPrefix === true ? '?' : ''; + + if (options.charsetSentinel) { + if (options.charset === 'iso-8859-1') { + // encodeURIComponent('✓'), the "numeric entity" representation of a checkmark + prefix += 'utf8=%26%2310003%3B&'; + } else { + // encodeURIComponent('✓') + prefix += 'utf8=%E2%9C%93&'; + } + } + + return joined.length > 0 ? prefix + joined : ''; + }; + + var has$2 = Object.prototype.hasOwnProperty; + var isArray$3 = Array.isArray; + + var defaults$1 = { + allowDots: false, + allowPrototypes: false, + arrayLimit: 20, + charset: 'utf-8', + charsetSentinel: false, + comma: false, + decoder: utils.decode, + delimiter: '&', + depth: 5, + ignoreQueryPrefix: false, + interpretNumericEntities: false, + parameterLimit: 1000, + parseArrays: true, + plainObjects: false, + strictNullHandling: false + }; + + var interpretNumericEntities = function (str) { + return str.replace(/&#(\d+);/g, function ($0, numberStr) { + return String.fromCharCode(parseInt(numberStr, 10)); + }); + }; + + var parseArrayValue = function (val, options) { + if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) { + return val.split(','); + } + + return val; + }; + + // This is what browsers will submit when the ✓ character occurs in an + // application/x-www-form-urlencoded body and the encoding of the page containing + // the form is iso-8859-1, or when the submitted form has an accept-charset + // attribute of iso-8859-1. Presumably also with other charsets that do not contain + // the ✓ character, such as us-ascii. + var isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓') + + // These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded. + var charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓') + + var parseValues = function parseQueryStringValues(str, options) { + var obj = {}; + var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\?/, '') : str; + var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit; + var parts = cleanStr.split(options.delimiter, limit); + var skipIndex = -1; // Keep track of where the utf8 sentinel was found + var i; + + var charset = options.charset; + if (options.charsetSentinel) { + for (i = 0; i < parts.length; ++i) { + if (parts[i].indexOf('utf8=') === 0) { + if (parts[i] === charsetSentinel) { + charset = 'utf-8'; + } else if (parts[i] === isoSentinel) { + charset = 'iso-8859-1'; + } + skipIndex = i; + i = parts.length; // The eslint settings do not allow break; + } + } + } + + for (i = 0; i < parts.length; ++i) { + if (i === skipIndex) { + continue; + } + var part = parts[i]; + + var bracketEqualsPos = part.indexOf(']='); + var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1; + + var key, val; + if (pos === -1) { + key = options.decoder(part, defaults$1.decoder, charset, 'key'); + val = options.strictNullHandling ? null : ''; + } else { + key = options.decoder(part.slice(0, pos), defaults$1.decoder, charset, 'key'); + val = utils.maybeMap( + parseArrayValue(part.slice(pos + 1), options), + function (encodedVal) { + return options.decoder(encodedVal, defaults$1.decoder, charset, 'value'); + } + ); + } + + if (val && options.interpretNumericEntities && charset === 'iso-8859-1') { + val = interpretNumericEntities(val); + } + + if (part.indexOf('[]=') > -1) { + val = isArray$3(val) ? [val] : val; + } + + if (has$2.call(obj, key)) { + obj[key] = utils.combine(obj[key], val); + } else { + obj[key] = val; + } + } + + return obj; + }; + + var parseObject = function (chain, val, options, valuesParsed) { + var leaf = valuesParsed ? val : parseArrayValue(val, options); + + for (var i = chain.length - 1; i >= 0; --i) { + var obj; + var root = chain[i]; + + if (root === '[]' && options.parseArrays) { + obj = [].concat(leaf); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root; + var index = parseInt(cleanRoot, 10); + if (!options.parseArrays && cleanRoot === '') { + obj = { 0: leaf }; + } else if ( + !isNaN(index) + && root !== cleanRoot + && String(index) === cleanRoot + && index >= 0 + && (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = leaf; + } else { + obj[cleanRoot] = leaf; + } + } + + leaf = obj; // eslint-disable-line no-param-reassign + } + + return leaf; + }; + + var parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^.[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var brackets = /(\[[^[\]]*])/; + var child = /(\[[^[\]]*])/g; + + // Get the parent + + var segment = options.depth > 0 && brackets.exec(key); + var parent = segment ? key.slice(0, segment.index) : key; + + // Stash the parent if it exists + + var keys = []; + if (parent) { + // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties + if (!options.plainObjects && has$2.call(Object.prototype, parent)) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(parent); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && has$2.call(Object.prototype, segment[1].slice(1, -1))) { + if (!options.allowPrototypes) { + return; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options, valuesParsed); + }; + + var normalizeParseOptions = function normalizeParseOptions(opts) { + if (!opts) { + return defaults$1; + } + + if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + var charset = typeof opts.charset === 'undefined' ? defaults$1.charset : opts.charset; + + return { + allowDots: typeof opts.allowDots === 'undefined' ? defaults$1.allowDots : !!opts.allowDots, + allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults$1.allowPrototypes, + arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults$1.arrayLimit, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults$1.charsetSentinel, + comma: typeof opts.comma === 'boolean' ? opts.comma : defaults$1.comma, + decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults$1.decoder, + delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults$1.delimiter, + // eslint-disable-next-line no-implicit-coercion, no-extra-parens + depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults$1.depth, + ignoreQueryPrefix: opts.ignoreQueryPrefix === true, + interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults$1.interpretNumericEntities, + parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults$1.parameterLimit, + parseArrays: opts.parseArrays !== false, + plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults$1.plainObjects, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults$1.strictNullHandling + }; + }; + + var parse = function (str, opts) { + var options = normalizeParseOptions(opts); + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string'); + obj = utils.merge(obj, newObj, options); + } + + return utils.compact(obj); + }; + + var lib = { + formats: formats, + parse: parse, + stringify: stringify_1 + }; + + function PopupHandler(webAuth) { + this.webAuth = webAuth; + this._current_popup = null; + this.options = null; + } + + PopupHandler.prototype.preload = function(options) { + var _this = this; + var _window = windowHandler.getWindow(); + + var url = options.url || 'about:blank'; + var popupOptions = options.popupOptions || {}; + + popupOptions.location = 'yes'; + delete popupOptions.width; + delete popupOptions.height; + + var windowFeatures = lib.stringify(popupOptions, { + encode: false, + delimiter: ',' + }); + + if (this._current_popup && !this._current_popup.closed) { + return this._current_popup; + } + + this._current_popup = _window.open(url, '_blank', windowFeatures); + + this._current_popup.kill = function(success) { + _this._current_popup.success = success; + this.close(); + _this._current_popup = null; + }; + + return this._current_popup; + }; + + PopupHandler.prototype.load = function(url, _, options, cb) { + var _this = this; + this.url = url; + this.options = options; + if (!this._current_popup) { + options.url = url; + this.preload(options); + } else { + this._current_popup.location.href = url; + } + + this.transientErrorHandler = function(event) { + _this.errorHandler(event, cb); + }; + + this.transientStartHandler = function(event) { + _this.startHandler(event, cb); + }; + + this.transientExitHandler = function() { + _this.exitHandler(cb); + }; + + this._current_popup.addEventListener('loaderror', this.transientErrorHandler); + this._current_popup.addEventListener('loadstart', this.transientStartHandler); + this._current_popup.addEventListener('exit', this.transientExitHandler); + }; + + PopupHandler.prototype.errorHandler = function(event, cb) { + if (!this._current_popup) { + return; + } + + this._current_popup.kill(true); + + cb({ error: 'window_error', errorDescription: event.message }); + }; + + PopupHandler.prototype.unhook = function() { + this._current_popup.removeEventListener( + 'loaderror', + this.transientErrorHandler + ); + this._current_popup.removeEventListener( + 'loadstart', + this.transientStartHandler + ); + this._current_popup.removeEventListener('exit', this.transientExitHandler); + }; + + PopupHandler.prototype.exitHandler = function(cb) { + if (!this._current_popup) { + return; + } + + // when the modal is closed, this event is called which ends up removing the + // event listeners. If you move this before closing the modal, it will add ~1 sec + // delay between the user being redirected to the callback and the popup gets closed. + this.unhook(); + + if (!this._current_popup.success) { + cb({ error: 'window_closed', errorDescription: 'Browser window closed' }); + } + }; + + PopupHandler.prototype.startHandler = function(event, cb) { + var _this = this; + + if (!this._current_popup) { + return; + } + + var callbackUrl = urlJoin( + 'https:', + this.webAuth.baseOptions.domain, + '/mobile' + ); + + if (event.url && !(event.url.indexOf(callbackUrl + '#') === 0)) { + return; + } + + var parts = event.url.split('#'); + + if (parts.length === 1) { + return; + } + + var opts = { hash: parts.pop() }; + + if (this.options.nonce) { + opts.nonce = this.options.nonce; + } + + this.webAuth.parseHash(opts, function(error, result) { + if (error || result) { + _this._current_popup.kill(true); + cb(error, result); + } + }); + }; + + function PluginHandler(webAuth) { + this.webAuth = webAuth; + } + + PluginHandler.prototype.processParams = function(params) { + params.redirectUri = urlJoin('https://' + params.domain, 'mobile'); + delete params.owp; + return params; + }; + + PluginHandler.prototype.getPopupHandler = function() { + return new PopupHandler(this.webAuth); + }; + + function CordovaPlugin() { + this.webAuth = null; + this.version = version.raw; + this.extensibilityPoints = ['popup.authorize', 'popup.getPopupHandler']; + } + + CordovaPlugin.prototype.setWebAuth = function(webAuth) { + this.webAuth = webAuth; + }; + + CordovaPlugin.prototype.supports = function(extensibilityPoint) { + var _window = windowHandler.getWindow(); + return ( + (!!_window.cordova || !!_window.electron) && + this.extensibilityPoints.indexOf(extensibilityPoint) > -1 + ); + }; + + CordovaPlugin.prototype.init = function() { + return new PluginHandler(this.webAuth); + }; + + return CordovaPlugin; + +}))); diff --git a/dist/cordova-auth0-plugin.min.js b/dist/cordova-auth0-plugin.min.js new file mode 100644 index 00000000..d6a12b3d --- /dev/null +++ b/dist/cordova-auth0-plugin.min.js @@ -0,0 +1,9 @@ +/** + * auth0-js v9.14.3 + * Author: Auth0 + * Date: 2021-01-26 + * License: MIT + */ + +!function(global,factory){"object"==typeof exports&&"undefined"!=typeof module?module.exports=factory():"function"==typeof define&&define.amd?define(factory):(global=global||self).CordovaAuth0Plugin=factory()}(this,(function(){"use strict";var version_raw="9.14.3",toString=Object.prototype.toString;function attribute(o,attr,type,text){if(type="array"===type?"object":type,o&&typeof o[attr]!==type)throw new Error(text)}function variable(o,type,text){if(typeof o!==type)throw new Error(text)}function value(o,values,text){if(-1===values.indexOf(o))throw new Error(text)}var assert={check:function(o,config,attributes){if(config.optional&&!o||variable(o,config.type,config.message),"object"===config.type&&attributes)for(var keys=Object.keys(attributes),index=0;index=65&&code<=90||!wasPrevNumber&&code>=48&&code<=57?(newKey+="_",newKey+=str[index].toLowerCase()):newKey+=str[index].toLowerCase(),wasPrevNumber=code>=48&&code<=57,wasPrevUppercase=code>=65&&code<=90,index++;return newKey}(key):key]=toSnakeCase(object[key]),p}),{}))},toCamelCase:function toCamelCase(object,exceptions,options){return"object"!=typeof object||assert.isArray(object)||null===object?object:(exceptions=exceptions||[],options=options||{},Object.keys(object).reduce((function(p,key){var parts,newKey=-1===exceptions.indexOf(key)?(parts=key.split("_")).reduce((function(p,c){return p+c.charAt(0).toUpperCase()+c.slice(1)}),parts.shift()):key;return p[newKey]=toCamelCase(object[newKey]||object[key],[],options),options.keepOriginal&&(p[key]=toCamelCase(object[key],[],options)),p}),{}))},blacklist:function(object,blacklistedKeys){return Object.keys(object).reduce((function(p,key){return-1===blacklistedKeys.indexOf(key)&&(p[key]=object[key]),p}),{})},merge:function(object,keys){return{base:keys?pick(object,keys):object,with:function(object2,keys2){return object2=keys2?pick(object2,keys2):object2,extend(this.base,object2)}}},pick:pick,getKeysNotIn:function(obj,allowedKeys){var notAllowed=[];for(var key in obj)-1===allowedKeys.indexOf(key)&¬Allowed.push(key);return notAllowed},extend:extend,getOriginFromUrl:function(url){if(url){var parsed=getLocationFromUrl(url);if(!parsed)return null;var origin=parsed.protocol+"//"+parsed.hostname;return parsed.port&&(origin+=":"+parsed.port),origin}},getLocationFromUrl:getLocationFromUrl,trimUserDetails:function(options){return function(options,keys){return keys.reduce(trim,options)}(options,["username","email","phoneNumber"])},updatePropertyOn:function updatePropertyOn(obj,path,value){"string"==typeof path&&(path=path.split("."));var next=path[0];obj.hasOwnProperty(next)&&(1===path.length?obj[next]=value:updatePropertyOn(obj[next],path.slice(1),value))}};function getWindow(){return window}var windowHandler={redirect:function(url){getWindow().location=url},getDocument:function(){return getWindow().document},getWindow:getWindow,getOrigin:function(){var location=getWindow().location,origin=location.origin;return origin||(origin=objectHelper.getOriginFromUrl(location.href)),origin}},commonjsGlobal="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};var urlJoin=function(fn,module){return fn(module={exports:{}},module.exports),module.exports}((function(module){var context,definition;context=commonjsGlobal,definition=function(){function normalize(strArray){var resultArray=[];if(0===strArray.length)return"";if("string"!=typeof strArray[0])throw new TypeError("Url must be a string. Received "+strArray[0]);if(strArray[0].match(/^[^/:]+:\/*$/)&&strArray.length>1){var first=strArray.shift();strArray[0]=first+strArray[0]}strArray[0].match(/^file:\/\/\//)?strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1:///"):strArray[0]=strArray[0].replace(/^([^/:]+):\/*/,"$1://");for(var i=0;i0&&(component=component.replace(/^[\/]+/,"")),component=i0?"?":"")+parts.join("&")}return function(){return normalize("object"==typeof arguments[0]?arguments[0]:[].slice.call(arguments))}},module.exports?module.exports=definition():context.urljoin=definition()})),has=Object.prototype.hasOwnProperty,isArray$1=Array.isArray,hexTable=function(){for(var array=[],i=0;i<256;++i)array.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return array}(),arrayToObject=function(source,options){for(var obj=options&&options.plainObjects?Object.create(null):{},i=0;i1;){var item=queue.pop(),obj=item.obj[item.prop];if(isArray$1(obj)){for(var compacted=[],j=0;j=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122?out+=string.charAt(i):c<128?out+=hexTable[c]:c<2048?out+=hexTable[192|c>>6]+hexTable[128|63&c]:c<55296||c>=57344?out+=hexTable[224|c>>12]+hexTable[128|c>>6&63]+hexTable[128|63&c]:(i+=1,c=65536+((1023&c)<<10|1023&string.charCodeAt(i)),out+=hexTable[240|c>>18]+hexTable[128|c>>12&63]+hexTable[128|c>>6&63]+hexTable[128|63&c])}return out},isBuffer:function(obj){return!(!obj||"object"!=typeof obj)&&!!(obj.constructor&&obj.constructor.isBuffer&&obj.constructor.isBuffer(obj))},isRegExp:function(obj){return"[object RegExp]"===Object.prototype.toString.call(obj)},maybeMap:function(val,fn){if(isArray$1(val)){for(var mapped=[],i=0;i0?prefix+joined:""});function PopupHandler(webAuth){this.webAuth=webAuth,this._current_popup=null,this.options=null}function PluginHandler(webAuth){this.webAuth=webAuth}function CordovaPlugin(){this.webAuth=null,this.version=version_raw,this.extensibilityPoints=["popup.authorize","popup.getPopupHandler"]}return PopupHandler.prototype.preload=function(options){var _this=this,_window=windowHandler.getWindow(),url=options.url||"about:blank",popupOptions=options.popupOptions||{};popupOptions.location="yes",delete popupOptions.width,delete popupOptions.height;var windowFeatures=lib_stringify(popupOptions,{encode:!1,delimiter:","});return this._current_popup&&!this._current_popup.closed||(this._current_popup=_window.open(url,"_blank",windowFeatures),this._current_popup.kill=function(success){_this._current_popup.success=success,this.close(),_this._current_popup=null}),this._current_popup},PopupHandler.prototype.load=function(url,_,options,cb){var _this=this;this.url=url,this.options=options,this._current_popup?this._current_popup.location.href=url:(options.url=url,this.preload(options)),this.transientErrorHandler=function(event){_this.errorHandler(event,cb)},this.transientStartHandler=function(event){_this.startHandler(event,cb)},this.transientExitHandler=function(){_this.exitHandler(cb)},this._current_popup.addEventListener("loaderror",this.transientErrorHandler),this._current_popup.addEventListener("loadstart",this.transientStartHandler),this._current_popup.addEventListener("exit",this.transientExitHandler)},PopupHandler.prototype.errorHandler=function(event,cb){this._current_popup&&(this._current_popup.kill(!0),cb({error:"window_error",errorDescription:event.message}))},PopupHandler.prototype.unhook=function(){this._current_popup.removeEventListener("loaderror",this.transientErrorHandler),this._current_popup.removeEventListener("loadstart",this.transientStartHandler),this._current_popup.removeEventListener("exit",this.transientExitHandler)},PopupHandler.prototype.exitHandler=function(cb){this._current_popup&&(this.unhook(),this._current_popup.success||cb({error:"window_closed",errorDescription:"Browser window closed"}))},PopupHandler.prototype.startHandler=function(event,cb){var _this=this;if(this._current_popup){var callbackUrl=urlJoin("https:",this.webAuth.baseOptions.domain,"/mobile");if(!event.url||0===event.url.indexOf(callbackUrl+"#")){var parts=event.url.split("#");if(1!==parts.length){var opts={hash:parts.pop()};this.options.nonce&&(opts.nonce=this.options.nonce),this.webAuth.parseHash(opts,(function(error,result){(error||result)&&(_this._current_popup.kill(!0),cb(error,result))}))}}}},PluginHandler.prototype.processParams=function(params){return params.redirectUri=urlJoin("https://"+params.domain,"mobile"),delete params.owp,params},PluginHandler.prototype.getPopupHandler=function(){return new PopupHandler(this.webAuth)},CordovaPlugin.prototype.setWebAuth=function(webAuth){this.webAuth=webAuth},CordovaPlugin.prototype.supports=function(extensibilityPoint){var _window=windowHandler.getWindow();return(!!_window.cordova||!!_window.electron)&&this.extensibilityPoints.indexOf(extensibilityPoint)>-1},CordovaPlugin.prototype.init=function(){return new PluginHandler(this.webAuth)},CordovaPlugin})); +//# sourceMappingURL=cordova-auth0-plugin.min.js.map diff --git a/dist/cordova-auth0-plugin.min.js.map b/dist/cordova-auth0-plugin.min.js.map new file mode 100644 index 00000000..d3718974 --- /dev/null +++ b/dist/cordova-auth0-plugin.min.js.map @@ -0,0 +1 @@ +{"version":3,"file":"cordova-auth0-plugin.min.js","sources":["../src/version.js","../src/helper/assert.js","../src/helper/object-assign.js","../src/helper/object.js","../src/helper/window.js","../node_modules/url-join/lib/url-join.js","../node_modules/qs/lib/utils.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/parse.js","../plugins/cordova/popup-handler.js","../plugins/cordova/plugin-handler.js","../plugins/cordova/index.js"],"sourcesContent":["module.exports = { raw: '9.14.3' };\n","var toString = Object.prototype.toString;\n\nfunction attribute(o, attr, type, text) {\n type = type === 'array' ? 'object' : type;\n if (o && typeof o[attr] !== type) {\n throw new Error(text);\n }\n}\n\nfunction variable(o, type, text) {\n if (typeof o !== type) {\n throw new Error(text);\n }\n}\n\nfunction value(o, values, text) {\n if (values.indexOf(o) === -1) {\n throw new Error(text);\n }\n}\n\nfunction check(o, config, attributes) {\n if (!config.optional || o) {\n variable(o, config.type, config.message);\n }\n if (config.type === 'object' && attributes) {\n var keys = Object.keys(attributes);\n\n for (var index = 0; index < keys.length; index++) {\n var a = keys[index];\n if (!attributes[a].optional || o[a]) {\n if (!attributes[a].condition || attributes[a].condition(o)) {\n attribute(o, a, attributes[a].type, attributes[a].message);\n if (attributes[a].values) {\n value(o[a], attributes[a].values, attributes[a].value_message);\n }\n }\n }\n }\n }\n}\n\n/**\n * Wrap `Array.isArray` Polyfill for IE9\n * source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray\n *\n * @param {Array} array\n * @private\n */\nfunction isArray(array) {\n if (this.supportsIsArray()) {\n return Array.isArray(array);\n }\n\n return toString.call(array) === '[object Array]';\n}\n\nfunction supportsIsArray() {\n return Array.isArray != null;\n}\n\nexport default {\n check: check,\n attribute: attribute,\n variable: variable,\n value: value,\n isArray: isArray,\n supportsIsArray: supportsIsArray\n};\n","/* eslint-disable no-continue */\n\nfunction get() {\n if (!Object.assign) {\n return objectAssignPolyfill;\n }\n\n return Object.assign;\n}\n\nfunction objectAssignPolyfill(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (\n var nextIndex = 0, len = keysArray.length;\n nextIndex < len;\n nextIndex++\n ) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nexport default {\n get: get,\n objectAssignPolyfill: objectAssignPolyfill\n};\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable guard-for-in */\n\nimport assert from './assert';\nimport objectAssign from './object-assign';\n\nfunction pick(object, keys) {\n return keys.reduce(function(prev, key) {\n if (object[key]) {\n prev[key] = object[key];\n }\n return prev;\n }, {});\n}\n\nfunction getKeysNotIn(obj, allowedKeys) {\n var notAllowed = [];\n for (var key in obj) {\n if (allowedKeys.indexOf(key) === -1) {\n notAllowed.push(key);\n }\n }\n return notAllowed;\n}\n\nfunction objectValues(obj) {\n var values = [];\n for (var key in obj) {\n values.push(obj[key]);\n }\n return values;\n}\n\nfunction extend() {\n var params = objectValues(arguments);\n params.unshift({});\n return objectAssign.get().apply(undefined, params);\n}\n\nfunction merge(object, keys) {\n return {\n base: keys ? pick(object, keys) : object,\n with: function(object2, keys2) {\n object2 = keys2 ? pick(object2, keys2) : object2;\n return extend(this.base, object2);\n }\n };\n}\n\nfunction blacklist(object, blacklistedKeys) {\n return Object.keys(object).reduce(function(p, key) {\n if (blacklistedKeys.indexOf(key) === -1) {\n p[key] = object[key];\n }\n return p;\n }, {});\n}\n\nfunction camelToSnake(str) {\n var newKey = '';\n var index = 0;\n var code;\n var wasPrevNumber = true;\n var wasPrevUppercase = true;\n\n while (index < str.length) {\n code = str.charCodeAt(index);\n if (\n (!wasPrevUppercase && code >= 65 && code <= 90) ||\n (!wasPrevNumber && code >= 48 && code <= 57)\n ) {\n newKey += '_';\n newKey += str[index].toLowerCase();\n } else {\n newKey += str[index].toLowerCase();\n }\n wasPrevNumber = code >= 48 && code <= 57;\n wasPrevUppercase = code >= 65 && code <= 90;\n index++;\n }\n\n return newKey;\n}\n\nfunction snakeToCamel(str) {\n var parts = str.split('_');\n return parts.reduce(function(p, c) {\n return p + c.charAt(0).toUpperCase() + c.slice(1);\n }, parts.shift());\n}\n\nfunction toSnakeCase(object, exceptions) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n exceptions = exceptions || [];\n\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? camelToSnake(key) : key;\n p[newKey] = toSnakeCase(object[key]);\n return p;\n }, {});\n}\n\nfunction toCamelCase(object, exceptions, options) {\n if (typeof object !== 'object' || assert.isArray(object) || object === null) {\n return object;\n }\n\n exceptions = exceptions || [];\n options = options || {};\n return Object.keys(object).reduce(function(p, key) {\n var newKey = exceptions.indexOf(key) === -1 ? snakeToCamel(key) : key;\n\n p[newKey] = toCamelCase(object[newKey] || object[key], [], options);\n\n if (options.keepOriginal) {\n p[key] = toCamelCase(object[key], [], options);\n }\n return p;\n }, {});\n}\n\nfunction getLocationFromUrl(href) {\n var match = href.match(\n /^(https?:|file:|chrome-extension:)\\/\\/(([^:/?#]*)(?::([0-9]+))?)([/]{0,1}[^?#]*)(\\?[^#]*|)(#.*|)$/\n );\n return (\n match && {\n href: href,\n protocol: match[1],\n host: match[2],\n hostname: match[3],\n port: match[4],\n pathname: match[5],\n search: match[6],\n hash: match[7]\n }\n );\n}\n\nfunction getOriginFromUrl(url) {\n if (!url) {\n return undefined;\n }\n var parsed = getLocationFromUrl(url);\n if (!parsed) {\n return null;\n }\n var origin = parsed.protocol + '//' + parsed.hostname;\n if (parsed.port) {\n origin += ':' + parsed.port;\n }\n return origin;\n}\n\nfunction trim(options, key) {\n var trimmed = extend(options);\n if (options[key]) {\n trimmed[key] = options[key].trim();\n }\n return trimmed;\n}\n\nfunction trimMultiple(options, keys) {\n return keys.reduce(trim, options);\n}\n\nfunction trimUserDetails(options) {\n return trimMultiple(options, ['username', 'email', 'phoneNumber']);\n}\n\n/**\n * Updates the value of a property on the given object, using a deep path selector.\n * @param {object} obj The object to set the property value on\n * @param {string|array} path The path to the property that should have its value updated. e.g. 'prop1.prop2.prop3' or ['prop1', 'prop2', 'prop3']\n * @param {any} value The value to set\n */\nfunction updatePropertyOn(obj, path, value) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n var next = path[0];\n\n if (obj.hasOwnProperty(next)) {\n if (path.length === 1) {\n obj[next] = value;\n } else {\n updatePropertyOn(obj[next], path.slice(1), value);\n }\n }\n}\n\nexport default {\n toSnakeCase: toSnakeCase,\n toCamelCase: toCamelCase,\n blacklist: blacklist,\n merge: merge,\n pick: pick,\n getKeysNotIn: getKeysNotIn,\n extend: extend,\n getOriginFromUrl: getOriginFromUrl,\n getLocationFromUrl: getLocationFromUrl,\n trimUserDetails: trimUserDetails,\n updatePropertyOn: updatePropertyOn\n};\n","import objectHelper from './object';\n\nfunction redirect(url) {\n getWindow().location = url;\n}\n\nfunction getDocument() {\n return getWindow().document;\n}\n\nfunction getWindow() {\n return window;\n}\n\nfunction getOrigin() {\n var location = getWindow().location;\n var origin = location.origin;\n\n if (!origin) {\n origin = objectHelper.getOriginFromUrl(location.href);\n }\n\n return origin;\n}\n\nexport default {\n redirect: redirect,\n getDocument: getDocument,\n getWindow: getWindow,\n getOrigin: getOrigin\n};\n","(function (name, context, definition) {\n if (typeof module !== 'undefined' && module.exports) module.exports = definition();\n else if (typeof define === 'function' && define.amd) define(definition);\n else context[name] = definition();\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar util = require('./utils');\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = util.assign(\n {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n }\n },\n Format\n);\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n }).join(',');\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key') : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key');\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value'))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n var value = obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && opts.encoder !== undefined && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj; // eslint-disable-line no-param-reassign\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","import windowHandler from '../../src/helper/window';\nimport qs from 'qs';\nimport urljoin from 'url-join';\n\nfunction PopupHandler(webAuth) {\n this.webAuth = webAuth;\n this._current_popup = null;\n this.options = null;\n}\n\nPopupHandler.prototype.preload = function(options) {\n var _this = this;\n var _window = windowHandler.getWindow();\n\n var url = options.url || 'about:blank';\n var popupOptions = options.popupOptions || {};\n\n popupOptions.location = 'yes';\n delete popupOptions.width;\n delete popupOptions.height;\n\n var windowFeatures = qs.stringify(popupOptions, {\n encode: false,\n delimiter: ','\n });\n\n if (this._current_popup && !this._current_popup.closed) {\n return this._current_popup;\n }\n\n this._current_popup = _window.open(url, '_blank', windowFeatures);\n\n this._current_popup.kill = function(success) {\n _this._current_popup.success = success;\n this.close();\n _this._current_popup = null;\n };\n\n return this._current_popup;\n};\n\nPopupHandler.prototype.load = function(url, _, options, cb) {\n var _this = this;\n this.url = url;\n this.options = options;\n if (!this._current_popup) {\n options.url = url;\n this.preload(options);\n } else {\n this._current_popup.location.href = url;\n }\n\n this.transientErrorHandler = function(event) {\n _this.errorHandler(event, cb);\n };\n\n this.transientStartHandler = function(event) {\n _this.startHandler(event, cb);\n };\n\n this.transientExitHandler = function() {\n _this.exitHandler(cb);\n };\n\n this._current_popup.addEventListener('loaderror', this.transientErrorHandler);\n this._current_popup.addEventListener('loadstart', this.transientStartHandler);\n this._current_popup.addEventListener('exit', this.transientExitHandler);\n};\n\nPopupHandler.prototype.errorHandler = function(event, cb) {\n if (!this._current_popup) {\n return;\n }\n\n this._current_popup.kill(true);\n\n cb({ error: 'window_error', errorDescription: event.message });\n};\n\nPopupHandler.prototype.unhook = function() {\n this._current_popup.removeEventListener(\n 'loaderror',\n this.transientErrorHandler\n );\n this._current_popup.removeEventListener(\n 'loadstart',\n this.transientStartHandler\n );\n this._current_popup.removeEventListener('exit', this.transientExitHandler);\n};\n\nPopupHandler.prototype.exitHandler = function(cb) {\n if (!this._current_popup) {\n return;\n }\n\n // when the modal is closed, this event is called which ends up removing the\n // event listeners. If you move this before closing the modal, it will add ~1 sec\n // delay between the user being redirected to the callback and the popup gets closed.\n this.unhook();\n\n if (!this._current_popup.success) {\n cb({ error: 'window_closed', errorDescription: 'Browser window closed' });\n }\n};\n\nPopupHandler.prototype.startHandler = function(event, cb) {\n var _this = this;\n\n if (!this._current_popup) {\n return;\n }\n\n var callbackUrl = urljoin(\n 'https:',\n this.webAuth.baseOptions.domain,\n '/mobile'\n );\n\n if (event.url && !(event.url.indexOf(callbackUrl + '#') === 0)) {\n return;\n }\n\n var parts = event.url.split('#');\n\n if (parts.length === 1) {\n return;\n }\n\n var opts = { hash: parts.pop() };\n\n if (this.options.nonce) {\n opts.nonce = this.options.nonce;\n }\n\n this.webAuth.parseHash(opts, function(error, result) {\n if (error || result) {\n _this._current_popup.kill(true);\n cb(error, result);\n }\n });\n};\n\nexport default PopupHandler;\n","import urljoin from 'url-join';\nimport PopupHandler from './popup-handler';\n\nfunction PluginHandler(webAuth) {\n this.webAuth = webAuth;\n}\n\nPluginHandler.prototype.processParams = function(params) {\n params.redirectUri = urljoin('https://' + params.domain, 'mobile');\n delete params.owp;\n return params;\n};\n\nPluginHandler.prototype.getPopupHandler = function() {\n return new PopupHandler(this.webAuth);\n};\n\nexport default PluginHandler;\n","import version from '../../src/version';\nimport windowHandler from '../../src/helper/window';\nimport PluginHandler from './plugin-handler';\n\nfunction CordovaPlugin() {\n this.webAuth = null;\n this.version = version.raw;\n this.extensibilityPoints = ['popup.authorize', 'popup.getPopupHandler'];\n}\n\nCordovaPlugin.prototype.setWebAuth = function(webAuth) {\n this.webAuth = webAuth;\n};\n\nCordovaPlugin.prototype.supports = function(extensibilityPoint) {\n var _window = windowHandler.getWindow();\n return (\n (!!_window.cordova || !!_window.electron) &&\n this.extensibilityPoints.indexOf(extensibilityPoint) > -1\n );\n};\n\nCordovaPlugin.prototype.init = function() {\n return new PluginHandler(this.webAuth);\n};\n\nexport default CordovaPlugin;\n"],"names":["toString","Object","prototype","attribute","o","attr","type","text","Error","variable","value","values","indexOf","check","config","attributes","optional","message","keys","index","length","a","condition","value_message","isArray","array","this","supportsIsArray","Array","call","objectAssignPolyfill","target","TypeError","to","i","arguments","nextSource","keysArray","nextIndex","len","nextKey","desc","getOwnPropertyDescriptor","undefined","enumerable","get","assign","pick","object","reduce","prev","key","objectValues","obj","push","extend","params","unshift","objectAssign","apply","getLocationFromUrl","href","match","protocol","host","hostname","port","pathname","search","hash","trim","options","trimmed","toSnakeCase","exceptions","assert","p","str","code","newKey","wasPrevNumber","wasPrevUppercase","charCodeAt","toLowerCase","camelToSnake","toCamelCase","parts","split","c","charAt","toUpperCase","slice","shift","keepOriginal","blacklist","blacklistedKeys","merge","base","with","object2","keys2","getKeysNotIn","allowedKeys","notAllowed","getOriginFromUrl","url","parsed","origin","trimUserDetails","trimMultiple","updatePropertyOn","path","next","hasOwnProperty","getWindow","window","redirect","location","getDocument","document","getOrigin","objectHelper","context","definition","normalize","strArray","resultArray","first","replace","component","join","module","exports","has","hexTable","arrayToObject","source","plainObjects","create","acc","combine","b","concat","compact","queue","prop","refs","item","j","val","pop","compacted","compactQueue","decode","decoder","charset","strWithoutPlus","unescape","decodeURIComponent","e","encode","defaultEncoder","string","Symbol","String","escape","$0","parseInt","out","isBuffer","constructor","isRegExp","maybeMap","fn","mapped","allowPrototypes","mergeTarget","forEach","targetItem","percentTwenties","Format","RFC1738","RFC3986","util","default","formatters","arrayPrefixGenerators","brackets","prefix","comma","indices","repeat","pushToArray","arr","valueOrArray","toISO","Date","toISOString","defaultFormat","formats","defaults","addQueryPrefix","allowDots","charsetSentinel","delimiter","encoder","utils","encodeValuesOnly","format","formatter","serializeDate","date","skipNulls","strictNullHandling","stringify","generateArrayPrefix","filter","sort","v","objKeys","keyPrefix","opts","normalizeStringifyOptions","arrayFormat","joined","PopupHandler","webAuth","_current_popup","PluginHandler","CordovaPlugin","version","extensibilityPoints","preload","_this","_window","windowHandler","popupOptions","width","height","windowFeatures","qs","closed","open","kill","success","close","load","_","cb","transientErrorHandler","event","errorHandler","transientStartHandler","startHandler","transientExitHandler","exitHandler","addEventListener","error","errorDescription","unhook","removeEventListener","callbackUrl","urljoin","baseOptions","domain","nonce","parseHash","result","processParams","redirectUri","owp","getPopupHandler","setWebAuth","supports","extensibilityPoint","cordova","electron","init"],"mappings":"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"} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index d63a057c..f1e3ca5f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "auth0-js", - "version": "9.14.2", + "version": "9.14.3", "lockfileVersion": 1, "requires": true, "dependencies": {