token-injectable-docker-builder 1.11.1 → 1.12.0

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.
package/.jsii CHANGED
@@ -8568,7 +8568,7 @@
8568
8568
  },
8569
8569
  "locationInModule": {
8570
8570
  "filename": "src/index.ts",
8571
- "line": 323
8571
+ "line": 346
8572
8572
  },
8573
8573
  "parameters": [
8574
8574
  {
@@ -8603,7 +8603,7 @@
8603
8603
  "kind": "class",
8604
8604
  "locationInModule": {
8605
8605
  "filename": "src/index.ts",
8606
- "line": 298
8606
+ "line": 321
8607
8607
  },
8608
8608
  "name": "TokenInjectableDockerBuilder",
8609
8609
  "properties": [
@@ -8615,7 +8615,7 @@
8615
8615
  "immutable": true,
8616
8616
  "locationInModule": {
8617
8617
  "filename": "src/index.ts",
8618
- "line": 308
8618
+ "line": 331
8619
8619
  },
8620
8620
  "name": "containerImage",
8621
8621
  "type": {
@@ -8630,7 +8630,7 @@
8630
8630
  "immutable": true,
8631
8631
  "locationInModule": {
8632
8632
  "filename": "src/index.ts",
8633
- "line": 314
8633
+ "line": 337
8634
8634
  },
8635
8635
  "name": "dockerImageCode",
8636
8636
  "type": {
@@ -8651,7 +8651,7 @@
8651
8651
  "kind": "interface",
8652
8652
  "locationInModule": {
8653
8653
  "filename": "src/index.ts",
8654
- "line": 120
8654
+ "line": 130
8655
8655
  },
8656
8656
  "name": "TokenInjectableDockerBuilderProps",
8657
8657
  "properties": [
@@ -8664,7 +8664,7 @@
8664
8664
  "immutable": true,
8665
8665
  "locationInModule": {
8666
8666
  "filename": "src/index.ts",
8667
- "line": 124
8667
+ "line": 134
8668
8668
  },
8669
8669
  "name": "path",
8670
8670
  "type": {
@@ -8682,7 +8682,7 @@
8682
8682
  "immutable": true,
8683
8683
  "locationInModule": {
8684
8684
  "filename": "src/index.ts",
8685
- "line": 135
8685
+ "line": 145
8686
8686
  },
8687
8687
  "name": "buildArgs",
8688
8688
  "optional": true,
@@ -8706,7 +8706,7 @@
8706
8706
  "immutable": true,
8707
8707
  "locationInModule": {
8708
8708
  "filename": "src/index.ts",
8709
- "line": 257
8709
+ "line": 267
8710
8710
  },
8711
8711
  "name": "buildLogGroup",
8712
8712
  "optional": true,
@@ -8725,7 +8725,7 @@
8725
8725
  "immutable": true,
8726
8726
  "locationInModule": {
8727
8727
  "filename": "src/index.ts",
8728
- "line": 248
8728
+ "line": 258
8729
8729
  },
8730
8730
  "name": "cacheDisabled",
8731
8731
  "optional": true,
@@ -8744,7 +8744,7 @@
8744
8744
  "immutable": true,
8745
8745
  "locationInModule": {
8746
8746
  "filename": "src/index.ts",
8747
- "line": 223
8747
+ "line": 233
8748
8748
  },
8749
8749
  "name": "completenessQueryInterval",
8750
8750
  "optional": true,
@@ -8763,7 +8763,7 @@
8763
8763
  "immutable": true,
8764
8764
  "locationInModule": {
8765
8765
  "filename": "src/index.ts",
8766
- "line": 152
8766
+ "line": 162
8767
8767
  },
8768
8768
  "name": "dockerLoginSecretArn",
8769
8769
  "optional": true,
@@ -8783,7 +8783,7 @@
8783
8783
  "immutable": true,
8784
8784
  "locationInModule": {
8785
8785
  "filename": "src/index.ts",
8786
- "line": 290
8786
+ "line": 300
8787
8787
  },
8788
8788
  "name": "ecrPullThroughCachePrefixes",
8789
8789
  "optional": true,
@@ -8807,7 +8807,7 @@
8807
8807
  "immutable": true,
8808
8808
  "locationInModule": {
8809
8809
  "filename": "src/index.ts",
8810
- "line": 231
8810
+ "line": 241
8811
8811
  },
8812
8812
  "name": "exclude",
8813
8813
  "optional": true,
@@ -8832,7 +8832,7 @@
8832
8832
  "immutable": true,
8833
8833
  "locationInModule": {
8834
8834
  "filename": "src/index.ts",
8835
- "line": 240
8835
+ "line": 250
8836
8836
  },
8837
8837
  "name": "file",
8838
8838
  "optional": true,
@@ -8851,7 +8851,7 @@
8851
8851
  "immutable": true,
8852
8852
  "locationInModule": {
8853
8853
  "filename": "src/index.ts",
8854
- "line": 192
8854
+ "line": 202
8855
8855
  },
8856
8856
  "name": "installCommands",
8857
8857
  "optional": true,
@@ -8875,7 +8875,7 @@
8875
8875
  "immutable": true,
8876
8876
  "locationInModule": {
8877
8877
  "filename": "src/index.ts",
8878
- "line": 215
8878
+ "line": 225
8879
8879
  },
8880
8880
  "name": "kmsEncryption",
8881
8881
  "optional": true,
@@ -8894,7 +8894,7 @@
8894
8894
  "immutable": true,
8895
8895
  "locationInModule": {
8896
8896
  "filename": "src/index.ts",
8897
- "line": 267
8897
+ "line": 277
8898
8898
  },
8899
8899
  "name": "platform",
8900
8900
  "optional": true,
@@ -8913,7 +8913,7 @@
8913
8913
  "immutable": true,
8914
8914
  "locationInModule": {
8915
8915
  "filename": "src/index.ts",
8916
- "line": 206
8916
+ "line": 216
8917
8917
  },
8918
8918
  "name": "preBuildCommands",
8919
8919
  "optional": true,
@@ -8937,7 +8937,7 @@
8937
8937
  "immutable": true,
8938
8938
  "locationInModule": {
8939
8939
  "filename": "src/index.ts",
8940
- "line": 278
8940
+ "line": 288
8941
8941
  },
8942
8942
  "name": "provider",
8943
8943
  "optional": true,
@@ -8945,6 +8945,25 @@
8945
8945
  "fqn": "token-injectable-docker-builder.TokenInjectableDockerBuilderProvider"
8946
8946
  }
8947
8947
  },
8948
+ {
8949
+ "abstract": true,
8950
+ "docs": {
8951
+ "default": "false",
8952
+ "remarks": "Because the log group is managed imperatively (not by CloudFormation),\nit survives stack rollbacks and preserves full build logs for debugging.\nA 7-day retention policy is applied so old logs auto-expire.\n\nSet to `false` after debugging to delete the log group and clean up.",
8953
+ "stability": "stable",
8954
+ "summary": "When `true`, creates a CloudWatch log group outside of CloudFormation (`/docker-builder/<projectName>`) and directs CodeBuild output there."
8955
+ },
8956
+ "immutable": true,
8957
+ "locationInModule": {
8958
+ "filename": "src/index.ts",
8959
+ "line": 313
8960
+ },
8961
+ "name": "retainBuildLogs",
8962
+ "optional": true,
8963
+ "type": {
8964
+ "primitive": "boolean"
8965
+ }
8966
+ },
8948
8967
  {
8949
8968
  "abstract": true,
8950
8969
  "docs": {
@@ -8956,7 +8975,7 @@
8956
8975
  "immutable": true,
8957
8976
  "locationInModule": {
8958
8977
  "filename": "src/index.ts",
8959
- "line": 168
8978
+ "line": 178
8960
8979
  },
8961
8980
  "name": "securityGroups",
8962
8981
  "optional": true,
@@ -8980,7 +8999,7 @@
8980
8999
  "immutable": true,
8981
9000
  "locationInModule": {
8982
9001
  "filename": "src/index.ts",
8983
- "line": 176
9002
+ "line": 186
8984
9003
  },
8985
9004
  "name": "subnetSelection",
8986
9005
  "optional": true,
@@ -8999,7 +9018,7 @@
8999
9018
  "immutable": true,
9000
9019
  "locationInModule": {
9001
9020
  "filename": "src/index.ts",
9002
- "line": 160
9021
+ "line": 170
9003
9022
  },
9004
9023
  "name": "vpc",
9005
9024
  "optional": true,
@@ -9065,7 +9084,7 @@
9065
9084
  },
9066
9085
  "locationInModule": {
9067
9086
  "filename": "src/index.ts",
9068
- "line": 100
9087
+ "line": 110
9069
9088
  },
9070
9089
  "name": "registerProject",
9071
9090
  "parameters": [
@@ -9148,6 +9167,6 @@
9148
9167
  "symbolId": "src/index:TokenInjectableDockerBuilderProviderProps"
9149
9168
  }
9150
9169
  },
9151
- "version": "1.11.1",
9152
- "fingerprint": "tgc6ukIOQspaSon/3bjNA/7RPJXe6z3DBSMizpHRK0Q="
9170
+ "version": "1.12.0",
9171
+ "fingerprint": "XP1cI8U37kjiDiRd3d5aJQjYhnt7o8M9LVZvrmotNFQ="
9153
9172
  }
package/API.md CHANGED
@@ -304,6 +304,7 @@ const tokenInjectableDockerBuilderProps: TokenInjectableDockerBuilderProps = { .
304
304
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.platform">platform</a></code> | <code>string</code> | Target platform for the Docker image. |
305
305
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.preBuildCommands">preBuildCommands</a></code> | <code>string[]</code> | Custom commands to run during the pre_build phase of CodeBuild. |
306
306
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.provider">provider</a></code> | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProvider">TokenInjectableDockerBuilderProvider</a></code> | Shared provider for the custom resource Lambdas. |
307
+ | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.retainBuildLogs">retainBuildLogs</a></code> | <code>boolean</code> | When `true`, creates a CloudWatch log group outside of CloudFormation (`/docker-builder/<projectName>`) and directs CodeBuild output there. |
307
308
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.securityGroups">securityGroups</a></code> | <code>aws-cdk-lib.aws_ec2.ISecurityGroup[]</code> | The security groups to attach to the CodeBuild project. |
308
309
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.subnetSelection">subnetSelection</a></code> | <code>aws-cdk-lib.aws_ec2.SubnetSelection</code> | The subnet selection to specify which subnets to use within the VPC. |
309
310
  | <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.vpc">vpc</a></code> | <code>aws-cdk-lib.aws_ec2.IVpc</code> | The VPC in which the CodeBuild project will be deployed. |
@@ -579,6 +580,25 @@ When omitted, each builder creates its own Lambdas (original behavior).
579
580
 
580
581
  ---
581
582
 
583
+ ##### `retainBuildLogs`<sup>Optional</sup> <a name="retainBuildLogs" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.retainBuildLogs"></a>
584
+
585
+ ```typescript
586
+ public readonly retainBuildLogs: boolean;
587
+ ```
588
+
589
+ - *Type:* boolean
590
+ - *Default:* false
591
+
592
+ When `true`, creates a CloudWatch log group outside of CloudFormation (`/docker-builder/<projectName>`) and directs CodeBuild output there.
593
+
594
+ Because the log group is managed imperatively (not by CloudFormation),
595
+ it survives stack rollbacks and preserves full build logs for debugging.
596
+ A 7-day retention policy is applied so old logs auto-expire.
597
+
598
+ Set to `false` after debugging to delete the log group and clean up.
599
+
600
+ ---
601
+
582
602
  ##### `securityGroups`<sup>Optional</sup> <a name="securityGroups" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProps.property.securityGroups"></a>
583
603
 
584
604
  ```typescript
@@ -80,14 +80,18 @@ exports.handler = async (event) => {
80
80
  };
81
81
  }
82
82
 
83
- // If the build is in a failed status, retrieve CloudWatch logs
84
83
  if (['FAILED', 'FAULT', 'STOPPED', 'TIMED_OUT'].includes(buildStatus)) {
85
- console.log(`Build ended with status: ${buildStatus}. Attempting to retrieve last log lines...`);
84
+ const retainBuildLogs = event.ResourceProperties?.RetainBuildLogs === 'true';
86
85
  const logsInfo = build.logs;
87
- console.log('Logs info:', JSON.stringify(logsInfo, null, 2));
86
+
87
+ if (retainBuildLogs && logsInfo?.groupName) {
88
+ throw new Error(
89
+ `Build ${buildStatus}. Full logs preserved in CW log group: ${logsInfo.groupName}`
90
+ );
91
+ }
88
92
 
89
93
  if (logsInfo?.groupName && logsInfo?.streamName) {
90
- console.log(`Retrieving up to 5 log events from CloudWatch Logs in group ${logsInfo.groupName} stream ${logsInfo.streamName}`);
94
+ console.log(`Retrieving last log events from ${logsInfo.groupName}/${logsInfo.streamName}`);
91
95
  const logResp = await logsClient.send(
92
96
  new GetLogEventsCommand({
93
97
  logGroupName: logsInfo.groupName,
@@ -96,16 +100,14 @@ exports.handler = async (event) => {
96
100
  limit: 5,
97
101
  })
98
102
  );
99
- console.log('GetLogEventsCommand response:', JSON.stringify(logResp, null, 2));
100
-
101
103
  const logEvents = logResp.events || [];
102
104
  const lastFive = logEvents.map(e => e.message).reverse().join('\n');
103
105
  console.error('Last 5 build log lines:\n', lastFive);
104
106
 
105
- throw new Error(`Build failed with status ${buildStatus}. Last logs:\n${lastFive}`);
106
- } else {
107
- throw new Error(`Build failed with status: ${buildStatus}, but no logs found.`);
107
+ throw new Error(`Build ${buildStatus}. Last logs:\n${lastFive}`);
108
108
  }
109
+
110
+ throw new Error(`Build ${buildStatus}, but no log info available.`);
109
111
  }
110
112
 
111
113
  // If we reach here, it's an unexpected status
package/lib/index.d.ts CHANGED
@@ -203,6 +203,18 @@ export interface TokenInjectableDockerBuilderProps {
203
203
  * @default - No pull-through cache access
204
204
  */
205
205
  readonly ecrPullThroughCachePrefixes?: string[];
206
+ /**
207
+ * When `true`, creates a CloudWatch log group outside of CloudFormation
208
+ * (`/docker-builder/<projectName>`) and directs CodeBuild output there.
209
+ * Because the log group is managed imperatively (not by CloudFormation),
210
+ * it survives stack rollbacks and preserves full build logs for debugging.
211
+ * A 7-day retention policy is applied so old logs auto-expire.
212
+ *
213
+ * Set to `false` after debugging to delete the log group and clean up.
214
+ *
215
+ * @default false
216
+ */
217
+ readonly retainBuildLogs?: boolean;
206
218
  }
207
219
  /**
208
220
  * A CDK construct to build and push Docker images to an ECR repository using
package/lib/index.js CHANGED
@@ -45,6 +45,14 @@ class TokenInjectableDockerBuilderProvider extends constructs_1.Construct {
45
45
  handler: 'onEvent.handler',
46
46
  timeout: aws_cdk_lib_1.Duration.minutes(15),
47
47
  });
48
+ this.onEventHandlerFunction.addToRolePolicy(new aws_iam_1.PolicyStatement({
49
+ actions: [
50
+ 'logs:CreateLogGroup',
51
+ 'logs:PutRetentionPolicy',
52
+ 'logs:DeleteLogGroup',
53
+ ],
54
+ resources: ['arn:aws:logs:*:*:log-group:/docker-builder/*'],
55
+ }));
48
56
  this.isCompleteHandlerFunction = new aws_lambda_1.Function(this, 'IsCompleteHandler', {
49
57
  runtime: aws_lambda_1.Runtime.NODEJS_22_X,
50
58
  code: aws_lambda_1.Code.fromAsset(path.resolve(__dirname, '../isComplete')),
@@ -87,7 +95,7 @@ class TokenInjectableDockerBuilderProvider extends constructs_1.Construct {
87
95
  }
88
96
  exports.TokenInjectableDockerBuilderProvider = TokenInjectableDockerBuilderProvider;
89
97
  _a = JSII_RTTI_SYMBOL_1;
90
- TokenInjectableDockerBuilderProvider[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilderProvider", version: "1.11.1" };
98
+ TokenInjectableDockerBuilderProvider[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilderProvider", version: "1.12.0" };
91
99
  /**
92
100
  * A CDK construct to build and push Docker images to an ECR repository using
93
101
  * CodeBuild and Lambda custom resources, **then** retrieve the final image tag
@@ -103,7 +111,7 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
103
111
  */
104
112
  constructor(scope, id, props) {
105
113
  super(scope, id);
106
- const { path: sourcePath, buildArgs, dockerLoginSecretArn, vpc, securityGroups, subnetSelection, installCommands, preBuildCommands, kmsEncryption = false, completenessQueryInterval, exclude, file: dockerFile, cacheDisabled = false, buildLogGroup: buildLogGroupProp, platform = 'linux/amd64', provider: sharedProvider, ecrPullThroughCachePrefixes, } = props;
114
+ const { path: sourcePath, buildArgs, dockerLoginSecretArn, vpc, securityGroups, subnetSelection, installCommands, preBuildCommands, kmsEncryption = false, completenessQueryInterval, exclude, file: dockerFile, cacheDisabled = false, buildLogGroup: buildLogGroupProp, platform = 'linux/amd64', provider: sharedProvider, ecrPullThroughCachePrefixes, retainBuildLogs = false, } = props;
107
115
  // Generate an ephemeral tag for CodeBuild
108
116
  const imageTag = crypto.randomUUID();
109
117
  // Optionally define a KMS key for ECR encryption if requested
@@ -265,6 +273,8 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
265
273
  'ecr:BatchGetImage',
266
274
  'ecr:GetDownloadUrlForLayer',
267
275
  'ecr:BatchCheckLayerAvailability',
276
+ 'ecr:BatchImportUpstreamImage',
277
+ 'ecr:CreateRepository',
268
278
  ],
269
279
  resources: ecrPullThroughCachePrefixes.map((prefix) => `arn:aws:ecr:${stack.region}:${stack.account}:repository/${prefix}/*`),
270
280
  }));
@@ -296,6 +306,14 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
296
306
  actions: ['codebuild:StartBuild'],
297
307
  resources: [codeBuildProject.projectArn],
298
308
  }));
309
+ onEventHandlerFunction.addToRolePolicy(new aws_iam_1.PolicyStatement({
310
+ actions: [
311
+ 'logs:CreateLogGroup',
312
+ 'logs:PutRetentionPolicy',
313
+ 'logs:DeleteLogGroup',
314
+ ],
315
+ resources: ['arn:aws:logs:*:*:log-group:/docker-builder/*'],
316
+ }));
299
317
  const isCompleteHandlerFunction = new aws_lambda_1.Function(this, 'IsCompleteHandlerFunction', {
300
318
  runtime: aws_lambda_1.Runtime.NODEJS_22_X,
301
319
  code: aws_lambda_1.Code.fromAsset(path.resolve(__dirname, '../isComplete')),
@@ -335,6 +353,7 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
335
353
  ProjectName: codeBuildProject.projectName,
336
354
  ImageTag: imageTag,
337
355
  Trigger: sourceAsset.assetHash,
356
+ RetainBuildLogs: retainBuildLogs ? 'true' : 'false',
338
357
  },
339
358
  });
340
359
  buildTriggerResource.node.addDependency(codeBuildProject);
@@ -348,5 +367,5 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
348
367
  }
349
368
  exports.TokenInjectableDockerBuilder = TokenInjectableDockerBuilder;
350
369
  _b = JSII_RTTI_SYMBOL_1;
351
- TokenInjectableDockerBuilder[_b] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.11.1" };
352
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpQ0FBaUM7QUFDakMseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUU3Qiw2Q0FBOEQ7QUFDOUQsNkRBQTRHO0FBRTVHLGlEQUFrRjtBQUNsRixpREFBcUQ7QUFDckQsaURBQXNEO0FBQ3RELGlEQUEwQztBQUMxQyx1REFBa0Y7QUFFbEYsNkRBQWtEO0FBQ2xELG1FQUF3RDtBQUN4RCwyQ0FBdUM7QUFFdkMsTUFBTSxxQkFBcUIsR0FBRyxzQ0FBc0MsQ0FBQztBQWNyRTs7Ozs7O0dBTUc7QUFDSCxNQUFhLG9DQUFxQyxTQUFRLHNCQUFTO0lBQ2pFOzs7O09BSUc7SUFDSSxNQUFNLENBQUMsV0FBVyxDQUFDLEtBQWdCLEVBQUUsS0FBaUQ7UUFDM0YsTUFBTSxLQUFLLEdBQUcsbUJBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMscUJBQXFCLENBQXFELENBQUM7UUFDcEgsSUFBSSxRQUFRO1lBQUUsT0FBTyxRQUFRLENBQUM7UUFDOUIsT0FBTyxJQUFJLG9DQUFvQyxDQUFDLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBUUQsWUFBb0IsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBaUQ7UUFDakcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsc0JBQXNCLEdBQUcsSUFBSSxxQkFBUSxDQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRTtZQUNqRSxPQUFPLEVBQUUsb0JBQU8sQ0FBQyxXQUFXO1lBQzVCLElBQUksRUFBRSxpQkFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxZQUFZLENBQUMs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V0FBVztnQkFDekMsUUFBUSxFQUFFLFFBQVE7Z0JBQ2xCLE9BQU8sRUFBRSxXQUFXLENBQUMsU0FBUzthQUMvQjtTQUNGLENBQUMsQ0FBQztRQUNILG9CQUFvQixDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUUxRCx5REFBeUQ7UUFDekQsTUFBTSxXQUFXLEdBQUcsb0JBQW9CLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxjQUFjLEdBQUcsd0JBQWMsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ3hGLElBQUksQ0FBQyxlQUFlLEdBQUcsNEJBQWUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUNqRSxXQUFXLEVBQUUsV0FBVztTQUN6QixDQUFDLENBQUM7SUFDTCxDQUFDOztBQWpVSCxvRUFrVUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjcnlwdG8gZnJvbSAnY3J5cHRvJztcbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7IEN1c3RvbVJlc291cmNlLCBEdXJhdGlvbiwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBQcm9qZWN0LCBTb3VyY2UsIExpbnV4QnVpbGRJbWFnZSwgTGludXhBcm1CdWlsZEltYWdlLCBCdWlsZFNwZWMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZWJ1aWxkJztcbmltcG9ydCB7IElWcGMsIElTZWN1cml0eUdyb3VwLCBTdWJuZXRTZWxlY3Rpb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IFJlcG9zaXRvcnksIFJlcG9zaXRvcnlFbmNyeXB0aW9uLCBUYWdTdGF0dXMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNyJztcbmltcG9ydCB7IENvbnRhaW5lckltYWdlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjcyc7XG5pbXBvcnQgeyBQb2xpY3lTdGF0ZW1lbnQgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IEtleSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1rbXMnO1xuaW1wb3J0IHsgUnVudGltZSwgQ29kZSwgRG9ja2VySW1hZ2VDb2RlLCBGdW5jdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0IHsgSUxvZ0dyb3VwIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWxvZ3MnO1xuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtczMtYXNzZXRzJztcbmltcG9ydCB7IFByb3ZpZGVyIH0gZnJvbSAnYXdzLWNkay1saWIvY3VzdG9tLXJlc291cmNlcyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuY29uc3QgUFJPVklERVJfU0lOR0xFVE9OX0lEID0gJ1Rva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJQcm92aWRlcic7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgY3JlYXRpbmcgYSBgVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBIb3cgb2Z0ZW4gdGhlIHByb3ZpZGVyIHBvbGxzIGZvciBidWlsZCBjb21wbGV0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBEdXJhdGlvbi5zZWNvbmRzKDMwKVxuICAgKi9cbiAgcmVhZG9ubHkgcXVlcnlJbnRlcnZhbD86IER1cmF0aW9uO1xufVxuXG4vKipcbiAqIFNoYXJlZCBwcm92aWRlciBmb3IgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGluc3RhbmNlcy5cbiAqXG4gKiBDcmVhdGVzIHRoZSBvbkV2ZW50IGFuZCBpc0NvbXBsZXRlIExhbWJkYSBmdW5jdGlvbnMgb25jZSBwZXIgc3RhY2suXG4gKiBFYWNoIGJ1aWxkZXIgaW5zdGFuY2UgcmVnaXN0ZXJzIGl0cyBDb2RlQnVpbGQgcHJvamVjdCBBUk4gc28gdGhlXG4gKiBzaGFyZWQgTGFtYmRhcyBoYXZlIHBlcm1pc3Npb24gdG8gc3RhcnQgYnVpbGRzIGFuZCByZWFkIGxvZ3MuXG4gKi9cbmV4cG9ydCBjbGFzcyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSB0aGUgc2luZ2xldG9uIHByb3ZpZGVyIGZvciB0aGlzIHN0YWNrLlxuICAgKiBBbGwgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGluc3RhbmNlcyBpbiB0aGUgc2FtZSBzdGFja1xuICAgKiBzaGFyZSBhIHNpbmdsZSBwYWlyIG9mIExhbWJkYSBmdW5jdGlvbnMuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGdldE9yQ3JlYXRlKHNjb3BlOiBDb25zdHJ1Y3QsIHByb3BzPzogVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyUHJvcHMpOiBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIge1xuICAgIGNvbnN0IHN0YWNrID0gU3RhY2sub2Yoc2NvcGUpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gc3RhY2subm9kZS50cnlGaW5kQ2hpbGQoUFJPVklERVJfU0lOR0xFVE9OX0lEKSBhcyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIgfCB1bmRlZmluZWQ7XG4gICAgaWYgKGV4aXN0aW5nKSByZXR1cm4gZXhpc3Rpbmc7XG4gICAgcmV0dXJuIG5ldyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIoc3RhY2ssIFBST1ZJREVSX1NJTkdMRVRPTl9JRCwgcHJvcHMpO1xuICB9XG5cbiAgLyoqIFRoZSBzZXJ2aWNlIHRva2VuIHVzZWQgYnkgQ3VzdG9tUmVzb3VyY2UgaW5zdGFuY2VzLiAqL1xuICBwdWJsaWMgcmVhZG9ubHkgc2VydmljZVRva2VuOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBvbkV2ZW50SGFuZGxlckZ1bmN0aW9uOiBGdW5jdGlvbjtcbiAgcHJpdmF0ZSByZWFkb25seSBpc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uOiBGdW5jdGlvbjtcblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5vbkV2ZW50SGFuZGxlckZ1bmN0aW9uID0gbmV3IEZ1bmN0aW9uKHRoaXMsICdPbkV2ZW50SGFuZGxlcicsIHtcbiAgICAgIHJ1bnRpbWU6IFJ1bnRpbWUuTk9ERUpTXzIyX1gsXG4gICAgICBjb2RlOiBDb2RlLmZyb21Bc3NldChwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnLi4vb25FdmVudCcpKSxcbiAgICAgIGhhbmRsZXI6ICdvbkV2ZW50LmhhbmRsZXInLFxuICAgICAgdGltZW91dDogRHVyYXRpb24ubWludXRlcygxNSksXG4gICAgfSk7XG5cbiAgICB0aGlzLmlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24gPSBuZXcgRnVuY3Rpb24odGhpcywgJ0lzQ29tcGxldGVIYW5kbGVyJywge1xuICAgICAgcnVudGltZTogUnVudGltZS5OT0RFSlNfMjJfWCxcbiAgICAgIGNvZGU6IENvZGUuZnJvbUFzc2V0KHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLi9pc0NvbXBsZXRlJykpLFxuICAgICAgaGFuZGxlcjogJ2lzQ29tcGxldGUuaGFuZGxlcicsXG4gICAgICB0aW1lb3V0OiBEdXJhdGlvbi5taW51dGVzKDE1KSxcbiAgICB9KTtcbiAgICB0aGlzLmlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24uYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFtcbiAgICAgICAgICAnY29kZWJ1aWxkOkJhdGNoR2V0QnVpbGRzJyxcbiAgICAgICAgICAnY29kZWJ1aWxkOkxpc3RCdWlsZHNGb3JQcm9qZWN0JyxcbiAgICAgICAgICAnbG9nczpHZXRMb2dFdmVudHMnLFxuICAgICAgICAgICdsb2dzOkRlc2NyaWJlTG9nU3RyZWFtcycsXG4gICAgICAgICAgJ2xvZ3M6RGVzY3JpYmVMb2dHcm91cHMnLFxuICAgICAgICBdLFxuICAgICAgICByZXNvdXJjZXM6IFsnKiddLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIGNvbnN0IHByb3ZpZGVyID0gbmV3IFByb3ZpZGVyKHRoaXMsICdQcm92aWRlcicsIHtcbiAgICAgIG9uRXZlbnRIYW5kbGVyOiB0aGlzLm9uRXZlbnRIYW5kbGVyRnVuY3Rpb24sXG4gICAgICBpc0NvbXBsZXRlSGFuZGxlcjogdGhpcy5pc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uLFxuICAgICAgcXVlcnlJbnRlcnZhbDogcHJvcHM/LnF1ZXJ5SW50ZXJ2YWwgPz8gRHVyYXRpb24uc2Vjb25kcygzMCksXG4gICAgfSk7XG5cbiAgICB0aGlzLnNlcnZpY2VUb2tlbiA9IHByb3ZpZGVyLnNlcnZpY2VUb2tlbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBHcmFudCB0aGUgc2hhcmVkIExhbWJkYXMgcGVybWlzc2lvbiB0byBzdGFydCBidWlsZHMgZm9yIGEgc3BlY2lmaWNcbiAgICogQ29kZUJ1aWxkIHByb2plY3QgYW5kIHB1bGwvcHVzaCB0byBpdHMgRUNSIHJlcG9zaXRvcnkuXG4gICAqL1xuICBwdWJsaWMgcmVnaXN0ZXJQcm9qZWN0KHByb2plY3Q6IFByb2plY3QsIGVjclJlcG86IFJlcG9zaXRvcnksIGVuY3J5cHRpb25LZXk/OiBLZXkpOiB2b2lkIHtcbiAgICB0aGlzLm9uRXZlbnRIYW5kbGVyRnVuY3Rpb24uYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFsnY29kZWJ1aWxkOlN0YXJ0QnVpbGQnXSxcbiAgICAgICAgcmVzb3VyY2VzOiBbcHJvamVjdC5wcm9qZWN0QXJuXSxcbiAgICAgIH0pLFxuICAgICk7XG4gICAgZWNyUmVwby5ncmFudFB1bGxQdXNoKHRoaXMub25FdmVudEhhbmRsZXJGdW5jdGlvbik7XG4gICAgZWNyUmVwby5ncmFudFB1bGxQdXNoKHRoaXMuaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbik7XG5cbiAgICBpZiAoZW5jcnlwdGlvbktleSkge1xuICAgICAgZW5jcnlwdGlvbktleS5ncmFudEVuY3J5cHREZWNyeXB0KHRoaXMub25FdmVudEhhbmRsZXJGdW5jdGlvbik7XG4gICAgICBlbmNyeXB0aW9uS2V5LmdyYW50RW5jcnlwdERlY3J5cHQodGhpcy5pc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciB0aGUgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGNvbnN0cnVjdC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvcHMge1xuICAvKipcbiAgICogVGhlIHBhdGggdG8gdGhlIGRpcmVjdG9yeSBjb250YWluaW5nIHRoZSBEb2NrZXJmaWxlIG9yIHNvdXJjZSBjb2RlLlxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBCdWlsZCBhcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgRG9ja2VyIGJ1aWxkIHByb2Nlc3MuXG4gICAqIFRoZXNlIGFyZSB0cmFuc2Zvcm1lZCBpbnRvIGAtLWJ1aWxkLWFyZyBLRVk9VkFMVUVgIGZsYWdzLlxuICAgKiBAZXhhbXBsZVxuICAgKiB7XG4gICAqICAgVE9LRU46ICdteS1zZWNyZXQtdG9rZW4nLFxuICAgKiAgIEVOVjogJ3Byb2R1Y3Rpb24nXG4gICAqIH1cbiAgICovXG4gIHJlYWRvbmx5IGJ1aWxkQXJncz86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG5cbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIEFXUyBTZWNyZXRzIE1hbmFnZXIgc2VjcmV0IGNvbnRhaW5pbmcgRG9ja2VyIGxvZ2luIGNyZWRlbnRpYWxzLlxuICAgKiBUaGlzIHNlY3JldCBzaG91bGQgc3RvcmUgYSBKU09OIG9iamVjdCB3aXRoIHRoZSBmb2xsb3dpbmcgc3RydWN0dXJlOlxuICAgKiBgYGBqc29uXG4gICAqIHtcbiAgICogICBcInVzZXJuYW1lXCI6IFwibXktZG9ja2VyLXVzZXJuYW1lXCIsXG4gICAqICAgXCJwYXNzd29yZFwiOiBcIm15LWRvY2tlci1wYXNzd29yZFwiXG4gICAqIH1cbiAgICogYGBgXG4gICAqIElmIG5vdCBwcm92aWRlZCAob3Igbm90IG5lZWRlZCksIHRoZSBjb25zdHJ1Y3Qgd2lsbCBza2lwIERvY2tlciBIdWIgbG9naW4uXG4gICAqXG4gICAqICoqTm90ZSoqOiBUaGUgc2VjcmV0IG11c3QgYmUgaW4gdGhlIHNhbWUgcmVnaW9uIGFzIHRoZSBzdGFjay5cbiAgICpcbiAgICogQGV4YW1wbGUgJ2Fybjphd3M6c2VjcmV0c21hbmFnZXI6dXMtZWFzdC0xOjEyMzQ1Njc4OTAxMjpzZWNyZXQ6RG9ja2VyTG9naW5TZWNyZXQnXG4gICAqL1xuICByZWFkb25seSBkb2NrZXJMb2dpblNlY3JldEFybj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIFZQQyBpbiB3aGljaCB0aGUgQ29kZUJ1aWxkIHByb2plY3Qgd2lsbCBiZSBkZXBsb3llZC5cbiAgICogSWYgcHJvdmlkZWQsIHRoZSBDb2RlQnVpbGQgcHJvamVjdCB3aWxsIGJlIGxhdW5jaGVkIHdpdGhpbiB0aGUgc3BlY2lmaWVkIFZQQy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBWUEMgaXMgYXR0YWNoZWQsIGFuZCB0aGUgQ29kZUJ1aWxkIHByb2plY3Qgd2lsbCB1c2UgcHVibGljIGludGVybmV0LlxuICAgKi9cbiAgcmVhZG9ubHkgdnBjPzogSVZwYztcblxuICAvKipcbiAgICogVGhlIHNlY3VyaXR5IGdyb3VwcyB0byBhdHRhY2ggdG8gdGhlIENvZGVCdWlsZCBwcm9qZWN0LlxuICAgKiBUaGVzZSBkZWZpbmUgdGhlIG5ldHdvcmsgYWNjZXNzIHJ1bGVzIGZvciB0aGUgQ29kZUJ1aWxkIHByb2plY3QuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gc2VjdXJpdHkgZ3JvdXBzIGFyZSBhdHRhY2hlZC5cbiAgICovXG4gIHJlYWRvbmx5IHNlY3VyaXR5R3JvdXBzPzogSVNlY3VyaXR5R3JvdXBbXTtcblxuICAvKipcbiAgICogVGhlIHN1Ym5ldCBzZWxlY3Rpb24gdG8gc3BlY2lmeSB3aGljaCBzdWJuZXRzIHRvIHVzZSB3aXRoaW4gdGhlIFZQQy5cbiAgICogQWxsb3dzIHRoZSB1c2VyIHRvIHNlbGVjdCBwcml2YXRlLCBwdWJsaWMsIG9yIGlzb2xhdGVkIHN1Ym5ldHMuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQWxsIHN1Ym5ldHMgaW4gdGhlIFZQQyBhcmUgdXNlZC5cbiAgICovXG4gIHJlYWRvbmx5IHN1Ym5ldFNlbGVjdGlvbj86IFN1Ym5ldFNlbGVjdGlvbjtcblxuICAvKipcbiAgICogQ3VzdG9tIGNvbW1hbmRzIHRvIHJ1biBkdXJpbmcgdGhlIGluc3RhbGwgcGhhc2Ugb2YgQ29kZUJ1aWxkLlxuICAgKlxuICAgKiAqKkV4YW1wbGUqKjpcbiAgICogYGBgdHNcbiAgICogaW5zdGFsbENvbW1hbmRzOiBbXG4gICAqICAgJ2VjaG8gXCJVcGRhdGluZyBwYWNrYWdlIGxpc3RzLi4uXCInLFxuICAgKiAgICdhcHQtZ2V0IHVwZGF0ZSAteScsXG4gICAqICAgJ2VjaG8gXCJJbnN0YWxsaW5nIHJlcXVpcmVkIHBhY2thZ2VzLi4uXCInLFxuICAgKiAgICdhcHQtZ2V0IGluc3RhbGwgLXkgY3VybCBkbnN1dGlscycsXG4gICAqIF0sXG4gICAqIGBgYFxuICAgKiBAZGVmYXVsdCAtIE5vIGFkZGl0aW9uYWwgaW5zdGFsbCBjb21tYW5kcy5cbiAgICovXG4gIHJlYWRvbmx5IGluc3RhbGxDb21tYW5kcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBDdXN0b20gY29tbWFuZHMgdG8gcnVuIGR1cmluZyB0aGUgcHJlX2J1aWxkIHBoYXNlIG9mIENvZGVCdWlsZC5cbiAgICpcbiAgICogKipFeGFtcGxlKio6XG4gICAqIGBgYHRzXG4gICAqIHByZUJ1aWxkQ29tbWFuZHM6IFtcbiAgICogICAnZWNobyBcIkZldGNoaW5nIGNvbmZpZ3VyYXRpb24gZnJvbSBwcml2YXRlIEFQSS4uLlwiJyxcbiAgICogICAnY3VybCAtbyBjb25maWcuanNvbiBodHRwczovL2FwaS5leGFtcGxlLmNvbS9jb25maWcnLFxuICAgKiBdLFxuICAgKiBgYGBcbiAgICogQGRlZmF1bHQgLSBObyBhZGRpdGlvbmFsIHByZS1idWlsZCBjb21tYW5kcy5cbiAgICovXG4gIHJlYWRvbmx5IHByZUJ1aWxkQ29tbWFuZHM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogV2hldGhlciB0byBlbmFibGUgS01TIGVuY3J5cHRpb24gZm9yIHRoZSBFQ1IgcmVwb3NpdG9yeS5cbiAgICogSWYgYHRydWVgLCBhIEtNUyBrZXkgd2lsbCBiZSBjcmVhdGVkIGZvciBlbmNyeXB0aW5nIEVDUiBpbWFnZXMuXG4gICAqIElmIGBmYWxzZWAsIHRoZSByZXBvc2l0b3J5IHdpbGwgdXNlIEFFUy0yNTYgZW5jcnlwdGlvbi5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkga21zRW5jcnlwdGlvbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBxdWVyeSBpbnRlcnZhbCBmb3IgY2hlY2tpbmcgaWYgdGhlIENvZGVCdWlsZCBwcm9qZWN0IGhhcyBjb21wbGV0ZWQuXG4gICAqIFRoaXMgZGV0ZXJtaW5lcyBob3cgZnJlcXVlbnRseSB0aGUgY3VzdG9tIHJlc291cmNlIHBvbGxzIGZvciBidWlsZCBjb21wbGV0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIER1cmF0aW9uLnNlY29uZHMoMzApXG4gICAqL1xuICByZWFkb25seSBjb21wbGV0ZW5lc3NRdWVyeUludGVydmFsPzogRHVyYXRpb247XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBmaWxlIHBhdGhzIGluIHRoZSBEb2NrZXIgZGlyZWN0b3J5IHRvIGV4Y2x1ZGUgZnJvbSBidWlsZC5cbiAgICogV2lsbCB1c2UgcGF0aHMgaW4gLmRvY2tlcmlnbm9yZSBmaWxlIGlmIHByZXNlbnQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gZmlsZSBwYXRoIGV4Y2x1c2lvbnNcbiAgICovXG4gIHJlYWRvbmx5IGV4Y2x1ZGU/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIERvY2tlcmZpbGUgdG8gdXNlIGZvciB0aGUgYnVpbGQuXG4gICAqIFBhc3NlZCBhcyBgLS1maWxlYCB0byBgZG9ja2VyIGJ1aWxkYC5cbiAgICpcbiAgICogQGV4YW1wbGUgJ0RvY2tlcmZpbGUucHJvZHVjdGlvbidcbiAgICogQGRlZmF1bHQgJ0RvY2tlcmZpbGUnXG4gICAqL1xuICByZWFkb25seSBmaWxlPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGVuIGB0cnVlYCwgZGlzYWJsZXMgRG9ja2VyIGxheWVyIGNhY2hpbmcuIEV2ZXJ5IGJ1aWxkIHJ1bnMgZnJvbSBzY3JhdGNoLlxuICAgKiBVc2UgZm9yIGRlYnVnZ2luZywgY29ycnVwdGVkIGNhY2hlLCBvciBtYWpvciBkZXBlbmRlbmN5IGNoYW5nZXMuXG4gICAqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBjYWNoZURpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQ2xvdWRXYXRjaCBsb2cgZ3JvdXAgZm9yIENvZGVCdWlsZCBidWlsZCBsb2dzLlxuICAgKiBXaGVuIHByb3ZpZGVkIHdpdGggYSBSRVRBSU4gcmVtb3ZhbCBwb2xpY3ksIGJ1aWxkIGxvZ3Mgc3Vydml2ZSByb2xsYmFja3NcbiAgICogYW5kIHN0YWNrIGRlbGV0aW9uIGZvciBkZWJ1Z2dpbmcuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ29kZUJ1aWxkIGRlZmF1bHQgbG9nZ2luZyAobG9ncyBhcmUgZGVsZXRlZCBvbiByb2xsYmFjaylcbiAgICovXG4gIHJlYWRvbmx5IGJ1aWxkTG9nR3JvdXA/OiBJTG9nR3JvdXA7XG5cbiAgLyoqXG4gICAqIFRhcmdldCBwbGF0Zm9ybSBmb3IgdGhlIERvY2tlciBpbWFnZS5cbiAgICpcbiAgICogV2hlbiBzZXQgdG8gYCdsaW51eC9hcm02NCdgLCB0aGUgY29uc3RydWN0IHVzZXMgYSBuYXRpdmUgQVJNL0dyYXZpdG9uXG4gICAqIENvZGVCdWlsZCBpbnN0YW5jZSBmb3IgZmFzdCBidWlsZHMgd2l0aG91dCBlbXVsYXRpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0ICdsaW51eC9hbWQ2NCdcbiAgICovXG4gIHJlYWRvbmx5IHBsYXRmb3JtPzogJ2xpbnV4L2FtZDY0JyB8ICdsaW51eC9hcm02NCc7XG5cbiAgLyoqXG4gICAqIFNoYXJlZCBwcm92aWRlciBmb3IgdGhlIGN1c3RvbSByZXNvdXJjZSBMYW1iZGFzLlxuICAgKiBVc2UgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJQcm92aWRlci5nZXRPckNyZWF0ZSh0aGlzKWAgdG8gY3JlYXRlXG4gICAqIGEgc2luZ2xldG9uIHRoYXQgaXMgc2hhcmVkIGFjcm9zcyBhbGwgYnVpbGRlcnMgaW4gdGhlIHNhbWUgc3RhY2suXG4gICAqXG4gICAqIFdoZW4gb21pdHRlZCwgZWFjaCBidWlsZGVyIGNyZWF0ZXMgaXRzIG93biBMYW1iZGFzIChvcmlnaW5hbCBiZWhhdmlvcikuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQSBuZXcgcHJvdmlkZXIgaXMgY3JlYXRlZCBwZXIgYnVpbGRlciBpbnN0YW5jZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvdmlkZXI/OiBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXI7XG5cbiAgLyoqXG4gICAqIEVDUiBwdWxsLXRocm91Z2ggY2FjaGUgcmVwb3NpdG9yeSBwcmVmaXhlcyB0byBncmFudCBwdWxsIGFjY2VzcyB0by5cbiAgICogVXNlIHdoZW4geW91ciBEb2NrZXJmaWxlIHJlZmVyZW5jZXMgYmFzZSBpbWFnZXMgZnJvbSBFQ1IgcHVsbC10aHJvdWdoXG4gICAqIGNhY2hlIChlLmcuIGRvY2tlci1odWIvbGlicmFyeS9ub2RlOjIwLXNsaW0sIGdoY3Ivb3JnL2ltYWdlOnRhZykuXG4gICAqIFRoZSBDb2RlQnVpbGQgcm9sZSB3aWxsIGJlIGdyYW50ZWQgZWNyOkJhdGNoR2V0SW1hZ2UsIGVjcjpHZXREb3dubG9hZFVybEZvckxheWVyLFxuICAgKiBhbmQgZWNyOkJhdGNoQ2hlY2tMYXllckF2YWlsYWJpbGl0eSBvbiByZXBvc2l0b3JpZXMgbWF0Y2hpbmcgZWFjaCBwcmVmaXguXG4gICAqXG4gICAqIEBleGFtcGxlIFsnZG9ja2VyLWh1YicsICdnaGNyJ11cbiAgICogQGRlZmF1bHQgLSBObyBwdWxsLXRocm91Z2ggY2FjaGUgYWNjZXNzXG4gICAqL1xuICByZWFkb25seSBlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXM/OiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBBIENESyBjb25zdHJ1Y3QgdG8gYnVpbGQgYW5kIHB1c2ggRG9ja2VyIGltYWdlcyB0byBhbiBFQ1IgcmVwb3NpdG9yeSB1c2luZ1xuICogQ29kZUJ1aWxkIGFuZCBMYW1iZGEgY3VzdG9tIHJlc291cmNlcywgKip0aGVuKiogcmV0cmlldmUgdGhlIGZpbmFsIGltYWdlIHRhZ1xuICogc28gdGhhdCBFQ1MvTGFtYmRhIHJlZmVyZW5jZXMgdXNlIHRoZSBleGFjdCBkaWdlc3QuXG4gKi9cbmV4cG9ydCBjbGFzcyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFRoZSBFQ1IgcmVwb3NpdG9yeSB0aGF0IHN0b3JlcyB0aGUgcmVzdWx0aW5nIERvY2tlciBpbWFnZS5cbiAgICovXG4gIHByaXZhdGUgcmVhZG9ubHkgZWNyUmVwb3NpdG9yeTogUmVwb3NpdG9yeTtcblxuICAvKipcbiAgICogQW4gRUNTLWNvbXBhdGlibGUgY29udGFpbmVyIGltYWdlIHJlZmVyZW5jaW5nIHRoZSB0YWdcbiAgICogb2YgdGhlIGJ1aWx0IERvY2tlciBpbWFnZS5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBjb250YWluZXJJbWFnZTogQ29udGFpbmVySW1hZ2U7XG5cbiAgLyoqXG4gICAqIEEgTGFtYmRhLWNvbXBhdGlibGUgRG9ja2VySW1hZ2VDb2RlIHJlZmVyZW5jaW5nIHRoZSB0YWdcbiAgICogb2YgdGhlIGJ1aWx0IERvY2tlciBpbWFnZS5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBkb2NrZXJJbWFnZUNvZGU6IERvY2tlckltYWdlQ29kZTtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBgVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlcmAuXG4gICAqXG4gICAqIEBwYXJhbSBzY29wZSBUaGUgc2NvcGUgaW4gd2hpY2ggdG8gZGVmaW5lIHRoaXMgY29uc3RydWN0LlxuICAgKiBAcGFyYW0gaWQgVGhlIHNjb3BlZCBjb25zdHJ1Y3QgSUQuXG4gICAqIEBwYXJhbSBwcm9wcyBDb25maWd1cmF0aW9uIGZvciBidWlsZGluZyBhbmQgcHVzaGluZyB0aGUgRG9ja2VyIGltYWdlLlxuICAgKi9cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBjb25zdCB7XG4gICAgICBwYXRoOiBzb3VyY2VQYXRoLFxuICAgICAgYnVpbGRBcmdzLFxuICAgICAgZG9ja2VyTG9naW5TZWNyZXRBcm4sXG4gICAgICB2cGMsXG4gICAgICBzZWN1cml0eUdyb3VwcyxcbiAgICAgIHN1Ym5ldFNlbGVjdGlvbixcbiAgICAgIGluc3RhbGxDb21tYW5kcyxcbiAgICAgIHByZUJ1aWxkQ29tbWFuZHMsXG4gICAgICBrbXNFbmNyeXB0aW9uID0gZmFsc2UsXG4gICAgICBjb21wbGV0ZW5lc3NRdWVyeUludGVydmFsLFxuICAgICAgZXhjbHVkZSxcbiAgICAgIGZpbGU6IGRvY2tlckZpbGUsXG4gICAgICBjYWNoZURpc2FibGVkID0gZmFsc2UsXG4gICAgICBidWlsZExvZ0dyb3VwOiBidWlsZExvZ0dyb3VwUHJvcCxcbiAgICAgIHBsYXRmb3JtID0gJ2xpbnV4L2FtZDY0JyxcbiAgICAgIHByb3ZpZGVyOiBzaGFyZWRQcm92aWRlcixcbiAgICAgIGVjclB1bGxUaHJvdWdoQ2FjaGVQcmVmaXhlcyxcbiAgICB9ID0gcHJvcHM7XG5cbiAgICAvLyBHZW5lcmF0ZSBhbiBlcGhlbWVyYWwgdGFnIGZvciBDb2RlQnVpbGRcbiAgICBjb25zdCBpbWFnZVRhZyA9IGNyeXB0by5yYW5kb21VVUlEKCk7XG5cbiAgICAvLyBPcHRpb25hbGx5IGRlZmluZSBhIEtNUyBrZXkgZm9yIEVDUiBlbmNyeXB0aW9uIGlmIHJlcXVlc3RlZFxuICAgIGxldCBlbmNyeXB0aW9uS2V5OiBLZXkgfCB1bmRlZmluZWQ7XG4gICAgaWYgKGttc0VuY3J5cHRpb24pIHtcbiAgICAgIGVuY3J5cHRpb25LZXkgPSBuZXcgS2V5KHRoaXMsICdFY3JFbmNyeXB0aW9uS2V5Jywge1xuICAgICAgICBlbmFibGVLZXlSb3RhdGlvbjogdHJ1ZSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIENyZWF0ZSBhbiBFQ1IgcmVwb3NpdG9yeSAob3B0aW9uYWxseSB3aXRoIEtNUyBlbmNyeXB0aW9uKVxuICAgIHRoaXMuZWNyUmVwb3NpdG9yeSA9IG5ldyBSZXBvc2l0b3J5KHRoaXMsICdFQ1JSZXBvc2l0b3J5Jywge1xuICAgICAgbGlmZWN5Y2xlUnVsZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHJ1bGVQcmlvcml0eTogMSxcbiAgICAgICAgICBkZXNjcmlwdGlvbjogJ1JlbW92ZSB1bnRhZ2dlZCBpbWFnZXMgYWZ0ZXIgMSBkYXknLFxuICAgICAgICAgIHRhZ1N0YXR1czogVGFnU3RhdHVzLlVOVEFHR0VELFxuICAgICAgICAgIG1heEltYWdlQWdlOiBEdXJhdGlvbi5kYXlzKDEpLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGVuY3J5cHRpb246IGttc0VuY3J5cHRpb24gPyBSZXBvc2l0b3J5RW5jcnlwdGlvbi5LTVMgOiBSZXBvc2l0b3J5RW5jcnlwdGlvbi5BRVNfMjU2LFxuICAgICAgZW5jcnlwdGlvbktleToga21zRW5jcnlwdGlvbiA/IGVuY3J5cHRpb25LZXkgOiB1bmRlZmluZWQsXG4gICAgICBpbWFnZVNjYW5PblB1c2g6IHRydWUsXG4gICAgfSk7XG5cbiAgICBsZXQgZWZmZWN0aXZlRXhjbHVkZSA9IGV4Y2x1ZGU7XG4gICAgaWYgKCFlZmZlY3RpdmVFeGNsdWRlKSB7XG4gICAgICBjb25zdCBkb2NrZXJpZ25vcmVQYXRoID0gcGF0aC5qb2luKHNvdXJjZVBhdGgsICcuZG9ja2VyaWdub3JlJyk7XG4gICAgICBpZiAoZnMuZXhpc3RzU3luYyhkb2NrZXJpZ25vcmVQYXRoKSkge1xuICAgICAgICBjb25zdCBmaWxlQ29udGVudCA9IGZzLnJlYWRGaWxlU3luYyhkb2NrZXJpZ25vcmVQYXRoLCAndXRmOCcpO1xuICAgICAgICBlZmZlY3RpdmVFeGNsdWRlID0gZmlsZUNvbnRlbnRcbiAgICAgICAgICAuc3BsaXQoJ1xcbicpXG4gICAgICAgICAgLm1hcCgobGluZTogc3RyaW5nKSA9PiBsaW5lLnRyaW0oKSlcbiAgICAgICAgICAuZmlsdGVyKChsaW5lOiBzdHJpbmcpID0+IGxpbmUubGVuZ3RoID4gMCAmJiAhbGluZS5zdGFydHNXaXRoKCcjJykpO1xuICAgICAgfVxuICAgIH1cblxuICAgIC8vIEVuc3VyZSB0aGUgdGFyZ2V0IERvY2tlcmZpbGUgaXMgbmV2ZXIgZXhjbHVkZWQgKGhhbmRsZXMgZ2xvYnMgbGlrZSBcIkRvY2tlcmZpbGUqXCIpXG4gICAgY29uc3QgZG9ja2VyRmlsZU5hbWUgPSBkb2NrZXJGaWxlID8/ICdEb2NrZXJmaWxlJztcbiAgICBpZiAoZWZmZWN0aXZlRXhjbHVkZSkge1xuICAgICAgZWZmZWN0aXZlRXhjbHVkZSA9IGVmZmVjdGl2ZUV4Y2x1ZGUuZmlsdGVyKChwYXR0ZXJuOiBzdHJpbmcpID0+IHtcbiAgICAgICAgY29uc3QgZXNjYXBlZCA9IHBhdHRlcm4ucmVwbGFjZSgvWy4rXiR7fSgpfFtcXF1cXFxcXS9nLCAnXFxcXCQmJyk7XG4gICAgICAgIGNvbnN0IHJlZ2V4ID0gbmV3IFJlZ0V4cChgXiR7ZXNjYXBlZC5yZXBsYWNlKC9cXCovZywgJy4qJykucmVwbGFjZSgvXFw/L2csICcuJyl9JGAsICdpJyk7XG4gICAgICAgIHJldHVybiAhcmVnZXgudGVzdChkb2NrZXJGaWxlTmFtZSk7XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBXcmFwIHRoZSBzb3VyY2UgZm9sZGVyIGFzIGFuIFMzIGFzc2V0IGZvciBDb2RlQnVpbGQgdG8gdXNlXG4gICAgY29uc3Qgc291cmNlQXNzZXQgPSBuZXcgQXNzZXQodGhpcywgJ1NvdXJjZUFzc2V0Jywge1xuICAgICAgcGF0aDogc291cmNlUGF0aCxcbiAgICAgIGV4Y2x1ZGU6IGVmZmVjdGl2ZUV4Y2x1ZGUsXG4gICAgfSk7XG5cbiAgICAvLyBDb252ZXJ0IGJ1aWxkQXJncyB0byBhIENMSS1mcmllbmRseSBzdHJpbmdcbiAgICBjb25zdCBidWlsZEFyZ3NTdHJpbmcgPSBidWlsZEFyZ3NcbiAgICAgID8gT2JqZWN0LmVudHJpZXMoYnVpbGRBcmdzKVxuICAgICAgICAubWFwKChbaywgdl0pID0+IGAtLWJ1aWxkLWFyZyAke2t9PSR7dn1gKVxuICAgICAgICAuam9pbignICcpXG4gICAgICA6ICcnO1xuXG4gICAgY29uc3QgZG9ja2VyRmlsZUZsYWcgPSBkb2NrZXJGaWxlID8gYC1mICRDT0RFQlVJTERfU1JDX0RJUi8ke2RvY2tlckZpbGV9YCA6ICcnO1xuXG4gICAgLy8gT3B0aW9uYWwgRG9ja2VySHViIGxvZ2luLCBpZiBhIHNlY3JldCBBUk4gaXMgcHJvdmlkZWRcbiAgICBjb25zdCBkb2NrZXJMb2dpbkNvbW1hbmRzID0gZG9ja2VyTG9naW5TZWNyZXRBcm5cbiAgICAgID8gW1xuICAgICAgICAnZWNobyBcIlJldHJpZXZpbmcgRG9ja2VyIGNyZWRlbnRpYWxzLi4uXCInLFxuICAgICAgICAnYXB0LWdldCB1cGRhdGUgLXkgJiYgYXB0LWdldCBpbnN0YWxsIC15IGpxJyxcbiAgICAgICAgYERPQ0tFUl9VU0VSTkFNRT0kKGF3cyBzZWNyZXRzbWFuYWdlciBnZXQtc2VjcmV0LXZhbHVlIC0tc2VjcmV0LWlkICR7ZG9ja2VyTG9naW5TZWNyZXRBcm59IC0tcXVlcnkgU2VjcmV0U3RyaW5nIC0tb3V0cHV0IHRleHQgfCBqcSAtciAudXNlcm5hbWUpYCxcbiAgICAgICAgYERPQ0tFUl9QQVNTV09SRD0kKGF3cyBzZWNyZXRzbWFuYWdlciBnZXQtc2VjcmV0LXZhbHVlIC0tc2VjcmV0LWlkICR7ZG9ja2VyTG9naW5TZWNyZXRBcm59IC0tcXVlcnkgU2VjcmV0U3RyaW5nIC0tb3V0cHV0IHRleHQgfCBqcSAtciAucGFzc3dvcmQpYCxcbiAgICAgICAgJ2VjaG8gXCJMb2dnaW5nIGluIHRvIERvY2tlciBIdWIuLi5cIicsXG4gICAgICAgICdlY2hvICRET0NLRVJfUEFTU1dPUkQgfCBkb2NrZXIgbG9naW4gLS11c2VybmFtZSAkRE9DS0VSX1VTRVJOQU1FIC0tcGFzc3dvcmQtc3RkaW4nLFxuICAgICAgXVxuICAgICAgOiBbJ2VjaG8gXCJObyBEb2NrZXIgY3JlZGVudGlhbHMuIFNraXBwaW5nIERvY2tlciBIdWIgbG9naW4uXCInXTtcblxuICAgIGNvbnN0IGJ1aWxkeEluc3RhbGxDb21tYW5kcyA9IGNhY2hlRGlzYWJsZWRcbiAgICAgID8gW11cbiAgICAgIDogW1xuICAgICAgICAnZWNobyBcIlNldHRpbmcgdXAgRG9ja2VyIGJ1aWxkeCBmb3IgRUNSIGxheWVyIGNhY2hlLi4uXCInLFxuICAgICAgICAnZG9ja2VyIGJ1aWxkeCBjcmVhdGUgLS1kcml2ZXIgZG9ja2VyLWNvbnRhaW5lciAtLW5hbWUgZWNyLWNhY2hlLWJ1aWxkZXIgLS11c2UgMj4vZGV2L251bGwgfHwgZG9ja2VyIGJ1aWxkeCB1c2UgZWNyLWNhY2hlLWJ1aWxkZXInLFxuICAgICAgXTtcblxuICAgIGNvbnN0IHBsYXRmb3JtRmxhZyA9IGAtLXBsYXRmb3JtICR7cGxhdGZvcm19YDtcblxuICAgIC8vIC0tcHJvdmVuYW5jZT1mYWxzZSAtLXNib209ZmFsc2U6IERvY2tlciBCdWlsZHggdjAuMTArIGFkZHMgYXR0ZXN0YXRpb25zIGJ5IGRlZmF1bHQsXG4gICAgLy8gcHJvZHVjaW5nIE9DSSBpbWFnZSBpbmRleGVzIHRoYXQgQVdTIExhbWJkYSBkb2VzIG5vdCBzdXBwb3J0LiBEaXNhYmxlIHRoZW0gZm9yIExhbWJkYS9FQ1MgY29tcGF0aWJpbGl0eS5cbiAgICBjb25zdCBidWlsZENvbW1hbmQgPSBjYWNoZURpc2FibGVkXG4gICAgICA/IGBkb2NrZXIgYnVpbGQgJHtwbGF0Zm9ybUZsYWd9ICR7ZG9ja2VyRmlsZUZsYWd9ICR7YnVpbGRBcmdzU3RyaW5nfSAtdCAkRUNSX1JFUE9fVVJJOiR7aW1hZ2VUYWd9ICRDT0RFQlVJTERfU1JDX0RJUmBcbiAgICAgIDogYGRvY2tlciBidWlsZHggYnVpbGQgLS1wdXNoICR7cGxhdGZvcm1GbGFnfSAtLXByb3ZlbmFuY2U9ZmFsc2UgLS1zYm9tPWZhbHNlIC0tY2FjaGUtZnJvbSB0eXBlPXJlZ2lzdHJ5LHJlZj0kRUNSX1JFUE9fVVJJOmNhY2hlIC0tY2FjaGUtdG8gdHlwZT1yZWdpc3RyeSxyZWY9JEVDUl9SRVBPX1VSSTpjYWNoZSxtb2RlPW1heCxpbWFnZS1tYW5pZmVzdD10cnVlICR7ZG9ja2VyRmlsZUZsYWd9ICR7YnVpbGRBcmdzU3RyaW5nfSAtdCAkRUNSX1JFUE9fVVJJOiR7aW1hZ2VUYWd9ICRDT0RFQlVJTERfU1JDX0RJUmA7XG5cbiAgICBjb25zdCBidWlsZFNwZWNPYmogPSB7XG4gICAgICB2ZXJzaW9uOiAnMC4yJyxcbiAgICAgIHBoYXNlczoge1xuICAgICAgICBpbnN0YWxsOiB7XG4gICAgICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgICAgICdlY2hvIFwiQmVnaW5uaW5nIGluc3RhbGwgcGhhc2UuLi5cIicsXG4gICAgICAgICAgICAuLi4oaW5zdGFsbENvbW1hbmRzID8/IFtdKSxcbiAgICAgICAgICAgIC4uLmJ1aWxkeEluc3RhbGxDb21tYW5kcyxcbiAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgICAgICBwcmVfYnVpbGQ6IHtcbiAgICAgICAgICBjb21tYW5kczogW1xuICAgICAgICAgICAgLi4uKHByZUJ1aWxkQ29tbWFuZHMgPz8gW10pLFxuICAgICAgICAgICAgLi4uZG9ja2VyTG9naW5Db21tYW5kcyxcbiAgICAgICAgICAgICdlY2hvIFwiUmV0cmlldmluZyBBV1MgQWNjb3VudCBJRC4uLlwiJyxcbiAgICAgICAgICAgICdleHBvcnQgQUNDT1VOVF9JRD0kKGF3cyBzdHMgZ2V0LWNhbGxlci1pZGVudGl0eSAtLXF1ZXJ5IEFjY291bnQgLS1vdXRwdXQgdGV4dCknLFxuICAgICAgICAgICAgJ2VjaG8gXCJMb2dnaW5nIGludG8gQW1hem9uIEVDUi4uLlwiJyxcbiAgICAgICAgICAgICdhd3MgZWNyIGdldC1sb2dpbi1wYXNzd29yZCAtLXJlZ2lvbiAkQVdTX0RFRkFVTFRfUkVHSU9OIHwgZG9ja2VyIGxvZ2luIC0tdXNlcm5hbWUgQVdTIC0tcGFzc3dvcmQtc3RkaW4gJEFDQ09VTlRfSUQuZGtyLmVjci4kQVdTX0RFRkFVTFRfUkVHSU9OLmFtYXpvbmF3cy5jb20nLFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICAgIGJ1aWxkOiB7XG4gICAgICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgICAgIGBlY2hvIFwiQnVpbGRpbmcgRG9ja2VyIGltYWdlIHdpdGggdGFnICR7aW1hZ2VUYWd9Li4uXCJgLFxuICAgICAgICAgICAgYnVpbGRDb21tYW5kLFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICAgIC4uLihjYWNoZURpc2FibGVkICYmIHtcbiAgICAgICAgICBwb3N0X2J1aWxkOiB7XG4gICAgICAgICAgICBjb21tYW5kczogW1xuICAgICAgICAgICAgICBgZWNobyBcIlB1c2hpbmcgRG9ja2VyIGltYWdlIHdpdGggdGFnICR7aW1hZ2VUYWd9Li4uXCJgLFxuICAgICAgICAgICAgICBgZG9ja2VyIHB1c2ggJEVDUl9SRVBPX1VSSToke2ltYWdlVGFnfWAsXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pLFxuICAgICAgfSxcbiAgICB9O1xuXG4gICAgY29uc3QgaXNBcm0gPSBwbGF0Zm9ybSA9PT0gJ2xpbnV4L2FybTY0JztcbiAgICBjb25zdCBjb2RlQnVpbGRJbWFnZSA9IGlzQXJtXG4gICAgICA/IExpbnV4QXJtQnVpbGRJbWFnZS5BTUFaT05fTElOVVhfMl9TVEFOREFSRF8zXzBcbiAgICAgIDogTGludXhCdWlsZEltYWdlLlNUQU5EQVJEXzdfMDtcblxuICAgIC8vIENyZWF0ZSB0aGUgQ29kZUJ1aWxkIHByb2plY3RcbiAgICBjb25zdCBjb2RlQnVpbGRQcm9qZWN0ID0gbmV3IFByb2plY3QodGhpcywgJ0NvZGVCdWlsZFByb2plY3QnLCB7XG4gICAgICBzb3VyY2U6IFNvdXJjZS5zMyh7XG4gICAgICAgIGJ1Y2tldDogc291cmNlQXNzZXQuYnVja2V0LFxuICAgICAgICBwYXRoOiBzb3VyY2VBc3NldC5zM09iamVjdEtleSxcbiAgICAgIH0pLFxuICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgYnVpbGRJbWFnZTogY29kZUJ1aWxkSW1hZ2UsXG4gICAgICAgIHByaXZpbGVnZWQ6IHRydWUsXG4gICAgICB9LFxuICAgICAgZW52aXJvbm1lbnRWYXJpYWJsZXM6IHtcbiAgICAgICAgRUNSX1JFUE9fVVJJOiB7IHZhbHVlOiB0aGlzLmVjclJlcG9zaXRvcnkucmVwb3NpdG9yeVVyaSB9LFxuICAgICAgfSxcbiAgICAgIGJ1aWxkU3BlYzogQnVpbGRTcGVjLmZyb21PYmplY3QoYnVpbGRTcGVjT2JqKSxcbiAgICAgIC4uLihidWlsZExvZ0dyb3VwUHJvcCAmJiB7XG4gICAgICAgIGxvZ2dpbmc6IHtcbiAgICAgICAgICBjbG91ZFdhdGNoOiB7XG4gICAgICAgICAgICBsb2dHcm91cDogYnVpbGRMb2dHcm91cFByb3AsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgdnBjLFxuICAgICAgc2VjdXJpdHlHcm91cHMsXG4gICAgICBzdWJuZXRTZWxlY3Rpb24sXG4gICAgfSk7XG5cbiAgICAvLyBHcmFudCBDb2RlQnVpbGQgdGhlIGFiaWxpdHkgdG8gaW50ZXJhY3Qgd2l0aCBFQ1JcbiAgICB0aGlzLmVjclJlcG9zaXRvcnkuZ3JhbnRQdWxsUHVzaChjb2RlQnVpbGRQcm9qZWN0KTtcbiAgICBjb2RlQnVpbGRQcm9qZWN0LmFkZFRvUm9sZVBvbGljeShcbiAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICBhY3Rpb25zOiBbXG4gICAgICAgICAgJ2VjcjpHZXRBdXRob3JpemF0aW9uVG9rZW4nLFxuICAgICAgICAgICdlY3I6R2V0RG93bmxvYWRVcmxGb3JMYXllcicsXG4gICAgICAgICAgJ2VjcjpCYXRjaENoZWNrTGF5ZXJBdmFpbGFiaWxpdHknLFxuICAgICAgICAgICdlY3I6QmF0Y2hHZXRJbWFnZScsXG4gICAgICAgIF0sXG4gICAgICAgIHJlc291cmNlczogWycqJ10sXG4gICAgICB9KSxcbiAgICApO1xuICAgIGlmIChlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXMgJiYgZWNyUHVsbFRocm91Z2hDYWNoZVByZWZpeGVzLmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbnN0IHN0YWNrID0gU3RhY2sub2YodGhpcyk7XG4gICAgICBjb2RlQnVpbGRQcm9qZWN0LmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogW1xuICAgICAgICAgICAgJ2VjcjpCYXRjaEdldEltYWdlJyxcbiAgICAgICAgICAgICdlY3I6R2V0RG93bmxvYWRVcmxGb3JMYXllcicsXG4gICAgICAgICAgICAnZWNyOkJhdGNoQ2hlY2tMYXllckF2YWlsYWJpbGl0eScsXG4gICAgICAgICAgXSxcbiAgICAgICAgICByZXNvdXJjZXM6IGVjclB1bGxUaHJvdWdoQ2FjaGVQcmVmaXhlcy5tYXAoXG4gICAgICAgICAgICAocHJlZml4KSA9PiBgYXJuOmF3czplY3I6JHtzdGFjay5yZWdpb259OiR7c3RhY2suYWNjb3VudH06cmVwb3NpdG9yeS8ke3ByZWZpeH0vKmAsXG4gICAgICAgICAgKSxcbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIH1cbiAgICBpZiAoZG9ja2VyTG9naW5TZWNyZXRBcm4pIHtcbiAgICAgIGNvZGVCdWlsZFByb2plY3QuYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgICBuZXcgUG9saWN5U3RhdGVtZW50KHtcbiAgICAgICAgICBhY3Rpb25zOiBbJ3NlY3JldHNtYW5hZ2VyOkdldFNlY3JldFZhbHVlJ10sXG4gICAgICAgICAgcmVzb3VyY2VzOiBbZG9ja2VyTG9naW5TZWNyZXRBcm5dLFxuICAgICAgICB9KSxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgLy8gQ29uZGl0aW9uYWxseSBncmFudCBLTVMgZW5jcnlwdC9kZWNyeXB0IGlmIGEga2V5IGlzIHVzZWRcbiAgICBpZiAoZW5jcnlwdGlvbktleSkge1xuICAgICAgZW5jcnlwdGlvbktleS5ncmFudEVuY3J5cHREZWNyeXB0KGNvZGVCdWlsZFByb2plY3Qucm9sZSEpO1xuICAgIH1cblxuICAgIC8vIFJlc29sdmUgdGhlIHNlcnZpY2UgdG9rZW46IHNoYXJlZCBwcm92aWRlciBvciBwZXItaW5zdGFuY2UgTGFtYmRhc1xuICAgIGxldCBzZXJ2aWNlVG9rZW46IHN0cmluZztcbiAgICBpZiAoc2hhcmVkUHJvdmlkZXIpIHtcbiAgICAgIHNoYXJlZFByb3ZpZGVyLnJlZ2lzdGVyUHJvamVjdChjb2RlQnVpbGRQcm9qZWN0LCB0aGlzLmVjclJlcG9zaXRvcnksIGVuY3J5cHRpb25LZXkpO1xuICAgICAgc2VydmljZVRva2VuID0gc2hhcmVkUHJvdmlkZXIuc2VydmljZVRva2VuO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBvbkV2ZW50SGFuZGxlckZ1bmN0aW9uID0gbmV3IEZ1bmN0aW9uKHRoaXMsICdPbkV2ZW50SGFuZGxlckZ1bmN0aW9uJywge1xuICAgICAgICBydW50aW1lOiBSdW50aW1lLk5PREVKU18yMl9YLFxuICAgICAgICBjb2RlOiBDb2RlLmZyb21Bc3NldChwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnLi4vb25FdmVudCcpKSxcbiAgICAgICAgaGFuZGxlcjogJ29uRXZlbnQuaGFuZGxlcicsXG4gICAgICAgIHRpbWVvdXQ6IER1cmF0aW9uLm1pbnV0ZXMoMTUpLFxuICAgICAgfSk7XG4gICAgICBvbkV2ZW50SGFuZGxlckZ1bmN0aW9uLmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogWydjb2RlYnVpbGQ6U3RhcnRCdWlsZCddLFxuICAgICAgICAgIHJlc291cmNlczogW2NvZGVCdWlsZFByb2plY3QucHJvamVjdEFybl0sXG4gICAgICAgIH0pLFxuICAgICAgKTtcblxuICAgICAgY29uc3QgaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbiA9IG5ldyBGdW5jdGlvbih0aGlzLCAnSXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbicsIHtcbiAgICAgICAgcnVudGltZTogUnVudGltZS5OT0RFSlNfMjJfWCxcbiAgICAgICAgY29kZTogQ29kZS5mcm9tQXNzZXQocGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uL2lzQ29tcGxldGUnKSksXG4gICAgICAgIGVudmlyb25tZW50OiB7XG4gICAgICAgICAgSU1BR0VfVEFHOiBpbWFnZVRhZyxcbiAgICAgICAgfSxcbiAgICAgICAgaGFuZGxlcjogJ2lzQ29tcGxldGUuaGFuZGxlcicsXG4gICAgICAgIHRpbWVvdXQ6IER1cmF0aW9uLm1pbnV0ZXMoMTUpLFxuICAgICAgfSk7XG4gICAgICBpc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uLmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogW1xuICAgICAgICAgICAgJ2NvZGVidWlsZDpCYXRjaEdldEJ1aWxkcycsXG4gICAgICAgICAgICAnY29kZWJ1aWxkOkxpc3RCdWlsZHNGb3JQcm9qZWN0JyxcbiAgICAgICAgICAgICdsb2dzOkdldExvZ0V2ZW50cycsXG4gICAgICAgICAgICAnbG9nczpEZXNjcmliZUxvZ1N0cmVhbXMnLFxuICAgICAgICAgICAgJ2xvZ3M6RGVzY3JpYmVMb2dHcm91cHMnLFxuICAgICAgICAgIF0sXG4gICAgICAgICAgcmVzb3VyY2VzOiBbJyonXSxcbiAgICAgICAgfSksXG4gICAgICApO1xuXG4gICAgICBpZiAoZW5jcnlwdGlvbktleSkge1xuICAgICAgICBlbmNyeXB0aW9uS2V5LmdyYW50RW5jcnlwdERlY3J5cHQob25FdmVudEhhbmRsZXJGdW5jdGlvbik7XG4gICAgICAgIGVuY3J5cHRpb25LZXkuZ3JhbnRFbmNyeXB0RGVjcnlwdChpc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uKTtcbiAgICAgIH1cbiAgICAgIHRoaXMuZWNyUmVwb3NpdG9yeS5ncmFudFB1bGxQdXNoKG9uRXZlbnRIYW5kbGVyRnVuY3Rpb24pO1xuICAgICAgdGhpcy5lY3JSZXBvc2l0b3J5LmdyYW50UHVsbFB1c2goaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbik7XG5cbiAgICAgIGNvbnN0IHByb3ZpZGVyID0gbmV3IFByb3ZpZGVyKHRoaXMsICdDdXN0b21SZXNvdXJjZVByb3ZpZGVyJywge1xuICAgICAgICBvbkV2ZW50SGFuZGxlcjogb25FdmVudEhhbmRsZXJGdW5jdGlvbixcbiAgICAgICAgaXNDb21wbGV0ZUhhbmRsZXI6IGlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24sXG4gICAgICAgIHF1ZXJ5SW50ZXJ2YWw6IGNvbXBsZXRlbmVzc1F1ZXJ5SW50ZXJ2YWwgPz8gRHVyYXRpb24uc2Vjb25kcygzMCksXG4gICAgICB9KTtcbiAgICAgIHNlcnZpY2VUb2tlbiA9IHByb3ZpZGVyLnNlcnZpY2VUb2tlbjtcbiAgICB9XG5cbiAgICAvLyBDdXN0b20gUmVzb3VyY2UgdGhhdCB0cmlnZ2VycyB0aGUgQ29kZUJ1aWxkIGFuZCB3YWl0cyBmb3IgY29tcGxldGlvblxuICAgIGNvbnN0IGJ1aWxkVHJpZ2dlclJlc291cmNlID0gbmV3IEN1c3RvbVJlc291cmNlKHRoaXMsICdCdWlsZFRyaWdnZXJSZXNvdXJjZScsIHtcbiAgICAgIHNlcnZpY2VUb2tlbixcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgUHJvamVjdE5hbWU6IGNvZGVCdWlsZFByb2plY3QucHJvamVjdE5hbWUsXG4gICAgICAgIEltYWdlVGFnOiBpbWFnZVRhZyxcbiAgICAgICAgVHJpZ2dlcjogc291cmNlQXNzZXQuYXNzZXRIYXNoLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICBidWlsZFRyaWdnZXJSZXNvdXJjZS5ub2RlLmFkZERlcGVuZGVuY3koY29kZUJ1aWxkUHJvamVjdCk7XG5cbiAgICAvLyBSZXRyaWV2ZSB0aGUgZmluYWwgRG9ja2VyIGltYWdlIHRhZyBmcm9tIERhdGEuSW1hZ2VUYWdcbiAgICBjb25zdCBpbWFnZVRhZ1JlZiA9IGJ1aWxkVHJpZ2dlclJlc291cmNlLmdldEF0dFN0cmluZygnSW1hZ2VUYWcnKTtcbiAgICB0aGlzLmNvbnRhaW5lckltYWdlID0gQ29udGFpbmVySW1hZ2UuZnJvbUVjclJlcG9zaXRvcnkodGhpcy5lY3JSZXBvc2l0b3J5LCBpbWFnZVRhZ1JlZik7XG4gICAgdGhpcy5kb2NrZXJJbWFnZUNvZGUgPSBEb2NrZXJJbWFnZUNvZGUuZnJvbUVjcih0aGlzLmVjclJlcG9zaXRvcnksIHtcbiAgICAgIHRhZ09yRGlnZXN0OiBpbWFnZVRhZ1JlZixcbiAgICB9KTtcbiAgfVxufVxuIl19
370
+ TokenInjectableDockerBuilder[_b] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.12.0" };
371
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpQ0FBaUM7QUFDakMseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUU3Qiw2Q0FBOEQ7QUFDOUQsNkRBQTRHO0FBRTVHLGlEQUFrRjtBQUNsRixpREFBcUQ7QUFDckQsaURBQXNEO0FBQ3RELGlEQUEwQztBQUMxQyx1REFBa0Y7QUFFbEYsNkRBQWtEO0FBQ2xELG1FQUF3RDtBQUN4RCwyQ0FBdUM7QUFFdkMsTUFBTSxxQkFBcUIsR0FBRyxzQ0FBc0MsQ0FBQztBQWNyRTs7Ozs7O0dBTUc7QUFDSCxNQUFhLG9DQUFxQyxTQUFRLHNCQUFTO0lBQ2pFOzs7O09BSUc7SUFDSSxNQUFNLENBQUMsV0FBVyxDQUFDLEtBQWdCLEVBQUUsS0FBaUQ7UUFDM0YsTUFBTSxLQUFLLEdBQUcsbUJBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMscUJBQXFCLENBQXFELENBQUM7UUFDcEgsSUFBSSxRQUFRO1lBQUUsT0FBTyxRQUFRLENBQUM7UUFDOUIsT0FBTyxJQUFJLG9DQUFvQyxDQUFDLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBUUQsWUFBb0IsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBaUQ7UUFDakcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsc0JBQXNCLEdBQUcsSUFBSSxxQkFBUSxDQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRTtZQUNqRSxPQUFPLEVBQUUsb0JBQU8sQ0FBQyxXQUFXO1lBQzVCLElBQUksRUFBRSxpQkFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxZQUFZLENBQUMs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ZnJvbSAnY3J5cHRvJztcbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7IEN1c3RvbVJlc291cmNlLCBEdXJhdGlvbiwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBQcm9qZWN0LCBTb3VyY2UsIExpbnV4QnVpbGRJbWFnZSwgTGludXhBcm1CdWlsZEltYWdlLCBCdWlsZFNwZWMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZWJ1aWxkJztcbmltcG9ydCB7IElWcGMsIElTZWN1cml0eUdyb3VwLCBTdWJuZXRTZWxlY3Rpb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IFJlcG9zaXRvcnksIFJlcG9zaXRvcnlFbmNyeXB0aW9uLCBUYWdTdGF0dXMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNyJztcbmltcG9ydCB7IENvbnRhaW5lckltYWdlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjcyc7XG5pbXBvcnQgeyBQb2xpY3lTdGF0ZW1lbnQgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IEtleSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1rbXMnO1xuaW1wb3J0IHsgUnVudGltZSwgQ29kZSwgRG9ja2VySW1hZ2VDb2RlLCBGdW5jdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0IHsgSUxvZ0dyb3VwIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWxvZ3MnO1xuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtczMtYXNzZXRzJztcbmltcG9ydCB7IFByb3ZpZGVyIH0gZnJvbSAnYXdzLWNkay1saWIvY3VzdG9tLXJlc291cmNlcyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuY29uc3QgUFJPVklERVJfU0lOR0xFVE9OX0lEID0gJ1Rva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJQcm92aWRlcic7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgY3JlYXRpbmcgYSBgVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBIb3cgb2Z0ZW4gdGhlIHByb3ZpZGVyIHBvbGxzIGZvciBidWlsZCBjb21wbGV0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBEdXJhdGlvbi5zZWNvbmRzKDMwKVxuICAgKi9cbiAgcmVhZG9ubHkgcXVlcnlJbnRlcnZhbD86IER1cmF0aW9uO1xufVxuXG4vKipcbiAqIFNoYXJlZCBwcm92aWRlciBmb3IgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGluc3RhbmNlcy5cbiAqXG4gKiBDcmVhdGVzIHRoZSBvbkV2ZW50IGFuZCBpc0NvbXBsZXRlIExhbWJkYSBmdW5jdGlvbnMgb25jZSBwZXIgc3RhY2suXG4gKiBFYWNoIGJ1aWxkZXIgaW5zdGFuY2UgcmVnaXN0ZXJzIGl0cyBDb2RlQnVpbGQgcHJvamVjdCBBUk4gc28gdGhlXG4gKiBzaGFyZWQgTGFtYmRhcyBoYXZlIHBlcm1pc3Npb24gdG8gc3RhcnQgYnVpbGRzIGFuZCByZWFkIGxvZ3MuXG4gKi9cbmV4cG9ydCBjbGFzcyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSB0aGUgc2luZ2xldG9uIHByb3ZpZGVyIGZvciB0aGlzIHN0YWNrLlxuICAgKiBBbGwgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGluc3RhbmNlcyBpbiB0aGUgc2FtZSBzdGFja1xuICAgKiBzaGFyZSBhIHNpbmdsZSBwYWlyIG9mIExhbWJkYSBmdW5jdGlvbnMuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGdldE9yQ3JlYXRlKHNjb3BlOiBDb25zdHJ1Y3QsIHByb3BzPzogVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyUHJvcHMpOiBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIge1xuICAgIGNvbnN0IHN0YWNrID0gU3RhY2sub2Yoc2NvcGUpO1xuICAgIGNvbnN0IGV4aXN0aW5nID0gc3RhY2subm9kZS50cnlGaW5kQ2hpbGQoUFJPVklERVJfU0lOR0xFVE9OX0lEKSBhcyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIgfCB1bmRlZmluZWQ7XG4gICAgaWYgKGV4aXN0aW5nKSByZXR1cm4gZXhpc3Rpbmc7XG4gICAgcmV0dXJuIG5ldyBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXIoc3RhY2ssIFBST1ZJREVSX1NJTkdMRVRPTl9JRCwgcHJvcHMpO1xuICB9XG5cbiAgLyoqIFRoZSBzZXJ2aWNlIHRva2VuIHVzZWQgYnkgQ3VzdG9tUmVzb3VyY2UgaW5zdGFuY2VzLiAqL1xuICBwdWJsaWMgcmVhZG9ubHkgc2VydmljZVRva2VuOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBvbkV2ZW50SGFuZGxlckZ1bmN0aW9uOiBGdW5jdGlvbjtcbiAgcHJpdmF0ZSByZWFkb25seSBpc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uOiBGdW5jdGlvbjtcblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlclByb3ZpZGVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5vbkV2ZW50SGFuZGxlckZ1bmN0aW9uID0gbmV3IEZ1bmN0aW9uKHRoaXMsICdPbkV2ZW50SGFuZGxlcicsIHtcbiAgICAgIHJ1bnRpbWU6IFJ1bnRpbWUuTk9ERUpTXzIyX1gsXG4gICAgICBjb2RlOiBDb2RlLmZyb21Bc3NldChwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnLi4vb25FdmVudCcpKSxcbiAgICAgIGhhbmRsZXI6ICdvbkV2ZW50LmhhbmRsZXInLFxuICAgICAgdGltZW91dDogRHVyYXRpb24ubWludXRlcygxNSksXG4gICAgfSk7XG4gICAgdGhpcy5vbkV2ZW50SGFuZGxlckZ1bmN0aW9uLmFkZFRvUm9sZVBvbGljeShcbiAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICBhY3Rpb25zOiBbXG4gICAgICAgICAgJ2xvZ3M6Q3JlYXRlTG9nR3JvdXAnLFxuICAgICAgICAgICdsb2dzOlB1dFJldGVudGlvblBvbGljeScsXG4gICAgICAgICAgJ2xvZ3M6RGVsZXRlTG9nR3JvdXAnLFxuICAgICAgICBdLFxuICAgICAgICByZXNvdXJjZXM6IFsnYXJuOmF3czpsb2dzOio6Kjpsb2ctZ3JvdXA6L2RvY2tlci1idWlsZGVyLyonXSxcbiAgICAgIH0pLFxuICAgICk7XG5cbiAgICB0aGlzLmlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24gPSBuZXcgRnVuY3Rpb24odGhpcywgJ0lzQ29tcGxldGVIYW5kbGVyJywge1xuICAgICAgcnVudGltZTogUnVudGltZS5OT0RFSlNfMjJfWCxcbiAgICAgIGNvZGU6IENvZGUuZnJvbUFzc2V0KHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLi9pc0NvbXBsZXRlJykpLFxuICAgICAgaGFuZGxlcjogJ2lzQ29tcGxldGUuaGFuZGxlcicsXG4gICAgICB0aW1lb3V0OiBEdXJhdGlvbi5taW51dGVzKDE1KSxcbiAgICB9KTtcbiAgICB0aGlzLmlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24uYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFtcbiAgICAgICAgICAnY29kZWJ1aWxkOkJhdGNoR2V0QnVpbGRzJyxcbiAgICAgICAgICAnY29kZWJ1aWxkOkxpc3RCdWlsZHNGb3JQcm9qZWN0JyxcbiAgICAgICAgICAnbG9nczpHZXRMb2dFdmVudHMnLFxuICAgICAgICAgICdsb2dzOkRlc2NyaWJlTG9nU3RyZWFtcycsXG4gICAgICAgICAgJ2xvZ3M6RGVzY3JpYmVMb2dHcm91cHMnLFxuICAgICAgICBdLFxuICAgICAgICByZXNvdXJjZXM6IFsnKiddLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIGNvbnN0IHByb3ZpZGVyID0gbmV3IFByb3ZpZGVyKHRoaXMsICdQcm92aWRlcicsIHtcbiAgICAgIG9uRXZlbnRIYW5kbGVyOiB0aGlzLm9uRXZlbnRIYW5kbGVyRnVuY3Rpb24sXG4gICAgICBpc0NvbXBsZXRlSGFuZGxlcjogdGhpcy5pc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uLFxuICAgICAgcXVlcnlJbnRlcnZhbDogcHJvcHM/LnF1ZXJ5SW50ZXJ2YWwgPz8gRHVyYXRpb24uc2Vjb25kcygzMCksXG4gICAgfSk7XG5cbiAgICB0aGlzLnNlcnZpY2VUb2tlbiA9IHByb3ZpZGVyLnNlcnZpY2VUb2tlbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBHcmFudCB0aGUgc2hhcmVkIExhbWJkYXMgcGVybWlzc2lvbiB0byBzdGFydCBidWlsZHMgZm9yIGEgc3BlY2lmaWNcbiAgICogQ29kZUJ1aWxkIHByb2plY3QgYW5kIHB1bGwvcHVzaCB0byBpdHMgRUNSIHJlcG9zaXRvcnkuXG4gICAqL1xuICBwdWJsaWMgcmVnaXN0ZXJQcm9qZWN0KHByb2plY3Q6IFByb2plY3QsIGVjclJlcG86IFJlcG9zaXRvcnksIGVuY3J5cHRpb25LZXk/OiBLZXkpOiB2b2lkIHtcbiAgICB0aGlzLm9uRXZlbnRIYW5kbGVyRnVuY3Rpb24uYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFsnY29kZWJ1aWxkOlN0YXJ0QnVpbGQnXSxcbiAgICAgICAgcmVzb3VyY2VzOiBbcHJvamVjdC5wcm9qZWN0QXJuXSxcbiAgICAgIH0pLFxuICAgICk7XG4gICAgZWNyUmVwby5ncmFudFB1bGxQdXNoKHRoaXMub25FdmVudEhhbmRsZXJGdW5jdGlvbik7XG4gICAgZWNyUmVwby5ncmFudFB1bGxQdXNoKHRoaXMuaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbik7XG5cbiAgICBpZiAoZW5jcnlwdGlvbktleSkge1xuICAgICAgZW5jcnlwdGlvbktleS5ncmFudEVuY3J5cHREZWNyeXB0KHRoaXMub25FdmVudEhhbmRsZXJGdW5jdGlvbik7XG4gICAgICBlbmNyeXB0aW9uS2V5LmdyYW50RW5jcnlwdERlY3J5cHQodGhpcy5pc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciB0aGUgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgIGNvbnN0cnVjdC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvcHMge1xuICAvKipcbiAgICogVGhlIHBhdGggdG8gdGhlIGRpcmVjdG9yeSBjb250YWluaW5nIHRoZSBEb2NrZXJmaWxlIG9yIHNvdXJjZSBjb2RlLlxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBCdWlsZCBhcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgRG9ja2VyIGJ1aWxkIHByb2Nlc3MuXG4gICAqIFRoZXNlIGFyZSB0cmFuc2Zvcm1lZCBpbnRvIGAtLWJ1aWxkLWFyZyBLRVk9VkFMVUVgIGZsYWdzLlxuICAgKiBAZXhhbXBsZVxuICAgKiB7XG4gICAqICAgVE9LRU46ICdteS1zZWNyZXQtdG9rZW4nLFxuICAgKiAgIEVOVjogJ3Byb2R1Y3Rpb24nXG4gICAqIH1cbiAgICovXG4gIHJlYWRvbmx5IGJ1aWxkQXJncz86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG5cbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIEFXUyBTZWNyZXRzIE1hbmFnZXIgc2VjcmV0IGNvbnRhaW5pbmcgRG9ja2VyIGxvZ2luIGNyZWRlbnRpYWxzLlxuICAgKiBUaGlzIHNlY3JldCBzaG91bGQgc3RvcmUgYSBKU09OIG9iamVjdCB3aXRoIHRoZSBmb2xsb3dpbmcgc3RydWN0dXJlOlxuICAgKiBgYGBqc29uXG4gICAqIHtcbiAgICogICBcInVzZXJuYW1lXCI6IFwibXktZG9ja2VyLXVzZXJuYW1lXCIsXG4gICAqICAgXCJwYXNzd29yZFwiOiBcIm15LWRvY2tlci1wYXNzd29yZFwiXG4gICAqIH1cbiAgICogYGBgXG4gICAqIElmIG5vdCBwcm92aWRlZCAob3Igbm90IG5lZWRlZCksIHRoZSBjb25zdHJ1Y3Qgd2lsbCBza2lwIERvY2tlciBIdWIgbG9naW4uXG4gICAqXG4gICAqICoqTm90ZSoqOiBUaGUgc2VjcmV0IG11c3QgYmUgaW4gdGhlIHNhbWUgcmVnaW9uIGFzIHRoZSBzdGFjay5cbiAgICpcbiAgICogQGV4YW1wbGUgJ2Fybjphd3M6c2VjcmV0c21hbmFnZXI6dXMtZWFzdC0xOjEyMzQ1Njc4OTAxMjpzZWNyZXQ6RG9ja2VyTG9naW5TZWNyZXQnXG4gICAqL1xuICByZWFkb25seSBkb2NrZXJMb2dpblNlY3JldEFybj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIFZQQyBpbiB3aGljaCB0aGUgQ29kZUJ1aWxkIHByb2plY3Qgd2lsbCBiZSBkZXBsb3llZC5cbiAgICogSWYgcHJvdmlkZWQsIHRoZSBDb2RlQnVpbGQgcHJvamVjdCB3aWxsIGJlIGxhdW5jaGVkIHdpdGhpbiB0aGUgc3BlY2lmaWVkIFZQQy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBWUEMgaXMgYXR0YWNoZWQsIGFuZCB0aGUgQ29kZUJ1aWxkIHByb2plY3Qgd2lsbCB1c2UgcHVibGljIGludGVybmV0LlxuICAgKi9cbiAgcmVhZG9ubHkgdnBjPzogSVZwYztcblxuICAvKipcbiAgICogVGhlIHNlY3VyaXR5IGdyb3VwcyB0byBhdHRhY2ggdG8gdGhlIENvZGVCdWlsZCBwcm9qZWN0LlxuICAgKiBUaGVzZSBkZWZpbmUgdGhlIG5ldHdvcmsgYWNjZXNzIHJ1bGVzIGZvciB0aGUgQ29kZUJ1aWxkIHByb2plY3QuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gc2VjdXJpdHkgZ3JvdXBzIGFyZSBhdHRhY2hlZC5cbiAgICovXG4gIHJlYWRvbmx5IHNlY3VyaXR5R3JvdXBzPzogSVNlY3VyaXR5R3JvdXBbXTtcblxuICAvKipcbiAgICogVGhlIHN1Ym5ldCBzZWxlY3Rpb24gdG8gc3BlY2lmeSB3aGljaCBzdWJuZXRzIHRvIHVzZSB3aXRoaW4gdGhlIFZQQy5cbiAgICogQWxsb3dzIHRoZSB1c2VyIHRvIHNlbGVjdCBwcml2YXRlLCBwdWJsaWMsIG9yIGlzb2xhdGVkIHN1Ym5ldHMuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQWxsIHN1Ym5ldHMgaW4gdGhlIFZQQyBhcmUgdXNlZC5cbiAgICovXG4gIHJlYWRvbmx5IHN1Ym5ldFNlbGVjdGlvbj86IFN1Ym5ldFNlbGVjdGlvbjtcblxuICAvKipcbiAgICogQ3VzdG9tIGNvbW1hbmRzIHRvIHJ1biBkdXJpbmcgdGhlIGluc3RhbGwgcGhhc2Ugb2YgQ29kZUJ1aWxkLlxuICAgKlxuICAgKiAqKkV4YW1wbGUqKjpcbiAgICogYGBgdHNcbiAgICogaW5zdGFsbENvbW1hbmRzOiBbXG4gICAqICAgJ2VjaG8gXCJVcGRhdGluZyBwYWNrYWdlIGxpc3RzLi4uXCInLFxuICAgKiAgICdhcHQtZ2V0IHVwZGF0ZSAteScsXG4gICAqICAgJ2VjaG8gXCJJbnN0YWxsaW5nIHJlcXVpcmVkIHBhY2thZ2VzLi4uXCInLFxuICAgKiAgICdhcHQtZ2V0IGluc3RhbGwgLXkgY3VybCBkbnN1dGlscycsXG4gICAqIF0sXG4gICAqIGBgYFxuICAgKiBAZGVmYXVsdCAtIE5vIGFkZGl0aW9uYWwgaW5zdGFsbCBjb21tYW5kcy5cbiAgICovXG4gIHJlYWRvbmx5IGluc3RhbGxDb21tYW5kcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBDdXN0b20gY29tbWFuZHMgdG8gcnVuIGR1cmluZyB0aGUgcHJlX2J1aWxkIHBoYXNlIG9mIENvZGVCdWlsZC5cbiAgICpcbiAgICogKipFeGFtcGxlKio6XG4gICAqIGBgYHRzXG4gICAqIHByZUJ1aWxkQ29tbWFuZHM6IFtcbiAgICogICAnZWNobyBcIkZldGNoaW5nIGNvbmZpZ3VyYXRpb24gZnJvbSBwcml2YXRlIEFQSS4uLlwiJyxcbiAgICogICAnY3VybCAtbyBjb25maWcuanNvbiBodHRwczovL2FwaS5leGFtcGxlLmNvbS9jb25maWcnLFxuICAgKiBdLFxuICAgKiBgYGBcbiAgICogQGRlZmF1bHQgLSBObyBhZGRpdGlvbmFsIHByZS1idWlsZCBjb21tYW5kcy5cbiAgICovXG4gIHJlYWRvbmx5IHByZUJ1aWxkQ29tbWFuZHM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogV2hldGhlciB0byBlbmFibGUgS01TIGVuY3J5cHRpb24gZm9yIHRoZSBFQ1IgcmVwb3NpdG9yeS5cbiAgICogSWYgYHRydWVgLCBhIEtNUyBrZXkgd2lsbCBiZSBjcmVhdGVkIGZvciBlbmNyeXB0aW5nIEVDUiBpbWFnZXMuXG4gICAqIElmIGBmYWxzZWAsIHRoZSByZXBvc2l0b3J5IHdpbGwgdXNlIEFFUy0yNTYgZW5jcnlwdGlvbi5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkga21zRW5jcnlwdGlvbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBxdWVyeSBpbnRlcnZhbCBmb3IgY2hlY2tpbmcgaWYgdGhlIENvZGVCdWlsZCBwcm9qZWN0IGhhcyBjb21wbGV0ZWQuXG4gICAqIFRoaXMgZGV0ZXJtaW5lcyBob3cgZnJlcXVlbnRseSB0aGUgY3VzdG9tIHJlc291cmNlIHBvbGxzIGZvciBidWlsZCBjb21wbGV0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIER1cmF0aW9uLnNlY29uZHMoMzApXG4gICAqL1xuICByZWFkb25seSBjb21wbGV0ZW5lc3NRdWVyeUludGVydmFsPzogRHVyYXRpb247XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBmaWxlIHBhdGhzIGluIHRoZSBEb2NrZXIgZGlyZWN0b3J5IHRvIGV4Y2x1ZGUgZnJvbSBidWlsZC5cbiAgICogV2lsbCB1c2UgcGF0aHMgaW4gLmRvY2tlcmlnbm9yZSBmaWxlIGlmIHByZXNlbnQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gZmlsZSBwYXRoIGV4Y2x1c2lvbnNcbiAgICovXG4gIHJlYWRvbmx5IGV4Y2x1ZGU/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIERvY2tlcmZpbGUgdG8gdXNlIGZvciB0aGUgYnVpbGQuXG4gICAqIFBhc3NlZCBhcyBgLS1maWxlYCB0byBgZG9ja2VyIGJ1aWxkYC5cbiAgICpcbiAgICogQGV4YW1wbGUgJ0RvY2tlcmZpbGUucHJvZHVjdGlvbidcbiAgICogQGRlZmF1bHQgJ0RvY2tlcmZpbGUnXG4gICAqL1xuICByZWFkb25seSBmaWxlPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGVuIGB0cnVlYCwgZGlzYWJsZXMgRG9ja2VyIGxheWVyIGNhY2hpbmcuIEV2ZXJ5IGJ1aWxkIHJ1bnMgZnJvbSBzY3JhdGNoLlxuICAgKiBVc2UgZm9yIGRlYnVnZ2luZywgY29ycnVwdGVkIGNhY2hlLCBvciBtYWpvciBkZXBlbmRlbmN5IGNoYW5nZXMuXG4gICAqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBjYWNoZURpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQ2xvdWRXYXRjaCBsb2cgZ3JvdXAgZm9yIENvZGVCdWlsZCBidWlsZCBsb2dzLlxuICAgKiBXaGVuIHByb3ZpZGVkIHdpdGggYSBSRVRBSU4gcmVtb3ZhbCBwb2xpY3ksIGJ1aWxkIGxvZ3Mgc3Vydml2ZSByb2xsYmFja3NcbiAgICogYW5kIHN0YWNrIGRlbGV0aW9uIGZvciBkZWJ1Z2dpbmcuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ29kZUJ1aWxkIGRlZmF1bHQgbG9nZ2luZyAobG9ncyBhcmUgZGVsZXRlZCBvbiByb2xsYmFjaylcbiAgICovXG4gIHJlYWRvbmx5IGJ1aWxkTG9nR3JvdXA/OiBJTG9nR3JvdXA7XG5cbiAgLyoqXG4gICAqIFRhcmdldCBwbGF0Zm9ybSBmb3IgdGhlIERvY2tlciBpbWFnZS5cbiAgICpcbiAgICogV2hlbiBzZXQgdG8gYCdsaW51eC9hcm02NCdgLCB0aGUgY29uc3RydWN0IHVzZXMgYSBuYXRpdmUgQVJNL0dyYXZpdG9uXG4gICAqIENvZGVCdWlsZCBpbnN0YW5jZSBmb3IgZmFzdCBidWlsZHMgd2l0aG91dCBlbXVsYXRpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0ICdsaW51eC9hbWQ2NCdcbiAgICovXG4gIHJlYWRvbmx5IHBsYXRmb3JtPzogJ2xpbnV4L2FtZDY0JyB8ICdsaW51eC9hcm02NCc7XG5cbiAgLyoqXG4gICAqIFNoYXJlZCBwcm92aWRlciBmb3IgdGhlIGN1c3RvbSByZXNvdXJjZSBMYW1iZGFzLlxuICAgKiBVc2UgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJQcm92aWRlci5nZXRPckNyZWF0ZSh0aGlzKWAgdG8gY3JlYXRlXG4gICAqIGEgc2luZ2xldG9uIHRoYXQgaXMgc2hhcmVkIGFjcm9zcyBhbGwgYnVpbGRlcnMgaW4gdGhlIHNhbWUgc3RhY2suXG4gICAqXG4gICAqIFdoZW4gb21pdHRlZCwgZWFjaCBidWlsZGVyIGNyZWF0ZXMgaXRzIG93biBMYW1iZGFzIChvcmlnaW5hbCBiZWhhdmlvcikuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQSBuZXcgcHJvdmlkZXIgaXMgY3JlYXRlZCBwZXIgYnVpbGRlciBpbnN0YW5jZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvdmlkZXI/OiBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvdmlkZXI7XG5cbiAgLyoqXG4gICAqIEVDUiBwdWxsLXRocm91Z2ggY2FjaGUgcmVwb3NpdG9yeSBwcmVmaXhlcyB0byBncmFudCBwdWxsIGFjY2VzcyB0by5cbiAgICogVXNlIHdoZW4geW91ciBEb2NrZXJmaWxlIHJlZmVyZW5jZXMgYmFzZSBpbWFnZXMgZnJvbSBFQ1IgcHVsbC10aHJvdWdoXG4gICAqIGNhY2hlIChlLmcuIGRvY2tlci1odWIvbGlicmFyeS9ub2RlOjIwLXNsaW0sIGdoY3Ivb3JnL2ltYWdlOnRhZykuXG4gICAqIFRoZSBDb2RlQnVpbGQgcm9sZSB3aWxsIGJlIGdyYW50ZWQgZWNyOkJhdGNoR2V0SW1hZ2UsIGVjcjpHZXREb3dubG9hZFVybEZvckxheWVyLFxuICAgKiBhbmQgZWNyOkJhdGNoQ2hlY2tMYXllckF2YWlsYWJpbGl0eSBvbiByZXBvc2l0b3JpZXMgbWF0Y2hpbmcgZWFjaCBwcmVmaXguXG4gICAqXG4gICAqIEBleGFtcGxlIFsnZG9ja2VyLWh1YicsICdnaGNyJ11cbiAgICogQGRlZmF1bHQgLSBObyBwdWxsLXRocm91Z2ggY2FjaGUgYWNjZXNzXG4gICAqL1xuICByZWFkb25seSBlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogV2hlbiBgdHJ1ZWAsIGNyZWF0ZXMgYSBDbG91ZFdhdGNoIGxvZyBncm91cCBvdXRzaWRlIG9mIENsb3VkRm9ybWF0aW9uXG4gICAqIChgL2RvY2tlci1idWlsZGVyLzxwcm9qZWN0TmFtZT5gKSBhbmQgZGlyZWN0cyBDb2RlQnVpbGQgb3V0cHV0IHRoZXJlLlxuICAgKiBCZWNhdXNlIHRoZSBsb2cgZ3JvdXAgaXMgbWFuYWdlZCBpbXBlcmF0aXZlbHkgKG5vdCBieSBDbG91ZEZvcm1hdGlvbiksXG4gICAqIGl0IHN1cnZpdmVzIHN0YWNrIHJvbGxiYWNrcyBhbmQgcHJlc2VydmVzIGZ1bGwgYnVpbGQgbG9ncyBmb3IgZGVidWdnaW5nLlxuICAgKiBBIDctZGF5IHJldGVudGlvbiBwb2xpY3kgaXMgYXBwbGllZCBzbyBvbGQgbG9ncyBhdXRvLWV4cGlyZS5cbiAgICpcbiAgICogU2V0IHRvIGBmYWxzZWAgYWZ0ZXIgZGVidWdnaW5nIHRvIGRlbGV0ZSB0aGUgbG9nIGdyb3VwIGFuZCBjbGVhbiB1cC5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHJldGFpbkJ1aWxkTG9ncz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBDREsgY29uc3RydWN0IHRvIGJ1aWxkIGFuZCBwdXNoIERvY2tlciBpbWFnZXMgdG8gYW4gRUNSIHJlcG9zaXRvcnkgdXNpbmdcbiAqIENvZGVCdWlsZCBhbmQgTGFtYmRhIGN1c3RvbSByZXNvdXJjZXMsICoqdGhlbioqIHJldHJpZXZlIHRoZSBmaW5hbCBpbWFnZSB0YWdcbiAqIHNvIHRoYXQgRUNTL0xhbWJkYSByZWZlcmVuY2VzIHVzZSB0aGUgZXhhY3QgZGlnZXN0LlxuICovXG5leHBvcnQgY2xhc3MgVG9rZW5JbmplY3RhYmxlRG9ja2VyQnVpbGRlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8qKlxuICAgKiBUaGUgRUNSIHJlcG9zaXRvcnkgdGhhdCBzdG9yZXMgdGhlIHJlc3VsdGluZyBEb2NrZXIgaW1hZ2UuXG4gICAqL1xuICBwcml2YXRlIHJlYWRvbmx5IGVjclJlcG9zaXRvcnk6IFJlcG9zaXRvcnk7XG5cbiAgLyoqXG4gICAqIEFuIEVDUy1jb21wYXRpYmxlIGNvbnRhaW5lciBpbWFnZSByZWZlcmVuY2luZyB0aGUgdGFnXG4gICAqIG9mIHRoZSBidWlsdCBEb2NrZXIgaW1hZ2UuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgY29udGFpbmVySW1hZ2U6IENvbnRhaW5lckltYWdlO1xuXG4gIC8qKlxuICAgKiBBIExhbWJkYS1jb21wYXRpYmxlIERvY2tlckltYWdlQ29kZSByZWZlcmVuY2luZyB0aGUgdGFnXG4gICAqIG9mIHRoZSBidWlsdCBEb2NrZXIgaW1hZ2UuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZG9ja2VySW1hZ2VDb2RlOiBEb2NrZXJJbWFnZUNvZGU7XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgYFRva2VuSW5qZWN0YWJsZURvY2tlckJ1aWxkZXJgLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgVGhlIHNjb3BlIGluIHdoaWNoIHRvIGRlZmluZSB0aGlzIGNvbnN0cnVjdC5cbiAgICogQHBhcmFtIGlkIFRoZSBzY29wZWQgY29uc3RydWN0IElELlxuICAgKiBAcGFyYW0gcHJvcHMgQ29uZmlndXJhdGlvbiBmb3IgYnVpbGRpbmcgYW5kIHB1c2hpbmcgdGhlIERvY2tlciBpbWFnZS5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBUb2tlbkluamVjdGFibGVEb2NrZXJCdWlsZGVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3Qge1xuICAgICAgcGF0aDogc291cmNlUGF0aCxcbiAgICAgIGJ1aWxkQXJncyxcbiAgICAgIGRvY2tlckxvZ2luU2VjcmV0QXJuLFxuICAgICAgdnBjLFxuICAgICAgc2VjdXJpdHlHcm91cHMsXG4gICAgICBzdWJuZXRTZWxlY3Rpb24sXG4gICAgICBpbnN0YWxsQ29tbWFuZHMsXG4gICAgICBwcmVCdWlsZENvbW1hbmRzLFxuICAgICAga21zRW5jcnlwdGlvbiA9IGZhbHNlLFxuICAgICAgY29tcGxldGVuZXNzUXVlcnlJbnRlcnZhbCxcbiAgICAgIGV4Y2x1ZGUsXG4gICAgICBmaWxlOiBkb2NrZXJGaWxlLFxuICAgICAgY2FjaGVEaXNhYmxlZCA9IGZhbHNlLFxuICAgICAgYnVpbGRMb2dHcm91cDogYnVpbGRMb2dHcm91cFByb3AsXG4gICAgICBwbGF0Zm9ybSA9ICdsaW51eC9hbWQ2NCcsXG4gICAgICBwcm92aWRlcjogc2hhcmVkUHJvdmlkZXIsXG4gICAgICBlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXMsXG4gICAgICByZXRhaW5CdWlsZExvZ3MgPSBmYWxzZSxcbiAgICB9ID0gcHJvcHM7XG5cbiAgICAvLyBHZW5lcmF0ZSBhbiBlcGhlbWVyYWwgdGFnIGZvciBDb2RlQnVpbGRcbiAgICBjb25zdCBpbWFnZVRhZyA9IGNyeXB0by5yYW5kb21VVUlEKCk7XG5cbiAgICAvLyBPcHRpb25hbGx5IGRlZmluZSBhIEtNUyBrZXkgZm9yIEVDUiBlbmNyeXB0aW9uIGlmIHJlcXVlc3RlZFxuICAgIGxldCBlbmNyeXB0aW9uS2V5OiBLZXkgfCB1bmRlZmluZWQ7XG4gICAgaWYgKGttc0VuY3J5cHRpb24pIHtcbiAgICAgIGVuY3J5cHRpb25LZXkgPSBuZXcgS2V5KHRoaXMsICdFY3JFbmNyeXB0aW9uS2V5Jywge1xuICAgICAgICBlbmFibGVLZXlSb3RhdGlvbjogdHJ1ZSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIENyZWF0ZSBhbiBFQ1IgcmVwb3NpdG9yeSAob3B0aW9uYWxseSB3aXRoIEtNUyBlbmNyeXB0aW9uKVxuICAgIHRoaXMuZWNyUmVwb3NpdG9yeSA9IG5ldyBSZXBvc2l0b3J5KHRoaXMsICdFQ1JSZXBvc2l0b3J5Jywge1xuICAgICAgbGlmZWN5Y2xlUnVsZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHJ1bGVQcmlvcml0eTogMSxcbiAgICAgICAgICBkZXNjcmlwdGlvbjogJ1JlbW92ZSB1bnRhZ2dlZCBpbWFnZXMgYWZ0ZXIgMSBkYXknLFxuICAgICAgICAgIHRhZ1N0YXR1czogVGFnU3RhdHVzLlVOVEFHR0VELFxuICAgICAgICAgIG1heEltYWdlQWdlOiBEdXJhdGlvbi5kYXlzKDEpLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIGVuY3J5cHRpb246IGttc0VuY3J5cHRpb24gPyBSZXBvc2l0b3J5RW5jcnlwdGlvbi5LTVMgOiBSZXBvc2l0b3J5RW5jcnlwdGlvbi5BRVNfMjU2LFxuICAgICAgZW5jcnlwdGlvbktleToga21zRW5jcnlwdGlvbiA/IGVuY3J5cHRpb25LZXkgOiB1bmRlZmluZWQsXG4gICAgICBpbWFnZVNjYW5PblB1c2g6IHRydWUsXG4gICAgfSk7XG5cbiAgICBsZXQgZWZmZWN0aXZlRXhjbHVkZSA9IGV4Y2x1ZGU7XG4gICAgaWYgKCFlZmZlY3RpdmVFeGNsdWRlKSB7XG4gICAgICBjb25zdCBkb2NrZXJpZ25vcmVQYXRoID0gcGF0aC5qb2luKHNvdXJjZVBhdGgsICcuZG9ja2VyaWdub3JlJyk7XG4gICAgICBpZiAoZnMuZXhpc3RzU3luYyhkb2NrZXJpZ25vcmVQYXRoKSkge1xuICAgICAgICBjb25zdCBmaWxlQ29udGVudCA9IGZzLnJlYWRGaWxlU3luYyhkb2NrZXJpZ25vcmVQYXRoLCAndXRmOCcpO1xuICAgICAgICBlZmZlY3RpdmVFeGNsdWRlID0gZmlsZUNvbnRlbnRcbiAgICAgICAgICAuc3BsaXQoJ1xcbicpXG4gICAgICAgICAgLm1hcCgobGluZTogc3RyaW5nKSA9PiBsaW5lLnRyaW0oKSlcbiAgICAgICAgICAuZmlsdGVyKChsaW5lOiBzdHJpbmcpID0+IGxpbmUubGVuZ3RoID4gMCAmJiAhbGluZS5zdGFydHNXaXRoKCcjJykpO1xuICAgICAgfVxuICAgIH1cblxuICAgIC8vIEVuc3VyZSB0aGUgdGFyZ2V0IERvY2tlcmZpbGUgaXMgbmV2ZXIgZXhjbHVkZWQgKGhhbmRsZXMgZ2xvYnMgbGlrZSBcIkRvY2tlcmZpbGUqXCIpXG4gICAgY29uc3QgZG9ja2VyRmlsZU5hbWUgPSBkb2NrZXJGaWxlID8/ICdEb2NrZXJmaWxlJztcbiAgICBpZiAoZWZmZWN0aXZlRXhjbHVkZSkge1xuICAgICAgZWZmZWN0aXZlRXhjbHVkZSA9IGVmZmVjdGl2ZUV4Y2x1ZGUuZmlsdGVyKChwYXR0ZXJuOiBzdHJpbmcpID0+IHtcbiAgICAgICAgY29uc3QgZXNjYXBlZCA9IHBhdHRlcm4ucmVwbGFjZSgvWy4rXiR7fSgpfFtcXF1cXFxcXS9nLCAnXFxcXCQmJyk7XG4gICAgICAgIGNvbnN0IHJlZ2V4ID0gbmV3IFJlZ0V4cChgXiR7ZXNjYXBlZC5yZXBsYWNlKC9cXCovZywgJy4qJykucmVwbGFjZSgvXFw/L2csICcuJyl9JGAsICdpJyk7XG4gICAgICAgIHJldHVybiAhcmVnZXgudGVzdChkb2NrZXJGaWxlTmFtZSk7XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBXcmFwIHRoZSBzb3VyY2UgZm9sZGVyIGFzIGFuIFMzIGFzc2V0IGZvciBDb2RlQnVpbGQgdG8gdXNlXG4gICAgY29uc3Qgc291cmNlQXNzZXQgPSBuZXcgQXNzZXQodGhpcywgJ1NvdXJjZUFzc2V0Jywge1xuICAgICAgcGF0aDogc291cmNlUGF0aCxcbiAgICAgIGV4Y2x1ZGU6IGVmZmVjdGl2ZUV4Y2x1ZGUsXG4gICAgfSk7XG5cbiAgICAvLyBDb252ZXJ0IGJ1aWxkQXJncyB0byBhIENMSS1mcmllbmRseSBzdHJpbmdcbiAgICBjb25zdCBidWlsZEFyZ3NTdHJpbmcgPSBidWlsZEFyZ3NcbiAgICAgID8gT2JqZWN0LmVudHJpZXMoYnVpbGRBcmdzKVxuICAgICAgICAubWFwKChbaywgdl0pID0+IGAtLWJ1aWxkLWFyZyAke2t9PSR7dn1gKVxuICAgICAgICAuam9pbignICcpXG4gICAgICA6ICcnO1xuXG4gICAgY29uc3QgZG9ja2VyRmlsZUZsYWcgPSBkb2NrZXJGaWxlID8gYC1mICRDT0RFQlVJTERfU1JDX0RJUi8ke2RvY2tlckZpbGV9YCA6ICcnO1xuXG4gICAgLy8gT3B0aW9uYWwgRG9ja2VySHViIGxvZ2luLCBpZiBhIHNlY3JldCBBUk4gaXMgcHJvdmlkZWRcbiAgICBjb25zdCBkb2NrZXJMb2dpbkNvbW1hbmRzID0gZG9ja2VyTG9naW5TZWNyZXRBcm5cbiAgICAgID8gW1xuICAgICAgICAnZWNobyBcIlJldHJpZXZpbmcgRG9ja2VyIGNyZWRlbnRpYWxzLi4uXCInLFxuICAgICAgICAnYXB0LWdldCB1cGRhdGUgLXkgJiYgYXB0LWdldCBpbnN0YWxsIC15IGpxJyxcbiAgICAgICAgYERPQ0tFUl9VU0VSTkFNRT0kKGF3cyBzZWNyZXRzbWFuYWdlciBnZXQtc2VjcmV0LXZhbHVlIC0tc2VjcmV0LWlkICR7ZG9ja2VyTG9naW5TZWNyZXRBcm59IC0tcXVlcnkgU2VjcmV0U3RyaW5nIC0tb3V0cHV0IHRleHQgfCBqcSAtciAudXNlcm5hbWUpYCxcbiAgICAgICAgYERPQ0tFUl9QQVNTV09SRD0kKGF3cyBzZWNyZXRzbWFuYWdlciBnZXQtc2VjcmV0LXZhbHVlIC0tc2VjcmV0LWlkICR7ZG9ja2VyTG9naW5TZWNyZXRBcm59IC0tcXVlcnkgU2VjcmV0U3RyaW5nIC0tb3V0cHV0IHRleHQgfCBqcSAtciAucGFzc3dvcmQpYCxcbiAgICAgICAgJ2VjaG8gXCJMb2dnaW5nIGluIHRvIERvY2tlciBIdWIuLi5cIicsXG4gICAgICAgICdlY2hvICRET0NLRVJfUEFTU1dPUkQgfCBkb2NrZXIgbG9naW4gLS11c2VybmFtZSAkRE9DS0VSX1VTRVJOQU1FIC0tcGFzc3dvcmQtc3RkaW4nLFxuICAgICAgXVxuICAgICAgOiBbJ2VjaG8gXCJObyBEb2NrZXIgY3JlZGVudGlhbHMuIFNraXBwaW5nIERvY2tlciBIdWIgbG9naW4uXCInXTtcblxuICAgIGNvbnN0IGJ1aWxkeEluc3RhbGxDb21tYW5kcyA9IGNhY2hlRGlzYWJsZWRcbiAgICAgID8gW11cbiAgICAgIDogW1xuICAgICAgICAnZWNobyBcIlNldHRpbmcgdXAgRG9ja2VyIGJ1aWxkeCBmb3IgRUNSIGxheWVyIGNhY2hlLi4uXCInLFxuICAgICAgICAnZG9ja2VyIGJ1aWxkeCBjcmVhdGUgLS1kcml2ZXIgZG9ja2VyLWNvbnRhaW5lciAtLW5hbWUgZWNyLWNhY2hlLWJ1aWxkZXIgLS11c2UgMj4vZGV2L251bGwgfHwgZG9ja2VyIGJ1aWxkeCB1c2UgZWNyLWNhY2hlLWJ1aWxkZXInLFxuICAgICAgXTtcblxuICAgIGNvbnN0IHBsYXRmb3JtRmxhZyA9IGAtLXBsYXRmb3JtICR7cGxhdGZvcm19YDtcblxuICAgIC8vIC0tcHJvdmVuYW5jZT1mYWxzZSAtLXNib209ZmFsc2U6IERvY2tlciBCdWlsZHggdjAuMTArIGFkZHMgYXR0ZXN0YXRpb25zIGJ5IGRlZmF1bHQsXG4gICAgLy8gcHJvZHVjaW5nIE9DSSBpbWFnZSBpbmRleGVzIHRoYXQgQVdTIExhbWJkYSBkb2VzIG5vdCBzdXBwb3J0LiBEaXNhYmxlIHRoZW0gZm9yIExhbWJkYS9FQ1MgY29tcGF0aWJpbGl0eS5cbiAgICBjb25zdCBidWlsZENvbW1hbmQgPSBjYWNoZURpc2FibGVkXG4gICAgICA/IGBkb2NrZXIgYnVpbGQgJHtwbGF0Zm9ybUZsYWd9ICR7ZG9ja2VyRmlsZUZsYWd9ICR7YnVpbGRBcmdzU3RyaW5nfSAtdCAkRUNSX1JFUE9fVVJJOiR7aW1hZ2VUYWd9ICRDT0RFQlVJTERfU1JDX0RJUmBcbiAgICAgIDogYGRvY2tlciBidWlsZHggYnVpbGQgLS1wdXNoICR7cGxhdGZvcm1GbGFnfSAtLXByb3ZlbmFuY2U9ZmFsc2UgLS1zYm9tPWZhbHNlIC0tY2FjaGUtZnJvbSB0eXBlPXJlZ2lzdHJ5LHJlZj0kRUNSX1JFUE9fVVJJOmNhY2hlIC0tY2FjaGUtdG8gdHlwZT1yZWdpc3RyeSxyZWY9JEVDUl9SRVBPX1VSSTpjYWNoZSxtb2RlPW1heCxpbWFnZS1tYW5pZmVzdD10cnVlICR7ZG9ja2VyRmlsZUZsYWd9ICR7YnVpbGRBcmdzU3RyaW5nfSAtdCAkRUNSX1JFUE9fVVJJOiR7aW1hZ2VUYWd9ICRDT0RFQlVJTERfU1JDX0RJUmA7XG5cbiAgICBjb25zdCBidWlsZFNwZWNPYmogPSB7XG4gICAgICB2ZXJzaW9uOiAnMC4yJyxcbiAgICAgIHBoYXNlczoge1xuICAgICAgICBpbnN0YWxsOiB7XG4gICAgICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgICAgICdlY2hvIFwiQmVnaW5uaW5nIGluc3RhbGwgcGhhc2UuLi5cIicsXG4gICAgICAgICAgICAuLi4oaW5zdGFsbENvbW1hbmRzID8/IFtdKSxcbiAgICAgICAgICAgIC4uLmJ1aWxkeEluc3RhbGxDb21tYW5kcyxcbiAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgICAgICBwcmVfYnVpbGQ6IHtcbiAgICAgICAgICBjb21tYW5kczogW1xuICAgICAgICAgICAgLi4uKHByZUJ1aWxkQ29tbWFuZHMgPz8gW10pLFxuICAgICAgICAgICAgLi4uZG9ja2VyTG9naW5Db21tYW5kcyxcbiAgICAgICAgICAgICdlY2hvIFwiUmV0cmlldmluZyBBV1MgQWNjb3VudCBJRC4uLlwiJyxcbiAgICAgICAgICAgICdleHBvcnQgQUNDT1VOVF9JRD0kKGF3cyBzdHMgZ2V0LWNhbGxlci1pZGVudGl0eSAtLXF1ZXJ5IEFjY291bnQgLS1vdXRwdXQgdGV4dCknLFxuICAgICAgICAgICAgJ2VjaG8gXCJMb2dnaW5nIGludG8gQW1hem9uIEVDUi4uLlwiJyxcbiAgICAgICAgICAgICdhd3MgZWNyIGdldC1sb2dpbi1wYXNzd29yZCAtLXJlZ2lvbiAkQVdTX0RFRkFVTFRfUkVHSU9OIHwgZG9ja2VyIGxvZ2luIC0tdXNlcm5hbWUgQVdTIC0tcGFzc3dvcmQtc3RkaW4gJEFDQ09VTlRfSUQuZGtyLmVjci4kQVdTX0RFRkFVTFRfUkVHSU9OLmFtYXpvbmF3cy5jb20nLFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICAgIGJ1aWxkOiB7XG4gICAgICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgICAgIGBlY2hvIFwiQnVpbGRpbmcgRG9ja2VyIGltYWdlIHdpdGggdGFnICR7aW1hZ2VUYWd9Li4uXCJgLFxuICAgICAgICAgICAgYnVpbGRDb21tYW5kLFxuICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgICAgIC4uLihjYWNoZURpc2FibGVkICYmIHtcbiAgICAgICAgICBwb3N0X2J1aWxkOiB7XG4gICAgICAgICAgICBjb21tYW5kczogW1xuICAgICAgICAgICAgICBgZWNobyBcIlB1c2hpbmcgRG9ja2VyIGltYWdlIHdpdGggdGFnICR7aW1hZ2VUYWd9Li4uXCJgLFxuICAgICAgICAgICAgICBgZG9ja2VyIHB1c2ggJEVDUl9SRVBPX1VSSToke2ltYWdlVGFnfWAsXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pLFxuICAgICAgfSxcbiAgICB9O1xuXG4gICAgY29uc3QgaXNBcm0gPSBwbGF0Zm9ybSA9PT0gJ2xpbnV4L2FybTY0JztcbiAgICBjb25zdCBjb2RlQnVpbGRJbWFnZSA9IGlzQXJtXG4gICAgICA/IExpbnV4QXJtQnVpbGRJbWFnZS5BTUFaT05fTElOVVhfMl9TVEFOREFSRF8zXzBcbiAgICAgIDogTGludXhCdWlsZEltYWdlLlNUQU5EQVJEXzdfMDtcblxuICAgIC8vIENyZWF0ZSB0aGUgQ29kZUJ1aWxkIHByb2plY3RcbiAgICBjb25zdCBjb2RlQnVpbGRQcm9qZWN0ID0gbmV3IFByb2plY3QodGhpcywgJ0NvZGVCdWlsZFByb2plY3QnLCB7XG4gICAgICBzb3VyY2U6IFNvdXJjZS5zMyh7XG4gICAgICAgIGJ1Y2tldDogc291cmNlQXNzZXQuYnVja2V0LFxuICAgICAgICBwYXRoOiBzb3VyY2VBc3NldC5zM09iamVjdEtleSxcbiAgICAgIH0pLFxuICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgYnVpbGRJbWFnZTogY29kZUJ1aWxkSW1hZ2UsXG4gICAgICAgIHByaXZpbGVnZWQ6IHRydWUsXG4gICAgICB9LFxuICAgICAgZW52aXJvbm1lbnRWYXJpYWJsZXM6IHtcbiAgICAgICAgRUNSX1JFUE9fVVJJOiB7IHZhbHVlOiB0aGlzLmVjclJlcG9zaXRvcnkucmVwb3NpdG9yeVVyaSB9LFxuICAgICAgfSxcbiAgICAgIGJ1aWxkU3BlYzogQnVpbGRTcGVjLmZyb21PYmplY3QoYnVpbGRTcGVjT2JqKSxcbiAgICAgIC4uLihidWlsZExvZ0dyb3VwUHJvcCAmJiB7XG4gICAgICAgIGxvZ2dpbmc6IHtcbiAgICAgICAgICBjbG91ZFdhdGNoOiB7XG4gICAgICAgICAgICBsb2dHcm91cDogYnVpbGRMb2dHcm91cFByb3AsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgdnBjLFxuICAgICAgc2VjdXJpdHlHcm91cHMsXG4gICAgICBzdWJuZXRTZWxlY3Rpb24sXG4gICAgfSk7XG5cbiAgICAvLyBHcmFudCBDb2RlQnVpbGQgdGhlIGFiaWxpdHkgdG8gaW50ZXJhY3Qgd2l0aCBFQ1JcbiAgICB0aGlzLmVjclJlcG9zaXRvcnkuZ3JhbnRQdWxsUHVzaChjb2RlQnVpbGRQcm9qZWN0KTtcbiAgICBjb2RlQnVpbGRQcm9qZWN0LmFkZFRvUm9sZVBvbGljeShcbiAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICBhY3Rpb25zOiBbXG4gICAgICAgICAgJ2VjcjpHZXRBdXRob3JpemF0aW9uVG9rZW4nLFxuICAgICAgICAgICdlY3I6R2V0RG93bmxvYWRVcmxGb3JMYXllcicsXG4gICAgICAgICAgJ2VjcjpCYXRjaENoZWNrTGF5ZXJBdmFpbGFiaWxpdHknLFxuICAgICAgICAgICdlY3I6QmF0Y2hHZXRJbWFnZScsXG4gICAgICAgIF0sXG4gICAgICAgIHJlc291cmNlczogWycqJ10sXG4gICAgICB9KSxcbiAgICApO1xuICAgIGlmIChlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXMgJiYgZWNyUHVsbFRocm91Z2hDYWNoZVByZWZpeGVzLmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbnN0IHN0YWNrID0gU3RhY2sub2YodGhpcyk7XG4gICAgICBjb2RlQnVpbGRQcm9qZWN0LmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogW1xuICAgICAgICAgICAgJ2VjcjpCYXRjaEdldEltYWdlJyxcbiAgICAgICAgICAgICdlY3I6R2V0RG93bmxvYWRVcmxGb3JMYXllcicsXG4gICAgICAgICAgICAnZWNyOkJhdGNoQ2hlY2tMYXllckF2YWlsYWJpbGl0eScsXG4gICAgICAgICAgICAnZWNyOkJhdGNoSW1wb3J0VXBzdHJlYW1JbWFnZScsXG4gICAgICAgICAgICAnZWNyOkNyZWF0ZVJlcG9zaXRvcnknLFxuICAgICAgICAgIF0sXG4gICAgICAgICAgcmVzb3VyY2VzOiBlY3JQdWxsVGhyb3VnaENhY2hlUHJlZml4ZXMubWFwKFxuICAgICAgICAgICAgKHByZWZpeCkgPT4gYGFybjphd3M6ZWNyOiR7c3RhY2sucmVnaW9ufToke3N0YWNrLmFjY291bnR9OnJlcG9zaXRvcnkvJHtwcmVmaXh9LypgLFxuICAgICAgICAgICksXG4gICAgICAgIH0pLFxuICAgICAgKTtcbiAgICB9XG4gICAgaWYgKGRvY2tlckxvZ2luU2VjcmV0QXJuKSB7XG4gICAgICBjb2RlQnVpbGRQcm9qZWN0LmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogWydzZWNyZXRzbWFuYWdlcjpHZXRTZWNyZXRWYWx1ZSddLFxuICAgICAgICAgIHJlc291cmNlczogW2RvY2tlckxvZ2luU2VjcmV0QXJuXSxcbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIH1cblxuICAgIC8vIENvbmRpdGlvbmFsbHkgZ3JhbnQgS01TIGVuY3J5cHQvZGVjcnlwdCBpZiBhIGtleSBpcyB1c2VkXG4gICAgaWYgKGVuY3J5cHRpb25LZXkpIHtcbiAgICAgIGVuY3J5cHRpb25LZXkuZ3JhbnRFbmNyeXB0RGVjcnlwdChjb2RlQnVpbGRQcm9qZWN0LnJvbGUhKTtcbiAgICB9XG5cbiAgICAvLyBSZXNvbHZlIHRoZSBzZXJ2aWNlIHRva2VuOiBzaGFyZWQgcHJvdmlkZXIgb3IgcGVyLWluc3RhbmNlIExhbWJkYXNcbiAgICBsZXQgc2VydmljZVRva2VuOiBzdHJpbmc7XG4gICAgaWYgKHNoYXJlZFByb3ZpZGVyKSB7XG4gICAgICBzaGFyZWRQcm92aWRlci5yZWdpc3RlclByb2plY3QoY29kZUJ1aWxkUHJvamVjdCwgdGhpcy5lY3JSZXBvc2l0b3J5LCBlbmNyeXB0aW9uS2V5KTtcbiAgICAgIHNlcnZpY2VUb2tlbiA9IHNoYXJlZFByb3ZpZGVyLnNlcnZpY2VUb2tlbjtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3Qgb25FdmVudEhhbmRsZXJGdW5jdGlvbiA9IG5ldyBGdW5jdGlvbih0aGlzLCAnT25FdmVudEhhbmRsZXJGdW5jdGlvbicsIHtcbiAgICAgICAgcnVudGltZTogUnVudGltZS5OT0RFSlNfMjJfWCxcbiAgICAgICAgY29kZTogQ29kZS5mcm9tQXNzZXQocGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uL29uRXZlbnQnKSksXG4gICAgICAgIGhhbmRsZXI6ICdvbkV2ZW50LmhhbmRsZXInLFxuICAgICAgICB0aW1lb3V0OiBEdXJhdGlvbi5taW51dGVzKDE1KSxcbiAgICAgIH0pO1xuICAgICAgb25FdmVudEhhbmRsZXJGdW5jdGlvbi5hZGRUb1JvbGVQb2xpY3koXG4gICAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICAgIGFjdGlvbnM6IFsnY29kZWJ1aWxkOlN0YXJ0QnVpbGQnXSxcbiAgICAgICAgICByZXNvdXJjZXM6IFtjb2RlQnVpbGRQcm9qZWN0LnByb2plY3RBcm5dLFxuICAgICAgICB9KSxcbiAgICAgICk7XG4gICAgICBvbkV2ZW50SGFuZGxlckZ1bmN0aW9uLmFkZFRvUm9sZVBvbGljeShcbiAgICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogW1xuICAgICAgICAgICAgJ2xvZ3M6Q3JlYXRlTG9nR3JvdXAnLFxuICAgICAgICAgICAgJ2xvZ3M6UHV0UmV0ZW50aW9uUG9saWN5JyxcbiAgICAgICAgICAgICdsb2dzOkRlbGV0ZUxvZ0dyb3VwJyxcbiAgICAgICAgICBdLFxuICAgICAgICAgIHJlc291cmNlczogWydhcm46YXdzOmxvZ3M6KjoqOmxvZy1ncm91cDovZG9ja2VyLWJ1aWxkZXIvKiddLFxuICAgICAgICB9KSxcbiAgICAgICk7XG5cbiAgICAgIGNvbnN0IGlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24gPSBuZXcgRnVuY3Rpb24odGhpcywgJ0lzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24nLCB7XG4gICAgICAgIHJ1bnRpbWU6IFJ1bnRpbWUuTk9ERUpTXzIyX1gsXG4gICAgICAgIGNvZGU6IENvZGUuZnJvbUFzc2V0KHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLi9pc0NvbXBsZXRlJykpLFxuICAgICAgICBlbnZpcm9ubWVudDoge1xuICAgICAgICAgIElNQUdFX1RBRzogaW1hZ2VUYWcsXG4gICAgICAgIH0sXG4gICAgICAgIGhhbmRsZXI6ICdpc0NvbXBsZXRlLmhhbmRsZXInLFxuICAgICAgICB0aW1lb3V0OiBEdXJhdGlvbi5taW51dGVzKDE1KSxcbiAgICAgIH0pO1xuICAgICAgaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbi5hZGRUb1JvbGVQb2xpY3koXG4gICAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICAgIGFjdGlvbnM6IFtcbiAgICAgICAgICAgICdjb2RlYnVpbGQ6QmF0Y2hHZXRCdWlsZHMnLFxuICAgICAgICAgICAgJ2NvZGVidWlsZDpMaXN0QnVpbGRzRm9yUHJvamVjdCcsXG4gICAgICAgICAgICAnbG9nczpHZXRMb2dFdmVudHMnLFxuICAgICAgICAgICAgJ2xvZ3M6RGVzY3JpYmVMb2dTdHJlYW1zJyxcbiAgICAgICAgICAgICdsb2dzOkRlc2NyaWJlTG9nR3JvdXBzJyxcbiAgICAgICAgICBdLFxuICAgICAgICAgIHJlc291cmNlczogWycqJ10sXG4gICAgICAgIH0pLFxuICAgICAgKTtcblxuICAgICAgaWYgKGVuY3J5cHRpb25LZXkpIHtcbiAgICAgICAgZW5jcnlwdGlvbktleS5ncmFudEVuY3J5cHREZWNyeXB0KG9uRXZlbnRIYW5kbGVyRnVuY3Rpb24pO1xuICAgICAgICBlbmNyeXB0aW9uS2V5LmdyYW50RW5jcnlwdERlY3J5cHQoaXNDb21wbGV0ZUhhbmRsZXJGdW5jdGlvbik7XG4gICAgICB9XG4gICAgICB0aGlzLmVjclJlcG9zaXRvcnkuZ3JhbnRQdWxsUHVzaChvbkV2ZW50SGFuZGxlckZ1bmN0aW9uKTtcbiAgICAgIHRoaXMuZWNyUmVwb3NpdG9yeS5ncmFudFB1bGxQdXNoKGlzQ29tcGxldGVIYW5kbGVyRnVuY3Rpb24pO1xuXG4gICAgICBjb25zdCBwcm92aWRlciA9IG5ldyBQcm92aWRlcih0aGlzLCAnQ3VzdG9tUmVzb3VyY2VQcm92aWRlcicsIHtcbiAgICAgICAgb25FdmVudEhhbmRsZXI6IG9uRXZlbnRIYW5kbGVyRnVuY3Rpb24sXG4gICAgICAgIGlzQ29tcGxldGVIYW5kbGVyOiBpc0NvbXBsZXRlSGFuZGxlckZ1bmN0aW9uLFxuICAgICAgICBxdWVyeUludGVydmFsOiBjb21wbGV0ZW5lc3NRdWVyeUludGVydmFsID8/IER1cmF0aW9uLnNlY29uZHMoMzApLFxuICAgICAgfSk7XG4gICAgICBzZXJ2aWNlVG9rZW4gPSBwcm92aWRlci5zZXJ2aWNlVG9rZW47XG4gICAgfVxuXG4gICAgLy8gQ3VzdG9tIFJlc291cmNlIHRoYXQgdHJpZ2dlcnMgdGhlIENvZGVCdWlsZCBhbmQgd2FpdHMgZm9yIGNvbXBsZXRpb25cbiAgICBjb25zdCBidWlsZFRyaWdnZXJSZXNvdXJjZSA9IG5ldyBDdXN0b21SZXNvdXJjZSh0aGlzLCAnQnVpbGRUcmlnZ2VyUmVzb3VyY2UnLCB7XG4gICAgICBzZXJ2aWNlVG9rZW4sXG4gICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgIFByb2plY3ROYW1lOiBjb2RlQnVpbGRQcm9qZWN0LnByb2plY3ROYW1lLFxuICAgICAgICBJbWFnZVRhZzogaW1hZ2VUYWcsXG4gICAgICAgIFRyaWdnZXI6IHNvdXJjZUFzc2V0LmFzc2V0SGFzaCxcbiAgICAgICAgUmV0YWluQnVpbGRMb2dzOiByZXRhaW5CdWlsZExvZ3MgPyAndHJ1ZScgOiAnZmFsc2UnLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICBidWlsZFRyaWdnZXJSZXNvdXJjZS5ub2RlLmFkZERlcGVuZGVuY3koY29kZUJ1aWxkUHJvamVjdCk7XG5cbiAgICAvLyBSZXRyaWV2ZSB0aGUgZmluYWwgRG9ja2VyIGltYWdlIHRhZyBmcm9tIERhdGEuSW1hZ2VUYWdcbiAgICBjb25zdCBpbWFnZVRhZ1JlZiA9IGJ1aWxkVHJpZ2dlclJlc291cmNlLmdldEF0dFN0cmluZygnSW1hZ2VUYWcnKTtcbiAgICB0aGlzLmNvbnRhaW5lckltYWdlID0gQ29udGFpbmVySW1hZ2UuZnJvbUVjclJlcG9zaXRvcnkodGhpcy5lY3JSZXBvc2l0b3J5LCBpbWFnZVRhZ1JlZik7XG4gICAgdGhpcy5kb2NrZXJJbWFnZUNvZGUgPSBEb2NrZXJJbWFnZUNvZGUuZnJvbUVjcih0aGlzLmVjclJlcG9zaXRvcnksIHtcbiAgICAgIHRhZ09yRGlnZXN0OiBpbWFnZVRhZ1JlZixcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -1,24 +1,84 @@
1
1
  const { CodeBuildClient, StartBuildCommand } = require('@aws-sdk/client-codebuild');
2
+ const {
3
+ CloudWatchLogsClient,
4
+ CreateLogGroupCommand,
5
+ PutRetentionPolicyCommand,
6
+ DeleteLogGroupCommand,
7
+ } = require('@aws-sdk/client-cloudwatch-logs');
2
8
  const crypto = require('crypto');
3
9
 
10
+ function buildLogGroupName(projectName) {
11
+ return `/docker-builder/${projectName}`;
12
+ }
13
+
14
+ async function ensureLogGroup(logsClient, logGroupName) {
15
+ try {
16
+ await logsClient.send(new CreateLogGroupCommand({ logGroupName }));
17
+ console.log(`Created log group: ${logGroupName}`);
18
+ } catch (error) {
19
+ if (error.name === 'ResourceAlreadyExistsException') {
20
+ console.log(`Log group already exists: ${logGroupName}`);
21
+ } else {
22
+ throw error;
23
+ }
24
+ }
25
+
26
+ await logsClient.send(new PutRetentionPolicyCommand({
27
+ logGroupName,
28
+ retentionInDays: 7,
29
+ }));
30
+ console.log(`Set 7-day retention on: ${logGroupName}`);
31
+ }
32
+
33
+ async function deleteLogGroup(logsClient, logGroupName) {
34
+ try {
35
+ await logsClient.send(new DeleteLogGroupCommand({ logGroupName }));
36
+ console.log(`Deleted log group: ${logGroupName}`);
37
+ } catch (error) {
38
+ if (error.name === 'ResourceNotFoundException') {
39
+ console.log(`Log group does not exist, nothing to delete: ${logGroupName}`);
40
+ } else {
41
+ throw error;
42
+ }
43
+ }
44
+ }
45
+
4
46
  exports.handler = async (event, context) => {
5
47
  console.log('Event:', JSON.stringify(event, null, 2));
6
48
 
7
- // Initialize the AWS SDK v3 CodeBuild client
8
- const codebuildClient = new CodeBuildClient({ region: process.env.AWS_REGION });
49
+ const region = process.env.AWS_REGION;
50
+ const codebuildClient = new CodeBuildClient({ region });
51
+ const logsClient = new CloudWatchLogsClient({ region });
9
52
 
10
- // Set the PhysicalResourceId
11
53
  let physicalResourceId = event.PhysicalResourceId || event.LogicalResourceId;
12
54
 
55
+ const projectName = event.ResourceProperties.ProjectName;
56
+ const retainBuildLogs = event.ResourceProperties.RetainBuildLogs === 'true';
57
+ const logGroupName = buildLogGroupName(projectName);
58
+
13
59
  if (event.RequestType === 'Create' || event.RequestType === 'Update') {
60
+ if (retainBuildLogs) {
61
+ await ensureLogGroup(logsClient, logGroupName);
62
+ } else {
63
+ await deleteLogGroup(logsClient, logGroupName);
64
+ }
65
+
14
66
  const params = {
15
- projectName: event.ResourceProperties.ProjectName,
16
- idempotencyToken: crypto.randomUUID()
67
+ projectName,
68
+ idempotencyToken: crypto.randomUUID(),
69
+ ...(retainBuildLogs && {
70
+ logsConfigOverride: {
71
+ cloudWatchLogs: {
72
+ status: 'ENABLED',
73
+ groupName: logGroupName,
74
+ },
75
+ },
76
+ }),
17
77
  };
18
78
 
19
79
  try {
20
- const command = new StartBuildCommand(params); // Create the command
21
- const build = await codebuildClient.send(command); // Send the command
80
+ const command = new StartBuildCommand(params);
81
+ const build = await codebuildClient.send(command);
22
82
  console.log('Started build:', JSON.stringify(build, null, 2));
23
83
  } catch (error) {
24
84
  console.error('Error starting build:', error);
@@ -30,8 +90,8 @@ exports.handler = async (event, context) => {
30
90
  };
31
91
  }
32
92
  } else if (event.RequestType === 'Delete') {
33
- // No action needed for delete, but ensure PhysicalResourceId remains the same
34
- console.log('Delete request received. No action required.');
93
+ await deleteLogGroup(logsClient, logGroupName);
94
+ console.log('Delete request received. Cleaned up log group.');
35
95
  }
36
96
 
37
97
  return {
package/package.json CHANGED
@@ -98,7 +98,7 @@
98
98
  "publishConfig": {
99
99
  "access": "public"
100
100
  },
101
- "version": "1.11.1",
101
+ "version": "1.12.0",
102
102
  "jest": {
103
103
  "coverageProvider": "v8",
104
104
  "testMatch": [