@ngxs/storage-plugin 3.7.6 → 3.8.0-dev.master-c341c15

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 (36) hide show
  1. package/bundles/ngxs-storage-plugin.umd.js +467 -499
  2. package/bundles/ngxs-storage-plugin.umd.js.map +1 -1
  3. package/esm2015/index.js +2 -6
  4. package/esm2015/ngxs-storage-plugin.js +2 -8
  5. package/esm2015/src/engines.js +10 -0
  6. package/esm2015/src/internals/final-options.js +16 -0
  7. package/esm2015/src/internals/storage-key.js +21 -0
  8. package/esm2015/src/internals.js +9 -58
  9. package/esm2015/src/public_api.js +3 -6
  10. package/esm2015/src/storage.module.js +16 -15
  11. package/esm2015/src/storage.plugin.js +41 -109
  12. package/esm2015/src/symbols.js +2 -91
  13. package/fesm2015/ngxs-storage-plugin.js +103 -273
  14. package/fesm2015/ngxs-storage-plugin.js.map +1 -1
  15. package/ngxs-storage-plugin.d.ts +1 -2
  16. package/package.json +5 -8
  17. package/src/engines.d.ts +4 -0
  18. package/src/internals/final-options.d.ts +10 -0
  19. package/src/internals/storage-key.d.ts +17 -0
  20. package/src/internals.d.ts +3 -9
  21. package/src/public_api.d.ts +1 -0
  22. package/src/storage.module.d.ts +5 -1
  23. package/src/storage.plugin.d.ts +6 -4
  24. package/src/symbols.d.ts +10 -4
  25. package/bundles/ngxs-storage-plugin.umd.min.js +0 -16
  26. package/bundles/ngxs-storage-plugin.umd.min.js.map +0 -1
  27. package/esm5/index.js +0 -9
  28. package/esm5/ngxs-storage-plugin.js +0 -11
  29. package/esm5/src/internals.js +0 -77
  30. package/esm5/src/public_api.js +0 -8
  31. package/esm5/src/storage.module.js +0 -55
  32. package/esm5/src/storage.plugin.js +0 -244
  33. package/esm5/src/symbols.js +0 -93
  34. package/fesm5/ngxs-storage-plugin.js +0 -473
  35. package/fesm5/ngxs-storage-plugin.js.map +0 -1
  36. package/ngxs-storage-plugin.metadata.json +0 -1
@@ -1,244 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import * as tslib_1 from "tslib";
6
- import { PLATFORM_ID, Inject, Injectable } from '@angular/core';
7
- import { isPlatformServer } from '@angular/common';
8
- import { setValue, getValue, InitState, UpdateState, actionMatcher } from '@ngxs/store';
9
- import { tap } from 'rxjs/operators';
10
- import { STORAGE_ENGINE, NGXS_STORAGE_PLUGIN_OPTIONS } from './symbols';
11
- import { DEFAULT_STATE_KEY } from './internals';
12
- var NgxsStoragePlugin = /** @class */ (function () {
13
- function NgxsStoragePlugin(_options, _engine, _platformId) {
14
- this._options = _options;
15
- this._engine = _engine;
16
- 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));
20
- // 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;
22
- }
23
- /**
24
- * @param {?} state
25
- * @param {?} event
26
- * @param {?} next
27
- * @return {?}
28
- */
29
- NgxsStoragePlugin.prototype.handle = /**
30
- * @param {?} state
31
- * @param {?} event
32
- * @param {?} next
33
- * @return {?}
34
- */
35
- function (state, event, next) {
36
- var _this = this;
37
- var e_1, _a;
38
- if (isPlatformServer(this._platformId) && this._engine === null) {
39
- return next(state, event);
40
- }
41
- /** @type {?} */
42
- var matches = actionMatcher(event);
43
- /** @type {?} */
44
- var isInitAction = matches(InitState);
45
- /** @type {?} */
46
- var isUpdateAction = matches(UpdateState);
47
- /** @type {?} */
48
- var isInitOrUpdateAction = isInitAction || isUpdateAction;
49
- /** @type {?} */
50
- var hasMigration = false;
51
- if (isInitOrUpdateAction) {
52
- /** @type {?} */
53
- var addedStates = isUpdateAction && event.addedStates;
54
- var _loop_1 = function (key) {
55
- // We're checking what states have been added by NGXS and if any of these states should be handled by
56
- // the storage plugin. For instance, we only want to deserialize the `auth` state, NGXS has added
57
- // the `user` state, the storage plugin will be rerun and will do redundant deserialization.
58
- // `usesDefaultStateKey` is necessary to check since `event.addedStates` never contains `@@STATE`.
59
- if (!this_1._usesDefaultStateKey && addedStates) {
60
- // We support providing keys that can be deeply nested via dot notation, for instance,
61
- // `keys: ['myState.myProperty']` is a valid key.
62
- // The state name should always go first. The below code checks if the `key` includes dot
63
- // notation and extracts the state name out of the key.
64
- // Given the `key` is `myState.myProperty`, the `addedStates` will only contain `myState`.
65
- /** @type {?} */
66
- var dotNotationIndex = key.indexOf(DOT);
67
- /** @type {?} */
68
- var stateName = dotNotationIndex > -1 ? key.slice(0, dotNotationIndex) : key;
69
- if (!addedStates.hasOwnProperty(stateName)) {
70
- return "continue";
71
- }
72
- }
73
- /** @type {?} */
74
- var storedValue = this_1._engine.getItem((/** @type {?} */ (key)));
75
- if (storedValue !== 'undefined' && storedValue != null) {
76
- try {
77
- /** @type {?} */
78
- var newVal = (/** @type {?} */ (this_1._options.deserialize))(storedValue);
79
- storedValue = (/** @type {?} */ (this_1._options.afterDeserialize))(newVal, key);
80
- }
81
- catch (_a) {
82
- // Caretaker note: we have still left the `typeof` condition in order to avoid
83
- // creating a breaking change for projects that still use the View Engine.
84
- 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);
86
- }
87
- storedValue = {};
88
- }
89
- if (this_1._options.migrations) {
90
- this_1._options.migrations.forEach((/**
91
- * @param {?} strategy
92
- * @return {?}
93
- */
94
- function (strategy) {
95
- /** @type {?} */
96
- var versionMatch = strategy.version === getValue(storedValue, strategy.versionKey || 'version');
97
- /** @type {?} */
98
- var keyMatch = (!strategy.key && _this._usesDefaultStateKey) || strategy.key === key;
99
- if (versionMatch && keyMatch) {
100
- storedValue = strategy.migrate(storedValue);
101
- hasMigration = true;
102
- }
103
- }));
104
- }
105
- if (!this_1._usesDefaultStateKey) {
106
- state = setValue(state, (/** @type {?} */ (key)), storedValue);
107
- }
108
- else {
109
- // The `UpdateState` action is dispatched whenever the feature state is added.
110
- // The below condition is met only when the `UpdateState` is dispatched.
111
- // Let's assume that we have 2 states `counter` and `@ngxs/router-plugin` state.
112
- // `CounterState` is provided on the root level when calling `NgxsModule.forRoot()`
113
- // and `@ngxs/router-plugin` is provided as a feature state.
114
- // The storage plugin may save the `counter` state value as `10` before.
115
- // The `CounterState` may implement the `ngxsOnInit` hook and call `ctx.setState(999)`.
116
- // The storage plugin will re-hydrate the whole state when the `RouterState` is registered,
117
- // and the `counter` state will again equal `10` (not `999`).
118
- if (storedValue && addedStates && Object.keys(addedStates).length > 0) {
119
- storedValue = Object.keys(addedStates).reduce((/**
120
- * @param {?} accumulator
121
- * @param {?} addedState
122
- * @return {?}
123
- */
124
- function (accumulator, addedState) {
125
- // The `storedValue` may equal the whole state (when the default state key is used).
126
- // If `addedStates` contains only `router` then we want to merge the state only
127
- // with the `router` value.
128
- // Let's assume that the `storedValue` is an object:
129
- // `{ counter: 10, router: {...} }`
130
- // This will pick only the `router` object from the `storedValue` and `counter`
131
- // state will not be re-hydrated unnecessary.
132
- if (storedValue.hasOwnProperty(addedState)) {
133
- accumulator[addedState] = storedValue[addedState];
134
- }
135
- return accumulator;
136
- }), (/** @type {?} */ ({})));
137
- }
138
- state = tslib_1.__assign({}, state, storedValue);
139
- }
140
- }
141
- };
142
- var this_1 = this;
143
- 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);
147
- }
148
- }
149
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
150
- finally {
151
- try {
152
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
153
- }
154
- finally { if (e_1) throw e_1.error; }
155
- }
156
- }
157
- return next(state, event).pipe(tap((/**
158
- * @param {?} nextState
159
- * @return {?}
160
- */
161
- function (nextState) {
162
- var e_2, _a;
163
- if (!isInitOrUpdateAction || (isInitOrUpdateAction && hasMigration)) {
164
- try {
165
- for (var _b = tslib_1.__values(_this._keys), _c = _b.next(); !_c.done; _c = _b.next()) {
166
- var key = _c.value;
167
- /** @type {?} */
168
- var val = nextState;
169
- if (key !== DEFAULT_STATE_KEY) {
170
- val = getValue(nextState, (/** @type {?} */ (key)));
171
- }
172
- try {
173
- /** @type {?} */
174
- var newVal = (/** @type {?} */ (_this._options.beforeSerialize))(val, key);
175
- _this._engine.setItem((/** @type {?} */ (key)), (/** @type {?} */ (_this._options.serialize))(newVal));
176
- }
177
- catch (error) {
178
- // Caretaker note: we have still left the `typeof` condition in order to avoid
179
- // creating a breaking change for projects that still use the View Engine.
180
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
181
- if (error &&
182
- (error.name === 'QuotaExceededError' ||
183
- error.name === 'NS_ERROR_DOM_QUOTA_REACHED')) {
184
- console.error("The " + key + " store value exceeds the browser storage quota: ", val);
185
- }
186
- else {
187
- console.error("Error ocurred while serializing the " + key + " store value, value not updated, the value obtained from the store: ", val);
188
- }
189
- }
190
- }
191
- }
192
- }
193
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
194
- finally {
195
- try {
196
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
197
- }
198
- finally { if (e_2) throw e_2.error; }
199
- }
200
- }
201
- })));
202
- };
203
- NgxsStoragePlugin.decorators = [
204
- { type: Injectable }
205
- ];
206
- /** @nocollapse */
207
- NgxsStoragePlugin.ctorParameters = function () { return [
208
- { type: undefined, decorators: [{ type: Inject, args: [NGXS_STORAGE_PLUGIN_OPTIONS,] }] },
209
- { type: undefined, decorators: [{ type: Inject, args: [STORAGE_ENGINE,] }] },
210
- { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
211
- ]; };
212
- return NgxsStoragePlugin;
213
- }());
214
- export { NgxsStoragePlugin };
215
- if (false) {
216
- /**
217
- * @type {?}
218
- * @private
219
- */
220
- NgxsStoragePlugin.prototype._keys;
221
- /**
222
- * @type {?}
223
- * @private
224
- */
225
- NgxsStoragePlugin.prototype._usesDefaultStateKey;
226
- /**
227
- * @type {?}
228
- * @private
229
- */
230
- NgxsStoragePlugin.prototype._options;
231
- /**
232
- * @type {?}
233
- * @private
234
- */
235
- NgxsStoragePlugin.prototype._engine;
236
- /**
237
- * @type {?}
238
- * @private
239
- */
240
- NgxsStoragePlugin.prototype._platformId;
241
- }
242
- /** @type {?} */
243
- var DOT = '.';
244
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5wbHVnaW4uanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Abmd4cy9zdG9yYWdlLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9zdG9yYWdlLnBsdWdpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRCxPQUFPLEVBRUwsUUFBUSxFQUNSLFFBQVEsRUFDUixTQUFTLEVBQ1QsV0FBVyxFQUNYLGFBQWEsRUFFZCxNQUFNLGFBQWEsQ0FBQztBQUNyQixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUdMLGNBQWMsRUFDZCwyQkFBMkIsRUFDNUIsTUFBTSxXQUFXLENBQUM7QUFDbkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBUWhEO0lBU0UsMkJBQytDLFFBQWtDLEVBQy9DLE9BQXNCLEVBQ3pCLFdBQW1CO1FBRkgsYUFBUSxHQUFSLFFBQVEsQ0FBMEI7UUFDL0MsWUFBTyxHQUFQLE9BQU8sQ0FBZTtRQUN6QixnQkFBVyxHQUFYLFdBQVcsQ0FBUTs7O1FBUjFDLFVBQUssR0FBRyxtQkFBQSxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBWSxDQUFDOztRQUV0Qyx5QkFBb0IsR0FDMUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssaUJBQWlCLENBQUM7SUFNOUQsQ0FBQzs7Ozs7OztJQUVKLGtDQUFNOzs7Ozs7SUFBTixVQUFPLEtBQVUsRUFBRSxLQUFVLEVBQUUsSUFBc0I7UUFBckQsaUJBdUlDOztRQXRJQyxJQUFJLGdCQUFnQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxJQUFJ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QUN0RCx3Q0FBZ0Q7OztJQTZJOUMsR0FBRyxHQUFHLEdBQUciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQTEFURk9STV9JRCwgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBsYWluT2JqZWN0IH0gZnJvbSAnQG5neHMvc3RvcmUvaW50ZXJuYWxzJztcbmltcG9ydCB7XG4gIE5neHNQbHVnaW4sXG4gIHNldFZhbHVlLFxuICBnZXRWYWx1ZSxcbiAgSW5pdFN0YXRlLFxuICBVcGRhdGVTdGF0ZSxcbiAgYWN0aW9uTWF0Y2hlcixcbiAgTmd4c05leHRQbHVnaW5GblxufSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7XG4gIFN0b3JhZ2VFbmdpbmUsXG4gIE5neHNTdG9yYWdlUGx1Z2luT3B0aW9ucyxcbiAgU1RPUkFHRV9FTkdJTkUsXG4gIE5HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OU1xufSBmcm9tICcuL3N5bWJvbHMnO1xuaW1wb3J0IHsgREVGQVVMVF9TVEFURV9LRVkgfSBmcm9tICcuL2ludGVybmFscyc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIFdpbGwgYmUgcHJvdmlkZWQgdGhyb3VnaCBUZXJzZXIgZ2xvYmFsIGRlZmluaXRpb25zIGJ5IEFuZ3VsYXIgQ0xJXG4gKiBkdXJpbmcgdGhlIHByb2R1Y3Rpb24gYnVpbGQuIFRoaXMgaXMgaG93IEFuZ3VsYXIgZG9lcyB0cmVlLXNoYWtpbmcgaW50ZXJuYWxseS5cbiAqL1xuZGVjbGFyZSBjb25zdCBuZ0Rldk1vZGU6IGJvb2xlYW47XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBOZ3hzU3RvcmFnZVBsdWdpbiBpbXBsZW1lbnRzIE5neHNQbHVnaW4ge1xuICAvLyBXZSBjYXN0IHRvIGBzdHJpbmdbXWAgaGVyZSBhcyB3ZSdyZSBzdXJlIHRoYXQgdGhpcyBvcHRpb24gaGFzIGJlZW5cbiAgLy8gdHJhbnNmb3JtZWQgYnkgdGhlIGBzdG9yYWdlT3B0aW9uc0ZhY3RvcnlgIGZ1bmN0aW9uIHRoYXQgcHJvdmlkZWQgdG9rZW4uXG4gIHByaXZhdGUgX2tleXMgPSB0aGlzLl9vcHRpb25zLmtleSBhcyBzdHJpbmdbXTtcbiAgLy8gV2UgZGVmYXVsdCB0byBgW0RFRkFVTFRfU1RBVEVfS0VZXWAgaWYgdGhlIHVzZXIgZXhwbGljaXRseSBkb2VzIG5vdCBwcm92aWRlIHRoZSBga2V5YCBvcHRpb24uXG4gIHByaXZhdGUgX3VzZXNEZWZhdWx0U3RhdGVLZXkgPVxuICAgIHRoaXMuX2tleXMubGVuZ3RoID09PSAxICYmIHRoaXMuX2tleXNbMF0gPT09IERFRkFVTFRfU1RBVEVfS0VZO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoTkdYU19TVE9SQUdFX1BMVUdJTl9PUFRJT05TKSBwcml2YXRlIF9vcHRpb25zOiBOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMsXG4gICAgQEluamVjdChTVE9SQUdFX0VOR0lORSkgcHJpdmF0ZSBfZW5naW5lOiBTdG9yYWdlRW5naW5lLFxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpIHByaXZhdGUgX3BsYXRmb3JtSWQ6IHN0cmluZ1xuICApIHt9XG5cbiAgaGFuZGxlKHN0YXRlOiBhbnksIGV2ZW50OiBhbnksIG5leHQ6IE5neHNOZXh0UGx1Z2luRm4pIHtcbiAgICBpZiAoaXNQbGF0Zm9ybVNlcnZlcih0aGlzLl9wbGF0Zm9ybUlkKSAmJiB0aGlzLl9lbmdpbmUgPT09IG51bGwpIHtcbiAgICAgIHJldHVybiBuZXh0KHN0YXRlLCBldmVudCk7XG4gICAgfVxuXG4gICAgY29uc3QgbWF0Y2hlcyA9IGFjdGlvbk1hdGNoZXIoZXZlbnQpO1xuICAgIGNvbnN0IGlzSW5pdEFjdGlvbiA9IG1hdGNoZXMoSW5pdFN0YXRlKTtcbiAgICBjb25zdCBpc1VwZGF0ZUFjdGlvbiA9IG1hdGNoZXMoVXBkYXRlU3RhdGUpO1xuICAgIGNvbnN0IGlzSW5pdE9yVXBkYXRlQWN0aW9uID0gaXNJbml0QWN0aW9uIHx8IGlzVXBkYXRlQWN0aW9uO1xuICAgIGxldCBoYXNNaWdyYXRpb24gPSBmYWxzZTtcblxuICAgIGlmIChpc0luaXRPclVwZGF0ZUFjdGlvbikge1xuICAgICAgY29uc3QgYWRkZWRTdGF0ZXMgPSBpc1VwZGF0ZUFjdGlvbiAmJiBldmVudC5hZGRlZFN0YXRlcztcblxuICAgICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5fa2V5cykge1xuICAgICAgICAvLyBXZSdyZSBjaGVja2luZyB3aGF0IHN0YXRlcyBoYXZlIGJlZW4gYWRkZWQgYnkgTkdYUyBhbmQgaWYgYW55IG9mIHRoZXNlIHN0YXRlcyBzaG91bGQgYmUgaGFuZGxlZCBieVxuICAgICAgICAvLyB0aGUgc3RvcmFnZSBwbHVnaW4uIEZvciBpbnN0YW5jZSwgd2Ugb25seSB3YW50IHRvIGRlc2VyaWFsaXplIHRoZSBgYXV0aGAgc3RhdGUsIE5HWFMgaGFzIGFkZGVkXG4gICAgICAgIC8vIHRoZSBgdXNlcmAgc3RhdGUsIHRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIGJlIHJlcnVuIGFuZCB3aWxsIGRvIHJlZHVuZGFudCBkZXNlcmlhbGl6YXRpb24uXG4gICAgICAgIC8vIGB1c2VzRGVmYXVsdFN0YXRlS2V5YCBpcyBuZWNlc3NhcnkgdG8gY2hlY2sgc2luY2UgYGV2ZW50LmFkZGVkU3RhdGVzYCBuZXZlciBjb250YWlucyBgQEBTVEFURWAuXG4gICAgICAgIGlmICghdGhpcy5fdXNlc0RlZmF1bHRTdGF0ZUtleSAmJiBhZGRlZFN0YXRlcykge1xuICAgICAgICAgIC8vIFdlIHN1cHBvcnQgcHJvdmlkaW5nIGtleXMgdGhhdCBjYW4gYmUgZGVlcGx5IG5lc3RlZCB2aWEgZG90IG5vdGF0aW9uLCBmb3IgaW5zdGFuY2UsXG4gICAgICAgICAgLy8gYGtleXM6IFsnbXlTdGF0ZS5teVByb3BlcnR5J11gIGlzIGEgdmFsaWQga2V5LlxuICAgICAgICAgIC8vIFRoZSBzdGF0ZSBuYW1lIHNob3VsZCBhbHdheXMgZ28gZmlyc3QuIFRoZSBiZWxvdyBjb2RlIGNoZWNrcyBpZiB0aGUgYGtleWAgaW5jbHVkZXMgZG90XG4gICAgICAgICAgLy8gbm90YXRpb24gYW5kIGV4dHJhY3RzIHRoZSBzdGF0ZSBuYW1lIG91dCBvZiB0aGUga2V5LlxuICAgICAgICAgIC8vIEdpdmVuIHRoZSBga2V5YCBpcyBgbXlTdGF0ZS5teVByb3BlcnR5YCwgdGhlIGBhZGRlZFN0YXRlc2Agd2lsbCBvbmx5IGNvbnRhaW4gYG15U3RhdGVgLlxuICAgICAgICAgIGNvbnN0IGRvdE5vdGF0aW9uSW5kZXggPSBrZXkuaW5kZXhPZihET1QpO1xuICAgICAgICAgIGNvbnN0IHN0YXRlTmFtZSA9IGRvdE5vdGF0aW9uSW5kZXggPiAtMSA/IGtleS5zbGljZSgwLCBkb3ROb3RhdGlvbkluZGV4KSA6IGtleTtcbiAgICAgICAgICBpZiAoIWFkZGVkU3RhdGVzLmhhc093blByb3BlcnR5KHN0YXRlTmFtZSkpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBzdG9yZWRWYWx1ZTogYW55ID0gdGhpcy5fZW5naW5lLmdldEl0ZW0oa2V5ISk7XG5cbiAgICAgICAgaWYgKHN0b3JlZFZhbHVlICE9PSAndW5kZWZpbmVkJyAmJiBzdG9yZWRWYWx1ZSAhPSBudWxsKSB7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IG5ld1ZhbCA9IHRoaXMuX29wdGlvbnMuZGVzZXJpYWxpemUhKHN0b3JlZFZhbHVlKTtcbiAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gdGhpcy5fb3B0aW9ucy5hZnRlckRlc2VyaWFsaXplIShuZXdWYWwsIGtleSk7XG4gICAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICAvLyBDYXJldGFrZXIgbm90ZTogd2UgaGF2ZSBzdGlsbCBsZWZ0IHRoZSBgdHlwZW9mYCBjb25kaXRpb24gaW4gb3JkZXIgdG8gYXZvaWRcbiAgICAgICAgICAgIC8vIGNyZWF0aW5nIGEgYnJlYWtpbmcgY2hhbmdlIGZvciBwcm9qZWN0cyB0aGF0IHN0aWxsIHVzZSB0aGUgVmlldyBFbmdpbmUuXG4gICAgICAgICAgICBpZiAodHlwZW9mIG5nRGV2TW9kZSA9PT0gJ3VuZGVmaW5lZCcgfHwgbmdEZXZNb2RlKSB7XG4gICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAgICAgYEVycm9yIG9jdXJyZWQgd2hpbGUgZGVzZXJpYWxpemluZyB0aGUgJHtrZXl9IHN0b3JlIHZhbHVlLCBmYWxsaW5nIGJhY2sgdG8gZW1wdHkgb2JqZWN0LCB0aGUgdmFsdWUgb2J0YWluZWQgZnJvbSB0aGUgc3RvcmU6IGAsXG4gICAgICAgICAgICAgICAgc3RvcmVkVmFsdWVcbiAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHN0b3JlZFZhbHVlID0ge307XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKHRoaXMuX29wdGlvbnMubWlncmF0aW9ucykge1xuICAgICAgICAgICAgdGhpcy5fb3B0aW9ucy5taWdyYXRpb25zLmZvckVhY2goc3RyYXRlZ3kgPT4ge1xuICAgICAgICAgICAgICBjb25zdCB2ZXJzaW9uTWF0Y2ggPVxuICAgICAgICAgICAgICAgIHN0cmF0ZWd5LnZlcnNpb24gPT09IGdldFZhbHVlKHN0b3JlZFZhbHVlLCBzdHJhdGVneS52ZXJzaW9uS2V5IHx8ICd2ZXJzaW9uJyk7XG4gICAgICAgICAgICAgIGNvbnN0IGtleU1hdGNoID1cbiAgICAgICAgICAgICAgICAoIXN0cmF0ZWd5LmtleSAmJiB0aGlzLl91c2VzRGVmYXVsdFN0YXRlS2V5KSB8fCBzdHJhdGVneS5rZXkgPT09IGtleTtcbiAgICAgICAgICAgICAgaWYgKHZlcnNpb25NYXRjaCAmJiBrZXlNYXRjaCkge1xuICAgICAgICAgICAgICAgIHN0b3JlZFZhbHVlID0gc3RyYXRlZ3kubWlncmF0ZShzdG9yZWRWYWx1ZSk7XG4gICAgICAgICAgICAgICAgaGFzTWlncmF0aW9uID0gdHJ1ZTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgaWYgKCF0aGlzLl91c2VzRGVmYXVsdFN0YXRlS2V5KSB7XG4gICAgICAgICAgICBzdGF0ZSA9IHNldFZhbHVlKHN0YXRlLCBrZXkhLCBzdG9yZWRWYWx1ZSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIC8vIFRoZSBgVXBkYXRlU3RhdGVgIGFjdGlvbiBpcyBkaXNwYXRjaGVkIHdoZW5ldmVyIHRoZSBmZWF0dXJlIHN0YXRlIGlzIGFkZGVkLlxuICAgICAgICAgICAgLy8gVGhlIGJlbG93IGNvbmRpdGlvbiBpcyBtZXQgb25seSB3aGVuIHRoZSBgVXBkYXRlU3RhdGVgIGlzIGRpc3BhdGNoZWQuXG4gICAgICAgICAgICAvLyBMZXQncyBhc3N1bWUgdGhhdCB3ZSBoYXZlIDIgc3RhdGVzIGBjb3VudGVyYCBhbmQgYEBuZ3hzL3JvdXRlci1wbHVnaW5gIHN0YXRlLlxuICAgICAgICAgICAgLy8gYENvdW50ZXJTdGF0ZWAgaXMgcHJvdmlkZWQgb24gdGhlIHJvb3QgbGV2ZWwgd2hlbiBjYWxsaW5nIGBOZ3hzTW9kdWxlLmZvclJvb3QoKWBcbiAgICAgICAgICAgIC8vIGFuZCBgQG5neHMvcm91dGVyLXBsdWdpbmAgaXMgcHJvdmlkZWQgYXMgYSBmZWF0dXJlIHN0YXRlLlxuICAgICAgICAgICAgLy8gVGhlIHN0b3JhZ2UgcGx1Z2luIG1heSBzYXZlIHRoZSBgY291bnRlcmAgc3RhdGUgdmFsdWUgYXMgYDEwYCBiZWZvcmUuXG4gICAgICAgICAgICAvLyBUaGUgYENvdW50ZXJTdGF0ZWAgbWF5IGltcGxlbWVudCB0aGUgYG5neHNPbkluaXRgIGhvb2sgYW5kIGNhbGwgYGN0eC5zZXRTdGF0ZSg5OTkpYC5cbiAgICAgICAgICAgIC8vIFRoZSBzdG9yYWdlIHBsdWdpbiB3aWxsIHJlLWh5ZHJhdGUgdGhlIHdob2xlIHN0YXRlIHdoZW4gdGhlIGBSb3V0ZXJTdGF0ZWAgaXMgcmVnaXN0ZXJlZCxcbiAgICAgICAgICAgIC8vIGFuZCB0aGUgYGNvdW50ZXJgIHN0YXRlIHdpbGwgYWdhaW4gZXF1YWwgYDEwYCAobm90IGA5OTlgKS5cbiAgICAgICAgICAgIGlmIChzdG9yZWRWYWx1ZSAmJiBhZGRlZFN0YXRlcyAmJiBPYmplY3Qua2V5cyhhZGRlZFN0YXRlcykubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgICBzdG9yZWRWYWx1ZSA9IE9iamVjdC5rZXlzKGFkZGVkU3RhdGVzKS5yZWR1Y2UoKGFjY3VtdWxhdG9yLCBhZGRlZFN0YXRlKSA9PiB7XG4gICAgICAgICAgICAgICAgLy8gVGhlIGBzdG9yZWRWYWx1ZWAgbWF5IGVxdWFsIHRoZSB3aG9sZSBzdGF0ZSAod2hlbiB0aGUgZGVmYXVsdCBzdGF0ZSBrZXkgaXMgdXNlZCkuXG4gICAgICAgICAgICAgICAgLy8gSWYgYGFkZGVkU3RhdGVzYCBjb250YWlucyBvbmx5IGByb3V0ZXJgIHRoZW4gd2Ugd2FudCB0byBtZXJnZSB0aGUgc3RhdGUgb25seVxuICAgICAgICAgICAgICAgIC8vIHdpdGggdGhlIGByb3V0ZXJgIHZhbHVlLlxuICAgICAgICAgICAgICAgIC8vIExldCdzIGFzc3VtZSB0aGF0IHRoZSBgc3RvcmVkVmFsdWVgIGlzIGFuIG9iamVjdDpcbiAgICAgICAgICAgICAgICAvLyBgeyBjb3VudGVyOiAxMCwgcm91dGVyOiB7Li4ufSB9YFxuICAgICAgICAgICAgICAgIC8vIFRoaXMgd2lsbCBwaWNrIG9ubHkgdGhlIGByb3V0ZXJgIG9iamVjdCBmcm9tIHRoZSBgc3RvcmVkVmFsdWVgIGFuZCBgY291bnRlcmBcbiAgICAgICAgICAgICAgICAvLyBzdGF0ZSB3aWxsIG5vdCBiZSByZS1oeWRyYXRlZCB1bm5lY2Vzc2FyeS5cbiAgICAgICAgICAgICAgICBpZiAoc3RvcmVkVmFsdWUuaGFzT3duUHJvcGVydHkoYWRkZWRTdGF0ZSkpIHtcbiAgICAgICAgICAgICAgICAgIGFjY3VtdWxhdG9yW2FkZGVkU3RhdGVdID0gc3RvcmVkVmFsdWVbYWRkZWRTdGF0ZV07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHJldHVybiBhY2N1bXVsYXRvcjtcbiAgICAgICAgICAgICAgfSwgPFBsYWluT2JqZWN0Pnt9KTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgc3RhdGUgPSB7IC4uLnN0YXRlLCAuLi5zdG9yZWRWYWx1ZSB9O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBuZXh0KHN0YXRlLCBldmVudCkucGlwZShcbiAgICAgIHRhcChuZXh0U3RhdGUgPT4ge1xuICAgICAgICBpZiAoIWlzSW5pdE9yVXBkYXRlQWN0aW9uIHx8IChpc0luaXRPclVwZGF0ZUFjdGlvbiAmJiBoYXNNaWdyYXRpb24pKSB7XG4gICAgICAgICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5fa2V5cykge1xuICAgICAgICAgICAgbGV0IHZhbCA9IG5leHRTdGF0ZTtcblxuICAgICAgICAgICAgaWYgKGtleSAhPT0gREVGQVVMVF9TVEFURV9LRVkpIHtcbiAgICAgICAgICAgICAgdmFsID0gZ2V0VmFsdWUobmV4dFN0YXRlLCBrZXkhKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgY29uc3QgbmV3VmFsID0gdGhpcy5fb3B0aW9ucy5iZWZvcmVTZXJpYWxpemUhKHZhbCwga2V5KTtcbiAgICAgICAgICAgICAgdGhpcy5fZW5naW5lLnNldEl0ZW0oa2V5ISwgdGhpcy5fb3B0aW9ucy5zZXJpYWxpemUhKG5ld1ZhbCkpO1xuICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgICAgLy8gQ2FyZXRha2VyIG5vdGU6IHdlIGhhdmUgc3RpbGwgbGVmdCB0aGUgYHR5cGVvZmAgY29uZGl0aW9uIGluIG9yZGVyIHRvIGF2b2lkXG4gICAgICAgICAgICAgIC8vIGNyZWF0aW5nIGEgYnJlYWtpbmcgY2hhbmdlIGZvciBwcm9qZWN0cyB0aGF0IHN0aWxsIHVzZSB0aGUgVmlldyBFbmdpbmUuXG4gICAgICAgICAgICAgIGlmICh0eXBlb2YgbmdEZXZNb2RlID09PSAndW5kZWZpbmVkJyB8fCBuZ0Rldk1vZGUpIHtcbiAgICAgICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICAgICBlcnJvciAmJlxuICAgICAgICAgICAgICAgICAgKGVycm9yLm5hbWUgPT09ICdRdW90YUV4Y2VlZGVkRXJyb3InIHx8XG4gICAgICAgICAgICAgICAgICAgIGVycm9yLm5hbWUgPT09ICdOU19FUlJPUl9ET01fUVVPVEFfUkVBQ0hFRCcpXG4gICAgICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKFxuICAgICAgICAgICAgICAgICAgICBgVGhlICR7a2V5fSBzdG9yZSB2YWx1ZSBleGNlZWRzIHRoZSBicm93c2VyIHN0b3JhZ2UgcXVvdGE6IGAsXG4gICAgICAgICAgICAgICAgICAgIHZhbFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgICAgICAgICAgICAgYEVycm9yIG9jdXJyZWQgd2hpbGUgc2VyaWFsaXppbmcgdGhlICR7a2V5fSBzdG9yZSB2YWx1ZSwgdmFsdWUgbm90IHVwZGF0ZWQsIHRoZSB2YWx1ZSBvYnRhaW5lZCBmcm9tIHRoZSBzdG9yZTogYCxcbiAgICAgICAgICAgICAgICAgICAgdmFsXG4gICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG5cbmNvbnN0IERPVCA9ICcuJztcbiJdfQ==
@@ -1,93 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import { InjectionToken } from '@angular/core';
6
- /** @enum {number} */
7
- var StorageOption = {
8
- LocalStorage: 0,
9
- SessionStorage: 1,
10
- };
11
- export { StorageOption };
12
- /**
13
- * @record
14
- */
15
- export function NgxsStoragePluginOptions() { }
16
- if (false) {
17
- /**
18
- * Key for the state slice to store in the storage engine.
19
- * @type {?|undefined}
20
- */
21
- NgxsStoragePluginOptions.prototype.key;
22
- /**
23
- * Storage engine to use. Deaults to localStorage but can provide
24
- *
25
- * sessionStorage or custom implementation of the StorageEngine interface
26
- * @type {?|undefined}
27
- */
28
- NgxsStoragePluginOptions.prototype.storage;
29
- /**
30
- * Migration strategies.
31
- * @type {?|undefined}
32
- */
33
- NgxsStoragePluginOptions.prototype.migrations;
34
- /**
35
- * Serailizer for the object before its pushed into the engine.
36
- * @param {?} obj
37
- * @return {?}
38
- */
39
- NgxsStoragePluginOptions.prototype.serialize = function (obj) { };
40
- /**
41
- * Deserializer for the object before its pulled out of the engine.
42
- * @param {?} obj
43
- * @return {?}
44
- */
45
- NgxsStoragePluginOptions.prototype.deserialize = function (obj) { };
46
- /**
47
- * Method to alter object before serialization.
48
- * @param {?} obj
49
- * @param {?} key
50
- * @return {?}
51
- */
52
- NgxsStoragePluginOptions.prototype.beforeSerialize = function (obj, key) { };
53
- /**
54
- * Method to alter object after deserialization.
55
- * @param {?} obj
56
- * @param {?} key
57
- * @return {?}
58
- */
59
- NgxsStoragePluginOptions.prototype.afterDeserialize = function (obj, key) { };
60
- }
61
- /** @type {?} */
62
- export var NGXS_STORAGE_PLUGIN_OPTIONS = new InjectionToken('NGXS_STORAGE_PLUGIN_OPTION');
63
- /** @type {?} */
64
- export var STORAGE_ENGINE = new InjectionToken('STORAGE_ENGINE');
65
- /**
66
- * @record
67
- */
68
- export function StorageEngine() { }
69
- if (false) {
70
- /** @type {?} */
71
- StorageEngine.prototype.length;
72
- /**
73
- * @param {?} key
74
- * @return {?}
75
- */
76
- StorageEngine.prototype.getItem = function (key) { };
77
- /**
78
- * @param {?} key
79
- * @param {?} val
80
- * @return {?}
81
- */
82
- StorageEngine.prototype.setItem = function (key, val) { };
83
- /**
84
- * @param {?} key
85
- * @return {?}
86
- */
87
- StorageEngine.prototype.removeItem = function (key) { };
88
- /**
89
- * @return {?}
90
- */
91
- StorageEngine.prototype.clear = function () { };
92
- }
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ltYm9scy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL3N0b3JhZ2UtcGx1Z2luLyIsInNvdXJjZXMiOlsic3JjL3N5bWJvbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7OztJQUs3QyxlQUFZO0lBQ1osaUJBQWM7Ozs7OztBQUdoQiw4Q0F5REM7Ozs7OztJQXJEQyx1Q0FBNkI7Ozs7Ozs7SUFPN0IsMkNBQXdCOzs7OztJQUt4Qiw4Q0FvQkk7Ozs7OztJQUtKLGtFQUE2Qjs7Ozs7O0lBSzdCLG9FQUE0Qjs7Ozs7OztJQUs1Qiw2RUFBNkM7Ozs7Ozs7SUFLN0MsOEVBQThDOzs7QUFHaEQsTUFBTSxLQUFPLDJCQUEyQixHQUFHLElBQUksY0FBYyxDQUFDLDRCQUE0QixDQUFDOztBQUUzRixNQUFNLEtBQU8sY0FBYyxHQUFHLElBQUksY0FBYyxDQUFDLGdCQUFnQixDQUFDOzs7O0FBRWxFLG1DQU1DOzs7SUFMQywrQkFBd0I7Ozs7O0lBQ3hCLHFEQUEwQjs7Ozs7O0lBQzFCLDBEQUFxQzs7Ozs7SUFDckMsd0RBQThCOzs7O0lBQzlCLGdEQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU3RvcmFnZUtleSB9IGZyb20gJy4vaW50ZXJuYWxzJztcblxuZXhwb3J0IGNvbnN0IGVudW0gU3RvcmFnZU9wdGlvbiB7XG4gIExvY2FsU3RvcmFnZSxcbiAgU2Vzc2lvblN0b3JhZ2Vcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOZ3hzU3RvcmFnZVBsdWdpbk9wdGlvbnMge1xuICAvKipcbiAgICogS2V5IGZvciB0aGUgc3RhdGUgc2xpY2UgdG8gc3RvcmUgaW4gdGhlIHN0b3JhZ2UgZW5naW5lLlxuICAgKi9cbiAga2V5PzogdW5kZWZpbmVkIHwgU3RvcmFnZUtleTtcblxuICAvKipcbiAgICogU3RvcmFnZSBlbmdpbmUgdG8gdXNlLiBEZWF1bHRzIHRvIGxvY2FsU3RvcmFnZSBidXQgY2FuIHByb3ZpZGVcbiAgICpcbiAgICogc2Vzc2lvblN0b3JhZ2Ugb3IgY3VzdG9tIGltcGxlbWVudGF0aW9uIG9mIHRoZSBTdG9yYWdlRW5naW5lIGludGVyZmFjZVxuICAgKi9cbiAgc3RvcmFnZT86IFN0b3JhZ2VPcHRpb247XG5cbiAgLyoqXG4gICAqIE1pZ3JhdGlvbiBzdHJhdGVnaWVzLlxuICAgKi9cbiAgbWlncmF0aW9ucz86IHtcbiAgICAvKipcbiAgICAgKiBWZXJzaW9uIHRvIGtleSBvZmYuXG4gICAgICovXG4gICAgdmVyc2lvbjogbnVtYmVyIHwgc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogTWV0aG9kIHRvIG1pZ3JhdGUgdGhlIHByZXZpb3VzIHN0YXRlLlxuICAgICAqL1xuICAgIG1pZ3JhdGU6IChzdGF0ZTogYW55KSA9PiBhbnk7XG5cbiAgICAvKipcbiAgICAgKiBLZXkgdG8gbWlncmF0ZS5cbiAgICAgKi9cbiAgICBrZXk/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBLZXkgZm9yIHRoZSB2ZXJzaW9uLiBEZWZhdWx0cyB0byAndmVyc2lvbicuXG4gICAgICovXG4gICAgdmVyc2lvbktleT86IHN0cmluZztcbiAgfVtdO1xuXG4gIC8qKlxuICAgKiBTZXJhaWxpemVyIGZvciB0aGUgb2JqZWN0IGJlZm9yZSBpdHMgcHVzaGVkIGludG8gdGhlIGVuZ2luZS5cbiAgICovXG4gIHNlcmlhbGl6ZT8ob2JqOiBhbnkpOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERlc2VyaWFsaXplciBmb3IgdGhlIG9iamVjdCBiZWZvcmUgaXRzIHB1bGxlZCBvdXQgb2YgdGhlIGVuZ2luZS5cbiAgICovXG4gIGRlc2VyaWFsaXplPyhvYmo6IGFueSk6IGFueTtcblxuICAvKipcbiAgICogTWV0aG9kIHRvIGFsdGVyIG9iamVjdCBiZWZvcmUgc2VyaWFsaXphdGlvbi5cbiAgICovXG4gIGJlZm9yZVNlcmlhbGl6ZT8ob2JqOiBhbnksIGtleTogc3RyaW5nKTogYW55O1xuXG4gIC8qKlxuICAgKiBNZXRob2QgdG8gYWx0ZXIgb2JqZWN0IGFmdGVyIGRlc2VyaWFsaXphdGlvbi5cbiAgICovXG4gIGFmdGVyRGVzZXJpYWxpemU/KG9iajogYW55LCBrZXk6IHN0cmluZyk6IGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IE5HWFNfU1RPUkFHRV9QTFVHSU5fT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbignTkdYU19TVE9SQUdFX1BMVUdJTl9PUFRJT04nKTtcblxuZXhwb3J0IGNvbnN0IFNUT1JBR0VfRU5HSU5FID0gbmV3IEluamVjdGlvblRva2VuKCdTVE9SQUdFX0VOR0lORScpO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0b3JhZ2VFbmdpbmUge1xuICByZWFkb25seSBsZW5ndGg6IG51bWJlcjtcbiAgZ2V0SXRlbShrZXk6IHN0cmluZyk6IGFueTtcbiAgc2V0SXRlbShrZXk6IHN0cmluZywgdmFsOiBhbnkpOiB2b2lkO1xuICByZW1vdmVJdGVtKGtleTogc3RyaW5nKTogdm9pZDtcbiAgY2xlYXIoKTogdm9pZDtcbn1cbiJdfQ==