@auth0/auth0-spa-js 1.19.4 → 1.21.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/auth0-spa-js.development.js +148 -79
- package/dist/auth0-spa-js.development.js.map +1 -1
- package/dist/auth0-spa-js.production.esm.js +1 -1
- package/dist/auth0-spa-js.production.esm.js.map +1 -1
- package/dist/auth0-spa-js.production.js +1 -1
- package/dist/auth0-spa-js.production.js.map +1 -1
- package/dist/lib/auth0-spa-js.cjs.js +148 -79
- package/dist/lib/auth0-spa-js.cjs.js.map +1 -1
- package/dist/typings/Auth0Client.d.ts +13 -12
- package/dist/typings/global.d.ts +16 -0
- package/dist/typings/storage.d.ts +1 -0
- package/dist/typings/version.d.ts +1 -1
- package/package.json +2 -2
- package/src/Auth0Client.ts +57 -30
- package/src/cache/cache-manager.ts +4 -1
- package/src/global.ts +18 -0
- package/src/http.ts +2 -0
- package/src/storage.ts +5 -0
- package/src/version.ts +1 -1
|
@@ -162,9 +162,15 @@
|
|
|
162
162
|
return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] != 7;
|
|
163
163
|
});
|
|
164
164
|
|
|
165
|
+
var functionBindNative = !fails(function () {
|
|
166
|
+
var test = (function () { /* empty */ }).bind();
|
|
167
|
+
// eslint-disable-next-line no-prototype-builtins -- safe
|
|
168
|
+
return typeof test != 'function' || test.hasOwnProperty('prototype');
|
|
169
|
+
});
|
|
170
|
+
|
|
165
171
|
var call$2 = Function.prototype.call;
|
|
166
172
|
|
|
167
|
-
var functionCall =
|
|
173
|
+
var functionCall = functionBindNative ? call$2.bind(call$2) : function () {
|
|
168
174
|
return call$2.apply(call$2, arguments);
|
|
169
175
|
};
|
|
170
176
|
|
|
@@ -177,13 +183,13 @@
|
|
|
177
183
|
|
|
178
184
|
// `Object.prototype.propertyIsEnumerable` method implementation
|
|
179
185
|
// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable
|
|
180
|
-
var f$
|
|
186
|
+
var f$7 = NASHORN_BUG ? function propertyIsEnumerable(V) {
|
|
181
187
|
var descriptor = getOwnPropertyDescriptor$2(this, V);
|
|
182
188
|
return !!descriptor && descriptor.enumerable;
|
|
183
189
|
} : $propertyIsEnumerable$1;
|
|
184
190
|
|
|
185
191
|
var objectPropertyIsEnumerable = {
|
|
186
|
-
f: f$
|
|
192
|
+
f: f$7
|
|
187
193
|
};
|
|
188
194
|
|
|
189
195
|
var createPropertyDescriptor = function (bitmap, value) {
|
|
@@ -196,12 +202,12 @@
|
|
|
196
202
|
};
|
|
197
203
|
|
|
198
204
|
var FunctionPrototype$2 = Function.prototype;
|
|
199
|
-
var bind$
|
|
205
|
+
var bind$2 = FunctionPrototype$2.bind;
|
|
200
206
|
var call$1 = FunctionPrototype$2.call;
|
|
201
|
-
var
|
|
207
|
+
var uncurryThis = functionBindNative && bind$2.bind(call$1, call$1);
|
|
202
208
|
|
|
203
|
-
var functionUncurryThis =
|
|
204
|
-
return fn &&
|
|
209
|
+
var functionUncurryThis = functionBindNative ? function (fn) {
|
|
210
|
+
return fn && uncurryThis(fn);
|
|
205
211
|
} : function (fn) {
|
|
206
212
|
return fn && function () {
|
|
207
213
|
return call$1.apply(fn, arguments);
|
|
@@ -378,9 +384,11 @@
|
|
|
378
384
|
(module.exports = function (key, value) {
|
|
379
385
|
return sharedStore[key] || (sharedStore[key] = value !== undefined ? value : {});
|
|
380
386
|
})('versions', []).push({
|
|
381
|
-
version: '3.
|
|
387
|
+
version: '3.21.1',
|
|
382
388
|
mode: 'global',
|
|
383
|
-
copyright: '©
|
|
389
|
+
copyright: '© 2014-2022 Denis Pushkarev (zloirock.ru)',
|
|
390
|
+
license: 'https://github.com/zloirock/core-js/blob/v3.21.1/LICENSE',
|
|
391
|
+
source: 'https://github.com/zloirock/core-js'
|
|
384
392
|
});
|
|
385
393
|
});
|
|
386
394
|
|
|
@@ -460,32 +468,42 @@
|
|
|
460
468
|
return EXISTS$1 ? document$1.createElement(it) : {};
|
|
461
469
|
};
|
|
462
470
|
|
|
463
|
-
//
|
|
471
|
+
// Thanks to IE8 for its funny defineProperty
|
|
464
472
|
var ie8DomDefine = !descriptors && !fails(function () {
|
|
465
|
-
// eslint-disable-next-line es/no-object-defineproperty --
|
|
473
|
+
// eslint-disable-next-line es/no-object-defineproperty -- required for testing
|
|
466
474
|
return Object.defineProperty(documentCreateElement('div'), 'a', {
|
|
467
475
|
get: function () { return 7; }
|
|
468
476
|
}).a != 7;
|
|
469
477
|
});
|
|
470
478
|
|
|
471
479
|
// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
|
|
472
|
-
var $getOwnPropertyDescriptor$
|
|
480
|
+
var $getOwnPropertyDescriptor$2 = Object.getOwnPropertyDescriptor;
|
|
473
481
|
|
|
474
482
|
// `Object.getOwnPropertyDescriptor` method
|
|
475
483
|
// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor
|
|
476
|
-
var f$
|
|
484
|
+
var f$6 = descriptors ? $getOwnPropertyDescriptor$2 : function getOwnPropertyDescriptor(O, P) {
|
|
477
485
|
O = toIndexedObject(O);
|
|
478
486
|
P = toPropertyKey(P);
|
|
479
487
|
if (ie8DomDefine) try {
|
|
480
|
-
return $getOwnPropertyDescriptor$
|
|
488
|
+
return $getOwnPropertyDescriptor$2(O, P);
|
|
481
489
|
} catch (error) { /* empty */ }
|
|
482
490
|
if (hasOwnProperty_1(O, P)) return createPropertyDescriptor(!functionCall(objectPropertyIsEnumerable.f, O, P), O[P]);
|
|
483
491
|
};
|
|
484
492
|
|
|
485
493
|
var objectGetOwnPropertyDescriptor = {
|
|
486
|
-
f: f$
|
|
494
|
+
f: f$6
|
|
487
495
|
};
|
|
488
496
|
|
|
497
|
+
// V8 ~ Chrome 36-
|
|
498
|
+
// https://bugs.chromium.org/p/v8/issues/detail?id=3334
|
|
499
|
+
var v8PrototypeDefineBug = descriptors && fails(function () {
|
|
500
|
+
// eslint-disable-next-line es/no-object-defineproperty -- required for testing
|
|
501
|
+
return Object.defineProperty(function () { /* empty */ }, 'prototype', {
|
|
502
|
+
value: 42,
|
|
503
|
+
writable: false
|
|
504
|
+
}).prototype != 42;
|
|
505
|
+
});
|
|
506
|
+
|
|
489
507
|
var String$3 = global_1.String;
|
|
490
508
|
var TypeError$c = global_1.TypeError;
|
|
491
509
|
|
|
@@ -498,10 +516,30 @@
|
|
|
498
516
|
var TypeError$b = global_1.TypeError;
|
|
499
517
|
// eslint-disable-next-line es/no-object-defineproperty -- safe
|
|
500
518
|
var $defineProperty$1 = Object.defineProperty;
|
|
519
|
+
// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
|
|
520
|
+
var $getOwnPropertyDescriptor$1 = Object.getOwnPropertyDescriptor;
|
|
521
|
+
var ENUMERABLE = 'enumerable';
|
|
522
|
+
var CONFIGURABLE$1 = 'configurable';
|
|
523
|
+
var WRITABLE = 'writable';
|
|
501
524
|
|
|
502
525
|
// `Object.defineProperty` method
|
|
503
526
|
// https://tc39.es/ecma262/#sec-object.defineproperty
|
|
504
|
-
var f$
|
|
527
|
+
var f$5 = descriptors ? v8PrototypeDefineBug ? function defineProperty(O, P, Attributes) {
|
|
528
|
+
anObject(O);
|
|
529
|
+
P = toPropertyKey(P);
|
|
530
|
+
anObject(Attributes);
|
|
531
|
+
if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {
|
|
532
|
+
var current = $getOwnPropertyDescriptor$1(O, P);
|
|
533
|
+
if (current && current[WRITABLE]) {
|
|
534
|
+
O[P] = Attributes.value;
|
|
535
|
+
Attributes = {
|
|
536
|
+
configurable: CONFIGURABLE$1 in Attributes ? Attributes[CONFIGURABLE$1] : current[CONFIGURABLE$1],
|
|
537
|
+
enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],
|
|
538
|
+
writable: false
|
|
539
|
+
};
|
|
540
|
+
}
|
|
541
|
+
} return $defineProperty$1(O, P, Attributes);
|
|
542
|
+
} : $defineProperty$1 : function defineProperty(O, P, Attributes) {
|
|
505
543
|
anObject(O);
|
|
506
544
|
P = toPropertyKey(P);
|
|
507
545
|
anObject(Attributes);
|
|
@@ -514,7 +552,7 @@
|
|
|
514
552
|
};
|
|
515
553
|
|
|
516
554
|
var objectDefineProperty = {
|
|
517
|
-
f: f$
|
|
555
|
+
f: f$5
|
|
518
556
|
};
|
|
519
557
|
|
|
520
558
|
var createNonEnumerableProperty = descriptors ? function (object, key, value) {
|
|
@@ -763,19 +801,19 @@
|
|
|
763
801
|
// `Object.getOwnPropertyNames` method
|
|
764
802
|
// https://tc39.es/ecma262/#sec-object.getownpropertynames
|
|
765
803
|
// eslint-disable-next-line es/no-object-getownpropertynames -- safe
|
|
766
|
-
var f$
|
|
804
|
+
var f$4 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
|
|
767
805
|
return objectKeysInternal(O, hiddenKeys);
|
|
768
806
|
};
|
|
769
807
|
|
|
770
808
|
var objectGetOwnPropertyNames = {
|
|
771
|
-
f: f$
|
|
809
|
+
f: f$4
|
|
772
810
|
};
|
|
773
811
|
|
|
774
812
|
// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe
|
|
775
|
-
var f$
|
|
813
|
+
var f$3 = Object.getOwnPropertySymbols;
|
|
776
814
|
|
|
777
815
|
var objectGetOwnPropertySymbols = {
|
|
778
|
-
f: f$
|
|
816
|
+
f: f$3
|
|
779
817
|
};
|
|
780
818
|
|
|
781
819
|
var concat = functionUncurryThis([].concat);
|
|
@@ -1147,11 +1185,10 @@
|
|
|
1147
1185
|
|
|
1148
1186
|
var FunctionPrototype = Function.prototype;
|
|
1149
1187
|
var apply = FunctionPrototype.apply;
|
|
1150
|
-
var bind$2 = FunctionPrototype.bind;
|
|
1151
1188
|
var call = FunctionPrototype.call;
|
|
1152
1189
|
|
|
1153
1190
|
// eslint-disable-next-line es/no-reflect -- safe
|
|
1154
|
-
var functionApply = typeof Reflect == 'object' && Reflect.apply || (
|
|
1191
|
+
var functionApply = typeof Reflect == 'object' && Reflect.apply || (functionBindNative ? call.bind(apply) : function () {
|
|
1155
1192
|
return call.apply(apply, arguments);
|
|
1156
1193
|
});
|
|
1157
1194
|
|
|
@@ -1165,7 +1202,7 @@
|
|
|
1165
1202
|
// `Object.defineProperties` method
|
|
1166
1203
|
// https://tc39.es/ecma262/#sec-object.defineproperties
|
|
1167
1204
|
// eslint-disable-next-line es/no-object-defineproperties -- safe
|
|
1168
|
-
var
|
|
1205
|
+
var f$2 = descriptors && !v8PrototypeDefineBug ? Object.defineProperties : function defineProperties(O, Properties) {
|
|
1169
1206
|
anObject(O);
|
|
1170
1207
|
var props = toIndexedObject(Properties);
|
|
1171
1208
|
var keys = objectKeys(Properties);
|
|
@@ -1176,6 +1213,10 @@
|
|
|
1176
1213
|
return O;
|
|
1177
1214
|
};
|
|
1178
1215
|
|
|
1216
|
+
var objectDefineProperties = {
|
|
1217
|
+
f: f$2
|
|
1218
|
+
};
|
|
1219
|
+
|
|
1179
1220
|
var html = getBuiltIn('document', 'documentElement');
|
|
1180
1221
|
|
|
1181
1222
|
/* global ActiveXObject -- old IE, WSH */
|
|
@@ -1258,7 +1299,7 @@
|
|
|
1258
1299
|
// add "__proto__" for Object.getPrototypeOf polyfill
|
|
1259
1300
|
result[IE_PROTO$1] = O;
|
|
1260
1301
|
} else result = NullProtoObject();
|
|
1261
|
-
return Properties === undefined ? result : objectDefineProperties(result, Properties);
|
|
1302
|
+
return Properties === undefined ? result : objectDefineProperties.f(result, Properties);
|
|
1262
1303
|
};
|
|
1263
1304
|
|
|
1264
1305
|
var Array$2 = global_1.Array;
|
|
@@ -1339,7 +1380,7 @@
|
|
|
1339
1380
|
// optional / simple context binding
|
|
1340
1381
|
var functionBindContext = function (fn, that) {
|
|
1341
1382
|
aCallable(fn);
|
|
1342
|
-
return that === undefined ? fn :
|
|
1383
|
+
return that === undefined ? fn : functionBindNative ? bind$1(fn, that) : function (/* ...args */) {
|
|
1343
1384
|
return fn.apply(that, arguments);
|
|
1344
1385
|
};
|
|
1345
1386
|
};
|
|
@@ -1565,6 +1606,7 @@
|
|
|
1565
1606
|
|
|
1566
1607
|
objectPropertyIsEnumerable.f = $propertyIsEnumerable;
|
|
1567
1608
|
objectDefineProperty.f = $defineProperty;
|
|
1609
|
+
objectDefineProperties.f = $defineProperties;
|
|
1568
1610
|
objectGetOwnPropertyDescriptor.f = $getOwnPropertyDescriptor;
|
|
1569
1611
|
objectGetOwnPropertyNames.f = objectGetOwnPropertyNamesExternal.f = $getOwnPropertyNames;
|
|
1570
1612
|
objectGetOwnPropertySymbols.f = $getOwnPropertySymbols;
|
|
@@ -2232,7 +2274,7 @@
|
|
|
2232
2274
|
var TYPED_ARRAY_CONSTRUCTOR$1 = uid('TYPED_ARRAY_CONSTRUCTOR');
|
|
2233
2275
|
// Fixing native typed arrays in Opera Presto crashes the browser, see #595
|
|
2234
2276
|
var NATIVE_ARRAY_BUFFER_VIEWS = arrayBufferNative && !!objectSetPrototypeOf && classof(global_1.opera) !== 'Opera';
|
|
2235
|
-
var
|
|
2277
|
+
var TYPED_ARRAY_TAG_REQUIRED = false;
|
|
2236
2278
|
var NAME, Constructor, Prototype;
|
|
2237
2279
|
|
|
2238
2280
|
var TypedArrayConstructorsList = {
|
|
@@ -2283,7 +2325,12 @@
|
|
|
2283
2325
|
var TypedArrayConstructor = global_1[ARRAY];
|
|
2284
2326
|
if (TypedArrayConstructor && hasOwnProperty_1(TypedArrayConstructor.prototype, KEY)) try {
|
|
2285
2327
|
delete TypedArrayConstructor.prototype[KEY];
|
|
2286
|
-
} catch (error) {
|
|
2328
|
+
} catch (error) {
|
|
2329
|
+
// old WebKit bug - some methods are non-configurable
|
|
2330
|
+
try {
|
|
2331
|
+
TypedArrayConstructor.prototype[KEY] = property;
|
|
2332
|
+
} catch (error2) { /* empty */ }
|
|
2333
|
+
}
|
|
2287
2334
|
}
|
|
2288
2335
|
if (!TypedArrayPrototype[KEY] || forced) {
|
|
2289
2336
|
redefine(TypedArrayPrototype, KEY, forced ? property
|
|
@@ -2353,7 +2400,7 @@
|
|
|
2353
2400
|
}
|
|
2354
2401
|
|
|
2355
2402
|
if (descriptors && !hasOwnProperty_1(TypedArrayPrototype, TO_STRING_TAG)) {
|
|
2356
|
-
|
|
2403
|
+
TYPED_ARRAY_TAG_REQUIRED = true;
|
|
2357
2404
|
defineProperty$2(TypedArrayPrototype, TO_STRING_TAG, { get: function () {
|
|
2358
2405
|
return isObject(this) ? this[TYPED_ARRAY_TAG] : undefined;
|
|
2359
2406
|
} });
|
|
@@ -2365,7 +2412,7 @@
|
|
|
2365
2412
|
var arrayBufferViewCore = {
|
|
2366
2413
|
NATIVE_ARRAY_BUFFER_VIEWS: NATIVE_ARRAY_BUFFER_VIEWS,
|
|
2367
2414
|
TYPED_ARRAY_CONSTRUCTOR: TYPED_ARRAY_CONSTRUCTOR$1,
|
|
2368
|
-
TYPED_ARRAY_TAG:
|
|
2415
|
+
TYPED_ARRAY_TAG: TYPED_ARRAY_TAG_REQUIRED && TYPED_ARRAY_TAG,
|
|
2369
2416
|
aTypedArray: aTypedArray$1,
|
|
2370
2417
|
aTypedArrayConstructor: aTypedArrayConstructor$1,
|
|
2371
2418
|
exportTypedArrayMethod: exportTypedArrayMethod$1,
|
|
@@ -4178,7 +4225,7 @@
|
|
|
4178
4225
|
|
|
4179
4226
|
var Lock = unwrapExports(browserTabsLock);
|
|
4180
4227
|
|
|
4181
|
-
var version = '1.
|
|
4228
|
+
var version = '1.21.0';
|
|
4182
4229
|
|
|
4183
4230
|
/**
|
|
4184
4231
|
* @ignore
|
|
@@ -4404,7 +4451,7 @@
|
|
|
4404
4451
|
var height = 600;
|
|
4405
4452
|
var left = window.screenX + (window.innerWidth - width) / 2;
|
|
4406
4453
|
var top = window.screenY + (window.innerHeight - height) / 2;
|
|
4407
|
-
return window.open(url, 'auth0:authorize:popup', "left="
|
|
4454
|
+
return window.open(url, 'auth0:authorize:popup', "left=".concat(left, ",top=").concat(top, ",width=").concat(width, ",height=").concat(height, ",resizable,scrollbars=yes,status=1"));
|
|
4408
4455
|
};
|
|
4409
4456
|
var runPopup = function (config) {
|
|
4410
4457
|
return new Promise(function (resolve, reject) {
|
|
@@ -4648,7 +4695,7 @@
|
|
|
4648
4695
|
}
|
|
4649
4696
|
_a = response.json, error = _a.error, error_description = _a.error_description, data = __rest(_a, ["error", "error_description"]), ok = response.ok;
|
|
4650
4697
|
if (!ok) {
|
|
4651
|
-
errorMessage = error_description || "HTTP error. Unable to fetch "
|
|
4698
|
+
errorMessage = error_description || "HTTP error. Unable to fetch ".concat(url);
|
|
4652
4699
|
if (error === 'mfa_required') {
|
|
4653
4700
|
throw new MfaRequiredError(error, errorMessage, data.mfa_token);
|
|
4654
4701
|
}
|
|
@@ -4670,7 +4717,7 @@
|
|
|
4670
4717
|
body = useFormData
|
|
4671
4718
|
? createQueryParams(options)
|
|
4672
4719
|
: JSON.stringify(options);
|
|
4673
|
-
return [4 /*yield*/, getJSON(baseUrl
|
|
4720
|
+
return [4 /*yield*/, getJSON("".concat(baseUrl, "/oauth/token"), timeout, audience || 'default', scope, {
|
|
4674
4721
|
method: 'POST',
|
|
4675
4722
|
body: body,
|
|
4676
4723
|
headers: {
|
|
@@ -4715,7 +4762,7 @@
|
|
|
4715
4762
|
* @returns A string representation of the key
|
|
4716
4763
|
*/
|
|
4717
4764
|
CacheKey.prototype.toKey = function () {
|
|
4718
|
-
return this.prefix
|
|
4765
|
+
return "".concat(this.prefix, "::").concat(this.client_id, "::").concat(this.audience, "::").concat(this.scope);
|
|
4719
4766
|
};
|
|
4720
4767
|
/**
|
|
4721
4768
|
* Converts a cache key string into a `CacheKey` instance.
|
|
@@ -4824,6 +4871,7 @@
|
|
|
4824
4871
|
if (!keys)
|
|
4825
4872
|
return [2 /*return*/];
|
|
4826
4873
|
matchedKey = this.matchExistingCacheKey(cacheKey, keys);
|
|
4874
|
+
if (!matchedKey) return [3 /*break*/, 4];
|
|
4827
4875
|
return [4 /*yield*/, this.cache.get(matchedKey)];
|
|
4828
4876
|
case 3:
|
|
4829
4877
|
wrappedEntry = _b.sent();
|
|
@@ -5009,7 +5057,7 @@
|
|
|
5009
5057
|
function TransactionManager(storage, clientId) {
|
|
5010
5058
|
this.storage = storage;
|
|
5011
5059
|
this.clientId = clientId;
|
|
5012
|
-
this.storageKey = TRANSACTION_STORAGE_KEY_PREFIX
|
|
5060
|
+
this.storageKey = "".concat(TRANSACTION_STORAGE_KEY_PREFIX, ".").concat(this.clientId);
|
|
5013
5061
|
this.transaction = this.storage.get(this.storageKey);
|
|
5014
5062
|
}
|
|
5015
5063
|
TransactionManager.prototype.create = function (transaction) {
|
|
@@ -5092,13 +5140,13 @@
|
|
|
5092
5140
|
throw new Error('Issuer (iss) claim must be a string present in the ID token');
|
|
5093
5141
|
}
|
|
5094
5142
|
if (decoded.claims.iss !== options.iss) {
|
|
5095
|
-
throw new Error("Issuer (iss) claim mismatch in the ID token; expected \""
|
|
5143
|
+
throw new Error("Issuer (iss) claim mismatch in the ID token; expected \"".concat(options.iss, "\", found \"").concat(decoded.claims.iss, "\""));
|
|
5096
5144
|
}
|
|
5097
5145
|
if (!decoded.user.sub) {
|
|
5098
5146
|
throw new Error('Subject (sub) claim must be a string present in the ID token');
|
|
5099
5147
|
}
|
|
5100
5148
|
if (decoded.header.alg !== 'RS256') {
|
|
5101
|
-
throw new Error("Signature algorithm of \""
|
|
5149
|
+
throw new Error("Signature algorithm of \"".concat(decoded.header.alg, "\" is not supported. Expected the ID token to be signed with \"RS256\"."));
|
|
5102
5150
|
}
|
|
5103
5151
|
if (!decoded.claims.aud ||
|
|
5104
5152
|
!(typeof decoded.claims.aud === 'string' ||
|
|
@@ -5107,26 +5155,26 @@
|
|
|
5107
5155
|
}
|
|
5108
5156
|
if (Array.isArray(decoded.claims.aud)) {
|
|
5109
5157
|
if (!decoded.claims.aud.includes(options.aud)) {
|
|
5110
|
-
throw new Error("Audience (aud) claim mismatch in the ID token; expected \""
|
|
5158
|
+
throw new Error("Audience (aud) claim mismatch in the ID token; expected \"".concat(options.aud, "\" but was not one of \"").concat(decoded.claims.aud.join(', '), "\""));
|
|
5111
5159
|
}
|
|
5112
5160
|
if (decoded.claims.aud.length > 1) {
|
|
5113
5161
|
if (!decoded.claims.azp) {
|
|
5114
5162
|
throw new Error('Authorized Party (azp) claim must be a string present in the ID token when Audience (aud) claim has multiple values');
|
|
5115
5163
|
}
|
|
5116
5164
|
if (decoded.claims.azp !== options.aud) {
|
|
5117
|
-
throw new Error("Authorized Party (azp) claim mismatch in the ID token; expected \""
|
|
5165
|
+
throw new Error("Authorized Party (azp) claim mismatch in the ID token; expected \"".concat(options.aud, "\", found \"").concat(decoded.claims.azp, "\""));
|
|
5118
5166
|
}
|
|
5119
5167
|
}
|
|
5120
5168
|
}
|
|
5121
5169
|
else if (decoded.claims.aud !== options.aud) {
|
|
5122
|
-
throw new Error("Audience (aud) claim mismatch in the ID token; expected \""
|
|
5170
|
+
throw new Error("Audience (aud) claim mismatch in the ID token; expected \"".concat(options.aud, "\" but found \"").concat(decoded.claims.aud, "\""));
|
|
5123
5171
|
}
|
|
5124
5172
|
if (options.nonce) {
|
|
5125
5173
|
if (!decoded.claims.nonce) {
|
|
5126
5174
|
throw new Error('Nonce (nonce) claim must be a string present in the ID token');
|
|
5127
5175
|
}
|
|
5128
5176
|
if (decoded.claims.nonce !== options.nonce) {
|
|
5129
|
-
throw new Error("Nonce (nonce) claim mismatch in the ID token; expected \""
|
|
5177
|
+
throw new Error("Nonce (nonce) claim mismatch in the ID token; expected \"".concat(options.nonce, "\", found \"").concat(decoded.claims.nonce, "\""));
|
|
5130
5178
|
}
|
|
5131
5179
|
}
|
|
5132
5180
|
if (options.max_age && !isNumber(decoded.claims.auth_time)) {
|
|
@@ -5148,20 +5196,20 @@
|
|
|
5148
5196
|
expDate.setUTCSeconds(decoded.claims.exp + leeway);
|
|
5149
5197
|
nbfDate.setUTCSeconds(decoded.claims.nbf - leeway);
|
|
5150
5198
|
if (now > expDate) {
|
|
5151
|
-
throw new Error("Expiration Time (exp) claim error in the ID token; current time ("
|
|
5199
|
+
throw new Error("Expiration Time (exp) claim error in the ID token; current time (".concat(now, ") is after expiration time (").concat(expDate, ")"));
|
|
5152
5200
|
}
|
|
5153
5201
|
if (isNumber(decoded.claims.nbf) && now < nbfDate) {
|
|
5154
|
-
throw new Error("Not Before time (nbf) claim in the ID token indicates that this token can't be used just yet. Currrent time ("
|
|
5202
|
+
throw new Error("Not Before time (nbf) claim in the ID token indicates that this token can't be used just yet. Currrent time (".concat(now, ") is before ").concat(nbfDate));
|
|
5155
5203
|
}
|
|
5156
5204
|
if (isNumber(decoded.claims.auth_time) && now > authTimeDate) {
|
|
5157
|
-
throw new Error("Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Currrent time ("
|
|
5205
|
+
throw new Error("Authentication Time (auth_time) claim in the ID token indicates that too much time has passed since the last end-user authentication. Currrent time (".concat(now, ") is after last auth at ").concat(authTimeDate));
|
|
5158
5206
|
}
|
|
5159
5207
|
if (options.organizationId) {
|
|
5160
5208
|
if (!decoded.claims.org_id) {
|
|
5161
5209
|
throw new Error('Organization ID (org_id) claim must be a string present in the ID token');
|
|
5162
5210
|
}
|
|
5163
5211
|
else if (options.organizationId !== decoded.claims.org_id) {
|
|
5164
|
-
throw new Error("Organization ID (org_id) claim mismatch in the ID token; expected \""
|
|
5212
|
+
throw new Error("Organization ID (org_id) claim mismatch in the ID token; expected \"".concat(options.organizationId, "\", found \"").concat(decoded.claims.org_id, "\""));
|
|
5165
5213
|
}
|
|
5166
5214
|
}
|
|
5167
5215
|
return decoded;
|
|
@@ -5281,6 +5329,9 @@
|
|
|
5281
5329
|
if (options === null || options === void 0 ? void 0 : options.daysUntilExpire) {
|
|
5282
5330
|
cookieAttributes.expires = options.daysUntilExpire;
|
|
5283
5331
|
}
|
|
5332
|
+
if (options === null || options === void 0 ? void 0 : options.cookieDomain) {
|
|
5333
|
+
cookieAttributes.domain = options.cookieDomain;
|
|
5334
|
+
}
|
|
5284
5335
|
esCookie_5(key, JSON.stringify(value), cookieAttributes);
|
|
5285
5336
|
},
|
|
5286
5337
|
remove: function (key) {
|
|
@@ -5301,7 +5352,7 @@
|
|
|
5301
5352
|
if (value) {
|
|
5302
5353
|
return value;
|
|
5303
5354
|
}
|
|
5304
|
-
return CookieStorage.get(""
|
|
5355
|
+
return CookieStorage.get("".concat(LEGACY_PREFIX).concat(key));
|
|
5305
5356
|
},
|
|
5306
5357
|
save: function (key, value, options) {
|
|
5307
5358
|
var cookieAttributes = {};
|
|
@@ -5311,12 +5362,12 @@
|
|
|
5311
5362
|
if (options === null || options === void 0 ? void 0 : options.daysUntilExpire) {
|
|
5312
5363
|
cookieAttributes.expires = options.daysUntilExpire;
|
|
5313
5364
|
}
|
|
5314
|
-
esCookie_5(""
|
|
5365
|
+
esCookie_5("".concat(LEGACY_PREFIX).concat(key), JSON.stringify(value), cookieAttributes);
|
|
5315
5366
|
CookieStorage.save(key, value, options);
|
|
5316
5367
|
},
|
|
5317
5368
|
remove: function (key) {
|
|
5318
5369
|
CookieStorage.remove(key);
|
|
5319
|
-
CookieStorage.remove(""
|
|
5370
|
+
CookieStorage.remove("".concat(LEGACY_PREFIX).concat(key));
|
|
5320
5371
|
}
|
|
5321
5372
|
};
|
|
5322
5373
|
/**
|
|
@@ -5372,7 +5423,7 @@
|
|
|
5372
5423
|
};
|
|
5373
5424
|
}
|
|
5374
5425
|
|
|
5375
|
-
var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
    'use strict';

    /*! *****************************************************************************
    Copyright (c) Microsoft Corporation.

    Permission to use, copy, modify, and/or distribute this software for any
    purpose with or without fee is hereby granted.

    THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
    REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
    AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
    INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
    LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
    OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
    PERFORMANCE OF THIS SOFTWARE.
    ***************************************************************************** */

    var __assign = function() {
        __assign = Object.assign || function __assign(t) {
            for (var s, i = 1, n = arguments.length; i < n; i++) {
                s = arguments[i];
                for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
            }
            return t;
        };
        return __assign.apply(this, arguments);
    };

    function __awaiter(thisArg, _arguments, P, generator) {
        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
        return new (P || (P = Promise))(function (resolve, reject) {
            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
            step((generator = generator.apply(thisArg, _arguments || [])).next());
        });
    }

    function __generator(thisArg, body) {
        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
        function verb(n) { return function (v) { return step([n, v]); }; }
        function step(op) {
            if (f) throw new TypeError("Generator is already executing.");
            while (_) try {
                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
                if (y = 0, t) op = [op[0] & 2, t.value];
                switch (op[0]) {
                    case 0: case 1: t = op; break;
                    case 4: _.label++; return { value: op[1], done: false };
                    case 5: _.label++; y = op[1]; op = [0]; continue;
                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
                    default:
                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
                        if (t[2]) _.ops.pop();
                        _.trys.pop(); continue;
                }
                op = body.call(thisArg, _);
            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
        }
    }

    function __read(o, n) {
        var m = typeof Symbol === "function" && o[Symbol.iterator];
        if (!m) return o;
        var i = m.call(o), r, ar = [], e;
        try {
            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
        }
        catch (error) { e = { error: error }; }
        finally {
            try {
                if (r && !r.done && (m = i["return"])) m.call(i);
            }
            finally { if (e) throw e.error; }
        }
        return ar;
    }

    /**
     * @ignore
     */
    var MISSING_REFRESH_TOKEN_ERROR_MESSAGE = 'The web worker is missing the refresh token';

    var refreshTokens = {};
    var cacheKey = function (audience, scope) { return audience + "|" + scope; };
    var getRefreshToken = function (audience, scope) {
        return refreshTokens[cacheKey(audience, scope)];
    };
    var setRefreshToken = function (refreshToken, audience, scope) { return (refreshTokens[cacheKey(audience, scope)] = refreshToken); };
    var deleteRefreshToken = function (audience, scope) {
        return delete refreshTokens[cacheKey(audience, scope)];
    };
    var wait = function (time) {
        return new Promise(function (resolve) { return setTimeout(resolve, time); });
    };
    var formDataToObject = function (formData) {
        var queryParams = new URLSearchParams(formData);
        var parsedQuery = {};
        queryParams.forEach(function (val, key) {
            parsedQuery[key] = val;
        });
        return parsedQuery;
    };
    var messageHandler = function (_a) {
        var _b = _a.data, timeout = _b.timeout, auth = _b.auth, fetchUrl = _b.fetchUrl, fetchOptions = _b.fetchOptions, useFormData = _b.useFormData, _c = __read(_a.ports, 1), port = _c[0];
        return __awaiter(void 0, void 0, void 0, function () {
            var json, _d, audience, scope, body, refreshToken, abortController, response, error_1, error_2;
            return __generator(this, function (_e) {
                switch (_e.label) {
                    case 0:
                        _d = auth || {}, audience = _d.audience, scope = _d.scope;
                        _e.label = 1;
                    case 1:
                        _e.trys.push([1, 7, , 8]);
                        body = useFormData
                            ? formDataToObject(fetchOptions.body)
                            : JSON.parse(fetchOptions.body);
                        if (!body.refresh_token && body.grant_type === 'refresh_token') {
                            refreshToken = getRefreshToken(audience, scope);
                            if (!refreshToken) {
                                throw new Error(MISSING_REFRESH_TOKEN_ERROR_MESSAGE);
                            }
                            fetchOptions.body = useFormData
                                ? new URLSearchParams(__assign(__assign({}, body), { refresh_token: refreshToken })).toString()
                                : JSON.stringify(__assign(__assign({}, body), { refresh_token: refreshToken }));
                        }
                        abortController = void 0;
                        if (typeof AbortController === 'function') {
                            abortController = new AbortController();
                            fetchOptions.signal = abortController.signal;
                        }
                        response = void 0;
                        _e.label = 2;
                    case 2:
                        _e.trys.push([2, 4, , 5]);
                        return [4 /*yield*/, Promise.race([
                                wait(timeout),
                                fetch(fetchUrl, __assign({}, fetchOptions))
                            ])];
                    case 3:
                        response = _e.sent();
                        return [3 /*break*/, 5];
                    case 4:
                        error_1 = _e.sent();
                        // fetch error, reject `sendMessage` using `error` key so that we retry.
                        port.postMessage({
                            error: error_1.message
                        });
                        return [2 /*return*/];
                    case 5:
                        if (!response) {
                            // If the request times out, abort it and let `switchFetch` raise the error.
                            if (abortController)
                                abortController.abort();
                            port.postMessage({
                                error: "Timeout when executing 'fetch'"
                            });
                            return [2 /*return*/];
                        }
                        return [4 /*yield*/, response.json()];
                    case 6:
                        json = _e.sent();
                        if (json.refresh_token) {
                            setRefreshToken(json.refresh_token, audience, scope);
                            delete json.refresh_token;
                        }
                        else {
                            deleteRefreshToken(audience, scope);
                        }
                        port.postMessage({
                            ok: response.ok,
                            json: json
                        });
                        return [3 /*break*/, 8];
                    case 7:
                        error_2 = _e.sent();
                        port.postMessage({
                            ok: false,
                            json: {
                                error_description: error_2.message
                            }
                        });
                        return [3 /*break*/, 8];
                    case 8: return [2 /*return*/];
                }
            });
        });
    };
    // Don't run `addEventListener` in our tests (this is replaced in rollup)
    /* istanbul ignore else  */
    {
        // @ts-ignore
        addEventListener('message', messageHandler);
    }

})();

', null, false);
|
|
5426
|
+
var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
    'use strict';

    /*! *****************************************************************************
    Copyright (c) Microsoft Corporation.

    Permission to use, copy, modify, and/or distribute this software for any
    purpose with or without fee is hereby granted.

    THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
    REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
    AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
    INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
    LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
    OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
    PERFORMANCE OF THIS SOFTWARE.
    ***************************************************************************** */

    var __assign = function() {
        __assign = Object.assign || function __assign(t) {
            for (var s, i = 1, n = arguments.length; i < n; i++) {
                s = arguments[i];
                for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
            }
            return t;
        };
        return __assign.apply(this, arguments);
    };

    function __awaiter(thisArg, _arguments, P, generator) {
        function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
        return new (P || (P = Promise))(function (resolve, reject) {
            function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
            function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
            function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
            step((generator = generator.apply(thisArg, _arguments || [])).next());
        });
    }

    function __generator(thisArg, body) {
        var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
        return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
        function verb(n) { return function (v) { return step([n, v]); }; }
        function step(op) {
            if (f) throw new TypeError("Generator is already executing.");
            while (_) try {
                if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
                if (y = 0, t) op = [op[0] & 2, t.value];
                switch (op[0]) {
                    case 0: case 1: t = op; break;
                    case 4: _.label++; return { value: op[1], done: false };
                    case 5: _.label++; y = op[1]; op = [0]; continue;
                    case 7: op = _.ops.pop(); _.trys.pop(); continue;
                    default:
                        if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
                        if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
                        if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
                        if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
                        if (t[2]) _.ops.pop();
                        _.trys.pop(); continue;
                }
                op = body.call(thisArg, _);
            } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
            if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
        }
    }

    function __read(o, n) {
        var m = typeof Symbol === "function" && o[Symbol.iterator];
        if (!m) return o;
        var i = m.call(o), r, ar = [], e;
        try {
            while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
        }
        catch (error) { e = { error: error }; }
        finally {
            try {
                if (r && !r.done && (m = i["return"])) m.call(i);
            }
            finally { if (e) throw e.error; }
        }
        return ar;
    }

    /**
     * @ignore
     */
    var MISSING_REFRESH_TOKEN_ERROR_MESSAGE = 'The web worker is missing the refresh token';

    var refreshTokens = {};
    var cacheKey = function (audience, scope) { return "".concat(audience, "|").concat(scope); };
    var getRefreshToken = function (audience, scope) {
        return refreshTokens[cacheKey(audience, scope)];
    };
    var setRefreshToken = function (refreshToken, audience, scope) { return (refreshTokens[cacheKey(audience, scope)] = refreshToken); };
    var deleteRefreshToken = function (audience, scope) {
        return delete refreshTokens[cacheKey(audience, scope)];
    };
    var wait = function (time) {
        return new Promise(function (resolve) { return setTimeout(resolve, time); });
    };
    var formDataToObject = function (formData) {
        var queryParams = new URLSearchParams(formData);
        var parsedQuery = {};
        queryParams.forEach(function (val, key) {
            parsedQuery[key] = val;
        });
        return parsedQuery;
    };
    var messageHandler = function (_a) {
        var _b = _a.data, timeout = _b.timeout, auth = _b.auth, fetchUrl = _b.fetchUrl, fetchOptions = _b.fetchOptions, useFormData = _b.useFormData, _c = __read(_a.ports, 1), port = _c[0];
        return __awaiter(void 0, void 0, void 0, function () {
            var json, _d, audience, scope, body, refreshToken, abortController, response, error_1, error_2;
            return __generator(this, function (_e) {
                switch (_e.label) {
                    case 0:
                        _d = auth || {}, audience = _d.audience, scope = _d.scope;
                        _e.label = 1;
                    case 1:
                        _e.trys.push([1, 7, , 8]);
                        body = useFormData
                            ? formDataToObject(fetchOptions.body)
                            : JSON.parse(fetchOptions.body);
                        if (!body.refresh_token && body.grant_type === 'refresh_token') {
                            refreshToken = getRefreshToken(audience, scope);
                            if (!refreshToken) {
                                throw new Error(MISSING_REFRESH_TOKEN_ERROR_MESSAGE);
                            }
                            fetchOptions.body = useFormData
                                ? new URLSearchParams(__assign(__assign({}, body), { refresh_token: refreshToken })).toString()
                                : JSON.stringify(__assign(__assign({}, body), { refresh_token: refreshToken }));
                        }
                        abortController = void 0;
                        if (typeof AbortController === 'function') {
                            abortController = new AbortController();
                            fetchOptions.signal = abortController.signal;
                        }
                        response = void 0;
                        _e.label = 2;
                    case 2:
                        _e.trys.push([2, 4, , 5]);
                        return [4 /*yield*/, Promise.race([
                                wait(timeout),
                                fetch(fetchUrl, __assign({}, fetchOptions))
                            ])];
                    case 3:
                        response = _e.sent();
                        return [3 /*break*/, 5];
                    case 4:
                        error_1 = _e.sent();
                        // fetch error, reject `sendMessage` using `error` key so that we retry.
                        port.postMessage({
                            error: error_1.message
                        });
                        return [2 /*return*/];
                    case 5:
                        if (!response) {
                            // If the request times out, abort it and let `switchFetch` raise the error.
                            if (abortController)
                                abortController.abort();
                            port.postMessage({
                                error: "Timeout when executing 'fetch'"
                            });
                            return [2 /*return*/];
                        }
                        return [4 /*yield*/, response.json()];
                    case 6:
                        json = _e.sent();
                        if (json.refresh_token) {
                            setRefreshToken(json.refresh_token, audience, scope);
                            delete json.refresh_token;
                        }
                        else {
                            deleteRefreshToken(audience, scope);
                        }
                        port.postMessage({
                            ok: response.ok,
                            json: json
                        });
                        return [3 /*break*/, 8];
                    case 7:
                        error_2 = _e.sent();
                        port.postMessage({
                            ok: false,
                            json: {
                                error_description: error_2.message
                            }
                        });
                        return [3 /*break*/, 8];
                    case 8: return [2 /*return*/];
                }
            });
        });
    };
    // Don't run `addEventListener` in our tests (this is replaced in rollup)
    /* istanbul ignore else  */
    {
        // @ts-ignore
        addEventListener('message', messageHandler);
    }

})();

', null, false);
|
|
5376
5427
|
/* eslint-enable */
|
|
5377
5428
|
|
|
5378
5429
|
var isIE11 = function () { return /Trident.*rv:11\.0/.test(navigator.userAgent); };
|
|
@@ -5471,7 +5522,7 @@
|
|
|
5471
5522
|
return this.cache.remove(this.manifestKey);
|
|
5472
5523
|
};
|
|
5473
5524
|
CacheKeyManifest.prototype.createManifestKeyFrom = function (clientId) {
|
|
5474
|
-
return CACHE_KEY_PREFIX
|
|
5525
|
+
return "".concat(CACHE_KEY_PREFIX, "::").concat(clientId);
|
|
5475
5526
|
};
|
|
5476
5527
|
return CacheKeyManifest;
|
|
5477
5528
|
}());
|
|
@@ -5488,7 +5539,7 @@
|
|
|
5488
5539
|
* @ignore
|
|
5489
5540
|
*/
|
|
5490
5541
|
var buildOrganizationHintCookieName = function (clientId) {
|
|
5491
|
-
return "auth0."
|
|
5542
|
+
return "auth0.".concat(clientId, ".organization_hint");
|
|
5492
5543
|
};
|
|
5493
5544
|
/**
|
|
5494
5545
|
* @ignore
|
|
@@ -5498,7 +5549,7 @@
|
|
|
5498
5549
|
* @ignore
|
|
5499
5550
|
*/
|
|
5500
5551
|
var buildIsAuthenticatedCookieName = function (clientId) {
|
|
5501
|
-
return "auth0."
|
|
5552
|
+
return "auth0.".concat(clientId, ".is.authenticated");
|
|
5502
5553
|
};
|
|
5503
5554
|
/**
|
|
5504
5555
|
* @ignore
|
|
@@ -5522,16 +5573,16 @@
|
|
|
5522
5573
|
*/
|
|
5523
5574
|
var getTokenIssuer = function (issuer, domainUrl) {
|
|
5524
5575
|
if (issuer) {
|
|
5525
|
-
return issuer.startsWith('https://') ? issuer : "https://"
|
|
5576
|
+
return issuer.startsWith('https://') ? issuer : "https://".concat(issuer, "/");
|
|
5526
5577
|
}
|
|
5527
|
-
return domainUrl
|
|
5578
|
+
return "".concat(domainUrl, "/");
|
|
5528
5579
|
};
|
|
5529
5580
|
/**
|
|
5530
5581
|
* @ignore
|
|
5531
5582
|
*/
|
|
5532
5583
|
var getDomain = function (domainUrl) {
|
|
5533
5584
|
if (!/^https?:\/\//.test(domainUrl)) {
|
|
5534
|
-
return "https://"
|
|
5585
|
+
return "https://".concat(domainUrl);
|
|
5535
5586
|
}
|
|
5536
5587
|
return domainUrl;
|
|
5537
5588
|
};
|
|
@@ -5560,10 +5611,13 @@
|
|
|
5560
5611
|
else {
|
|
5561
5612
|
this.cacheLocation = options.cacheLocation || CACHE_LOCATION_MEMORY;
|
|
5562
5613
|
if (!cacheFactory(this.cacheLocation)) {
|
|
5563
|
-
throw new Error("Invalid cache location \""
|
|
5614
|
+
throw new Error("Invalid cache location \"".concat(this.cacheLocation, "\""));
|
|
5564
5615
|
}
|
|
5565
5616
|
cache = cacheFactory(this.cacheLocation)();
|
|
5566
5617
|
}
|
|
5618
|
+
this.httpTimeoutMs = options.httpTimeoutInSeconds
|
|
5619
|
+
? options.httpTimeoutInSeconds * 1000
|
|
5620
|
+
: DEFAULT_FETCH_TIMEOUT_MS;
|
|
5567
5621
|
this.cookieStorage =
|
|
5568
5622
|
options.legacySameSiteCookie === false
|
|
5569
5623
|
? CookieStorage
|
|
@@ -5604,17 +5658,17 @@
|
|
|
5604
5658
|
}
|
|
5605
5659
|
Auth0Client.prototype._url = function (path) {
|
|
5606
5660
|
var auth0Client = encodeURIComponent(btoa(JSON.stringify(this.options.auth0Client || DEFAULT_AUTH0_CLIENT)));
|
|
5607
|
-
return ""
|
|
5661
|
+
return "".concat(this.domainUrl).concat(path, "&auth0Client=").concat(auth0Client);
|
|
5608
5662
|
};
|
|
5609
5663
|
Auth0Client.prototype._getParams = function (authorizeOptions, state, nonce, code_challenge, redirect_uri) {
|
|
5610
5664
|
// These options should be excluded from the authorize URL,
|
|
5611
5665
|
// as they're options for the client and not for the IdP.
|
|
5612
5666
|
// ** IMPORTANT ** If adding a new client option, include it in this destructure list.
|
|
5613
|
-
var _a = this.options; _a.useRefreshTokens; _a.useCookiesForTransactions; _a.useFormData; _a.auth0Client; _a.cacheLocation; _a.advancedOptions; _a.detailedResponse; _a.nowProvider; _a.authorizeTimeoutInSeconds; _a.legacySameSiteCookie; _a.sessionCheckExpiryDays; _a.domain; _a.leeway; var loginOptions = __rest(_a, ["useRefreshTokens", "useCookiesForTransactions", "useFormData", "auth0Client", "cacheLocation", "advancedOptions", "detailedResponse", "nowProvider", "authorizeTimeoutInSeconds", "legacySameSiteCookie", "sessionCheckExpiryDays", "domain", "leeway"]);
|
|
5667
|
+
var _a = this.options; _a.useRefreshTokens; _a.useCookiesForTransactions; _a.useFormData; _a.auth0Client; _a.cacheLocation; _a.advancedOptions; _a.detailedResponse; _a.nowProvider; _a.authorizeTimeoutInSeconds; _a.legacySameSiteCookie; _a.sessionCheckExpiryDays; _a.domain; _a.leeway; _a.httpTimeoutInSeconds; var loginOptions = __rest(_a, ["useRefreshTokens", "useCookiesForTransactions", "useFormData", "auth0Client", "cacheLocation", "advancedOptions", "detailedResponse", "nowProvider", "authorizeTimeoutInSeconds", "legacySameSiteCookie", "sessionCheckExpiryDays", "domain", "leeway", "httpTimeoutInSeconds"]);
|
|
5614
5668
|
return __assign(__assign(__assign({}, loginOptions), authorizeOptions), { scope: getUniqueScopes(this.defaultScope, this.scope, authorizeOptions.scope), response_type: 'code', response_mode: 'query', state: state, nonce: nonce, redirect_uri: redirect_uri || this.options.redirect_uri, code_challenge: code_challenge, code_challenge_method: 'S256' });
|
|
5615
5669
|
};
|
|
5616
5670
|
Auth0Client.prototype._authorizeUrl = function (authorizeOptions) {
|
|
5617
|
-
return this._url("/authorize?"
|
|
5671
|
+
return this._url("/authorize?".concat(createQueryParams(authorizeOptions)));
|
|
5618
5672
|
};
|
|
5619
5673
|
Auth0Client.prototype._verifyIdToken = function (id_token, nonce, organizationId) {
|
|
5620
5674
|
return __awaiter(this, void 0, void 0, function () {
|
|
@@ -5680,7 +5734,7 @@
|
|
|
5680
5734
|
case 1:
|
|
5681
5735
|
code_challengeBuffer = _a.sent();
|
|
5682
5736
|
code_challenge = bufferToBase64UrlEncoded(code_challengeBuffer);
|
|
5683
|
-
fragment = options.fragment ? "#"
|
|
5737
|
+
fragment = options.fragment ? "#".concat(options.fragment) : '';
|
|
5684
5738
|
params = this._getParams(authorizeOptions, stateIn, nonceIn, code_challenge, redirect_uri);
|
|
5685
5739
|
url = this._authorizeUrl(params);
|
|
5686
5740
|
organizationId = options.organization || this.options.organization;
|
|
@@ -5723,6 +5777,9 @@
|
|
|
5723
5777
|
config = config || {};
|
|
5724
5778
|
if (!config.popup) {
|
|
5725
5779
|
config.popup = openPopup('');
|
|
5780
|
+
if (!config.popup) {
|
|
5781
|
+
throw new Error('Unable to open a popup for loginWithPopup - window.open returned `null`');
|
|
5782
|
+
}
|
|
5726
5783
|
}
|
|
5727
5784
|
authorizeOptions = __rest(options, []);
|
|
5728
5785
|
stateIn = encode(createRandomString());
|
|
@@ -5753,7 +5810,8 @@
|
|
|
5753
5810
|
grant_type: 'authorization_code',
|
|
5754
5811
|
redirect_uri: params.redirect_uri,
|
|
5755
5812
|
auth0Client: this.options.auth0Client,
|
|
5756
|
-
useFormData: this.options.useFormData
|
|
5813
|
+
useFormData: this.options.useFormData,
|
|
5814
|
+
timeout: this.httpTimeoutMs
|
|
5757
5815
|
}, this.worker)];
|
|
5758
5816
|
case 3:
|
|
5759
5817
|
authResult = _a.sent();
|
|
@@ -5766,7 +5824,8 @@
|
|
|
5766
5824
|
case 5:
|
|
5767
5825
|
_a.sent();
|
|
5768
5826
|
this.cookieStorage.save(this.isAuthenticatedCookieName, true, {
|
|
5769
|
-
daysUntilExpire: this.sessionCheckExpiryDays
|
|
5827
|
+
daysUntilExpire: this.sessionCheckExpiryDays,
|
|
5828
|
+
cookieDomain: this.options.cookieDomain
|
|
5770
5829
|
});
|
|
5771
5830
|
this._processOrgIdHint(decodedToken.claims.org_id);
|
|
5772
5831
|
return [2 /*return*/];
|
|
@@ -5912,7 +5971,8 @@
|
|
|
5912
5971
|
grant_type: 'authorization_code',
|
|
5913
5972
|
code: code,
|
|
5914
5973
|
auth0Client: this.options.auth0Client,
|
|
5915
|
-
useFormData: this.options.useFormData
|
|
5974
|
+
useFormData: this.options.useFormData,
|
|
5975
|
+
timeout: this.httpTimeoutMs
|
|
5916
5976
|
};
|
|
5917
5977
|
// some old versions of the SDK might not have added redirect_uri to the
|
|
5918
5978
|
// transaction, we dont want the key to be set to undefined.
|
|
@@ -5929,7 +5989,8 @@
|
|
|
5929
5989
|
case 3:
|
|
5930
5990
|
_b.sent();
|
|
5931
5991
|
this.cookieStorage.save(this.isAuthenticatedCookieName, true, {
|
|
5932
|
-
daysUntilExpire: this.sessionCheckExpiryDays
|
|
5992
|
+
daysUntilExpire: this.sessionCheckExpiryDays,
|
|
5993
|
+
cookieDomain: this.options.cookieDomain
|
|
5933
5994
|
});
|
|
5934
5995
|
this._processOrgIdHint(decodedToken.claims.org_id);
|
|
5935
5996
|
return [2 /*return*/, {
|
|
@@ -5977,7 +6038,8 @@
|
|
|
5977
6038
|
else {
|
|
5978
6039
|
// Migrate the existing cookie to the new name scoped by client ID
|
|
5979
6040
|
this.cookieStorage.save(this.isAuthenticatedCookieName, true, {
|
|
5980
|
-
daysUntilExpire: this.sessionCheckExpiryDays
|
|
6041
|
+
daysUntilExpire: this.sessionCheckExpiryDays,
|
|
6042
|
+
cookieDomain: this.options.cookieDomain
|
|
5981
6043
|
});
|
|
5982
6044
|
this.cookieStorage.remove(OLD_IS_AUTHENTICATED_COOKIE_NAME);
|
|
5983
6045
|
}
|
|
@@ -6007,11 +6069,17 @@
|
|
|
6007
6069
|
* const token = await auth0.getTokenSilently(options);
|
|
6008
6070
|
* ```
|
|
6009
6071
|
*
|
|
6010
|
-
* If there's a valid token stored
|
|
6011
|
-
*
|
|
6012
|
-
*
|
|
6013
|
-
*
|
|
6014
|
-
* will be
|
|
6072
|
+
* If there's a valid token stored and it has more than 60 seconds
|
|
6073
|
+
* remaining before expiration, return the token. Otherwise, attempt
|
|
6074
|
+
* to obtain a new token.
|
|
6075
|
+
*
|
|
6076
|
+
* A new token will be obtained either by opening an iframe or a
|
|
6077
|
+
* refresh token (if `useRefreshTokens` is `true`)
|
|
6078
|
+
|
|
6079
|
+
* If iframes are used, opens an iframe with the `/authorize` URL
|
|
6080
|
+
* using the parameters provided as arguments. Random and secure `state`
|
|
6081
|
+
* and `nonce` parameters will be auto-generated. If the response is successful,
|
|
6082
|
+
* results will be validated according to their expiration times.
|
|
6015
6083
|
*
|
|
6016
6084
|
* If refresh tokens are used, the token endpoint is called directly with the
|
|
6017
6085
|
* 'refresh_token' grant. If no refresh token is available to make this call,
|
|
@@ -6037,7 +6105,7 @@
|
|
|
6037
6105
|
_a = __assign(__assign({ audience: this.options.audience, ignoreCache: false }, options), { scope: getUniqueScopes(this.defaultScope, this.scope, options.scope) }), ignoreCache = _a.ignoreCache, getTokenOptions = __rest(_a, ["ignoreCache"]);
|
|
6038
6106
|
return [2 /*return*/, singlePromise(function () {
|
|
6039
6107
|
return _this._getTokenSilently(__assign({ ignoreCache: ignoreCache }, getTokenOptions));
|
|
6040
|
-
}, this.options.client_id
|
|
6108
|
+
}, "".concat(this.options.client_id, "::").concat(getTokenOptions.audience, "::").concat(getTokenOptions.scope))];
|
|
6041
6109
|
});
|
|
6042
6110
|
});
|
|
6043
6111
|
};
|
|
@@ -6097,7 +6165,8 @@
|
|
|
6097
6165
|
case 11:
|
|
6098
6166
|
_b.sent();
|
|
6099
6167
|
this.cookieStorage.save(this.isAuthenticatedCookieName, true, {
|
|
6100
|
-
daysUntilExpire: this.sessionCheckExpiryDays
|
|
6168
|
+
daysUntilExpire: this.sessionCheckExpiryDays,
|
|
6169
|
+
cookieDomain: this.options.cookieDomain
|
|
6101
6170
|
});
|
|
6102
6171
|
if (options.detailedResponse) {
|
|
6103
6172
|
id_token = authResult.id_token, access_token = authResult.access_token, oauthTokenScope = authResult.oauthTokenScope, expires_in = authResult.expires_in;
|
|
@@ -6193,7 +6262,7 @@
|
|
|
6193
6262
|
}
|
|
6194
6263
|
var federated = options.federated, logoutOptions = __rest(options, ["federated"]);
|
|
6195
6264
|
var federatedQuery = federated ? "&federated" : '';
|
|
6196
|
-
var url = this._url("/v2/logout?"
|
|
6265
|
+
var url = this._url("/v2/logout?".concat(createQueryParams(logoutOptions)));
|
|
6197
6266
|
return url + federatedQuery;
|
|
6198
6267
|
};
|
|
6199
6268
|
/**
|
|
@@ -6240,7 +6309,7 @@
|
|
|
6240
6309
|
};
|
|
6241
6310
|
Auth0Client.prototype._getTokenFromIFrame = function (options) {
|
|
6242
6311
|
return __awaiter(this, void 0, void 0, function () {
|
|
6243
|
-
var stateIn, nonceIn, code_verifier, code_challengeBuffer, code_challenge, withoutClientOptions, params, orgIdHint, url,
|
|
6312
|
+
var stateIn, nonceIn, code_verifier, code_challengeBuffer, code_challenge, withoutClientOptions, params, orgIdHint, url, authorizeTimeout, codeResult, scope, audience, customOptions, tokenResult, decodedToken, e_1;
|
|
6244
6313
|
return __generator(this, function (_a) {
|
|
6245
6314
|
switch (_a.label) {
|
|
6246
6315
|
case 0:
|
|
@@ -6260,7 +6329,6 @@
|
|
|
6260
6329
|
params.organization = orgIdHint;
|
|
6261
6330
|
}
|
|
6262
6331
|
url = this._authorizeUrl(__assign(__assign({}, params), { prompt: 'none', response_mode: 'web_message' }));
|
|
6263
|
-
timeout = options.timeoutInSeconds || this.options.authorizeTimeoutInSeconds;
|
|
6264
6332
|
_a.label = 2;
|
|
6265
6333
|
case 2:
|
|
6266
6334
|
_a.trys.push([2, 6, , 7]);
|
|
@@ -6270,14 +6338,15 @@
|
|
|
6270
6338
|
if (window.crossOriginIsolated) {
|
|
6271
6339
|
throw new GenericError('login_required', 'The application is running in a Cross-Origin Isolated context, silently retrieving a token without refresh token is not possible.');
|
|
6272
6340
|
}
|
|
6273
|
-
|
|
6341
|
+
authorizeTimeout = options.timeoutInSeconds || this.options.authorizeTimeoutInSeconds;
|
|
6342
|
+
return [4 /*yield*/, runIframe(url, this.domainUrl, authorizeTimeout)];
|
|
6274
6343
|
case 3:
|
|
6275
6344
|
codeResult = _a.sent();
|
|
6276
6345
|
if (stateIn !== codeResult.state) {
|
|
6277
6346
|
throw new Error('Invalid state');
|
|
6278
6347
|
}
|
|
6279
6348
|
scope = options.scope, audience = options.audience, customOptions = __rest(options, ["scope", "audience", "redirect_uri", "ignoreCache", "timeoutInSeconds", "detailedResponse"]);
|
|
6280
|
-
return [4 /*yield*/, oauthToken(__assign(__assign(__assign({}, this.customOptions), customOptions), { scope: scope, audience: audience, baseUrl: this.domainUrl, client_id: this.options.client_id, code_verifier: code_verifier, code: codeResult.code, grant_type: 'authorization_code', redirect_uri: params.redirect_uri, auth0Client: this.options.auth0Client, useFormData: this.options.useFormData }), this.worker)];
|
|
6349
|
+
return [4 /*yield*/, oauthToken(__assign(__assign(__assign({}, this.customOptions), customOptions), { scope: scope, audience: audience, baseUrl: this.domainUrl, client_id: this.options.client_id, code_verifier: code_verifier, code: codeResult.code, grant_type: 'authorization_code', redirect_uri: params.redirect_uri, auth0Client: this.options.auth0Client, useFormData: this.options.useFormData, timeout: customOptions.timeout || this.httpTimeoutMs }), this.worker)];
|
|
6281
6350
|
case 4:
|
|
6282
6351
|
tokenResult = _a.sent();
|
|
6283
6352
|
return [4 /*yield*/, this._verifyIdToken(tokenResult.id_token, nonceIn)];
|
|
@@ -6326,7 +6395,7 @@
|
|
|
6326
6395
|
_a.label = 4;
|
|
6327
6396
|
case 4:
|
|
6328
6397
|
_a.trys.push([4, 6, , 9]);
|
|
6329
|
-
return [4 /*yield*/, oauthToken(__assign(__assign(__assign(__assign(__assign({}, this.customOptions), customOptions), { audience: audience, scope: scope, baseUrl: this.domainUrl, client_id: this.options.client_id, grant_type: 'refresh_token', refresh_token: cache && cache.refresh_token, redirect_uri: redirect_uri }), (timeout && { timeout: timeout })), { auth0Client: this.options.auth0Client, useFormData: this.options.useFormData }), this.worker)];
|
|
6398
|
+
return [4 /*yield*/, oauthToken(__assign(__assign(__assign(__assign(__assign({}, this.customOptions), customOptions), { audience: audience, scope: scope, baseUrl: this.domainUrl, client_id: this.options.client_id, grant_type: 'refresh_token', refresh_token: cache && cache.refresh_token, redirect_uri: redirect_uri }), (timeout && { timeout: timeout })), { auth0Client: this.options.auth0Client, useFormData: this.options.useFormData, timeout: this.httpTimeoutMs }), this.worker)];
|
|
6330
6399
|
case 5:
|
|
6331
6400
|
tokenResult = _a.sent();
|
|
6332
6401
|
return [3 /*break*/, 9];
|