@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.
@@ -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 = call$2.bind ? call$2.bind(call$2) : function () {
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$6 = NASHORN_BUG ? function propertyIsEnumerable(V) {
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$6
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$3 = FunctionPrototype$2.bind;
205
+ var bind$2 = FunctionPrototype$2.bind;
200
206
  var call$1 = FunctionPrototype$2.call;
201
- var callBind = bind$3 && bind$3.bind(call$1);
207
+ var uncurryThis = functionBindNative && bind$2.bind(call$1, call$1);
202
208
 
203
- var functionUncurryThis = bind$3 ? function (fn) {
204
- return fn && callBind(call$1, 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.20.0',
387
+ version: '3.21.1',
382
388
  mode: 'global',
383
- copyright: '© 2021 Denis Pushkarev (zloirock.ru)'
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
- // Thank's IE8 for his funny defineProperty
471
+ // Thanks to IE8 for its funny defineProperty
464
472
  var ie8DomDefine = !descriptors && !fails(function () {
465
- // eslint-disable-next-line es/no-object-defineproperty -- requied for testing
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$1 = Object.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$5 = descriptors ? $getOwnPropertyDescriptor$1 : function getOwnPropertyDescriptor(O, P) {
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$1(O, P);
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$5
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$4 = descriptors ? $defineProperty$1 : function defineProperty(O, P, Attributes) {
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$4
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$3 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
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$3
809
+ f: f$4
772
810
  };
773
811
 
774
812
  // eslint-disable-next-line es/no-object-getownpropertysymbols -- safe
775
- var f$2 = Object.getOwnPropertySymbols;
813
+ var f$3 = Object.getOwnPropertySymbols;
776
814
 
777
815
  var objectGetOwnPropertySymbols = {
778
- f: f$2
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 || (bind$2 ? call.bind(apply) : function () {
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 objectDefineProperties = descriptors ? Object.defineProperties : function defineProperties(O, Properties) {
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 : bind$1 ? bind$1(fn, that) : function (/* ...args */) {
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 TYPED_ARRAY_TAG_REQIRED = false;
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) { /* empty */ }
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
- TYPED_ARRAY_TAG_REQIRED = true;
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: TYPED_ARRAY_TAG_REQIRED && 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.19.4';
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=" + left + ",top=" + top + ",width=" + width + ",height=" + height + ",resizable,scrollbars=yes,status=1");
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 " + url;
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 + "/oauth/token", timeout, audience || 'default', scope, {
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 + "::" + this.client_id + "::" + this.audience + "::" + this.scope;
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 + "." + this.clientId;
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 \"" + options.iss + "\", found \"" + decoded.claims.iss + "\"");
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 \"" + decoded.header.alg + "\" is not supported. Expected the ID token to be signed with \"RS256\".");
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 \"" + options.aud + "\" but was not one of \"" + decoded.claims.aud.join(', ') + "\"");
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 \"" + options.aud + "\", found \"" + decoded.claims.azp + "\"");
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 \"" + options.aud + "\" but found \"" + decoded.claims.aud + "\"");
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 \"" + options.nonce + "\", found \"" + decoded.claims.nonce + "\"");
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 (" + now + ") is after expiration time (" + expDate + ")");
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 (" + now + ") is before " + nbfDate);
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 (" + now + ") is after last auth at " + authTimeDate);
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 \"" + options.organizationId + "\", found \"" + decoded.claims.org_id + "\"");
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("" + LEGACY_PREFIX + key);
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("" + LEGACY_PREFIX + key, JSON.stringify(value), cookieAttributes);
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("" + LEGACY_PREFIX + key);
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 + "::" + clientId;
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." + clientId + ".organization_hint";
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." + clientId + ".is.authenticated";
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://" + issuer + "/";
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://" + domainUrl;
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 \"" + this.cacheLocation + "\"");
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 "" + this.domainUrl + path + "&auth0Client=" + auth0Client;
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?" + createQueryParams(authorizeOptions));
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 ? "#" + 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, return it. Otherwise, opens an
6011
- * iframe with the `/authorize` URL using the parameters provided
6012
- * as arguments. Random and secure `state` and `nonce` parameters
6013
- * will be auto-generated. If the response is successful, results
6014
- * will be valid according to their expiration times.
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 + "::" + getTokenOptions.audience + "::" + getTokenOptions.scope)];
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?" + createQueryParams(logoutOptions));
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, timeout, codeResult, scope, audience, customOptions, tokenResult, decodedToken, e_1;
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
- return [4 /*yield*/, runIframe(url, this.domainUrl, timeout)];
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];