@sumaris-net/ngx-components 18.14.2 → 18.14.3

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.
@@ -14,22 +14,16 @@ class DecoratorUtils {
14
14
  static createPropertyName(prefix, propertyKey) {
15
15
  return `${prefix}${this.capitalize(propertyKey)}`;
16
16
  }
17
- static validateStateProperty(target, stateVarName) {
18
- if (!production && stateVarName !== 'this') {
19
- return `
20
- if (!${stateVarName}) {
21
- throw new Error('Missing state! Please add a RxState in class: ' + this.constructor.name);
17
+ static validateStateProperty(target, stateObject) {
18
+ if (!production && !stateObject) {
19
+ throw new Error(`Missing state! Please add a RxState in class: ${target.constructor.name}`);
22
20
  }
23
- `;
24
- }
25
- return '';
26
21
  }
27
22
  }
28
23
  const STATE_VAR_NAME_KEY = '__stateName';
29
24
  const DEFAULT_STATE_VAR_NAME = '_state';
30
25
  /**
31
26
  * Decorator to register the RxState property in a component
32
- * Must be used once per class hierarchy
33
27
  */
34
28
  export function RxStateRegister() {
35
29
  return function (target, key) {
@@ -46,49 +40,36 @@ export function RxStateRegister() {
46
40
  }
47
41
  /**
48
42
  * Decorator for RxState properties with getter/setter access
49
- * Creates reactive properties that sync with RxState
50
43
  */
51
44
  export function RxStateProperty(statePropertyName, projectValueReducer) {
52
45
  return function (target, key) {
53
- // Vérification de type au runtime (optionnelle)
54
- const descriptor = Object.getOwnPropertyDescriptor(target, key);
55
- if (descriptor && typeof descriptor.value !== 'undefined') {
56
- // On peut ajouter ici des vérifications de type runtime si nécessaire
57
- }
58
46
  const finalStatePropertyName = statePropertyName || key;
59
47
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || DEFAULT_STATE_VAR_NAME;
60
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
61
- // Generate method names
62
- const getMethodName = DecoratorUtils.createMethodName('_get', key);
63
- const setMethodName = DecoratorUtils.createMethodName('_set', key);
64
- const reducerMethodName = DecoratorUtils.createMethodName('_reduce', key);
65
- // State validation (only in development)
66
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
67
- // Create reducer logic
68
- const reducerLogic = projectValueReducer ? `(state) => this.${reducerMethodName}(state, value)` : '() => value';
69
- // Create dynamic methods using Function constructor for better performance
70
- const getter = new Function(`
71
- return function ${getMethodName}() {
72
- ${stateValidation}
73
- return ${stateObject}.get('${finalStatePropertyName}');
74
- }
75
- `)();
76
- const setter = new Function(`
77
- return function ${setMethodName}(value) {
78
- ${stateValidation}
79
- ${stateObject}.set('${finalStatePropertyName}', ${reducerLogic});
80
- }
81
- `)();
82
- // Attach methods to prototype
83
- target[getMethodName] = getter;
84
- target[setMethodName] = setter;
85
- if (projectValueReducer) {
86
- target[reducerMethodName] = projectValueReducer;
87
- }
48
+ // Create unique property names to avoid conflicts
49
+ const privateValueKey = `__${key}_value`;
50
+ const privateInitializedKey = `__${key}_initialized`;
88
51
  // Define property with getter/setter
89
52
  Object.defineProperty(target, key, {
90
- get: getter,
91
- set: setter,
53
+ get: function () {
54
+ const stateObject = stateVarName ? this[stateVarName] : this;
55
+ DecoratorUtils.validateStateProperty(target, stateObject);
56
+ if (!this[privateInitializedKey]) {
57
+ this[privateValueKey] = stateObject.get(finalStatePropertyName);
58
+ this[privateInitializedKey] = true;
59
+ }
60
+ return this[privateValueKey];
61
+ },
62
+ set: function (value) {
63
+ const stateObject = stateVarName ? this[stateVarName] : this;
64
+ DecoratorUtils.validateStateProperty(target, stateObject);
65
+ this[privateValueKey] = value;
66
+ if (projectValueReducer) {
67
+ stateObject.set(finalStatePropertyName, (state) => projectValueReducer(state, value));
68
+ }
69
+ else {
70
+ stateObject.set(finalStatePropertyName, () => value);
71
+ }
72
+ },
92
73
  enumerable: true,
93
74
  configurable: true,
94
75
  });
@@ -100,118 +81,80 @@ export function RxStateProperty(statePropertyName, projectValueReducer) {
100
81
  }
101
82
  /**
102
83
  * Decorator for RxState observable selectors
103
- * Creates observable properties that select from RxState
104
- *
105
- * ⚠️ IMPORTANT: La propriété décorée DOIT être typée comme Observable<T>
106
- *
107
- * @example
108
- * ```typescript
109
- * @RxStateSelect()
110
- * protected pmfms$: Observable<IPmfm[]>; // ✅ Correct
111
- *
112
- * @RxStateSelect()
113
- * protected badProperty: boolean; // ❌ TypeScript Error
114
- * ```
115
84
  */
116
85
  export function RxStateSelect(statePropertyName, opts) {
117
86
  return function (target, key) {
118
- // Vérification simple basée sur la convention (optionnelle)
87
+ // Convention check
119
88
  if (!production && !key.endsWith('$')) {
120
89
  console.warn(`[RxStateSelect] Convention: Property ${target.constructor?.name}.${key} should end with '$' to indicate it's an Observable`);
121
90
  }
122
- // Determine state property name (remove trailing $ if present)
91
+ // Determine state property name
123
92
  const finalStatePropertyName = statePropertyName || key.replace(/\$$/, '');
124
93
  // Determine state object
125
94
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || opts?.stateName || DEFAULT_STATE_VAR_NAME;
126
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
127
95
  // Create cache property name
128
- const cachePropertyName = `_${key}`;
129
- // Generate method name
130
- const getMethodName = DecoratorUtils.createMethodName('_get', key.replace(/\$$/, '') + '$');
131
- // Create observable selector logic
132
- const observableSelector = finalStatePropertyName === '$'
133
- ? `${stateObject}.$`
134
- : finalStatePropertyName.includes('.')
135
- ? `${stateObject}.select('${finalStatePropertyName.split('.').join("', '")}')`
136
- : `${stateObject}.select('${finalStatePropertyName}')`;
137
- // State validation
138
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
139
- // Create getter with caching
140
- const getter = new Function(`
141
- return function ${getMethodName}() {
142
- ${stateValidation}
143
- if (!this.${cachePropertyName}) {
144
- this.${cachePropertyName} = ${observableSelector};
145
- }
146
- return this.${cachePropertyName};
147
- }
148
- `)();
149
- // Attach method to prototype
150
- target[getMethodName] = getter;
96
+ const cachePropertyName = `__${key}_cache`;
151
97
  // Define property with getter only
152
98
  Object.defineProperty(target, key, {
153
- get: getter,
99
+ get: function () {
100
+ const stateObject = stateVarName ? this[stateVarName] : this;
101
+ DecoratorUtils.validateStateProperty(target, stateObject);
102
+ if (!this[cachePropertyName]) {
103
+ if (finalStatePropertyName === '$') {
104
+ this[cachePropertyName] = stateObject.$;
105
+ }
106
+ else if (finalStatePropertyName.includes('.')) {
107
+ const path = finalStatePropertyName.split('.');
108
+ this[cachePropertyName] = stateObject.select(...path);
109
+ }
110
+ else {
111
+ this[cachePropertyName] = stateObject.select(finalStatePropertyName);
112
+ }
113
+ }
114
+ return this[cachePropertyName];
115
+ },
154
116
  enumerable: true,
155
117
  configurable: false,
156
118
  });
157
119
  // Development logging
158
120
  if (!production) {
159
- console.debug(`[RxStateSelect] ${target.constructor?.name}.${key} -> ${observableSelector}`);
121
+ console.debug(`[RxStateSelect] ${target.constructor?.name}.${key} -> state.select('${finalStatePropertyName}')`);
160
122
  }
161
123
  };
162
124
  }
163
125
  /**
164
126
  * Utility decorator to create computed observables from state
165
- *
166
- * ⚠️ IMPORTANT: La propriété décorée DOIT être typée comme Observable<T>
167
127
  */
168
128
  export function RxStateComputed(dependencies, computeFn, opts) {
169
129
  return function (target, key) {
170
- // Vérification simple basée sur la convention (optionnelle)
130
+ // Convention check
171
131
  if (!production && !key.endsWith('$')) {
172
132
  console.warn(`[RxStateComputed] Convention: Property ${target.constructor?.name}.${key} should end with '$' to indicate it's an Observable`);
173
133
  }
174
134
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || opts?.stateName || DEFAULT_STATE_VAR_NAME;
175
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
176
- const cachePropertyName = `_${key}`;
177
- const getMethodName = DecoratorUtils.createMethodName('_get', key.replace(/\$$/, '') + '$');
178
- const computeMethodName = DecoratorUtils.createMethodName('_compute', key);
179
- const keyCompareMapPropertyName = DecoratorUtils.createPropertyName(`_compareMap`, key);
180
- // State validation
181
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
182
- // Create dependencies array as string for code generation
183
- const dependenciesStr = dependencies.map((dep) => `'${dep}'`).join(', ');
184
- // Create the compute method as string, for code generation
185
- const computeMethodNameStr = computeFn ? `, (slice) => this.${computeMethodName}(slice)` : '';
186
- // Create the comparator map function as string, for code generation
187
- const keyCompareMapStr = opts?.keyCompareMap ? `, this.${keyCompareMapPropertyName}` : '';
188
- // Create getter with caching using RxState's native multi-select + pipe(map())
189
- const getter = new Function(`
190
- return function ${getMethodName}() {
191
- ${stateValidation}
192
- if (!this.${cachePropertyName}) {
193
- const { map } = require('rxjs/operators');
194
- this.${cachePropertyName} = ${stateObject}.select([${dependenciesStr}]${computeMethodNameStr}${keyCompareMapStr});
195
- }
196
- return this.${cachePropertyName};
197
- }
198
- `)();
199
- // Attach compute method, optional keyCompareMap with unique name, and getter to prototype
200
- if (computeFn)
201
- target[computeMethodName] = computeFn;
202
- if (opts?.keyCompareMap)
203
- target[keyCompareMapPropertyName] = opts.keyCompareMap;
204
- target[getMethodName] = getter;
135
+ const cachePropertyName = `__${key}_cache`;
205
136
  // Define property with getter only
206
137
  Object.defineProperty(target, key, {
207
- get: getter,
138
+ get: function () {
139
+ const stateObject = stateVarName ? this[stateVarName] : this;
140
+ DecoratorUtils.validateStateProperty(target, stateObject);
141
+ if (!this[cachePropertyName]) {
142
+ let observable = stateObject.select(dependencies, opts?.keyCompareMap);
143
+ if (computeFn) {
144
+ const { map } = require('rxjs/operators');
145
+ observable = observable.pipe(map(computeFn));
146
+ }
147
+ this[cachePropertyName] = observable;
148
+ }
149
+ return this[cachePropertyName];
150
+ },
208
151
  enumerable: true,
209
152
  configurable: false,
210
153
  });
211
154
  // Development logging
212
155
  if (!production) {
213
- console.debug(`[RxStateComputed] ${target.constructor?.name}.${key} -> ${stateObject}.select([${dependenciesStr}]).pipe(map(computeFn))`);
156
+ console.debug(`[RxStateComputed] ${target.constructor?.name}.${key} -> state.select([${dependencies.map((d) => `'${d}'`).join(', ')}])`);
214
157
  }
215
158
  };
216
159
  }
217
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicngtc3RhdGUuZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvc2hhcmVkL3J4LXN0YXRlL3J4LXN0YXRlLmRlY29yYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUF1QixPQUFPLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVqRSxJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUM7QUFDdkIsTUFBTSxVQUFVLHFCQUFxQjtJQUNuQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0FBQ3BCLENBQUM7QUFRRCx5QkFBeUI7QUFDekIsTUFBTSxjQUFjO0lBQ2xCLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBVztRQUMzQixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE1BQWMsRUFBRSxXQUFtQjtRQUN6RCxPQUFPLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztJQUNwRCxDQUFDO0lBQ0QsTUFBTSxDQUFDLGtCQUFrQixDQUFDLE1BQWMsRUFBRSxXQUFtQjtRQUMzRCxPQUFPLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLHFCQUFxQixDQUFDLE1BQVcsRUFBRSxZQUFvQjtRQUM1RCxJQUFJLENBQUMsVUFBVSxJQUFJLFlBQVksS0FBSyxNQUFNLEVBQUUsQ0FBQztZQUMzQyxPQUFPO2VBQ0UsWUFBWTs7O09BR3BCLENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0NBQ0Y7QUFFRCxNQUFNLGtCQUFrQixHQUFHLGFB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c0I7UUFDdEIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2hCLE9BQU8sQ0FBQyxLQUFLLENBQ1gscUJBQXFCLE1BQU0sQ0FBQyxXQUFXLEVBQUUsSUFBSSxJQUFJLEdBQWEsT0FBTyxXQUFXLFlBQVksZUFBZSx5QkFBeUIsQ0FDckksQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUHJvamVjdFZhbHVlUmVkdWNlciwgUnhTdGF0ZSB9IGZyb20gJ0ByeC1hbmd1bGFyL3N0YXRlJztcblxubGV0IHByb2R1Y3Rpb24gPSBmYWxzZTtcbmV4cG9ydCBmdW5jdGlvbiBlbmFibGVSeFN0YXRlUHJvZE1vZGUoKSB7XG4gIHByb2R1Y3Rpb24gPSB0cnVlO1xufVxuXG5kZWNsYXJlIHR5cGUgQ29uc3RydWN0b3I8VCA9IGFueT4gPSBuZXcgKC4uLmFyZ3M6IGFueVtdKSA9PiBUO1xuXG50eXBlIE9ic2VydmFibGVQcm9wZXJ0eURlY29yYXRvcjxUPiA9IDxLIGV4dGVuZHMgUHJvcGVydHlLZXk+KHRhcmdldDogYW55LCBwcm9wZXJ0eUtleTogSykgPT4gdm9pZDtcblxudHlwZSBTdGF0ZVByb3BlcnR5RGVjb3JhdG9yPFQ+ID0gPEsgZXh0ZW5kcyBQcm9wZXJ0eUtleT4odGFyZ2V0OiBhbnksIHByb3BlcnR5S2V5OiBLKSA9PiB2b2lkO1xuXG4vLyBVdGlsaXR5IGZvciBkZWNvcmF0b3JzXG5jbGFzcyBEZWNvcmF0b3JVdGlscyB7XG4gIHN0YXRpYyBjYXBpdGFsaXplKHN0cjogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gc3RyLmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpICsgc3RyLnNsaWNlKDEpO1xuICB9XG5cbiAgc3RhdGljIGNyZWF0ZU1ldGhvZE5hbWUocHJlZml4OiBzdHJpbmcsIHByb3BlcnR5S2V5OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHtwcmVmaXh9JHt0aGlzLmNhcGl0YWxpemUocHJvcGVydHlLZXkpfWA7XG4gIH1cbiAgc3RhdGljIGNyZWF0ZVByb3BlcnR5TmFtZShwcmVmaXg6IHN0cmluZywgcHJvcGVydHlLZXk6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3ByZWZpeH0ke3RoaXMuY2FwaXRhbGl6ZShwcm9wZXJ0eUtleSl9YDtcbiAgfVxuXG4gIHN0YXRpYyB2YWxpZGF0ZVN0YXRlUHJvcGVydHkodGFyZ2V0OiBhbnksIHN0YXRlVmFyTmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBpZiAoIXByb2R1Y3Rpb24gJiYgc3RhdGVWYXJOYW1lICE9PSAndGhpcycpIHtcbiAgICAgIHJldHVybiBgXG4gICAgICAgIGlmICghJHtzdGF0ZVZhck5hbWV9KSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHN0YXRlISBQbGVhc2UgYWRkIGEgUnhTdGF0ZSBpbiBjbGFzczogJyArIHRoaXMuY29uc3RydWN0b3IubmFtZSk7XG4gICAgICAgIH1cbiAgICAgIGA7XG4gICAgfVxuICAgIHJldHVybiAnJztcbiAgfVxufVxuXG5jb25zdCBTVEFURV9WQVJfTkFNRV9LRVkgPSAnX19zdGF0ZU5hbWUnO1xuY29uc3QgREVGQVVMVF9TVEFURV9WQVJfTkFNRSA9ICdfc3RhdGUnO1xuXG4vKipcbiAqIERlY29yYXRvciB0byByZWdpc3RlciB0aGUgUnhTdGF0ZSBwcm9wZXJ0eSBpbiBhIGNvbXBvbmVudFxuICogTXVzdCBiZSB1c2VkIG9uY2UgcGVyIGNsYXNzIGhpZXJhcmNoeVxuICovXG5leHBvcnQgZnVuY3Rpb24gUnhTdGF0ZVJlZ2lzdGVyKCk6IFByb3BlcnR5RGVjb3JhdG9yIHtcbiAgcmV0dXJuIGZ1bmN0aW9uICh0YXJnZXQ6IENvbnN0cnVjdG9yPGFueT4sIGtleTogc3RyaW5nKSB7XG4gICAgaWYgKHRhcmdldFtTVEFURV9WQVJfTkFNRV9LRVldKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBkZWZpbmUgbW9yZSB0aGFuIG9uZSBAUnhTdGF0ZVJlZ2lzdGVyKCkgaW4gY2xhc3MgaGllcmFyY2h5LiBGb3VuZDogJHt0YXJnZXRbU1RBVEVfVkFSX05BTUVfS0VZXX0gYW5kICR7a2V5fWApO1xuICAgIH1cblxuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIFNUQVRFX1ZBUl9OQU1FX0tFWSwge1xuICAgICAgdmFsdWU6IGtleSxcbiAgICAgIHdyaXRhYmxlOiBmYWxzZSxcbiAgICAgIGVudW1lcmFibGU6IGZhbHNlLFxuICAgICAgY29uZmlndXJhYmxlOiBmYWxzZSxcbiAgICB9KTtcbiAgfTtcbn1cblxuLyoqXG4gKiBEZWNvcmF0b3IgZm9yIFJ4U3RhdGUgcHJvcGVydGllcyB3aXRoIGdldHRlci9zZXR0ZXIgYWNjZXNzXG4gKiBDcmVhdGVzIHJlYWN0aXZlIHByb3BlcnRpZXMgdGhhdCBzeW5jIHdpdGggUnhTdGF0ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gUnhTdGF0ZVByb3BlcnR5PFQgPSBhbnksIEsgZXh0ZW5kcyBrZXlvZiBUID0gYW55LCBWIGV4dGVuZHMgVFtLXSA9IGFueT4oXG4gIHN0YXRlUHJvcGVydHlOYW1lPzogc3RyaW5nIHwgSyxcbiAgcHJvamVjdFZhbHVlUmVkdWNlcj86IFByb2plY3RWYWx1ZVJlZHVjZXI8VCwgSywgVj5cbik6IFN0YXRlUHJvcGVydHlEZWNvcmF0b3I8Vj4ge1xuICByZXR1cm4gZnVuY3Rpb24gPFAgZXh0ZW5kcyBQcm9wZXJ0eUtleT4odGFyZ2V0OiBhbnksIGtleTogUCkge1xuICAgIC8vIFbDqXJpZmljYXRpb24gZGUgdHlwZSBhdSBydW50aW1lIChvcHRpb25uZWxsZSlcbiAgICBjb25zdCBkZXNjcmlwdG9yID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcih0YXJnZXQsIGtleSk7XG4gICAgaWYgKGRlc2NyaXB0b3IgJiYgdHlwZW9mIGRlc2NyaXB0b3IudmFsdWUgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAvLyBPbiBwZXV0IGFqb3V0ZXIgaWNpIGRlcyB2w6lyaWZpY2F0aW9ucyBkZSB0eXBlIHJ1bnRpbWUgc2kgbsOpY2Vzc2FpcmVcbiAgICB9XG5cbiAgICBjb25zdCBmaW5hbFN0YXRlUHJvcGVydHlOYW1lID0gKHN0YXRlUHJvcGVydHlOYW1lIGFzIHN0cmluZykgfHwgKGtleSBhcyBzdHJpbmcpO1xuICAgIGNvbnN0IHN0YXRlVmFyTmFtZSA9IHRhcmdldCBpbnN0YW5jZW9mIFJ4U3RhdGUgPyBudWxsIDogdGFyZ2V0W1NUQVRFX1ZBUl9OQU1FX0tFWV0gfHwgREVGQVVMVF9TVEFURV9WQVJfTkFNRTtcbiAgICBjb25zdCBzdGF0ZU9iamVjdCA9IHN0YXRlVmFyTmFtZSA/IGB0aGlzLiR7c3RhdGVWYXJOYW1lfWAgOiAndGhpcyc7XG5cbiAgICAvLyBHZW5lcmF0ZSBtZXRob2QgbmFtZXNcbiAgICBjb25zdCBnZXRNZXRob2ROYW1lID0gRGVjb3JhdG9yVXRpbHMuY3JlYXRlTWV0aG9kTmFtZSgnX2dldCcsIGtleSBhcyBzdHJpbmcpO1xuICAgIGNvbnN0IHNldE1ldGhvZE5hbWUgPSBEZWNvcmF0b3JVdGlscy5jcmVhdGVNZXRob2ROYW1lKCdfc2V0Jywga2V5IGFzIHN0cmluZyk7XG4gICAgY29uc3QgcmVkdWNlck1ldGhvZE5hbWUgPSBEZWNvcmF0b3JVdGlscy5jcmVhdGVNZXRob2ROYW1lKCdfcmVkdWNlJywga2V5IGFzIHN0cmluZyk7XG5cbiAgICAvLyBTdGF0ZSB2YWxpZGF0aW9uIChvbmx5IGluIGRldmVsb3BtZW50KVxuICAgIGNvbnN0IHN0YXRlVmFsaWRhdGlvbiA9IERlY29yYXRvclV0aWxzLnZhbGlkYXRlU3RhdGVQcm9wZXJ0eSh0YXJnZXQsIHN0YXRlT2JqZWN0KTtcblxuICAgIC8vIENyZWF0ZSByZWR1Y2VyIGxvZ2ljXG4gICAgY29uc3QgcmVkdWNlckxvZ2ljID0gcHJvamVjdFZhbHVlUmVkdWNlciA/IGAoc3RhdGUpID0+IHRoaXMuJHtyZWR1Y2VyTWV0aG9kTmFtZX0oc3RhdGUsIHZhbHVlKWAgOiAnKCkgPT4gdmFsdWUnO1xuXG4gICAgLy8gQ3JlYXRlIGR5bmFtaWMgbWV0aG9kcyB1c2luZyBGdW5jdGlvbiBjb25zdHJ1Y3RvciBmb3IgYmV0dGVyIHBlcmZvcm1hbmNlXG4gICAgY29uc3QgZ2V0dGVyID0gbmV3IEZ1bmN0aW9uKGBcbiAgICAgIHJldHVybiBmdW5jdGlvbiAke2dldE1ldGhvZE5hbWV9KCkge1xuICAgICAgICAke3N0YXRlVmFsaWRhdGlvbn1cbiAgICAgICAgcmV0dXJuICR7c3RhdGVPYmplY3R9LmdldCgnJHtmaW5hbFN0YXRlUHJvcGVydHlOYW1lfScpO1xuICAgICAgfVxuICAgIGApKCk7XG5cbiAgICBjb25zdCBzZXR0ZXIgPSBuZXcgRnVuY3Rpb24oYFxuICAgICAgcmV0dXJuIGZ1bmN0aW9uICR7c2V0TWV0aG9kTmFtZX0odmFsdWUpIHtcbiAgICAgICAgJHtzdGF0ZVZhbGlkYXRpb259XG4gICAgICAgICR7c3RhdGVPYmplY3R9LnNldCgnJHtmaW5hbFN0YXRlUHJvcGVydHlOYW1lfScsICR7cmVkdWNlckxvZ2ljfSk7XG4gICAgICB9XG4gICAgYCkoKTtcblxuICAgIC8vIEF0dGFjaCBtZXRob2RzIHRvIHByb3RvdHlwZVxuICAgIHRhcmdldFtnZXRNZXRob2ROYW1lXSA9IGdldHRlcjtcbiAgICB0YXJnZXRbc2V0TWV0aG9kTmFtZV0gPSBzZXR0ZXI7XG4gICAgaWYgKHByb2plY3RWYWx1ZVJlZHVjZXIpIHtcbiAgICAgIHRhcmdldFtyZWR1Y2VyTWV0aG9kTmFtZV0gPSBwcm9qZWN0VmFsdWVSZWR1Y2VyO1xuICAgIH1cblxuICAgIC8vIERlZmluZSBwcm9wZXJ0eSB3aXRoIGdldHRlci9zZXR0ZXJcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHtcbiAgICAgIGdldDogZ2V0dGVyLFxuICAgICAgc2V0OiBzZXR0ZXIsXG4gICAgICBlbnVtZXJhYmxlOiB0cnVlLFxuICAgICAgY29uZmlndXJhYmxlOiB0cnVlLFxuICAgIH0pO1xuXG4gICAgLy8gRGV2ZWxvcG1lbnQgbG9nZ2luZ1xuICAgIGlmICghcHJvZHVjdGlvbikge1xuICAgICAgY29uc29sZS5kZWJ1ZyhgW1J4U3RhdGVQcm9wZXJ0eV0gJHt0YXJnZXQuY29uc3RydWN0b3I/Lm5hbWV9LiR7a2V5IGFzIHN0cmluZ30gLT4gc3RhdGUuJHtmaW5hbFN0YXRlUHJvcGVydHlOYW1lfWApO1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBEZWNvcmF0b3IgZm9yIFJ4U3RhdGUgb2JzZXJ2YWJsZSBzZWxlY3RvcnNcbiAqIENyZWF0ZXMgb2JzZXJ2YWJsZSBwcm9wZXJ0aWVzIHRoYXQgc2VsZWN0IGZyb20gUnhTdGF0ZVxuICpcbiAqIOKaoO+4jyBJTVBPUlRBTlQ6IExhIHByb3ByacOpdMOpIGTDqWNvcsOpZSBET0lUIMOqdHJlIHR5cMOpZSBjb21tZSBPYnNlcnZhYmxlPFQ+XG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIEBSeFN0YXRlU2VsZWN0KClcbiAqIHByb3RlY3RlZCBwbWZtcyQ6IE9ic2VydmFibGU8SVBtZm1bXT47IC8vIOKchSBDb3JyZWN0XG4gKlxuICogQFJ4U3RhdGVTZWxlY3QoKVxuICogcHJvdGVjdGVkIGJhZFByb3BlcnR5OiBib29sZWFuOyAvLyDinYwgVHlwZVNjcmlwdCBFcnJvclxuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBSeFN0YXRlU2VsZWN0PFQgPSBhbnksIFIgPSBUW2tleW9mIFRdPihcbiAgc3RhdGVQcm9wZXJ0eU5hbWU/OiBzdHJpbmcgfCBrZXlvZiBUIHwgJyQnLFxuICBvcHRzPzoge1xuICAgIHN0YXRlTmFtZT86IHN0cmluZztcbiAgfVxuKTogT2JzZXJ2YWJsZVByb3BlcnR5RGVjb3JhdG9yPE9ic2VydmFibGU8Uj4+IHtcbiAgcmV0dXJuIGZ1bmN0aW9uIDxQIGV4dGVuZHMgUHJvcGVydHlLZXk+KHRhcmdldDogYW55LCBrZXk6IFApIHtcbiAgICAvLyBWw6lyaWZpY2F0aW9uIHNpbXBsZSBiYXPDqWUgc3VyIGxhIGNvbnZlbnRpb24gKG9wdGlvbm5lbGxlKVxuICAgIGlmICghcHJvZHVjdGlvbiAmJiAhKGtleSBhcyBzdHJpbmcpLmVuZHNXaXRoKCckJykpIHtcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgYFtSeFN0YXRlU2VsZWN0XSBDb252ZW50aW9uOiBQcm9wZXJ0eSAke3RhcmdldC5jb25zdHJ1Y3Rvcj8ubmFtZX0uJHtrZXkgYXMgc3RyaW5nfSBzaG91bGQgZW5kIHdpdGggJyQnIHRvIGluZGljYXRlIGl0J3MgYW4gT2JzZXJ2YWJsZWBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgLy8gRGV0ZXJtaW5lIHN0YXRlIHByb3BlcnR5IG5hbWUgKHJlbW92ZSB0cmFpbGluZyAkIGlmIHByZXNlbnQpXG4gICAgY29uc3QgZmluYWxTdGF0ZVByb3BlcnR5TmFtZSA9IChzdGF0ZVByb3BlcnR5TmFtZSBhcyBzdHJpbmcpIHx8IChrZXkgYXMgc3RyaW5nKS5yZXBsYWNlKC9cXCQkLywgJycpO1xuXG4gICAgLy8gRGV0ZXJtaW5lIHN0YXRlIG9iamVjdFxuICAgIGNvbnN0IHN0YXRlVmFyTmFtZSA9IHRhcmdldCBpbnN0YW5jZW9mIFJ4U3RhdGUgPyBudWxsIDogdGFyZ2V0W1NUQVRFX1ZBUl9OQU1FX0tFWV0gfHwgb3B0cz8uc3RhdGVOYW1lIHx8IERFRkFVTFRfU1RBVEVfVkFSX05BTUU7XG4gICAgY29uc3Qgc3RhdGVPYmplY3QgPSBzdGF0ZVZhck5hbWUgPyBgdGhpcy4ke3N0YXRlVmFyTmFtZX1gIDogJ3RoaXMnO1xuXG4gICAgLy8gQ3JlYXRlIGNhY2hlIHByb3BlcnR5IG5hbWVcbiAgICBjb25zdCBjYWNoZVByb3BlcnR5TmFtZSA9IGBfJHtrZXkgYXMgc3RyaW5nfWA7XG5cbiAgICAvLyBHZW5lcmF0ZSBtZXRob2QgbmFtZVxuICAgIGNvbnN0IGdldE1ldGhvZE5hbWUgPSBEZWNvcmF0b3JVdGlscy5jcmVhdGVNZXRob2ROYW1lKCdfZ2V0JywgKGtleSBhcyBzdHJpbmcpLnJlcGxhY2UoL1xcJCQvLCAnJykgKyAnJCcpO1xuXG4gICAgLy8gQ3JlYXRlIG9ic2VydmFibGUgc2VsZWN0b3IgbG9naWNcbiAgICBjb25zdCBvYnNlcnZhYmxlU2VsZWN0b3IgPVxuICAgICAgZmluYWxTdGF0ZVByb3BlcnR5TmFtZSA9PT0gJyQnXG4gICAgICAgID8gYCR7c3RhdGVPYmplY3R9LiRgXG4gICAgICAgIDogZmluYWxTdGF0ZVByb3BlcnR5TmFtZS5pbmNsdWRlcygnLicpXG4gICAgICAgICAgPyBgJHtzdGF0ZU9iamVjdH0uc2VsZWN0KCcke2ZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUuc3BsaXQoJy4nKS5qb2luKFwiJywgJ1wiKX0nKWBcbiAgICAgICAgICA6IGAke3N0YXRlT2JqZWN0fS5zZWxlY3QoJyR7ZmluYWxTdGF0ZVByb3BlcnR5TmFtZX0nKWA7XG5cbiAgICAvLyBTdGF0ZSB2YWxpZGF0aW9uXG4gICAgY29uc3Qgc3RhdGVWYWxpZGF0aW9uID0gRGVjb3JhdG9yVXRpbHMudmFsaWRhdGVTdGF0ZVByb3BlcnR5KHRhcmdldCwgc3RhdGVPYmplY3QpO1xuXG4gICAgLy8gQ3JlYXRlIGdldHRlciB3aXRoIGNhY2hpbmdcbiAgICBjb25zdCBnZXR0ZXIgPSBuZXcgRnVuY3Rpb24oYFxuICAgICAgcmV0dXJuIGZ1bmN0aW9uICR7Z2V0TWV0aG9kTmFtZX0oKSB7XG4gICAgICAgICR7c3RhdGVWYWxpZGF0aW9ufVxuICAgICAgICBpZiAoIXRoaXMuJHtjYWNoZVByb3BlcnR5TmFtZX0pIHtcbiAgICAgICAgICB0aGlzLiR7Y2FjaGVQcm9wZXJ0eU5hbWV9ID0gJHtvYnNlcnZhYmxlU2VsZWN0b3J9O1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLiR7Y2FjaGVQcm9wZXJ0eU5hbWV9O1xuICAgICAgfVxuICAgIGApKCk7XG5cbiAgICAvLyBBdHRhY2ggbWV0aG9kIHRvIHByb3RvdHlwZVxuICAgIHRhcmdldFtnZXRNZXRob2ROYW1lXSA9IGdldHRlcjtcblxuICAgIC8vIERlZmluZSBwcm9wZXJ0eSB3aXRoIGdldHRlciBvbmx5XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCB7XG4gICAgICBnZXQ6IGdldHRlcixcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IGZhbHNlLFxuICAgIH0pO1xuXG4gICAgLy8gRGV2ZWxvcG1lbnQgbG9nZ2luZ1xuICAgIGlmICghcHJvZHVjdGlvbikge1xuICAgICAgY29uc29sZS5kZWJ1ZyhgW1J4U3RhdGVTZWxlY3RdICR7dGFyZ2V0LmNvbnN0cnVjdG9yPy5uYW1lfS4ke2tleSBhcyBzdHJpbmd9IC0+ICR7b2JzZXJ2YWJsZVNlbGVjdG9yfWApO1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBVdGlsaXR5IGRlY29yYXRvciB0byBjcmVhdGUgY29tcHV0ZWQgb2JzZXJ2YWJsZXMgZnJvbSBzdGF0ZVxuICpcbiAqIOKaoO+4jyBJTVBPUlRBTlQ6IExhIHByb3ByacOpdMOpIGTDqWNvcsOpZSBET0lUIMOqdHJlIHR5cMOpZSBjb21tZSBPYnNlcnZhYmxlPFQ+XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBSeFN0YXRlQ29tcHV0ZWQ8VCA9IGFueSwgSyBleHRlbmRzIGtleW9mIFQgPSBhbnksIFIgPSBhbnk+KFxuICBkZXBlbmRlbmNpZXM6IEtbXSxcbiAgY29tcHV0ZUZuPzogKHNsaWNlOiBQaWNrPFQsIEs+KSA9PiBSLFxuICBvcHRzPzoge1xuICAgIHN0YXRlTmFtZT86IHN0cmluZztcbiAgICBrZXlDb21wYXJlTWFwPzogYW55O1xuICB9XG4pOiBPYnNlcnZhYmxlUHJvcGVydHlEZWNvcmF0b3I8T2JzZXJ2YWJsZTxSPj4ge1xuICByZXR1cm4gZnVuY3Rpb24gPFAgZXh0ZW5kcyBQcm9wZXJ0eUtleT4odGFyZ2V0OiBhbnksIGtleTogUCkge1xuICAgIC8vIFbDqXJpZmljYXRpb24gc2ltcGxlIGJhc8OpZSBzdXIgbGEgY29udmVudGlvbiAob3B0aW9ubmVsbGUpXG4gICAgaWYgKCFwcm9kdWN0aW9uICYmICEoa2V5IGFzIHN0cmluZykuZW5kc1dpdGgoJyQnKSkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICBgW1J4U3RhdGVDb21wdXRlZF0gQ29udmVudGlvbjogUHJvcGVydHkgJHt0YXJnZXQuY29uc3RydWN0b3I/Lm5hbWV9LiR7a2V5IGFzIHN0cmluZ30gc2hvdWxkIGVuZCB3aXRoICckJyB0byBpbmRpY2F0ZSBpdCdzIGFuIE9ic2VydmFibGVgXG4gICAgICApO1xuICAgIH1cbiAgICBjb25zdCBzdGF0ZVZhck5hbWUgPSB0YXJnZXQgaW5zdGFuY2VvZiBSeFN0YXRlID8gbnVsbCA6IHRhcmdldFtTVEFURV9WQVJfTkFNRV9LRVldIHx8IG9wdHM/LnN0YXRlTmFtZSB8fCBERUZBVUxUX1NUQVRFX1ZBUl9OQU1FO1xuICAgIGNvbnN0IHN0YXRlT2JqZWN0ID0gc3RhdGVWYXJOYW1lID8gYHRoaXMuJHtzdGF0ZVZhck5hbWV9YCA6ICd0aGlzJztcblxuICAgIGNvbnN0IGNhY2hlUHJvcGVydHlOYW1lID0gYF8ke2tleSBhcyBzdHJpbmd9YDtcbiAgICBjb25zdCBnZXRNZXRob2ROYW1lID0gRGVjb3JhdG9yVXRpbHMuY3JlYXRlTWV0aG9kTmFtZSgnX2dldCcsIChrZXkgYXMgc3RyaW5nKS5yZXBsYWNlKC9cXCQkLywgJycpICsgJyQnKTtcbiAgICBjb25zdCBjb21wdXRlTWV0aG9kTmFtZSA9IERlY29yYXRvclV0aWxzLmNyZWF0ZU1ldGhvZE5hbWUoJ19jb21wdXRlJywga2V5IGFzIHN0cmluZyk7XG4gICAgY29uc3Qga2V5Q29tcGFyZU1hcFByb3BlcnR5TmFtZSA9IERlY29yYXRvclV0aWxzLmNyZWF0ZVByb3BlcnR5TmFtZShgX2NvbXBhcmVNYXBgLCBrZXkgYXMgc3RyaW5nKTtcblxuICAgIC8vIFN0YXRlIHZhbGlkYXRpb25cbiAgICBjb25zdCBzdGF0ZVZhbGlkYXRpb24gPSBEZWNvcmF0b3JVdGlscy52YWxpZGF0ZVN0YXRlUHJvcGVydHkodGFyZ2V0LCBzdGF0ZU9iamVjdCk7XG5cbiAgICAvLyBDcmVhdGUgZGVwZW5kZW5jaWVzIGFycmF5IGFzIHN0cmluZyBmb3IgY29kZSBnZW5lcmF0aW9uXG4gICAgY29uc3QgZGVwZW5kZW5jaWVzU3RyID0gZGVwZW5kZW5jaWVzLm1hcCgoZGVwKSA9PiBgJyR7ZGVwIGFzIHN0cmluZ30nYCkuam9pbignLCAnKTtcblxuICAgIC8vIENyZWF0ZSB0aGUgY29tcHV0ZSBtZXRob2QgYXMgc3RyaW5nLCBmb3IgY29kZSBnZW5lcmF0aW9uXG4gICAgY29uc3QgY29tcHV0ZU1ldGhvZE5hbWVTdHIgPSBjb21wdXRlRm4gPyBgLCAoc2xpY2UpID0+IHRoaXMuJHtjb21wdXRlTWV0aG9kTmFtZX0oc2xpY2UpYCA6ICcnO1xuXG4gICAgLy8gQ3JlYXRlIHRoZSBjb21wYXJhdG9yIG1hcCBmdW5jdGlvbiBhcyBzdHJpbmcsIGZvciBjb2RlIGdlbmVyYXRpb25cbiAgICBjb25zdCBrZXlDb21wYXJlTWFwU3RyID0gb3B0cz8ua2V5Q29tcGFyZU1hcCA/IGAsIHRoaXMuJHtrZXlDb21wYXJlTWFwUHJvcGVydHlOYW1lfWAgOiAnJztcblxuICAgIC8vIENyZWF0ZSBnZXR0ZXIgd2l0aCBjYWNoaW5nIHVzaW5nIFJ4U3RhdGUncyBuYXRpdmUgbXVsdGktc2VsZWN0ICsgcGlwZShtYXAoKSlcbiAgICBjb25zdCBnZXR0ZXIgPSBuZXcgRnVuY3Rpb24oYFxuICAgICAgcmV0dXJuIGZ1bmN0aW9uICR7Z2V0TWV0aG9kTmFtZX0oKSB7XG4gICAgICAgICR7c3RhdGVWYWxpZGF0aW9ufVxuICAgICAgICBpZiAoIXRoaXMuJHtjYWNoZVByb3BlcnR5TmFtZX0pIHtcbiAgICAgICAgICBjb25zdCB7IG1hcCB9ID0gcmVxdWlyZSgncnhqcy9vcGVyYXRvcnMnKTtcbiAgICAgICAgICB0aGlzLiR7Y2FjaGVQcm9wZXJ0eU5hbWV9ID0gJHtzdGF0ZU9iamVjdH0uc2VsZWN0KFske2RlcGVuZGVuY2llc1N0cn1dJHtjb21wdXRlTWV0aG9kTmFtZVN0cn0ke2tleUNvbXBhcmVNYXBTdHJ9KTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy4ke2NhY2hlUHJvcGVydHlOYW1lfTtcbiAgICAgIH1cbiAgICBgKSgpO1xuXG4gICAgLy8gQXR0YWNoIGNvbXB1dGUgbWV0aG9kLCBvcHRpb25hbCBrZXlDb21wYXJlTWFwIHdpdGggdW5pcXVlIG5hbWUsIGFuZCBnZXR0ZXIgdG8gcHJvdG90eXBlXG4gICAgaWYgKGNvbXB1dGVGbikgdGFyZ2V0W2NvbXB1dGVNZXRob2ROYW1lXSA9IGNvbXB1dGVGbjtcbiAgICBpZiAob3B0cz8ua2V5Q29tcGFyZU1hcCkgdGFyZ2V0W2tleUNvbXBhcmVNYXBQcm9wZXJ0eU5hbWVdID0gb3B0cy5rZXlDb21wYXJlTWFwO1xuICAgIHRhcmdldFtnZXRNZXRob2ROYW1lXSA9IGdldHRlcjtcblxuICAgIC8vIERlZmluZSBwcm9wZXJ0eSB3aXRoIGdldHRlciBvbmx5XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCB7XG4gICAgICBnZXQ6IGdldHRlcixcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IGZhbHNlLFxuICAgIH0pO1xuXG4gICAgLy8gRGV2ZWxvcG1lbnQgbG9nZ2luZ1xuICAgIGlmICghcHJvZHVjdGlvbikge1xuICAgICAgY29uc29sZS5kZWJ1ZyhcbiAgICAgICAgYFtSeFN0YXRlQ29tcHV0ZWRdICR7dGFyZ2V0LmNvbnN0cnVjdG9yPy5uYW1lfS4ke2tleSBhcyBzdHJpbmd9IC0+ICR7c3RhdGVPYmplY3R9LnNlbGVjdChbJHtkZXBlbmRlbmNpZXNTdHJ9XSkucGlwZShtYXAoY29tcHV0ZUZuKSlgXG4gICAgICApO1xuICAgIH1cbiAgfTtcbn1cbiJdfQ==
160
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicngtc3RhdGUuZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvc2hhcmVkL3J4LXN0YXRlL3J4LXN0YXRlLmRlY29yYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUF1QixPQUFPLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVqRSxJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUM7QUFDdkIsTUFBTSxVQUFVLHFCQUFxQjtJQUNuQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0FBQ3BCLENBQUM7QUFPRCx5QkFBeUI7QUFDekIsTUFBTSxjQUFjO0lBQ2xCLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBVztRQUMzQixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE1BQWMsRUFBRSxXQUFtQjtRQUN6RCxPQUFPLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLGtCQUFrQixDQUFDLE1BQWMsRUFBRSxXQUFtQjtRQUMzRCxPQUFPLEdBQUcsTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLHFCQUFxQixDQUFDLE1BQVcsRUFBRSxXQUFnQjtRQUN4RCxJQUFJLENBQUMsVUFBVSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDaEMsTUFBTSxJQUFJLEtBQUssQ0FBQyxpREFBaUQsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQzlGLENBQUM7SUFDSCxDQUFDO0NBQ0Y7QUFFRCxNQUFN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cEIsQ0FBQyxDQUFDO1FBRUgsc0JBQXNCO1FBQ3RCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNoQixPQUFPLENBQUMsS0FBSyxDQUNYLHFCQUFxQixNQUFNLENBQUMsV0FBVyxFQUFFLElBQUksSUFBSSxHQUFhLHFCQUFxQixZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQVcsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQzlJLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFByb2plY3RWYWx1ZVJlZHVjZXIsIFJ4U3RhdGUgfSBmcm9tICdAcngtYW5ndWxhci9zdGF0ZSc7XG5cbmxldCBwcm9kdWN0aW9uID0gZmFsc2U7XG5leHBvcnQgZnVuY3Rpb24gZW5hYmxlUnhTdGF0ZVByb2RNb2RlKCkge1xuICBwcm9kdWN0aW9uID0gdHJ1ZTtcbn1cblxuZGVjbGFyZSB0eXBlIENvbnN0cnVjdG9yPFQgPSBhbnk+ID0gbmV3ICguLi5hcmdzOiBhbnlbXSkgPT4gVDtcblxudHlwZSBPYnNlcnZhYmxlUHJvcGVydHlEZWNvcmF0b3I8VD4gPSA8SyBleHRlbmRzIFByb3BlcnR5S2V5Pih0YXJnZXQ6IGFueSwgcHJvcGVydHlLZXk6IEspID0+IHZvaWQ7XG50eXBlIFN0YXRlUHJvcGVydHlEZWNvcmF0b3I8VD4gPSA8SyBleHRlbmRzIFByb3BlcnR5S2V5Pih0YXJnZXQ6IGFueSwgcHJvcGVydHlLZXk6IEspID0+IHZvaWQ7XG5cbi8vIFV0aWxpdHkgZm9yIGRlY29yYXRvcnNcbmNsYXNzIERlY29yYXRvclV0aWxzIHtcbiAgc3RhdGljIGNhcGl0YWxpemUoc3RyOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBzdHIuY2hhckF0KDApLnRvVXBwZXJDYXNlKCkgKyBzdHIuc2xpY2UoMSk7XG4gIH1cblxuICBzdGF0aWMgY3JlYXRlTWV0aG9kTmFtZShwcmVmaXg6IHN0cmluZywgcHJvcGVydHlLZXk6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3ByZWZpeH0ke3RoaXMuY2FwaXRhbGl6ZShwcm9wZXJ0eUtleSl9YDtcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVQcm9wZXJ0eU5hbWUocHJlZml4OiBzdHJpbmcsIHByb3BlcnR5S2V5OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHtwcmVmaXh9JHt0aGlzLmNhcGl0YWxpemUocHJvcGVydHlLZXkpfWA7XG4gIH1cblxuICBzdGF0aWMgdmFsaWRhdGVTdGF0ZVByb3BlcnR5KHRhcmdldDogYW55LCBzdGF0ZU9iamVjdDogYW55KTogdm9pZCB7XG4gICAgaWYgKCFwcm9kdWN0aW9uICYmICFzdGF0ZU9iamVjdCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nIHN0YXRlISBQbGVhc2UgYWRkIGEgUnhTdGF0ZSBpbiBjbGFzczogJHt0YXJnZXQuY29uc3RydWN0b3IubmFtZX1gKTtcbiAgICB9XG4gIH1cbn1cblxuY29uc3QgU1RBVEVfVkFSX05BTUVfS0VZID0gJ19fc3RhdGVOYW1lJztcbmNvbnN0IERFRkFVTFRfU1RBVEVfVkFSX05BTUUgPSAnX3N0YXRlJztcblxuLyoqXG4gKiBEZWNvcmF0b3IgdG8gcmVnaXN0ZXIgdGhlIFJ4U3RhdGUgcHJvcGVydHkgaW4gYSBjb21wb25lbnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIFJ4U3RhdGVSZWdpc3RlcigpOiBQcm9wZXJ0eURlY29yYXRvciB7XG4gIHJldHVybiBmdW5jdGlvbiAodGFyZ2V0OiBDb25zdHJ1Y3Rvcjxhbnk+LCBrZXk6IHN0cmluZykge1xuICAgIGlmICh0YXJnZXRbU1RBVEVfVkFSX05BTUVfS0VZXSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3QgZGVmaW5lIG1vcmUgdGhhbiBvbmUgQFJ4U3RhdGVSZWdpc3RlcigpIGluIGNsYXNzIGhpZXJhcmNoeS4gRm91bmQ6ICR7dGFyZ2V0W1NUQVRFX1ZBUl9OQU1FX0tFWV19IGFuZCAke2tleX1gKTtcbiAgICB9XG5cbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBTVEFURV9WQVJfTkFNRV9LRVksIHtcbiAgICAgIHZhbHVlOiBrZXksXG4gICAgICB3cml0YWJsZTogZmFsc2UsXG4gICAgICBlbnVtZXJhYmxlOiBmYWxzZSxcbiAgICAgIGNvbmZpZ3VyYWJsZTogZmFsc2UsXG4gICAgfSk7XG4gIH07XG59XG5cbi8qKlxuICogRGVjb3JhdG9yIGZvciBSeFN0YXRlIHByb3BlcnRpZXMgd2l0aCBnZXR0ZXIvc2V0dGVyIGFjY2Vzc1xuICovXG5leHBvcnQgZnVuY3Rpb24gUnhTdGF0ZVByb3BlcnR5PFQgZXh0ZW5kcyBvYmplY3QgPSBhbnksIEsgZXh0ZW5kcyBrZXlvZiBUID0gYW55LCBWIGV4dGVuZHMgVFtLXSA9IGFueT4oXG4gIHN0YXRlUHJvcGVydHlOYW1lPzogc3RyaW5nIHwgSyxcbiAgcHJvamVjdFZhbHVlUmVkdWNlcj86IFByb2plY3RWYWx1ZVJlZHVjZXI8VCwgSywgVj5cbik6IFN0YXRlUHJvcGVydHlEZWNvcmF0b3I8Vj4ge1xuICByZXR1cm4gZnVuY3Rpb24gPFAgZXh0ZW5kcyBQcm9wZXJ0eUtleT4odGFyZ2V0OiBhbnksIGtleTogUCkge1xuICAgIGNvbnN0IGZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUgPSAoc3RhdGVQcm9wZXJ0eU5hbWUgYXMgc3RyaW5nKSB8fCAoa2V5IGFzIHN0cmluZyk7XG4gICAgY29uc3Qgc3RhdGVWYXJOYW1lID0gdGFyZ2V0IGluc3RhbmNlb2YgUnhTdGF0ZSA/IG51bGwgOiB0YXJnZXRbU1RBVEVfVkFSX05BTUVfS0VZXSB8fCBERUZBVUxUX1NUQVRFX1ZBUl9OQU1FO1xuXG4gICAgLy8gQ3JlYXRlIHVuaXF1ZSBwcm9wZXJ0eSBuYW1lcyB0byBhdm9pZCBjb25mbGljdHNcbiAgICBjb25zdCBwcml2YXRlVmFsdWVLZXkgPSBgX18ke2tleSBhcyBzdHJpbmd9X3ZhbHVlYDtcbiAgICBjb25zdCBwcml2YXRlSW5pdGlhbGl6ZWRLZXkgPSBgX18ke2tleSBhcyBzdHJpbmd9X2luaXRpYWxpemVkYDtcblxuICAgIC8vIERlZmluZSBwcm9wZXJ0eSB3aXRoIGdldHRlci9zZXR0ZXJcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHtcbiAgICAgIGdldDogZnVuY3Rpb24gKCkge1xuICAgICAgICBjb25zdCBzdGF0ZU9iamVjdDogUnhTdGF0ZTxUPiA9IHN0YXRlVmFyTmFtZSA/IHRoaXNbc3RhdGVWYXJOYW1lXSA6IHRoaXM7XG4gICAgICAgIERlY29yYXRvclV0aWxzLnZhbGlkYXRlU3RhdGVQcm9wZXJ0eSh0YXJnZXQsIHN0YXRlT2JqZWN0KTtcblxuICAgICAgICBpZiAoIXRoaXNbcHJpdmF0ZUluaXRpYWxpemVkS2V5XSkge1xuICAgICAgICAgIHRoaXNbcHJpdmF0ZVZhbHVlS2V5XSA9IHN0YXRlT2JqZWN0LmdldChmaW5hbFN0YXRlUHJvcGVydHlOYW1lIGFzIGtleW9mIFQpO1xuICAgICAgICAgIHRoaXNbcHJpdmF0ZUluaXRpYWxpemVkS2V5XSA9IHRydWU7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdGhpc1twcml2YXRlVmFsdWVLZXldIGFzIFY7XG4gICAgICB9LFxuICAgICAgc2V0OiBmdW5jdGlvbiAodmFsdWU6IFYpIHtcbiAgICAgICAgY29uc3Qgc3RhdGVPYmplY3Q6IFJ4U3RhdGU8VD4gPSBzdGF0ZVZhck5hbWUgPyB0aGlzW3N0YXRlVmFyTmFtZV0gOiB0aGlzO1xuICAgICAgICBEZWNvcmF0b3JVdGlscy52YWxpZGF0ZVN0YXRlUHJvcGVydHkodGFyZ2V0LCBzdGF0ZU9iamVjdCk7XG5cbiAgICAgICAgdGhpc1twcml2YXRlVmFsdWVLZXldID0gdmFsdWU7XG5cbiAgICAgICAgaWYgKHByb2plY3RWYWx1ZVJlZHVjZXIpIHtcbiAgICAgICAgICBzdGF0ZU9iamVjdC5zZXQoZmluYWxTdGF0ZVByb3BlcnR5TmFtZSBhcyBrZXlvZiBULCAoc3RhdGU6IFQpID0+IHByb2plY3RWYWx1ZVJlZHVjZXIoc3RhdGUsIHZhbHVlKSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc3RhdGVPYmplY3Quc2V0KGZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUgYXMga2V5b2YgVCwgKCkgPT4gdmFsdWUpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgZW51bWVyYWJsZTogdHJ1ZSxcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcbiAgICB9KTtcblxuICAgIC8vIERldmVsb3BtZW50IGxvZ2dpbmdcbiAgICBpZiAoIXByb2R1Y3Rpb24pIHtcbiAgICAgIGNvbnNvbGUuZGVidWcoYFtSeFN0YXRlUHJvcGVydHldICR7dGFyZ2V0LmNvbnN0cnVjdG9yPy5uYW1lfS4ke2tleSBhcyBzdHJpbmd9IC0+IHN0YXRlLiR7ZmluYWxTdGF0ZVByb3BlcnR5TmFtZX1gKTtcbiAgICB9XG4gIH07XG59XG5cbi8qKlxuICogRGVjb3JhdG9yIGZvciBSeFN0YXRlIG9ic2VydmFibGUgc2VsZWN0b3JzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBSeFN0YXRlU2VsZWN0PFQgPSBhbnksIFIgPSBUW2tleW9mIFRdPihcbiAgc3RhdGVQcm9wZXJ0eU5hbWU/OiBzdHJpbmcgfCBrZXlvZiBUIHwgJyQnLFxuICBvcHRzPzoge1xuICAgIHN0YXRlTmFtZT86IHN0cmluZztcbiAgfVxuKTogT2JzZXJ2YWJsZVByb3BlcnR5RGVjb3JhdG9yPE9ic2VydmFibGU8Uj4+IHtcbiAgcmV0dXJuIGZ1bmN0aW9uIDxQIGV4dGVuZHMgUHJvcGVydHlLZXk+KHRhcmdldDogYW55LCBrZXk6IFApIHtcbiAgICAvLyBDb252ZW50aW9uIGNoZWNrXG4gICAgaWYgKCFwcm9kdWN0aW9uICYmICEoa2V5IGFzIHN0cmluZykuZW5kc1dpdGgoJyQnKSkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICBgW1J4U3RhdGVTZWxlY3RdIENvbnZlbnRpb246IFByb3BlcnR5ICR7dGFyZ2V0LmNvbnN0cnVjdG9yPy5uYW1lfS4ke2tleSBhcyBzdHJpbmd9IHNob3VsZCBlbmQgd2l0aCAnJCcgdG8gaW5kaWNhdGUgaXQncyBhbiBPYnNlcnZhYmxlYFxuICAgICAgKTtcbiAgICB9XG5cbiAgICAvLyBEZXRlcm1pbmUgc3RhdGUgcHJvcGVydHkgbmFtZVxuICAgIGNvbnN0IGZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUgPSAoc3RhdGVQcm9wZXJ0eU5hbWUgYXMgc3RyaW5nKSB8fCAoa2V5IGFzIHN0cmluZykucmVwbGFjZSgvXFwkJC8sICcnKTtcblxuICAgIC8vIERldGVybWluZSBzdGF0ZSBvYmplY3RcbiAgICBjb25zdCBzdGF0ZVZhck5hbWUgPSB0YXJnZXQgaW5zdGFuY2VvZiBSeFN0YXRlID8gbnVsbCA6IHRhcmdldFtTVEFURV9WQVJfTkFNRV9LRVldIHx8IG9wdHM/LnN0YXRlTmFtZSB8fCBERUZBVUxUX1NUQVRFX1ZBUl9OQU1FO1xuXG4gICAgLy8gQ3JlYXRlIGNhY2hlIHByb3BlcnR5IG5hbWVcbiAgICBjb25zdCBjYWNoZVByb3BlcnR5TmFtZSA9IGBfXyR7a2V5IGFzIHN0cmluZ31fY2FjaGVgO1xuXG4gICAgLy8gRGVmaW5lIHByb3BlcnR5IHdpdGggZ2V0dGVyIG9ubHlcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHtcbiAgICAgIGdldDogZnVuY3Rpb24gKCkge1xuICAgICAgICBjb25zdCBzdGF0ZU9iamVjdCA9IHN0YXRlVmFyTmFtZSA/IHRoaXNbc3RhdGVWYXJOYW1lXSA6IHRoaXM7XG4gICAgICAgIERlY29yYXRvclV0aWxzLnZhbGlkYXRlU3RhdGVQcm9wZXJ0eSh0YXJnZXQsIHN0YXRlT2JqZWN0KTtcblxuICAgICAgICBpZiAoIXRoaXNbY2FjaGVQcm9wZXJ0eU5hbWVdKSB7XG4gICAgICAgICAgaWYgKGZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUgPT09ICckJykge1xuICAgICAgICAgICAgdGhpc1tjYWNoZVByb3BlcnR5TmFtZV0gPSBzdGF0ZU9iamVjdC4kO1xuICAgICAgICAgIH0gZWxzZSBpZiAoZmluYWxTdGF0ZVByb3BlcnR5TmFtZS5pbmNsdWRlcygnLicpKSB7XG4gICAgICAgICAgICBjb25zdCBwYXRoID0gZmluYWxTdGF0ZVByb3BlcnR5TmFtZS5zcGxpdCgnLicpO1xuICAgICAgICAgICAgdGhpc1tjYWNoZVByb3BlcnR5TmFtZV0gPSBzdGF0ZU9iamVjdC5zZWxlY3QoLi4ucGF0aCk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXNbY2FjaGVQcm9wZXJ0eU5hbWVdID0gc3RhdGVPYmplY3Quc2VsZWN0KGZpbmFsU3RhdGVQcm9wZXJ0eU5hbWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0aGlzW2NhY2hlUHJvcGVydHlOYW1lXTtcbiAgICAgIH0sXG4gICAgICBlbnVtZXJhYmxlOiB0cnVlLFxuICAgICAgY29uZmlndXJhYmxlOiBmYWxzZSxcbiAgICB9KTtcblxuICAgIC8vIERldmVsb3BtZW50IGxvZ2dpbmdcbiAgICBpZiAoIXByb2R1Y3Rpb24pIHtcbiAgICAgIGNvbnNvbGUuZGVidWcoYFtSeFN0YXRlU2VsZWN0XSAke3RhcmdldC5jb25zdHJ1Y3Rvcj8ubmFtZX0uJHtrZXkgYXMgc3RyaW5nfSAtPiBzdGF0ZS5zZWxlY3QoJyR7ZmluYWxTdGF0ZVByb3BlcnR5TmFtZX0nKWApO1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBVdGlsaXR5IGRlY29yYXRvciB0byBjcmVhdGUgY29tcHV0ZWQgb2JzZXJ2YWJsZXMgZnJvbSBzdGF0ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gUnhTdGF0ZUNvbXB1dGVkPFQgPSBhbnksIEsgZXh0ZW5kcyBrZXlvZiBUID0gYW55LCBSID0gYW55PihcbiAgZGVwZW5kZW5jaWVzOiBLW10sXG4gIGNvbXB1dGVGbj86IChzbGljZTogUGljazxULCBLPikgPT4gUixcbiAgb3B0cz86IHtcbiAgICBzdGF0ZU5hbWU/OiBzdHJpbmc7XG4gICAga2V5Q29tcGFyZU1hcD86IGFueTtcbiAgfVxuKTogT2JzZXJ2YWJsZVByb3BlcnR5RGVjb3JhdG9yPE9ic2VydmFibGU8Uj4+IHtcbiAgcmV0dXJuIGZ1bmN0aW9uIDxQIGV4dGVuZHMgUHJvcGVydHlLZXk+KHRhcmdldDogYW55LCBrZXk6IFApIHtcbiAgICAvLyBDb252ZW50aW9uIGNoZWNrXG4gICAgaWYgKCFwcm9kdWN0aW9uICYmICEoa2V5IGFzIHN0cmluZykuZW5kc1dpdGgoJyQnKSkge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICBgW1J4U3RhdGVDb21wdXRlZF0gQ29udmVudGlvbjogUHJvcGVydHkgJHt0YXJnZXQuY29uc3RydWN0b3I/Lm5hbWV9LiR7a2V5IGFzIHN0cmluZ30gc2hvdWxkIGVuZCB3aXRoICckJyB0byBpbmRpY2F0ZSBpdCdzIGFuIE9ic2VydmFibGVgXG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IHN0YXRlVmFyTmFtZSA9IHRhcmdldCBpbnN0YW5jZW9mIFJ4U3RhdGUgPyBudWxsIDogdGFyZ2V0W1NUQVRFX1ZBUl9OQU1FX0tFWV0gfHwgb3B0cz8uc3RhdGVOYW1lIHx8IERFRkFVTFRfU1RBVEVfVkFSX05BTUU7XG4gICAgY29uc3QgY2FjaGVQcm9wZXJ0eU5hbWUgPSBgX18ke2tleSBhcyBzdHJpbmd9X2NhY2hlYDtcblxuICAgIC8vIERlZmluZSBwcm9wZXJ0eSB3aXRoIGdldHRlciBvbmx5XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCB7XG4gICAgICBnZXQ6IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgY29uc3Qgc3RhdGVPYmplY3QgPSBzdGF0ZVZhck5hbWUgPyB0aGlzW3N0YXRlVmFyTmFtZV0gOiB0aGlzO1xuICAgICAgICBEZWNvcmF0b3JVdGlscy52YWxpZGF0ZVN0YXRlUHJvcGVydHkodGFyZ2V0LCBzdGF0ZU9iamVjdCk7XG5cbiAgICAgICAgaWYgKCF0aGlzW2NhY2hlUHJvcGVydHlOYW1lXSkge1xuICAgICAgICAgIGxldCBvYnNlcnZhYmxlID0gc3RhdGVPYmplY3Quc2VsZWN0KGRlcGVuZGVuY2llcywgb3B0cz8ua2V5Q29tcGFyZU1hcCk7XG5cbiAgICAgICAgICBpZiAoY29tcHV0ZUZuKSB7XG4gICAgICAgICAgICBjb25zdCB7IG1hcCB9ID0gcmVxdWlyZSgncnhqcy9vcGVyYXRvcnMnKTtcbiAgICAgICAgICAgIG9ic2VydmFibGUgPSBvYnNlcnZhYmxlLnBpcGUobWFwKGNvbXB1dGVGbikpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHRoaXNbY2FjaGVQcm9wZXJ0eU5hbWVdID0gb2JzZXJ2YWJsZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0aGlzW2NhY2hlUHJvcGVydHlOYW1lXTtcbiAgICAgIH0sXG4gICAgICBlbnVtZXJhYmxlOiB0cnVlLFxuICAgICAgY29uZmlndXJhYmxlOiBmYWxzZSxcbiAgICB9KTtcblxuICAgIC8vIERldmVsb3BtZW50IGxvZ2dpbmdcbiAgICBpZiAoIXByb2R1Y3Rpb24pIHtcbiAgICAgIGNvbnNvbGUuZGVidWcoXG4gICAgICAgIGBbUnhTdGF0ZUNvbXB1dGVkXSAke3RhcmdldC5jb25zdHJ1Y3Rvcj8ubmFtZX0uJHtrZXkgYXMgc3RyaW5nfSAtPiBzdGF0ZS5zZWxlY3QoWyR7ZGVwZW5kZW5jaWVzLm1hcCgoZCkgPT4gYCcke2QgYXMgc3RyaW5nfSdgKS5qb2luKCcsICcpfV0pYFxuICAgICAgKTtcbiAgICB9XG4gIH07XG59XG4iXX0=
@@ -26365,22 +26365,16 @@ class DecoratorUtils {
26365
26365
  static createPropertyName(prefix, propertyKey) {
26366
26366
  return `${prefix}${this.capitalize(propertyKey)}`;
26367
26367
  }
26368
- static validateStateProperty(target, stateVarName) {
26369
- if (!production && stateVarName !== 'this') {
26370
- return `
26371
- if (!${stateVarName}) {
26372
- throw new Error('Missing state! Please add a RxState in class: ' + this.constructor.name);
26368
+ static validateStateProperty(target, stateObject) {
26369
+ if (!production && !stateObject) {
26370
+ throw new Error(`Missing state! Please add a RxState in class: ${target.constructor.name}`);
26373
26371
  }
26374
- `;
26375
- }
26376
- return '';
26377
26372
  }
26378
26373
  }
26379
26374
  const STATE_VAR_NAME_KEY = '__stateName';
26380
26375
  const DEFAULT_STATE_VAR_NAME = '_state';
26381
26376
  /**
26382
26377
  * Decorator to register the RxState property in a component
26383
- * Must be used once per class hierarchy
26384
26378
  */
26385
26379
  function RxStateRegister() {
26386
26380
  return function (target, key) {
@@ -26397,49 +26391,36 @@ function RxStateRegister() {
26397
26391
  }
26398
26392
  /**
26399
26393
  * Decorator for RxState properties with getter/setter access
26400
- * Creates reactive properties that sync with RxState
26401
26394
  */
26402
26395
  function RxStateProperty(statePropertyName, projectValueReducer) {
26403
26396
  return function (target, key) {
26404
- // Vérification de type au runtime (optionnelle)
26405
- const descriptor = Object.getOwnPropertyDescriptor(target, key);
26406
- if (descriptor && typeof descriptor.value !== 'undefined') {
26407
- // On peut ajouter ici des vérifications de type runtime si nécessaire
26408
- }
26409
26397
  const finalStatePropertyName = statePropertyName || key;
26410
26398
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || DEFAULT_STATE_VAR_NAME;
26411
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
26412
- // Generate method names
26413
- const getMethodName = DecoratorUtils.createMethodName('_get', key);
26414
- const setMethodName = DecoratorUtils.createMethodName('_set', key);
26415
- const reducerMethodName = DecoratorUtils.createMethodName('_reduce', key);
26416
- // State validation (only in development)
26417
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
26418
- // Create reducer logic
26419
- const reducerLogic = projectValueReducer ? `(state) => this.${reducerMethodName}(state, value)` : '() => value';
26420
- // Create dynamic methods using Function constructor for better performance
26421
- const getter = new Function(`
26422
- return function ${getMethodName}() {
26423
- ${stateValidation}
26424
- return ${stateObject}.get('${finalStatePropertyName}');
26425
- }
26426
- `)();
26427
- const setter = new Function(`
26428
- return function ${setMethodName}(value) {
26429
- ${stateValidation}
26430
- ${stateObject}.set('${finalStatePropertyName}', ${reducerLogic});
26431
- }
26432
- `)();
26433
- // Attach methods to prototype
26434
- target[getMethodName] = getter;
26435
- target[setMethodName] = setter;
26436
- if (projectValueReducer) {
26437
- target[reducerMethodName] = projectValueReducer;
26438
- }
26399
+ // Create unique property names to avoid conflicts
26400
+ const privateValueKey = `__${key}_value`;
26401
+ const privateInitializedKey = `__${key}_initialized`;
26439
26402
  // Define property with getter/setter
26440
26403
  Object.defineProperty(target, key, {
26441
- get: getter,
26442
- set: setter,
26404
+ get: function () {
26405
+ const stateObject = stateVarName ? this[stateVarName] : this;
26406
+ DecoratorUtils.validateStateProperty(target, stateObject);
26407
+ if (!this[privateInitializedKey]) {
26408
+ this[privateValueKey] = stateObject.get(finalStatePropertyName);
26409
+ this[privateInitializedKey] = true;
26410
+ }
26411
+ return this[privateValueKey];
26412
+ },
26413
+ set: function (value) {
26414
+ const stateObject = stateVarName ? this[stateVarName] : this;
26415
+ DecoratorUtils.validateStateProperty(target, stateObject);
26416
+ this[privateValueKey] = value;
26417
+ if (projectValueReducer) {
26418
+ stateObject.set(finalStatePropertyName, (state) => projectValueReducer(state, value));
26419
+ }
26420
+ else {
26421
+ stateObject.set(finalStatePropertyName, () => value);
26422
+ }
26423
+ },
26443
26424
  enumerable: true,
26444
26425
  configurable: true,
26445
26426
  });
@@ -26451,117 +26432,79 @@ function RxStateProperty(statePropertyName, projectValueReducer) {
26451
26432
  }
26452
26433
  /**
26453
26434
  * Decorator for RxState observable selectors
26454
- * Creates observable properties that select from RxState
26455
- *
26456
- * ⚠️ IMPORTANT: La propriété décorée DOIT être typée comme Observable<T>
26457
- *
26458
- * @example
26459
- * ```typescript
26460
- * @RxStateSelect()
26461
- * protected pmfms$: Observable<IPmfm[]>; // ✅ Correct
26462
- *
26463
- * @RxStateSelect()
26464
- * protected badProperty: boolean; // ❌ TypeScript Error
26465
- * ```
26466
26435
  */
26467
26436
  function RxStateSelect(statePropertyName, opts) {
26468
26437
  return function (target, key) {
26469
- // Vérification simple basée sur la convention (optionnelle)
26438
+ // Convention check
26470
26439
  if (!production && !key.endsWith('$')) {
26471
26440
  console.warn(`[RxStateSelect] Convention: Property ${target.constructor?.name}.${key} should end with '$' to indicate it's an Observable`);
26472
26441
  }
26473
- // Determine state property name (remove trailing $ if present)
26442
+ // Determine state property name
26474
26443
  const finalStatePropertyName = statePropertyName || key.replace(/\$$/, '');
26475
26444
  // Determine state object
26476
26445
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || opts?.stateName || DEFAULT_STATE_VAR_NAME;
26477
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
26478
26446
  // Create cache property name
26479
- const cachePropertyName = `_${key}`;
26480
- // Generate method name
26481
- const getMethodName = DecoratorUtils.createMethodName('_get', key.replace(/\$$/, '') + '$');
26482
- // Create observable selector logic
26483
- const observableSelector = finalStatePropertyName === '$'
26484
- ? `${stateObject}.$`
26485
- : finalStatePropertyName.includes('.')
26486
- ? `${stateObject}.select('${finalStatePropertyName.split('.').join("', '")}')`
26487
- : `${stateObject}.select('${finalStatePropertyName}')`;
26488
- // State validation
26489
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
26490
- // Create getter with caching
26491
- const getter = new Function(`
26492
- return function ${getMethodName}() {
26493
- ${stateValidation}
26494
- if (!this.${cachePropertyName}) {
26495
- this.${cachePropertyName} = ${observableSelector};
26496
- }
26497
- return this.${cachePropertyName};
26498
- }
26499
- `)();
26500
- // Attach method to prototype
26501
- target[getMethodName] = getter;
26447
+ const cachePropertyName = `__${key}_cache`;
26502
26448
  // Define property with getter only
26503
26449
  Object.defineProperty(target, key, {
26504
- get: getter,
26450
+ get: function () {
26451
+ const stateObject = stateVarName ? this[stateVarName] : this;
26452
+ DecoratorUtils.validateStateProperty(target, stateObject);
26453
+ if (!this[cachePropertyName]) {
26454
+ if (finalStatePropertyName === '$') {
26455
+ this[cachePropertyName] = stateObject.$;
26456
+ }
26457
+ else if (finalStatePropertyName.includes('.')) {
26458
+ const path = finalStatePropertyName.split('.');
26459
+ this[cachePropertyName] = stateObject.select(...path);
26460
+ }
26461
+ else {
26462
+ this[cachePropertyName] = stateObject.select(finalStatePropertyName);
26463
+ }
26464
+ }
26465
+ return this[cachePropertyName];
26466
+ },
26505
26467
  enumerable: true,
26506
26468
  configurable: false,
26507
26469
  });
26508
26470
  // Development logging
26509
26471
  if (!production) {
26510
- console.debug(`[RxStateSelect] ${target.constructor?.name}.${key} -> ${observableSelector}`);
26472
+ console.debug(`[RxStateSelect] ${target.constructor?.name}.${key} -> state.select('${finalStatePropertyName}')`);
26511
26473
  }
26512
26474
  };
26513
26475
  }
26514
26476
  /**
26515
26477
  * Utility decorator to create computed observables from state
26516
- *
26517
- * ⚠️ IMPORTANT: La propriété décorée DOIT être typée comme Observable<T>
26518
26478
  */
26519
26479
  function RxStateComputed(dependencies, computeFn, opts) {
26520
26480
  return function (target, key) {
26521
- // Vérification simple basée sur la convention (optionnelle)
26481
+ // Convention check
26522
26482
  if (!production && !key.endsWith('$')) {
26523
26483
  console.warn(`[RxStateComputed] Convention: Property ${target.constructor?.name}.${key} should end with '$' to indicate it's an Observable`);
26524
26484
  }
26525
26485
  const stateVarName = target instanceof RxState ? null : target[STATE_VAR_NAME_KEY] || opts?.stateName || DEFAULT_STATE_VAR_NAME;
26526
- const stateObject = stateVarName ? `this.${stateVarName}` : 'this';
26527
- const cachePropertyName = `_${key}`;
26528
- const getMethodName = DecoratorUtils.createMethodName('_get', key.replace(/\$$/, '') + '$');
26529
- const computeMethodName = DecoratorUtils.createMethodName('_compute', key);
26530
- const keyCompareMapPropertyName = DecoratorUtils.createPropertyName(`_compareMap`, key);
26531
- // State validation
26532
- const stateValidation = DecoratorUtils.validateStateProperty(target, stateObject);
26533
- // Create dependencies array as string for code generation
26534
- const dependenciesStr = dependencies.map((dep) => `'${dep}'`).join(', ');
26535
- // Create the compute method as string, for code generation
26536
- const computeMethodNameStr = computeFn ? `, (slice) => this.${computeMethodName}(slice)` : '';
26537
- // Create the comparator map function as string, for code generation
26538
- const keyCompareMapStr = opts?.keyCompareMap ? `, this.${keyCompareMapPropertyName}` : '';
26539
- // Create getter with caching using RxState's native multi-select + pipe(map())
26540
- const getter = new Function(`
26541
- return function ${getMethodName}() {
26542
- ${stateValidation}
26543
- if (!this.${cachePropertyName}) {
26544
- const { map } = require('rxjs/operators');
26545
- this.${cachePropertyName} = ${stateObject}.select([${dependenciesStr}]${computeMethodNameStr}${keyCompareMapStr});
26546
- }
26547
- return this.${cachePropertyName};
26548
- }
26549
- `)();
26550
- // Attach compute method, optional keyCompareMap with unique name, and getter to prototype
26551
- if (computeFn)
26552
- target[computeMethodName] = computeFn;
26553
- if (opts?.keyCompareMap)
26554
- target[keyCompareMapPropertyName] = opts.keyCompareMap;
26555
- target[getMethodName] = getter;
26486
+ const cachePropertyName = `__${key}_cache`;
26556
26487
  // Define property with getter only
26557
26488
  Object.defineProperty(target, key, {
26558
- get: getter,
26489
+ get: function () {
26490
+ const stateObject = stateVarName ? this[stateVarName] : this;
26491
+ DecoratorUtils.validateStateProperty(target, stateObject);
26492
+ if (!this[cachePropertyName]) {
26493
+ let observable = stateObject.select(dependencies, opts?.keyCompareMap);
26494
+ if (computeFn) {
26495
+ const { map } = require('rxjs/operators');
26496
+ observable = observable.pipe(map(computeFn));
26497
+ }
26498
+ this[cachePropertyName] = observable;
26499
+ }
26500
+ return this[cachePropertyName];
26501
+ },
26559
26502
  enumerable: true,
26560
26503
  configurable: false,
26561
26504
  });
26562
26505
  // Development logging
26563
26506
  if (!production) {
26564
- console.debug(`[RxStateComputed] ${target.constructor?.name}.${key} -> ${stateObject}.select([${dependenciesStr}]).pipe(map(computeFn))`);
26507
+ console.debug(`[RxStateComputed] ${target.constructor?.name}.${key} -> state.select([${dependencies.map((d) => `'${d}'`).join(', ')}])`);
26565
26508
  }
26566
26509
  };
26567
26510
  }