@ngxs/storage-plugin 3.7.5-dev.master-66b90a9 → 3.7.5-dev.master-7ca104f

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 (38) hide show
  1. package/bundles/ngxs-storage-plugin.umd.js +162 -66
  2. package/bundles/ngxs-storage-plugin.umd.js.map +1 -1
  3. package/bundles/ngxs-storage-plugin.umd.min.js +1 -1
  4. package/bundles/ngxs-storage-plugin.umd.min.js.map +1 -1
  5. package/esm2015/index.js +2 -2
  6. package/esm2015/ngxs-storage-plugin.js +4 -3
  7. package/esm2015/src/engines.js +22 -0
  8. package/esm2015/src/internals/final-options.js +42 -0
  9. package/esm2015/src/internals/storage-key.js +47 -0
  10. package/esm2015/src/internals.js +13 -35
  11. package/esm2015/src/public_api.js +2 -1
  12. package/esm2015/src/storage.module.js +9 -3
  13. package/esm2015/src/storage.plugin.js +24 -30
  14. package/esm2015/src/symbols.js +9 -2
  15. package/esm5/index.js +2 -2
  16. package/esm5/ngxs-storage-plugin.js +4 -3
  17. package/esm5/src/engines.js +22 -0
  18. package/esm5/src/internals/final-options.js +43 -0
  19. package/esm5/src/internals/storage-key.js +47 -0
  20. package/esm5/src/internals.js +13 -35
  21. package/esm5/src/public_api.js +2 -1
  22. package/esm5/src/storage.module.js +9 -3
  23. package/esm5/src/storage.plugin.js +28 -33
  24. package/esm5/src/symbols.js +9 -2
  25. package/fesm2015/ngxs-storage-plugin.js +154 -63
  26. package/fesm2015/ngxs-storage-plugin.js.map +1 -1
  27. package/fesm5/ngxs-storage-plugin.js +158 -66
  28. package/fesm5/ngxs-storage-plugin.js.map +1 -1
  29. package/ngxs-storage-plugin.d.ts +2 -1
  30. package/ngxs-storage-plugin.metadata.json +1 -1
  31. package/package.json +1 -1
  32. package/src/engines.d.ts +4 -0
  33. package/src/internals/final-options.d.ts +10 -0
  34. package/src/internals/storage-key.d.ts +17 -0
  35. package/src/internals.d.ts +3 -9
  36. package/src/public_api.d.ts +1 -0
  37. package/src/storage.plugin.d.ts +3 -4
  38. package/src/symbols.d.ts +9 -3
@@ -7,18 +7,15 @@ import { PLATFORM_ID, Inject, Injectable } from '@angular/core';
7
7
  import { isPlatformServer } from '@angular/common';
8
8
  import { setValue, getValue, InitState, UpdateState, actionMatcher } from '@ngxs/store';
9
9
  import { tap } from 'rxjs/operators';
10
- import { STORAGE_ENGINE, NGXS_STORAGE_PLUGIN_OPTIONS } from './symbols';
11
- import { DEFAULT_STATE_KEY } from './internals';
10
+ import { DEFAULT_STATE_KEY, getStorageKey } from './internals';
11
+ import { FINAL_NGXS_STORAGE_PLUGIN_OPTIONS } from './internals/final-options';
12
12
  var NgxsStoragePlugin = /** @class */ (function () {
13
- function NgxsStoragePlugin(_options, _engine, _platformId) {
13
+ function NgxsStoragePlugin(_options, _platformId) {
14
14
  this._options = _options;
15
- this._engine = _engine;
16
15
  this._platformId = _platformId;
17
- // We cast to `string[]` here as we're sure that this option has been
18
- // transformed by the `storageOptionsFactory` function that provided token.
19
- this._keys = (/** @type {?} */ (this._options.key));
16
+ this._keysWithEngines = this._options.keysWithEngines;
20
17
  // We default to `[DEFAULT_STATE_KEY]` if the user explicitly does not provide the `key` option.
21
- this._usesDefaultStateKey = this._keys.length === 1 && this._keys[0] === DEFAULT_STATE_KEY;
18
+ this._usesDefaultStateKey = this._keysWithEngines.length === 1 && this._keysWithEngines[0].key === DEFAULT_STATE_KEY;
22
19
  }
23
20
  /**
24
21
  * @param {?} state
@@ -35,7 +32,7 @@ var NgxsStoragePlugin = /** @class */ (function () {
35
32
  function (state, event, next) {
36
33
  var _this = this;
37
34
  var e_1, _a;
38
- if (isPlatformServer(this._platformId) && this._engine === null) {
35
+ if (isPlatformServer(this._platformId)) {
39
36
  return next(state, event);
40
37
  }
41
38
  /** @type {?} */
@@ -51,7 +48,7 @@ var NgxsStoragePlugin = /** @class */ (function () {
51
48
  if (isInitOrUpdateAction) {
52
49
  /** @type {?} */
53
50
  var addedStates = isUpdateAction && event.addedStates;
54
- var _loop_1 = function (key) {
51
+ var _loop_1 = function (key, engine) {
55
52
  // We're checking what states have been added by NGXS and if any of these states should be handled by
56
53
  // the storage plugin. For instance, we only want to deserialize the `auth` state, NGXS has added
57
54
  // the `user` state, the storage plugin will be rerun and will do redundant deserialization.
@@ -71,7 +68,9 @@ var NgxsStoragePlugin = /** @class */ (function () {
71
68
  }
72
69
  }
73
70
  /** @type {?} */
74
- var storedValue = this_1._engine.getItem((/** @type {?} */ (key)));
71
+ var storageKey = getStorageKey(key, this_1._options);
72
+ /** @type {?} */
73
+ var storedValue = engine.getItem(storageKey);
75
74
  if (storedValue !== 'undefined' && storedValue != null) {
76
75
  try {
77
76
  /** @type {?} */
@@ -82,7 +81,7 @@ var NgxsStoragePlugin = /** @class */ (function () {
82
81
  // Caretaker note: we have still left the `typeof` condition in order to avoid
83
82
  // creating a breaking change for projects that still use the View Engine.
84
83
  if (typeof ngDevMode === 'undefined' || ngDevMode) {
85
- console.error("Error ocurred while deserializing the " + key + " store value, falling back to empty object, the value obtained from the store: ", storedValue);
84
+ console.error("Error ocurred while deserializing the " + storageKey + " store value, falling back to empty object, the value obtained from the store: ", storedValue);
86
85
  }
87
86
  storedValue = {};
88
87
  }
@@ -103,7 +102,7 @@ var NgxsStoragePlugin = /** @class */ (function () {
103
102
  }));
104
103
  }
105
104
  if (!this_1._usesDefaultStateKey) {
106
- state = setValue(state, (/** @type {?} */ (key)), storedValue);
105
+ state = setValue(state, key, storedValue);
107
106
  }
108
107
  else {
109
108
  // The `UpdateState` action is dispatched whenever the feature state is added.
@@ -141,9 +140,9 @@ var NgxsStoragePlugin = /** @class */ (function () {
141
140
  };
142
141
  var this_1 = this;
143
142
  try {
144
- for (var _b = tslib_1.__values(this._keys), _c = _b.next(); !_c.done; _c = _b.next()) {
145
- var key = _c.value;
146
- _loop_1(key);
143
+ for (var _b = tslib_1.__values(this._keysWithEngines), _c = _b.next(); !_c.done; _c = _b.next()) {
144
+ var _d = _c.value, key = _d.key, engine = _d.engine;
145
+ _loop_1(key, engine);
147
146
  }
148
147
  }
149
148
  catch (e_1_1) { e_1 = { error: e_1_1 }; }
@@ -162,17 +161,19 @@ var NgxsStoragePlugin = /** @class */ (function () {
162
161
  var e_2, _a;
163
162
  if (!isInitOrUpdateAction || (isInitOrUpdateAction && hasMigration)) {
164
163
  try {
165
- for (var _b = tslib_1.__values(_this._keys), _c = _b.next(); !_c.done; _c = _b.next()) {
166
- var key = _c.value;
164
+ for (var _b = tslib_1.__values(_this._keysWithEngines), _c = _b.next(); !_c.done; _c = _b.next()) {
165
+ var _d = _c.value, key = _d.key, engine = _d.engine;
166
+ /** @type {?} */
167
+ var storedValue = nextState;
167
168
  /** @type {?} */
168
- var val = nextState;
169
+ var storageKey = getStorageKey(key, _this._options);
169
170
  if (key !== DEFAULT_STATE_KEY) {
170
- val = getValue(nextState, (/** @type {?} */ (key)));
171
+ storedValue = getValue(nextState, key);
171
172
  }
172
173
  try {
173
174
  /** @type {?} */
174
- var newVal = (/** @type {?} */ (_this._options.beforeSerialize))(val, key);
175
- _this._engine.setItem((/** @type {?} */ (key)), (/** @type {?} */ (_this._options.serialize))(newVal));
175
+ var newStoredValue = (/** @type {?} */ (_this._options.beforeSerialize))(storedValue, key);
176
+ engine.setItem(storageKey, (/** @type {?} */ (_this._options.serialize))(newStoredValue));
176
177
  }
177
178
  catch (error) {
178
179
  // Caretaker note: we have still left the `typeof` condition in order to avoid
@@ -181,10 +182,10 @@ var NgxsStoragePlugin = /** @class */ (function () {
181
182
  if (error &&
182
183
  (error.name === 'QuotaExceededError' ||
183
184
  error.name === 'NS_ERROR_DOM_QUOTA_REACHED')) {
184
- console.error("The " + key + " store value exceeds the browser storage quota: ", val);
185
+ console.error("The " + storageKey + " store value exceeds the browser storage quota: ", storedValue);
185
186
  }
186
187
  else {
187
- console.error("Error ocurred while serializing the " + key + " store value, value not updated, the value obtained from the store: ", val);
188
+ console.error("Error ocurred while serializing the " + storageKey + " store value, value not updated, the value obtained from the store: ", storedValue);
188
189
  }
189
190
  }
190
191
  }
@@ -205,8 +206,7 @@ var NgxsStoragePlugin = /** @class */ (function () {
205
206
  ];
206
207
  /** @nocollapse */
207
208
  NgxsStoragePlugin.ctorParameters = function () { return [
208
- { type: undefined, decorators: [{ type: Inject, args: [NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
209
- { type: undefined, decorators: [{ type: Inject, args: [STORAGE_ENGINE,] }] },
209
+ { type: undefined, decorators: [{ type: Inject, args: [FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
210
210
  { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
211
211
  ]; };
212
212
  return NgxsStoragePlugin;
@@ -217,7 +217,7 @@ if (false) {
217
217
  * @type {?}
218
218
  * @private
219
219
  */
220
- NgxsStoragePlugin.prototype._keys;
220
+ NgxsStoragePlugin.prototype._keysWithEngines;
221
221
  /**
222
222
  * @type {?}
223
223
  * @private
@@ -228,11 +228,6 @@ if (false) {
228
228
  * @private
229
229
  */
230
230
  NgxsStoragePlugin.prototype._options;
231
- /**
232
- * @type {?}
233
- * @private
234
- */
235
- NgxsStoragePlugin.prototype._engine;
236
231
  /**
237
232
  * @type {?}
238
233
  * @private
@@ -241,4 +236,4 @@ if (false) {
241
236
  }
242
237
  /** @type {?} */
243
238
  var DOT = '.';
244
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5wbHVnaW4uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Abmd4cy9zdG9yYWdlLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zdG9yYWdlLnBsdWdpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRCxPQUFPLEVBRUwsUUFBUSxFQUNSLFFBQVEsRUFDUixTQUFTLEVBQ1QsV0FBVyxFQUNYLGFBQWEsRUFFZCxNQUFNLGFBQWEsQ0FBQztBQUNyQixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUdMLGNBQWMsRUFDZCwyQkFBMkIsRUFDNUIsTUFBTSxXQUFXLENBQUM7QUFDbkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBUWhEO0lBU0UsMkJBQytDLFFBQWtDLEVBQy9DLE9BQXNCLEVBQ3pCLFdBQW1CO1FBRkgsYUFBUSxHQUFSLFFBQVEsQ0FBMEI7UUFDL0MsWUFBTyxHQUFQLE9BQU8sQ0FBZTtRQUN6QixnQkFBVyxHQUFYLFdBQVcsQ0FBUTs7O1FBUjFDLFVBQUssR0FBRyxtQkFBQSxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBWSxDQUFDOztRQUV0Qyx5QkFBb0IsR0FDMUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssaUJBQWlCLENBQUM7SUFNOUQsQ0FBQzs7Ozs7OztJQUVKLGtDQUFNOzs7Ozs7SUFBTixVQUFPLEtBQVUsRUFBRSxLQUFVLEVBQUUsSUFBc0I7UUFBckQsaUJBdUlDOztRQXRJQyxJQUFJLGdCQUFnQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxJQUFJ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QUN0RCx3Q0FBZ0Q7OztJQTZJOUMsR0FBRyxHQUFHLEdBQUciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQTEFURk9STV9JRCwgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBsYWluT2JqZWN0IH0gZnJvbSAnQG5neHMvc3RvcmUvaW50ZXJuYWxzJztcbmltcG9ydCB7XG4gIE5neHNQbHVnaW4sXG4gIHNldFZhbHVlLFxuICBnZXRWYWx1ZSxcbiAgSW5pdFN0YXRlLFxuICBVcGRhdGVTdGF0ZSxcbiAgYWN0aW9uTWF0Y2hlcixcbiAgTmd4c05leHRQbHVnaW5GblxufSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7XG4gIFN0b3JhZ2VFbmdpbmUsXG4gIE5neHNTdG9yYWdlUGx1Z2luT3B0aW9ucyxcbiAgU1RPUkFHRV9FTkdJTkUsXG4gIE5HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OU1xufSBmcm9tICcuL3N5bWJvbHMnO1xuaW1wb3J0IHsgREVGQVVMVF9TVEFURV9LRVkgfSBmcm9tICcuL2ludGVybmFscyc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFdpbGwgYmUgcHJvdmlkZWQgdGhyb3VnaCBUZXJzZXIgZ2xvYmFsIGRlZmluaXRpb25zIGJ5IEFuZ3VsYXIgQ0xJXG4gKiBkdXJpbmcgdGhlIHByb2R1Y3Rpb24gYnVpbGQuIFRoaXMgaXMgaG93IEFuZ3VsYXIgZG9lcyB0cmVlLXNoYWtpbmcgaW50ZXJuYWxseS5cbiAqL1xuZGVjbGFyZSBjb25zdCBuZ0Rldk1vZGU6IGJvb2xlYW47XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBOZ3hzU3RvcmFnZVBsdWdpbiBpbXBsZW1lbnRzIE5neHNQbHVnaW4ge1xuICAvLyBXZSBjYXN0IHRvIGBzdHJpbmdbXWAgaGVyZSBhcyB3ZSdyZSBzdXJlIHRoYXQgdGhpcyBvcHRpb24gaGFzIGJlZW5cbiAgLy8gdHJhbnNmb3JtZWQgYnkgdGhlIGBzdG9yYWdlT3B0aW9uc0ZhY3RvcnlgIGZ1bmN0aW9uIHRoYXQgcHJvdmlkZWQgdG9rZW4uXG4gIHByaXZhdGUgX2tleXMgPSB0aGlzLl9vcHRpb25zLmtleSBhcyBzdHJpbmdbXTtcbiAgLy8gV2UgZGVmYXVsdCB0byBgW0RFRkFVTFRfU1RBVEVfS0VZXWAgaWYgdGhlIHVzZXIgZXhwbGljaXRseSBkb2VzIG5vdCBwcm92aWRlIHRoZSBga2V5YCBvcHRpb24uXG4gIHByaXZhdGUgX3VzZXNEZWZhdWx0U3RhdGVLZXkgPVxuICAgIHRoaXMuX2tleXMubGVuZ3RoID09PSAxICYmIHRoaXMuX2tleXNbMF0gPT09IERFRkFVTFRfU1RBVEVfS0VZO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoTkdYU19TVE9SQUdFX1BMVUdJTl9PUFRJT05TKSBwcml2YXRlIF9vcHRpb25zOiBOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMsXG4gICAgQEluamVjdChTVE9SQUdFX0VOR0lORSkgcHJpdmF0ZSBfZW5naW5lOiBTdG9yYWdlRW5naW5lLFxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpIHByaXZhdGUgX3BsYXRmb3JtSWQ6IHN0cmluZ1xuICApIHt9XG5cbiAgaGFuZGxlKHN0YXRlOiBhbnksIGV2ZW50OiBhbnksIG5leHQ6IE5neHNOZXh0UGx1Z2luRm4pIHtcbiAgICBpZiAoaXNQbGF0Zm9ybVNlcnZlcih0aGlzLl9wbGF0Zm9ybUlkKSAmJiB0aGlzLl9lbmdpbmUgPT09IG51bGwpIHtcbiAgICAgIHJldHVybiBuZXh0KHN0YXRlLCBldmVudCk7XG4gICAgfVxuXG4gICAgY29uc3QgbWF0Y2hlcyA9IGFjdGlvbk1hdGNoZXIoZXZlbnQpO1xuICAgIGNvbnN0IGlzSW5pdEFjdGlvbiA9IG1hdGNoZXMoSW5pdFN0YXRlKTtcbiAgICBjb25zdCBpc1VwZGF0ZUFjdGlvbiA9IG1hdGNoZXMoVXBkYXRlU3RhdGUpO1xuICAgIGNvbnN0IGlzSW5pdE9yVXBkYXRlQWN0aW9uID0gaXNJbml0QWN0aW9uIHx8IGlzVXBkYXRlQWN0aW9uO1xuICAgIGxldCBoYXNNaWdyYXRpb24gPSBmYWxzZTtcblxuICAgIGlmIChpc0luaXRPclVwZGF0ZUFjdGlvbikge1xuICAgICAgY29uc3QgYWRkZWRTdGF0ZXMgPSBpc1VwZGF0ZUFjdGlvbiAmJiBldmVudC5hZGRlZFN0YXRlcztcblxuICAgICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5fa2V5cykge1xuICAgICAgICAvLyBXZSdyZSBjaGVja2luZyB3aGF0IHN0YXRlcyBoYXZlIGJlZW4gYWRkZWQgYnkgTkdYUyBhbmQgaWYgYW55IG9mIHRoZXNlIHN0YXRlcyBzaG91bGQgYmUgaGFuZGxlZCBieVxuICAgICAgICAvLyB0aGUgc3RvcmFnZSBwbHVnaW4uIEZvciBpbnN0YW5jZSwgd2Ugb25seSB3YW50IHRvIGRlc2VyaWFsaXplIHRoZSBgYXV0aGAgc3RhdGUsIE5HWFMgaGFzIGFkZGVkXG4gICAgICAgIC8vIHRoZSBgdXNlcmAgc3RhdGUsIHRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIGJlIHJlcnVuIGFuZCB3aWxsIGRvIHJlZHVuZGFudCBkZXNlcmlhbGl6YXRpb24uXG4gICAgICAgIC8vIGB1c2VzRGVmYXVsdFN0YXRlS2V5YCBpcyBuZWNlc3NhcnkgdG8gY2hlY2sgc2luY2UgYGV2ZW50LmFkZGVkU3RhdGVzYCBuZXZlciBjb250YWlucyBgQEBTVEFURWAuXG4gICAgICAgIGlmICghdGhpcy5fdXNlc0RlZmF1bHRTdGF0ZUtleSAmJiBhZGRlZFN0YXRlcykge1xuICAgICAgICAgIC8vIFdlIHN1cHBvcnQgcHJvdmlkaW5nIGtleXMgdGhhdCBjYW4gYmUgZGVlcGx5IG5lc3RlZCB2aWEgZG90IG5vdGF0aW9uLCBmb3IgaW5zdGFuY2UsXG4gICAgICAgICAgLy8gYGtleXM6IFsnbXlTdGF0ZS5teVByb3BlcnR5J11gIGlzIGEgdmFsaWQga2V5LlxuICAgICAgICAgIC8vIFRoZSBzdGF0ZSBuYW1lIHNob3VsZCBhbHdheXMgZ28gZmlyc3QuIFRoZSBiZWxvdyBjb2RlIGNoZWNrcyBpZiB0aGUgYGtleWAgaW5jbHVkZXMgZG90XG4gICAgICAgICAgLy8gbm90YXRpb24gYW5kIGV4dHJhY3RzIHRoZSBzdGF0ZSBuYW1lIG91dCBvZiB0aGUga2V5LlxuICAgICAgICAgIC8vIEdpdmVuIHRoZSBga2V5YCBpcyBgbXlTdGF0ZS5teVByb3BlcnR5YCwgdGhlIGBhZGRlZFN0YXRlc2Agd2lsbCBvbmx5IGNvbnRhaW4gYG15U3RhdGVgLlxuICAgICAgICAgIGNvbnN0IGRvdE5vdGF0aW9uSW5kZXggPSBrZXkuaW5kZXhPZihET1QpO1xuICAgICAgICAgIGNvbnN0IHN0YXRlTmFtZSA9IGRvdE5vdGF0aW9uSW5kZXggPiAtMSA/IGtleS5zbGljZSgwLCBkb3ROb3RhdGlvbkluZGV4KSA6IGtleTtcbiAgICAgICAgICBpZiAoIWFkZGVkU3RhdGVzLmhhc093blByb3BlcnR5KHN0YXRlTmFtZSkpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBzdG9yZWRWYWx1ZTogYW55ID0gdGhpcy5fZW5naW5lLmdldEl0ZW0oa2V5ISk7XG5cbiAgICAgICAgaWYgKHN0b3JlZFZhbHVlICE9PSAndW5kZWZpbmVkJyAmJiBzdG9yZWRWYWx1ZSAhPSBudWxsKSB7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IG5ld1ZhbCA9IHRoaXMuX29wdGlvbnMuZGVzZXJpYWxpemUhKHN0b3JlZFZhbHVlKTtcbiAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gdGhpcy5fb3B0aW9ucy5hZnRlckRlc2VyaWFsaXplIShuZXdWYWwsIGtleSk7XG4gICAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICAvLyBDYXJldGFrZXIgbm90ZTogd2UgaGF2ZSBzdGlsbCBsZWZ0IHRoZSBgdHlwZW9mYCBjb25kaXRpb24gaW4gb3JkZXIgdG8gYXZvaWRcbiAgICAgICAgICAgIC8vIGNyZWF0aW5nIGEgYnJlYWtpbmcgY2hhbmdlIGZvciBwcm9qZWN0cyB0aGF0IHN0aWxsIHVzZSB0aGUgVmlldyBFbmdpbmUuXG4gICAgICAgICAgICBpZiAodHlwZW9mIG5nRGV2TW9kZSA9PT0gJ3VuZGVmaW5lZCcgfHwgbmdEZXZNb2RlKSB7XG4gICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAgICAgYEVycm9yIG9jdXJyZWQgd2hpbGUgZGVzZXJpYWxpemluZyB0aGUgJHtrZXl9IHN0b3JlIHZhbHVlLCBmYWxsaW5nIGJhY2sgdG8gZW1wdHkgb2JqZWN0LCB0aGUgdmFsdWUgb2J0YWluZWQgZnJvbSB0aGUgc3RvcmU6IGAsXG4gICAgICAgICAgICAgICAgc3RvcmVkVmFsdWVcbiAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHN0b3JlZFZhbHVlID0ge307XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKHRoaXMuX29wdGlvbnMubWlncmF0aW9ucykge1xuICAgICAgICAgICAgdGhpcy5fb3B0aW9ucy5taWdyYXRpb25zLmZvckVhY2goc3RyYXRlZ3kgPT4ge1xuICAgICAgICAgICAgICBjb25zdCB2ZXJzaW9uTWF0Y2ggPVxuICAgICAgICAgICAgICAgIHN0cmF0ZWd5LnZlcnNpb24gPT09IGdldFZhbHVlKHN0b3JlZFZhbHVlLCBzdHJhdGVneS52ZXJzaW9uS2V5IHx8ICd2ZXJzaW9uJyk7XG4gICAgICAgICAgICAgIGNvbnN0IGtleU1hdGNoID1cbiAgICAgICAgICAgICAgICAoIXN0cmF0ZWd5LmtleSAmJiB0aGlzLl91c2VzRGVmYXVsdFN0YXRlS2V5KSB8fCBzdHJhdGVneS5rZXkgPT09IGtleTtcbiAgICAgICAgICAgICAgaWYgKHZlcnNpb25NYXRjaCAmJiBrZXlNYXRjaCkge1xuICAgICAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gc3RyYXRlZ3kubWlncmF0ZShzdG9yZWRWYWx1ZSk7XG4gICAgICAgICAgICAgICAgaGFzTWlncmF0aW9uID0gdHJ1ZTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKCF0aGlzLl91c2VzRGVmYXVsdFN0YXRlS2V5KSB7XG4gICAgICAgICAgICBzdGF0ZSA9IHNldFZhbHVlKHN0YXRlLCBrZXkhLCBzdG9yZWRWYWx1ZSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIC8vIFRoZSBgVXBkYXRlU3RhdGVgIGFjdGlvbiBpcyBkaXNwYXRjaGVkIHdoZW5ldmVyIHRoZSBmZWF0dXJlIHN0YXRlIGlzIGFkZGVkLlxuICAgICAgICAgICAgLy8gVGhlIGJlbG93IGNvbmRpdGlvbiBpcyBtZXQgb25seSB3aGVuIHRoZSBgVXBkYXRlU3RhdGVgIGlzIGRpc3BhdGNoZWQuXG4gICAgICAgICAgICAvLyBMZXQncyBhc3N1bWUgdGhhdCB3ZSBoYXZlIDIgc3RhdGVzIGBjb3VudGVyYCBhbmQgYEBuZ3hzL3JvdXRlci1wbHVnaW5gIHN0YXRlLlxuICAgICAgICAgICAgLy8gYENvdW50ZXJTdGF0ZWAgaXMgcHJvdmlkZWQgb24gdGhlIHJvb3QgbGV2ZWwgd2hlbiBjYWxsaW5nIGBOZ3hzTW9kdWxlLmZvclJvb3QoKWBcbiAgICAgICAgICAgIC8vIGFuZCBgQG5neHMvcm91dGVyLXBsdWdpbmAgaXMgcHJvdmlkZWQgYXMgYSBmZWF0dXJlIHN0YXRlLlxuICAgICAgICAgICAgLy8gVGhlIHN0b3JhZ2UgcGx1Z2luIG1heSBzYXZlIHRoZSBgY291bnRlcmAgc3RhdGUgdmFsdWUgYXMgYDEwYCBiZWZvcmUuXG4gICAgICAgICAgICAvLyBUaGUgYENvdW50ZXJTdGF0ZWAgbWF5IGltcGxlbWVudCB0aGUgYG5neHNPbkluaXRgIGhvb2sgYW5kIGNhbGwgYGN0eC5zZXRTdGF0ZSg5OTkpYC5cbiAgICAgICAgICAgIC8vIFRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIHJlLWh5ZHJhdGUgdGhlIHdob2xlIHN0YXRlIHdoZW4gdGhlIGBSb3V0ZXJTdGF0ZWAgaXMgcmVnaXN0ZXJlZCxcbiAgICAgICAgICAgIC8vIGFuZCB0aGUgYGNvdW50ZXJgIHN0YXRlIHdpbGwgYWdhaW4gZXF1YWwgYDEwYCAobm90IGA5OTlgKS5cbiAgICAgICAgICAgIGlmIChzdG9yZWRWYWx1ZSAmJiBhZGRlZFN0YXRlcyAmJiBPYmplY3Qua2V5cyhhZGRlZFN0YXRlcykubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgICBzdG9yZWRWYWx1ZSA9IE9iamVjdC5rZXlzKGFkZGVkU3RhdGVzKS5yZWR1Y2UoKGFjY3VtdWxhdG9yLCBhZGRlZFN0YXRlKSA9PiB7XG4gICAgICAgICAgICAgICAgLy8gVGhlIGBzdG9yZWRWYWx1ZWAgbWF5IGVxdWFsIHRoZSB3aG9sZSBzdGF0ZSAod2hlbiB0aGUgZGVmYXVsdCBzdGF0ZSBrZXkgaXMgdXNlZCkuXG4gICAgICAgICAgICAgICAgLy8gSWYgYGFkZGVkU3RhdGVzYCBjb250YWlucyBvbmx5IGByb3V0ZXJgIHRoZW4gd2Ugd2FudCB0byBtZXJnZSB0aGUgc3RhdGUgb25seVxuICAgICAgICAgICAgICAgIC8vIHdpdGggdGhlIGByb3V0ZXJgIHZhbHVlLlxuICAgICAgICAgICAgICAgIC8vIExldCdzIGFzc3VtZSB0aGF0IHRoZSBgc3RvcmVkVmFsdWVgIGlzIGFuIG9iamVjdDpcbiAgICAgICAgICAgICAgICAvLyBgeyBjb3VudGVyOiAxMCwgcm91dGVyOiB7Li4ufSB9YFxuICAgICAgICAgICAgICAgIC8vIFRoaXMgd2lsbCBwaWNrIG9ubHkgdGhlIGByb3V0ZXJgIG9iamVjdCBmcm9tIHRoZSBgc3RvcmVkVmFsdWVgIGFuZCBgY291bnRlcmBcbiAgICAgICAgICAgICAgICAvLyBzdGF0ZSB3aWxsIG5vdCBiZSByZS1oeWRyYXRlZCB1bm5lY2Vzc2FyeS5cbiAgICAgICAgICAgICAgICBpZiAoc3RvcmVkVmFsdWUuaGFzT3duUHJvcGVydHkoYWRkZWRTdGF0ZSkpIHtcbiAgICAgICAgICAgICAgICAgIGFjY3VtdWxhdG9yW2FkZGVkU3RhdGVdID0gc3RvcmVkVmFsdWVbYWRkZWRTdGF0ZV07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHJldHVybiBhY2N1bXVsYXRvcjtcbiAgICAgICAgICAgICAgfSwgPFBsYWluT2JqZWN0Pnt9KTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgc3RhdGUgPSB7IC4uLnN0YXRlLCAuLi5zdG9yZWRWYWx1ZSB9O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBuZXh0KHN0YXRlLCBldmVudCkucGlwZShcbiAgICAgIHRhcChuZXh0U3RhdGUgPT4ge1xuICAgICAgICBpZiAoIWlzSW5pdE9yVXBkYXRlQWN0aW9uIHx8IChpc0luaXRPclVwZGF0ZUFjdGlvbiAmJiBoYXNNaWdyYXRpb24pKSB7XG4gICAgICAgICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5fa2V5cykge1xuICAgICAgICAgICAgbGV0IHZhbCA9IG5leHRTdGF0ZTtcblxuICAgICAgICAgICAgaWYgKGtleSAhPT0gREVGQVVMVF9TVEFURV9LRVkpIHtcbiAgICAgICAgICAgICAgdmFsID0gZ2V0VmFsdWUobmV4dFN0YXRlLCBrZXkhKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgY29uc3QgbmV3VmFsID0gdGhpcy5fb3B0aW9ucy5iZWZvcmVTZXJpYWxpemUhKHZhbCwga2V5KTtcbiAgICAgICAgICAgICAgdGhpcy5fZW5naW5lLnNldEl0ZW0oa2V5ISwgdGhpcy5fb3B0aW9ucy5zZXJpYWxpemUhKG5ld1ZhbCkpO1xuICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgICAgLy8gQ2FyZXRha2VyIG5vdGU6IHdlIGhhdmUgc3RpbGwgbGVmdCB0aGUgYHR5cGVvZmAgY29uZGl0aW9uIGluIG9yZGVyIHRvIGF2b2lkXG4gICAgICAgICAgICAgIC8vIGNyZWF0aW5nIGEgYnJlYWtpbmcgY2hhbmdlIGZvciBwcm9qZWN0cyB0aGF0IHN0aWxsIHVzZSB0aGUgVmlldyBFbmdpbmUuXG4gICAgICAgICAgICAgIGlmICh0eXBlb2YgbmdEZXZNb2RlID09PSAndW5kZWZpbmVkJyB8fCBuZ0Rldk1vZGUpIHtcbiAgICAgICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICAgICBlcnJvciAmJlxuICAgICAgICAgICAgICAgICAgKGVycm9yLm5hbWUgPT09ICdRdW90YUV4Y2VlZGVkRXJyb3InIHx8XG4gICAgICAgICAgICAgICAgICAgIGVycm9yLm5hbWUgPT09ICdOU19FUlJPUl9ET01fUVVPVEFfUkVBQ0hFRCcpXG4gICAgICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKFxuICAgICAgICAgICAgICAgICAgICBgVGhlICR7a2V5fSBzdG9yZSB2YWx1ZSBleGNlZWRzIHRoZSBicm93c2VyIHN0b3JhZ2UgcXVvdGE6IGAsXG4gICAgICAgICAgICAgICAgICAgIHZhbFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgICAgICAgICAgICAgYEVycm9yIG9jdXJyZWQgd2hpbGUgc2VyaWFsaXppbmcgdGhlICR7a2V5fSBzdG9yZSB2YWx1ZSwgdmFsdWUgbm90IHVwZGF0ZWQsIHRoZSB2YWx1ZSBvYnRhaW5lZCBmcm9tIHRoZSBzdG9yZTogYCxcbiAgICAgICAgICAgICAgICAgICAgdmFsXG4gICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG5cbmNvbnN0IERPVCA9ICcuJztcbiJdfQ==
239
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5wbHVnaW4uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Abmd4cy9zdG9yYWdlLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zdG9yYWdlLnBsdWdpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRCxPQUFPLEVBRUwsUUFBUSxFQUNSLFFBQVEsRUFDUixTQUFTLEVBQ1QsV0FBVyxFQUNYLGFBQWEsRUFFZCxNQUFNLGFBQWEsQ0FBQztBQUNyQixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGFBQWEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUMvRCxPQUFPLEVBRUwsaUNBQWlDLEVBQ2xDLE1BQU0sMkJBQTJCLENBQUM7QUFRbkM7SUFPRSwyQkFDcUQsUUFBdUMsRUFDN0QsV0FBbUI7UUFERyxhQUFRLEdBQVIsUUFBUSxDQUErQjtRQUM3RCxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQVAxQyxxQkFBZ0IsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQzs7UUFFakQseUJBQW9CLEdBQzFCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssaUJBQWlCLENBQUM7SUFLeEYsQ0FBQzs7Ozs7OztJQUVKLGtDQUFNOzs7Ozs7SUFBTixVQUFPLEtBQVUsRUFBRSxLQUFVLEVBQUUsSUFBc0I7UUFBckQsaUJBMElDOztRQXpJQyxJQUFJLGdCQUFnQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUN0QyxPQUFPLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxD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QTBGOzs7OztJQUMxRix3Q0FBZ0Q7OztJQWdKOUMsR0FBRyxHQUFHLEdBQUciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQTEFURk9STV9JRCwgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBsYWluT2JqZWN0IH0gZnJvbSAnQG5neHMvc3RvcmUvaW50ZXJuYWxzJztcbmltcG9ydCB7XG4gIE5neHNQbHVnaW4sXG4gIHNldFZhbHVlLFxuICBnZXRWYWx1ZSxcbiAgSW5pdFN0YXRlLFxuICBVcGRhdGVTdGF0ZSxcbiAgYWN0aW9uTWF0Y2hlcixcbiAgTmd4c05leHRQbHVnaW5GblxufSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IERFRkFVTFRfU1RBVEVfS0VZLCBnZXRTdG9yYWdlS2V5IH0gZnJvbSAnLi9pbnRlcm5hbHMnO1xuaW1wb3J0IHtcbiAgRmluYWxOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMsXG4gIEZJTkFMX05HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OU1xufSBmcm9tICcuL2ludGVybmFscy9maW5hbC1vcHRpb25zJztcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gV2lsbCBiZSBwcm92aWRlZCB0aHJvdWdoIFRlcnNlciBnbG9iYWwgZGVmaW5pdGlvbnMgYnkgQW5ndWxhciBDTElcbiAqIGR1cmluZyB0aGUgcHJvZHVjdGlvbiBidWlsZC4gVGhpcyBpcyBob3cgQW5ndWxhciBkb2VzIHRyZWUtc2hha2luZyBpbnRlcm5hbGx5LlxuICovXG5kZWNsYXJlIGNvbnN0IG5nRGV2TW9kZTogYm9vbGVhbjtcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE5neHNTdG9yYWdlUGx1Z2luIGltcGxlbWVudHMgTmd4c1BsdWdpbiB7XG4gIHByaXZhdGUgX2tleXNXaXRoRW5naW5lcyA9IHRoaXMuX29wdGlvbnMua2V5c1dpdGhFbmdpbmVzO1xuICAvLyBXZSBkZWZhdWx0IHRvIGBbREVGQVVMVF9TVEFURV9LRVldYCBpZiB0aGUgdXNlciBleHBsaWNpdGx5IGRvZXMgbm90IHByb3ZpZGUgdGhlIGBrZXlgIG9wdGlvbi5cbiAgcHJpdmF0ZSBfdXNlc0RlZmF1bHRTdGF0ZUtleSA9XG4gICAgdGhpcy5fa2V5c1dpdGhFbmdpbmVzLmxlbmd0aCA9PT0gMSAmJiB0aGlzLl9rZXlzV2l0aEVuZ2luZXNbMF0ua2V5ID09PSBERUZBVUxUX1NUQVRFX0tFWTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KEZJTkFMX05HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OUykgcHJpdmF0ZSBfb3B0aW9uczogRmluYWxOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMsXG4gICAgQEluamVjdChQTEFURk9STV9JRCkgcHJpdmF0ZSBfcGxhdGZvcm1JZDogc3RyaW5nXG4gICkge31cblxuICBoYW5kbGUoc3RhdGU6IGFueSwgZXZlbnQ6IGFueSwgbmV4dDogTmd4c05leHRQbHVnaW5Gbikge1xuICAgIGlmIChpc1BsYXRmb3JtU2VydmVyKHRoaXMuX3BsYXRmb3JtSWQpKSB7XG4gICAgICByZXR1cm4gbmV4dChzdGF0ZSwgZXZlbnQpO1xuICAgIH1cblxuICAgIGNvbnN0IG1hdGNoZXMgPSBhY3Rpb25NYXRjaGVyKGV2ZW50KTtcbiAgICBjb25zdCBpc0luaXRBY3Rpb24gPSBtYXRjaGVzKEluaXRTdGF0ZSk7XG4gICAgY29uc3QgaXNVcGRhdGVBY3Rpb24gPSBtYXRjaGVzKFVwZGF0ZVN0YXRlKTtcbiAgICBjb25zdCBpc0luaXRPclVwZGF0ZUFjdGlvbiA9IGlzSW5pdEFjdGlvbiB8fCBpc1VwZGF0ZUFjdGlvbjtcbiAgICBsZXQgaGFzTWlncmF0aW9uID0gZmFsc2U7XG5cbiAgICBpZiAoaXNJbml0T3JVcGRhdGVBY3Rpb24pIHtcbiAgICAgIGNvbnN0IGFkZGVkU3RhdGVzID0gaXNVcGRhdGVBY3Rpb24gJiYgZXZlbnQuYWRkZWRTdGF0ZXM7XG5cbiAgICAgIGZvciAoY29uc3QgeyBrZXksIGVuZ2luZSB9IG9mIHRoaXMuX2tleXNXaXRoRW5naW5lcykge1xuICAgICAgICAvLyBXZSdyZSBjaGVja2luZyB3aGF0IHN0YXRlcyBoYXZlIGJlZW4gYWRkZWQgYnkgTkdYUyBhbmQgaWYgYW55IG9mIHRoZXNlIHN0YXRlcyBzaG91bGQgYmUgaGFuZGxlZCBieVxuICAgICAgICAvLyB0aGUgc3RvcmFnZSBwbHVnaW4uIEZvciBpbnN0YW5jZSwgd2Ugb25seSB3YW50IHRvIGRlc2VyaWFsaXplIHRoZSBgYXV0aGAgc3RhdGUsIE5HWFMgaGFzIGFkZGVkXG4gICAgICAgIC8vIHRoZSBgdXNlcmAgc3RhdGUsIHRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIGJlIHJlcnVuIGFuZCB3aWxsIGRvIHJlZHVuZGFudCBkZXNlcmlhbGl6YXRpb24uXG4gICAgICAgIC8vIGB1c2VzRGVmYXVsdFN0YXRlS2V5YCBpcyBuZWNlc3NhcnkgdG8gY2hlY2sgc2luY2UgYGV2ZW50LmFkZGVkU3RhdGVzYCBuZXZlciBjb250YWlucyBgQEBTVEFURWAuXG4gICAgICAgIGlmICghdGhpcy5fdXNlc0RlZmF1bHRTdGF0ZUtleSAmJiBhZGRlZFN0YXRlcykge1xuICAgICAgICAgIC8vIFdlIHN1cHBvcnQgcHJvdmlkaW5nIGtleXMgdGhhdCBjYW4gYmUgZGVlcGx5IG5lc3RlZCB2aWEgZG90IG5vdGF0aW9uLCBmb3IgaW5zdGFuY2UsXG4gICAgICAgICAgLy8gYGtleXM6IFsnbXlTdGF0ZS5teVByb3BlcnR5J11gIGlzIGEgdmFsaWQga2V5LlxuICAgICAgICAgIC8vIFRoZSBzdGF0ZSBuYW1lIHNob3VsZCBhbHdheXMgZ28gZmlyc3QuIFRoZSBiZWxvdyBjb2RlIGNoZWNrcyBpZiB0aGUgYGtleWAgaW5jbHVkZXMgZG90XG4gICAgICAgICAgLy8gbm90YXRpb24gYW5kIGV4dHJhY3RzIHRoZSBzdGF0ZSBuYW1lIG91dCBvZiB0aGUga2V5LlxuICAgICAgICAgIC8vIEdpdmVuIHRoZSBga2V5YCBpcyBgbXlTdGF0ZS5teVByb3BlcnR5YCwgdGhlIGBhZGRlZFN0YXRlc2Agd2lsbCBvbmx5IGNvbnRhaW4gYG15U3RhdGVgLlxuICAgICAgICAgIGNvbnN0IGRvdE5vdGF0aW9uSW5kZXggPSBrZXkuaW5kZXhPZihET1QpO1xuICAgICAgICAgIGNvbnN0IHN0YXRlTmFtZSA9IGRvdE5vdGF0aW9uSW5kZXggPiAtMSA/IGtleS5zbGljZSgwLCBkb3ROb3RhdGlvbkluZGV4KSA6IGtleTtcbiAgICAgICAgICBpZiAoIWFkZGVkU3RhdGVzLmhhc093blByb3BlcnR5KHN0YXRlTmFtZSkpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHN0b3JhZ2VLZXkgPSBnZXRTdG9yYWdlS2V5KGtleSwgdGhpcy5fb3B0aW9ucyk7XG4gICAgICAgIGxldCBzdG9yZWRWYWx1ZTogYW55ID0gZW5naW5lLmdldEl0ZW0oc3RvcmFnZUtleSk7XG5cbiAgICAgICAgaWYgKHN0b3JlZFZhbHVlICE9PSAndW5kZWZpbmVkJyAmJiBzdG9yZWRWYWx1ZSAhPSBudWxsKSB7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IG5ld1ZhbCA9IHRoaXMuX29wdGlvbnMuZGVzZXJpYWxpemUhKHN0b3JlZFZhbHVlKTtcbiAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gdGhpcy5fb3B0aW9ucy5hZnRlckRlc2VyaWFsaXplIShuZXdWYWwsIGtleSk7XG4gICAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICAvLyBDYXJldGFrZXIgbm90ZTogd2UgaGF2ZSBzdGlsbCBsZWZ0IHRoZSBgdHlwZW9mYCBjb25kaXRpb24gaW4gb3JkZXIgdG8gYXZvaWRcbiAgICAgICAgICAgIC8vIGNyZWF0aW5nIGEgYnJlYWtpbmcgY2hhbmdlIGZvciBwcm9qZWN0cyB0aGF0IHN0aWxsIHVzZSB0aGUgVmlldyBFbmdpbmUuXG4gICAgICAgICAgICBpZiAodHlwZW9mIG5nRGV2TW9kZSA9PT0gJ3VuZGVmaW5lZCcgfHwgbmdEZXZNb2RlKSB7XG4gICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAgICAgYEVycm9yIG9jdXJyZWQgd2hpbGUgZGVzZXJpYWxpemluZyB0aGUgJHtzdG9yYWdlS2V5fSBzdG9yZSB2YWx1ZSwgZmFsbGluZyBiYWNrIHRvIGVtcHR5IG9iamVjdCwgdGhlIHZhbHVlIG9idGFpbmVkIGZyb20gdGhlIHN0b3JlOiBgLFxuICAgICAgICAgICAgICAgIHN0b3JlZFZhbHVlXG4gICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBzdG9yZWRWYWx1ZSA9IHt9O1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGlmICh0aGlzLl9vcHRpb25zLm1pZ3JhdGlvbnMpIHtcbiAgICAgICAgICAgIHRoaXMuX29wdGlvbnMubWlncmF0aW9ucy5mb3JFYWNoKHN0cmF0ZWd5ID0+IHtcbiAgICAgICAgICAgICAgY29uc3QgdmVyc2lvbk1hdGNoID1cbiAgICAgICAgICAgICAgICBzdHJhdGVneS52ZXJzaW9uID09PSBnZXRWYWx1ZShzdG9yZWRWYWx1ZSwgc3RyYXRlZ3kudmVyc2lvbktleSB8fCAndmVyc2lvbicpO1xuICAgICAgICAgICAgICBjb25zdCBrZXlNYXRjaCA9XG4gICAgICAgICAgICAgICAgKCFzdHJhdGVneS5rZXkgJiYgdGhpcy5fdXNlc0RlZmF1bHRTdGF0ZUtleSkgfHwgc3RyYXRlZ3kua2V5ID09PSBrZXk7XG4gICAgICAgICAgICAgIGlmICh2ZXJzaW9uTWF0Y2ggJiYga2V5TWF0Y2gpIHtcbiAgICAgICAgICAgICAgICBzdG9yZWRWYWx1ZSA9IHN0cmF0ZWd5Lm1pZ3JhdGUoc3RvcmVkVmFsdWUpO1xuICAgICAgICAgICAgICAgIGhhc01pZ3JhdGlvbiA9IHRydWU7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGlmICghdGhpcy5fdXNlc0RlZmF1bHRTdGF0ZUtleSkge1xuICAgICAgICAgICAgc3RhdGUgPSBzZXRWYWx1ZShzdGF0ZSwga2V5LCBzdG9yZWRWYWx1ZSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIC8vIFRoZSBgVXBkYXRlU3RhdGVgIGFjdGlvbiBpcyBkaXNwYXRjaGVkIHdoZW5ldmVyIHRoZSBmZWF0dXJlIHN0YXRlIGlzIGFkZGVkLlxuICAgICAgICAgICAgLy8gVGhlIGJlbG93IGNvbmRpdGlvbiBpcyBtZXQgb25seSB3aGVuIHRoZSBgVXBkYXRlU3RhdGVgIGlzIGRpc3BhdGNoZWQuXG4gICAgICAgICAgICAvLyBMZXQncyBhc3N1bWUgdGhhdCB3ZSBoYXZlIDIgc3RhdGVzIGBjb3VudGVyYCBhbmQgYEBuZ3hzL3JvdXRlci1wbHVnaW5gIHN0YXRlLlxuICAgICAgICAgICAgLy8gYENvdW50ZXJTdGF0ZWAgaXMgcHJvdmlkZWQgb24gdGhlIHJvb3QgbGV2ZWwgd2hlbiBjYWxsaW5nIGBOZ3hzTW9kdWxlLmZvclJvb3QoKWBcbiAgICAgICAgICAgIC8vIGFuZCBgQG5neHMvcm91dGVyLXBsdWdpbmAgaXMgcHJvdmlkZWQgYXMgYSBmZWF0dXJlIHN0YXRlLlxuICAgICAgICAgICAgLy8gVGhlIHN0b3JhZ2UgcGx1Z2luIG1heSBzYXZlIHRoZSBgY291bnRlcmAgc3RhdGUgdmFsdWUgYXMgYDEwYCBiZWZvcmUuXG4gICAgICAgICAgICAvLyBUaGUgYENvdW50ZXJTdGF0ZWAgbWF5IGltcGxlbWVudCB0aGUgYG5neHNPbkluaXRgIGhvb2sgYW5kIGNhbGwgYGN0eC5zZXRTdGF0ZSg5OTkpYC5cbiAgICAgICAgICAgIC8vIFRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIHJlLWh5ZHJhdGUgdGhlIHdob2xlIHN0YXRlIHdoZW4gdGhlIGBSb3V0ZXJTdGF0ZWAgaXMgcmVnaXN0ZXJlZCxcbiAgICAgICAgICAgIC8vIGFuZCB0aGUgYGNvdW50ZXJgIHN0YXRlIHdpbGwgYWdhaW4gZXF1YWwgYDEwYCAobm90IGA5OTlgKS5cbiAgICAgICAgICAgIGlmIChzdG9yZWRWYWx1ZSAmJiBhZGRlZFN0YXRlcyAmJiBPYmplY3Qua2V5cyhhZGRlZFN0YXRlcykubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgICBzdG9yZWRWYWx1ZSA9IE9iamVjdC5rZXlzKGFkZGVkU3RhdGVzKS5yZWR1Y2UoKGFjY3VtdWxhdG9yLCBhZGRlZFN0YXRlKSA9PiB7XG4gICAgICAgICAgICAgICAgLy8gVGhlIGBzdG9yZWRWYWx1ZWAgbWF5IGVxdWFsIHRoZSB3aG9sZSBzdGF0ZSAod2hlbiB0aGUgZGVmYXVsdCBzdGF0ZSBrZXkgaXMgdXNlZCkuXG4gICAgICAgICAgICAgICAgLy8gSWYgYGFkZGVkU3RhdGVzYCBjb250YWlucyBvbmx5IGByb3V0ZXJgIHRoZW4gd2Ugd2FudCB0byBtZXJnZSB0aGUgc3RhdGUgb25seVxuICAgICAgICAgICAgICAgIC8vIHdpdGggdGhlIGByb3V0ZXJgIHZhbHVlLlxuICAgICAgICAgICAgICAgIC8vIExldCdzIGFzc3VtZSB0aGF0IHRoZSBgc3RvcmVkVmFsdWVgIGlzIGFuIG9iamVjdDpcbiAgICAgICAgICAgICAgICAvLyBgeyBjb3VudGVyOiAxMCwgcm91dGVyOiB7Li4ufSB9YFxuICAgICAgICAgICAgICAgIC8vIFRoaXMgd2lsbCBwaWNrIG9ubHkgdGhlIGByb3V0ZXJgIG9iamVjdCBmcm9tIHRoZSBgc3RvcmVkVmFsdWVgIGFuZCBgY291bnRlcmBcbiAgICAgICAgICAgICAgICAvLyBzdGF0ZSB3aWxsIG5vdCBiZSByZS1oeWRyYXRlZCB1bm5lY2Vzc2FyeS5cbiAgICAgICAgICAgICAgICBpZiAoc3RvcmVkVmFsdWUuaGFzT3duUHJvcGVydHkoYWRkZWRTdGF0ZSkpIHtcbiAgICAgICAgICAgICAgICAgIGFjY3VtdWxhdG9yW2FkZGVkU3RhdGVdID0gc3RvcmVkVmFsdWVbYWRkZWRTdGF0ZV07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHJldHVybiBhY2N1bXVsYXRvcjtcbiAgICAgICAgICAgICAgfSwgPFBsYWluT2JqZWN0Pnt9KTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgc3RhdGUgPSB7IC4uLnN0YXRlLCAuLi5zdG9yZWRWYWx1ZSB9O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBuZXh0KHN0YXRlLCBldmVudCkucGlwZShcbiAgICAgIHRhcChuZXh0U3RhdGUgPT4ge1xuICAgICAgICBpZiAoIWlzSW5pdE9yVXBkYXRlQWN0aW9uIHx8IChpc0luaXRPclVwZGF0ZUFjdGlvbiAmJiBoYXNNaWdyYXRpb24pKSB7XG4gICAgICAgICAgZm9yIChjb25zdCB7IGtleSwgZW5naW5lIH0gb2YgdGhpcy5fa2V5c1dpdGhFbmdpbmVzKSB7XG4gICAgICAgICAgICBsZXQgc3RvcmVkVmFsdWUgPSBuZXh0U3RhdGU7XG5cbiAgICAgICAgICAgIGNvbnN0IHN0b3JhZ2VLZXkgPSBnZXRTdG9yYWdlS2V5KGtleSwgdGhpcy5fb3B0aW9ucyk7XG5cbiAgICAgICAgICAgIGlmIChrZXkgIT09IERFRkFVTFRfU1RBVEVfS0VZKSB7XG4gICAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gZ2V0VmFsdWUobmV4dFN0YXRlLCBrZXkpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICBjb25zdCBuZXdTdG9yZWRWYWx1ZSA9IHRoaXMuX29wdGlvbnMuYmVmb3JlU2VyaWFsaXplIShzdG9yZWRWYWx1ZSwga2V5KTtcbiAgICAgICAgICAgICAgZW5naW5lLnNldEl0ZW0oc3RvcmFnZUtleSwgdGhpcy5fb3B0aW9ucy5zZXJpYWxpemUhKG5ld1N0b3JlZFZhbHVlKSk7XG4gICAgICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgICAgICAvLyBDYXJldGFrZXIgbm90ZTogd2UgaGF2ZSBzdGlsbCBsZWZ0IHRoZSBgdHlwZW9mYCBjb25kaXRpb24gaW4gb3JkZXIgdG8gYXZvaWRcbiAgICAgICAgICAgICAgLy8gY3JlYXRpbmcgYSBicmVha2luZyBjaGFuZ2UgZm9yIHByb2plY3RzIHRoYXQgc3RpbGwgdXNlIHRoZSBWaWV3IEVuZ2luZS5cbiAgICAgICAgICAgICAgaWYgKHR5cGVvZiBuZ0Rldk1vZGUgPT09ICd1bmRlZmluZWQnIHx8IG5nRGV2TW9kZSkge1xuICAgICAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgICAgIGVycm9yICYmXG4gICAgICAgICAgICAgICAgICAoZXJyb3IubmFtZSA9PT0gJ1F1b3RhRXhjZWVkZWRFcnJvcicgfHxcbiAgICAgICAgICAgICAgICAgICAgZXJyb3IubmFtZSA9PT0gJ05TX0VSUk9SX0RPTV9RVU9UQV9SRUFDSEVEJylcbiAgICAgICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAgICAgICAgIGBUaGUgJHtzdG9yYWdlS2V5fSBzdG9yZSB2YWx1ZSBleGNlZWRzIHRoZSBicm93c2VyIHN0b3JhZ2UgcXVvdGE6IGAsXG4gICAgICAgICAgICAgICAgICAgIHN0b3JlZFZhbHVlXG4gICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKFxuICAgICAgICAgICAgICAgICAgICBgRXJyb3Igb2N1cnJlZCB3aGlsZSBzZXJpYWxpemluZyB0aGUgJHtzdG9yYWdlS2V5fSBzdG9yZSB2YWx1ZSwgdmFsdWUgbm90IHVwZGF0ZWQsIHRoZSB2YWx1ZSBvYnRhaW5lZCBmcm9tIHRoZSBzdG9yZTogYCxcbiAgICAgICAgICAgICAgICAgICAgc3RvcmVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9KVxuICAgICk7XG4gIH1cbn1cblxuY29uc3QgRE9UID0gJy4nO1xuIl19
@@ -19,6 +19,13 @@ if (false) {
19
19
  * @type {?|undefined}
20
20
  */
21
21
  NgxsStoragePluginOptions.prototype.key;
22
+ /**
23
+ * The namespace is used to prefix the key for the state slice. This is
24
+ * necessary when running micro frontend applications which use storage plugin.
25
+ * The namespace will eliminate the conflict between keys that might overlap.
26
+ * @type {?|undefined}
27
+ */
28
+ NgxsStoragePluginOptions.prototype.namespace;
22
29
  /**
23
30
  * Storage engine to use. Deaults to localStorage but can provide
24
31
  *
@@ -59,7 +66,7 @@ if (false) {
59
66
  NgxsStoragePluginOptions.prototype.afterDeserialize = function (obj, key) { };
60
67
  }
61
68
  /** @type {?} */
62
- export var NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTION');
69
+ export var NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTIONS');
63
70
  /** @type {?} */
64
71
  export var STORAGE_ENGINE = new InjectionToken('STORAGE_ENGINE');
65
72
  /**
@@ -90,4 +97,4 @@ if (false) {
90
97
  */
91
98
  StorageEngine.prototype.clear = function () { };
92
99
  }
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL3N0b3JhZ2UtcGx1Z2luLyIsInNvdXJjZXMiOlsic3JjL3N5bWJvbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7OztJQUs3QyxlQUFZO0lBQ1osaUJBQWM7Ozs7OztBQUdoQiw4Q0F5REM7Ozs7OztJQXJEQyx1Q0FBNkI7Ozs7Ozs7SUFPN0IsMkNBQXdCOzs7OztJQUt4Qiw4Q0FvQkk7Ozs7OztJQUtKLGtFQUE2Qjs7Ozs7O0lBSzdCLG9FQUE0Qjs7Ozs7OztJQUs1Qiw2RUFBNkM7Ozs7Ozs7SUFLN0MsOEVBQThDOzs7QUFHaEQsTUFBTSxLQUFPLDJCQUEyQixHQUFHLElBQUksY0FBYyxDQUFDLDRCQUE0QixDQUFDOztBQUUzRixNQUFNLEtBQU8sY0FBYyxHQUFHLElBQUksY0FBYyxDQUFDLGdCQUFnQixDQUFDOzs7O0FBRWxFLG1DQU1DOzs7SUFMQywrQkFBd0I7Ozs7O0lBQ3hCLHFEQUEwQjs7Ozs7O0lBQzFCLDBEQUFxQzs7Ozs7SUFDckMsd0RBQThCOzs7O0lBQzlCLGdEQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU3RvcmFnZUtleSB9IGZyb20gJy4vaW50ZXJuYWxzJztcblxuZXhwb3J0IGNvbnN0IGVudW0gU3RvcmFnZU9wdGlvbiB7XG4gIExvY2FsU3RvcmFnZSxcbiAgU2Vzc2lvblN0b3JhZ2Vcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMge1xuICAvKipcbiAgICogS2V5IGZvciB0aGUgc3RhdGUgc2xpY2UgdG8gc3RvcmUgaW4gdGhlIHN0b3JhZ2UgZW5naW5lLlxuICAgKi9cbiAga2V5PzogdW5kZWZpbmVkIHwgU3RvcmFnZUtleTtcblxuICAvKipcbiAgICogU3RvcmFnZSBlbmdpbmUgdG8gdXNlLiBEZWF1bHRzIHRvIGxvY2FsU3RvcmFnZSBidXQgY2FuIHByb3ZpZGVcbiAgICpcbiAgICogc2Vzc2lvblN0b3JhZ2Ugb3IgY3VzdG9tIGltcGxlbWVudGF0aW9uIG9mIHRoZSBTdG9yYWdlRW5naW5lIGludGVyZmFjZVxuICAgKi9cbiAgc3RvcmFnZT86IFN0b3JhZ2VPcHRpb247XG5cbiAgLyoqXG4gICAqIE1pZ3JhdGlvbiBzdHJhdGVnaWVzLlxuICAgKi9cbiAgbWlncmF0aW9ucz86IHtcbiAgICAvKipcbiAgICAgKiBWZXJzaW9uIHRvIGtleSBvZmYuXG4gICAgICovXG4gICAgdmVyc2lvbjogbnVtYmVyIHwgc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogTWV0aG9kIHRvIG1pZ3JhdGUgdGhlIHByZXZpb3VzIHN0YXRlLlxuICAgICAqL1xuICAgIG1pZ3JhdGU6IChzdGF0ZTogYW55KSA9PiBhbnk7XG5cbiAgICAvKipcbiAgICAgKiBLZXkgdG8gbWlncmF0ZS5cbiAgICAgKi9cbiAgICBrZXk/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBLZXkgZm9yIHRoZSB2ZXJzaW9uLiBEZWZhdWx0cyB0byAndmVyc2lvbicuXG4gICAgICovXG4gICAgdmVyc2lvbktleT86IHN0cmluZztcbiAgfVtdO1xuXG4gIC8qKlxuICAgKiBTZXJhaWxpemVyIGZvciB0aGUgb2JqZWN0IGJlZm9yZSBpdHMgcHVzaGVkIGludG8gdGhlIGVuZ2luZS5cbiAgICovXG4gIHNlcmlhbGl6ZT8ob2JqOiBhbnkpOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERlc2VyaWFsaXplciBmb3IgdGhlIG9iamVjdCBiZWZvcmUgaXRzIHB1bGxlZCBvdXQgb2YgdGhlIGVuZ2luZS5cbiAgICovXG4gIGRlc2VyaWFsaXplPyhvYmo6IGFueSk6IGFueTtcblxuICAvKipcbiAgICogTWV0aG9kIHRvIGFsdGVyIG9iamVjdCBiZWZvcmUgc2VyaWFsaXphdGlvbi5cbiAgICovXG4gIGJlZm9yZVNlcmlhbGl6ZT8ob2JqOiBhbnksIGtleTogc3RyaW5nKTogYW55O1xuXG4gIC8qKlxuICAgKiBNZXRob2QgdG8gYWx0ZXIgb2JqZWN0IGFmdGVyIGRlc2VyaWFsaXphdGlvbi5cbiAgICovXG4gIGFmdGVyRGVzZXJpYWxpemU/KG9iajogYW55LCBrZXk6IHN0cmluZyk6IGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IE5HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbignTkdYU19TVE9SQUdFX1BMVUdJTl9PUFRJT04nKTtcblxuZXhwb3J0IGNvbnN0IFNUT1JBR0VfRU5HSU5FID0gbmV3IEluamVjdGlvblRva2VuKCdTVE9SQUdFX0VOR0lORScpO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0b3JhZ2VFbmdpbmUge1xuICByZWFkb25seSBsZW5ndGg6IG51bWJlcjtcbiAgZ2V0SXRlbShrZXk6IHN0cmluZyk6IGFueTtcbiAgc2V0SXRlbShrZXk6IHN0cmluZywgdmFsOiBhbnkpOiB2b2lkO1xuICByZW1vdmVJdGVtKGtleTogc3RyaW5nKTogdm9pZDtcbiAgY2xlYXIoKTogdm9pZDtcbn1cbiJdfQ==
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL3N0b3JhZ2UtcGx1Z2luLyIsInNvdXJjZXMiOlsic3JjL3N5bWJvbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7OztJQUs3QyxlQUFZO0lBQ1osaUJBQWM7Ozs7OztBQUdoQiw4Q0FnRUM7Ozs7OztJQTVEQyx1Q0FBNEM7Ozs7Ozs7SUFPNUMsNkNBQW1COzs7Ozs7O0lBT25CLDJDQUF3Qjs7Ozs7SUFLeEIsOENBb0JJOzs7Ozs7SUFLSixrRUFBNkI7Ozs7OztJQUs3QixvRUFBNEI7Ozs7Ozs7SUFLNUIsNkVBQTZDOzs7Ozs7O0lBSzdDLDhFQUE4Qzs7O0FBR2hELE1BQU0sS0FBTywyQkFBMkIsR0FBRyxJQUFJLGNBQWMsQ0FBQyw2QkFBNkIsQ0FBQzs7QUFFNUYsTUFBTSxLQUFPLGNBQWMsR0FBRyxJQUFJLGNBQWMsQ0FBZ0IsZ0JBQWdCLENBQUM7Ozs7QUFFakYsbUNBTUM7OztJQUxDLCtCQUF3Qjs7Ozs7SUFDeEIscURBQTBCOzs7Ozs7SUFDMUIsMERBQXFDOzs7OztJQUNyQyx3REFBOEI7Ozs7SUFDOUIsZ0RBQWMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTdG9yYWdlS2V5IH0gZnJvbSAnLi9pbnRlcm5hbHMvc3RvcmFnZS1rZXknO1xuXG5leHBvcnQgY29uc3QgZW51bSBTdG9yYWdlT3B0aW9uIHtcbiAgTG9jYWxTdG9yYWdlLFxuICBTZXNzaW9uU3RvcmFnZVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5neHNTdG9yYWdlUGx1Z2luT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBLZXkgZm9yIHRoZSBzdGF0ZSBzbGljZSB0byBzdG9yZSBpbiB0aGUgc3RvcmFnZSBlbmdpbmUuXG4gICAqL1xuICBrZXk/OiB1bmRlZmluZWQgfCBTdG9yYWdlS2V5IHwgU3RvcmFnZUtleVtdO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZXNwYWNlIGlzIHVzZWQgdG8gcHJlZml4IHRoZSBrZXkgZm9yIHRoZSBzdGF0ZSBzbGljZS4gVGhpcyBpc1xuICAgKiBuZWNlc3Nhcnkgd2hlbiBydW5uaW5nIG1pY3JvIGZyb250ZW5kIGFwcGxpY2F0aW9ucyB3aGljaCB1c2Ugc3RvcmFnZSBwbHVnaW4uXG4gICAqIFRoZSBuYW1lc3BhY2Ugd2lsbCBlbGltaW5hdGUgdGhlIGNvbmZsaWN0IGJldHdlZW4ga2V5cyB0aGF0IG1pZ2h0IG92ZXJsYXAuXG4gICAqL1xuICBuYW1lc3BhY2U/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFN0b3JhZ2UgZW5naW5lIHRvIHVzZS4gRGVhdWx0cyB0byBsb2NhbFN0b3JhZ2UgYnV0IGNhbiBwcm92aWRlXG4gICAqXG4gICAqIHNlc3Npb25TdG9yYWdlIG9yIGN1c3RvbSBpbXBsZW1lbnRhdGlvbiBvZiB0aGUgU3RvcmFnZUVuZ2luZSBpbnRlcmZhY2VcbiAgICovXG4gIHN0b3JhZ2U/OiBTdG9yYWdlT3B0aW9uO1xuXG4gIC8qKlxuICAgKiBNaWdyYXRpb24gc3RyYXRlZ2llcy5cbiAgICovXG4gIG1pZ3JhdGlvbnM/OiB7XG4gICAgLyoqXG4gICAgICogVmVyc2lvbiB0byBrZXkgb2ZmLlxuICAgICAqL1xuICAgIHZlcnNpb246IG51bWJlciB8IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIE1ldGhvZCB0byBtaWdyYXRlIHRoZSBwcmV2aW91cyBzdGF0ZS5cbiAgICAgKi9cbiAgICBtaWdyYXRlOiAoc3RhdGU6IGFueSkgPT4gYW55O1xuXG4gICAgLyoqXG4gICAgICogS2V5IHRvIG1pZ3JhdGUuXG4gICAgICovXG4gICAga2V5Pzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogS2V5IGZvciB0aGUgdmVyc2lvbi4gRGVmYXVsdHMgdG8gJ3ZlcnNpb24nLlxuICAgICAqL1xuICAgIHZlcnNpb25LZXk/OiBzdHJpbmc7XG4gIH1bXTtcblxuICAvKipcbiAgICogU2VyYWlsaXplciBmb3IgdGhlIG9iamVjdCBiZWZvcmUgaXRzIHB1c2hlZCBpbnRvIHRoZSBlbmdpbmUuXG4gICAqL1xuICBzZXJpYWxpemU/KG9iajogYW55KTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBEZXNlcmlhbGl6ZXIgZm9yIHRoZSBvYmplY3QgYmVmb3JlIGl0cyBwdWxsZWQgb3V0IG9mIHRoZSBlbmdpbmUuXG4gICAqL1xuICBkZXNlcmlhbGl6ZT8ob2JqOiBhbnkpOiBhbnk7XG5cbiAgLyoqXG4gICAqIE1ldGhvZCB0byBhbHRlciBvYmplY3QgYmVmb3JlIHNlcmlhbGl6YXRpb24uXG4gICAqL1xuICBiZWZvcmVTZXJpYWxpemU/KG9iajogYW55LCBrZXk6IHN0cmluZyk6IGFueTtcblxuICAvKipcbiAgICogTWV0aG9kIHRvIGFsdGVyIG9iamVjdCBhZnRlciBkZXNlcmlhbGl6YXRpb24uXG4gICAqL1xuICBhZnRlckRlc2VyaWFsaXplPyhvYmo6IGFueSwga2V5OiBzdHJpbmcpOiBhbnk7XG59XG5cbmV4cG9ydCBjb25zdCBOR1hTX1NUT1JBR0VfUExVR0lOX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ05HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OUycpO1xuXG5leHBvcnQgY29uc3QgU1RPUkFHRV9FTkdJTkUgPSBuZXcgSW5qZWN0aW9uVG9rZW48U3RvcmFnZUVuZ2luZT4oJ1NUT1JBR0VfRU5HSU5FJyk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RvcmFnZUVuZ2luZSB7XG4gIHJlYWRvbmx5IGxlbmd0aDogbnVtYmVyO1xuICBnZXRJdGVtKGtleTogc3RyaW5nKTogYW55O1xuICBzZXRJdGVtKGtleTogc3RyaW5nLCB2YWw6IGFueSk6IHZvaWQ7XG4gIHJlbW92ZUl0ZW0oa2V5OiBzdHJpbmcpOiB2b2lkO1xuICBjbGVhcigpOiB2b2lkO1xufVxuIl19
@@ -1,4 +1,4 @@
1
- import { InjectionToken, Injectable, Inject, PLATFORM_ID, NgModule } from '@angular/core';
1
+ import { InjectionToken, Injectable, Inject, PLATFORM_ID, Injector, NgModule } from '@angular/core';
2
2
  import { StateToken, actionMatcher, InitState, UpdateState, getValue, setValue, NGXS_PLUGINS } from '@ngxs/store';
3
3
  import { isPlatformServer } from '@angular/common';
4
4
  import { tap } from 'rxjs/operators';
@@ -22,6 +22,13 @@ if (false) {
22
22
  * @type {?|undefined}
23
23
  */
24
24
  NgxsStoragePluginOptions.prototype.key;
25
+ /**
26
+ * The namespace is used to prefix the key for the state slice. This is
27
+ * necessary when running micro frontend applications which use storage plugin.
28
+ * The namespace will eliminate the conflict between keys that might overlap.
29
+ * @type {?|undefined}
30
+ */
31
+ NgxsStoragePluginOptions.prototype.namespace;
25
32
  /**
26
33
  * Storage engine to use. Deaults to localStorage but can provide
27
34
  *
@@ -62,7 +69,7 @@ if (false) {
62
69
  NgxsStoragePluginOptions.prototype.afterDeserialize = function (obj, key) { };
63
70
  }
64
71
  /** @type {?} */
65
- const NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTION');
72
+ const NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTIONS');
66
73
  /** @type {?} */
67
74
  const STORAGE_ENGINE = new InjectionToken('STORAGE_ENGINE');
68
75
  /**
@@ -99,47 +106,16 @@ if (false) {
99
106
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
100
107
  */
101
108
  /**
102
- * If the `key` option is not provided then the below constant
103
- * will be used as a default key
109
+ * The following key is used to store the entire serialized
110
+ * state when there's no specific state provided.
104
111
  * @type {?}
105
112
  */
106
113
  const DEFAULT_STATE_KEY = '@@STATE';
107
- /**
108
- * This key is used to retrieve static metadatas on state classes.
109
- * This constant is taken from the core codebase
110
- * @type {?}
111
- */
112
- const META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
113
- /**
114
- * @param {?} key
115
- * @return {?}
116
- */
117
- function transformKeyOption(key) {
118
- if (!Array.isArray(key)) {
119
- key = [key];
120
- }
121
- return key.map((/**
122
- * @param {?} token
123
- * @return {?}
124
- */
125
- (token) => {
126
- // If it has the `NGXS_OPTIONS_META` key then it means the developer
127
- // has provided state class like `key: [AuthState]`.
128
- if (token.hasOwnProperty(META_OPTIONS_KEY)) {
129
- // The `name` property will be an actual state name or a `StateToken`.
130
- token = ((/** @type {?} */ (token)))[META_OPTIONS_KEY].name;
131
- }
132
- return token instanceof StateToken ? token.getName() : ((/** @type {?} */ (token)));
133
- }));
134
- }
135
114
  /**
136
115
  * @param {?} options
137
116
  * @return {?}
138
117
  */
139
118
  function storageOptionsFactory(options) {
140
- if (options !== undefined && options.key) {
141
- options.key = transformKeyOption(options.key);
142
- }
143
119
  return Object.assign({ key: [DEFAULT_STATE_KEY], storage: 0 /* LocalStorage */, serialize: JSON.stringify, deserialize: JSON.parse, beforeSerialize: (/**
144
120
  * @param {?} obj
145
121
  * @return {?}
@@ -167,6 +143,101 @@ function engineFactory(options, platformId) {
167
143
  }
168
144
  return null;
169
145
  }
146
+ /**
147
+ * @param {?} key
148
+ * @param {?=} options
149
+ * @return {?}
150
+ */
151
+ function getStorageKey(key, options) {
152
+ // Prepends the `namespace` option to any key if it's been provided by a user.
153
+ // So `@@STATE` becomes `my-app:@@STATE`.
154
+ return options && options.namespace ? `${options.namespace}:${key}` : key;
155
+ }
156
+
157
+ /**
158
+ * @fileoverview added by tsickle
159
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
160
+ */
161
+ /**
162
+ * This enables the user to provide a storage engine per individual key.
163
+ * @record
164
+ */
165
+ function KeyWithExplicitEngine() { }
166
+ if (false) {
167
+ /** @type {?} */
168
+ KeyWithExplicitEngine.prototype.key;
169
+ /** @type {?} */
170
+ KeyWithExplicitEngine.prototype.engine;
171
+ }
172
+ /**
173
+ * Determines whether the provided key has the following structure.
174
+ * @param {?} key
175
+ * @return {?}
176
+ */
177
+ function isKeyWithExplicitEngine(key) {
178
+ return key != null && !!key.engine;
179
+ }
180
+ /**
181
+ * This symbol is used to store the metadata on state classes.
182
+ * @type {?}
183
+ */
184
+ const META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
185
+ /**
186
+ * @param {?} storageKey
187
+ * @return {?}
188
+ */
189
+ function exctractStringKey(storageKey) {
190
+ // Extract the actual key out of the `{ key, engine }` structure.
191
+ if (isKeyWithExplicitEngine(storageKey)) {
192
+ storageKey = storageKey.key;
193
+ }
194
+ // Given the `storageKey` is a class, for instance, `AuthState`.
195
+ // We should retrieve its metadata and the `name` property.
196
+ // The `name` property might be a string (state name) or a state token.
197
+ if (storageKey.hasOwnProperty(META_OPTIONS_KEY)) {
198
+ storageKey = ((/** @type {?} */ (storageKey)))[META_OPTIONS_KEY].name;
199
+ }
200
+ return storageKey instanceof StateToken ? storageKey.getName() : (/** @type {?} */ (storageKey));
201
+ }
202
+
203
+ /**
204
+ * @fileoverview added by tsickle
205
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
206
+ */
207
+ /**
208
+ * @record
209
+ */
210
+ function FinalNgxsStoragePluginOptions() { }
211
+ if (false) {
212
+ /** @type {?} */
213
+ FinalNgxsStoragePluginOptions.prototype.keysWithEngines;
214
+ }
215
+ /** @type {?} */
216
+ const FINAL_NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('FINAL_NGXS_STORAGE_PLUGIN_OPTIONS');
217
+ /**
218
+ * @param {?} injector
219
+ * @param {?} options
220
+ * @return {?}
221
+ */
222
+ function createFinalStoragePluginOptions(injector, options) {
223
+ /** @type {?} */
224
+ const storageKeys = Array.isArray(options.key) ? options.key : [(/** @type {?} */ (options.key))];
225
+ /** @type {?} */
226
+ const keysWithEngines = storageKeys.map((/**
227
+ * @param {?} storageKey
228
+ * @return {?}
229
+ */
230
+ (storageKey) => {
231
+ /** @type {?} */
232
+ const key = exctractStringKey(storageKey);
233
+ /** @type {?} */
234
+ const engine = isKeyWithExplicitEngine(storageKey)
235
+ ? injector.get(storageKey.engine)
236
+ : injector.get(STORAGE_ENGINE);
237
+ return { key, engine };
238
+ }));
239
+ return Object.assign({}, options, { keysWithEngines });
240
+ }
170
241
 
171
242
  /**
172
243
  * @fileoverview added by tsickle
@@ -175,18 +246,14 @@ function engineFactory(options, platformId) {
175
246
  class NgxsStoragePlugin {
176
247
  /**
177
248
  * @param {?} _options
178
- * @param {?} _engine
179
249
  * @param {?} _platformId
180
250
  */
181
- constructor(_options, _engine, _platformId) {
251
+ constructor(_options, _platformId) {
182
252
  this._options = _options;
183
- this._engine = _engine;
184
253
  this._platformId = _platformId;
185
- // We cast to `string[]` here as we're sure that this option has been
186
- // transformed by the `storageOptionsFactory` function that provided token.
187
- this._keys = (/** @type {?} */ (this._options.key));
254
+ this._keysWithEngines = this._options.keysWithEngines;
188
255
  // We default to `[DEFAULT_STATE_KEY]` if the user explicitly does not provide the `key` option.
189
- this._usesDefaultStateKey = this._keys.length === 1 && this._keys[0] === DEFAULT_STATE_KEY;
256
+ this._usesDefaultStateKey = this._keysWithEngines.length === 1 && this._keysWithEngines[0].key === DEFAULT_STATE_KEY;
190
257
  }
191
258
  /**
192
259
  * @param {?} state
@@ -195,7 +262,7 @@ class NgxsStoragePlugin {
195
262
  * @return {?}
196
263
  */
197
264
  handle(state, event, next) {
198
- if (isPlatformServer(this._platformId) && this._engine === null) {
265
+ if (isPlatformServer(this._platformId)) {
199
266
  return next(state, event);
200
267
  }
201
268
  /** @type {?} */
@@ -211,7 +278,7 @@ class NgxsStoragePlugin {
211
278
  if (isInitOrUpdateAction) {
212
279
  /** @type {?} */
213
280
  const addedStates = isUpdateAction && event.addedStates;
214
- for (const key of this._keys) {
281
+ for (const { key, engine } of this._keysWithEngines) {
215
282
  // We're checking what states have been added by NGXS and if any of these states should be handled by
216
283
  // the storage plugin. For instance, we only want to deserialize the `auth` state, NGXS has added
217
284
  // the `user` state, the storage plugin will be rerun and will do redundant deserialization.
@@ -231,7 +298,9 @@ class NgxsStoragePlugin {
231
298
  }
232
299
  }
233
300
  /** @type {?} */
234
- let storedValue = this._engine.getItem((/** @type {?} */ (key)));
301
+ const storageKey = getStorageKey(key, this._options);
302
+ /** @type {?} */
303
+ let storedValue = engine.getItem(storageKey);
235
304
  if (storedValue !== 'undefined' && storedValue != null) {
236
305
  try {
237
306
  /** @type {?} */
@@ -242,7 +311,7 @@ class NgxsStoragePlugin {
242
311
  // Caretaker note: we have still left the `typeof` condition in order to avoid
243
312
  // creating a breaking change for projects that still use the View Engine.
244
313
  if (typeof ngDevMode === 'undefined' || ngDevMode) {
245
- console.error(`Error ocurred while deserializing the ${key} store value, falling back to empty object, the value obtained from the store: `, storedValue);
314
+ console.error(`Error ocurred while deserializing the ${storageKey} store value, falling back to empty object, the value obtained from the store: `, storedValue);
246
315
  }
247
316
  storedValue = {};
248
317
  }
@@ -263,7 +332,7 @@ class NgxsStoragePlugin {
263
332
  }));
264
333
  }
265
334
  if (!this._usesDefaultStateKey) {
266
- state = setValue(state, (/** @type {?} */ (key)), storedValue);
335
+ state = setValue(state, key, storedValue);
267
336
  }
268
337
  else {
269
338
  // The `UpdateState` action is dispatched whenever the feature state is added.
@@ -306,16 +375,18 @@ class NgxsStoragePlugin {
306
375
  */
307
376
  nextState => {
308
377
  if (!isInitOrUpdateAction || (isInitOrUpdateAction && hasMigration)) {
309
- for (const key of this._keys) {
378
+ for (const { key, engine } of this._keysWithEngines) {
379
+ /** @type {?} */
380
+ let storedValue = nextState;
310
381
  /** @type {?} */
311
- let val = nextState;
382
+ const storageKey = getStorageKey(key, this._options);
312
383
  if (key !== DEFAULT_STATE_KEY) {
313
- val = getValue(nextState, (/** @type {?} */ (key)));
384
+ storedValue = getValue(nextState, key);
314
385
  }
315
386
  try {
316
387
  /** @type {?} */
317
- const newVal = (/** @type {?} */ (this._options.beforeSerialize))(val, key);
318
- this._engine.setItem((/** @type {?} */ (key)), (/** @type {?} */ (this._options.serialize))(newVal));
388
+ const newStoredValue = (/** @type {?} */ (this._options.beforeSerialize))(storedValue, key);
389
+ engine.setItem(storageKey, (/** @type {?} */ (this._options.serialize))(newStoredValue));
319
390
  }
320
391
  catch (error) {
321
392
  // Caretaker note: we have still left the `typeof` condition in order to avoid
@@ -324,10 +395,10 @@ class NgxsStoragePlugin {
324
395
  if (error &&
325
396
  (error.name === 'QuotaExceededError' ||
326
397
  error.name === 'NS_ERROR_DOM_QUOTA_REACHED')) {
327
- console.error(`The ${key} store value exceeds the browser storage quota: `, val);
398
+ console.error(`The ${storageKey} store value exceeds the browser storage quota: `, storedValue);
328
399
  }
329
400
  else {
330
- console.error(`Error ocurred while serializing the ${key} store value, value not updated, the value obtained from the store: `, val);
401
+ console.error(`Error ocurred while serializing the ${storageKey} store value, value not updated, the value obtained from the store: `, storedValue);
331
402
  }
332
403
  }
333
404
  }
@@ -341,8 +412,7 @@ NgxsStoragePlugin.decorators = [
341
412
  ];
342
413
  /** @nocollapse */
343
414
  NgxsStoragePlugin.ctorParameters = () => [
344
- { type: undefined, decorators: [{ type: Inject, args: [NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
345
- { type: undefined, decorators: [{ type: Inject, args: [STORAGE_ENGINE,] }] },
415
+ { type: undefined, decorators: [{ type: Inject, args: [FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
346
416
  { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
347
417
  ];
348
418
  if (false) {
@@ -350,7 +420,7 @@ if (false) {
350
420
  * @type {?}
351
421
  * @private
352
422
  */
353
- NgxsStoragePlugin.prototype._keys;
423
+ NgxsStoragePlugin.prototype._keysWithEngines;
354
424
  /**
355
425
  * @type {?}
356
426
  * @private
@@ -361,11 +431,6 @@ if (false) {
361
431
  * @private
362
432
  */
363
433
  NgxsStoragePlugin.prototype._options;
364
- /**
365
- * @type {?}
366
- * @private
367
- */
368
- NgxsStoragePlugin.prototype._engine;
369
434
  /**
370
435
  * @type {?}
371
436
  * @private
@@ -408,6 +473,11 @@ class NgxsStoragePluginModule {
408
473
  provide: STORAGE_ENGINE,
409
474
  useFactory: engineFactory,
410
475
  deps: [NGXS_STORAGE_PLUGIN_OPTIONS, PLATFORM_ID]
476
+ },
477
+ {
478
+ provide: FINAL_NGXS_STORAGE_PLUGIN_OPTIONS,
479
+ useFactory: createFinalStoragePluginOptions,
480
+ deps: [Injector, NGXS_STORAGE_PLUGIN_OPTIONS]
411
481
  }
412
482
  ]
413
483
  };
@@ -417,6 +487,27 @@ NgxsStoragePluginModule.decorators = [
417
487
  { type: NgModule }
418
488
  ];
419
489
 
490
+ /**
491
+ * @fileoverview added by tsickle
492
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
493
+ */
494
+ /** @type {?} */
495
+ const LOCAL_STORAGE_ENGINE = new InjectionToken('LOCAL_STORAGE_ENGINE', {
496
+ providedIn: 'root',
497
+ factory: (/**
498
+ * @return {?}
499
+ */
500
+ () => localStorage)
501
+ });
502
+ /** @type {?} */
503
+ const SESSION_STORAGE_ENGINE = new InjectionToken('SESSION_STORAGE_ENGINE', {
504
+ providedIn: 'root',
505
+ factory: (/**
506
+ * @return {?}
507
+ */
508
+ () => sessionStorage)
509
+ });
510
+
420
511
  /**
421
512
  * @fileoverview added by tsickle
422
513
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
@@ -432,5 +523,5 @@ NgxsStoragePluginModule.decorators = [
432
523
  * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
433
524
  */
434
525
 
435
- export { NGXS_STORAGE_PLUGIN_OPTIONS, NgxsStoragePlugin, NgxsStoragePluginModule, STORAGE_ENGINE, USER_OPTIONS as ɵa, storageOptionsFactory as ɵb, engineFactory as ɵc };
526
+ export { LOCAL_STORAGE_ENGINE, NGXS_STORAGE_PLUGIN_OPTIONS, NgxsStoragePlugin, NgxsStoragePluginModule, SESSION_STORAGE_ENGINE, STORAGE_ENGINE, USER_OPTIONS as ɵa, FINAL_NGXS_STORAGE_PLUGIN_OPTIONS as ɵc, createFinalStoragePluginOptions as ɵd, storageOptionsFactory as ɵe, engineFactory as ɵf };
436
527
  //# sourceMappingURL=ngxs-storage-plugin.js.map