@grnsft/if 0.1.2 → 0.1.3-beta

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 (85) hide show
  1. package/CONTRIBUTING.md +13 -17
  2. package/README.md +36 -18
  3. package/build/config/config.d.ts +12 -0
  4. package/build/config/config.js +54 -0
  5. package/build/config/strings.d.ts +8 -3
  6. package/build/config/strings.js +10 -6
  7. package/build/index.js +15 -8
  8. package/build/lib/models-universe.d.ts +10 -2
  9. package/build/lib/models-universe.js +52 -34
  10. package/build/lib/observatory.d.ts +20 -0
  11. package/build/lib/observatory.js +31 -0
  12. package/build/lib/planet-aggregator.d.ts +6 -0
  13. package/build/lib/planet-aggregator.js +35 -0
  14. package/build/lib/supercomputer.d.ts +7 -0
  15. package/build/lib/supercomputer.js +45 -6
  16. package/build/models/index.d.ts +1 -0
  17. package/build/models/index.js +6 -0
  18. package/build/models/time-sync.d.ts +55 -0
  19. package/build/models/time-sync.js +235 -0
  20. package/build/types/helpers.d.ts +1 -0
  21. package/build/types/helpers.js +3 -0
  22. package/build/types/impl.d.ts +14 -9
  23. package/build/types/impl.js +3 -1
  24. package/build/types/model-interface.d.ts +14 -0
  25. package/build/types/model-interface.js +3 -0
  26. package/build/types/models-universe.d.ts +5 -6
  27. package/build/types/models-universe.js +1 -1
  28. package/build/types/planet-aggregator.d.ts +6 -0
  29. package/build/types/planet-aggregator.js +3 -0
  30. package/build/types/process-args.d.ts +7 -0
  31. package/build/types/process-args.js +3 -0
  32. package/build/types/supercomputer.d.ts +4 -0
  33. package/build/types/supercomputer.js +3 -0
  34. package/build/types/time-sync.d.ts +9 -0
  35. package/build/types/time-sync.js +3 -0
  36. package/build/types/units-dealer.d.ts +3 -0
  37. package/build/types/units-dealer.js +3 -0
  38. package/build/types/units.d.ts +11 -0
  39. package/build/types/units.js +37 -0
  40. package/build/util/args.js +58 -0
  41. package/build/util/errors.d.ts +6 -0
  42. package/build/util/errors.js +25 -0
  43. package/build/util/helpers.js +18 -0
  44. package/build/util/units-dealer.d.ts +10 -0
  45. package/build/util/units-dealer.js +32 -0
  46. package/build/util/validations.d.ts +4 -0
  47. package/build/util/validations.js +29 -1
  48. package/build/util/yaml.d.ts +1 -2
  49. package/build/util/yaml.js +1 -1
  50. package/coverage/clover.xml +111 -65
  51. package/coverage/coverage-final.json +7 -6
  52. package/coverage/lcov-report/config/config.ts.html +12 -3
  53. package/coverage/lcov-report/config/index.html +1 -1
  54. package/coverage/lcov-report/config/index.ts.html +3 -3
  55. package/coverage/lcov-report/config/strings.ts.html +2 -2
  56. package/coverage/lcov-report/index.html +9 -9
  57. package/coverage/lcov-report/lib/index.html +24 -9
  58. package/coverage/lcov-report/lib/models-universe.ts.html +1 -1
  59. package/coverage/lcov-report/lib/observatory.ts.html +7 -7
  60. package/coverage/lcov-report/lib/planet-aggregator.ts.html +253 -0
  61. package/coverage/lcov-report/lib/supercomputer.ts.html +211 -52
  62. package/coverage/lcov-report/util/args.ts.html +1 -1
  63. package/coverage/lcov-report/util/errors.ts.html +10 -7
  64. package/coverage/lcov-report/util/index.html +1 -1
  65. package/coverage/lcov-report/util/yaml.ts.html +1 -1
  66. package/coverage/lcov.info +184 -105
  67. package/examples/impls/case-studies/aggregation.yml +97 -0
  68. package/examples/impls/case-studies/ntt-data-on-premise.yaml +0 -42
  69. package/examples/impls/test/aggregation-test.yml +109 -0
  70. package/examples/impls/test/large-impl.yml +257303 -0
  71. package/examples/impls/test/time-sync.yml +75 -0
  72. package/examples/ompls/aggregation-test.yml +340 -0
  73. package/examples/ompls/test/time-sync.yml +255 -0
  74. package/examples/ompls/time-sync.yml +212 -0
  75. package/hack-banner.png +0 -0
  76. package/package.json +3 -1
  77. package/src/config/units.yaml +11 -24
  78. package/src/models/README.md +266 -0
  79. package/tsconfig.build.tsbuildinfo +1 -0
  80. package/build/types/azure-importer.d.ts +0 -29
  81. package/build/types/azure-importer.js +0 -3
  82. package/build/types/boavizta.d.ts +0 -7
  83. package/build/types/boavizta.js +0 -3
  84. package/build/types/common.d.ts +0 -7
  85. package/build/types/common.js +0 -9
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.planetAggregator = void 0;
4
+ const errors_1 = require("../util/errors");
5
+ const { InvalidAggregationParams } = errors_1.ERRORS;
6
+ /**
7
+ * Aggregates child node level metrics. Uses provided aggregation `params`.
8
+ */
9
+ const planetAggregator = (inputs, params) => {
10
+ if (!params['aggregation-metrics'] ||
11
+ params['aggregation-metrics'].length === 0) {
12
+ throw new InvalidAggregationParams('Provided aggregation metrics are invalid. Please provide an array of strings.');
13
+ }
14
+ const aggregationMetrics = params['aggregation-metrics'];
15
+ const aggregationMethod = params['aggregation-method'];
16
+ return inputs.reduce((acc, input, index) => {
17
+ for (const metric of aggregationMetrics) {
18
+ if (!(metric in input)) {
19
+ throw new InvalidAggregationParams(`Aggregation metric ${metric} is not found in inputs[${index}].`);
20
+ }
21
+ const accessKey = `aggregated-${metric}`;
22
+ const value = parseFloat(input[metric]);
23
+ acc[accessKey] = acc[accessKey] ?? 0;
24
+ acc[accessKey] += value;
25
+ if (index === inputs.length - 1) {
26
+ if (aggregationMethod === 'avg') {
27
+ acc[accessKey] /= inputs.length;
28
+ }
29
+ }
30
+ }
31
+ return acc;
32
+ }, {});
33
+ };
34
+ exports.planetAggregator = planetAggregator;
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhbmV0LWFnZ3JlZ2F0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL3BsYW5ldC1hZ2dyZWdhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJDQUFzQztBQVN0QyxNQUFNLEVBQUMsd0JBQXdCLEVBQUMsR0FBRyxlQUFNLENBQUM7QUFFMUM7O0dBRUc7QUFDSSxNQUFNLGdCQUFnQixHQUFHLENBQzlCLE1BQXFCLEVBQ3JCLE1BQThCLEVBQzlCLEVBQUU7SUFDRixJQUNFLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDO1FBQzlCLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQzFDLENBQUM7UUFDRCxNQUFNLElBQUksd0JBQXdCLENBQ2hDLCtFQUErRSxDQUNoRixDQUFDO0lBQ0osQ0FBQztJQUVELE1BQU0sa0JBQWtCLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFrQixDQUFDO0lBQzFFLE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFFdkQsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRTtRQUN6QyxLQUFLLE1BQU0sTUFBTSxJQUFJLGtCQUFrQixFQUFFLENBQUM7WUFDeEMsSUFBSSxDQUFDLENBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ3ZCLE1BQU0sSUFBSSx3QkFBd0IsQ0FDaEMsc0JBQXNCLE1BQU0sMkJBQTJCLEtBQUssSUFBSSxDQUNqRSxDQUFDO1lBQ0osQ0FBQztZQUVELE1BQU0sU0FBUyxHQUFHLGNBQWMsTUFBTSxFQUFFLENBQUM7WUFDekMsTUFBTSxLQUFLLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1lBQ3hDLEdBQUcsQ0FBQyxTQUFTLENBQUMsR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3JDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxLQUFLLENBQUM7WUFFeEIsSUFBSSxLQUFLLEtBQUssTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDaEMsSUFBSSxpQkFBaUIsS0FBSyxLQUFLLEVBQUUsQ0FBQztvQkFDaEMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUM7Z0JBQ2xDLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQyxFQUFFLEVBQXVCLENBQUMsQ0FBQztBQUM5QixDQUFDLENBQUM7QUF0Q1csUUFBQSxnQkFBZ0Isb0JBc0MzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RVJST1JTfSBmcm9tICcuLi91dGlsL2Vycm9ycyc7XG5cbmltcG9ydCB7XG4gIEFnZ3JlZ2F0aW9uUmVzdWx0LFxuICBQbGFuZXRBZ2dyZWdhdG9yUGFyYW1zLFxufSBmcm9tICcuLi90eXBlcy9wbGFuZXQtYWdncmVnYXRvcic7XG5pbXBvcnQge01vZGVsUGFyYW1zfSBmcm9tICcuLi90eXBlcy9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi4vdHlwZXMvdW5pdHMnO1xuXG5jb25zdCB7SW52YWxpZEFnZ3JlZ2F0aW9uUGFyYW1zfSA9IEVSUk9SUztcblxuLyoqXG4gKiBBZ2dyZWdhdGVzIGNoaWxkIG5vZGUgbGV2ZWwgbWV0cmljcy4gVXNlcyBwcm92aWRlZCBhZ2dyZWdhdGlvbiBgcGFyYW1zYC5cbiAqL1xuZXhwb3J0IGNvbnN0IHBsYW5ldEFnZ3JlZ2F0b3IgPSAoXG4gIGlucHV0czogTW9kZWxQYXJhbXNbXSxcbiAgcGFyYW1zOiBQbGFuZXRBZ2dyZWdhdG9yUGFyYW1zXG4pID0+IHtcbiAgaWYgKFxuICAgICFwYXJhbXNbJ2FnZ3JlZ2F0aW9uLW1ldHJpY3MnXSB8fFxuICAgIHBhcmFtc1snYWdncmVnYXRpb24tbWV0cmljcyddLmxlbmd0aCA9PT0gMFxuICApIHtcbiAgICB0aHJvdyBuZXcgSW52YWxpZEFnZ3JlZ2F0aW9uUGFyYW1zKFxuICAgICAgJ1Byb3ZpZGVkIGFnZ3JlZ2F0aW9uIG1ldHJpY3MgYXJlIGludmFsaWQuIFBsZWFzZSBwcm92aWRlIGFuIGFycmF5IG9mIHN0cmluZ3MuJ1xuICAgICk7XG4gIH1cblxuICBjb25zdCBhZ2dyZWdhdGlvbk1ldHJpY3MgPSBwYXJhbXNbJ2FnZ3JlZ2F0aW9uLW1ldHJpY3MnXSBhcyBVbml0S2V5TmFtZVtdO1xuICBjb25zdCBhZ2dyZWdhdGlvbk1ldGhvZCA9IHBhcmFtc1snYWdncmVnYXRpb24tbWV0aG9kJ107XG5cbiAgcmV0dXJuIGlucHV0cy5yZWR1Y2UoKGFjYywgaW5wdXQsIGluZGV4KSA9PiB7XG4gICAgZm9yIChjb25zdCBtZXRyaWMgb2YgYWdncmVnYXRpb25NZXRyaWNzKSB7XG4gICAgICBpZiAoIShtZXRyaWMgaW4gaW5wdXQpKSB7XG4gICAgICAgIHRocm93IG5ldyBJbnZhbGlkQWdncmVnYXRpb25QYXJhbXMoXG4gICAgICAgICAgYEFnZ3JlZ2F0aW9uIG1ldHJpYyAke21ldHJpY30gaXMgbm90IGZvdW5kIGluIGlucHV0c1ske2luZGV4fV0uYFxuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBhY2Nlc3NLZXkgPSBgYWdncmVnYXRlZC0ke21ldHJpY31gO1xuICAgICAgY29uc3QgdmFsdWUgPSBwYXJzZUZsb2F0KGlucHV0W21ldHJpY10pO1xuICAgICAgYWNjW2FjY2Vzc0tleV0gPSBhY2NbYWNjZXNzS2V5XSA/PyAwO1xuICAgICAgYWNjW2FjY2Vzc0tleV0gKz0gdmFsdWU7XG5cbiAgICAgIGlmIChpbmRleCA9PT0gaW5wdXRzLmxlbmd0aCAtIDEpIHtcbiAgICAgICAgaWYgKGFnZ3JlZ2F0aW9uTWV0aG9kID09PSAnYXZnJykge1xuICAgICAgICAgIGFjY1thY2Nlc3NLZXldIC89IGlucHV0cy5sZW5ndGg7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSBhcyBBZ2dyZWdhdGlvblJlc3VsdCk7XG59O1xuIl19
@@ -1,5 +1,6 @@
1
1
  import { ModelsUniverse } from './models-universe';
2
2
  import { Impl } from '../types/impl';
3
+ import { AggregationResult } from '../types/planet-aggregator';
3
4
  /**
4
5
  * Computer for `impl` documents.
5
6
  */
@@ -7,7 +8,13 @@ export declare class Supercomputer {
7
8
  private olderChild;
8
9
  private impl;
9
10
  private modelsHandbook;
11
+ private aggregatedImpacts;
12
+ private childAmount;
10
13
  constructor(impl: Impl, modelsHandbook: ModelsUniverse);
14
+ /**
15
+ * Goes through all aggregations collected from child components, then calculates the average.
16
+ */
17
+ calculateAggregation(): AggregationResult;
11
18
  /**
12
19
  * Flattens config entries.
13
20
  */
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Supercomputer = void 0;
4
4
  const observatory_1 = require("./observatory");
5
+ const planet_aggregator_1 = require("./planet-aggregator");
5
6
  const errors_1 = require("../util/errors");
6
7
  const config_1 = require("../config");
7
8
  const { ImplValidationError } = errors_1.ERRORS;
@@ -12,9 +13,33 @@ const { STRUCTURE_MALFORMED } = config_1.STRINGS;
12
13
  class Supercomputer {
13
14
  constructor(impl, modelsHandbook) {
14
15
  this.olderChild = { name: '', info: {} };
16
+ this.aggregatedImpacts = [];
17
+ this.childAmount = 0;
15
18
  this.impl = impl;
16
19
  this.modelsHandbook = modelsHandbook;
17
20
  }
21
+ /**
22
+ * Goes through all aggregations collected from child components, then calculates the average.
23
+ */
24
+ calculateAggregation() {
25
+ if (!this.impl.aggregation) {
26
+ throw new ImplValidationError('Aggregation params are not provided.');
27
+ }
28
+ const method = this.impl.aggregation['aggregation-method'];
29
+ return this.aggregatedImpacts.reduce((acc, impact, index) => {
30
+ const keys = Object.keys(impact);
31
+ keys.forEach(key => {
32
+ acc[key] = acc[key] ?? 0;
33
+ acc[key] += impact[key];
34
+ if (index === this.childAmount - 1) {
35
+ if (method === 'avg') {
36
+ acc[key] /= this.childAmount;
37
+ }
38
+ }
39
+ });
40
+ return acc;
41
+ }, {});
42
+ }
18
43
  /**
19
44
  * Flattens config entries.
20
45
  */
@@ -65,6 +90,7 @@ class Supercomputer {
65
90
  if (!('inputs' in childrenObject[childName])) {
66
91
  throw new ImplValidationError(STRUCTURE_MALFORMED(childName));
67
92
  }
93
+ this.childAmount++;
68
94
  const specificInputs = areChildrenNested
69
95
  ? childrenObject[childName].inputs
70
96
  : inputs;
@@ -77,13 +103,26 @@ class Supercomputer {
77
103
  await observatory.doInvestigationsWith(modelInstance);
78
104
  }
79
105
  const outputs = observatory.getOutputs();
106
+ /**
107
+ * If aggregation is required, then init `aggregated-outputs`.
108
+ */
109
+ if (this.impl.aggregation) {
110
+ const aggregatedImpactsPerChild = (0, planet_aggregator_1.planetAggregator)(outputs, this.impl.aggregation);
111
+ this.aggregatedImpacts.push(aggregatedImpactsPerChild);
112
+ if (areChildrenNested) {
113
+ this.impl.graph.children[this.olderChild.name].children[childName]['aggregated-outputs'] = aggregatedImpactsPerChild;
114
+ }
115
+ else {
116
+ this.impl.graph.children[this.olderChild.name]['aggregated-outputs'] =
117
+ aggregatedImpactsPerChild;
118
+ }
119
+ }
80
120
  if (areChildrenNested) {
81
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
82
- // @ts-ignore
83
- this.impl.graph.children[this.olderChild.name].children[childName].outputs = observatory.getOutputs();
84
- return;
121
+ this.impl.graph.children[this.olderChild.name].children[childName].outputs = outputs;
122
+ }
123
+ else {
124
+ this.impl.graph.children[this.olderChild.name].outputs = outputs;
85
125
  }
86
- this.impl.graph.children[this.olderChild.name].outputs = outputs;
87
126
  return;
88
127
  }
89
128
  /**
@@ -106,4 +145,4 @@ class Supercomputer {
106
145
  }
107
146
  }
108
147
  exports.Supercomputer = Supercomputer;
109
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwZXJjb21wdXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvc3VwZXJjb21wdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrQ0FBMEM7QUFFMUMsMkNBQXNDO0FBRXRDLHNDQUFrQztBQUtsQyxNQUFNLEVBQUMsbUJBQW1CLEVBQUMsR0FBRyxlQUFNLENBQUM7QUFFckMsTUFBTSxFQUFDLG1CQUFtQixFQUFDLEdBQUcsZ0JBQU8sQ0FBQztBQUV0Qzs7R0FFRztBQUNILE1BQWEsYUFBYTtJQUt4QixZQUFZLElBQVUsRUFBRSxjQUE4QjtRQUo5QyxlQUFVLEdBQXFCLEVBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFDLENBQUM7UUFLMUQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDdkMsQ0FBQztJQUVEOztPQUVHO0lBQ0ssbUJBQW1CLENBQUMsTUFBYztRQUN4QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUVELE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM3QyxNQUFNLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFRLEVBQUUsSUFBWSxFQUFFLEVBQUU7WUFDaEUsR0FBRyxHQUFHO2dCQUNKLEdBQUcsR0FBRztnQkFDTixHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUM7YUFDaEIsQ0FBQztZQUVGLE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRVAsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ssWUFBWSxDQUNsQixNQUFxQixFQUNyQixNQUFjLEVBQ2QsWUFBb0I7UUFFcEIsTUFBTSxZQUFZLEdBQUcs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QUFJLENBQUMsSUFBSSxDQUFDO1FBQ25ELE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxDQUFDLGNBQWMsQ0FBQztRQUMzQyxNQUFNLFFBQVEsR0FBYSxpQkFBaUI7WUFDMUMsQ0FBQyxDQUFDLGNBQWM7WUFDaEIsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQ2xDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFNUMsS0FBSyxNQUFNLFNBQVMsSUFBSSxhQUFhLEVBQUU7WUFDckMsTUFBTSxJQUFJLENBQUMsd0JBQXdCLENBQUMsUUFBUSxFQUFFO2dCQUM1QyxTQUFTO2dCQUNULGlCQUFpQjthQUNsQixDQUFDLENBQUM7U0FDSjtRQUVELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0NBQ0Y7QUExSUQsc0NBMElDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2RlbHNVbml2ZXJzZX0gZnJvbSAnLi9tb2RlbHMtdW5pdmVyc2UnO1xuaW1wb3J0IHtPYnNlcnZhdG9yeX0gZnJvbSAnLi9vYnNlcnZhdG9yeSc7XG5cbmltcG9ydCB7RVJST1JTfSBmcm9tICcuLi91dGlsL2Vycm9ycyc7XG5cbmltcG9ydCB7U1RSSU5HU30gZnJvbSAnLi4vY29uZmlnJztcblxuaW1wb3J0IHtDaGlsZEluZm9ybWF0aW9ufSBmcm9tICcuLi90eXBlcy9zdXBlcmNvbXB1dGVyJztcbmltcG9ydCB7Q2hpbGRyZW4sIENvbmZpZywgSW1wbCwgTW9kZWxQYXJhbXN9IGZyb20gJy4uL3R5cGVzL2ltcGwnO1xuXG5jb25zdCB7SW1wbFZhbGlkYXRpb25FcnJvcn0gPSBFUlJPUlM7XG5cbmNvbnN0IHtTVFJVQ1RVUkVfTUFMRk9STUVEfSA9IFNUUklOR1M7XG5cbi8qKlxuICogQ29tcHV0ZXIgZm9yIGBpbXBsYCBkb2N1bWVudHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBTdXBlcmNvbXB1dGVyIHtcbiAgcHJpdmF0ZSBvbGRlckNoaWxkOiBDaGlsZEluZm9ybWF0aW9uID0ge25hbWU6ICcnLCBpbmZvOiB7fX07XG4gIHByaXZhdGUgaW1wbDogSW1wbDtcbiAgcHJpdmF0ZSBtb2RlbHNIYW5kYm9vazogTW9kZWxzVW5pdmVyc2U7XG5cbiAgY29uc3RydWN0b3IoaW1wbDogSW1wbCwgbW9kZWxzSGFuZGJvb2s6IE1vZGVsc1VuaXZlcnNlKSB7XG4gICAgdGhpcy5pbXBsID0gaW1wbDtcbiAgICB0aGlzLm1vZGVsc0hhbmRib29rID0gbW9kZWxzSGFuZGJvb2s7XG4gIH1cblxuICAvKipcbiAgICogRmxhdHRlbnMgY29uZmlnIGVudHJpZXMuXG4gICAqL1xuICBwcml2YXRlIGZsYXR0ZW5Db25maWdWYWx1ZXMoY29uZmlnOiBDb25maWcpIHtcbiAgICBpZiAoIWNvbmZpZykge1xuICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIGNvbnN0IGNvbmZpZ01vZGVsTmFtZXMgPSBPYmplY3Qua2V5cyhjb25maWcpO1xuICAgIGNvbnN0IHZhbHVlcyA9IGNvbmZpZ01vZGVsTmFtZXMucmVkdWNlKChhY2M6IGFueSwgbmFtZTogc3RyaW5nKSA9PiB7XG4gICAgICBhY2MgPSB7XG4gICAgICAgIC4uLmFjYyxcbiAgICAgICAgLi4uY29uZmlnW25hbWVdLFxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG5cbiAgICByZXR1cm4gdmFsdWVzO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgY29uZmlnIGVudHJpZXMgdG8gZWFjaCBvYnNlcmNhdGlvbiBvYmplY3QgcGFzc2VkLlxuICAgKi9cbiAgcHJpdmF0ZSBlbnJpY2hJbnB1dHMoXG4gICAgaW5wdXRzOiBNb2RlbFBhcmFtc1tdLFxuICAgIGNvbmZpZzogQ29uZmlnLFxuICAgIG5lc3RlZENvbmZpZzogQ29uZmlnXG4gICkge1xuICAgIGNvbnN0IGNvbmZpZ1ZhbHVlcyA9IHRoaXMuZmxhdHRlbkNvbmZpZ1ZhbHVlcyhjb25maWcpO1xuICAgIGNvbnN0IG5lc3RlZENvbmZpZ1ZhbHVlcyA9IHRoaXMuZmxhdHRlbkNvbmZpZ1ZhbHVlcyhuZXN0ZWRDb25maWcpO1xuXG4gICAgcmV0dXJuIGlucHV0cy5tYXAoKGlucHV0OiBhbnkpID0+ICh7XG4gICAgICAuLi5pbnB1dCxcbiAgICAgIC4uLmNvbmZpZ1ZhbHVlcyxcbiAgICAgIC4uLm5lc3RlZENvbmZpZ1ZhbHVlcyxcbiAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogSWYgY2hpbGQgaXMgdG9wIGxldmVsLCB0aGVuIGluaXRpYWxpemVzIGB0aGlzLm9sZGVyQ2hpbGRgLlxuICAgKiBJZiBgY2hpbGRyZW5gIG9iamVjdCBjb250YWlucyBgY2hpbGRyZW5gIHByb3BlcnR5LCBpdCBtZWFucyBpbnB1dHMgYXJlIG5lc3RlZCAoY2FsbHMgY29tcHV0ZSBhZ2FpbikuXG4gICAqIE90aGVyd2lzZSBlbnJpY2hlcyBpbnB1dHMsIHBhc3NlcyB0aGVtIHRvIE9ic2VydmF0b3J5LlxuICAgKiBGb3IgZWFjaCBtb2RlbCBmcm9tIHBpcGVsaW5lIE9ic2VydmF0b3J5IGdhdGhlcnMgaW5wdXRzLiBUaGVuIHJlc3VsdHMgYXJlIHN0b3JlZC5cbiAgICovXG4gIHByaXZhdGUgYXN5bmMgY2FsY3VsYXRlT3V0cHV0c0ZvckNoaWxkKFxuICAgIGNoaWxkcmVuT2JqZWN0OiBDaGlsZHJlbixcbiAgICBwYXJhbXM6IGFueVxuICApIHtcbiAgICBjb25zdCB7Y2hpbGROYW1lLCBhcmVDaGlsZHJlbk5lc3RlZH0gPSBwYXJhbXM7XG5cbiAgICBpZiAoIWFyZUNoaWxkcmVuTmVzdGVkKSB7XG4gICAgICB0aGlzLm9sZGVyQ2hpbGQgPSB7XG4gICAgICAgIG5hbWU6IGNoaWxkTmFtZSxcbiAgICAgICAgaW5mbzogdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW2NoaWxkTmFtZV0sXG4gICAgICB9O1xuICAgIH1cblxuICAgIGNvbnN0IHtwaXBlbGluZSwgaW5wdXRzLCBjb25maWd9ID0gdGhpcy5vbGRlckNoaWxkLmluZm87XG5cbiAgICBpZiAoJ2NoaWxkcmVuJyBpbiBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdKSB7XG4gICAgICByZXR1cm4gdGhpcy5jb21wdXRlKGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0uY2hpbGRyZW4pO1xuICAgIH1cblxuICAgIGlmICghKCdpbnB1dHMnIGluIGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0pKSB7XG4gICAgICB0aHJvdyBuZXcgSW1wbFZhbGlkYXRpb25FcnJvcihTVFJVQ1RVUkVfTUFMRk9STUVEKGNoaWxkTmFtZSkpO1xuICAgIH1cblxuICAgIGNvbnN0IHNwZWNpZmljSW5wdXRzID0gYXJlQ2hpbGRyZW5OZXN0ZWRcbiAgICAgID8gY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXS5pbnB1dHNcbiAgICAgIDogaW5wdXRzO1xuXG4gICAgY29uc3QgY2hpbGRyZW5Db25maWcgPSBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdLmNvbmZpZyB8fCB7fTtcblxuICAgIGNvbnN0IGVucmljaGVkSW5wdXRzID0gdGhpcy5lbnJpY2hJbnB1dHMoXG4gICAgICBzcGVjaWZpY0lucHV0cyxcbiAgICAgIGNvbmZpZyxcbiAgICAgIGNoaWxkcmVuQ29uZmlnXG4gICAgKTtcblxuICAgIGNvbnN0IG9ic2VydmF0b3J5ID0gbmV3IE9ic2VydmF0b3J5KGVucmljaGVkSW5wdXRzKTtcblxuICAgIGZvciAoY29uc3QgbW9kZWxOYW1lIG9mIHBpcGVsaW5lKSB7XG4gICAgICBjb25zdCBwYXJhbXMgPSBjb25maWcgJiYgY29uZmlnW21vZGVsTmFtZV07XG4gICAgICBjb25zdCBtb2RlbEluc3RhbmNlID0gYXdhaXQgdGhpcy5tb2RlbHNIYW5kYm9vay5nZXRJbml0aWFsaXplZE1vZGVsKFxuICAgICAgICBtb2RlbE5hbWUsXG4gICAgICAgIHBhcmFtc1xuICAgICAgKTtcblxuICAgICAgYXdhaXQgb2JzZXJ2YXRvcnkuZG9JbnZlc3RpZ2F0aW9uc1dpdGgobW9kZWxJbnN0YW5jZSk7XG4gICAgfVxuXG4gICAgY29uc3Qgb3V0cHV0cyA9IG9ic2VydmF0b3J5LmdldE91dHB1dHMoKTtcblxuICAgIGlmIChhcmVDaGlsZHJlbk5lc3RlZCkge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW3RoaXMub2xkZXJDaGlsZC5uYW1lXS5jaGlsZHJlbltcbiAgICAgICAgY2hpbGROYW1lXG4gICAgICBdLm91dHB1dHMgPSBvYnNlcnZhdG9yeS5nZXRPdXRwdXRzKCk7XG5cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdLm91dHB1dHMgPSBvdXRwdXRzO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgb2JqZWN0IGlzIHRvcCBsZXZlbCBjaGlsZHJlbiBvciBuZXN0ZWQsIHRoZW4gcnVucyB0aHJvdWdoIGFsbCBjaGlsZHJlbiBhbmQgY2FsY3VsYXRlcyBvdXRwdXRzLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGNvbXB1dGUoY2hpbGRyZW5PYmplY3Q/OiBhbnkpIHtcbiAgICBjb25zdCBpbXBsT3JDaGlsZHJlbiA9IGNoaWxkcmVuT2JqZWN0IHx8IHRoaXMuaW1wbDtcbiAgICBjb25zdCBhcmVDaGlsZHJlbk5lc3RlZCA9ICEhY2hpbGRyZW5PYmplY3Q7XG4gICAgY29uc3QgY2hpbGRyZW46IENoaWxkcmVuID0gYXJlQ2hpbGRyZW5OZXN0ZWRcbiAgICAgID8gaW1wbE9yQ2hpbGRyZW5cbiAgICAgIDogaW1wbE9yQ2hpbGRyZW4uZ3JhcGguY2hpbGRyZW47XG4gICAgY29uc3QgY2hpbGRyZW5OYW1lcyA9IE9iamVjdC5rZXlzKGNoaWxkcmVuKTtcblxuICAgIGZvciAoY29uc3QgY2hpbGROYW1lIG9mIGNoaWxkcmVuTmFtZXMpIHtcbiAgICAgIGF3YWl0IHRoaXMuY2FsY3VsYXRlT3V0cHV0c0ZvckNoaWxkKGNoaWxkcmVuLCB7XG4gICAgICAgIGNoaWxkTmFtZSxcbiAgICAgICAgYXJlQ2hpbGRyZW5OZXN0ZWQsXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5pbXBsO1xuICB9XG59XG4iXX0=
148
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwZXJjb21wdXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvc3VwZXJjb21wdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrQ0FBMEM7QUFDMUMsMkRBQXFEO0FBRXJELDJDQUFzQztBQUV0QyxzQ0FBa0M7QUFPbEMsTUFBTSxFQUFDLG1CQUFtQixFQUFDLEdBQUcsZUFBTSxDQUFDO0FBRXJDLE1BQU0sRUFBQyxtQkFBbUIsRUFBQyxHQUFHLGdCQUFPLENBQUM7QUFFdEM7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFPeEIsWUFBWSxJQUFVLEVBQUUsY0FBOEI7UUFOOUMsZUFBVSxHQUFxQixFQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBQyxDQUFDO1FBR3BELHNCQUFpQixHQUF3QixFQUFFLENBQUM7UUFDNUMsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFHdEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDdkMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksb0JBQW9CO1FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzNCLE1BQU0sSUFBSSxtQkFBbUIsQ0FBQyxzQ0FBc0MsQ0FBQyxDQUFDO1FBQ3hFLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRTNELE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDMUQsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUVqQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFF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c0NBNExDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2RlbHNVbml2ZXJzZX0gZnJvbSAnLi9tb2RlbHMtdW5pdmVyc2UnO1xuaW1wb3J0IHtPYnNlcnZhdG9yeX0gZnJvbSAnLi9vYnNlcnZhdG9yeSc7XG5pbXBvcnQge3BsYW5ldEFnZ3JlZ2F0b3J9IGZyb20gJy4vcGxhbmV0LWFnZ3JlZ2F0b3InO1xuXG5pbXBvcnQge0VSUk9SU30gZnJvbSAnLi4vdXRpbC9lcnJvcnMnO1xuXG5pbXBvcnQge1NUUklOR1N9IGZyb20gJy4uL2NvbmZpZyc7XG5cbmltcG9ydCB7Q2hpbGRyZW4sIENvbmZpZywgSW1wbH0gZnJvbSAnLi4vdHlwZXMvaW1wbCc7XG5pbXBvcnQge01vZGVsUGFyYW1zfSBmcm9tICcuLi90eXBlcy9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtBZ2dyZWdhdGlvblJlc3VsdH0gZnJvbSAnLi4vdHlwZXMvcGxhbmV0LWFnZ3JlZ2F0b3InO1xuaW1wb3J0IHtDaGlsZEluZm9ybWF0aW9ufSBmcm9tICcuLi90eXBlcy9zdXBlcmNvbXB1dGVyJztcblxuY29uc3Qge0ltcGxWYWxpZGF0aW9uRXJyb3J9ID0gRVJST1JTO1xuXG5jb25zdCB7U1RSVUNUVVJFX01BTEZPUk1FRH0gPSBTVFJJTkdTO1xuXG4vKipcbiAqIENvbXB1dGVyIGZvciBgaW1wbGAgZG9jdW1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgU3VwZXJjb21wdXRlciB7XG4gIHByaXZhdGUgb2xkZXJDaGlsZDogQ2hpbGRJbmZvcm1hdGlvbiA9IHtuYW1lOiAnJywgaW5mbzoge319O1xuICBwcml2YXRlIGltcGw6IEltcGw7XG4gIHByaXZhdGUgbW9kZWxzSGFuZGJvb2s6IE1vZGVsc1VuaXZlcnNlO1xuICBwcml2YXRlIGFnZ3JlZ2F0ZWRJbXBhY3RzOiBBZ2dyZWdhdGlvblJlc3VsdFtdID0gW107XG4gIHByaXZhdGUgY2hpbGRBbW91bnQgPSAwO1xuXG4gIGNvbnN0cnVjdG9yKGltcGw6IEltcGwsIG1vZGVsc0hhbmRib29rOiBNb2RlbHNVbml2ZXJzZSkge1xuICAgIHRoaXMuaW1wbCA9IGltcGw7XG4gICAgdGhpcy5tb2RlbHNIYW5kYm9vayA9IG1vZGVsc0hhbmRib29rO1xuICB9XG5cbiAgLyoqXG4gICAqIEdvZXMgdGhyb3VnaCBhbGwgYWdncmVnYXRpb25zIGNvbGxlY3RlZCBmcm9tIGNoaWxkIGNvbXBvbmVudHMsIHRoZW4gY2FsY3VsYXRlcyB0aGUgYXZlcmFnZS5cbiAgICovXG4gIHB1YmxpYyBjYWxjdWxhdGVBZ2dyZWdhdGlvbigpIHtcbiAgICBpZiAoIXRoaXMuaW1wbC5hZ2dyZWdhdGlvbikge1xuICAgICAgdGhyb3cgbmV3IEltcGxWYWxpZGF0aW9uRXJyb3IoJ0FnZ3JlZ2F0aW9uIHBhcmFtcyBhcmUgbm90IHByb3ZpZGVkLicpO1xuICAgIH1cblxuICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuaW1wbC5hZ2dyZWdhdGlvblsnYWdncmVnYXRpb24tbWV0aG9kJ107XG5cbiAgICByZXR1cm4gdGhpcy5hZ2dyZWdhdGVkSW1wYWN0cy5yZWR1Y2UoKGFjYywgaW1wYWN0LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKGltcGFjdCk7XG5cbiAgICAgIGtleXMuZm9yRWFjaChrZXkgPT4ge1xuICAgICAgICBhY2Nba2V5XSA9IGFjY1trZXldID8/IDA7XG4gICAgICAgIGFjY1trZXldICs9IGltcGFjdFtrZXldO1xuXG4gICAgICAgIGlmIChpbmRleCA9PT0gdGhpcy5jaGlsZEFtb3VudCAtIDEpIHtcbiAgICAgICAgICBpZiAobWV0aG9kID09PSAnYXZnJykge1xuICAgICAgICAgICAgYWNjW2tleV0gLz0gdGhpcy5jaGlsZEFtb3VudDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGbGF0dGVucyBjb25maWcgZW50cmllcy5cbiAgICovXG4gIHByaXZhdGUgZmxhdHRlbkNvbmZpZ1ZhbHVlcyhjb25maWc6IENvbmZpZykge1xuICAgIGlmICghY29uZmlnKSB7XG4gICAgICByZXR1cm4ge307XG4gICAgfVxuXG4gICAgY29uc3QgY29uZmlnTW9kZWxOYW1lcyA9IE9iamVjdC5rZXlzKGNvbmZpZyk7XG4gICAgY29uc3QgdmFsdWVzID0gY29uZmlnTW9kZWxOYW1lcy5yZWR1Y2UoKGFjYzogYW55LCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICAgIGFjYyA9IHtcbiAgICAgICAgLi4uYWNjLFxuICAgICAgICAuLi5jb25maWdbbmFtZV0sXG4gICAgICB9O1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcblxuICAgIHJldHVybiB2YWx1ZXM7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBjb25maWcgZW50cmllcyB0byBlYWNoIG9ic2VyY2F0aW9uIG9iamVjdCBwYXNzZWQuXG4gICAqL1xuICBwcml2YXRlIGVucmljaElucHV0cyhcbiAgICBpbnB1dHM6IE1vZGVsUGFyYW1zW10sXG4gICAgY29uZmlnOiBDb25maWcsXG4gICAgbmVzdGVkQ29uZmlnOiBDb25maWdcbiAgKSB7XG4gICAgY29uc3QgY29uZmlnVmFsdWVzID0gdGhpcy5mbGF0dGVuQ29uZmlnVmFsdWVzKGNvbmZpZyk7XG4gICAgY29uc3QgbmVzdGVkQ29uZmlnVmFsdWVzID0gdGhpcy5mbGF0dGVuQ29uZmlnVmFsdWVzKG5lc3RlZENvbmZpZyk7XG5cbiAgICByZXR1cm4gaW5wdXRzLm1hcCgoaW5wdXQ6IGFueSkgPT4gKHtcbiAgICAgIC4uLmlucHV0LFxuICAgICAgLi4uY29uZmlnVmFsdWVzLFxuICAgICAgLi4ubmVzdGVkQ29uZmlnVmFsdWVzLFxuICAgIH0pKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJZiBjaGlsZCBpcyB0b3AgbGV2ZWwsIHRoZW4gaW5pdGlhbGl6ZXMgYHRoaXMub2xkZXJDaGlsZGAuXG4gICAqIElmIGBjaGlsZHJlbmAgb2JqZWN0IGNvbnRhaW5zIGBjaGlsZHJlbmAgcHJvcGVydHksIGl0IG1lYW5zIGlucHV0cyBhcmUgbmVzdGVkIChjYWxscyBjb21wdXRlIGFnYWluKS5cbiAgICogT3RoZXJ3aXNlIGVucmljaGVzIGlucHV0cywgcGFzc2VzIHRoZW0gdG8gT2JzZXJ2YXRvcnkuXG4gICAqIEZvciBlYWNoIG1vZGVsIGZyb20gcGlwZWxpbmUgT2JzZXJ2YXRvcnkgZ2F0aGVycyBpbnB1dHMuIFRoZW4gcmVzdWx0cyBhcmUgc3RvcmVkLlxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBjYWxjdWxhdGVPdXRwdXRzRm9yQ2hpbGQoXG4gICAgY2hpbGRyZW5PYmplY3Q6IENoaWxkcmVuLFxuICAgIHBhcmFtczogYW55XG4gICkge1xuICAgIGNvbnN0IHtjaGlsZE5hbWUsIGFyZUNoaWxkcmVuTmVzdGVkfSA9IHBhcmFtcztcblxuICAgIGlmICghYXJlQ2hpbGRyZW5OZXN0ZWQpIHtcbiAgICAgIHRoaXMub2xkZXJDaGlsZCA9IHtcbiAgICAgICAgbmFtZTogY2hpbGROYW1lLFxuICAgICAgICBpbmZvOiB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bY2hpbGROYW1lXSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgY29uc3Qge3BpcGVsaW5lLCBpbnB1dHMsIGNvbmZpZ30gPSB0aGlzLm9sZGVyQ2hpbGQuaW5mbztcblxuICAgIGlmICgnY2hpbGRyZW4nIGluIGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0pIHtcbiAgICAgIHJldHVybiB0aGlzLmNvbXB1dGUoY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXS5jaGlsZHJlbik7XG4gICAgfVxuXG4gICAgaWYgKCEoJ2lucHV0cycgaW4gY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXSkpIHtcbiAgICAgIHRocm93IG5ldyBJbXBsVmFsaWRhdGlvbkVycm9yKFNUUlVDVFVSRV9NQUxGT1JNRUQoY2hpbGROYW1lKSk7XG4gICAgfVxuXG4gICAgdGhpcy5jaGlsZEFtb3VudCsrO1xuXG4gICAgY29uc3Qgc3BlY2lmaWNJbnB1dHMgPSBhcmVDaGlsZHJlbk5lc3RlZFxuICAgICAgPyBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdLmlucHV0c1xuICAgICAgOiBpbnB1dHM7XG5cbiAgICBjb25zdCBjaGlsZHJlbkNvbmZpZyA9IGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0uY29uZmlnIHx8IHt9O1xuXG4gICAgY29uc3QgZW5yaWNoZWRJbnB1dHMgPSB0aGlzLmVucmljaElucHV0cyhcbiAgICAgIHNwZWNpZmljSW5wdXRzLFxuICAgICAgY29uZmlnLFxuICAgICAgY2hpbGRyZW5Db25maWdcbiAgICApO1xuXG4gICAgY29uc3Qgb2JzZXJ2YXRvcnkgPSBuZXcgT2JzZXJ2YXRvcnkoZW5yaWNoZWRJbnB1dHMpO1xuXG4gICAgZm9yIChjb25zdCBtb2RlbE5hbWUgb2YgcGlwZWxpbmUpIHtcbiAgICAgIGNvbnN0IHBhcmFtcyA9IGNvbmZpZyAmJiBjb25maWdbbW9kZWxOYW1lXTtcbiAgICAgIGNvbnN0IG1vZGVsSW5zdGFuY2UgPSBhd2FpdCB0aGlzLm1vZGVsc0hhbmRib29rLmdldEluaXRpYWxpemVkTW9kZWwoXG4gICAgICAgIG1vZGVsTmFtZSxcbiAgICAgICAgcGFyYW1zXG4gICAgICApO1xuXG4gICAgICBhd2FpdCBvYnNlcnZhdG9yeS5kb0ludmVzdGlnYXRpb25zV2l0aChtb2RlbEluc3RhbmNlKTtcbiAgICB9XG5cbiAgICBjb25zdCBvdXRwdXRzID0gb2JzZXJ2YXRvcnkuZ2V0T3V0cHV0cygpO1xuXG4gICAgLyoqXG4gICAgICogSWYgYWdncmVnYXRpb24gaXMgcmVxdWlyZWQsIHRoZW4gaW5pdCBgYWdncmVnYXRlZC1vdXRwdXRzYC5cbiAgICAgKi9cbiAgICBpZiAodGhpcy5pbXBsLmFnZ3JlZ2F0aW9uKSB7XG4gICAgICBjb25zdCBhZ2dyZWdhdGVkSW1wYWN0c1BlckNoaWxkID0gcGxhbmV0QWdncmVnYXRvcihcbiAgICAgICAgb3V0cHV0cyxcbiAgICAgICAgdGhpcy5pbXBsLmFnZ3JlZ2F0aW9uXG4gICAgICApO1xuXG4gICAgICB0aGlzLmFnZ3JlZ2F0ZWRJbXBhY3RzLnB1c2goYWdncmVnYXRlZEltcGFjdHNQZXJDaGlsZCk7XG5cbiAgICAgIGlmIChhcmVDaGlsZHJlbk5lc3RlZCkge1xuICAgICAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdLmNoaWxkcmVuW2NoaWxkTmFtZV1bXG4gICAgICAgICAgJ2FnZ3JlZ2F0ZWQtb3V0cHV0cydcbiAgICAgICAgXSA9IGFnZ3JlZ2F0ZWRJbXBhY3RzUGVyQ2hpbGQ7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdWydhZ2dyZWdhdGVkLW91dHB1dHMnXSA9XG4gICAgICAgICAgYWdncmVnYXRlZEltcGFjdHNQZXJDaGlsZDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoYXJlQ2hpbGRyZW5OZXN0ZWQpIHtcbiAgICAgIHRoaXMuaW1wbC5ncmFwaC5jaGlsZHJlblt0aGlzLm9sZGVyQ2hpbGQubmFtZV0uY2hpbGRyZW5bXG4gICAgICAgIGNoaWxkTmFtZVxuICAgICAgXS5vdXRwdXRzID0gb3V0cHV0cztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW3RoaXMub2xkZXJDaGlsZC5uYW1lXS5vdXRwdXRzID0gb3V0cHV0cztcbiAgICB9XG5cbiAgICByZXR1cm47XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIG9iamVjdCBpcyB0b3AgbGV2ZWwgY2hpbGRyZW4gb3IgbmVzdGVkLCB0aGVuIHJ1bnMgdGhyb3VnaCBhbGwgY2hpbGRyZW4gYW5kIGNhbGN1bGF0ZXMgb3V0cHV0cy5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBjb21wdXRlKGNoaWxkcmVuT2JqZWN0PzogYW55KSB7XG4gICAgY29uc3QgaW1wbE9yQ2hpbGRyZW4gPSBjaGlsZHJlbk9iamVjdCB8fCB0aGlzLmltcGw7XG4gICAgY29uc3QgYXJlQ2hpbGRyZW5OZXN0ZWQgPSAhIWNoaWxkcmVuT2JqZWN0O1xuICAgIGNvbnN0IGNoaWxkcmVuOiBDaGlsZHJlbiA9IGFyZUNoaWxkcmVuTmVzdGVkXG4gICAgICA/IGltcGxPckNoaWxkcmVuXG4gICAgICA6IGltcGxPckNoaWxkcmVuLmdyYXBoLmNoaWxkcmVuO1xuICAgIGNvbnN0IGNoaWxkcmVuTmFtZXMgPSBPYmplY3Qua2V5cyhjaGlsZHJlbik7XG5cbiAgICBmb3IgKGNvbnN0IGNoaWxkTmFtZSBvZiBjaGlsZHJlbk5hbWVzKSB7XG4gICAgICBhd2FpdCB0aGlzLmNhbGN1bGF0ZU91dHB1dHNGb3JDaGlsZChjaGlsZHJlbiwge1xuICAgICAgICBjaGlsZE5hbWUsXG4gICAgICAgIGFyZUNoaWxkcmVuTmVzdGVkLFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuaW1wbDtcbiAgfVxufVxuIl19
@@ -0,0 +1 @@
1
+ export { TimeSyncModel } from './time-sync';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TimeSyncModel = void 0;
4
+ var time_sync_1 = require("./time-sync");
5
+ Object.defineProperty(exports, "TimeSyncModel", { enumerable: true, get: function () { return time_sync_1.TimeSyncModel; } });
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUEwQztBQUFsQywwR0FBQSxhQUFhLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge1RpbWVTeW5jTW9kZWx9IGZyb20gJy4vdGltZS1zeW5jJztcbiJdfQ==
@@ -0,0 +1,55 @@
1
+ import { ModelParams, ModelPluginInterface } from '../types/model-interface';
2
+ import { TimeNormalizerConfig } from '../types/time-sync';
3
+ import { UnitsDealerUsage } from '../types/units-dealer';
4
+ export declare class TimeSyncModel implements ModelPluginInterface {
5
+ startTime: string | undefined;
6
+ endTime: string | undefined;
7
+ dealer: UnitsDealerUsage;
8
+ interval: number;
9
+ /**
10
+ * Setups basic configuration.
11
+ */
12
+ configure(params: TimeNormalizerConfig): Promise<ModelPluginInterface>;
13
+ /**
14
+ * Validates `startTime`, `endTime` and `interval` params.
15
+ */
16
+ private validateParams;
17
+ /**
18
+ * Calculates minimal factor.
19
+ */
20
+ private convertPerInterval;
21
+ /**
22
+ * Normalize time per given second.
23
+ */
24
+ private normalizeTimePerSecond;
25
+ /**
26
+ * Barkes down input per minimal time unit.
27
+ */
28
+ private breakDownInput;
29
+ /**
30
+ * Populates object to fill the gaps in observational timeline using zeroish values.
31
+ */
32
+ private fillWithZeroishInput;
33
+ /**
34
+ * Checks if padding is needed either at start of the timeline or the end and returns status.
35
+ */
36
+ private checkForPadding;
37
+ /**
38
+ * Iterates over given inputs frame, meanwhile checking if aggregation method is `sum`, then calculates it.
39
+ * For methods is `avg` and `none` calculating average of the frame.
40
+ */
41
+ private resampleInputFrame;
42
+ /**
43
+ * Takes each array frame with interval length, then aggregating them together as from units.yaml file.
44
+ */
45
+ private resampleInputs;
46
+ /**
47
+ * Pads zeroish inputs from the beginning or at the end of the inputs if needed.
48
+ */
49
+ private padInputs;
50
+ private trimInputsByGlobalTimeline;
51
+ /**
52
+ * Normalizes provided time window according to time configuration.
53
+ */
54
+ execute(inputs: ModelParams[]): Promise<ModelParams[]>;
55
+ }
@@ -0,0 +1,235 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TimeSyncModel = void 0;
4
+ const moment = require("moment");
5
+ const moment_range_1 = require("moment-range");
6
+ const config_1 = require("../config");
7
+ const errors_1 = require("../util/errors");
8
+ const units_dealer_1 = require("../util/units-dealer");
9
+ const momentRange = (0, moment_range_1.extendMoment)(moment);
10
+ const { InputValidationError } = errors_1.ERRORS;
11
+ const { INVALID_TIME_NORMALIZATION, INVALID_TIME_INTERVAL, INVALID_OBSERVATION_OVERLAP, } = config_1.STRINGS;
12
+ class TimeSyncModel {
13
+ constructor() {
14
+ this.interval = 1;
15
+ /**
16
+ * Calculates minimal factor.
17
+ */
18
+ this.convertPerInterval = (value, duration) => value / duration;
19
+ /**
20
+ * Normalize time per given second.
21
+ */
22
+ this.normalizeTimePerSecond = (currentRoundMoment, i) => {
23
+ const thisMoment = moment(currentRoundMoment).milliseconds(0);
24
+ return thisMoment.add(i, 'second');
25
+ };
26
+ /**
27
+ * Iterates over given inputs frame, meanwhile checking if aggregation method is `sum`, then calculates it.
28
+ * For methods is `avg` and `none` calculating average of the frame.
29
+ */
30
+ this.resampleInputFrame = (inputsInTimeslot) => {
31
+ return inputsInTimeslot.reduce((acc, input, index, inputs) => {
32
+ const metrics = Object.keys(input);
33
+ metrics.forEach(metric => {
34
+ const method = this.dealer.askToGiveMethodFor(metric);
35
+ acc[metric] = acc[metric] ?? 0;
36
+ if (metric === 'timestamp') {
37
+ acc[metric] = inputs[0][metric];
38
+ return;
39
+ }
40
+ if (method === 'sum') {
41
+ acc[metric] += input[metric];
42
+ return;
43
+ }
44
+ /** divide each metric by the timeslot length, so that their sum yields the timeslot average.*/
45
+ if (index === inputsInTimeslot.length - 1) {
46
+ acc[metric] /= inputsInTimeslot.length;
47
+ return;
48
+ }
49
+ acc[metric] += input[metric];
50
+ });
51
+ return acc;
52
+ }, {});
53
+ };
54
+ }
55
+ /**
56
+ * Setups basic configuration.
57
+ */
58
+ async configure(params) {
59
+ this.startTime = params['start-time'];
60
+ this.endTime = params['end-time'];
61
+ this.interval = params.interval;
62
+ this.dealer = await (0, units_dealer_1.UnitsDealer)();
63
+ return this;
64
+ }
65
+ /**
66
+ * Validates `startTime`, `endTime` and `interval` params.
67
+ */
68
+ validateParams() {
69
+ if (!this.startTime || !this.endTime) {
70
+ throw new InputValidationError(INVALID_TIME_NORMALIZATION);
71
+ }
72
+ if (this.startTime > this.endTime) {
73
+ throw new InputValidationError(INVALID_TIME_NORMALIZATION);
74
+ }
75
+ if (!this.interval) {
76
+ throw new InputValidationError(INVALID_TIME_INTERVAL);
77
+ }
78
+ }
79
+ /**
80
+ * Barkes down input per minimal time unit.
81
+ */
82
+ breakDownInput(input, i) {
83
+ const inputKeys = Object.keys(input);
84
+ return inputKeys.reduce((acc, key) => {
85
+ const method = this.dealer.askToGiveMethodFor(key);
86
+ if (key === 'timestamp') {
87
+ const perSecond = this.normalizeTimePerSecond(input.timestamp, i);
88
+ acc[key] = moment(perSecond).milliseconds(0).toISOString();
89
+ return acc;
90
+ }
91
+ /** @todo use user defined resolution later */
92
+ if (key === 'duration') {
93
+ acc[key] = 1;
94
+ return acc;
95
+ }
96
+ acc[key] =
97
+ method === 'sum'
98
+ ? this.convertPerInterval(input[key], input['duration'])
99
+ : input[key];
100
+ return acc;
101
+ }, {});
102
+ }
103
+ /**
104
+ * Populates object to fill the gaps in observational timeline using zeroish values.
105
+ */
106
+ fillWithZeroishInput(input, missingTimestamp) {
107
+ const metrics = Object.keys(input);
108
+ return metrics.reduce((acc, metric) => {
109
+ if (metric === 'timestamp') {
110
+ acc[metric] = moment(missingTimestamp).milliseconds(0).toISOString();
111
+ return acc;
112
+ }
113
+ /** @todo later will be changed to user defined interval */
114
+ if (metric === 'duration') {
115
+ acc[metric] = 1;
116
+ return acc;
117
+ }
118
+ if (metric === 'time-reserved') {
119
+ acc[metric] = acc['duration'];
120
+ return acc;
121
+ }
122
+ const method = this.dealer.askToGiveMethodFor(metric);
123
+ acc[metric] = method === 'avg' || method === 'sum' ? 0 : input[metric];
124
+ return acc;
125
+ }, {});
126
+ }
127
+ /**
128
+ * Checks if padding is needed either at start of the timeline or the end and returns status.
129
+ */
130
+ checkForPadding(inputs) {
131
+ const startDiffInSeconds = moment(inputs[0].timestamp).diff(moment(this.startTime)) / 1000;
132
+ const lastInput = inputs[inputs.length - 1];
133
+ const endDiffInSeconds = moment(lastInput.timestamp)
134
+ .add(lastInput.duration, 'seconds')
135
+ .diff(moment(this.endTime)) / 1000;
136
+ return {
137
+ start: startDiffInSeconds > 0,
138
+ end: endDiffInSeconds < 0,
139
+ };
140
+ }
141
+ /**
142
+ * Takes each array frame with interval length, then aggregating them together as from units.yaml file.
143
+ */
144
+ resampleInputs(inputs) {
145
+ return inputs.reduce((acc, _input, index, inputs) => {
146
+ const frameStart = index * this.interval;
147
+ const frameEnd = (index + 1) * this.interval;
148
+ const inputsFrame = inputs.slice(frameStart, frameEnd);
149
+ const resampledInput = this.resampleInputFrame(inputsFrame);
150
+ /** Checks if resampled input is not empty, then includes in result. */
151
+ if (Object.keys(resampledInput).length > 0) {
152
+ acc.push(resampledInput);
153
+ }
154
+ return acc;
155
+ }, []);
156
+ }
157
+ /**
158
+ * Pads zeroish inputs from the beginning or at the end of the inputs if needed.
159
+ */
160
+ padInputs(inputs, pad) {
161
+ const { start, end } = pad;
162
+ const paddedFromBeginning = [];
163
+ if (start) {
164
+ const dateRange = momentRange.range(moment(this.startTime), moment(inputs[0].timestamp).subtract(1, 'second'));
165
+ /** Checks if converting to value of is needed. */
166
+ for (const second of dateRange.by('second')) {
167
+ paddedFromBeginning.push(this.fillWithZeroishInput(inputs[0], second.valueOf()));
168
+ }
169
+ }
170
+ const paddedArray = paddedFromBeginning.concat(inputs);
171
+ if (end) {
172
+ const lastInput = inputs[inputs.length - 1];
173
+ const dateRange = momentRange.range(moment(lastInput.timestamp).add(lastInput.duration, 'seconds'), moment(this.endTime));
174
+ for (const second of dateRange.by('second')) {
175
+ paddedArray.push(this.fillWithZeroishInput(lastInput, second.valueOf()));
176
+ }
177
+ }
178
+ return paddedArray;
179
+ }
180
+ /*
181
+ * Checks if input's timestamp is included in global specified period then leaves it, otherwise.
182
+ */
183
+ trimInputsByGlobalTimeline(inputs) {
184
+ return inputs.reduce((acc, item) => {
185
+ const { timestamp } = item;
186
+ if (moment(timestamp).isSameOrAfter(moment(this.startTime)) &&
187
+ moment(timestamp).isSameOrBefore(moment(this.endTime))) {
188
+ acc.push(item);
189
+ }
190
+ return acc;
191
+ }, []);
192
+ }
193
+ /**
194
+ * Normalizes provided time window according to time configuration.
195
+ */
196
+ async execute(inputs) {
197
+ this.validateParams();
198
+ const pad = this.checkForPadding(inputs);
199
+ const paddedInputs = this.padInputs(inputs, pad);
200
+ const flattenInputs = paddedInputs.reduce((acc, input, index) => {
201
+ const currentMoment = moment(input.timestamp);
202
+ /** Checks if not the first input, then check consistency with previous ones. */
203
+ if (index > 0) {
204
+ const previousInput = paddedInputs[index - 1];
205
+ const previousInputTimestamp = moment(previousInput.timestamp);
206
+ /** Checks for timestamps overlap. */
207
+ if (moment(previousInput.timestamp)
208
+ .add(previousInput.duration, 'seconds')
209
+ .isAfter(currentMoment)) {
210
+ throw new InputValidationError(INVALID_OBSERVATION_OVERLAP);
211
+ }
212
+ const compareableTime = previousInputTimestamp.add(previousInput.duration, 'second');
213
+ const timelineGapSize = currentMoment.diff(compareableTime, 'second');
214
+ //console.log(currentMoment, timelineGapSize)
215
+ /** Checks if there is gap in timeline. */
216
+ if (timelineGapSize > 1) {
217
+ for (let missingTimestamp = compareableTime.valueOf(); missingTimestamp <= currentMoment.valueOf() - 1000; missingTimestamp += 1000) {
218
+ const filledGap = this.fillWithZeroishInput(input, missingTimestamp);
219
+ acc.push(filledGap);
220
+ }
221
+ }
222
+ }
223
+ /** Break down current observation. */
224
+ for (let i = 0; i < input.duration; i++) {
225
+ const normalizedInput = this.breakDownInput(input, i);
226
+ acc.push(normalizedInput);
227
+ }
228
+ return this.trimInputsByGlobalTimeline(acc);
229
+ }, []);
230
+ const sortedInputs = flattenInputs.sort((a, b) => moment(a.timestamp).diff(moment(b.timestamp)));
231
+ return this.resampleInputs(sortedInputs);
232
+ }
233
+ }
234
+ exports.TimeSyncModel = TimeSyncModel;
235
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1zeW5jLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vZGVscy90aW1lLXN5bmMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQWtDO0FBQ2xDLCtDQUEwQztBQUUxQyxzQ0FBa0M7QUFFbEMsMkNBQXNDO0FBQ3RDLHVEQUFpRDtBQU9qRCxNQUFNLFdBQVcsR0FBRyxJQUFBLDJCQUFZLEVBQUMsTUFBTSxDQUFDLENBQUM7QUFFekMsTUFBTSxFQUFDLG9CQUFvQixFQUFDLEdBQUcsZUFBTSxDQUFDO0FBRXRDLE1BQU0sRUFDSiwwQkFBMEIsRUFDMUIscUJBQXFCLEVBQ3JCLDJCQUEyQixHQUM1QixHQUFHLGdCQUFPLENBQUM7QUFFWixNQUFhLGFBQWE7SUFBMUI7UUFJRSxhQUFRLEdBQUcsQ0FBQyxDQUFDO1FBK0JiOztXQUVHO1FBQ0ssdUJBQWtCLEdBQUcsQ0FBQyxLQUFhLEVBQUUsUUFBZ0IsRUFBRSxFQUFFLENBQy9ELEtBQUssR0FBRyxRQUFRLENBQUM7UUFFbkI7O1dBRUc7UUFDSywyQkFBc0IsR0FBRyxDQUFDLGtCQUEwQixFQUFFLENBQVMsRUFBRSxFQUFFO1lBQ3pFLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUU5RCxPQUFPLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3JDLENBQUMsQ0FBQztRQXNGRjs7O1dBR0c7UUFDSyx1QkFBa0IsR0FBRyxDQUFDLGdCQUErQixFQUFFLEVBQUU7WUFDL0QsT0FBTyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRTtnQkFDM0QsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQWtCLENBQUM7Z0JBRXBELE9BQU8sQ0FBQyxP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QUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzNDLENBQUM7Q0FDRjtBQTVURCxzQ0E0VEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbW9tZW50ID0gcmVxdWlyZSgnbW9tZW50Jyk7XG5pbXBvcnQge2V4dGVuZE1vbWVudH0gZnJvbSAnbW9tZW50LXJhbmdlJztcblxuaW1wb3J0IHtTVFJJTkdTfSBmcm9tICcuLi9jb25maWcnO1xuXG5pbXBvcnQge0VSUk9SU30gZnJvbSAnLi4vdXRpbC9lcnJvcnMnO1xuaW1wb3J0IHtVbml0c0RlYWxlcn0gZnJvbSAnLi4vdXRpbC91bml0cy1kZWFsZXInO1xuXG5pbXBvcnQge01vZGVsUGFyYW1zLCBNb2RlbFBsdWdpbkludGVyZmFjZX0gZnJvbSAnLi4vdHlwZXMvbW9kZWwtaW50ZXJmYWNlJztcbmltcG9ydCB7UGFkZGluZ1JlY2VpcHQsIFRpbWVOb3JtYWxpemVyQ29uZmlnfSBmcm9tICcuLi90eXBlcy90aW1lLXN5bmMnO1xuaW1wb3J0IHtVbml0c0RlYWxlclVzYWdlfSBmcm9tICcuLi90eXBlcy91bml0cy1kZWFsZXInO1xuaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi4vdHlwZXMvdW5pdHMnO1xuXG5jb25zdCBtb21lbnRSYW5nZSA9IGV4dGVuZE1vbWVudChtb21lbnQpO1xuXG5jb25zdCB7SW5wdXRWYWxpZGF0aW9uRXJyb3J9ID0gRVJST1JTO1xuXG5jb25zdCB7XG4gIElOVkFMSURfVElNRV9OT1JNQUxJWkFUSU9OLFxuICBJTlZBTElEX1RJTUVfSU5URVJWQUwsXG4gIElOVkFMSURfT0JTRVJWQVRJT05fT1ZFUkxBUCxcbn0gPSBTVFJJTkdTO1xuXG5leHBvcnQgY2xhc3MgVGltZVN5bmNNb2RlbCBpbXBsZW1lbnRzIE1vZGVsUGx1Z2luSW50ZXJmYWNlIHtcbiAgc3RhcnRUaW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGVuZFRpbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgZGVhbGVyITogVW5pdHNEZWFsZXJVc2FnZTtcbiAgaW50ZXJ2YWwgPSAxO1xuXG4gIC8qKlxuICAgKiBTZXR1cHMgYmFzaWMgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIGFzeW5jIGNvbmZpZ3VyZShwYXJhbXM6IFRpbWVOb3JtYWxpemVyQ29uZmlnKTogUHJvbWlzZTxNb2RlbFBsdWdpbkludGVyZmFjZT4ge1xuICAgIHRoaXMuc3RhcnRUaW1lID0gcGFyYW1zWydzdGFydC10aW1lJ107XG4gICAgdGhpcy5lbmRUaW1lID0gcGFyYW1zWydlbmQtdGltZSddO1xuICAgIHRoaXMuaW50ZXJ2YWwgPSBwYXJhbXMuaW50ZXJ2YWw7XG4gICAgdGhpcy5kZWFsZXIgPSBhd2FpdCBVbml0c0RlYWxlcigpO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIGBzdGFydFRpbWVgLCBgZW5kVGltZWAgYW5kIGBpbnRlcnZhbGAgcGFyYW1zLlxuICAgKi9cbiAgcHJpdmF0ZSB2YWxpZGF0ZVBhcmFtcygpIHtcbiAgICBpZiAoIXRoaXMuc3RhcnRUaW1lIHx8ICF0aGlzLmVuZFRpbWUpIHtcbiAgICAgIHRocm93IG5ldyBJbnB1dFZhbGlkYXRpb25FcnJvcihJTlZBTElEX1RJTUVfTk9STUFMSVpBVElPTik7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuc3RhcnRUaW1lID4gdGhpcy5lbmRUaW1lKSB7XG4gICAgICB0aHJvdyBuZXcgSW5wdXRWYWxpZGF0aW9uRXJyb3IoSU5WQUxJRF9USU1FX05PUk1BTElaQVRJT04pO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5pbnRlcnZhbCkge1xuICAgICAgdGhyb3cgbmV3IElucHV0VmFsaWRhdGlvbkVycm9yKElOVkFMSURfVElNRV9JTlRFUlZBTCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIENhbGN1bGF0ZXMgbWluaW1hbCBmYWN0b3IuXG4gICAqL1xuICBwcml2YXRlIGNvbnZlcnRQZXJJbnRlcnZhbCA9ICh2YWx1ZTogbnVtYmVyLCBkdXJhdGlvbjogbnVtYmVyKSA9PlxuICAgIHZhbHVlIC8gZHVyYXRpb247XG5cbiAgLyoqXG4gICAqIE5vcm1hbGl6ZSB0aW1lIHBlciBnaXZlbiBzZWNvbmQuXG4gICAqL1xuICBwcml2YXRlIG5vcm1hbGl6ZVRpbWVQZXJTZWNvbmQgPSAoY3VycmVudFJvdW5kTW9tZW50OiBzdHJpbmcsIGk6IG51bWJlcikgPT4ge1xuICAgIGNvbnN0IHRoaXNNb21lbnQgPSBtb21lbnQoY3VycmVudFJvdW5kTW9tZW50KS5taWxsaXNlY29uZHMoMCk7XG5cbiAgICByZXR1cm4gdGhpc01vbWVudC5hZGQoaSwgJ3NlY29uZCcpO1xuICB9O1xuXG4gIC8qKlxuICAgKiBCYXJrZXMgZG93biBpbnB1dCBwZXIgbWluaW1hbCB0aW1lIHVuaXQuXG4gICAqL1xuICBwcml2YXRlIGJyZWFrRG93bklucHV0KGlucHV0OiBNb2RlbFBhcmFtcywgaTogbnVtYmVyKSB7XG4gICAgY29uc3QgaW5wdXRLZXlzID0gT2JqZWN0LmtleXMoaW5wdXQpIGFzIFVuaXRLZXlOYW1lW107XG5cbiAgICByZXR1cm4gaW5wdXRLZXlzLnJlZHVjZSgoYWNjLCBrZXkpID0+IHtcbiAgICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuZGVhbGVyLmFza1RvR2l2ZU1ldGhvZEZvcihrZXkpO1xuXG4gICAgICBpZiAoa2V5ID09PSAndGltZXN0YW1wJykge1xuICAgICAgICBjb25zdCBwZXJTZWNvbmQgPSB0aGlzLm5vcm1hbGl6ZVRpbWVQZXJTZWNvbmQoaW5wdXQudGltZXN0YW1wLCBpKTtcbiAgICAgICAgYWNjW2tleV0gPSBtb21lbnQocGVyU2Vjb25kKS5taWxsaXNlY29uZHMoMCkudG9JU09TdHJpbmcoKTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICAvKiogQHRvZG8gdXNlIHVzZXIgZGVmaW5lZCByZXNvbHV0aW9uIGxhdGVyICovXG4gICAgICBpZiAoa2V5ID09PSAnZHVyYXRpb24nKSB7XG4gICAgICAgIGFjY1trZXldID0gMTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICBhY2Nba2V5XSA9XG4gICAgICAgIG1ldGhvZCA9PT0gJ3N1bSdcbiAgICAgICAgICA/IHRoaXMuY29udmVydFBlckludGVydmFsKGlucHV0W2tleV0sIGlucHV0WydkdXJhdGlvbiddKVxuICAgICAgICAgIDogaW5wdXRba2V5XTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBNb2RlbFBhcmFtcyk7XG4gIH1cblxuICAvKipcbiAgICogUG9wdWxhdGVzIG9iamVjdCB0byBmaWxsIHRoZSBnYXBzIGluIG9ic2VydmF0aW9uYWwgdGltZWxpbmUgdXNpbmcgemVyb2lzaCB2YWx1ZXMuXG4gICAqL1xuICBwcml2YXRlIGZpbGxXaXRoWmVyb2lzaElucHV0KGlucHV0OiBNb2RlbFBhcmFtcywgbWlzc2luZ1RpbWVzdGFtcDogbnVtYmVyKSB7XG4gICAgY29uc3QgbWV0cmljcyA9IE9iamVjdC5rZXlzKGlucHV0KSBhcyBVbml0S2V5TmFtZVtdO1xuXG4gICAgcmV0dXJuIG1ldHJpY3MucmVkdWNlKChhY2MsIG1ldHJpYykgPT4ge1xuICAgICAgaWYgKG1ldHJpYyA9PT0gJ3RpbWVzdGFtcCcpIHtcbiAgICAgICAgYWNjW21ldHJpY10gPSBtb21lbnQobWlzc2luZ1RpbWVzdGFtcCkubWlsbGlzZWNvbmRzKDApLnRvSVNPU3RyaW5nKCk7XG5cbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH1cblxuICAgICAgLyoqIEB0b2RvIGxhdGVyIHdpbGwgYmUgY2hhbmdlZCB0byB1c2VyIGRlZmluZWQgaW50ZXJ2YWwgKi9cbiAgICAgIGlmIChtZXRyaWMgPT09ICdkdXJhdGlvbicpIHtcbiAgICAgICAgYWNjW21ldHJpY10gPSAxO1xuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9XG5cbiAgICAgIGlmIChtZXRyaWMgPT09ICd0aW1lLXJlc2VydmVkJykge1xuICAgICAgICBhY2NbbWV0cmljXSA9IGFjY1snZHVyYXRpb24nXTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBtZXRob2QgPSB0aGlzLmRlYWxlci5hc2tUb0dpdmVNZXRob2RGb3IobWV0cmljKTtcbiAgICAgIGFjY1ttZXRyaWNdID0gbWV0aG9kID09PSAnYXZnJyB8fCBtZXRob2QgPT09ICdzdW0nID8gMCA6IGlucHV0W21ldHJpY107XG5cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgTW9kZWxQYXJhbXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiBwYWRkaW5nIGlzIG5lZWRlZCBlaXRoZXIgYXQgc3RhcnQgb2YgdGhlIHRpbWVsaW5lIG9yIHRoZSBlbmQgYW5kIHJldHVybnMgc3RhdHVzLlxuICAgKi9cbiAgcHJpdmF0ZSBjaGVja0ZvclBhZGRpbmcoaW5wdXRzOiBNb2RlbFBhcmFtc1tdKTogUGFkZGluZ1JlY2VpcHQge1xuICAgIGNvbnN0IHN0YXJ0RGlmZkluU2Vjb25kcyA9XG4gICAgICBtb21lbnQoaW5wdXRzWzBdLnRpbWVzdGFtcCkuZGlmZihtb21lbnQodGhpcy5zdGFydFRpbWUpKSAvIDEwMDA7XG5cbiAgICBjb25zdCBsYXN0SW5wdXQgPSBpbnB1dHNbaW5wdXRzLmxlbmd0aCAtIDFdO1xuICAgIGNvbnN0IGVuZERpZmZJblNlY29uZHMgPVxuICAgICAgbW9tZW50KGxhc3RJbnB1dC50aW1lc3RhbXApXG4gICAgICAgIC5hZGQobGFzdElucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpXG4gICAgICAgIC5kaWZmKG1vbWVudCh0aGlzLmVuZFRpbWUpKSAvIDEwMDA7XG5cbiAgICByZXR1cm4ge1xuICAgICAgc3RhcnQ6IHN0YXJ0RGlmZkluU2Vjb25kcyA+IDAsXG4gICAgICBlbmQ6IGVuZERpZmZJblNlY29uZHMgPCAwLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogSXRlcmF0ZXMgb3ZlciBnaXZlbiBpbnB1dHMgZnJhbWUsIG1lYW53aGlsZSBjaGVja2luZyBpZiBhZ2dyZWdhdGlvbiBtZXRob2QgaXMgYHN1bWAsIHRoZW4gY2FsY3VsYXRlcyBpdC5cbiAgICogRm9yIG1ldGhvZHMgaXMgYGF2Z2AgYW5kIGBub25lYCBjYWxjdWxhdGluZyBhdmVyYWdlIG9mIHRoZSBmcmFtZS5cbiAgICovXG4gIHByaXZhdGUgcmVzYW1wbGVJbnB1dEZyYW1lID0gKGlucHV0c0luVGltZXNsb3Q6IE1vZGVsUGFyYW1zW10pID0+IHtcbiAgICByZXR1cm4gaW5wdXRzSW5UaW1lc2xvdC5yZWR1Y2UoKGFjYywgaW5wdXQsIGluZGV4LCBpbnB1dHMpID0+IHtcbiAgICAgIGNvbnN0IG1ldHJpY3MgPSBPYmplY3Qua2V5cyhpbnB1dCkgYXMgVW5pdEtleU5hbWVbXTtcblxuICAgICAgbWV0cmljcy5mb3JFYWNoKG1ldHJpYyA9PiB7XG4gICAgICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuZGVhbGVyLmFza1RvR2l2ZU1ldGhvZEZvcihtZXRyaWMpO1xuICAgICAgICBhY2NbbWV0cmljXSA9IGFjY1ttZXRyaWNdID8/IDA7XG5cbiAgICAgICAgaWYgKG1ldHJpYyA9PT0gJ3RpbWVzdGFtcCcpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSA9IGlucHV0c1swXVttZXRyaWNdO1xuXG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKG1ldGhvZCA9PT0gJ3N1bScpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSArPSBpbnB1dFttZXRyaWNdO1xuXG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgLyoqIGRpdmlkZSBlYWNoIG1ldHJpYyBieSB0aGUgdGltZXNsb3QgbGVuZ3RoLCBzbyB0aGF0IHRoZWlyIHN1bSB5aWVsZHMgdGhlIHRpbWVzbG90IGF2ZXJhZ2UuKi9cbiAgICAgICAgaWYgKGluZGV4ID09PSBpbnB1dHNJblRpbWVzbG90Lmxlbmd0aCAtIDEpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSAvPSBpbnB1dHNJblRpbWVzbG90Lmxlbmd0aDtcblxuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGFjY1ttZXRyaWNdICs9IGlucHV0W21ldHJpY107XG4gICAgICB9KTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBNb2RlbFBhcmFtcyk7XG4gIH07XG5cbiAgLyoqXG4gICAqIFRha2VzIGVhY2ggYXJyYXkgZnJhbWUgd2l0aCBpbnRlcnZhbCBsZW5ndGgsIHRoZW4gYWdncmVnYXRpbmcgdGhlbSB0b2dldGhlciBhcyBmcm9tIHVuaXRzLnlhbWwgZmlsZS5cbiAgICovXG4gIHByaXZhdGUgcmVzYW1wbGVJbnB1dHMoaW5wdXRzOiBNb2RlbFBhcmFtc1tdKSB7XG4gICAgcmV0dXJuIGlucHV0cy5yZWR1Y2UoKGFjYywgX2lucHV0LCBpbmRleCwgaW5wdXRzKSA9PiB7XG4gICAgICBjb25zdCBmcmFtZVN0YXJ0ID0gaW5kZXggKiB0aGlzLmludGVydmFsO1xuICAgICAgY29uc3QgZnJhbWVFbmQgPSAoaW5kZXggKyAxKSAqIHRoaXMuaW50ZXJ2YWw7XG4gICAgICBjb25zdCBpbnB1dHNGcmFtZSA9IGlucHV0cy5zbGljZShmcmFtZVN0YXJ0LCBmcmFtZUVuZCk7XG5cbiAgICAgIGNvbnN0IHJlc2FtcGxlZElucHV0ID0gdGhpcy5yZXNhbXBsZUlucHV0RnJhbWUoaW5wdXRzRnJhbWUpO1xuXG4gICAgICAvKiogQ2hlY2tzIGlmIHJlc2FtcGxlZCBpbnB1dCBpcyBub3QgZW1wdHksIHRoZW4gaW5jbHVkZXMgaW4gcmVzdWx0LiAqL1xuICAgICAgaWYgKE9iamVjdC5rZXlzKHJlc2FtcGxlZElucHV0KS5sZW5ndGggPiAwKSB7XG4gICAgICAgIGFjYy5wdXNoKHJlc2FtcGxlZElucHV0KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCBbXSBhcyBNb2RlbFBhcmFtc1tdKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQYWRzIHplcm9pc2ggaW5wdXRzIGZyb20gdGhlIGJlZ2lubmluZyBvciBhdCB0aGUgZW5kIG9mIHRoZSBpbnB1dHMgaWYgbmVlZGVkLlxuICAgKi9cbiAgcHJpdmF0ZSBwYWRJbnB1dHMoaW5wdXRzOiBNb2RlbFBhcmFtc1tdLCBwYWQ6IFBhZGRpbmdSZWNlaXB0KTogTW9kZWxQYXJhbXNbXSB7XG4gICAgY29uc3Qge3N0YXJ0LCBlbmR9ID0gcGFkO1xuICAgIGNvbnN0IHBhZGRlZEZyb21CZWdpbm5pbmcgPSBbXTtcblxuICAgIGlmIChzdGFydCkge1xuICAgICAgY29uc3QgZGF0ZVJhbmdlID0gbW9tZW50UmFuZ2UucmFuZ2UoXG4gICAgICAgIG1vbWVudCh0aGlzLnN0YXJ0VGltZSksXG4gICAgICAgIG1vbWVudChpbnB1dHNbMF0udGltZXN0YW1wKS5zdWJ0cmFjdCgxLCAnc2Vjb25kJylcbiAgICAgICk7XG5cbiAgICAgIC8qKiBDaGVja3MgaWYgY29udmVydGluZyB0byB2YWx1ZSBvZiBpcyBuZWVkZWQuICovXG4gICAgICBmb3IgKGNvbnN0IHNlY29uZCBvZiBkYXRlUmFuZ2UuYnkoJ3NlY29uZCcpKSB7XG4gICAgICAgIHBhZGRlZEZyb21CZWdpbm5pbmcucHVzaChcbiAgICAgICAgICB0aGlzLmZpbGxXaXRoWmVyb2lzaElucHV0KGlucHV0c1swXSwgc2Vjb25kLnZhbHVlT2YoKSlcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCBwYWRkZWRBcnJheSA9IHBhZGRlZEZyb21CZWdpbm5pbmcuY29uY2F0KGlucHV0cyk7XG5cbiAgICBpZiAoZW5kKSB7XG4gICAgICBjb25zdCBsYXN0SW5wdXQgPSBpbnB1dHNbaW5wdXRzLmxlbmd0aCAtIDFdO1xuICAgICAgY29uc3QgZGF0ZVJhbmdlID0gbW9tZW50UmFuZ2UucmFuZ2UoXG4gICAgICAgIG1vbWVudChsYXN0SW5wdXQudGltZXN0YW1wKS5hZGQobGFzdElucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpLFxuICAgICAgICBtb21lbnQodGhpcy5lbmRUaW1lKVxuICAgICAgKTtcblxuICAgICAgZm9yIChjb25zdCBzZWNvbmQgb2YgZGF0ZVJhbmdlLmJ5KCdzZWNvbmQnKSkge1xuICAgICAgICBwYWRkZWRBcnJheS5wdXNoKFxuICAgICAgICAgIHRoaXMuZmlsbFdpdGhaZXJvaXNoSW5wdXQobGFzdElucHV0LCBzZWNvbmQudmFsdWVPZigpKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBwYWRkZWRBcnJheTtcbiAgfVxuXG4gIC8qXG4gICAqIENoZWNrcyBpZiBpbnB1dCdzIHRpbWVzdGFtcCBpcyBpbmNsdWRlZCBpbiBnbG9iYWwgc3BlY2lmaWVkIHBlcmlvZCB0aGVuIGxlYXZlcyBpdCwgb3RoZXJ3aXNlLlxuICAgKi9cbiAgcHJpdmF0ZSB0cmltSW5wdXRzQnlHbG9iYWxUaW1lbGluZShpbnB1dHM6IE1vZGVsUGFyYW1zW10pOiBNb2RlbFBhcmFtc1tdIHtcbiAgICByZXR1cm4gaW5wdXRzLnJlZHVjZSgoYWNjLCBpdGVtKSA9PiB7XG4gICAgICBjb25zdCB7dGltZXN0YW1wfSA9IGl0ZW07XG5cbiAgICAgIGlmIChcbiAgICAgICAgbW9tZW50KHRpbWVzdGFtcCkuaXNTYW1lT3JBZnRlcihtb21lbnQodGhpcy5zdGFydFRpbWUpKSAmJlxuICAgICAgICBtb21lbnQodGltZXN0YW1wKS5pc1NhbWVPckJlZm9yZShtb21lbnQodGhpcy5lbmRUaW1lKSlcbiAgICAgICkge1xuICAgICAgICBhY2MucHVzaChpdGVtKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCBbXSBhcyBNb2RlbFBhcmFtc1tdKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOb3JtYWxpemVzIHByb3ZpZGVkIHRpbWUgd2luZG93IGFjY29yZGluZyB0byB0aW1lIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBhc3luYyBleGVjdXRlKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IFByb21pc2U8TW9kZWxQYXJhbXNbXT4ge1xuICAgIHRoaXMudmFsaWRhdGVQYXJhbXMoKTtcblxuICAgIGNvbnN0IHBhZCA9IHRoaXMuY2hlY2tGb3JQYWRkaW5nKGlucHV0cyk7XG4gICAgY29uc3QgcGFkZGVkSW5wdXRzID0gdGhpcy5wYWRJbnB1dHMoaW5wdXRzLCBwYWQpO1xuXG4gICAgY29uc3QgZmxhdHRlbklucHV0cyA9IHBhZGRlZElucHV0cy5yZWR1Y2UoKGFjYywgaW5wdXQsIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBjdXJyZW50TW9tZW50ID0gbW9tZW50KGlucHV0LnRpbWVzdGFtcCk7XG5cbiAgICAgIC8qKiBDaGVja3MgaWYgbm90IHRoZSBmaXJzdCBpbnB1dCwgdGhlbiBjaGVjayBjb25zaXN0ZW5jeSB3aXRoIHByZXZpb3VzIG9uZXMuICovXG4gICAgICBpZiAoaW5kZXggPiAwKSB7XG4gICAgICAgIGNvbnN0IHByZXZpb3VzSW5wdXQgPSBwYWRkZWRJbnB1dHNbaW5kZXggLSAxXTtcbiAgICAgICAgY29uc3QgcHJldmlvdXNJbnB1dFRpbWVzdGFtcCA9IG1vbWVudChwcmV2aW91c0lucHV0LnRpbWVzdGFtcCk7XG5cbiAgICAgICAgLyoqIENoZWNrcyBmb3IgdGltZXN0YW1wcyBvdmVybGFwLiAqL1xuICAgICAgICBpZiAoXG4gICAgICAgICAgbW9tZW50KHByZXZpb3VzSW5wdXQudGltZXN0YW1wKVxuICAgICAgICAgICAgLmFkZChwcmV2aW91c0lucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpXG4gICAgICAgICAgICAuaXNBZnRlcihjdXJyZW50TW9tZW50KVxuICAgICAgICApIHtcbiAgICAgICAgICB0aHJvdyBuZXcgSW5wdXRWYWxpZGF0aW9uRXJyb3IoSU5WQUxJRF9PQlNFUlZBVElPTl9PVkVSTEFQKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGNvbXBhcmVhYmxlVGltZSA9IHByZXZpb3VzSW5wdXRUaW1lc3RhbXAuYWRkKFxuICAgICAgICAgIHByZXZpb3VzSW5wdXQuZHVyYXRpb24sXG4gICAgICAgICAgJ3NlY29uZCdcbiAgICAgICAgKTtcblxuICAgICAgICBjb25zdCB0aW1lbGluZUdhcFNpemUgPSBjdXJyZW50TW9tZW50LmRpZmYoY29tcGFyZWFibGVUaW1lLCAnc2Vjb25kJyk7XG4gICAgICAgIC8vY29uc29sZS5sb2coY3VycmVudE1vbWVudCwgdGltZWxpbmVHYXBTaXplKVxuICAgICAgICAvKiogQ2hlY2tzIGlmIHRoZXJlIGlzIGdhcCBpbiB0aW1lbGluZS4gKi9cbiAgICAgICAgaWYgKHRpbWVsaW5lR2FwU2l6ZSA+IDEpIHtcbiAgICAgICAgICBmb3IgKFxuICAgICAgICAgICAgbGV0IG1pc3NpbmdUaW1lc3RhbXAgPSBjb21wYXJlYWJsZVRpbWUudmFsdWVPZigpO1xuICAgICAgICAgICAgbWlzc2luZ1RpbWVzdGFtcCA8PSBjdXJyZW50TW9tZW50LnZhbHVlT2YoKSAtIDEwMDA7XG4gICAgICAgICAgICBtaXNzaW5nVGltZXN0YW1wICs9IDEwMDBcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIGNvbnN0IGZpbGxlZEdhcCA9IHRoaXMuZmlsbFdpdGhaZXJvaXNoSW5wdXQoXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBtaXNzaW5nVGltZXN0YW1wXG4gICAgICAgICAgICApO1xuXG4gICAgICAgICAgICBhY2MucHVzaChmaWxsZWRHYXApO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvKiogQnJlYWsgZG93biBjdXJyZW50IG9ic2VydmF0aW9uLiAqL1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBpbnB1dC5kdXJhdGlvbjsgaSsrKSB7XG4gICAgICAgIGNvbnN0IG5vcm1hbGl6ZWRJbnB1dCA9IHRoaXMuYnJlYWtEb3duSW5wdXQoaW5wdXQsIGkpO1xuXG4gICAgICAgIGFjYy5wdXNoKG5vcm1hbGl6ZWRJbnB1dCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLnRyaW1JbnB1dHNCeUdsb2JhbFRpbWVsaW5lKGFjYyk7XG4gICAgfSwgW10gYXMgTW9kZWxQYXJhbXNbXSk7XG5cbiAgICBjb25zdCBzb3J0ZWRJbnB1dHMgPSBmbGF0dGVuSW5wdXRzLnNvcnQoKGEsIGIpID0+XG4gICAgICBtb21lbnQoYS50aW1lc3RhbXApLmRpZmYobW9tZW50KGIudGltZXN0YW1wKSlcbiAgICApO1xuXG4gICAgcmV0dXJuIHRoaXMucmVzYW1wbGVJbnB1dHMoc29ydGVkSW5wdXRzKTtcbiAgfVxufVxuIl19
@@ -0,0 +1 @@
1
+ export type AsyncReturnType<T extends (...args: any) => Promise<any>> = T extends (...args: any) => Promise<infer R> ? R : any;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBc3luY1JldHVyblR5cGU8VCBleHRlbmRzICguLi5hcmdzOiBhbnkpID0+IFByb21pc2U8YW55Pj4gPVxuICBUIGV4dGVuZHMgKC4uLmFyZ3M6IGFueSkgPT4gUHJvbWlzZTxpbmZlciBSPiA/IFIgOiBhbnk7XG4iXX0=
@@ -1,3 +1,6 @@
1
+ import { ModelParams } from './model-interface';
2
+ import { AggregationResult } from './planet-aggregator';
3
+ declare const AGGREGATION_METHODS: string[], AGGREGATION_METRICS: string[];
1
4
  type Tag = {
2
5
  kind?: string;
3
6
  complexity?: string;
@@ -8,24 +11,21 @@ type Model = {
8
11
  kind?: string;
9
12
  verbose?: boolean;
10
13
  path?: string;
14
+ config?: Config;
11
15
  };
12
- export type ModelParams = {
13
- timestamp: number;
14
- duration: number;
15
- [key: string]: any;
16
- };
17
- export type Config = {
18
- [key: string]: any;
19
- };
16
+ export type Config = Record<string, any>;
20
17
  export type Children = {
21
18
  [key: string]: {
22
19
  pipeline: string[];
23
20
  config: Config;
24
21
  inputs: ModelParams[];
25
- children?: Children;
22
+ children: Children;
26
23
  outputs?: ModelParams[];
24
+ 'aggregated-outputs'?: AggregationResult;
27
25
  };
28
26
  };
27
+ export type AggregationMetrics = (typeof AGGREGATION_METRICS)[number];
28
+ export type AggregationMethod = (typeof AGGREGATION_METHODS)[number];
29
29
  export type Impl = {
30
30
  name: string;
31
31
  description: string | null | undefined;
@@ -36,5 +36,10 @@ export type Impl = {
36
36
  graph: {
37
37
  children: Children;
38
38
  };
39
+ aggregation?: {
40
+ 'aggregation-metrics': AggregationMetrics[];
41
+ 'aggregation-method': AggregationMethod;
42
+ };
43
+ 'aggregated-outputs'?: AggregationResult;
39
44
  };
40
45
  export {};
@@ -1,3 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1wbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbXBsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ0eXBlIFRhZyA9IHtcbiAga2luZD86IHN0cmluZztcbiAgY29tcGxleGl0eT86IHN0cmluZztcbiAgY2F0ZWdvcnk/OiBzdHJpbmc7XG59O1xuXG50eXBlIE1vZGVsID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGtpbmQ/OiBzdHJpbmc7XG4gIHZlcmJvc2U/OiBib29sZWFuO1xuICBwYXRoPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgTW9kZWxQYXJhbXMgPSB7XG4gIHRpbWVzdGFtcDogbnVtYmVyO1xuICBkdXJhdGlvbjogbnVtYmVyO1xuICBba2V5OiBzdHJpbmddOiBhbnk7XG59O1xuXG5leHBvcnQgdHlwZSBDb25maWcgPSB7XG4gIFtrZXk6IHN0cmluZ106IGFueTtcbn07XG5cbmV4cG9ydCB0eXBlIENoaWxkcmVuID0ge1xuICBba2V5OiBzdHJpbmddOiB7XG4gICAgcGlwZWxpbmU6IHN0cmluZ1tdO1xuICAgIGNvbmZpZzogQ29uZmlnO1xuICAgIGlucHV0czogTW9kZWxQYXJhbXNbXTtcbiAgICBjaGlsZHJlbj86IENoaWxkcmVuO1xuICAgIG91dHB1dHM/OiBNb2RlbFBhcmFtc1tdO1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgSW1wbCA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgdGFnczogVGFnIHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgaW5pdGlhbGl6ZToge1xuICAgIG1vZGVsczogTW9kZWxbXTtcbiAgfTtcbiAgZ3JhcGg6IHtcbiAgICBjaGlsZHJlbjogQ2hpbGRyZW47XG4gIH07XG59O1xuIl19
3
+ const config_1 = require("../config");
4
+ const { AGGREGATION_METHODS, AGGREGATION_METRICS } = config_1.CONFIG;
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1wbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbXBsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQWlDO0FBSWpDLE1BQU0sRUFBQyxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBQyxHQUFHLGVBQU0sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q09ORklHfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtNb2RlbFBhcmFtc30gZnJvbSAnLi9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtBZ2dyZWdhdGlvblJlc3VsdH0gZnJvbSAnLi9wbGFuZXQtYWdncmVnYXRvcic7XG5cbmNvbnN0IHtBR0dSRUdBVElPTl9NRVRIT0RTLCBBR0dSRUdBVElPTl9NRVRSSUNTfSA9IENPTkZJRztcblxudHlwZSBUYWcgPSB7XG4gIGtpbmQ/OiBzdHJpbmc7XG4gIGNvbXBsZXhpdHk/OiBzdHJpbmc7XG4gIGNhdGVnb3J5Pzogc3RyaW5nO1xufTtcblxudHlwZSBNb2RlbCA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICBraW5kPzogc3RyaW5nO1xuICB2ZXJib3NlPzogYm9vbGVhbjtcbiAgcGF0aD86IHN0cmluZztcbiAgY29uZmlnPzogQ29uZmlnO1xufTtcblxuZXhwb3J0IHR5cGUgQ29uZmlnID0gUmVjb3JkPHN0cmluZywgYW55PjtcblxuZXhwb3J0IHR5cGUgQ2hpbGRyZW4gPSB7XG4gIFtrZXk6IHN0cmluZ106IHtcbiAgICBwaXBlbGluZTogc3RyaW5nW107XG4gICAgY29uZmlnOiBDb25maWc7XG4gICAgaW5wdXRzOiBNb2RlbFBhcmFtc1tdO1xuICAgIGNoaWxkcmVuOiBDaGlsZHJlbjtcbiAgICBvdXRwdXRzPzogTW9kZWxQYXJhbXNbXTtcbiAgICAnYWdncmVnYXRlZC1vdXRwdXRzJz86IEFnZ3JlZ2F0aW9uUmVzdWx0O1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgQWdncmVnYXRpb25NZXRyaWNzID0gKHR5cGVvZiBBR0dSRUdBVElPTl9NRVRSSUNTKVtudW1iZXJdO1xuZXhwb3J0IHR5cGUgQWdncmVnYXRpb25NZXRob2QgPSAodHlwZW9mIEFHR1JFR0FUSU9OX01FVEhPRFMpW251bWJlcl07XG5cbmV4cG9ydCB0eXBlIEltcGwgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIHRhZ3M6IFRhZyB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIGluaXRpYWxpemU6IHtcbiAgICBtb2RlbHM6IE1vZGVsW107XG4gIH07XG4gIGdyYXBoOiB7XG4gICAgY2hpbGRyZW46IENoaWxkcmVuO1xuICB9O1xuICBhZ2dyZWdhdGlvbj86IHtcbiAgICAnYWdncmVnYXRpb24tbWV0cmljcyc6IEFnZ3JlZ2F0aW9uTWV0cmljc1tdO1xuICAgICdhZ2dyZWdhdGlvbi1tZXRob2QnOiBBZ2dyZWdhdGlvbk1ldGhvZDtcbiAgfTtcbiAgJ2FnZ3JlZ2F0ZWQtb3V0cHV0cyc/OiBBZ2dyZWdhdGlvblJlc3VsdDtcbn07XG4iXX0=
@@ -0,0 +1,14 @@
1
+ import { UnitKeyName } from './units';
2
+ export type ModelParams = {
3
+ [K in UnitKeyName]?: any;
4
+ };
5
+ export interface ModelPluginInterface {
6
+ /**
7
+ * Configures instance with given params.
8
+ */
9
+ configure(params: object | undefined): Promise<ModelPluginInterface>;
10
+ /**
11
+ * Calculates `output` based on given model's `input`.
12
+ */
13
+ execute(inputs: ModelParams[]): Promise<ModelParams[]>;
14
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwtaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGVzL21vZGVsLWludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi91bml0cyc7XG5cbmV4cG9ydCB0eXBlIE1vZGVsUGFyYW1zID0ge1xuICBbSyBpbiBVbml0S2V5TmFtZV0/OiBhbnk7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUGx1Z2luSW50ZXJmYWNlIHtcbiAgLyoqXG4gICAqIENvbmZpZ3VyZXMgaW5zdGFuY2Ugd2l0aCBnaXZlbiBwYXJhbXMuXG4gICAqL1xuICBjb25maWd1cmUocGFyYW1zOiBvYmplY3QgfCB1bmRlZmluZWQpOiBQcm9taXNlPE1vZGVsUGx1Z2luSW50ZXJmYWNlPjtcblxuICAvKipcbiAgICogQ2FsY3VsYXRlcyBgb3V0cHV0YCBiYXNlZCBvbiBnaXZlbiBtb2RlbCdzIGBpbnB1dGAuXG4gICAqL1xuICBleGVjdXRlKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IFByb21pc2U8TW9kZWxQYXJhbXNbXT47XG59XG4iXX0=