nuxeo-development-framework 6.1.5 → 6.1.7

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 (39) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +688 -1009
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/components/ndf-filters/components/__parts/filter-autocomplete-input/filter-autocomplete.service.js +7 -5
  4. package/esm2015/lib/components/ndf-filters/containers/filters-panel/filters-panel.component.js +9 -9
  5. package/esm2015/lib/components/ndf-filters/models/base-field-config.js +1 -1
  6. package/esm2015/lib/components/ndf-filters/pipes/check-condition.pipe.js +9 -4
  7. package/esm2015/lib/components/ndf-filters/pipes/evaluate-label.pipe.js +3 -3
  8. package/esm2015/lib/components/pdf-tron/pdftron/pdftron.component.js +2 -1
  9. package/esm2015/lib/components/pdf-tron/pdftron/silent-pdftron.service.js +2 -1
  10. package/esm2015/lib/components/reports/ndf-reports/models/details.js +1 -1
  11. package/esm2015/lib/components/reports/ndf-reports/models/graph-definition.js +1 -1
  12. package/esm2015/lib/components/reports/ndf-reports/pipes/check-condition.pipe.js +3 -3
  13. package/esm2015/lib/components/reports/ndf-reports/services/report-config-mapper.service.js +28 -15
  14. package/esm2015/lib/components/reports/ndf-reports/services/reports-hooks.service.js +3 -3
  15. package/esm2015/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.js +1 -1
  16. package/esm2015/lib/components/tables/dynamic-table/services/table-hooks.service.js +4 -4
  17. package/esm2015/lib/components/tables/ndf-table/models/table-config.js +1 -1
  18. package/esm2015/lib/shared/index.js +5 -6
  19. package/esm2015/lib/shared-services/global-pdftron.service.js +2 -1
  20. package/esm2015/public-api.js +12 -13
  21. package/fesm2015/nuxeo-development-framework.js +644 -938
  22. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  23. package/lib/components/ndf-filters/components/__parts/filter-autocomplete-input/filter-autocomplete.service.d.ts +1 -2
  24. package/lib/components/ndf-filters/containers/filters-panel/filters-panel.component.d.ts +3 -3
  25. package/lib/components/ndf-filters/models/base-field-config.d.ts +1 -1
  26. package/lib/components/ndf-filters/pipes/check-condition.pipe.d.ts +1 -2
  27. package/lib/components/reports/ndf-reports/models/details.d.ts +1 -1
  28. package/lib/components/reports/ndf-reports/models/graph-definition.d.ts +2 -2
  29. package/lib/components/reports/ndf-reports/services/report-config-mapper.service.d.ts +2 -2
  30. package/lib/components/tables/ndf-table/models/table-config.d.ts +1 -1
  31. package/lib/shared/index.d.ts +7 -5
  32. package/package.json +1 -1
  33. package/public-api.d.ts +11 -12
  34. package/esm2015/lib/shared/evaluator/evaluator.js +0 -318
  35. package/esm2015/lib/shared/evaluator/index.js +0 -3
  36. package/esm2015/lib/shared/evaluator/types.js +0 -2
  37. package/lib/shared/evaluator/evaluator.d.ts +0 -79
  38. package/lib/shared/evaluator/index.d.ts +0 -2
  39. package/lib/shared/evaluator/types.d.ts +0 -18
@@ -1,6 +1,5 @@
1
1
  import { Injector } from '@angular/core';
2
2
  import { BaseService } from '../../../../../shared/services/base';
3
- import { InterpolateString } from '../../../../../shared/evaluator';
4
3
  import { AggregationFieldConfig, SearchConfig } from '../../../models';
5
4
  import * as i0 from "@angular/core";
6
5
  export declare class FilterAutocompleteService extends BaseService {
@@ -8,7 +7,7 @@ export declare class FilterAutocompleteService extends BaseService {
8
7
  private readonly _aggregationService;
9
8
  constructor(injector: Injector);
10
9
  customSearch(searchText: string, query: SearchConfig['search']['query'], fieldConfig: AggregationFieldConfig): import("rxjs").Observable<import("../../../models").FilterOption[]>;
11
- replacePlaceholder(template: InterpolateString, searchText: string): string;
10
+ replacePlaceholder(template: string, searchText: string): string;
12
11
  static ɵfac: i0.ɵɵFactoryDeclaration<FilterAutocompleteService, never>;
13
12
  static ɵprov: i0.ɵɵInjectableDeclaration<FilterAutocompleteService>;
14
13
  }
@@ -1,11 +1,11 @@
1
+ import { Direction } from '@angular/cdk/bidi';
1
2
  import { EventEmitter, OnChanges, OnInit, SimpleChanges } from '@angular/core';
2
3
  import { FormGroup } from '@angular/forms';
4
+ import { TranslateService } from '@ngx-translate/core';
3
5
  import { Observable } from 'rxjs';
6
+ import { NuxeoService } from '../../../../core/services';
4
7
  import { AggregationResponse, FieldConfigModel, FormQueryModel } from '../../models';
5
8
  import { BaseFiltersPanel } from './base-filters-panel';
6
- import { Direction } from '@angular/cdk/bidi';
7
- import { TranslateService } from '@ngx-translate/core';
8
- import { NuxeoService } from '../../../../core/services';
9
9
  import * as i0 from "@angular/core";
10
10
  export declare class FiltersPanelComponent extends BaseFiltersPanel implements OnInit, OnChanges {
11
11
  private _translateService;
@@ -1,4 +1,4 @@
1
- import { EvaluatedString, InterpolateString } from '../../../shared/evaluator';
1
+ import { EvaluatedString, InterpolateString } from '../../../shared';
2
2
  import { TranslateKey } from '../../../shared/models';
3
3
  import { ComparisonOperator } from './types-helper';
4
4
  export declare type BaseFieldConfig = {
@@ -1,12 +1,11 @@
1
1
  import { PipeTransform } from '@angular/core';
2
- import { Evaluator } from '../../../shared/evaluator';
3
2
  import { NuxeoService } from '../../../core/services';
4
3
  import * as i0 from "@angular/core";
5
4
  export declare class CheckConditionPipe implements PipeTransform {
6
5
  nuxeoService: NuxeoService;
7
6
  user: Record<string, any>;
8
7
  constructor(nuxeoService: NuxeoService);
9
- transform(condition: string, aggregations: Record<string, any>, language: string, filterValues: Record<string, any>): Evaluator;
8
+ transform(condition: string, aggregations: Record<string, any>, language: string, filterValues: Record<string, any>): any;
10
9
  static ɵfac: i0.ɵɵFactoryDeclaration<CheckConditionPipe, never>;
11
10
  static ɵpipe: i0.ɵɵPipeDeclaration<CheckConditionPipe, "checkCondition">;
12
11
  }
@@ -1,7 +1,7 @@
1
1
  import { FilterMode, TableColumnConfig, TableExportConfig, TableSortConfig, TableSortOptions } from '../../../tables/ndf-table';
2
- import { NdfReportsRequest } from './request';
3
2
  import { EvaluatedString } from '../../../../shared';
4
3
  import { NdfReportsFilters } from './ndf-reports.config';
4
+ import { NdfReportsRequest } from './request';
5
5
  export declare type ReportDetailsConfig = {
6
6
  enabled: boolean;
7
7
  source: ReportDetailsKey | ReportConfigOptions;
@@ -1,11 +1,11 @@
1
1
  import { DialogPosition } from '@angular/material/dialog';
2
2
  import { ChartDataset, ChartType, Plugin } from 'chart.js';
3
3
  import { CustomChartOptions } from '../../charts';
4
+ import { EvaluatedString } from '../../../../shared';
5
+ import { CHARTS_TYPES } from '../constants';
4
6
  import { BaseReportConfig } from './base';
5
7
  import { ChartOptionsByType } from './common';
6
8
  import { ReportDataSource } from './report-data-source';
7
- import { CHARTS_TYPES } from '../constants';
8
- import { EvaluatedString } from '../../../../shared';
9
9
  declare type chartTypes = Omit<typeof CHARTS_TYPES, 'line'>;
10
10
  export declare type AllowedChartType = chartTypes[keyof chartTypes];
11
11
  export interface ChartTypeConfig {
@@ -1,7 +1,7 @@
1
+ import { TranslateService } from '@ngx-translate/core';
1
2
  import { CustomChart, CustomChartDefinition, DigitChart, DigitChartDefinition, DynamicLineChart, DynamicLineChartDefinition, GraphChart, GraphChartDefinition } from '../models';
2
- import { ChartPluginsRegistry } from './chart-plugins-registry.service';
3
3
  import { ChartCallbacksRegisterService } from './chart-callbacks-register.services';
4
- import { TranslateService } from '@ngx-translate/core';
4
+ import { ChartPluginsRegistry } from './chart-plugins-registry.service';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class ReportConfigMapperService {
7
7
  private readonly _chartPluginsRegistry;
@@ -1,7 +1,7 @@
1
+ import { EvaluatedString } from '../../../../shared';
1
2
  import { TableColumnAction, TableColumnConfig } from './table-column';
2
3
  import { NdfTableOptions } from './table-options';
3
4
  import { TableDefaultSortModel, TablePaginationOptions, TableSortOptions } from './types';
4
- import { EvaluatedString } from '../../../../shared';
5
5
  /**
6
6
  * Configuration type for the NDF Table component.
7
7
  * Extends `TablePaginationOptions` and provides additional properties
@@ -1,7 +1,9 @@
1
- export * from './directives';
2
- export * from './services';
3
1
  export * from './components';
4
- export * from './models';
5
- export * from './libraryShared.module';
6
- export * from './evaluator';
7
2
  export * from './constants';
3
+ export * from './directives';
4
+ export * from './libraryShared.module';
5
+ export * from './models';
6
+ export * from './services';
7
+ export declare type InterpolateString = string;
8
+ export declare type Whitespace = '' | ' ' | `${any}`;
9
+ export declare type EvaluatedString<VAR extends string = 'show'> = `${string}${VAR}${Whitespace}=${Whitespace}${string}`;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nuxeo-development-framework",
3
- "version": "6.1.5",
3
+ "version": "6.1.7",
4
4
  "peerDependencies": {
5
5
  "@angular/animations": "12.2.3",
6
6
  "@angular/common": "12.2.3",
package/public-api.d.ts CHANGED
@@ -117,11 +117,11 @@ export * from './lib/components/latest-activity/components/single-activity/singl
117
117
  export * from './lib/components/latest-activity/latest-activity.module';
118
118
  export * from './lib/components/pagination/pagination.module';
119
119
  export * from './lib/components/pagination/pagination/pagination.component';
120
+ export * from './lib/components/pdf-tron/directives/ndf-tron-extract-text.directive';
120
121
  export * from './lib/components/pdf-tron/pdf-tron.module';
121
122
  export * from './lib/components/pdf-tron/pdftron/pdftron.component';
122
123
  export * from './lib/components/pdf-tron/pdftron/pdftron.service';
123
124
  export * from './lib/components/pdf-tron/pdftron/silent-pdftron.service';
124
- export * from './lib/components/pdf-tron/directives/ndf-tron-extract-text.directive';
125
125
  export * from './lib/components/select/select.module';
126
126
  export * from './lib/components/select/select/select.component';
127
127
  export * from './lib/components/users-card/users-card.component';
@@ -178,18 +178,18 @@ export * from './lib/components/toasts';
178
178
  export * from './lib/components/dynamic-fields-renderer/dynamic-fields-renderer.module';
179
179
  export * from './lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component';
180
180
  export * from './lib/shared/components/button/button.component';
181
+ export * from './lib/shared/components/general-notification-popup/general-notification-popup.component';
181
182
  export * from './lib/shared/components/item-list/item-list.component';
182
183
  export * from './lib/shared/components/no-data/no-data.component';
183
184
  export * from './lib/shared/components/read-more/read-more.component';
184
185
  export * from './lib/shared/components/search-autocomplete/search-autocomplete.component';
185
186
  export * from './lib/shared/components/spinner/spinner.component';
186
187
  export * from './lib/shared/components/user-card/user-card.component';
187
- export * from './lib/shared/components/general-notification-popup/general-notification-popup.component';
188
188
  export * from './lib/shared/libraryShared.module';
189
+ export * from './lib/shared-services/apis-errors-messages.service';
189
190
  export * from './lib/shared-services/global-admin.service';
190
191
  export * from './lib/shared-services/shared-services.module';
191
192
  export * from './lib/shared-services/user.service';
192
- export * from './lib/shared-services/apis-errors-messages.service';
193
193
  export * from './lib/core/adapters/adapter.service';
194
194
  export * from './lib/core/enums/language.enum';
195
195
  export * from './lib/core/env/index';
@@ -230,21 +230,20 @@ export * from './lib/configuration/app-config.service';
230
230
  export * from './lib/configuration/helpers/app-initializer';
231
231
  export * from './lib/directive/permissions/evaluators.service';
232
232
  export * from './lib/components/comments/services/comment-api.service';
233
- export * from './lib/shared/directives';
234
- export * from './lib/core/tokens';
233
+ export * from './lib/components/ndf-config-editor';
235
234
  export * from './lib/components/ndf-datepicker';
235
+ export * from './lib/components/ndf-filters';
236
236
  export * from './lib/components/ndf-panel';
237
+ export * from './lib/components/ndf-scanner';
238
+ export * from './lib/components/ndf-signatures';
237
239
  export * from './lib/components/ndf-tabs';
240
+ export * from './lib/components/ndf-uploader';
238
241
  export * from './lib/components/no-data-found';
242
+ export * from './lib/components/reports/chart-panel';
239
243
  export * from './lib/components/reports/charts';
240
244
  export * from './lib/components/reports/ndf-reports';
241
- export * from './lib/components/reports/chart-panel';
242
245
  export * from './lib/components/skeleton';
243
246
  export * from './lib/components/tables';
244
- export * from './lib/components/ndf-config-editor';
245
- export * from './lib/components/ndf-filters';
246
- export * from './lib/components/ndf-uploader';
247
- export * from './lib/components/ndf-scanner';
248
- export * from './lib/components/ndf-signatures';
249
- export * from './lib/shared/evaluator';
247
+ export * from './lib/core/tokens';
250
248
  export * from './lib/shared/constants';
249
+ export * from './lib/shared/directives';
@@ -1,318 +0,0 @@
1
- import _, { get, keys, set, trim, values } from 'lodash';
2
- import stringHash from 'string-hash';
3
- /**
4
- * Creates a secure context for function evaluation that prevents access to the window object.
5
- * @returns {Record<string, any>} A secure context object with safe properties.
6
- */
7
- function createSecureContext() {
8
- // Create a secure context with only safe properties
9
- return {
10
- // Add any safe globals here that should be accessible
11
- console: {
12
- log: console.log,
13
- warn: console.warn,
14
- error: console.error
15
- },
16
- // Add other safe objects/functions as needed
17
- Math,
18
- Date,
19
- Number,
20
- String,
21
- Boolean,
22
- Array,
23
- Object,
24
- JSON,
25
- // Prevent access to window
26
- window: undefined,
27
- self: undefined,
28
- globalThis: undefined,
29
- _: _ // Include lodash if needed, but ensure it's used safely
30
- };
31
- }
32
- /**
33
- * A utility class for evaluating expressions, interpolating strings, and working with templates.
34
- * This class provides static methods for dynamic evaluation of code, string interpolation,
35
- * and template processing with caching capabilities.
36
- */
37
- export class Evaluator {
38
- /**
39
- * Creates a function from a string or returns the function if already provided.
40
- * Uses a secure context to prevent access to the window object by default.
41
- * @param {string|Function} func - The function or string to convert to a function.
42
- * @param {...any} params - The parameters to pass to the function.
43
- * @param {EvaluatorOptions} [options={}] - Optional configuration for the evaluation.
44
- * @returns {Function} - The resulting function.
45
- */
46
- static evaluator(func, ...params) {
47
- // Extract options if the last parameter is an options object
48
- let options = {};
49
- if (params.length > 0 &&
50
- params[params.length - 1] &&
51
- typeof params[params.length - 1] === 'object' &&
52
- 'securityMode' in params[params.length - 1]) {
53
- options = params.pop();
54
- }
55
- if (typeof func === 'function') {
56
- return func;
57
- }
58
- if (typeof params[0] === 'object') {
59
- params = keys(params[0]);
60
- }
61
- // Check if we should use secure mode (default) or unsafe mode
62
- const securityMode = options.securityMode || 'secure';
63
- if (securityMode === 'unsafe') {
64
- // In unsafe mode, create a function with access to all globals
65
- return new Function(...params, func);
66
- }
67
- const sandbox = createSecureContext();
68
- const sandboxKeys = Object.keys(sandbox);
69
- const sandboxAssignments = sandboxKeys.map((key) => `const ${key} = sandbox.${key};`).join('');
70
- const wrapper = new Function(...params, 'sandbox', `${sandboxAssignments}${func}`);
71
- return (...args) => wrapper(...args, sandbox);
72
- }
73
- /**
74
- * Replaces template expressions in a string with values from data.
75
- * Supports function calls within templates and fallback values using || syntax.
76
- * By default, ensures evaluation happens in a secure context to prevent access to window object.
77
- * @param {string} rawTemplate - The template string containing expressions to interpolate.
78
- * @param {Record<string, any>} data - The data object containing values to use for interpolation.
79
- * @param {EvaluatorOptions} [options={}] - Optional configuration for the interpolation process.
80
- * @returns {string} - The interpolated string with all expressions replaced with actual values.
81
- */
82
- static interpolateString(rawTemplate, data, options = {}) {
83
- if (!rawTemplate) {
84
- return '';
85
- }
86
- if (typeof rawTemplate !== 'string') {
87
- return rawTemplate.toString();
88
- }
89
- // Check if we should use secure mode (default) or unsafe mode
90
- const securityMode = options.securityMode || 'secure';
91
- // Create a secure data object if needed
92
- const secureData = securityMode === 'unsafe'
93
- ? data
94
- : Object.assign(Object.assign(Object.assign({}, createSecureContext()), data), {
95
- // Ensure these remain undefined
96
- window: undefined, self: undefined, globalThis: undefined });
97
- return rawTemplate.replace(/({{\s*(.*?)\s*}})/g, (match, $1, expression) => {
98
- if (expression.indexOf('(') !== -1) {
99
- return expression.replace(/([^(]+)\(([^)]+)\s*\);?/, (_, fnName, argsStr) => {
100
- fnName = trim(fnName);
101
- const func = get(secureData, fnName);
102
- if (func) {
103
- if (argsStr) {
104
- const args = argsStr.split(',').map((arg) => {
105
- const trimmed = trim(arg);
106
- if (/^['"]/.test(trimmed))
107
- return trimmed.slice(1, -1);
108
- return get(secureData, trimmed);
109
- });
110
- return Evaluator.evaluate(func, args, '', false, secureData, options);
111
- }
112
- return Evaluator.evaluate(func, [], '', false, secureData, options);
113
- }
114
- return '';
115
- });
116
- }
117
- else {
118
- let dataPath = expression;
119
- if (expression.indexOf('?') !== -1) {
120
- dataPath = expression.replace(/\?\./g, '.');
121
- }
122
- const parts = dataPath.split('||').map((item) => item.trim());
123
- let value = '';
124
- let path = '';
125
- for (let i = 0; i < parts.length; i++) {
126
- path = parts[i];
127
- if (_.has(secureData, path)) {
128
- value = _.get(secureData, path);
129
- break;
130
- }
131
- }
132
- if (options.data) {
133
- set(options.data, path, value);
134
- }
135
- return value;
136
- }
137
- });
138
- }
139
- /**
140
- * Performs an evaluation using the evaluation context of this component.
141
- * By default, ensures evaluation happens in a secure context to prevent access to window object.
142
- * @param {string|Function|object} func - The function or string to evaluate.
143
- * @param {object} args - The arguments to pass to the evaluation.
144
- * @param {string} ret - The name of the variable within the evaluation context to return.
145
- * @param {boolean} interpolate - Determines if it should replace all {{ }} token references with actual data.
146
- * @param {object} context - - The evaluation context.
147
- * @param {EvaluatorOptions } options - The options to pass to the evaluation.
148
- * @returns {*} - The result of the evaluation.
149
- */
150
- static evaluate(func, args = {}, ret = 'show', interpolate = false, context = {}, options = {}) {
151
- let returnVal = null;
152
- const field = args.field ? args.field : { key: 'unknown' };
153
- const fieldKey = field.key;
154
- if (typeof func === 'string') {
155
- if (ret) {
156
- func = `var ${ret};${func};return ${ret}`;
157
- }
158
- if (interpolate) {
159
- func = Evaluator.interpolate(func, args, options);
160
- }
161
- try {
162
- // Pass the security mode option to the evaluator
163
- const evaluatorOptions = { securityMode: options.securityMode || 'secure' };
164
- func = Evaluator.evaluator(func, args, context, evaluatorOptions);
165
- args = Array.isArray(args) ? args : values(args);
166
- }
167
- catch (err) {
168
- console.warn(`An error occured within the custom function for ${fieldKey}`, err);
169
- returnVal = null;
170
- func = false;
171
- }
172
- }
173
- if (typeof func === 'function') {
174
- try {
175
- returnVal = Evaluator.execute(func, args, context, options);
176
- }
177
- catch (err) {
178
- returnVal = null;
179
- console.warn(`An error occured within custom function for ${fieldKey}`, err);
180
- }
181
- }
182
- else if (func) {
183
- console.warn(`Unknown function type for ${fieldKey}`);
184
- }
185
- return returnVal;
186
- }
187
- /**
188
- * Executes a function with provided arguments and context.
189
- * By default, ensures execution happens in a secure context to prevent access to window object.
190
- * @param {Function} func - The function to execute.
191
- * @param {any[]|Record<string, any>} args - The arguments to pass to the function, either as an array or object.
192
- * @param {Record<string, any>} [context={}] - The context (this) to use when executing the function.
193
- * @param {EvaluatorOptions} [options={}] - Optional configuration for the execution.
194
- * @returns {any} - The result of the function execution.
195
- */
196
- static execute(func, args, context = {}, options = {}) {
197
- // Check if we should use secure mode (default) or unsafe mode
198
- const securityMode = options.securityMode || 'secure';
199
- if (securityMode === 'unsafe') {
200
- // In unsafe mode, execute with the original context
201
- return Array.isArray(args) ? func.apply(context, args) : func.call(context, args);
202
- }
203
- else {
204
- // In secure mode, create a secure context by merging the provided context with our secure context
205
- const secureContext = Object.assign(Object.assign(Object.assign({}, createSecureContext()), context), {
206
- // Ensure these remain undefined even if they were in the provided context
207
- window: undefined, self: undefined, globalThis: undefined });
208
- // Execute the function with the secure context
209
- return Array.isArray(args) ? func.apply(secureContext, args) : func.call(secureContext, args);
210
- }
211
- }
212
- /**
213
- * Creates a template function from a string with caching for performance.
214
- * By default, ensures the template function executes in a secure context.
215
- * @param {string} template - The template string to compile into a function.
216
- * @param {string} [hash] - Optional hash to use as cache key. If not provided, a hash will be generated from the template.
217
- * @param {EvaluatorOptions} [options={}] - Optional configuration for the template.
218
- * @returns {Function|undefined} - The compiled template function, or undefined if compilation fails.
219
- */
220
- static template(template, hash, options = {}) {
221
- hash = hash || stringHash(template).toString();
222
- // If hash contains options object, extract it
223
- if (typeof hash === 'object' && 'securityMode' in hash) {
224
- options = hash;
225
- hash = stringHash(template).toString();
226
- }
227
- // Check if we have a cached version
228
- const cacheKey = hash + (options.securityMode || 'secure');
229
- if (Evaluator.cache[cacheKey]) {
230
- return Evaluator.cache[cacheKey];
231
- }
232
- try {
233
- template = template.replace(/ctx\./g, '');
234
- // Create the template function using lodash
235
- const templateFunc = _.template(template, Evaluator.templateSettings);
236
- // Check if we should use secure mode (default) or unsafe mode
237
- const securityMode = options.securityMode || 'secure';
238
- if (securityMode === 'unsafe') {
239
- // In unsafe mode, return the original template function
240
- return (Evaluator.cache[cacheKey] = templateFunc);
241
- }
242
- else {
243
- // In secure mode, wrap the template function to ensure it runs in a secure context
244
- const secureTemplateFunc = (data) => {
245
- // Create a secure context for the template
246
- const secureData = Object.assign(Object.assign(Object.assign({}, createSecureContext()), data), {
247
- // Ensure these remain undefined
248
- window: undefined, self: undefined, globalThis: undefined });
249
- return templateFunc(secureData);
250
- };
251
- // Cache and return the secure template function
252
- return (Evaluator.cache[cacheKey] = secureTemplateFunc);
253
- }
254
- }
255
- catch (err) {
256
- console.warn('Error while processing template', err, template);
257
- return undefined;
258
- }
259
- }
260
- /**
261
- * Interpolates a template with data, handling both function templates and string templates.
262
- * By default, ensures interpolation happens in a secure context to prevent access to window object.
263
- * @param {string|Function} rawTemplate - The template to interpolate, either as a string or a function.
264
- * @param {Record<string, any>} data - The data object to use for interpolation.
265
- * @param {EvaluatorOptions} options - Options for the interpolation process.
266
- * @returns {string|any} - The result of the interpolation, typically a string but could be any type depending on the template.
267
- */
268
- static interpolate(rawTemplate, data, options = {}) {
269
- if (typeof rawTemplate === 'function') {
270
- try {
271
- // If the template is a function, execute it with the data
272
- // We can't directly secure a provided function, but we can use execute
273
- // to run it in a secure context if needed
274
- if (options.securityMode !== 'unsafe') {
275
- const secureData = Object.assign(Object.assign(Object.assign({}, createSecureContext()), data), { window: undefined, self: undefined, globalThis: undefined });
276
- return rawTemplate(secureData);
277
- }
278
- else {
279
- return rawTemplate(data);
280
- }
281
- }
282
- catch (err) {
283
- console.warn('Error interpolating template', err, data);
284
- return err.message;
285
- }
286
- }
287
- rawTemplate = String(rawTemplate);
288
- // Pass the security mode option to the template method
289
- const template = Evaluator.template(rawTemplate, undefined, options);
290
- if (typeof template === 'function') {
291
- try {
292
- return template(data);
293
- }
294
- catch (err) {
295
- console.warn('Error interpolating template', err, rawTemplate, data);
296
- return err.message;
297
- }
298
- }
299
- return template;
300
- }
301
- }
302
- /**
303
- * Cache for storing compiled template functions to improve performance.
304
- * Keys are string hashes of the template, values are the compiled functions.
305
- */
306
- Evaluator.cache = {};
307
- /**
308
- * Settings for template processing, defining regex patterns for different template operations.
309
- * - interpolate: Pattern for variable interpolation ({{ variable }})
310
- * - evaluate: Pattern for code evaluation ({% code %})
311
- * - escape: Pattern for HTML escaping ({{{ variable }}})
312
- */
313
- Evaluator.templateSettings = {
314
- interpolate: /{{([\s\S]+?)}}/g,
315
- evaluate: /\{%([\s\S]+?)%\}/g,
316
- escape: /\{\{\{([\s\S]+?)\}\}\}/g
317
- };
318
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evaluator.js","sourceRoot":"","sources":["../../../../../../projects/nuxeo-development-framework/src/lib/shared/evaluator/evaluator.ts"],"names":[],"mappings":"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","sourcesContent":["import _, { get, keys, set, trim, values } from 'lodash';\r\nimport stringHash from 'string-hash';\r\n\r\nimport { EvaluatorOptions, TemplateSettings } from './types';\r\n\r\n/**\r\n * Creates a secure context for function evaluation that prevents access to the window object.\r\n * @returns {Record<string, any>} A secure context object with safe properties.\r\n */\r\nfunction createSecureContext(): Record<string, any> {\r\n\t// Create a secure context with only safe properties\r\n\treturn {\r\n\t\t// Add any safe globals here that should be accessible\r\n\t\tconsole: {\r\n\t\t\tlog: console.log,\r\n\t\t\twarn: console.warn,\r\n\t\t\terror: console.error\r\n\t\t},\r\n\t\t// Add other safe objects/functions as needed\r\n\t\tMath,\r\n\t\tDate,\r\n\t\tNumber,\r\n\t\tString,\r\n\t\tBoolean,\r\n\t\tArray,\r\n\t\tObject,\r\n\t\tJSON,\r\n\t\t// Prevent access to window\r\n\t\twindow: undefined,\r\n\t\tself: undefined,\r\n\t\tglobalThis: undefined,\r\n\t\t_: _ // Include lodash if needed, but ensure it's used safely\r\n\t};\r\n}\r\n\r\n/**\r\n * A utility class for evaluating expressions, interpolating strings, and working with templates.\r\n * This class provides static methods for dynamic evaluation of code, string interpolation,\r\n * and template processing with caching capabilities.\r\n */\r\nexport class Evaluator {\r\n\t/**\r\n\t * Cache for storing compiled template functions to improve performance.\r\n\t * Keys are string hashes of the template, values are the compiled functions.\r\n\t */\r\n\tstatic cache: Record<string, Function> = {};\r\n\r\n\t/**\r\n\t * Settings for template processing, defining regex patterns for different template operations.\r\n\t * - interpolate: Pattern for variable interpolation ({{ variable }})\r\n\t * - evaluate: Pattern for code evaluation ({% code %})\r\n\t * - escape: Pattern for HTML escaping ({{{ variable }}})\r\n\t */\r\n\tstatic templateSettings: TemplateSettings = {\r\n\t\tinterpolate: /{{([\\s\\S]+?)}}/g,\r\n\t\tevaluate: /\\{%([\\s\\S]+?)%\\}/g,\r\n\t\tescape: /\\{\\{\\{([\\s\\S]+?)\\}\\}\\}/g\r\n\t};\r\n\r\n\t/**\r\n\t * Creates a function from a string or returns the function if already provided.\r\n\t * Uses a secure context to prevent access to the window object by default.\r\n\t * @param {string|Function} func - The function or string to convert to a function.\r\n\t * @param {...any} params - The parameters to pass to the function.\r\n\t * @param {EvaluatorOptions} [options={}] - Optional configuration for the evaluation.\r\n\t * @returns {Function} - The resulting function.\r\n\t */\r\n\tstatic evaluator(func: string | Function, ...params: any[]): Function {\r\n\t\t// Extract options if the last parameter is an options object\r\n\t\tlet options: EvaluatorOptions = {};\r\n\t\tif (\r\n\t\t\tparams.length > 0 &&\r\n\t\t\tparams[params.length - 1] &&\r\n\t\t\ttypeof params[params.length - 1] === 'object' &&\r\n\t\t\t'securityMode' in params[params.length - 1]\r\n\t\t) {\r\n\t\t\toptions = params.pop() as EvaluatorOptions;\r\n\t\t}\r\n\r\n\t\tif (typeof func === 'function') {\r\n\t\t\treturn func;\r\n\t\t}\r\n\r\n\t\tif (typeof params[0] === 'object') {\r\n\t\t\tparams = keys(params[0]);\r\n\t\t}\r\n\r\n\t\t// Check if we should use secure mode (default) or unsafe mode\r\n\t\tconst securityMode = options.securityMode || 'secure';\r\n\r\n\t\tif (securityMode === 'unsafe') {\r\n\t\t\t// In unsafe mode, create a function with access to all globals\r\n\t\t\treturn new Function(...params, func as string);\r\n\t\t}\r\n\t\tconst sandbox = createSecureContext();\r\n\t\tconst sandboxKeys = Object.keys(sandbox);\r\n\t\tconst sandboxAssignments = sandboxKeys.map((key) => `const ${key} = sandbox.${key};`).join('');\r\n\r\n\t\tconst wrapper = new Function(...params, 'sandbox', `${sandboxAssignments}${func as string}`);\r\n\r\n\t\treturn (...args: any[]) => wrapper(...args, sandbox);\r\n\t}\r\n\r\n\t/**\r\n\t * Replaces template expressions in a string with values from data.\r\n\t * Supports function calls within templates and fallback values using || syntax.\r\n\t * By default, ensures evaluation happens in a secure context to prevent access to window object.\r\n\t * @param {string} rawTemplate - The template string containing expressions to interpolate.\r\n\t * @param {Record<string, any>} data - The data object containing values to use for interpolation.\r\n\t * @param {EvaluatorOptions} [options={}] - Optional configuration for the interpolation process.\r\n\t * @returns {string} - The interpolated string with all expressions replaced with actual values.\r\n\t */\r\n\tstatic interpolateString(rawTemplate: string, data: Record<string, any>, options: EvaluatorOptions = {}): string {\r\n\t\tif (!rawTemplate) {\r\n\t\t\treturn '';\r\n\t\t}\r\n\t\tif (typeof rawTemplate !== 'string') {\r\n\t\t\treturn (rawTemplate as any).toString();\r\n\t\t}\r\n\r\n\t\t// Check if we should use secure mode (default) or unsafe mode\r\n\t\tconst securityMode = options.securityMode || 'secure';\r\n\r\n\t\t// Create a secure data object if needed\r\n\t\tconst secureData =\r\n\t\t\tsecurityMode === 'unsafe'\r\n\t\t\t\t? data\r\n\t\t\t\t: {\r\n\t\t\t\t\t\t...createSecureContext(),\r\n\t\t\t\t\t\t...data,\r\n\t\t\t\t\t\t// Ensure these remain undefined\r\n\t\t\t\t\t\twindow: undefined,\r\n\t\t\t\t\t\tself: undefined,\r\n\t\t\t\t\t\tglobalThis: undefined\r\n\t\t\t\t\t};\r\n\r\n\t\treturn rawTemplate.replace(/({{\\s*(.*?)\\s*}})/g, (match: string, $1: string, expression: string) => {\r\n\t\t\tif (expression.indexOf('(') !== -1) {\r\n\t\t\t\treturn expression.replace(/([^(]+)\\(([^)]+)\\s*\\);?/, (_: string, fnName: string, argsStr: string) => {\r\n\t\t\t\t\tfnName = trim(fnName);\r\n\t\t\t\t\tconst func = get(secureData, fnName);\r\n\r\n\t\t\t\t\tif (func) {\r\n\t\t\t\t\t\tif (argsStr) {\r\n\t\t\t\t\t\t\tconst args = argsStr.split(',').map((arg: string) => {\r\n\t\t\t\t\t\t\t\tconst trimmed = trim(arg);\r\n\t\t\t\t\t\t\t\tif (/^['\"]/.test(trimmed)) return trimmed.slice(1, -1);\r\n\t\t\t\t\t\t\t\treturn get(secureData, trimmed);\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t\treturn Evaluator.evaluate(func, args, '', false, secureData, options);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\treturn Evaluator.evaluate(func, [], '', false, secureData, options);\r\n\t\t\t\t\t}\r\n\t\t\t\t\treturn '';\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\tlet dataPath = expression;\r\n\t\t\t\tif (expression.indexOf('?') !== -1) {\r\n\t\t\t\t\tdataPath = expression.replace(/\\?\\./g, '.');\r\n\t\t\t\t}\r\n\t\t\t\tconst parts = dataPath.split('||').map((item: string) => item.trim());\r\n\t\t\t\tlet value = '';\r\n\t\t\t\tlet path = '';\r\n\t\t\t\tfor (let i = 0; i < parts.length; i++) {\r\n\t\t\t\t\tpath = parts[i];\r\n\t\t\t\t\tif (_.has(secureData, path)) {\r\n\t\t\t\t\t\tvalue = _.get(secureData, path);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (options.data) {\r\n\t\t\t\t\tset(options.data, path, value);\r\n\t\t\t\t}\r\n\t\t\t\treturn value;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Performs an evaluation using the evaluation context of this component.\r\n\t * By default, ensures evaluation happens in a secure context to prevent access to window object.\r\n\t * @param {string|Function|object} func - The function or string to evaluate.\r\n\t * @param {object} args - The arguments to pass to the evaluation.\r\n\t * @param {string} ret - The name of the variable within the evaluation context to return.\r\n\t * @param {boolean} interpolate - Determines if it should replace all {{ }} token references with actual data.\r\n\t * @param {object} context -   - The evaluation context.\r\n\t * @param {EvaluatorOptions } options - The options to pass to the evaluation.\r\n\t * @returns {*} - The result of the evaluation.\r\n\t */\r\n\tstatic evaluate(\r\n\t\tfunc: any,\r\n\t\targs: Record<string, any> = {},\r\n\t\tret: string = 'show',\r\n\t\tinterpolate: boolean = false,\r\n\t\tcontext: Record<string, any> = {},\r\n\t\toptions: EvaluatorOptions = {}\r\n\t): any {\r\n\t\tlet returnVal = null;\r\n\r\n\t\tconst field = args.field ? args.field : { key: 'unknown' };\r\n\t\tconst fieldKey = field.key;\r\n\r\n\t\tif (typeof func === 'string') {\r\n\t\t\tif (ret) {\r\n\t\t\t\tfunc = `var ${ret};${func};return ${ret}`;\r\n\t\t\t}\r\n\r\n\t\t\tif (interpolate) {\r\n\t\t\t\tfunc = Evaluator.interpolate(func, args, options);\r\n\t\t\t}\r\n\r\n\t\t\ttry {\r\n\t\t\t\t// Pass the security mode option to the evaluator\r\n\t\t\t\tconst evaluatorOptions = { securityMode: options.securityMode || 'secure' };\r\n\t\t\t\tfunc = Evaluator.evaluator(func, args, context, evaluatorOptions);\r\n\t\t\t\targs = Array.isArray(args) ? args : values(args);\r\n\t\t\t} catch (err) {\r\n\t\t\t\tconsole.warn(`An error occured within the custom function for ${fieldKey}`, err);\r\n\t\t\t\treturnVal = null;\r\n\t\t\t\tfunc = false;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (typeof func === 'function') {\r\n\t\t\ttry {\r\n\t\t\t\treturnVal = Evaluator.execute(func, args, context, options);\r\n\t\t\t} catch (err) {\r\n\t\t\t\treturnVal = null;\r\n\t\t\t\tconsole.warn(`An error occured within custom function for ${fieldKey}`, err);\r\n\t\t\t}\r\n\t\t} else if (func) {\r\n\t\t\tconsole.warn(`Unknown function type for ${fieldKey}`);\r\n\t\t}\r\n\t\treturn returnVal;\r\n\t}\r\n\r\n\t/**\r\n\t * Executes a function with provided arguments and context.\r\n\t * By default, ensures execution happens in a secure context to prevent access to window object.\r\n\t * @param {Function} func - The function to execute.\r\n\t * @param {any[]|Record<string, any>} args - The arguments to pass to the function, either as an array or object.\r\n\t * @param {Record<string, any>} [context={}] - The context (this) to use when executing the function.\r\n\t * @param {EvaluatorOptions} [options={}] - Optional configuration for the execution.\r\n\t * @returns {any} - The result of the function execution.\r\n\t */\r\n\tstatic execute(\r\n\t\tfunc: Function,\r\n\t\targs: any[] | Record<string, any>,\r\n\t\tcontext: Record<string, any> = {},\r\n\t\toptions: EvaluatorOptions = {}\r\n\t): any {\r\n\t\t// Check if we should use secure mode (default) or unsafe mode\r\n\t\tconst securityMode = options.securityMode || 'secure';\r\n\r\n\t\tif (securityMode === 'unsafe') {\r\n\t\t\t// In unsafe mode, execute with the original context\r\n\t\t\treturn Array.isArray(args) ? func.apply(context, args) : func.call(context, args);\r\n\t\t} else {\r\n\t\t\t// In secure mode, create a secure context by merging the provided context with our secure context\r\n\t\t\tconst secureContext = {\r\n\t\t\t\t...createSecureContext(),\r\n\t\t\t\t...context,\r\n\t\t\t\t// Ensure these remain undefined even if they were in the provided context\r\n\t\t\t\twindow: undefined,\r\n\t\t\t\tself: undefined,\r\n\t\t\t\tglobalThis: undefined\r\n\t\t\t};\r\n\r\n\t\t\t// Execute the function with the secure context\r\n\t\t\treturn Array.isArray(args) ? func.apply(secureContext, args) : func.call(secureContext, args);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Creates a template function from a string with caching for performance.\r\n\t * By default, ensures the template function executes in a secure context.\r\n\t * @param {string} template - The template string to compile into a function.\r\n\t * @param {string} [hash] - Optional hash to use as cache key. If not provided, a hash will be generated from the template.\r\n\t * @param {EvaluatorOptions} [options={}] - Optional configuration for the template.\r\n\t * @returns {Function|undefined} - The compiled template function, or undefined if compilation fails.\r\n\t */\r\n\tstatic template(template: string, hash?: string, options: EvaluatorOptions = {}): Function | undefined {\r\n\t\thash = hash || stringHash(template).toString();\r\n\r\n\t\t// If hash contains options object, extract it\r\n\t\tif (typeof hash === 'object' && 'securityMode' in hash) {\r\n\t\t\toptions = hash as unknown as EvaluatorOptions;\r\n\t\t\thash = stringHash(template).toString();\r\n\t\t}\r\n\r\n\t\t// Check if we have a cached version\r\n\t\tconst cacheKey = hash + (options.securityMode || 'secure');\r\n\t\tif (Evaluator.cache[cacheKey]) {\r\n\t\t\treturn Evaluator.cache[cacheKey];\r\n\t\t}\r\n\r\n\t\ttry {\r\n\t\t\ttemplate = template.replace(/ctx\\./g, '');\r\n\r\n\t\t\t// Create the template function using lodash\r\n\t\t\tconst templateFunc = _.template(template, Evaluator.templateSettings);\r\n\r\n\t\t\t// Check if we should use secure mode (default) or unsafe mode\r\n\t\t\tconst securityMode = options.securityMode || 'secure';\r\n\r\n\t\t\tif (securityMode === 'unsafe') {\r\n\t\t\t\t// In unsafe mode, return the original template function\r\n\t\t\t\treturn (Evaluator.cache[cacheKey] = templateFunc);\r\n\t\t\t} else {\r\n\t\t\t\t// In secure mode, wrap the template function to ensure it runs in a secure context\r\n\t\t\t\tconst secureTemplateFunc = (data: any) => {\r\n\t\t\t\t\t// Create a secure context for the template\r\n\t\t\t\t\tconst secureData = {\r\n\t\t\t\t\t\t...createSecureContext(),\r\n\t\t\t\t\t\t...data,\r\n\t\t\t\t\t\t// Ensure these remain undefined\r\n\t\t\t\t\t\twindow: undefined,\r\n\t\t\t\t\t\tself: undefined,\r\n\t\t\t\t\t\tglobalThis: undefined\r\n\t\t\t\t\t};\r\n\r\n\t\t\t\t\treturn templateFunc(secureData);\r\n\t\t\t\t};\r\n\r\n\t\t\t\t// Cache and return the secure template function\r\n\t\t\t\treturn (Evaluator.cache[cacheKey] = secureTemplateFunc);\r\n\t\t\t}\r\n\t\t} catch (err) {\r\n\t\t\tconsole.warn('Error while processing template', err, template);\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Interpolates a template with data, handling both function templates and string templates.\r\n\t * By default, ensures interpolation happens in a secure context to prevent access to window object.\r\n\t * @param {string|Function} rawTemplate - The template to interpolate, either as a string or a function.\r\n\t * @param {Record<string, any>} data - The data object to use for interpolation.\r\n\t * @param {EvaluatorOptions} options - Options for the interpolation process.\r\n\t * @returns {string|any} - The result of the interpolation, typically a string but could be any type depending on the template.\r\n\t */\r\n\tstatic interpolate(\r\n\t\trawTemplate: string | Function,\r\n\t\tdata: Record<string, any>,\r\n\t\toptions: EvaluatorOptions = {}\r\n\t): string | any {\r\n\t\tif (typeof rawTemplate === 'function') {\r\n\t\t\ttry {\r\n\t\t\t\t// If the template is a function, execute it with the data\r\n\t\t\t\t// We can't directly secure a provided function, but we can use execute\r\n\t\t\t\t// to run it in a secure context if needed\r\n\t\t\t\tif (options.securityMode !== 'unsafe') {\r\n\t\t\t\t\tconst secureData = {\r\n\t\t\t\t\t\t...createSecureContext(),\r\n\t\t\t\t\t\t...data,\r\n\t\t\t\t\t\twindow: undefined,\r\n\t\t\t\t\t\tself: undefined,\r\n\t\t\t\t\t\tglobalThis: undefined\r\n\t\t\t\t\t};\r\n\t\t\t\t\treturn rawTemplate(secureData);\r\n\t\t\t\t} else {\r\n\t\t\t\t\treturn rawTemplate(data);\r\n\t\t\t\t}\r\n\t\t\t} catch (err) {\r\n\t\t\t\tconsole.warn('Error interpolating template', err, data);\r\n\t\t\t\treturn (err as Error).message;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\trawTemplate = String(rawTemplate);\r\n\t\t// Pass the security mode option to the template method\r\n\t\tconst template = Evaluator.template(rawTemplate, undefined, options);\r\n\r\n\t\tif (typeof template === 'function') {\r\n\t\t\ttry {\r\n\t\t\t\treturn template(data);\r\n\t\t\t} catch (err) {\r\n\t\t\t\tconsole.warn('Error interpolating template', err, rawTemplate, data);\r\n\t\t\t\treturn (err as Error).message;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn template;\r\n\t}\r\n}\r\n"]}
@@ -1,3 +0,0 @@
1
- export * from './evaluator';
2
- export * from './types';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9zaGFyZWQvZXZhbHVhdG9yL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsU0FBUyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ldmFsdWF0b3InO1xyXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJ1xyXG4iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9zaGFyZWQvZXZhbHVhdG9yL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBFdmFsdWF0b3JPcHRpb25zID0ge1xyXG5cdGRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xyXG5cdC8qKlxyXG5cdCAqIENvbnRyb2xzIHRoZSBzZWN1cml0eSBsZXZlbCBvZiBldmFsdWF0aW9uLlxyXG5cdCAqIC0gJ3NlY3VyZScgKGRlZmF1bHQpOiBQcmV2ZW50cyBhY2Nlc3MgdG8gd2luZG93IG9iamVjdCBhbmQgb3RoZXIgZ2xvYmFsIG9iamVjdHNcclxuXHQgKiAtICd1bnNhZmUnOiBBbGxvd3MgYWNjZXNzIHRvIGFsbCBnbG9iYWwgb2JqZWN0cyAodXNlIHdpdGggY2F1dGlvbilcclxuXHQgKi9cclxuXHRzZWN1cml0eU1vZGU/OiAnc2VjdXJlJyB8ICd1bnNhZmUnO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgVGVtcGxhdGVTZXR0aW5ncyA9IHtcclxuXHRpbnRlcnBvbGF0ZTogUmVnRXhwO1xyXG5cdGV2YWx1YXRlOiBSZWdFeHA7XHJcblx0ZXNjYXBlOiBSZWdFeHA7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBJbnRlcnBvbGF0ZVN0cmluZyA9IHN0cmluZztcclxuXHJcbmV4cG9ydCB0eXBlIEV2YWx1YXRlZFN0cmluZzxWQVIgZXh0ZW5kcyBzdHJpbmcgPSAnc2hvdyc+ID0gYCR7c3RyaW5nfSR7VkFSfSR7V2hpdGVzcGFjZX09JHtXaGl0ZXNwYWNlfSR7c3RyaW5nfWA7XHJcblxyXG50eXBlIFdoaXRlc3BhY2UgPSAnJyB8ICcgJyB8IGAke2FueX1gO1xyXG4iXX0=