bruce-models 2.3.3 → 2.3.5

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.
Files changed (66) hide show
  1. package/dist/bruce-models.es5.js +3142 -298
  2. package/dist/bruce-models.es5.js.map +1 -1
  3. package/dist/bruce-models.umd.js +3142 -298
  4. package/dist/bruce-models.umd.js.map +1 -1
  5. package/dist/lib/account/account.js +9 -9
  6. package/dist/lib/account/account.js.map +1 -1
  7. package/dist/lib/ann-document/ann-document.js +6 -6
  8. package/dist/lib/ann-document/ann-document.js.map +1 -1
  9. package/dist/lib/api/abstract-api.js +6 -1
  10. package/dist/lib/api/abstract-api.js.map +1 -1
  11. package/dist/lib/api/api.js +1 -1
  12. package/dist/lib/api/api.js.map +1 -1
  13. package/dist/lib/client-file/client-file.js +3 -3
  14. package/dist/lib/client-file/client-file.js.map +1 -1
  15. package/dist/lib/common/cache.js +162 -139
  16. package/dist/lib/common/cache.js.map +1 -1
  17. package/dist/lib/custom-form/custom-form.js +6 -6
  18. package/dist/lib/custom-form/custom-form.js.map +1 -1
  19. package/dist/lib/entity/entity-attachment-type.js +3 -3
  20. package/dist/lib/entity/entity-attachment-type.js.map +1 -1
  21. package/dist/lib/entity/entity-attachment.js +3 -3
  22. package/dist/lib/entity/entity-attachment.js.map +1 -1
  23. package/dist/lib/entity/entity-comment.js +3 -3
  24. package/dist/lib/entity/entity-comment.js.map +1 -1
  25. package/dist/lib/entity/entity-coords.js +3 -3
  26. package/dist/lib/entity/entity-coords.js.map +1 -1
  27. package/dist/lib/entity/entity-link.js +3 -3
  28. package/dist/lib/entity/entity-link.js.map +1 -1
  29. package/dist/lib/entity/entity-lod-category.js +6 -6
  30. package/dist/lib/entity/entity-lod-category.js.map +1 -1
  31. package/dist/lib/entity/entity-lod.js +9 -9
  32. package/dist/lib/entity/entity-lod.js.map +1 -1
  33. package/dist/lib/entity/entity-relation-type.js +6 -6
  34. package/dist/lib/entity/entity-relation-type.js.map +1 -1
  35. package/dist/lib/entity/entity-relation.js +6 -6
  36. package/dist/lib/entity/entity-relation.js.map +1 -1
  37. package/dist/lib/entity/entity-source.js +3 -3
  38. package/dist/lib/entity/entity-source.js.map +1 -1
  39. package/dist/lib/entity/entity-tag.js +6 -6
  40. package/dist/lib/entity/entity-tag.js.map +1 -1
  41. package/dist/lib/entity/entity-type.js +6 -6
  42. package/dist/lib/entity/entity-type.js.map +1 -1
  43. package/dist/lib/entity/entity.js +6 -6
  44. package/dist/lib/entity/entity.js.map +1 -1
  45. package/dist/lib/import/imported-file.js +9 -9
  46. package/dist/lib/import/imported-file.js.map +1 -1
  47. package/dist/lib/plugin/plugin.js +6 -6
  48. package/dist/lib/plugin/plugin.js.map +1 -1
  49. package/dist/lib/program-key/program-key.js +6 -6
  50. package/dist/lib/program-key/program-key.js.map +1 -1
  51. package/dist/lib/project/project-view-bookmark.js +6 -6
  52. package/dist/lib/project/project-view-bookmark.js.map +1 -1
  53. package/dist/lib/project/project-view.js +6 -6
  54. package/dist/lib/project/project-view.js.map +1 -1
  55. package/dist/lib/style/style.js +6 -6
  56. package/dist/lib/style/style.js.map +1 -1
  57. package/dist/lib/tileset/tileset.js +12 -12
  58. package/dist/lib/tileset/tileset.js.map +1 -1
  59. package/dist/lib/user/session.js +5 -4
  60. package/dist/lib/user/session.js.map +1 -1
  61. package/dist/lib/user/user.js +15 -15
  62. package/dist/lib/user/user.js.map +1 -1
  63. package/dist/types/api/abstract-api.d.ts +4 -1
  64. package/dist/types/api/api.d.ts +1 -1
  65. package/dist/types/common/cache.d.ts +47 -17
  66. package/package.json +2 -2
@@ -69,7 +69,7 @@
69
69
  ECacheKey["ImportedFile"] = "importedfile";
70
70
  ECacheKey["Plugin"] = "plugin";
71
71
  })(ECacheKey = Api.ECacheKey || (Api.ECacheKey = {}));
72
- Api.DEFAULT_CACHE_DURATION = 60; // 1 minute.
72
+ Api.DEFAULT_CACHE_DURATION = 60 * 1000; // 1 minute.
73
73
  Api.TEMPLATE_ACCOUNT_ID = "template";
74
74
  Api.ACCESS_TOKEN_HEADER = "X-Access-Token";
75
75
  /**
@@ -138,9 +138,9 @@
138
138
  throw ("Doc ID is required.");
139
139
  }
140
140
  const key = GetCacheKey(docId);
141
- const cacheData = yield api.GetCacheItem(key, reqParams);
142
- if (cacheData) {
143
- return cacheData;
141
+ const cache = yield api.GetCacheItem(key, reqParams);
142
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
143
+ return cache.data;
144
144
  }
145
145
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
146
146
  try {
@@ -168,9 +168,9 @@
168
168
  if (!type) {
169
169
  type = "";
170
170
  }
171
- const cacheData = yield api.GetCacheItem(GetListCacheKey(type), reqParams);
172
- if (cacheData) {
173
- return cacheData;
171
+ const cache = yield api.GetCacheItem(GetListCacheKey(type), reqParams);
172
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
173
+ return cache.data;
174
174
  }
175
175
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
176
176
  try {
@@ -218,9 +218,9 @@
218
218
  if (!id) {
219
219
  throw ("Id is required.");
220
220
  }
221
- const cacheData = yield api.GetCacheItem(GetCacheKey(id), reqParams);
222
- if (cacheData) {
223
- return cacheData;
221
+ const cache = yield api.GetCacheItem(GetCacheKey(id), reqParams);
222
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
223
+ return cache.data;
224
224
  }
225
225
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
226
226
  try {
@@ -257,9 +257,9 @@
257
257
  return __awaiter(this, void 0, void 0, function* () {
258
258
  const { api, entityTypeId: typeId, req: reqParams } = params;
259
259
  const url = typeId ? `entityType/${typeId}/customForms` : "customForms";
260
- const cacheData = yield api.GetCacheItem(GetListCacheKey(typeId), reqParams);
261
- if (cacheData) {
262
- return cacheData;
260
+ const cache = yield api.GetCacheItem(GetListCacheKey(typeId), reqParams);
261
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
262
+ return cache.data;
263
263
  }
264
264
  const req = api.GET(url, exports.Api.PrepReqParams(reqParams));
265
265
  const prom = req.then((data) => {
@@ -315,165 +315,3003 @@
315
315
  })(EFlowDirection = CustomFormContent.EFlowDirection || (CustomFormContent.EFlowDirection = {}));
316
316
  })(exports.CustomFormContent || (exports.CustomFormContent = {}));
317
317
 
318
- class CacheItem {
319
- /**
320
- * @param id
321
- * @param data
322
- * @param duration in seconds until considered expired.
323
- */
324
- constructor(id, data, duration) {
325
- this.Id = id;
326
- this.Data = data;
327
- this.Duration = duration;
328
- this._created = duration > -1 ? new Date() : null;
329
- }
330
- IsExpired() {
331
- if (this._created == null) {
332
- return false;
333
- }
334
- return (new Date().getTime() - this._created.getTime()) / 1000 > this.Duration;
335
- }
336
- }
337
- // Milliseconds between each data cleaning.
338
- const CLEANER_INTERVAL = 5000;
339
- // Max number of items to clean in each cleaning.
340
- const MAX_CLEAN_BATCH = 100;
341
- // (Default) Max idle time to keep the cleaner alive.
342
- // Set to default API cache duration by default.
343
- const DEFAULT_MAX_CLEAN_IDLE = 60 * 5;
344
- /**
345
- * Simple local cache controller.
346
- */
318
+ var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
319
+
320
+ function commonjsRequire () {
321
+ throw new Error('Dynamic requires are not currently supported by rollup-plugin-commonjs');
322
+ }
323
+
324
+ function createCommonjsModule(fn, module) {
325
+ return module = { exports: {} }, fn(module, module.exports), module.exports;
326
+ }
327
+
328
+ var localforage = createCommonjsModule(function (module, exports) {
329
+ /*!
330
+ localForage -- Offline Storage, Improved
331
+ Version 1.10.0
332
+ https://localforage.github.io/localForage
333
+ (c) 2013-2017 Mozilla, Apache License 2.0
334
+ */
335
+ (function(f){{module.exports=f();}})(function(){return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof commonjsRequire=="function"&&commonjsRequire;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw (f.code="MODULE_NOT_FOUND", f)}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r);}return n[o].exports}var i=typeof commonjsRequire=="function"&&commonjsRequire;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(_dereq_,module,exports){
336
+ (function (global){
337
+ var Mutation = global.MutationObserver || global.WebKitMutationObserver;
338
+
339
+ var scheduleDrain;
340
+
341
+ {
342
+ if (Mutation) {
343
+ var called = 0;
344
+ var observer = new Mutation(nextTick);
345
+ var element = global.document.createTextNode('');
346
+ observer.observe(element, {
347
+ characterData: true
348
+ });
349
+ scheduleDrain = function () {
350
+ element.data = (called = ++called % 2);
351
+ };
352
+ } else if (!global.setImmediate && typeof global.MessageChannel !== 'undefined') {
353
+ var channel = new global.MessageChannel();
354
+ channel.port1.onmessage = nextTick;
355
+ scheduleDrain = function () {
356
+ channel.port2.postMessage(0);
357
+ };
358
+ } else if ('document' in global && 'onreadystatechange' in global.document.createElement('script')) {
359
+ scheduleDrain = function () {
360
+
361
+ // Create a <script> element; its readystatechange event will be fired asynchronously once it is inserted
362
+ // into the document. Do so, thus queuing up the task. Remember to clean up once it's been called.
363
+ var scriptEl = global.document.createElement('script');
364
+ scriptEl.onreadystatechange = function () {
365
+ nextTick();
366
+
367
+ scriptEl.onreadystatechange = null;
368
+ scriptEl.parentNode.removeChild(scriptEl);
369
+ scriptEl = null;
370
+ };
371
+ global.document.documentElement.appendChild(scriptEl);
372
+ };
373
+ } else {
374
+ scheduleDrain = function () {
375
+ setTimeout(nextTick, 0);
376
+ };
377
+ }
378
+ }
379
+
380
+ var draining;
381
+ var queue = [];
382
+ //named nextTick for less confusing stack traces
383
+ function nextTick() {
384
+ draining = true;
385
+ var i, oldQueue;
386
+ var len = queue.length;
387
+ while (len) {
388
+ oldQueue = queue;
389
+ queue = [];
390
+ i = -1;
391
+ while (++i < len) {
392
+ oldQueue[i]();
393
+ }
394
+ len = queue.length;
395
+ }
396
+ draining = false;
397
+ }
398
+
399
+ module.exports = immediate;
400
+ function immediate(task) {
401
+ if (queue.push(task) === 1 && !draining) {
402
+ scheduleDrain();
403
+ }
404
+ }
405
+
406
+ }).call(this,typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
407
+ },{}],2:[function(_dereq_,module,exports){
408
+ var immediate = _dereq_(1);
409
+
410
+ /* istanbul ignore next */
411
+ function INTERNAL() {}
412
+
413
+ var handlers = {};
414
+
415
+ var REJECTED = ['REJECTED'];
416
+ var FULFILLED = ['FULFILLED'];
417
+ var PENDING = ['PENDING'];
418
+
419
+ module.exports = Promise;
420
+
421
+ function Promise(resolver) {
422
+ if (typeof resolver !== 'function') {
423
+ throw new TypeError('resolver must be a function');
424
+ }
425
+ this.state = PENDING;
426
+ this.queue = [];
427
+ this.outcome = void 0;
428
+ if (resolver !== INTERNAL) {
429
+ safelyResolveThenable(this, resolver);
430
+ }
431
+ }
432
+
433
+ Promise.prototype["catch"] = function (onRejected) {
434
+ return this.then(null, onRejected);
435
+ };
436
+ Promise.prototype.then = function (onFulfilled, onRejected) {
437
+ if (typeof onFulfilled !== 'function' && this.state === FULFILLED ||
438
+ typeof onRejected !== 'function' && this.state === REJECTED) {
439
+ return this;
440
+ }
441
+ var promise = new this.constructor(INTERNAL);
442
+ if (this.state !== PENDING) {
443
+ var resolver = this.state === FULFILLED ? onFulfilled : onRejected;
444
+ unwrap(promise, resolver, this.outcome);
445
+ } else {
446
+ this.queue.push(new QueueItem(promise, onFulfilled, onRejected));
447
+ }
448
+
449
+ return promise;
450
+ };
451
+ function QueueItem(promise, onFulfilled, onRejected) {
452
+ this.promise = promise;
453
+ if (typeof onFulfilled === 'function') {
454
+ this.onFulfilled = onFulfilled;
455
+ this.callFulfilled = this.otherCallFulfilled;
456
+ }
457
+ if (typeof onRejected === 'function') {
458
+ this.onRejected = onRejected;
459
+ this.callRejected = this.otherCallRejected;
460
+ }
461
+ }
462
+ QueueItem.prototype.callFulfilled = function (value) {
463
+ handlers.resolve(this.promise, value);
464
+ };
465
+ QueueItem.prototype.otherCallFulfilled = function (value) {
466
+ unwrap(this.promise, this.onFulfilled, value);
467
+ };
468
+ QueueItem.prototype.callRejected = function (value) {
469
+ handlers.reject(this.promise, value);
470
+ };
471
+ QueueItem.prototype.otherCallRejected = function (value) {
472
+ unwrap(this.promise, this.onRejected, value);
473
+ };
474
+
475
+ function unwrap(promise, func, value) {
476
+ immediate(function () {
477
+ var returnValue;
478
+ try {
479
+ returnValue = func(value);
480
+ } catch (e) {
481
+ return handlers.reject(promise, e);
482
+ }
483
+ if (returnValue === promise) {
484
+ handlers.reject(promise, new TypeError('Cannot resolve promise with itself'));
485
+ } else {
486
+ handlers.resolve(promise, returnValue);
487
+ }
488
+ });
489
+ }
490
+
491
+ handlers.resolve = function (self, value) {
492
+ var result = tryCatch(getThen, value);
493
+ if (result.status === 'error') {
494
+ return handlers.reject(self, result.value);
495
+ }
496
+ var thenable = result.value;
497
+
498
+ if (thenable) {
499
+ safelyResolveThenable(self, thenable);
500
+ } else {
501
+ self.state = FULFILLED;
502
+ self.outcome = value;
503
+ var i = -1;
504
+ var len = self.queue.length;
505
+ while (++i < len) {
506
+ self.queue[i].callFulfilled(value);
507
+ }
508
+ }
509
+ return self;
510
+ };
511
+ handlers.reject = function (self, error) {
512
+ self.state = REJECTED;
513
+ self.outcome = error;
514
+ var i = -1;
515
+ var len = self.queue.length;
516
+ while (++i < len) {
517
+ self.queue[i].callRejected(error);
518
+ }
519
+ return self;
520
+ };
521
+
522
+ function getThen(obj) {
523
+ // Make sure we only access the accessor once as required by the spec
524
+ var then = obj && obj.then;
525
+ if (obj && (typeof obj === 'object' || typeof obj === 'function') && typeof then === 'function') {
526
+ return function appyThen() {
527
+ then.apply(obj, arguments);
528
+ };
529
+ }
530
+ }
531
+
532
+ function safelyResolveThenable(self, thenable) {
533
+ // Either fulfill, reject or reject with error
534
+ var called = false;
535
+ function onError(value) {
536
+ if (called) {
537
+ return;
538
+ }
539
+ called = true;
540
+ handlers.reject(self, value);
541
+ }
542
+
543
+ function onSuccess(value) {
544
+ if (called) {
545
+ return;
546
+ }
547
+ called = true;
548
+ handlers.resolve(self, value);
549
+ }
550
+
551
+ function tryToUnwrap() {
552
+ thenable(onSuccess, onError);
553
+ }
554
+
555
+ var result = tryCatch(tryToUnwrap);
556
+ if (result.status === 'error') {
557
+ onError(result.value);
558
+ }
559
+ }
560
+
561
+ function tryCatch(func, value) {
562
+ var out = {};
563
+ try {
564
+ out.value = func(value);
565
+ out.status = 'success';
566
+ } catch (e) {
567
+ out.status = 'error';
568
+ out.value = e;
569
+ }
570
+ return out;
571
+ }
572
+
573
+ Promise.resolve = resolve;
574
+ function resolve(value) {
575
+ if (value instanceof this) {
576
+ return value;
577
+ }
578
+ return handlers.resolve(new this(INTERNAL), value);
579
+ }
580
+
581
+ Promise.reject = reject;
582
+ function reject(reason) {
583
+ var promise = new this(INTERNAL);
584
+ return handlers.reject(promise, reason);
585
+ }
586
+
587
+ Promise.all = all;
588
+ function all(iterable) {
589
+ var self = this;
590
+ if (Object.prototype.toString.call(iterable) !== '[object Array]') {
591
+ return this.reject(new TypeError('must be an array'));
592
+ }
593
+
594
+ var len = iterable.length;
595
+ var called = false;
596
+ if (!len) {
597
+ return this.resolve([]);
598
+ }
599
+
600
+ var values = new Array(len);
601
+ var resolved = 0;
602
+ var i = -1;
603
+ var promise = new this(INTERNAL);
604
+
605
+ while (++i < len) {
606
+ allResolver(iterable[i], i);
607
+ }
608
+ return promise;
609
+ function allResolver(value, i) {
610
+ self.resolve(value).then(resolveFromAll, function (error) {
611
+ if (!called) {
612
+ called = true;
613
+ handlers.reject(promise, error);
614
+ }
615
+ });
616
+ function resolveFromAll(outValue) {
617
+ values[i] = outValue;
618
+ if (++resolved === len && !called) {
619
+ called = true;
620
+ handlers.resolve(promise, values);
621
+ }
622
+ }
623
+ }
624
+ }
625
+
626
+ Promise.race = race;
627
+ function race(iterable) {
628
+ var self = this;
629
+ if (Object.prototype.toString.call(iterable) !== '[object Array]') {
630
+ return this.reject(new TypeError('must be an array'));
631
+ }
632
+
633
+ var len = iterable.length;
634
+ var called = false;
635
+ if (!len) {
636
+ return this.resolve([]);
637
+ }
638
+
639
+ var i = -1;
640
+ var promise = new this(INTERNAL);
641
+
642
+ while (++i < len) {
643
+ resolver(iterable[i]);
644
+ }
645
+ return promise;
646
+ function resolver(value) {
647
+ self.resolve(value).then(function (response) {
648
+ if (!called) {
649
+ called = true;
650
+ handlers.resolve(promise, response);
651
+ }
652
+ }, function (error) {
653
+ if (!called) {
654
+ called = true;
655
+ handlers.reject(promise, error);
656
+ }
657
+ });
658
+ }
659
+ }
660
+
661
+ },{"1":1}],3:[function(_dereq_,module,exports){
662
+ (function (global){
663
+ if (typeof global.Promise !== 'function') {
664
+ global.Promise = _dereq_(2);
665
+ }
666
+
667
+ }).call(this,typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
668
+ },{"2":2}],4:[function(_dereq_,module,exports){
669
+
670
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
671
+
672
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
673
+
674
+ function getIDB() {
675
+ /* global indexedDB,webkitIndexedDB,mozIndexedDB,OIndexedDB,msIndexedDB */
676
+ try {
677
+ if (typeof indexedDB !== 'undefined') {
678
+ return indexedDB;
679
+ }
680
+ if (typeof webkitIndexedDB !== 'undefined') {
681
+ return webkitIndexedDB;
682
+ }
683
+ if (typeof mozIndexedDB !== 'undefined') {
684
+ return mozIndexedDB;
685
+ }
686
+ if (typeof OIndexedDB !== 'undefined') {
687
+ return OIndexedDB;
688
+ }
689
+ if (typeof msIndexedDB !== 'undefined') {
690
+ return msIndexedDB;
691
+ }
692
+ } catch (e) {
693
+ return;
694
+ }
695
+ }
696
+
697
+ var idb = getIDB();
698
+
699
+ function isIndexedDBValid() {
700
+ try {
701
+ // Initialize IndexedDB; fall back to vendor-prefixed versions
702
+ // if needed.
703
+ if (!idb || !idb.open) {
704
+ return false;
705
+ }
706
+ // We mimic PouchDB here;
707
+ //
708
+ // We test for openDatabase because IE Mobile identifies itself
709
+ // as Safari. Oh the lulz...
710
+ var isSafari = typeof openDatabase !== 'undefined' && /(Safari|iPhone|iPad|iPod)/.test(navigator.userAgent) && !/Chrome/.test(navigator.userAgent) && !/BlackBerry/.test(navigator.platform);
711
+
712
+ var hasFetch = typeof fetch === 'function' && fetch.toString().indexOf('[native code') !== -1;
713
+
714
+ // Safari <10.1 does not meet our requirements for IDB support
715
+ // (see: https://github.com/pouchdb/pouchdb/issues/5572).
716
+ // Safari 10.1 shipped with fetch, we can use that to detect it.
717
+ // Note: this creates issues with `window.fetch` polyfills and
718
+ // overrides; see:
719
+ // https://github.com/localForage/localForage/issues/856
720
+ return (!isSafari || hasFetch) && typeof indexedDB !== 'undefined' &&
721
+ // some outdated implementations of IDB that appear on Samsung
722
+ // and HTC Android devices <4.4 are missing IDBKeyRange
723
+ // See: https://github.com/mozilla/localForage/issues/128
724
+ // See: https://github.com/mozilla/localForage/issues/272
725
+ typeof IDBKeyRange !== 'undefined';
726
+ } catch (e) {
727
+ return false;
728
+ }
729
+ }
730
+
731
+ // Abstracts constructing a Blob object, so it also works in older
732
+ // browsers that don't support the native Blob constructor. (i.e.
733
+ // old QtWebKit versions, at least).
734
+ // Abstracts constructing a Blob object, so it also works in older
735
+ // browsers that don't support the native Blob constructor. (i.e.
736
+ // old QtWebKit versions, at least).
737
+ function createBlob(parts, properties) {
738
+ /* global BlobBuilder,MSBlobBuilder,MozBlobBuilder,WebKitBlobBuilder */
739
+ parts = parts || [];
740
+ properties = properties || {};
741
+ try {
742
+ return new Blob(parts, properties);
743
+ } catch (e) {
744
+ if (e.name !== 'TypeError') {
745
+ throw e;
746
+ }
747
+ var Builder = typeof BlobBuilder !== 'undefined' ? BlobBuilder : typeof MSBlobBuilder !== 'undefined' ? MSBlobBuilder : typeof MozBlobBuilder !== 'undefined' ? MozBlobBuilder : WebKitBlobBuilder;
748
+ var builder = new Builder();
749
+ for (var i = 0; i < parts.length; i += 1) {
750
+ builder.append(parts[i]);
751
+ }
752
+ return builder.getBlob(properties.type);
753
+ }
754
+ }
755
+
756
+ // This is CommonJS because lie is an external dependency, so Rollup
757
+ // can just ignore it.
758
+ if (typeof Promise === 'undefined') {
759
+ // In the "nopromises" build this will just throw if you don't have
760
+ // a global promise object, but it would throw anyway later.
761
+ _dereq_(3);
762
+ }
763
+ var Promise$1 = Promise;
764
+
765
+ function executeCallback(promise, callback) {
766
+ if (callback) {
767
+ promise.then(function (result) {
768
+ callback(null, result);
769
+ }, function (error) {
770
+ callback(error);
771
+ });
772
+ }
773
+ }
774
+
775
+ function executeTwoCallbacks(promise, callback, errorCallback) {
776
+ if (typeof callback === 'function') {
777
+ promise.then(callback);
778
+ }
779
+
780
+ if (typeof errorCallback === 'function') {
781
+ promise["catch"](errorCallback);
782
+ }
783
+ }
784
+
785
+ function normalizeKey(key) {
786
+ // Cast the key to a string, as that's all we can set as a key.
787
+ if (typeof key !== 'string') {
788
+ console.warn(key + ' used as a key, but it is not a string.');
789
+ key = String(key);
790
+ }
791
+
792
+ return key;
793
+ }
794
+
795
+ function getCallback() {
796
+ if (arguments.length && typeof arguments[arguments.length - 1] === 'function') {
797
+ return arguments[arguments.length - 1];
798
+ }
799
+ }
800
+
801
+ // Some code originally from async_storage.js in
802
+ // [Gaia](https://github.com/mozilla-b2g/gaia).
803
+
804
+ var DETECT_BLOB_SUPPORT_STORE = 'local-forage-detect-blob-support';
805
+ var supportsBlobs = void 0;
806
+ var dbContexts = {};
807
+ var toString = Object.prototype.toString;
808
+
809
+ // Transaction Modes
810
+ var READ_ONLY = 'readonly';
811
+ var READ_WRITE = 'readwrite';
812
+
813
+ // Transform a binary string to an array buffer, because otherwise
814
+ // weird stuff happens when you try to work with the binary string directly.
815
+ // It is known.
816
+ // From http://stackoverflow.com/questions/14967647/ (continues on next line)
817
+ // encode-decode-image-with-base64-breaks-image (2013-04-21)
818
+ function _binStringToArrayBuffer(bin) {
819
+ var length = bin.length;
820
+ var buf = new ArrayBuffer(length);
821
+ var arr = new Uint8Array(buf);
822
+ for (var i = 0; i < length; i++) {
823
+ arr[i] = bin.charCodeAt(i);
824
+ }
825
+ return buf;
826
+ }
827
+
828
+ //
829
+ // Blobs are not supported in all versions of IndexedDB, notably
830
+ // Chrome <37 and Android <5. In those versions, storing a blob will throw.
831
+ //
832
+ // Various other blob bugs exist in Chrome v37-42 (inclusive).
833
+ // Detecting them is expensive and confusing to users, and Chrome 37-42
834
+ // is at very low usage worldwide, so we do a hacky userAgent check instead.
835
+ //
836
+ // content-type bug: https://code.google.com/p/chromium/issues/detail?id=408120
837
+ // 404 bug: https://code.google.com/p/chromium/issues/detail?id=447916
838
+ // FileReader bug: https://code.google.com/p/chromium/issues/detail?id=447836
839
+ //
840
+ // Code borrowed from PouchDB. See:
841
+ // https://github.com/pouchdb/pouchdb/blob/master/packages/node_modules/pouchdb-adapter-idb/src/blobSupport.js
842
+ //
843
+ function _checkBlobSupportWithoutCaching(idb) {
844
+ return new Promise$1(function (resolve) {
845
+ var txn = idb.transaction(DETECT_BLOB_SUPPORT_STORE, READ_WRITE);
846
+ var blob = createBlob(['']);
847
+ txn.objectStore(DETECT_BLOB_SUPPORT_STORE).put(blob, 'key');
848
+
849
+ txn.onabort = function (e) {
850
+ // If the transaction aborts now its due to not being able to
851
+ // write to the database, likely due to the disk being full
852
+ e.preventDefault();
853
+ e.stopPropagation();
854
+ resolve(false);
855
+ };
856
+
857
+ txn.oncomplete = function () {
858
+ var matchedChrome = navigator.userAgent.match(/Chrome\/(\d+)/);
859
+ var matchedEdge = navigator.userAgent.match(/Edge\//);
860
+ // MS Edge pretends to be Chrome 42:
861
+ // https://msdn.microsoft.com/en-us/library/hh869301%28v=vs.85%29.aspx
862
+ resolve(matchedEdge || !matchedChrome || parseInt(matchedChrome[1], 10) >= 43);
863
+ };
864
+ })["catch"](function () {
865
+ return false; // error, so assume unsupported
866
+ });
867
+ }
868
+
869
+ function _checkBlobSupport(idb) {
870
+ if (typeof supportsBlobs === 'boolean') {
871
+ return Promise$1.resolve(supportsBlobs);
872
+ }
873
+ return _checkBlobSupportWithoutCaching(idb).then(function (value) {
874
+ supportsBlobs = value;
875
+ return supportsBlobs;
876
+ });
877
+ }
878
+
879
+ function _deferReadiness(dbInfo) {
880
+ var dbContext = dbContexts[dbInfo.name];
881
+
882
+ // Create a deferred object representing the current database operation.
883
+ var deferredOperation = {};
884
+
885
+ deferredOperation.promise = new Promise$1(function (resolve, reject) {
886
+ deferredOperation.resolve = resolve;
887
+ deferredOperation.reject = reject;
888
+ });
889
+
890
+ // Enqueue the deferred operation.
891
+ dbContext.deferredOperations.push(deferredOperation);
892
+
893
+ // Chain its promise to the database readiness.
894
+ if (!dbContext.dbReady) {
895
+ dbContext.dbReady = deferredOperation.promise;
896
+ } else {
897
+ dbContext.dbReady = dbContext.dbReady.then(function () {
898
+ return deferredOperation.promise;
899
+ });
900
+ }
901
+ }
902
+
903
+ function _advanceReadiness(dbInfo) {
904
+ var dbContext = dbContexts[dbInfo.name];
905
+
906
+ // Dequeue a deferred operation.
907
+ var deferredOperation = dbContext.deferredOperations.pop();
908
+
909
+ // Resolve its promise (which is part of the database readiness
910
+ // chain of promises).
911
+ if (deferredOperation) {
912
+ deferredOperation.resolve();
913
+ return deferredOperation.promise;
914
+ }
915
+ }
916
+
917
+ function _rejectReadiness(dbInfo, err) {
918
+ var dbContext = dbContexts[dbInfo.name];
919
+
920
+ // Dequeue a deferred operation.
921
+ var deferredOperation = dbContext.deferredOperations.pop();
922
+
923
+ // Reject its promise (which is part of the database readiness
924
+ // chain of promises).
925
+ if (deferredOperation) {
926
+ deferredOperation.reject(err);
927
+ return deferredOperation.promise;
928
+ }
929
+ }
930
+
931
+ function _getConnection(dbInfo, upgradeNeeded) {
932
+ return new Promise$1(function (resolve, reject) {
933
+ dbContexts[dbInfo.name] = dbContexts[dbInfo.name] || createDbContext();
934
+
935
+ if (dbInfo.db) {
936
+ if (upgradeNeeded) {
937
+ _deferReadiness(dbInfo);
938
+ dbInfo.db.close();
939
+ } else {
940
+ return resolve(dbInfo.db);
941
+ }
942
+ }
943
+
944
+ var dbArgs = [dbInfo.name];
945
+
946
+ if (upgradeNeeded) {
947
+ dbArgs.push(dbInfo.version);
948
+ }
949
+
950
+ var openreq = idb.open.apply(idb, dbArgs);
951
+
952
+ if (upgradeNeeded) {
953
+ openreq.onupgradeneeded = function (e) {
954
+ var db = openreq.result;
955
+ try {
956
+ db.createObjectStore(dbInfo.storeName);
957
+ if (e.oldVersion <= 1) {
958
+ // Added when support for blob shims was added
959
+ db.createObjectStore(DETECT_BLOB_SUPPORT_STORE);
960
+ }
961
+ } catch (ex) {
962
+ if (ex.name === 'ConstraintError') {
963
+ console.warn('The database "' + dbInfo.name + '"' + ' has been upgraded from version ' + e.oldVersion + ' to version ' + e.newVersion + ', but the storage "' + dbInfo.storeName + '" already exists.');
964
+ } else {
965
+ throw ex;
966
+ }
967
+ }
968
+ };
969
+ }
970
+
971
+ openreq.onerror = function (e) {
972
+ e.preventDefault();
973
+ reject(openreq.error);
974
+ };
975
+
976
+ openreq.onsuccess = function () {
977
+ var db = openreq.result;
978
+ db.onversionchange = function (e) {
979
+ // Triggered when the database is modified (e.g. adding an objectStore) or
980
+ // deleted (even when initiated by other sessions in different tabs).
981
+ // Closing the connection here prevents those operations from being blocked.
982
+ // If the database is accessed again later by this instance, the connection
983
+ // will be reopened or the database recreated as needed.
984
+ e.target.close();
985
+ };
986
+ resolve(db);
987
+ _advanceReadiness(dbInfo);
988
+ };
989
+ });
990
+ }
991
+
992
+ function _getOriginalConnection(dbInfo) {
993
+ return _getConnection(dbInfo, false);
994
+ }
995
+
996
+ function _getUpgradedConnection(dbInfo) {
997
+ return _getConnection(dbInfo, true);
998
+ }
999
+
1000
+ function _isUpgradeNeeded(dbInfo, defaultVersion) {
1001
+ if (!dbInfo.db) {
1002
+ return true;
1003
+ }
1004
+
1005
+ var isNewStore = !dbInfo.db.objectStoreNames.contains(dbInfo.storeName);
1006
+ var isDowngrade = dbInfo.version < dbInfo.db.version;
1007
+ var isUpgrade = dbInfo.version > dbInfo.db.version;
1008
+
1009
+ if (isDowngrade) {
1010
+ // If the version is not the default one
1011
+ // then warn for impossible downgrade.
1012
+ if (dbInfo.version !== defaultVersion) {
1013
+ console.warn('The database "' + dbInfo.name + '"' + " can't be downgraded from version " + dbInfo.db.version + ' to version ' + dbInfo.version + '.');
1014
+ }
1015
+ // Align the versions to prevent errors.
1016
+ dbInfo.version = dbInfo.db.version;
1017
+ }
1018
+
1019
+ if (isUpgrade || isNewStore) {
1020
+ // If the store is new then increment the version (if needed).
1021
+ // This will trigger an "upgradeneeded" event which is required
1022
+ // for creating a store.
1023
+ if (isNewStore) {
1024
+ var incVersion = dbInfo.db.version + 1;
1025
+ if (incVersion > dbInfo.version) {
1026
+ dbInfo.version = incVersion;
1027
+ }
1028
+ }
1029
+
1030
+ return true;
1031
+ }
1032
+
1033
+ return false;
1034
+ }
1035
+
1036
+ // encode a blob for indexeddb engines that don't support blobs
1037
+ function _encodeBlob(blob) {
1038
+ return new Promise$1(function (resolve, reject) {
1039
+ var reader = new FileReader();
1040
+ reader.onerror = reject;
1041
+ reader.onloadend = function (e) {
1042
+ var base64 = btoa(e.target.result || '');
1043
+ resolve({
1044
+ __local_forage_encoded_blob: true,
1045
+ data: base64,
1046
+ type: blob.type
1047
+ });
1048
+ };
1049
+ reader.readAsBinaryString(blob);
1050
+ });
1051
+ }
1052
+
1053
+ // decode an encoded blob
1054
+ function _decodeBlob(encodedBlob) {
1055
+ var arrayBuff = _binStringToArrayBuffer(atob(encodedBlob.data));
1056
+ return createBlob([arrayBuff], { type: encodedBlob.type });
1057
+ }
1058
+
1059
+ // is this one of our fancy encoded blobs?
1060
+ function _isEncodedBlob(value) {
1061
+ return value && value.__local_forage_encoded_blob;
1062
+ }
1063
+
1064
+ // Specialize the default `ready()` function by making it dependent
1065
+ // on the current database operations. Thus, the driver will be actually
1066
+ // ready when it's been initialized (default) *and* there are no pending
1067
+ // operations on the database (initiated by some other instances).
1068
+ function _fullyReady(callback) {
1069
+ var self = this;
1070
+
1071
+ var promise = self._initReady().then(function () {
1072
+ var dbContext = dbContexts[self._dbInfo.name];
1073
+
1074
+ if (dbContext && dbContext.dbReady) {
1075
+ return dbContext.dbReady;
1076
+ }
1077
+ });
1078
+
1079
+ executeTwoCallbacks(promise, callback, callback);
1080
+ return promise;
1081
+ }
1082
+
1083
+ // Try to establish a new db connection to replace the
1084
+ // current one which is broken (i.e. experiencing
1085
+ // InvalidStateError while creating a transaction).
1086
+ function _tryReconnect(dbInfo) {
1087
+ _deferReadiness(dbInfo);
1088
+
1089
+ var dbContext = dbContexts[dbInfo.name];
1090
+ var forages = dbContext.forages;
1091
+
1092
+ for (var i = 0; i < forages.length; i++) {
1093
+ var forage = forages[i];
1094
+ if (forage._dbInfo.db) {
1095
+ forage._dbInfo.db.close();
1096
+ forage._dbInfo.db = null;
1097
+ }
1098
+ }
1099
+ dbInfo.db = null;
1100
+
1101
+ return _getOriginalConnection(dbInfo).then(function (db) {
1102
+ dbInfo.db = db;
1103
+ if (_isUpgradeNeeded(dbInfo)) {
1104
+ // Reopen the database for upgrading.
1105
+ return _getUpgradedConnection(dbInfo);
1106
+ }
1107
+ return db;
1108
+ }).then(function (db) {
1109
+ // store the latest db reference
1110
+ // in case the db was upgraded
1111
+ dbInfo.db = dbContext.db = db;
1112
+ for (var i = 0; i < forages.length; i++) {
1113
+ forages[i]._dbInfo.db = db;
1114
+ }
1115
+ })["catch"](function (err) {
1116
+ _rejectReadiness(dbInfo, err);
1117
+ throw err;
1118
+ });
1119
+ }
1120
+
1121
+ // FF doesn't like Promises (micro-tasks) and IDDB store operations,
1122
+ // so we have to do it with callbacks
1123
+ function createTransaction(dbInfo, mode, callback, retries) {
1124
+ if (retries === undefined) {
1125
+ retries = 1;
1126
+ }
1127
+
1128
+ try {
1129
+ var tx = dbInfo.db.transaction(dbInfo.storeName, mode);
1130
+ callback(null, tx);
1131
+ } catch (err) {
1132
+ if (retries > 0 && (!dbInfo.db || err.name === 'InvalidStateError' || err.name === 'NotFoundError')) {
1133
+ return Promise$1.resolve().then(function () {
1134
+ if (!dbInfo.db || err.name === 'NotFoundError' && !dbInfo.db.objectStoreNames.contains(dbInfo.storeName) && dbInfo.version <= dbInfo.db.version) {
1135
+ // increase the db version, to create the new ObjectStore
1136
+ if (dbInfo.db) {
1137
+ dbInfo.version = dbInfo.db.version + 1;
1138
+ }
1139
+ // Reopen the database for upgrading.
1140
+ return _getUpgradedConnection(dbInfo);
1141
+ }
1142
+ }).then(function () {
1143
+ return _tryReconnect(dbInfo).then(function () {
1144
+ createTransaction(dbInfo, mode, callback, retries - 1);
1145
+ });
1146
+ })["catch"](callback);
1147
+ }
1148
+
1149
+ callback(err);
1150
+ }
1151
+ }
1152
+
1153
+ function createDbContext() {
1154
+ return {
1155
+ // Running localForages sharing a database.
1156
+ forages: [],
1157
+ // Shared database.
1158
+ db: null,
1159
+ // Database readiness (promise).
1160
+ dbReady: null,
1161
+ // Deferred operations on the database.
1162
+ deferredOperations: []
1163
+ };
1164
+ }
1165
+
1166
+ // Open the IndexedDB database (automatically creates one if one didn't
1167
+ // previously exist), using any options set in the config.
1168
+ function _initStorage(options) {
1169
+ var self = this;
1170
+ var dbInfo = {
1171
+ db: null
1172
+ };
1173
+
1174
+ if (options) {
1175
+ for (var i in options) {
1176
+ dbInfo[i] = options[i];
1177
+ }
1178
+ }
1179
+
1180
+ // Get the current context of the database;
1181
+ var dbContext = dbContexts[dbInfo.name];
1182
+
1183
+ // ...or create a new context.
1184
+ if (!dbContext) {
1185
+ dbContext = createDbContext();
1186
+ // Register the new context in the global container.
1187
+ dbContexts[dbInfo.name] = dbContext;
1188
+ }
1189
+
1190
+ // Register itself as a running localForage in the current context.
1191
+ dbContext.forages.push(self);
1192
+
1193
+ // Replace the default `ready()` function with the specialized one.
1194
+ if (!self._initReady) {
1195
+ self._initReady = self.ready;
1196
+ self.ready = _fullyReady;
1197
+ }
1198
+
1199
+ // Create an array of initialization states of the related localForages.
1200
+ var initPromises = [];
1201
+
1202
+ function ignoreErrors() {
1203
+ // Don't handle errors here,
1204
+ // just makes sure related localForages aren't pending.
1205
+ return Promise$1.resolve();
1206
+ }
1207
+
1208
+ for (var j = 0; j < dbContext.forages.length; j++) {
1209
+ var forage = dbContext.forages[j];
1210
+ if (forage !== self) {
1211
+ // Don't wait for itself...
1212
+ initPromises.push(forage._initReady()["catch"](ignoreErrors));
1213
+ }
1214
+ }
1215
+
1216
+ // Take a snapshot of the related localForages.
1217
+ var forages = dbContext.forages.slice(0);
1218
+
1219
+ // Initialize the connection process only when
1220
+ // all the related localForages aren't pending.
1221
+ return Promise$1.all(initPromises).then(function () {
1222
+ dbInfo.db = dbContext.db;
1223
+ // Get the connection or open a new one without upgrade.
1224
+ return _getOriginalConnection(dbInfo);
1225
+ }).then(function (db) {
1226
+ dbInfo.db = db;
1227
+ if (_isUpgradeNeeded(dbInfo, self._defaultConfig.version)) {
1228
+ // Reopen the database for upgrading.
1229
+ return _getUpgradedConnection(dbInfo);
1230
+ }
1231
+ return db;
1232
+ }).then(function (db) {
1233
+ dbInfo.db = dbContext.db = db;
1234
+ self._dbInfo = dbInfo;
1235
+ // Share the final connection amongst related localForages.
1236
+ for (var k = 0; k < forages.length; k++) {
1237
+ var forage = forages[k];
1238
+ if (forage !== self) {
1239
+ // Self is already up-to-date.
1240
+ forage._dbInfo.db = dbInfo.db;
1241
+ forage._dbInfo.version = dbInfo.version;
1242
+ }
1243
+ }
1244
+ });
1245
+ }
1246
+
1247
+ function getItem(key, callback) {
1248
+ var self = this;
1249
+
1250
+ key = normalizeKey(key);
1251
+
1252
+ var promise = new Promise$1(function (resolve, reject) {
1253
+ self.ready().then(function () {
1254
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
1255
+ if (err) {
1256
+ return reject(err);
1257
+ }
1258
+
1259
+ try {
1260
+ var store = transaction.objectStore(self._dbInfo.storeName);
1261
+ var req = store.get(key);
1262
+
1263
+ req.onsuccess = function () {
1264
+ var value = req.result;
1265
+ if (value === undefined) {
1266
+ value = null;
1267
+ }
1268
+ if (_isEncodedBlob(value)) {
1269
+ value = _decodeBlob(value);
1270
+ }
1271
+ resolve(value);
1272
+ };
1273
+
1274
+ req.onerror = function () {
1275
+ reject(req.error);
1276
+ };
1277
+ } catch (e) {
1278
+ reject(e);
1279
+ }
1280
+ });
1281
+ })["catch"](reject);
1282
+ });
1283
+
1284
+ executeCallback(promise, callback);
1285
+ return promise;
1286
+ }
1287
+
1288
+ // Iterate over all items stored in database.
1289
+ function iterate(iterator, callback) {
1290
+ var self = this;
1291
+
1292
+ var promise = new Promise$1(function (resolve, reject) {
1293
+ self.ready().then(function () {
1294
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
1295
+ if (err) {
1296
+ return reject(err);
1297
+ }
1298
+
1299
+ try {
1300
+ var store = transaction.objectStore(self._dbInfo.storeName);
1301
+ var req = store.openCursor();
1302
+ var iterationNumber = 1;
1303
+
1304
+ req.onsuccess = function () {
1305
+ var cursor = req.result;
1306
+
1307
+ if (cursor) {
1308
+ var value = cursor.value;
1309
+ if (_isEncodedBlob(value)) {
1310
+ value = _decodeBlob(value);
1311
+ }
1312
+ var result = iterator(value, cursor.key, iterationNumber++);
1313
+
1314
+ // when the iterator callback returns any
1315
+ // (non-`undefined`) value, then we stop
1316
+ // the iteration immediately
1317
+ if (result !== void 0) {
1318
+ resolve(result);
1319
+ } else {
1320
+ cursor["continue"]();
1321
+ }
1322
+ } else {
1323
+ resolve();
1324
+ }
1325
+ };
1326
+
1327
+ req.onerror = function () {
1328
+ reject(req.error);
1329
+ };
1330
+ } catch (e) {
1331
+ reject(e);
1332
+ }
1333
+ });
1334
+ })["catch"](reject);
1335
+ });
1336
+
1337
+ executeCallback(promise, callback);
1338
+
1339
+ return promise;
1340
+ }
1341
+
1342
+ function setItem(key, value, callback) {
1343
+ var self = this;
1344
+
1345
+ key = normalizeKey(key);
1346
+
1347
+ var promise = new Promise$1(function (resolve, reject) {
1348
+ var dbInfo;
1349
+ self.ready().then(function () {
1350
+ dbInfo = self._dbInfo;
1351
+ if (toString.call(value) === '[object Blob]') {
1352
+ return _checkBlobSupport(dbInfo.db).then(function (blobSupport) {
1353
+ if (blobSupport) {
1354
+ return value;
1355
+ }
1356
+ return _encodeBlob(value);
1357
+ });
1358
+ }
1359
+ return value;
1360
+ }).then(function (value) {
1361
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
1362
+ if (err) {
1363
+ return reject(err);
1364
+ }
1365
+
1366
+ try {
1367
+ var store = transaction.objectStore(self._dbInfo.storeName);
1368
+
1369
+ // The reason we don't _save_ null is because IE 10 does
1370
+ // not support saving the `null` type in IndexedDB. How
1371
+ // ironic, given the bug below!
1372
+ // See: https://github.com/mozilla/localForage/issues/161
1373
+ if (value === null) {
1374
+ value = undefined;
1375
+ }
1376
+
1377
+ var req = store.put(value, key);
1378
+
1379
+ transaction.oncomplete = function () {
1380
+ // Cast to undefined so the value passed to
1381
+ // callback/promise is the same as what one would get out
1382
+ // of `getItem()` later. This leads to some weirdness
1383
+ // (setItem('foo', undefined) will return `null`), but
1384
+ // it's not my fault localStorage is our baseline and that
1385
+ // it's weird.
1386
+ if (value === undefined) {
1387
+ value = null;
1388
+ }
1389
+
1390
+ resolve(value);
1391
+ };
1392
+ transaction.onabort = transaction.onerror = function () {
1393
+ var err = req.error ? req.error : req.transaction.error;
1394
+ reject(err);
1395
+ };
1396
+ } catch (e) {
1397
+ reject(e);
1398
+ }
1399
+ });
1400
+ })["catch"](reject);
1401
+ });
1402
+
1403
+ executeCallback(promise, callback);
1404
+ return promise;
1405
+ }
1406
+
1407
+ function removeItem(key, callback) {
1408
+ var self = this;
1409
+
1410
+ key = normalizeKey(key);
1411
+
1412
+ var promise = new Promise$1(function (resolve, reject) {
1413
+ self.ready().then(function () {
1414
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
1415
+ if (err) {
1416
+ return reject(err);
1417
+ }
1418
+
1419
+ try {
1420
+ var store = transaction.objectStore(self._dbInfo.storeName);
1421
+ // We use a Grunt task to make this safe for IE and some
1422
+ // versions of Android (including those used by Cordova).
1423
+ // Normally IE won't like `.delete()` and will insist on
1424
+ // using `['delete']()`, but we have a build step that
1425
+ // fixes this for us now.
1426
+ var req = store["delete"](key);
1427
+ transaction.oncomplete = function () {
1428
+ resolve();
1429
+ };
1430
+
1431
+ transaction.onerror = function () {
1432
+ reject(req.error);
1433
+ };
1434
+
1435
+ // The request will be also be aborted if we've exceeded our storage
1436
+ // space.
1437
+ transaction.onabort = function () {
1438
+ var err = req.error ? req.error : req.transaction.error;
1439
+ reject(err);
1440
+ };
1441
+ } catch (e) {
1442
+ reject(e);
1443
+ }
1444
+ });
1445
+ })["catch"](reject);
1446
+ });
1447
+
1448
+ executeCallback(promise, callback);
1449
+ return promise;
1450
+ }
1451
+
1452
+ function clear(callback) {
1453
+ var self = this;
1454
+
1455
+ var promise = new Promise$1(function (resolve, reject) {
1456
+ self.ready().then(function () {
1457
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
1458
+ if (err) {
1459
+ return reject(err);
1460
+ }
1461
+
1462
+ try {
1463
+ var store = transaction.objectStore(self._dbInfo.storeName);
1464
+ var req = store.clear();
1465
+
1466
+ transaction.oncomplete = function () {
1467
+ resolve();
1468
+ };
1469
+
1470
+ transaction.onabort = transaction.onerror = function () {
1471
+ var err = req.error ? req.error : req.transaction.error;
1472
+ reject(err);
1473
+ };
1474
+ } catch (e) {
1475
+ reject(e);
1476
+ }
1477
+ });
1478
+ })["catch"](reject);
1479
+ });
1480
+
1481
+ executeCallback(promise, callback);
1482
+ return promise;
1483
+ }
1484
+
1485
+ function length(callback) {
1486
+ var self = this;
1487
+
1488
+ var promise = new Promise$1(function (resolve, reject) {
1489
+ self.ready().then(function () {
1490
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
1491
+ if (err) {
1492
+ return reject(err);
1493
+ }
1494
+
1495
+ try {
1496
+ var store = transaction.objectStore(self._dbInfo.storeName);
1497
+ var req = store.count();
1498
+
1499
+ req.onsuccess = function () {
1500
+ resolve(req.result);
1501
+ };
1502
+
1503
+ req.onerror = function () {
1504
+ reject(req.error);
1505
+ };
1506
+ } catch (e) {
1507
+ reject(e);
1508
+ }
1509
+ });
1510
+ })["catch"](reject);
1511
+ });
1512
+
1513
+ executeCallback(promise, callback);
1514
+ return promise;
1515
+ }
1516
+
1517
+ function key(n, callback) {
1518
+ var self = this;
1519
+
1520
+ var promise = new Promise$1(function (resolve, reject) {
1521
+ if (n < 0) {
1522
+ resolve(null);
1523
+
1524
+ return;
1525
+ }
1526
+
1527
+ self.ready().then(function () {
1528
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
1529
+ if (err) {
1530
+ return reject(err);
1531
+ }
1532
+
1533
+ try {
1534
+ var store = transaction.objectStore(self._dbInfo.storeName);
1535
+ var advanced = false;
1536
+ var req = store.openKeyCursor();
1537
+
1538
+ req.onsuccess = function () {
1539
+ var cursor = req.result;
1540
+ if (!cursor) {
1541
+ // this means there weren't enough keys
1542
+ resolve(null);
1543
+
1544
+ return;
1545
+ }
1546
+
1547
+ if (n === 0) {
1548
+ // We have the first key, return it if that's what they
1549
+ // wanted.
1550
+ resolve(cursor.key);
1551
+ } else {
1552
+ if (!advanced) {
1553
+ // Otherwise, ask the cursor to skip ahead n
1554
+ // records.
1555
+ advanced = true;
1556
+ cursor.advance(n);
1557
+ } else {
1558
+ // When we get here, we've got the nth key.
1559
+ resolve(cursor.key);
1560
+ }
1561
+ }
1562
+ };
1563
+
1564
+ req.onerror = function () {
1565
+ reject(req.error);
1566
+ };
1567
+ } catch (e) {
1568
+ reject(e);
1569
+ }
1570
+ });
1571
+ })["catch"](reject);
1572
+ });
1573
+
1574
+ executeCallback(promise, callback);
1575
+ return promise;
1576
+ }
1577
+
1578
+ function keys(callback) {
1579
+ var self = this;
1580
+
1581
+ var promise = new Promise$1(function (resolve, reject) {
1582
+ self.ready().then(function () {
1583
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
1584
+ if (err) {
1585
+ return reject(err);
1586
+ }
1587
+
1588
+ try {
1589
+ var store = transaction.objectStore(self._dbInfo.storeName);
1590
+ var req = store.openKeyCursor();
1591
+ var keys = [];
1592
+
1593
+ req.onsuccess = function () {
1594
+ var cursor = req.result;
1595
+
1596
+ if (!cursor) {
1597
+ resolve(keys);
1598
+ return;
1599
+ }
1600
+
1601
+ keys.push(cursor.key);
1602
+ cursor["continue"]();
1603
+ };
1604
+
1605
+ req.onerror = function () {
1606
+ reject(req.error);
1607
+ };
1608
+ } catch (e) {
1609
+ reject(e);
1610
+ }
1611
+ });
1612
+ })["catch"](reject);
1613
+ });
1614
+
1615
+ executeCallback(promise, callback);
1616
+ return promise;
1617
+ }
1618
+
1619
+ function dropInstance(options, callback) {
1620
+ callback = getCallback.apply(this, arguments);
1621
+
1622
+ var currentConfig = this.config();
1623
+ options = typeof options !== 'function' && options || {};
1624
+ if (!options.name) {
1625
+ options.name = options.name || currentConfig.name;
1626
+ options.storeName = options.storeName || currentConfig.storeName;
1627
+ }
1628
+
1629
+ var self = this;
1630
+ var promise;
1631
+ if (!options.name) {
1632
+ promise = Promise$1.reject('Invalid arguments');
1633
+ } else {
1634
+ var isCurrentDb = options.name === currentConfig.name && self._dbInfo.db;
1635
+
1636
+ var dbPromise = isCurrentDb ? Promise$1.resolve(self._dbInfo.db) : _getOriginalConnection(options).then(function (db) {
1637
+ var dbContext = dbContexts[options.name];
1638
+ var forages = dbContext.forages;
1639
+ dbContext.db = db;
1640
+ for (var i = 0; i < forages.length; i++) {
1641
+ forages[i]._dbInfo.db = db;
1642
+ }
1643
+ return db;
1644
+ });
1645
+
1646
+ if (!options.storeName) {
1647
+ promise = dbPromise.then(function (db) {
1648
+ _deferReadiness(options);
1649
+
1650
+ var dbContext = dbContexts[options.name];
1651
+ var forages = dbContext.forages;
1652
+
1653
+ db.close();
1654
+ for (var i = 0; i < forages.length; i++) {
1655
+ var forage = forages[i];
1656
+ forage._dbInfo.db = null;
1657
+ }
1658
+
1659
+ var dropDBPromise = new Promise$1(function (resolve, reject) {
1660
+ var req = idb.deleteDatabase(options.name);
1661
+
1662
+ req.onerror = function () {
1663
+ var db = req.result;
1664
+ if (db) {
1665
+ db.close();
1666
+ }
1667
+ reject(req.error);
1668
+ };
1669
+
1670
+ req.onblocked = function () {
1671
+ // Closing all open connections in onversionchange handler should prevent this situation, but if
1672
+ // we do get here, it just means the request remains pending - eventually it will succeed or error
1673
+ console.warn('dropInstance blocked for database "' + options.name + '" until all open connections are closed');
1674
+ };
1675
+
1676
+ req.onsuccess = function () {
1677
+ var db = req.result;
1678
+ if (db) {
1679
+ db.close();
1680
+ }
1681
+ resolve(db);
1682
+ };
1683
+ });
1684
+
1685
+ return dropDBPromise.then(function (db) {
1686
+ dbContext.db = db;
1687
+ for (var i = 0; i < forages.length; i++) {
1688
+ var _forage = forages[i];
1689
+ _advanceReadiness(_forage._dbInfo);
1690
+ }
1691
+ })["catch"](function (err) {
1692
+ (_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function () {});
1693
+ throw err;
1694
+ });
1695
+ });
1696
+ } else {
1697
+ promise = dbPromise.then(function (db) {
1698
+ if (!db.objectStoreNames.contains(options.storeName)) {
1699
+ return;
1700
+ }
1701
+
1702
+ var newVersion = db.version + 1;
1703
+
1704
+ _deferReadiness(options);
1705
+
1706
+ var dbContext = dbContexts[options.name];
1707
+ var forages = dbContext.forages;
1708
+
1709
+ db.close();
1710
+ for (var i = 0; i < forages.length; i++) {
1711
+ var forage = forages[i];
1712
+ forage._dbInfo.db = null;
1713
+ forage._dbInfo.version = newVersion;
1714
+ }
1715
+
1716
+ var dropObjectPromise = new Promise$1(function (resolve, reject) {
1717
+ var req = idb.open(options.name, newVersion);
1718
+
1719
+ req.onerror = function (err) {
1720
+ var db = req.result;
1721
+ db.close();
1722
+ reject(err);
1723
+ };
1724
+
1725
+ req.onupgradeneeded = function () {
1726
+ var db = req.result;
1727
+ db.deleteObjectStore(options.storeName);
1728
+ };
1729
+
1730
+ req.onsuccess = function () {
1731
+ var db = req.result;
1732
+ db.close();
1733
+ resolve(db);
1734
+ };
1735
+ });
1736
+
1737
+ return dropObjectPromise.then(function (db) {
1738
+ dbContext.db = db;
1739
+ for (var j = 0; j < forages.length; j++) {
1740
+ var _forage2 = forages[j];
1741
+ _forage2._dbInfo.db = db;
1742
+ _advanceReadiness(_forage2._dbInfo);
1743
+ }
1744
+ })["catch"](function (err) {
1745
+ (_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function () {});
1746
+ throw err;
1747
+ });
1748
+ });
1749
+ }
1750
+ }
1751
+
1752
+ executeCallback(promise, callback);
1753
+ return promise;
1754
+ }
1755
+
1756
+ var asyncStorage = {
1757
+ _driver: 'asyncStorage',
1758
+ _initStorage: _initStorage,
1759
+ _support: isIndexedDBValid(),
1760
+ iterate: iterate,
1761
+ getItem: getItem,
1762
+ setItem: setItem,
1763
+ removeItem: removeItem,
1764
+ clear: clear,
1765
+ length: length,
1766
+ key: key,
1767
+ keys: keys,
1768
+ dropInstance: dropInstance
1769
+ };
1770
+
1771
+ function isWebSQLValid() {
1772
+ return typeof openDatabase === 'function';
1773
+ }
1774
+
1775
+ // Sadly, the best way to save binary data in WebSQL/localStorage is serializing
1776
+ // it to Base64, so this is how we store it to prevent very strange errors with less
1777
+ // verbose ways of binary <-> string data storage.
1778
+ var BASE_CHARS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
1779
+
1780
+ var BLOB_TYPE_PREFIX = '~~local_forage_type~';
1781
+ var BLOB_TYPE_PREFIX_REGEX = /^~~local_forage_type~([^~]+)~/;
1782
+
1783
+ var SERIALIZED_MARKER = '__lfsc__:';
1784
+ var SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER.length;
1785
+
1786
+ // OMG the serializations!
1787
+ var TYPE_ARRAYBUFFER = 'arbf';
1788
+ var TYPE_BLOB = 'blob';
1789
+ var TYPE_INT8ARRAY = 'si08';
1790
+ var TYPE_UINT8ARRAY = 'ui08';
1791
+ var TYPE_UINT8CLAMPEDARRAY = 'uic8';
1792
+ var TYPE_INT16ARRAY = 'si16';
1793
+ var TYPE_INT32ARRAY = 'si32';
1794
+ var TYPE_UINT16ARRAY = 'ur16';
1795
+ var TYPE_UINT32ARRAY = 'ui32';
1796
+ var TYPE_FLOAT32ARRAY = 'fl32';
1797
+ var TYPE_FLOAT64ARRAY = 'fl64';
1798
+ var TYPE_SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER_LENGTH + TYPE_ARRAYBUFFER.length;
1799
+
1800
+ var toString$1 = Object.prototype.toString;
1801
+
1802
+ function stringToBuffer(serializedString) {
1803
+ // Fill the string into a ArrayBuffer.
1804
+ var bufferLength = serializedString.length * 0.75;
1805
+ var len = serializedString.length;
1806
+ var i;
1807
+ var p = 0;
1808
+ var encoded1, encoded2, encoded3, encoded4;
1809
+
1810
+ if (serializedString[serializedString.length - 1] === '=') {
1811
+ bufferLength--;
1812
+ if (serializedString[serializedString.length - 2] === '=') {
1813
+ bufferLength--;
1814
+ }
1815
+ }
1816
+
1817
+ var buffer = new ArrayBuffer(bufferLength);
1818
+ var bytes = new Uint8Array(buffer);
1819
+
1820
+ for (i = 0; i < len; i += 4) {
1821
+ encoded1 = BASE_CHARS.indexOf(serializedString[i]);
1822
+ encoded2 = BASE_CHARS.indexOf(serializedString[i + 1]);
1823
+ encoded3 = BASE_CHARS.indexOf(serializedString[i + 2]);
1824
+ encoded4 = BASE_CHARS.indexOf(serializedString[i + 3]);
1825
+
1826
+ /*jslint bitwise: true */
1827
+ bytes[p++] = encoded1 << 2 | encoded2 >> 4;
1828
+ bytes[p++] = (encoded2 & 15) << 4 | encoded3 >> 2;
1829
+ bytes[p++] = (encoded3 & 3) << 6 | encoded4 & 63;
1830
+ }
1831
+ return buffer;
1832
+ }
1833
+
1834
+ // Converts a buffer to a string to store, serialized, in the backend
1835
+ // storage library.
1836
+ function bufferToString(buffer) {
1837
+ // base64-arraybuffer
1838
+ var bytes = new Uint8Array(buffer);
1839
+ var base64String = '';
1840
+ var i;
1841
+
1842
+ for (i = 0; i < bytes.length; i += 3) {
1843
+ /*jslint bitwise: true */
1844
+ base64String += BASE_CHARS[bytes[i] >> 2];
1845
+ base64String += BASE_CHARS[(bytes[i] & 3) << 4 | bytes[i + 1] >> 4];
1846
+ base64String += BASE_CHARS[(bytes[i + 1] & 15) << 2 | bytes[i + 2] >> 6];
1847
+ base64String += BASE_CHARS[bytes[i + 2] & 63];
1848
+ }
1849
+
1850
+ if (bytes.length % 3 === 2) {
1851
+ base64String = base64String.substring(0, base64String.length - 1) + '=';
1852
+ } else if (bytes.length % 3 === 1) {
1853
+ base64String = base64String.substring(0, base64String.length - 2) + '==';
1854
+ }
1855
+
1856
+ return base64String;
1857
+ }
1858
+
1859
+ // Serialize a value, afterwards executing a callback (which usually
1860
+ // instructs the `setItem()` callback/promise to be executed). This is how
1861
+ // we store binary data with localStorage.
1862
+ function serialize(value, callback) {
1863
+ var valueType = '';
1864
+ if (value) {
1865
+ valueType = toString$1.call(value);
1866
+ }
1867
+
1868
+ // Cannot use `value instanceof ArrayBuffer` or such here, as these
1869
+ // checks fail when running the tests using casper.js...
1870
+ //
1871
+ // TODO: See why those tests fail and use a better solution.
1872
+ if (value && (valueType === '[object ArrayBuffer]' || value.buffer && toString$1.call(value.buffer) === '[object ArrayBuffer]')) {
1873
+ // Convert binary arrays to a string and prefix the string with
1874
+ // a special marker.
1875
+ var buffer;
1876
+ var marker = SERIALIZED_MARKER;
1877
+
1878
+ if (value instanceof ArrayBuffer) {
1879
+ buffer = value;
1880
+ marker += TYPE_ARRAYBUFFER;
1881
+ } else {
1882
+ buffer = value.buffer;
1883
+
1884
+ if (valueType === '[object Int8Array]') {
1885
+ marker += TYPE_INT8ARRAY;
1886
+ } else if (valueType === '[object Uint8Array]') {
1887
+ marker += TYPE_UINT8ARRAY;
1888
+ } else if (valueType === '[object Uint8ClampedArray]') {
1889
+ marker += TYPE_UINT8CLAMPEDARRAY;
1890
+ } else if (valueType === '[object Int16Array]') {
1891
+ marker += TYPE_INT16ARRAY;
1892
+ } else if (valueType === '[object Uint16Array]') {
1893
+ marker += TYPE_UINT16ARRAY;
1894
+ } else if (valueType === '[object Int32Array]') {
1895
+ marker += TYPE_INT32ARRAY;
1896
+ } else if (valueType === '[object Uint32Array]') {
1897
+ marker += TYPE_UINT32ARRAY;
1898
+ } else if (valueType === '[object Float32Array]') {
1899
+ marker += TYPE_FLOAT32ARRAY;
1900
+ } else if (valueType === '[object Float64Array]') {
1901
+ marker += TYPE_FLOAT64ARRAY;
1902
+ } else {
1903
+ callback(new Error('Failed to get type for BinaryArray'));
1904
+ }
1905
+ }
1906
+
1907
+ callback(marker + bufferToString(buffer));
1908
+ } else if (valueType === '[object Blob]') {
1909
+ // Conver the blob to a binaryArray and then to a string.
1910
+ var fileReader = new FileReader();
1911
+
1912
+ fileReader.onload = function () {
1913
+ // Backwards-compatible prefix for the blob type.
1914
+ var str = BLOB_TYPE_PREFIX + value.type + '~' + bufferToString(this.result);
1915
+
1916
+ callback(SERIALIZED_MARKER + TYPE_BLOB + str);
1917
+ };
1918
+
1919
+ fileReader.readAsArrayBuffer(value);
1920
+ } else {
1921
+ try {
1922
+ callback(JSON.stringify(value));
1923
+ } catch (e) {
1924
+ console.error("Couldn't convert value into a JSON string: ", value);
1925
+
1926
+ callback(null, e);
1927
+ }
1928
+ }
1929
+ }
1930
+
1931
+ // Deserialize data we've inserted into a value column/field. We place
1932
+ // special markers into our strings to mark them as encoded; this isn't
1933
+ // as nice as a meta field, but it's the only sane thing we can do whilst
1934
+ // keeping localStorage support intact.
1935
+ //
1936
+ // Oftentimes this will just deserialize JSON content, but if we have a
1937
+ // special marker (SERIALIZED_MARKER, defined above), we will extract
1938
+ // some kind of arraybuffer/binary data/typed array out of the string.
1939
+ function deserialize(value) {
1940
+ // If we haven't marked this string as being specially serialized (i.e.
1941
+ // something other than serialized JSON), we can just return it and be
1942
+ // done with it.
1943
+ if (value.substring(0, SERIALIZED_MARKER_LENGTH) !== SERIALIZED_MARKER) {
1944
+ return JSON.parse(value);
1945
+ }
1946
+
1947
+ // The following code deals with deserializing some kind of Blob or
1948
+ // TypedArray. First we separate out the type of data we're dealing
1949
+ // with from the data itself.
1950
+ var serializedString = value.substring(TYPE_SERIALIZED_MARKER_LENGTH);
1951
+ var type = value.substring(SERIALIZED_MARKER_LENGTH, TYPE_SERIALIZED_MARKER_LENGTH);
1952
+
1953
+ var blobType;
1954
+ // Backwards-compatible blob type serialization strategy.
1955
+ // DBs created with older versions of localForage will simply not have the blob type.
1956
+ if (type === TYPE_BLOB && BLOB_TYPE_PREFIX_REGEX.test(serializedString)) {
1957
+ var matcher = serializedString.match(BLOB_TYPE_PREFIX_REGEX);
1958
+ blobType = matcher[1];
1959
+ serializedString = serializedString.substring(matcher[0].length);
1960
+ }
1961
+ var buffer = stringToBuffer(serializedString);
1962
+
1963
+ // Return the right type based on the code/type set during
1964
+ // serialization.
1965
+ switch (type) {
1966
+ case TYPE_ARRAYBUFFER:
1967
+ return buffer;
1968
+ case TYPE_BLOB:
1969
+ return createBlob([buffer], { type: blobType });
1970
+ case TYPE_INT8ARRAY:
1971
+ return new Int8Array(buffer);
1972
+ case TYPE_UINT8ARRAY:
1973
+ return new Uint8Array(buffer);
1974
+ case TYPE_UINT8CLAMPEDARRAY:
1975
+ return new Uint8ClampedArray(buffer);
1976
+ case TYPE_INT16ARRAY:
1977
+ return new Int16Array(buffer);
1978
+ case TYPE_UINT16ARRAY:
1979
+ return new Uint16Array(buffer);
1980
+ case TYPE_INT32ARRAY:
1981
+ return new Int32Array(buffer);
1982
+ case TYPE_UINT32ARRAY:
1983
+ return new Uint32Array(buffer);
1984
+ case TYPE_FLOAT32ARRAY:
1985
+ return new Float32Array(buffer);
1986
+ case TYPE_FLOAT64ARRAY:
1987
+ return new Float64Array(buffer);
1988
+ default:
1989
+ throw new Error('Unkown type: ' + type);
1990
+ }
1991
+ }
1992
+
1993
+ var localforageSerializer = {
1994
+ serialize: serialize,
1995
+ deserialize: deserialize,
1996
+ stringToBuffer: stringToBuffer,
1997
+ bufferToString: bufferToString
1998
+ };
1999
+
2000
+ /*
2001
+ * Includes code from:
2002
+ *
2003
+ * base64-arraybuffer
2004
+ * https://github.com/niklasvh/base64-arraybuffer
2005
+ *
2006
+ * Copyright (c) 2012 Niklas von Hertzen
2007
+ * Licensed under the MIT license.
2008
+ */
2009
+
2010
+ function createDbTable(t, dbInfo, callback, errorCallback) {
2011
+ t.executeSql('CREATE TABLE IF NOT EXISTS ' + dbInfo.storeName + ' ' + '(id INTEGER PRIMARY KEY, key unique, value)', [], callback, errorCallback);
2012
+ }
2013
+
2014
+ // Open the WebSQL database (automatically creates one if one didn't
2015
+ // previously exist), using any options set in the config.
2016
+ function _initStorage$1(options) {
2017
+ var self = this;
2018
+ var dbInfo = {
2019
+ db: null
2020
+ };
2021
+
2022
+ if (options) {
2023
+ for (var i in options) {
2024
+ dbInfo[i] = typeof options[i] !== 'string' ? options[i].toString() : options[i];
2025
+ }
2026
+ }
2027
+
2028
+ var dbInfoPromise = new Promise$1(function (resolve, reject) {
2029
+ // Open the database; the openDatabase API will automatically
2030
+ // create it for us if it doesn't exist.
2031
+ try {
2032
+ dbInfo.db = openDatabase(dbInfo.name, String(dbInfo.version), dbInfo.description, dbInfo.size);
2033
+ } catch (e) {
2034
+ return reject(e);
2035
+ }
2036
+
2037
+ // Create our key/value table if it doesn't exist.
2038
+ dbInfo.db.transaction(function (t) {
2039
+ createDbTable(t, dbInfo, function () {
2040
+ self._dbInfo = dbInfo;
2041
+ resolve();
2042
+ }, function (t, error) {
2043
+ reject(error);
2044
+ });
2045
+ }, reject);
2046
+ });
2047
+
2048
+ dbInfo.serializer = localforageSerializer;
2049
+ return dbInfoPromise;
2050
+ }
2051
+
2052
+ function tryExecuteSql(t, dbInfo, sqlStatement, args, callback, errorCallback) {
2053
+ t.executeSql(sqlStatement, args, callback, function (t, error) {
2054
+ if (error.code === error.SYNTAX_ERR) {
2055
+ t.executeSql('SELECT name FROM sqlite_master ' + "WHERE type='table' AND name = ?", [dbInfo.storeName], function (t, results) {
2056
+ if (!results.rows.length) {
2057
+ // if the table is missing (was deleted)
2058
+ // re-create it table and retry
2059
+ createDbTable(t, dbInfo, function () {
2060
+ t.executeSql(sqlStatement, args, callback, errorCallback);
2061
+ }, errorCallback);
2062
+ } else {
2063
+ errorCallback(t, error);
2064
+ }
2065
+ }, errorCallback);
2066
+ } else {
2067
+ errorCallback(t, error);
2068
+ }
2069
+ }, errorCallback);
2070
+ }
2071
+
2072
+ function getItem$1(key, callback) {
2073
+ var self = this;
2074
+
2075
+ key = normalizeKey(key);
2076
+
2077
+ var promise = new Promise$1(function (resolve, reject) {
2078
+ self.ready().then(function () {
2079
+ var dbInfo = self._dbInfo;
2080
+ dbInfo.db.transaction(function (t) {
2081
+ tryExecuteSql(t, dbInfo, 'SELECT * FROM ' + dbInfo.storeName + ' WHERE key = ? LIMIT 1', [key], function (t, results) {
2082
+ var result = results.rows.length ? results.rows.item(0).value : null;
2083
+
2084
+ // Check to see if this is serialized content we need to
2085
+ // unpack.
2086
+ if (result) {
2087
+ result = dbInfo.serializer.deserialize(result);
2088
+ }
2089
+
2090
+ resolve(result);
2091
+ }, function (t, error) {
2092
+ reject(error);
2093
+ });
2094
+ });
2095
+ })["catch"](reject);
2096
+ });
2097
+
2098
+ executeCallback(promise, callback);
2099
+ return promise;
2100
+ }
2101
+
2102
+ function iterate$1(iterator, callback) {
2103
+ var self = this;
2104
+
2105
+ var promise = new Promise$1(function (resolve, reject) {
2106
+ self.ready().then(function () {
2107
+ var dbInfo = self._dbInfo;
2108
+
2109
+ dbInfo.db.transaction(function (t) {
2110
+ tryExecuteSql(t, dbInfo, 'SELECT * FROM ' + dbInfo.storeName, [], function (t, results) {
2111
+ var rows = results.rows;
2112
+ var length = rows.length;
2113
+
2114
+ for (var i = 0; i < length; i++) {
2115
+ var item = rows.item(i);
2116
+ var result = item.value;
2117
+
2118
+ // Check to see if this is serialized content
2119
+ // we need to unpack.
2120
+ if (result) {
2121
+ result = dbInfo.serializer.deserialize(result);
2122
+ }
2123
+
2124
+ result = iterator(result, item.key, i + 1);
2125
+
2126
+ // void(0) prevents problems with redefinition
2127
+ // of `undefined`.
2128
+ if (result !== void 0) {
2129
+ resolve(result);
2130
+ return;
2131
+ }
2132
+ }
2133
+
2134
+ resolve();
2135
+ }, function (t, error) {
2136
+ reject(error);
2137
+ });
2138
+ });
2139
+ })["catch"](reject);
2140
+ });
2141
+
2142
+ executeCallback(promise, callback);
2143
+ return promise;
2144
+ }
2145
+
2146
+ function _setItem(key, value, callback, retriesLeft) {
2147
+ var self = this;
2148
+
2149
+ key = normalizeKey(key);
2150
+
2151
+ var promise = new Promise$1(function (resolve, reject) {
2152
+ self.ready().then(function () {
2153
+ // The localStorage API doesn't return undefined values in an
2154
+ // "expected" way, so undefined is always cast to null in all
2155
+ // drivers. See: https://github.com/mozilla/localForage/pull/42
2156
+ if (value === undefined) {
2157
+ value = null;
2158
+ }
2159
+
2160
+ // Save the original value to pass to the callback.
2161
+ var originalValue = value;
2162
+
2163
+ var dbInfo = self._dbInfo;
2164
+ dbInfo.serializer.serialize(value, function (value, error) {
2165
+ if (error) {
2166
+ reject(error);
2167
+ } else {
2168
+ dbInfo.db.transaction(function (t) {
2169
+ tryExecuteSql(t, dbInfo, 'INSERT OR REPLACE INTO ' + dbInfo.storeName + ' ' + '(key, value) VALUES (?, ?)', [key, value], function () {
2170
+ resolve(originalValue);
2171
+ }, function (t, error) {
2172
+ reject(error);
2173
+ });
2174
+ }, function (sqlError) {
2175
+ // The transaction failed; check
2176
+ // to see if it's a quota error.
2177
+ if (sqlError.code === sqlError.QUOTA_ERR) {
2178
+ // We reject the callback outright for now, but
2179
+ // it's worth trying to re-run the transaction.
2180
+ // Even if the user accepts the prompt to use
2181
+ // more storage on Safari, this error will
2182
+ // be called.
2183
+ //
2184
+ // Try to re-run the transaction.
2185
+ if (retriesLeft > 0) {
2186
+ resolve(_setItem.apply(self, [key, originalValue, callback, retriesLeft - 1]));
2187
+ return;
2188
+ }
2189
+ reject(sqlError);
2190
+ }
2191
+ });
2192
+ }
2193
+ });
2194
+ })["catch"](reject);
2195
+ });
2196
+
2197
+ executeCallback(promise, callback);
2198
+ return promise;
2199
+ }
2200
+
2201
+ function setItem$1(key, value, callback) {
2202
+ return _setItem.apply(this, [key, value, callback, 1]);
2203
+ }
2204
+
2205
+ function removeItem$1(key, callback) {
2206
+ var self = this;
2207
+
2208
+ key = normalizeKey(key);
2209
+
2210
+ var promise = new Promise$1(function (resolve, reject) {
2211
+ self.ready().then(function () {
2212
+ var dbInfo = self._dbInfo;
2213
+ dbInfo.db.transaction(function (t) {
2214
+ tryExecuteSql(t, dbInfo, 'DELETE FROM ' + dbInfo.storeName + ' WHERE key = ?', [key], function () {
2215
+ resolve();
2216
+ }, function (t, error) {
2217
+ reject(error);
2218
+ });
2219
+ });
2220
+ })["catch"](reject);
2221
+ });
2222
+
2223
+ executeCallback(promise, callback);
2224
+ return promise;
2225
+ }
2226
+
2227
+ // Deletes every item in the table.
2228
+ // TODO: Find out if this resets the AUTO_INCREMENT number.
2229
+ function clear$1(callback) {
2230
+ var self = this;
2231
+
2232
+ var promise = new Promise$1(function (resolve, reject) {
2233
+ self.ready().then(function () {
2234
+ var dbInfo = self._dbInfo;
2235
+ dbInfo.db.transaction(function (t) {
2236
+ tryExecuteSql(t, dbInfo, 'DELETE FROM ' + dbInfo.storeName, [], function () {
2237
+ resolve();
2238
+ }, function (t, error) {
2239
+ reject(error);
2240
+ });
2241
+ });
2242
+ })["catch"](reject);
2243
+ });
2244
+
2245
+ executeCallback(promise, callback);
2246
+ return promise;
2247
+ }
2248
+
2249
+ // Does a simple `COUNT(key)` to get the number of items stored in
2250
+ // localForage.
2251
+ function length$1(callback) {
2252
+ var self = this;
2253
+
2254
+ var promise = new Promise$1(function (resolve, reject) {
2255
+ self.ready().then(function () {
2256
+ var dbInfo = self._dbInfo;
2257
+ dbInfo.db.transaction(function (t) {
2258
+ // Ahhh, SQL makes this one soooooo easy.
2259
+ tryExecuteSql(t, dbInfo, 'SELECT COUNT(key) as c FROM ' + dbInfo.storeName, [], function (t, results) {
2260
+ var result = results.rows.item(0).c;
2261
+ resolve(result);
2262
+ }, function (t, error) {
2263
+ reject(error);
2264
+ });
2265
+ });
2266
+ })["catch"](reject);
2267
+ });
2268
+
2269
+ executeCallback(promise, callback);
2270
+ return promise;
2271
+ }
2272
+
2273
+ // Return the key located at key index X; essentially gets the key from a
2274
+ // `WHERE id = ?`. This is the most efficient way I can think to implement
2275
+ // this rarely-used (in my experience) part of the API, but it can seem
2276
+ // inconsistent, because we do `INSERT OR REPLACE INTO` on `setItem()`, so
2277
+ // the ID of each key will change every time it's updated. Perhaps a stored
2278
+ // procedure for the `setItem()` SQL would solve this problem?
2279
+ // TODO: Don't change ID on `setItem()`.
2280
+ function key$1(n, callback) {
2281
+ var self = this;
2282
+
2283
+ var promise = new Promise$1(function (resolve, reject) {
2284
+ self.ready().then(function () {
2285
+ var dbInfo = self._dbInfo;
2286
+ dbInfo.db.transaction(function (t) {
2287
+ tryExecuteSql(t, dbInfo, 'SELECT key FROM ' + dbInfo.storeName + ' WHERE id = ? LIMIT 1', [n + 1], function (t, results) {
2288
+ var result = results.rows.length ? results.rows.item(0).key : null;
2289
+ resolve(result);
2290
+ }, function (t, error) {
2291
+ reject(error);
2292
+ });
2293
+ });
2294
+ })["catch"](reject);
2295
+ });
2296
+
2297
+ executeCallback(promise, callback);
2298
+ return promise;
2299
+ }
2300
+
2301
+ function keys$1(callback) {
2302
+ var self = this;
2303
+
2304
+ var promise = new Promise$1(function (resolve, reject) {
2305
+ self.ready().then(function () {
2306
+ var dbInfo = self._dbInfo;
2307
+ dbInfo.db.transaction(function (t) {
2308
+ tryExecuteSql(t, dbInfo, 'SELECT key FROM ' + dbInfo.storeName, [], function (t, results) {
2309
+ var keys = [];
2310
+
2311
+ for (var i = 0; i < results.rows.length; i++) {
2312
+ keys.push(results.rows.item(i).key);
2313
+ }
2314
+
2315
+ resolve(keys);
2316
+ }, function (t, error) {
2317
+ reject(error);
2318
+ });
2319
+ });
2320
+ })["catch"](reject);
2321
+ });
2322
+
2323
+ executeCallback(promise, callback);
2324
+ return promise;
2325
+ }
2326
+
2327
+ // https://www.w3.org/TR/webdatabase/#databases
2328
+ // > There is no way to enumerate or delete the databases available for an origin from this API.
2329
+ function getAllStoreNames(db) {
2330
+ return new Promise$1(function (resolve, reject) {
2331
+ db.transaction(function (t) {
2332
+ t.executeSql('SELECT name FROM sqlite_master ' + "WHERE type='table' AND name <> '__WebKitDatabaseInfoTable__'", [], function (t, results) {
2333
+ var storeNames = [];
2334
+
2335
+ for (var i = 0; i < results.rows.length; i++) {
2336
+ storeNames.push(results.rows.item(i).name);
2337
+ }
2338
+
2339
+ resolve({
2340
+ db: db,
2341
+ storeNames: storeNames
2342
+ });
2343
+ }, function (t, error) {
2344
+ reject(error);
2345
+ });
2346
+ }, function (sqlError) {
2347
+ reject(sqlError);
2348
+ });
2349
+ });
2350
+ }
2351
+
2352
+ function dropInstance$1(options, callback) {
2353
+ callback = getCallback.apply(this, arguments);
2354
+
2355
+ var currentConfig = this.config();
2356
+ options = typeof options !== 'function' && options || {};
2357
+ if (!options.name) {
2358
+ options.name = options.name || currentConfig.name;
2359
+ options.storeName = options.storeName || currentConfig.storeName;
2360
+ }
2361
+
2362
+ var self = this;
2363
+ var promise;
2364
+ if (!options.name) {
2365
+ promise = Promise$1.reject('Invalid arguments');
2366
+ } else {
2367
+ promise = new Promise$1(function (resolve) {
2368
+ var db;
2369
+ if (options.name === currentConfig.name) {
2370
+ // use the db reference of the current instance
2371
+ db = self._dbInfo.db;
2372
+ } else {
2373
+ db = openDatabase(options.name, '', '', 0);
2374
+ }
2375
+
2376
+ if (!options.storeName) {
2377
+ // drop all database tables
2378
+ resolve(getAllStoreNames(db));
2379
+ } else {
2380
+ resolve({
2381
+ db: db,
2382
+ storeNames: [options.storeName]
2383
+ });
2384
+ }
2385
+ }).then(function (operationInfo) {
2386
+ return new Promise$1(function (resolve, reject) {
2387
+ operationInfo.db.transaction(function (t) {
2388
+ function dropTable(storeName) {
2389
+ return new Promise$1(function (resolve, reject) {
2390
+ t.executeSql('DROP TABLE IF EXISTS ' + storeName, [], function () {
2391
+ resolve();
2392
+ }, function (t, error) {
2393
+ reject(error);
2394
+ });
2395
+ });
2396
+ }
2397
+
2398
+ var operations = [];
2399
+ for (var i = 0, len = operationInfo.storeNames.length; i < len; i++) {
2400
+ operations.push(dropTable(operationInfo.storeNames[i]));
2401
+ }
2402
+
2403
+ Promise$1.all(operations).then(function () {
2404
+ resolve();
2405
+ })["catch"](function (e) {
2406
+ reject(e);
2407
+ });
2408
+ }, function (sqlError) {
2409
+ reject(sqlError);
2410
+ });
2411
+ });
2412
+ });
2413
+ }
2414
+
2415
+ executeCallback(promise, callback);
2416
+ return promise;
2417
+ }
2418
+
2419
+ var webSQLStorage = {
2420
+ _driver: 'webSQLStorage',
2421
+ _initStorage: _initStorage$1,
2422
+ _support: isWebSQLValid(),
2423
+ iterate: iterate$1,
2424
+ getItem: getItem$1,
2425
+ setItem: setItem$1,
2426
+ removeItem: removeItem$1,
2427
+ clear: clear$1,
2428
+ length: length$1,
2429
+ key: key$1,
2430
+ keys: keys$1,
2431
+ dropInstance: dropInstance$1
2432
+ };
2433
+
2434
+ function isLocalStorageValid() {
2435
+ try {
2436
+ return typeof localStorage !== 'undefined' && 'setItem' in localStorage &&
2437
+ // in IE8 typeof localStorage.setItem === 'object'
2438
+ !!localStorage.setItem;
2439
+ } catch (e) {
2440
+ return false;
2441
+ }
2442
+ }
2443
+
2444
+ function _getKeyPrefix(options, defaultConfig) {
2445
+ var keyPrefix = options.name + '/';
2446
+
2447
+ if (options.storeName !== defaultConfig.storeName) {
2448
+ keyPrefix += options.storeName + '/';
2449
+ }
2450
+ return keyPrefix;
2451
+ }
2452
+
2453
+ // Check if localStorage throws when saving an item
2454
+ function checkIfLocalStorageThrows() {
2455
+ var localStorageTestKey = '_localforage_support_test';
2456
+
2457
+ try {
2458
+ localStorage.setItem(localStorageTestKey, true);
2459
+ localStorage.removeItem(localStorageTestKey);
2460
+
2461
+ return false;
2462
+ } catch (e) {
2463
+ return true;
2464
+ }
2465
+ }
2466
+
2467
+ // Check if localStorage is usable and allows to save an item
2468
+ // This method checks if localStorage is usable in Safari Private Browsing
2469
+ // mode, or in any other case where the available quota for localStorage
2470
+ // is 0 and there wasn't any saved items yet.
2471
+ function _isLocalStorageUsable() {
2472
+ return !checkIfLocalStorageThrows() || localStorage.length > 0;
2473
+ }
2474
+
2475
+ // Config the localStorage backend, using options set in the config.
2476
+ function _initStorage$2(options) {
2477
+ var self = this;
2478
+ var dbInfo = {};
2479
+ if (options) {
2480
+ for (var i in options) {
2481
+ dbInfo[i] = options[i];
2482
+ }
2483
+ }
2484
+
2485
+ dbInfo.keyPrefix = _getKeyPrefix(options, self._defaultConfig);
2486
+
2487
+ if (!_isLocalStorageUsable()) {
2488
+ return Promise$1.reject();
2489
+ }
2490
+
2491
+ self._dbInfo = dbInfo;
2492
+ dbInfo.serializer = localforageSerializer;
2493
+
2494
+ return Promise$1.resolve();
2495
+ }
2496
+
2497
+ // Remove all keys from the datastore, effectively destroying all data in
2498
+ // the app's key/value store!
2499
+ function clear$2(callback) {
2500
+ var self = this;
2501
+ var promise = self.ready().then(function () {
2502
+ var keyPrefix = self._dbInfo.keyPrefix;
2503
+
2504
+ for (var i = localStorage.length - 1; i >= 0; i--) {
2505
+ var key = localStorage.key(i);
2506
+
2507
+ if (key.indexOf(keyPrefix) === 0) {
2508
+ localStorage.removeItem(key);
2509
+ }
2510
+ }
2511
+ });
2512
+
2513
+ executeCallback(promise, callback);
2514
+ return promise;
2515
+ }
2516
+
2517
+ // Retrieve an item from the store. Unlike the original async_storage
2518
+ // library in Gaia, we don't modify return values at all. If a key's value
2519
+ // is `undefined`, we pass that value to the callback function.
2520
+ function getItem$2(key, callback) {
2521
+ var self = this;
2522
+
2523
+ key = normalizeKey(key);
2524
+
2525
+ var promise = self.ready().then(function () {
2526
+ var dbInfo = self._dbInfo;
2527
+ var result = localStorage.getItem(dbInfo.keyPrefix + key);
2528
+
2529
+ // If a result was found, parse it from the serialized
2530
+ // string into a JS object. If result isn't truthy, the key
2531
+ // is likely undefined and we'll pass it straight to the
2532
+ // callback.
2533
+ if (result) {
2534
+ result = dbInfo.serializer.deserialize(result);
2535
+ }
2536
+
2537
+ return result;
2538
+ });
2539
+
2540
+ executeCallback(promise, callback);
2541
+ return promise;
2542
+ }
2543
+
2544
+ // Iterate over all items in the store.
2545
+ function iterate$2(iterator, callback) {
2546
+ var self = this;
2547
+
2548
+ var promise = self.ready().then(function () {
2549
+ var dbInfo = self._dbInfo;
2550
+ var keyPrefix = dbInfo.keyPrefix;
2551
+ var keyPrefixLength = keyPrefix.length;
2552
+ var length = localStorage.length;
2553
+
2554
+ // We use a dedicated iterator instead of the `i` variable below
2555
+ // so other keys we fetch in localStorage aren't counted in
2556
+ // the `iterationNumber` argument passed to the `iterate()`
2557
+ // callback.
2558
+ //
2559
+ // See: github.com/mozilla/localForage/pull/435#discussion_r38061530
2560
+ var iterationNumber = 1;
2561
+
2562
+ for (var i = 0; i < length; i++) {
2563
+ var key = localStorage.key(i);
2564
+ if (key.indexOf(keyPrefix) !== 0) {
2565
+ continue;
2566
+ }
2567
+ var value = localStorage.getItem(key);
2568
+
2569
+ // If a result was found, parse it from the serialized
2570
+ // string into a JS object. If result isn't truthy, the
2571
+ // key is likely undefined and we'll pass it straight
2572
+ // to the iterator.
2573
+ if (value) {
2574
+ value = dbInfo.serializer.deserialize(value);
2575
+ }
2576
+
2577
+ value = iterator(value, key.substring(keyPrefixLength), iterationNumber++);
2578
+
2579
+ if (value !== void 0) {
2580
+ return value;
2581
+ }
2582
+ }
2583
+ });
2584
+
2585
+ executeCallback(promise, callback);
2586
+ return promise;
2587
+ }
2588
+
2589
+ // Same as localStorage's key() method, except takes a callback.
2590
+ function key$2(n, callback) {
2591
+ var self = this;
2592
+ var promise = self.ready().then(function () {
2593
+ var dbInfo = self._dbInfo;
2594
+ var result;
2595
+ try {
2596
+ result = localStorage.key(n);
2597
+ } catch (error) {
2598
+ result = null;
2599
+ }
2600
+
2601
+ // Remove the prefix from the key, if a key is found.
2602
+ if (result) {
2603
+ result = result.substring(dbInfo.keyPrefix.length);
2604
+ }
2605
+
2606
+ return result;
2607
+ });
2608
+
2609
+ executeCallback(promise, callback);
2610
+ return promise;
2611
+ }
2612
+
2613
+ function keys$2(callback) {
2614
+ var self = this;
2615
+ var promise = self.ready().then(function () {
2616
+ var dbInfo = self._dbInfo;
2617
+ var length = localStorage.length;
2618
+ var keys = [];
2619
+
2620
+ for (var i = 0; i < length; i++) {
2621
+ var itemKey = localStorage.key(i);
2622
+ if (itemKey.indexOf(dbInfo.keyPrefix) === 0) {
2623
+ keys.push(itemKey.substring(dbInfo.keyPrefix.length));
2624
+ }
2625
+ }
2626
+
2627
+ return keys;
2628
+ });
2629
+
2630
+ executeCallback(promise, callback);
2631
+ return promise;
2632
+ }
2633
+
2634
+ // Supply the number of keys in the datastore to the callback function.
2635
+ function length$2(callback) {
2636
+ var self = this;
2637
+ var promise = self.keys().then(function (keys) {
2638
+ return keys.length;
2639
+ });
2640
+
2641
+ executeCallback(promise, callback);
2642
+ return promise;
2643
+ }
2644
+
2645
+ // Remove an item from the store, nice and simple.
2646
+ function removeItem$2(key, callback) {
2647
+ var self = this;
2648
+
2649
+ key = normalizeKey(key);
2650
+
2651
+ var promise = self.ready().then(function () {
2652
+ var dbInfo = self._dbInfo;
2653
+ localStorage.removeItem(dbInfo.keyPrefix + key);
2654
+ });
2655
+
2656
+ executeCallback(promise, callback);
2657
+ return promise;
2658
+ }
2659
+
2660
+ // Set a key's value and run an optional callback once the value is set.
2661
+ // Unlike Gaia's implementation, the callback function is passed the value,
2662
+ // in case you want to operate on that value only after you're sure it
2663
+ // saved, or something like that.
2664
+ function setItem$2(key, value, callback) {
2665
+ var self = this;
2666
+
2667
+ key = normalizeKey(key);
2668
+
2669
+ var promise = self.ready().then(function () {
2670
+ // Convert undefined values to null.
2671
+ // https://github.com/mozilla/localForage/pull/42
2672
+ if (value === undefined) {
2673
+ value = null;
2674
+ }
2675
+
2676
+ // Save the original value to pass to the callback.
2677
+ var originalValue = value;
2678
+
2679
+ return new Promise$1(function (resolve, reject) {
2680
+ var dbInfo = self._dbInfo;
2681
+ dbInfo.serializer.serialize(value, function (value, error) {
2682
+ if (error) {
2683
+ reject(error);
2684
+ } else {
2685
+ try {
2686
+ localStorage.setItem(dbInfo.keyPrefix + key, value);
2687
+ resolve(originalValue);
2688
+ } catch (e) {
2689
+ // localStorage capacity exceeded.
2690
+ // TODO: Make this a specific error/event.
2691
+ if (e.name === 'QuotaExceededError' || e.name === 'NS_ERROR_DOM_QUOTA_REACHED') {
2692
+ reject(e);
2693
+ }
2694
+ reject(e);
2695
+ }
2696
+ }
2697
+ });
2698
+ });
2699
+ });
2700
+
2701
+ executeCallback(promise, callback);
2702
+ return promise;
2703
+ }
2704
+
2705
+ function dropInstance$2(options, callback) {
2706
+ callback = getCallback.apply(this, arguments);
2707
+
2708
+ options = typeof options !== 'function' && options || {};
2709
+ if (!options.name) {
2710
+ var currentConfig = this.config();
2711
+ options.name = options.name || currentConfig.name;
2712
+ options.storeName = options.storeName || currentConfig.storeName;
2713
+ }
2714
+
2715
+ var self = this;
2716
+ var promise;
2717
+ if (!options.name) {
2718
+ promise = Promise$1.reject('Invalid arguments');
2719
+ } else {
2720
+ promise = new Promise$1(function (resolve) {
2721
+ if (!options.storeName) {
2722
+ resolve(options.name + '/');
2723
+ } else {
2724
+ resolve(_getKeyPrefix(options, self._defaultConfig));
2725
+ }
2726
+ }).then(function (keyPrefix) {
2727
+ for (var i = localStorage.length - 1; i >= 0; i--) {
2728
+ var key = localStorage.key(i);
2729
+
2730
+ if (key.indexOf(keyPrefix) === 0) {
2731
+ localStorage.removeItem(key);
2732
+ }
2733
+ }
2734
+ });
2735
+ }
2736
+
2737
+ executeCallback(promise, callback);
2738
+ return promise;
2739
+ }
2740
+
2741
+ var localStorageWrapper = {
2742
+ _driver: 'localStorageWrapper',
2743
+ _initStorage: _initStorage$2,
2744
+ _support: isLocalStorageValid(),
2745
+ iterate: iterate$2,
2746
+ getItem: getItem$2,
2747
+ setItem: setItem$2,
2748
+ removeItem: removeItem$2,
2749
+ clear: clear$2,
2750
+ length: length$2,
2751
+ key: key$2,
2752
+ keys: keys$2,
2753
+ dropInstance: dropInstance$2
2754
+ };
2755
+
2756
+ var sameValue = function sameValue(x, y) {
2757
+ return x === y || typeof x === 'number' && typeof y === 'number' && isNaN(x) && isNaN(y);
2758
+ };
2759
+
2760
+ var includes = function includes(array, searchElement) {
2761
+ var len = array.length;
2762
+ var i = 0;
2763
+ while (i < len) {
2764
+ if (sameValue(array[i], searchElement)) {
2765
+ return true;
2766
+ }
2767
+ i++;
2768
+ }
2769
+
2770
+ return false;
2771
+ };
2772
+
2773
+ var isArray = Array.isArray || function (arg) {
2774
+ return Object.prototype.toString.call(arg) === '[object Array]';
2775
+ };
2776
+
2777
+ // Drivers are stored here when `defineDriver()` is called.
2778
+ // They are shared across all instances of localForage.
2779
+ var DefinedDrivers = {};
2780
+
2781
+ var DriverSupport = {};
2782
+
2783
+ var DefaultDrivers = {
2784
+ INDEXEDDB: asyncStorage,
2785
+ WEBSQL: webSQLStorage,
2786
+ LOCALSTORAGE: localStorageWrapper
2787
+ };
2788
+
2789
+ var DefaultDriverOrder = [DefaultDrivers.INDEXEDDB._driver, DefaultDrivers.WEBSQL._driver, DefaultDrivers.LOCALSTORAGE._driver];
2790
+
2791
+ var OptionalDriverMethods = ['dropInstance'];
2792
+
2793
+ var LibraryMethods = ['clear', 'getItem', 'iterate', 'key', 'keys', 'length', 'removeItem', 'setItem'].concat(OptionalDriverMethods);
2794
+
2795
+ var DefaultConfig = {
2796
+ description: '',
2797
+ driver: DefaultDriverOrder.slice(),
2798
+ name: 'localforage',
2799
+ // Default DB size is _JUST UNDER_ 5MB, as it's the highest size
2800
+ // we can use without a prompt.
2801
+ size: 4980736,
2802
+ storeName: 'keyvaluepairs',
2803
+ version: 1.0
2804
+ };
2805
+
2806
+ function callWhenReady(localForageInstance, libraryMethod) {
2807
+ localForageInstance[libraryMethod] = function () {
2808
+ var _args = arguments;
2809
+ return localForageInstance.ready().then(function () {
2810
+ return localForageInstance[libraryMethod].apply(localForageInstance, _args);
2811
+ });
2812
+ };
2813
+ }
2814
+
2815
+ function extend() {
2816
+ for (var i = 1; i < arguments.length; i++) {
2817
+ var arg = arguments[i];
2818
+
2819
+ if (arg) {
2820
+ for (var _key in arg) {
2821
+ if (arg.hasOwnProperty(_key)) {
2822
+ if (isArray(arg[_key])) {
2823
+ arguments[0][_key] = arg[_key].slice();
2824
+ } else {
2825
+ arguments[0][_key] = arg[_key];
2826
+ }
2827
+ }
2828
+ }
2829
+ }
2830
+ }
2831
+
2832
+ return arguments[0];
2833
+ }
2834
+
2835
+ var LocalForage = function () {
2836
+ function LocalForage(options) {
2837
+ _classCallCheck(this, LocalForage);
2838
+
2839
+ for (var driverTypeKey in DefaultDrivers) {
2840
+ if (DefaultDrivers.hasOwnProperty(driverTypeKey)) {
2841
+ var driver = DefaultDrivers[driverTypeKey];
2842
+ var driverName = driver._driver;
2843
+ this[driverTypeKey] = driverName;
2844
+
2845
+ if (!DefinedDrivers[driverName]) {
2846
+ // we don't need to wait for the promise,
2847
+ // since the default drivers can be defined
2848
+ // in a blocking manner
2849
+ this.defineDriver(driver);
2850
+ }
2851
+ }
2852
+ }
2853
+
2854
+ this._defaultConfig = extend({}, DefaultConfig);
2855
+ this._config = extend({}, this._defaultConfig, options);
2856
+ this._driverSet = null;
2857
+ this._initDriver = null;
2858
+ this._ready = false;
2859
+ this._dbInfo = null;
2860
+
2861
+ this._wrapLibraryMethodsWithReady();
2862
+ this.setDriver(this._config.driver)["catch"](function () {});
2863
+ }
2864
+
2865
+ // Set any config values for localForage; can be called anytime before
2866
+ // the first API call (e.g. `getItem`, `setItem`).
2867
+ // We loop through options so we don't overwrite existing config
2868
+ // values.
2869
+
2870
+
2871
+ LocalForage.prototype.config = function config(options) {
2872
+ // If the options argument is an object, we use it to set values.
2873
+ // Otherwise, we return either a specified config value or all
2874
+ // config values.
2875
+ if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) === 'object') {
2876
+ // If localforage is ready and fully initialized, we can't set
2877
+ // any new configuration values. Instead, we return an error.
2878
+ if (this._ready) {
2879
+ return new Error("Can't call config() after localforage " + 'has been used.');
2880
+ }
2881
+
2882
+ for (var i in options) {
2883
+ if (i === 'storeName') {
2884
+ options[i] = options[i].replace(/\W/g, '_');
2885
+ }
2886
+
2887
+ if (i === 'version' && typeof options[i] !== 'number') {
2888
+ return new Error('Database version must be a number.');
2889
+ }
2890
+
2891
+ this._config[i] = options[i];
2892
+ }
2893
+
2894
+ // after all config options are set and
2895
+ // the driver option is used, try setting it
2896
+ if ('driver' in options && options.driver) {
2897
+ return this.setDriver(this._config.driver);
2898
+ }
2899
+
2900
+ return true;
2901
+ } else if (typeof options === 'string') {
2902
+ return this._config[options];
2903
+ } else {
2904
+ return this._config;
2905
+ }
2906
+ };
2907
+
2908
+ // Used to define a custom driver, shared across all instances of
2909
+ // localForage.
2910
+
2911
+
2912
+ LocalForage.prototype.defineDriver = function defineDriver(driverObject, callback, errorCallback) {
2913
+ var promise = new Promise$1(function (resolve, reject) {
2914
+ try {
2915
+ var driverName = driverObject._driver;
2916
+ var complianceError = new Error('Custom driver not compliant; see ' + 'https://mozilla.github.io/localForage/#definedriver');
2917
+
2918
+ // A driver name should be defined and not overlap with the
2919
+ // library-defined, default drivers.
2920
+ if (!driverObject._driver) {
2921
+ reject(complianceError);
2922
+ return;
2923
+ }
2924
+
2925
+ var driverMethods = LibraryMethods.concat('_initStorage');
2926
+ for (var i = 0, len = driverMethods.length; i < len; i++) {
2927
+ var driverMethodName = driverMethods[i];
2928
+
2929
+ // when the property is there,
2930
+ // it should be a method even when optional
2931
+ var isRequired = !includes(OptionalDriverMethods, driverMethodName);
2932
+ if ((isRequired || driverObject[driverMethodName]) && typeof driverObject[driverMethodName] !== 'function') {
2933
+ reject(complianceError);
2934
+ return;
2935
+ }
2936
+ }
2937
+
2938
+ var configureMissingMethods = function configureMissingMethods() {
2939
+ var methodNotImplementedFactory = function methodNotImplementedFactory(methodName) {
2940
+ return function () {
2941
+ var error = new Error('Method ' + methodName + ' is not implemented by the current driver');
2942
+ var promise = Promise$1.reject(error);
2943
+ executeCallback(promise, arguments[arguments.length - 1]);
2944
+ return promise;
2945
+ };
2946
+ };
2947
+
2948
+ for (var _i = 0, _len = OptionalDriverMethods.length; _i < _len; _i++) {
2949
+ var optionalDriverMethod = OptionalDriverMethods[_i];
2950
+ if (!driverObject[optionalDriverMethod]) {
2951
+ driverObject[optionalDriverMethod] = methodNotImplementedFactory(optionalDriverMethod);
2952
+ }
2953
+ }
2954
+ };
2955
+
2956
+ configureMissingMethods();
2957
+
2958
+ var setDriverSupport = function setDriverSupport(support) {
2959
+ if (DefinedDrivers[driverName]) {
2960
+ console.info('Redefining LocalForage driver: ' + driverName);
2961
+ }
2962
+ DefinedDrivers[driverName] = driverObject;
2963
+ DriverSupport[driverName] = support;
2964
+ // don't use a then, so that we can define
2965
+ // drivers that have simple _support methods
2966
+ // in a blocking manner
2967
+ resolve();
2968
+ };
2969
+
2970
+ if ('_support' in driverObject) {
2971
+ if (driverObject._support && typeof driverObject._support === 'function') {
2972
+ driverObject._support().then(setDriverSupport, reject);
2973
+ } else {
2974
+ setDriverSupport(!!driverObject._support);
2975
+ }
2976
+ } else {
2977
+ setDriverSupport(true);
2978
+ }
2979
+ } catch (e) {
2980
+ reject(e);
2981
+ }
2982
+ });
2983
+
2984
+ executeTwoCallbacks(promise, callback, errorCallback);
2985
+ return promise;
2986
+ };
2987
+
2988
+ LocalForage.prototype.driver = function driver() {
2989
+ return this._driver || null;
2990
+ };
2991
+
2992
+ LocalForage.prototype.getDriver = function getDriver(driverName, callback, errorCallback) {
2993
+ var getDriverPromise = DefinedDrivers[driverName] ? Promise$1.resolve(DefinedDrivers[driverName]) : Promise$1.reject(new Error('Driver not found.'));
2994
+
2995
+ executeTwoCallbacks(getDriverPromise, callback, errorCallback);
2996
+ return getDriverPromise;
2997
+ };
2998
+
2999
+ LocalForage.prototype.getSerializer = function getSerializer(callback) {
3000
+ var serializerPromise = Promise$1.resolve(localforageSerializer);
3001
+ executeTwoCallbacks(serializerPromise, callback);
3002
+ return serializerPromise;
3003
+ };
3004
+
3005
+ LocalForage.prototype.ready = function ready(callback) {
3006
+ var self = this;
3007
+
3008
+ var promise = self._driverSet.then(function () {
3009
+ if (self._ready === null) {
3010
+ self._ready = self._initDriver();
3011
+ }
3012
+
3013
+ return self._ready;
3014
+ });
3015
+
3016
+ executeTwoCallbacks(promise, callback, callback);
3017
+ return promise;
3018
+ };
3019
+
3020
+ LocalForage.prototype.setDriver = function setDriver(drivers, callback, errorCallback) {
3021
+ var self = this;
3022
+
3023
+ if (!isArray(drivers)) {
3024
+ drivers = [drivers];
3025
+ }
3026
+
3027
+ var supportedDrivers = this._getSupportedDrivers(drivers);
3028
+
3029
+ function setDriverToConfig() {
3030
+ self._config.driver = self.driver();
3031
+ }
3032
+
3033
+ function extendSelfWithDriver(driver) {
3034
+ self._extend(driver);
3035
+ setDriverToConfig();
3036
+
3037
+ self._ready = self._initStorage(self._config);
3038
+ return self._ready;
3039
+ }
3040
+
3041
+ function initDriver(supportedDrivers) {
3042
+ return function () {
3043
+ var currentDriverIndex = 0;
3044
+
3045
+ function driverPromiseLoop() {
3046
+ while (currentDriverIndex < supportedDrivers.length) {
3047
+ var driverName = supportedDrivers[currentDriverIndex];
3048
+ currentDriverIndex++;
3049
+
3050
+ self._dbInfo = null;
3051
+ self._ready = null;
3052
+
3053
+ return self.getDriver(driverName).then(extendSelfWithDriver)["catch"](driverPromiseLoop);
3054
+ }
3055
+
3056
+ setDriverToConfig();
3057
+ var error = new Error('No available storage method found.');
3058
+ self._driverSet = Promise$1.reject(error);
3059
+ return self._driverSet;
3060
+ }
3061
+
3062
+ return driverPromiseLoop();
3063
+ };
3064
+ }
3065
+
3066
+ // There might be a driver initialization in progress
3067
+ // so wait for it to finish in order to avoid a possible
3068
+ // race condition to set _dbInfo
3069
+ var oldDriverSetDone = this._driverSet !== null ? this._driverSet["catch"](function () {
3070
+ return Promise$1.resolve();
3071
+ }) : Promise$1.resolve();
3072
+
3073
+ this._driverSet = oldDriverSetDone.then(function () {
3074
+ var driverName = supportedDrivers[0];
3075
+ self._dbInfo = null;
3076
+ self._ready = null;
3077
+
3078
+ return self.getDriver(driverName).then(function (driver) {
3079
+ self._driver = driver._driver;
3080
+ setDriverToConfig();
3081
+ self._wrapLibraryMethodsWithReady();
3082
+ self._initDriver = initDriver(supportedDrivers);
3083
+ });
3084
+ })["catch"](function () {
3085
+ setDriverToConfig();
3086
+ var error = new Error('No available storage method found.');
3087
+ self._driverSet = Promise$1.reject(error);
3088
+ return self._driverSet;
3089
+ });
3090
+
3091
+ executeTwoCallbacks(this._driverSet, callback, errorCallback);
3092
+ return this._driverSet;
3093
+ };
3094
+
3095
+ LocalForage.prototype.supports = function supports(driverName) {
3096
+ return !!DriverSupport[driverName];
3097
+ };
3098
+
3099
+ LocalForage.prototype._extend = function _extend(libraryMethodsAndProperties) {
3100
+ extend(this, libraryMethodsAndProperties);
3101
+ };
3102
+
3103
+ LocalForage.prototype._getSupportedDrivers = function _getSupportedDrivers(drivers) {
3104
+ var supportedDrivers = [];
3105
+ for (var i = 0, len = drivers.length; i < len; i++) {
3106
+ var driverName = drivers[i];
3107
+ if (this.supports(driverName)) {
3108
+ supportedDrivers.push(driverName);
3109
+ }
3110
+ }
3111
+ return supportedDrivers;
3112
+ };
3113
+
3114
+ LocalForage.prototype._wrapLibraryMethodsWithReady = function _wrapLibraryMethodsWithReady() {
3115
+ // Add a stub for each driver API method that delays the call to the
3116
+ // corresponding driver method until localForage is ready. These stubs
3117
+ // will be replaced by the driver methods as soon as the driver is
3118
+ // loaded, so there is no performance impact.
3119
+ for (var i = 0, len = LibraryMethods.length; i < len; i++) {
3120
+ callWhenReady(this, LibraryMethods[i]);
3121
+ }
3122
+ };
3123
+
3124
+ LocalForage.prototype.createInstance = function createInstance(options) {
3125
+ return new LocalForage(options);
3126
+ };
3127
+
3128
+ return LocalForage;
3129
+ }();
3130
+
3131
+ // The actual localForage object that we expose as a module or via a
3132
+ // global. It's extended by pulling in one of our other libraries.
3133
+
3134
+
3135
+ var localforage_js = new LocalForage();
3136
+
3137
+ module.exports = localforage_js;
3138
+
3139
+ },{"3":3}]},{},[4])(4)
3140
+ });
3141
+ });
3142
+
3143
+ const DEFAULT_DURATION = 60 * 1000; // 1 minute.
3144
+ const VERSION = 4;
347
3145
  class CacheControl {
348
3146
  constructor(id) {
349
- this.data = {};
3147
+ this._storageKeys = null;
3148
+ this.memory = new Map();
350
3149
  this.Disabled = false;
351
- this.cleanerInterval = null;
352
- // Max idle time to keep the cleaner alive.
353
- // This value is increased when a new item is added with a larger cache duration.
354
- this.maxCleanIdle = DEFAULT_MAX_CLEAN_IDLE;
3150
+ if (!id) {
3151
+ id = "default";
3152
+ }
3153
+ this.storage = localforage.createInstance({
3154
+ name: `v${VERSION}_${id}`,
3155
+ });
3156
+ }
3157
+ getStorageKeys() {
3158
+ return __awaiter(this, void 0, void 0, function* () {
3159
+ if (this._storageKeys == null) {
3160
+ this._storageKeys = yield this.storage.keys();
3161
+ }
3162
+ return this._storageKeys;
3163
+ });
355
3164
  }
356
3165
  /**
3166
+ * Sets item to cache.
357
3167
  * @param id
358
3168
  * @param data
359
- * @param duration seconds to keep the data in cache. -1 for infinite.
3169
+ * @param duration
360
3170
  */
361
- Set(id, data, duration = -1) {
362
- this.data[id + ""] = new CacheItem(id + "", data, duration);
363
- if (duration > -1) {
364
- this.startCleaning();
365
- if (this.maxCleanIdle < duration) {
366
- // Add 5 seconds to be sure cleaner stays alive to get it.
367
- this.maxCleanIdle = duration + 5;
3171
+ Set(params) {
3172
+ return __awaiter(this, void 0, void 0, function* () {
3173
+ if (this.Disabled) {
3174
+ return;
368
3175
  }
369
- }
3176
+ let { id, data, persistence, duration } = params;
3177
+ if (!duration || duration < 0) {
3178
+ duration = DEFAULT_DURATION;
3179
+ }
3180
+ id = String(id);
3181
+ this._storageKeys = null;
3182
+ const expires = Date.now() + duration;
3183
+ const record = {
3184
+ id,
3185
+ data,
3186
+ expires
3187
+ };
3188
+ if (persistence == "storage") {
3189
+ let putIntoStorage = true;
3190
+ // Cannot store promises, so will need to wait for them to resolve.
3191
+ if (data instanceof Promise) {
3192
+ // Store in memory until resolved, that way we can return the data if requested again.
3193
+ this.memory.set(id, record);
3194
+ try {
3195
+ data = yield data;
3196
+ record.data = data;
3197
+ }
3198
+ catch (e) {
3199
+ // If it failed then we keep it in memory so that requesting it will retain the promise exception.
3200
+ putIntoStorage = false;
3201
+ }
3202
+ }
3203
+ if (putIntoStorage) {
3204
+ yield this.storage.setItem(id, record);
3205
+ if (this.memory.has(id)) {
3206
+ this.memory.delete(id);
3207
+ }
3208
+ }
3209
+ }
3210
+ else {
3211
+ this.memory.set(id, record);
3212
+ yield this.storage.removeItem(id);
3213
+ }
3214
+ });
370
3215
  }
3216
+ /**
3217
+ * Returns the item with the given id.
3218
+ * @param id
3219
+ * @returns
3220
+ */
371
3221
  Get(id) {
372
- if (this.Disabled) {
373
- return null;
374
- }
375
- const item = this.data[id + ""];
376
- if (item == null) {
377
- return null;
378
- }
379
- if (item.IsExpired()) {
380
- delete this.data[id + ""];
381
- return null;
382
- }
383
- return item.Data;
3222
+ return __awaiter(this, void 0, void 0, function* () {
3223
+ if (this.Disabled) {
3224
+ return null;
3225
+ }
3226
+ id = String(id);
3227
+ // Prioritize memory over storage because it's faster to access.
3228
+ let record = this.memory.get(id);
3229
+ if (!record) {
3230
+ record = yield this.storage.getItem(id);
3231
+ }
3232
+ if (!record) {
3233
+ return {
3234
+ data: null,
3235
+ found: false
3236
+ };
3237
+ }
3238
+ if (record.expires < Date.now()) {
3239
+ if (this.memory.has(id)) {
3240
+ this.memory.delete(id);
3241
+ }
3242
+ yield this.storage.removeItem(id);
3243
+ return {
3244
+ data: null,
3245
+ found: false
3246
+ };
3247
+ }
3248
+ return {
3249
+ data: record.data,
3250
+ found: true
3251
+ };
3252
+ });
384
3253
  }
3254
+ /**
3255
+ * Removes all items from the cache.
3256
+ */
385
3257
  Clear() {
386
- this.data = {};
387
- this.stopCleaning();
3258
+ return __awaiter(this, void 0, void 0, function* () {
3259
+ this.memory.clear();
3260
+ yield this.storage.clear();
3261
+ this._storageKeys = null;
3262
+ });
388
3263
  }
3264
+ /**
3265
+ * Removes the item with the given id.
3266
+ * @param id
3267
+ */
389
3268
  Remove(id) {
390
- delete this.data[id + ""];
391
- if (Object.keys(this.data).length <= 0) {
392
- this.stopCleaning();
393
- }
3269
+ return __awaiter(this, void 0, void 0, function* () {
3270
+ id = String(id);
3271
+ this.memory.delete(id);
3272
+ yield this.storage.removeItem(id);
3273
+ this._storageKeys = null;
3274
+ });
394
3275
  }
395
- RemoveByStartsWith(text) {
396
- for (const key in this.data) {
397
- if (key.startsWith(text)) {
398
- delete this.data[key];
3276
+ /**
3277
+ * Removes all items that match the callback.
3278
+ * If callback returns true then the item is removed.
3279
+ * @param callback
3280
+ */
3281
+ RemoveBy(callback) {
3282
+ return __awaiter(this, void 0, void 0, function* () {
3283
+ const storageKeys = yield this.getStorageKeys();
3284
+ for (const key of storageKeys) {
3285
+ if (callback(key)) {
3286
+ yield this.storage.removeItem(key);
3287
+ }
399
3288
  }
400
- }
401
- if (Object.keys(this.data).length <= 0) {
402
- this.stopCleaning();
403
- }
404
- }
405
- RemoveByContains(text) {
406
- for (const key in this.data) {
407
- if (key.includes(text)) {
408
- delete this.data[key];
3289
+ const memoryKeys = Array.from(this.memory.keys());
3290
+ for (const key of memoryKeys) {
3291
+ if (callback(key)) {
3292
+ this.memory.delete(key);
3293
+ }
409
3294
  }
410
- }
411
- if (Object.keys(this.data).length <= 0) {
412
- this.stopCleaning();
413
- }
414
- }
415
- GetKeys() {
416
- if (this.Disabled) {
417
- return [];
418
- }
419
- return Object.keys(this.data);
3295
+ this._storageKeys = null;
3296
+ });
420
3297
  }
421
- GetValues() {
422
- if (this.Disabled) {
423
- return [];
424
- }
425
- const values = [];
426
- for (const key in this.data) {
427
- const data = this.Get(key);
428
- if (data != null) {
429
- values.push(data);
430
- }
431
- }
432
- return values;
433
- }
434
- startCleaning() {
435
- if (this.cleanerInterval == null) {
436
- let cleanIdleStart = null;
437
- this.cleanerInterval = setInterval(() => {
438
- let cleaned = 0;
439
- for (const key in this.data) {
440
- const item = this.data[key];
441
- if (item.IsExpired()) {
442
- delete this.data[key];
443
- cleaned += 1;
444
- }
445
- if (cleaned >= MAX_CLEAN_BATCH) {
446
- break;
447
- }
448
- }
449
- if (cleaned <= 0) {
450
- // Stop cleaner if nothing in cache.
451
- if (Object.keys(this.data).length <= 0) {
452
- this.stopCleaning();
453
- }
454
- // Stop cleaner if idle time is reached.
455
- else {
456
- if (cleanIdleStart == null) {
457
- cleanIdleStart = new Date().getTime();
458
- }
459
- const now = new Date().getTime();
460
- if (now - cleanIdleStart > this.maxCleanIdle * 1000) {
461
- this.stopCleaning();
462
- }
463
- }
464
- }
465
- else {
466
- cleanIdleStart = null;
467
- }
468
- }, CLEANER_INTERVAL);
469
- }
3298
+ /**
3299
+ * Removes all items that start with the given text.
3300
+ * @param text
3301
+ */
3302
+ RemoveByStartsWith(text) {
3303
+ return __awaiter(this, void 0, void 0, function* () {
3304
+ yield this.RemoveBy(key => String(key).startsWith(String(text)));
3305
+ });
470
3306
  }
471
- stopCleaning() {
472
- if (this.cleanerInterval != null) {
473
- clearInterval(this.cleanerInterval);
474
- this.cleanerInterval = null;
475
- this.maxCleanIdle = DEFAULT_MAX_CLEAN_IDLE;
476
- }
3307
+ /**
3308
+ * Removes all items that contain the given text.
3309
+ * @param text
3310
+ */
3311
+ RemoveByContains(text) {
3312
+ return __awaiter(this, void 0, void 0, function* () {
3313
+ yield this.RemoveBy(key => String(key).includes(String(text)));
3314
+ });
477
3315
  }
478
3316
  }
479
3317
 
@@ -566,7 +3404,12 @@
566
3404
  if (isNaN(duration)) {
567
3405
  duration = exports.Api.DEFAULT_CACHE_DURATION;
568
3406
  }
569
- yield this.Cache.Set(key, value, duration);
3407
+ yield this.Cache.Set({
3408
+ id: key,
3409
+ data: value,
3410
+ duration,
3411
+ persistence: "memory"
3412
+ });
570
3413
  });
571
3414
  }
572
3415
  GetSessionId() {
@@ -959,9 +3802,9 @@
959
3802
  function Get(params) {
960
3803
  return __awaiter(this, void 0, void 0, function* () {
961
3804
  const { api, accountId: id, req: reqParams } = params;
962
- const cacheData = yield api.GetCacheItem(GetCacheKey(id), reqParams);
963
- if (cacheData) {
964
- return cacheData;
3805
+ const cache = yield api.GetCacheItem(GetCacheKey(id), reqParams);
3806
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
3807
+ return cache.data;
965
3808
  }
966
3809
  const req = yield api.GET(`account/${id}`, reqParams);
967
3810
  const resData = {
@@ -979,9 +3822,9 @@
979
3822
  function GetRelatedList(params) {
980
3823
  return __awaiter(this, void 0, void 0, function* () {
981
3824
  const { api, req: reqParams } = params;
982
- const cacheData = yield api.GetCacheItem(GetListCacheKey(api.GetSessionId()), reqParams);
983
- if (cacheData) {
984
- return cacheData;
3825
+ const cache = yield api.GetCacheItem(GetListCacheKey(api.GetSessionId()), reqParams);
3826
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
3827
+ return cache.data;
985
3828
  }
986
3829
  const req = api.GET("user/relatedClientAccounts", reqParams);
987
3830
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
@@ -1008,9 +3851,9 @@
1008
3851
  function GetAppSettings(params) {
1009
3852
  return __awaiter(this, void 0, void 0, function* () {
1010
3853
  const { api, accountId: id, appId, req: reqParams } = params;
1011
- const cacheData = yield api.GetCacheItem(GetCacheKey(id, appId), reqParams);
1012
- if (cacheData) {
1013
- return cacheData;
3854
+ const cache = yield api.GetCacheItem(GetCacheKey(id, appId), reqParams);
3855
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
3856
+ return cache.data;
1014
3857
  }
1015
3858
  const req = yield api.GET(`account/${id}?ApplicationID=${appId}`, reqParams);
1016
3859
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
@@ -1965,9 +4808,9 @@
1965
4808
  throw ("Entity ID is required.");
1966
4809
  }
1967
4810
  const key = GetCacheKey(entityId, entityTypeId, expandLocation);
1968
- const cacheData = yield api.GetCacheItem(key, reqParams);
1969
- if (cacheData) {
1970
- return cacheData;
4811
+ const cache = yield api.GetCacheItem(key, reqParams);
4812
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
4813
+ return cache.data;
1971
4814
  }
1972
4815
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
1973
4816
  try {
@@ -2007,9 +4850,9 @@
2007
4850
  for (let i = 0; i < entityIds.length; i++) {
2008
4851
  const entityId = entityIds[i];
2009
4852
  const key = GetCacheKey(entityId);
2010
- const cacheData = yield api.GetCacheItem(key, reqParams);
2011
- if (cacheData) {
2012
- reqs.push(cacheData);
4853
+ const cache = yield api.GetCacheItem(key, reqParams);
4854
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
4855
+ reqs.push(cache.data);
2013
4856
  }
2014
4857
  else {
2015
4858
  reqIds.push(entityId);
@@ -3207,9 +6050,9 @@
3207
6050
  function GetList(params) {
3208
6051
  return __awaiter(this, void 0, void 0, function* () {
3209
6052
  const { api, reqParams } = params;
3210
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
3211
- if (cacheData) {
3212
- return cacheData;
6053
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
6054
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6055
+ return cache.data;
3213
6056
  }
3214
6057
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3215
6058
  try {
@@ -3300,9 +6143,9 @@
3300
6143
  if (!entityId) {
3301
6144
  throw ("Entity ID is required.");
3302
6145
  }
3303
- const cacheData = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
3304
- if (cacheData) {
3305
- return cacheData;
6146
+ const cache = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
6147
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6148
+ return cache.data;
3306
6149
  }
3307
6150
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3308
6151
  try {
@@ -3384,9 +6227,9 @@
3384
6227
  if (!entityId) {
3385
6228
  throw ("Entity ID is required.");
3386
6229
  }
3387
- const cacheData = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
3388
- if (cacheData) {
3389
- return cacheData;
6230
+ const cache = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
6231
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6232
+ return cache.data;
3390
6233
  }
3391
6234
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3392
6235
  try {
@@ -3453,9 +6296,9 @@
3453
6296
  if (!entityId) {
3454
6297
  throw ("Entity ID is required.");
3455
6298
  }
3456
- const cacheData = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
3457
- if (cacheData) {
3458
- return cacheData;
6299
+ const cache = yield api.GetCacheItem(GetListCacheKey(entityId), reqParams);
6300
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6301
+ return cache.data;
3459
6302
  }
3460
6303
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3461
6304
  try {
@@ -3518,9 +6361,9 @@
3518
6361
  if (!url) {
3519
6362
  throw ("Url is required.");
3520
6363
  }
3521
- const cacheData = yield api.GetCacheItem(GetCacheKey(url), reqParams);
3522
- if (cacheData) {
3523
- return cacheData;
6364
+ const cache = yield api.GetCacheItem(GetCacheKey(url), reqParams);
6365
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6366
+ return cache.data;
3524
6367
  }
3525
6368
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3526
6369
  try {
@@ -3562,9 +6405,9 @@
3562
6405
  if (!entityId) {
3563
6406
  throw ("Entity id is required.");
3564
6407
  }
3565
- const cacheData = yield api.GetCacheItem(GetEntityListKey(entityId), reqParams);
3566
- if (cacheData) {
3567
- return cacheData;
6408
+ const cache = yield api.GetCacheItem(GetEntityListKey(entityId), reqParams);
6409
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6410
+ return cache.data;
3568
6411
  }
3569
6412
  const req = api.GET(`entity/${entityId}/lods?includeClientFiles=yes`, exports.Api.PrepReqParams(reqParams));
3570
6413
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
@@ -3597,9 +6440,9 @@
3597
6440
  if (!group) {
3598
6441
  group = "DEFAULT";
3599
6442
  }
3600
- const cacheData = yield api.GetCacheItem(GetTypeListKey(typeId, group), reqParams);
3601
- if (cacheData) {
3602
- return cacheData;
6443
+ const cache = yield api.GetCacheItem(GetTypeListKey(typeId, group), reqParams);
6444
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6445
+ return cache.data;
3603
6446
  }
3604
6447
  const url = `entityType/${typeId}/lods?includeClientFiles=yes` + (group ? "&group=" + group : "");
3605
6448
  const req = api.GET(url, exports.Api.PrepReqParams(reqParams));
@@ -3669,9 +6512,9 @@
3669
6512
  function GetList(params) {
3670
6513
  return __awaiter(this, void 0, void 0, function* () {
3671
6514
  const { api, req: reqParams } = params;
3672
- const cacheKey = yield api.GetCacheItem(GetListCacheKey(), reqParams);
3673
- if (cacheKey) {
3674
- return cacheKey;
6515
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
6516
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6517
+ return cache.data;
3675
6518
  }
3676
6519
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3677
6520
  try {
@@ -3699,9 +6542,9 @@
3699
6542
  if (!id) {
3700
6543
  throw ("Lod category id is required.");
3701
6544
  }
3702
- const cacheData = yield api.GetCacheItem(GetCacheKey(id), reqParams);
3703
- if (cacheData) {
3704
- return cacheData;
6545
+ const cache = yield api.GetCacheItem(GetCacheKey(id), reqParams);
6546
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6547
+ return cache.data;
3705
6548
  }
3706
6549
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3707
6550
  try {
@@ -3768,9 +6611,9 @@
3768
6611
  throw ("Type ID is required.");
3769
6612
  }
3770
6613
  const key = GetCacheKey(typeId);
3771
- const cacheData = yield api.GetCacheItem(key, reqParams);
3772
- if (cacheData) {
3773
- return cacheData;
6614
+ const cache = yield api.GetCacheItem(key, reqParams);
6615
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6616
+ return cache.data;
3774
6617
  }
3775
6618
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3776
6619
  try {
@@ -3807,9 +6650,9 @@
3807
6650
  function GetList(params) {
3808
6651
  return __awaiter(this, void 0, void 0, function* () {
3809
6652
  const { api, req: reqParams } = params;
3810
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
3811
- if (cacheData) {
3812
- return cacheData;
6653
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
6654
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6655
+ return cache.data;
3813
6656
  }
3814
6657
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3815
6658
  try {
@@ -3929,9 +6772,9 @@
3929
6772
  throw ("Entity ID is required.");
3930
6773
  }
3931
6774
  filter = Object.assign({ relationTypeId: "", oneWayOnly: false, loadEntityData: false }, filter);
3932
- const cacheData = yield api.GetCacheItem(GetListCacheKey(entityId, filter), reqParams);
3933
- if (cacheData) {
3934
- return cacheData;
6775
+ const cache = yield api.GetCacheItem(GetListCacheKey(entityId, filter), reqParams);
6776
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6777
+ return cache.data;
3935
6778
  }
3936
6779
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3937
6780
  try {
@@ -3964,9 +6807,9 @@
3964
6807
  if (!entityId) {
3965
6808
  throw ("Entity ID is required.");
3966
6809
  }
3967
- const cacheData = yield api.GetCacheItem(GetEntityCacheKey(entityId), reqParams);
3968
- if (cacheData) {
3969
- return cacheData;
6810
+ const cache = yield api.GetCacheItem(GetEntityCacheKey(entityId), reqParams);
6811
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6812
+ return cache.data;
3970
6813
  }
3971
6814
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
3972
6815
  try {
@@ -4024,9 +6867,9 @@
4024
6867
  const reqs = [];
4025
6868
  for (let i = 0; i < sourceKeys.length; i++) {
4026
6869
  const sourceKey = sourceKeys[i];
4027
- const cacheData = yield api.GetCacheItem(GetCacheKey(sourceId, sourceKey), reqParams);
4028
- if (cacheData) {
4029
- reqs.push(cacheData);
6870
+ const cache = yield api.GetCacheItem(GetCacheKey(sourceId, sourceKey), reqParams);
6871
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6872
+ reqs.push(cache.data);
4030
6873
  }
4031
6874
  else {
4032
6875
  reqKeys.push(sourceKey);
@@ -4147,9 +6990,9 @@
4147
6990
  const reqs = [];
4148
6991
  for (let i = 0; i < tagIds.length; i++) {
4149
6992
  const tagId = tagIds[i];
4150
- const cacheData = yield api.GetCacheItem(GetCacheKey(tagId), reqParams);
4151
- if (cacheData) {
4152
- reqs.push(cacheData);
6993
+ const cache = yield api.GetCacheItem(GetCacheKey(tagId), reqParams);
6994
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
6995
+ reqs.push(cache.data);
4153
6996
  }
4154
6997
  else {
4155
6998
  reqIds.push(tagId);
@@ -4196,9 +7039,9 @@
4196
7039
  function GetList(params) {
4197
7040
  return __awaiter(this, void 0, void 0, function* () {
4198
7041
  const { api, entityTypeId, req: reqParams } = params;
4199
- const cacheData = yield api.GetCacheItem(GetListCacheKey(entityTypeId), reqParams);
4200
- if (cacheData) {
4201
- return cacheData;
7042
+ const cache = yield api.GetCacheItem(GetListCacheKey(entityTypeId), reqParams);
7043
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
7044
+ return cache.data;
4202
7045
  }
4203
7046
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
4204
7047
  try {
@@ -4263,9 +7106,9 @@
4263
7106
  throw ("Type ID is required.");
4264
7107
  }
4265
7108
  const key = GetCacheKey(typeId);
4266
- const cacheData = yield api.GetCacheItem(key, reqParams);
4267
- if (cacheData) {
4268
- return cacheData;
7109
+ const cache = yield api.GetCacheItem(key, reqParams);
7110
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
7111
+ return cache.data;
4269
7112
  }
4270
7113
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
4271
7114
  try {
@@ -4302,9 +7145,9 @@
4302
7145
  function GetList(params) {
4303
7146
  return __awaiter(this, void 0, void 0, function* () {
4304
7147
  const { api, req: reqParams } = params;
4305
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
4306
- if (cacheData) {
4307
- return cacheData;
7148
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
7149
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
7150
+ return cache.data;
4308
7151
  }
4309
7152
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
4310
7153
  try {
@@ -4909,9 +7752,9 @@
4909
7752
  function GetEntityCoords(params) {
4910
7753
  return __awaiter(this, void 0, void 0, function* () {
4911
7754
  const { api, rootEntityId: entityId, req: reqParams } = params;
4912
- const cacheData = yield api.GetCacheItem(GetCacheKey(entityId), reqParams);
4913
- if (cacheData) {
4914
- return cacheData;
7755
+ const cache = yield api.GetCacheItem(GetCacheKey(entityId), reqParams);
7756
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
7757
+ return cache.data;
4915
7758
  }
4916
7759
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
4917
7760
  try {
@@ -5159,9 +8002,9 @@
5159
8002
  throw ("File ID is required.");
5160
8003
  }
5161
8004
  const key = GetCacheKey(fileId);
5162
- const cacheData = yield api.GetCacheItem(key, reqParams);
5163
- if (cacheData) {
5164
- return cacheData;
8005
+ const cache = yield api.GetCacheItem(key, reqParams);
8006
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8007
+ return cache.data;
5165
8008
  }
5166
8009
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5167
8010
  try {
@@ -5397,9 +8240,9 @@
5397
8240
  throw ("Program ID is required.");
5398
8241
  }
5399
8242
  const key = GetCacheKey(programId);
5400
- const cacheData = yield api.GetCacheItem(key, reqParams);
5401
- if (cacheData) {
5402
- return cacheData;
8243
+ const cache = yield api.GetCacheItem(key, reqParams);
8244
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8245
+ return cache.data;
5403
8246
  }
5404
8247
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5405
8248
  try {
@@ -5424,9 +8267,9 @@
5424
8267
  function GetList(params) {
5425
8268
  return __awaiter(this, void 0, void 0, function* () {
5426
8269
  const { api, req: reqParams } = params;
5427
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
5428
- if (cacheData) {
5429
- return cacheData;
8270
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
8271
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8272
+ return cache.data;
5430
8273
  }
5431
8274
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5432
8275
  try {
@@ -5527,9 +8370,9 @@
5527
8370
  if (!tilesetId) {
5528
8371
  throw ("Tileset ID is required.");
5529
8372
  }
5530
- const cacheData = yield api.GetCacheItem(GetCacheKey(tilesetId, loadFiles), reqParams);
5531
- if (cacheData) {
5532
- return cacheData;
8373
+ const cache = yield api.GetCacheItem(GetCacheKey(tilesetId, loadFiles), reqParams);
8374
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8375
+ return cache.data;
5533
8376
  }
5534
8377
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5535
8378
  try {
@@ -5585,9 +8428,9 @@
5585
8428
  function GetList(params) {
5586
8429
  return __awaiter(this, void 0, void 0, function* () {
5587
8430
  const { api, req: reqParams } = params;
5588
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
5589
- if (cacheData) {
5590
- return cacheData;
8431
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
8432
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8433
+ return cache.data;
5591
8434
  }
5592
8435
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5593
8436
  try {
@@ -5824,9 +8667,9 @@
5824
8667
  if (!accountId || !tilesetId) {
5825
8668
  throw ("Client account ID and tileset ID are required.");
5826
8669
  }
5827
- const cacheData = yield api.GetCacheItem(GetCacheKey(accountId, tilesetId), reqParams);
5828
- if (cacheData) {
5829
- return cacheData;
8670
+ const cache = yield api.GetCacheItem(GetCacheKey(accountId, tilesetId), reqParams);
8671
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8672
+ return cache.data;
5830
8673
  }
5831
8674
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5832
8675
  try {
@@ -5854,9 +8697,9 @@
5854
8697
  if (!accountId) {
5855
8698
  throw ("Client account ID is required.");
5856
8699
  }
5857
- const cacheData = yield api.GetCacheItem(GetCacheKey(accountId), reqParams);
5858
- if (cacheData) {
5859
- return cacheData;
8700
+ const cache = yield api.GetCacheItem(GetCacheKey(accountId), reqParams);
8701
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8702
+ return cache.data;
5860
8703
  }
5861
8704
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
5862
8705
  try {
@@ -6035,9 +8878,9 @@
6035
8878
  throw ("View ID and Bookmark ID are required.");
6036
8879
  }
6037
8880
  const key = GetCacheKey(viewId, bookmarkId);
6038
- const cacheData = yield api.GetCacheItem(key, reqParams);
6039
- if (cacheData) {
6040
- return cacheData;
8881
+ const cache = yield api.GetCacheItem(key, reqParams);
8882
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8883
+ return cache.data;
6041
8884
  }
6042
8885
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6043
8886
  try {
@@ -6077,9 +8920,9 @@
6077
8920
  if (!viewId) {
6078
8921
  throw ("View ID is required.");
6079
8922
  }
6080
- const cacheData = yield api.GetCacheItem(GetListCacheKey(viewId), reqParams);
6081
- if (cacheData) {
6082
- return cacheData;
8923
+ const cache = yield api.GetCacheItem(GetListCacheKey(viewId), reqParams);
8924
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
8925
+ return cache.data;
6083
8926
  }
6084
8927
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6085
8928
  try {
@@ -6174,9 +9017,9 @@
6174
9017
  throw ("View ID is required.");
6175
9018
  }
6176
9019
  const key = GetCacheKey(viewId);
6177
- const cacheData = yield api.GetCacheItem(key, reqParams);
6178
- if (cacheData) {
6179
- return cacheData;
9020
+ const cache = yield api.GetCacheItem(key, reqParams);
9021
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9022
+ return cache.data;
6180
9023
  }
6181
9024
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6182
9025
  try {
@@ -6201,9 +9044,9 @@
6201
9044
  function GetList(params) {
6202
9045
  return __awaiter(this, void 0, void 0, function* () {
6203
9046
  const { api, req: reqParams } = params;
6204
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
6205
- if (cacheData) {
6206
- return cacheData;
9047
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
9048
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9049
+ return cache.data;
6207
9050
  }
6208
9051
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6209
9052
  try {
@@ -6537,9 +9380,9 @@
6537
9380
  function GetList(params) {
6538
9381
  return __awaiter(this, void 0, void 0, function* () {
6539
9382
  const { api, req: reqParams } = params;
6540
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), reqParams);
6541
- if (cacheData) {
6542
- return cacheData;
9383
+ const cache = yield api.GetCacheItem(GetListCacheKey(), reqParams);
9384
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9385
+ return cache.data;
6543
9386
  }
6544
9387
  const res = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6545
9388
  try {
@@ -6567,9 +9410,9 @@
6567
9410
  if (!id) {
6568
9411
  throw ("Style ID is required.");
6569
9412
  }
6570
- const cacheData = yield api.GetCacheItem(GetCacheKey(id), reqParams);
6571
- if (cacheData) {
6572
- return cacheData;
9413
+ const cache = yield api.GetCacheItem(GetCacheKey(id), reqParams);
9414
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9415
+ return cache.data;
6573
9416
  }
6574
9417
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6575
9418
  try {
@@ -6651,9 +9494,9 @@
6651
9494
  throw ("Session ID is required.");
6652
9495
  }
6653
9496
  const key = GetCacheKey(sessionId);
6654
- const cacheData = yield api.GetCacheItem(key, reqParams);
6655
- if (cacheData) {
6656
- return cacheData;
9497
+ const cache = yield api.GetCacheItem(key, reqParams);
9498
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9499
+ return cache.data;
6657
9500
  }
6658
9501
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6659
9502
  try {
@@ -6669,7 +9512,8 @@
6669
9512
  yield api.SetCacheItem({
6670
9513
  key,
6671
9514
  value: prom,
6672
- req: reqParams
9515
+ req: reqParams,
9516
+ duration: 5000
6673
9517
  });
6674
9518
  return prom;
6675
9519
  });
@@ -6870,9 +9714,9 @@
6870
9714
  if (!id) {
6871
9715
  throw ("ID is required.");
6872
9716
  }
6873
- const cacheData = yield api.GetCacheItem(GetCacheKey(id, accountId), reqParams);
6874
- if (cacheData) {
6875
- return cacheData;
9717
+ const cache = yield api.GetCacheItem(GetCacheKey(id, accountId), reqParams);
9718
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9719
+ return cache.data;
6876
9720
  }
6877
9721
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6878
9722
  try {
@@ -6939,9 +9783,9 @@
6939
9783
  if (!userId || !appId) {
6940
9784
  throw ("UserId and appId are required.");
6941
9785
  }
6942
- const cacheData = yield api.GetCacheItem(GetSettingsCacheKey(userId, appId), req);
6943
- if (cacheData) {
6944
- return cacheData;
9786
+ const cache = yield api.GetCacheItem(GetSettingsCacheKey(userId, appId), req);
9787
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9788
+ return cache.data;
6945
9789
  }
6946
9790
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
6947
9791
  try {
@@ -7031,9 +9875,9 @@
7031
9875
  if (!email) {
7032
9876
  throw ("Email is required.");
7033
9877
  }
7034
- const cacheData = yield api.GetCacheItem(GetEmailCacheKey(email, accountId), reqParams);
7035
- if (cacheData) {
7036
- return cacheData;
9878
+ const cache = yield api.GetCacheItem(GetEmailCacheKey(email, accountId), reqParams);
9879
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9880
+ return cache.data;
7037
9881
  }
7038
9882
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7039
9883
  try {
@@ -7064,9 +9908,9 @@
7064
9908
  if (!exclusive) {
7065
9909
  exclusive = false;
7066
9910
  }
7067
- const cacheData = exclusive ? null : yield api.GetCacheItem(GetListCacheKey(accountId), reqParams);
7068
- if (cacheData) {
7069
- return cacheData;
9911
+ const cache = exclusive ? null : yield api.GetCacheItem(GetListCacheKey(accountId), reqParams);
9912
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
9913
+ return cache.data;
7070
9914
  }
7071
9915
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7072
9916
  try {
@@ -7226,9 +10070,9 @@
7226
10070
  function GetList(params) {
7227
10071
  return __awaiter(this, void 0, void 0, function* () {
7228
10072
  const { api, accountId, req: reqParams } = params;
7229
- const cacheData = yield api.GetCacheItem(GetListCacheKey(accountId), reqParams);
7230
- if (cacheData) {
7231
- return cacheData;
10073
+ const cache = yield api.GetCacheItem(GetListCacheKey(accountId), reqParams);
10074
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10075
+ return cache.data;
7232
10076
  }
7233
10077
  const req = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7234
10078
  try {
@@ -7598,9 +10442,9 @@
7598
10442
  if (!pageIndex) {
7599
10443
  pageIndex = 0;
7600
10444
  }
7601
- const cacheData = yield api.GetCacheItem(GetListCacheKey(type, pageIndex), reqParams);
7602
- if (cacheData) {
7603
- return cacheData;
10445
+ const cache = yield api.GetCacheItem(GetListCacheKey(type, pageIndex), reqParams);
10446
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10447
+ return cache.data;
7604
10448
  }
7605
10449
  let first = true;
7606
10450
  let url = "entityImportFiles";
@@ -7635,9 +10479,9 @@
7635
10479
  function GetListByRootId(params) {
7636
10480
  return __awaiter(this, void 0, void 0, function* () {
7637
10481
  const { api, rootId, req: reqParams } = params;
7638
- const cacheData = yield api.GetCacheItem(GetCacheKeyByRootId(rootId), reqParams);
7639
- if (cacheData) {
7640
- return cacheData;
10482
+ const cache = yield api.GetCacheItem(GetCacheKeyByRootId(rootId), reqParams);
10483
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10484
+ return cache.data;
7641
10485
  }
7642
10486
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7643
10487
  try {
@@ -7662,9 +10506,9 @@
7662
10506
  function Get(params) {
7663
10507
  return __awaiter(this, void 0, void 0, function* () {
7664
10508
  const { api, importedFileId: fileId, req: reqParams } = params;
7665
- const cacheData = yield api.GetCacheItem(GetCacheKey(fileId), reqParams);
7666
- if (cacheData) {
7667
- return cacheData;
10509
+ const cache = yield api.GetCacheItem(GetCacheKey(fileId), reqParams);
10510
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10511
+ return cache.data;
7668
10512
  }
7669
10513
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7670
10514
  try {
@@ -7885,9 +10729,9 @@
7885
10729
  if (!pluginId) {
7886
10730
  throw ("Plugin ID is required.");
7887
10731
  }
7888
- const cacheData = yield api.GetCacheItem(GetCacheKey(pluginId), req);
7889
- if (cacheData) {
7890
- return cacheData;
10732
+ const cache = yield api.GetCacheItem(GetCacheKey(pluginId), req);
10733
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10734
+ return cache.data;
7891
10735
  }
7892
10736
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7893
10737
  try {
@@ -7912,9 +10756,9 @@
7912
10756
  function GetList(params) {
7913
10757
  return __awaiter(this, void 0, void 0, function* () {
7914
10758
  const { api, req } = params;
7915
- const cacheData = yield api.GetCacheItem(GetListCacheKey(), req);
7916
- if (cacheData) {
7917
- return cacheData;
10759
+ const cache = yield api.GetCacheItem(GetListCacheKey(), req);
10760
+ if (cache === null || cache === void 0 ? void 0 : cache.found) {
10761
+ return cache.data;
7918
10762
  }
7919
10763
  const prom = new Promise((res, rej) => __awaiter(this, void 0, void 0, function* () {
7920
10764
  try {