aws-delivlib 14.5.8 → 14.6.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/lib/pipeline.d.ts +8 -0
- package/lib/pipeline.js +23 -1
- package/lib/signing/nuget/sign.sh +64 -0
- package/lib/signing.d.ts +52 -0
- package/lib/signing.js +73 -0
- package/package.json +1 -1
package/lib/pipeline.d.ts
CHANGED
|
@@ -8,6 +8,7 @@ import { AutoBump, AutoBumpProps } from './pull-request';
|
|
|
8
8
|
import { AutoMergeBackPipelineOptions } from './pull-request/merge-back';
|
|
9
9
|
import { IRepo } from './repo';
|
|
10
10
|
import { Shellable, ShellableProps } from './shellable';
|
|
11
|
+
import * as signing from './signing';
|
|
11
12
|
export interface PipelineProps {
|
|
12
13
|
/**
|
|
13
14
|
* The source repository to build (e.g. GitHubRepo).
|
|
@@ -158,6 +159,7 @@ export declare class Pipeline extends Construct {
|
|
|
158
159
|
private readonly branch;
|
|
159
160
|
private readonly notify?;
|
|
160
161
|
private stages;
|
|
162
|
+
private _signingOutput?;
|
|
161
163
|
private readonly concurrency?;
|
|
162
164
|
private readonly repo;
|
|
163
165
|
private readonly dryRun;
|
|
@@ -165,6 +167,10 @@ export declare class Pipeline extends Construct {
|
|
|
165
167
|
private readonly buildSpec?;
|
|
166
168
|
private firstPublishStageName?;
|
|
167
169
|
constructor(parent: Construct, name: string, props: PipelineProps);
|
|
170
|
+
/**
|
|
171
|
+
* Signing output artifact
|
|
172
|
+
*/
|
|
173
|
+
get signingOutput(): cpipeline.Artifact | undefined;
|
|
168
174
|
notifyOnFailure(notification: IPipelineNotification): void;
|
|
169
175
|
/**
|
|
170
176
|
* Add an action to run a shell script to the pipeline
|
|
@@ -191,6 +197,8 @@ export declare class Pipeline extends Construct {
|
|
|
191
197
|
* @param options the options to configure the change control policy.
|
|
192
198
|
*/
|
|
193
199
|
addChangeControl(options?: AddChangeControlOptions): ChangeController;
|
|
200
|
+
addSigning(signer: signing.ISigner, options?: signing.AddSigningOptions): void;
|
|
201
|
+
signNuGetWithSigner(options: signing.SignNuGetWithSignerProps & signing.AddSigningOptions): void;
|
|
194
202
|
publishToNpm(options: publishing.PublishToNpmProjectProps & AddPublishOptions): void;
|
|
195
203
|
publishToMaven(options: publishing.PublishToMavenProjectProps & AddPublishOptions): void;
|
|
196
204
|
publishToNuGet(options: publishing.PublishToNuGetProjectProps & AddPublishOptions): void;
|
package/lib/pipeline.js
CHANGED
|
@@ -36,8 +36,10 @@ const publishing = __importStar(require("./publishing"));
|
|
|
36
36
|
const pull_request_1 = require("./pull-request");
|
|
37
37
|
const repo_1 = require("./repo");
|
|
38
38
|
const shellable_1 = require("./shellable");
|
|
39
|
+
const signing = __importStar(require("./signing"));
|
|
39
40
|
const util_1 = require("./util");
|
|
40
41
|
const PUBLISH_STAGE_NAME = 'Publish';
|
|
42
|
+
const SIGINING_STAGE_NAME = 'Sign';
|
|
41
43
|
const TEST_STAGE_NAME = 'Test';
|
|
42
44
|
const METRIC_NAMESPACE = 'CDK/Delivlib';
|
|
43
45
|
const FAILURE_METRIC_NAME = 'Failures';
|
|
@@ -102,6 +104,12 @@ class Pipeline extends constructs_1.Construct {
|
|
|
102
104
|
this.autoBuildProject = this.autoBuild(props.autoBuildOptions).project;
|
|
103
105
|
}
|
|
104
106
|
}
|
|
107
|
+
/**
|
|
108
|
+
* Signing output artifact
|
|
109
|
+
*/
|
|
110
|
+
get signingOutput() {
|
|
111
|
+
return this._signingOutput;
|
|
112
|
+
}
|
|
105
113
|
notifyOnFailure(notification) {
|
|
106
114
|
notification.bind({
|
|
107
115
|
pipeline: this,
|
|
@@ -163,6 +171,20 @@ class Pipeline extends constructs_1.Construct {
|
|
|
163
171
|
pipelineStage: publishStage,
|
|
164
172
|
});
|
|
165
173
|
}
|
|
174
|
+
addSigning(signer, options = {}) {
|
|
175
|
+
var _a;
|
|
176
|
+
const signingStageName = (_a = options.stageName) !== null && _a !== void 0 ? _a : SIGINING_STAGE_NAME;
|
|
177
|
+
const stage = this.getOrCreateStage(signingStageName);
|
|
178
|
+
this._signingOutput = signer.addToPipeline(stage, `${signer.node.id}Sign`, {
|
|
179
|
+
inputArtifact: options.inputArtifact || this.buildOutput,
|
|
180
|
+
runOrder: this.determineRunOrderForNewAction(stage),
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
signNuGetWithSigner(options) {
|
|
184
|
+
this.addSigning(new signing.SignNuGetWithSigner(this, 'NuGetSigning', {
|
|
185
|
+
...options,
|
|
186
|
+
}), options);
|
|
187
|
+
}
|
|
166
188
|
publishToNpm(options) {
|
|
167
189
|
this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {
|
|
168
190
|
dryRun: this.dryRun,
|
|
@@ -342,4 +364,4 @@ class Pipeline extends constructs_1.Construct {
|
|
|
342
364
|
}
|
|
343
365
|
}
|
|
344
366
|
exports.Pipeline = Pipeline;
|
|
345
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Duration,\n  aws_cloudwatch as cloudwatch,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam, aws_s3 as s3,\n  aws_sns as sns,\n  aws_sns_subscriptions as sns_subs,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\n\nimport { AutoBuild, AutoBuildOptions } from './auto-build';\nimport { createBuildEnvironment } from './build-env';\nimport { Canary, CanaryProps } from './canary';\nimport { ChangeController } from './change-controller';\nimport { ChimeNotifier } from './chime-notifier';\nimport { PipelineWatcher } from './pipeline-watcher';\nimport * as publishing from './publishing';\nimport { AutoBump, AutoMergeBack, AutoBumpProps } from './pull-request';\nimport { AutoMergeBackPipelineOptions } from './pull-request/merge-back';\nimport { IRepo, WritableGitHubRepo } from './repo';\nimport { Shellable, ShellableProps } from './shellable';\nimport { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\nconst TEST_STAGE_NAME = 'Test';\nconst METRIC_NAMESPACE = 'CDK/Delivlib';\nconst FAILURE_METRIC_NAME = 'Failures';\n\nexport interface PipelineProps {\n  /**\n   * The source repository to build (e.g. GitHubRepo).\n   */\n  readonly repo: IRepo;\n\n  /**\n   * A display name for this pipeline.\n   */\n  readonly title?: string;\n\n  /**\n   * A physical name for this pipeline.\n   * @default - a new name will be generated.\n   */\n  readonly pipelineName?: string;\n\n  /**\n   * Branch to build.\n   * @default master\n   */\n  readonly branch?: string;\n\n  /**\n   * Email to send failure notifications.\n   * @default - No email notifications\n   */\n  readonly notificationEmail?: string;\n\n  /**\n   * The image used for the builds.\n   *\n   * @default jsii/superchain (see docs)\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The name of the CodeBuild project that will be part of this pipeline.\n   * @default - `${pipelineName}-Build`, if `pipelineName` property is specified; automatically generated, otherwise.\n   */\n  readonly buildProjectName?: string;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * @default taken from {@link #buildImage#defaultComputeType}\n   */\n  readonly computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Environment variables to pass to build\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * Optional buildspec, as an alternative to a buildspec.yml file\n   */\n  readonly buildSpec?: cbuild.BuildSpec;\n\n  /**\n   * Indicates whether to re-run the pipeline after you've updated it.\n   * @default true\n   */\n  readonly restartExecutionOnUpdate?: boolean;\n\n  /**\n   * Indicates the concurrency limit test and publish stages.\n   *\n   * For example, if this value is 2, then only two actions will execute concurrently.\n   * If this value is 1, the pipeline will not have any concurrent execution.\n   *\n   * @default - no limit\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Set the default dryRun for all publishing steps\n   *\n   * (Can still be changed when adding a step).\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Automatically build commits that are pushed to this repository, including PR builds on github.\n   *\n   * @default false\n   */\n  readonly autoBuild?: boolean;\n\n  /**\n   * Options for auto-build\n   *\n   * @default - 'autoBuildOptions.publicLogs' will be set to its default. 'autoBuildOptions.buildspec' will be configured to match with the\n   * 'buildSpec' property.\n   */\n  readonly autoBuildOptions?: AutoBuildOptions;\n\n  /**\n   * Post a notification to the given Chime webhooks if the pipeline fails\n   * @default - no Chime notifications on pipeline failure\n   * @deprecated - use `notifyOnFailure()` instead in combination with `PipelineNotification.chime()`.\n   */\n  readonly chimeFailureWebhooks?: string[];\n\n  /**\n   * The Chime message to post\n   *\n   * @default - A default message\n   */\n  readonly chimeMessage?: string;\n\n  /**\n   * Build timeout\n   *\n   * How long the build can take at maximum (before failing with an error).\n   *\n   * @default - Duration.hours(8)\n   */\n  readonly buildTimeout?: Duration;\n}\n\nexport interface PipelineNotificationBindOptions {\n  readonly pipeline: Pipeline;\n}\n\nexport interface IPipelineNotification {\n  bind(pipeline: PipelineNotificationBindOptions): void;\n}\n\n/**\n * Options for configuring an auto bump for this pipeline.\n */\nexport interface AutoBumpOptions extends Omit<AutoBumpProps, 'repo'> {\n}\n\n/**\n * Defines a delivlib CI/CD pipeline.\n */\nexport class Pipeline extends Construct {\n  public buildRole?: iam.IRole;\n  public readonly failureAlarm: cloudwatch.Alarm;\n  public readonly buildOutput: cpipeline.Artifact;\n  public readonly sourceArtifact: cpipeline.Artifact;\n\n  /**\n   * The primary CodeBuild project of this pipeline.\n   */\n  public readonly buildProject: cbuild.IProject;\n\n  /**\n   * The auto build project. undefined if 'autoBuild' is disabled for this pipeline.\n   */\n  public readonly autoBuildProject?: cbuild.Project;\n\n  /*\n   * The underlying CodePipeline Pipeline object that models this pipeline.\n   */\n  public readonly pipeline: cpipeline.Pipeline;\n  private readonly branch: string;\n  private readonly notify?: sns.Topic;\n  private stages: { [name: string]: cpipeline.IStage } = { };\n\n  private readonly concurrency?: number;\n  private readonly repo: IRepo;\n  private readonly dryRun: boolean;\n  private readonly buildEnvironment: cbuild.BuildEnvironment;\n  private readonly buildSpec?: cbuild.BuildSpec;\n  private firstPublishStageName?: string;\n\n  constructor(parent: Construct, name: string, props: PipelineProps) {\n    super(parent, name);\n\n    this.concurrency = props.concurrency;\n    this.repo = props.repo;\n    this.dryRun = !!props.dryRun;\n\n    this.pipeline = new cpipeline.Pipeline(this, 'BuildPipeline', {\n      pipelineName: props.pipelineName,\n      restartExecutionOnUpdate: props.restartExecutionOnUpdate === undefined ? true : props.restartExecutionOnUpdate,\n    });\n\n    this.branch = props.branch || 'master';\n    this.sourceArtifact = props.repo.createSourceStage(this.pipeline, this.branch);\n\n    this.buildEnvironment = createBuildEnvironment(props);\n    this.buildSpec = props.buildSpec;\n\n    let buildProjectName = props.buildProjectName;\n    if (buildProjectName === undefined && props.pipelineName !== undefined) {\n      buildProjectName = `${props.pipelineName}-Build`;\n    }\n    this.buildProject = new cbuild.PipelineProject(this, 'BuildProject', {\n      projectName: buildProjectName,\n      environment: this.buildEnvironment,\n      buildSpec: this.buildSpec,\n      timeout: props.buildTimeout ?? Duration.hours(8),\n      ssmSessionPermissions: true,\n    });\n\n    this.buildRole = this.buildProject.role;\n    this.buildRole!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    const buildStage = this.getOrCreateStage('Build');\n    const buildOutput = new cpipeline.Artifact();\n    buildStage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: 'Build',\n      project: this.buildProject,\n      input: this.sourceArtifact,\n      outputs: [buildOutput],\n    }));\n    this.buildOutput = buildOutput;\n\n    if (props.notificationEmail) {\n      this.notify = new sns.Topic(this, 'NotificationsTopic');\n      this.notify.addSubscription(new sns_subs.EmailSubscription(props.notificationEmail));\n    }\n\n    // add a failure alarm for the entire pipeline.\n    this.failureAlarm = this.addFailureAlarm(props.title);\n\n    // emit an SNS notification every time build fails.\n    this.addBuildFailureNotification(this.buildProject, `${props.title} build failed`);\n\n    // Also emit to Chime webhooks if configured\n    if (props.chimeFailureWebhooks) {\n      new ChimeNotifier(this, 'ChimeNotifier', {\n        pipeline: this.pipeline,\n        message: props.chimeMessage,\n        webhookUrls: props.chimeFailureWebhooks,\n      });\n    }\n\n    if (props.autoBuild) {\n      this.autoBuildProject = this.autoBuild(props.autoBuildOptions).project;\n    }\n  }\n\n  public notifyOnFailure(notification: IPipelineNotification) {\n    notification.bind({\n      pipeline: this,\n    });\n  }\n\n  /**\n   * Add an action to run a shell script to the pipeline\n   *\n   * @return The Shellable and the Action added to the pipeline.\n   */\n  public addShellable(stageName: string, id: string, options: AddShellableOptions): {\n    shellable: Shellable; action: cpipeline_actions.CodeBuildAction;} {\n    const stage = this.getOrCreateStage(stageName);\n\n    const sh = new Shellable(this, id, options);\n    const action = sh.addToPipeline(\n      stage,\n      options.actionName || `Action${id}`,\n      options.inputArtifact || this.buildOutput,\n      this.determineRunOrderForNewAction(stage));\n\n    if (options.failureNotification) {\n      this.addBuildFailureNotification(sh.project, options.failureNotification);\n    }\n\n    return { shellable: sh, action };\n  }\n\n  public addTest(id: string, props: ShellableProps): {shellable: Shellable; action: cpipeline_actions.CodeBuildAction} {\n    return this.addShellable(TEST_STAGE_NAME, id, {\n      actionName: `Test${id}`,\n      failureNotification: `Test ${id} failed`,\n      ...props,\n    });\n  }\n\n  /**\n   * Convenience/discovery method that defines a canary test in your account.\n   * @param id the construct id\n   * @param props canary options\n   */\n  public addCanary(id: string, props: CanaryProps) {\n    return new Canary(this, `Canary${id}`, props);\n  }\n\n  public addPublish(publisher: IPublisher, options: AddPublishOptions = {}) {\n    const publishStageName = options.stageName ?? PUBLISH_STAGE_NAME;\n    if (!this.firstPublishStageName) {\n      this.firstPublishStageName = publishStageName;\n    }\n    const stage = this.getOrCreateStage(publishStageName);\n\n    publisher.addToPipeline(stage, `${publisher.node.id}Publish`, {\n      inputArtifact: options.inputArtifact || this.buildOutput,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n  }\n\n  /**\n   * Adds a change control policy to block transitions into the publish stage during certain time windows.\n   * @param options the options to configure the change control policy.\n   */\n  public addChangeControl(options: AddChangeControlOptions = { }): ChangeController {\n    const publishStage = this.getStage(this.firstPublishStageName ?? PUBLISH_STAGE_NAME);\n    if (!publishStage) {\n      throw new Error(`This pipeline does not have a ${PUBLISH_STAGE_NAME} stage yet. Add one first.`);\n    }\n\n    return new ChangeController(this, 'ChangeController', {\n      ...options,\n      pipelineStage: publishStage,\n    });\n  }\n\n  public publishToNpm(options: publishing.PublishToNpmProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToMaven(options: publishing.PublishToMavenProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToMavenProject(this, 'Maven', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToNuGet(options: publishing.PublishToNuGetProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNuGetProject(this, 'NuGet', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHubPages(options: publishing.PublishDocsToGitHubProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishDocsToGitHubProject(this, 'GitHubPages', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHub(options: publishing.PublishToGitHubProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToGitHub(this, 'GitHub', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToPyPI(options: publishing.PublishToPyPiProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToPyPi(this, 'PyPI', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToS3(id: string, options: publishing.PublishToS3Props & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToS3(this, id, {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  /**\n   * Publish Golang code from `go` directory in build artifact to a GitHub repository.\n   */\n  public publishToGolang(options: publishing.PublishToGolangProps) {\n    this.addPublish(new publishing.PublishToGolang(this, 'Golang', {\n      dryRun: this.dryRun,\n      ...options,\n    }));\n  }\n\n  /**\n   * Enables automatic bumps for the source repo.\n   * @param options Options for auto bump (see AutoBumpOptions for description of defaults)\n   */\n  public autoBump(options?: AutoBumpOptions): AutoBump {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-bump');\n    }\n\n    const autoBump = new AutoBump(this, 'AutoBump', {\n      repo: this.repo,\n      ...options,\n    });\n\n    return autoBump;\n  }\n\n  /**\n   * Enables automatic merge backs for the source repo.\n   * @param options Options for auto bump (see AutoMergeBackPipelineOptions for description of defaults)\n   */\n  public autoMergeBack(options?: AutoMergeBackPipelineOptions) {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-merge-back');\n    }\n\n    const mergeBack = new AutoMergeBack(this, 'MergeBack', {\n      repo: this.repo,\n      ...options,\n    });\n\n    if (options?.stage) {\n\n      const afterStage = this.getStage(options.stage.after);\n\n      if (!afterStage) {\n        throw new Error(`'options.stage.after' must be configured to an existing stage: ${options.stage.after}`);\n      }\n\n      const stage = this.getOrCreateStage(options.stage.name ?? 'MergeBack', { justAfter: afterStage });\n      stage.addAction(new cpipeline_actions.CodeBuildAction({\n        actionName: 'CreateMergeBackPullRequest',\n        project: mergeBack.pr.project,\n        input: this.sourceArtifact,\n      }));\n    }\n  }\n\n  /**\n   * Enables automatic builds of pull requests in the Github repository and posts the\n   * results back as a comment with a public link to the build logs.\n   */\n  public autoBuild(options: AutoBuildOptions = { }): AutoBuild {\n    return new AutoBuild(this, 'AutoBuild', {\n      environment: this.buildEnvironment,\n      repo: this.repo,\n      buildSpec: options.buildSpec || this.buildSpec,\n      ...options,\n    });\n  }\n\n  /**\n   * The metric that tracks pipeline failures.\n   */\n  public metricFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: METRIC_NAMESPACE,\n      metricName: FAILURE_METRIC_NAME,\n      dimensionsMap: {\n        Pipeline: this.pipeline.pipelineName,\n      },\n      statistic: 'Sum',\n      ...options,\n    });\n  }\n\n  /**\n   * The metrics that track failure of each action within the pipeline.\n   */\n  public metricActionFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric[] {\n    return flatMap(this.pipeline.stages, stage => stage.actions.map(action => {\n      return new cloudwatch.Metric({\n        namespace: METRIC_NAMESPACE,\n        metricName: FAILURE_METRIC_NAME,\n        dimensionsMap: {\n          Pipeline: this.pipeline.pipelineName,\n          Action: action.actionProperties.actionName,\n        },\n        statistic: 'Sum',\n        ...options,\n      });\n    }));\n  }\n\n  public addManualApprovalToStage(stageName: string, props?: cpipeline_actions.ManualApprovalActionProps) {\n    const stage = this.getOrCreateStage(stageName);\n    stage.addAction(new cpipeline_actions.ManualApprovalAction(props ?? {\n      actionName: 'ManualApprovalAction',\n    }));\n  }\n\n  private addFailureAlarm(title?: string): cloudwatch.Alarm {\n    return new PipelineWatcher(this, 'PipelineWatcher', {\n      pipeline: this.pipeline,\n      metricNamespace: METRIC_NAMESPACE,\n      failureMetricName: FAILURE_METRIC_NAME,\n      title,\n    }).alarm;\n  }\n\n  private addBuildFailureNotification(buildProject: cbuild.IProject, message: string) {\n    if (!this.notify) {\n      return;\n    }\n\n    buildProject.onBuildFailed('OnBuildFailed').addTarget(new events_targets.SnsTopic(this.notify, {\n      message: events.RuleTargetInput.fromText(message),\n    }));\n  }\n\n  /**\n   * @returns the stage or undefined if the stage doesn't exist\n   */\n  private getStage(stageName: string): cpipeline.IStage | undefined {\n    return this.stages[stageName];\n  }\n\n  private getOrCreateStage(stageName: string, placement?: cpipeline.StagePlacement): cpipeline.IStage {\n    // otherwise, group all actions so they run concurrently.\n    let stage = this.getStage(stageName);\n    if (!stage) {\n      stage = this.pipeline.addStage({\n        stageName,\n        placement,\n      });\n      this.stages[stageName] = stage;\n    }\n    return stage;\n  }\n\n  private determineRunOrderForNewAction(stage: cpipeline.IStage): number | undefined {\n    return determineRunOrder(stage.actions.length, this.concurrency);\n  }\n}\n\nexport interface IPublisher extends IConstruct {\n  addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void;\n}\n\nexport interface AddToPipelineOptions {\n  inputArtifact?: cpipeline.Artifact;\n  runOrder?: number;\n}\n\nexport interface AddChangeControlOptions {\n  /**\n   * The bucket in which the ChangeControl iCal document will be stored.\n   *\n   * @default a new bucket will be provisioned.\n   */\n  changeControlBucket?: s3.IBucket;\n\n  /**\n   * The key in which the iCal fille will be stored.\n   *\n   * @default 'change-control.ical'\n   */\n  changeControlObjectKey?: string;\n\n  /**\n   * Schedule to run the change controller on\n   *\n   * @default rate(15 minutes)\n   */\n  scheduleExpression?: string;\n}\n\nexport interface AddPublishOptions {\n  /**\n   * The input artifact to use\n   *\n   * @default Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n\n  /**\n   * Stage name to add publishing job to\n   *\n   * By default, this will be the stage name `'Publish'`, but if you want to\n   * separate out the publishing actions into different stages (in order to\n   * block/unblock them separately for example) you can change this.\n   *\n   * Stages appear in the pipeline in the order they are referenced for\n   * the first time.\n   *\n   * @default \"Publish\"\n   */\n  readonly stageName?: string;\n}\n\nexport interface AddShellableOptions extends ShellableProps {\n  /**\n   * String to use as action name\n   *\n   * @default Id\n   */\n  actionName?: string;\n\n  /**\n   * Message to use as failure notification\n   *\n   * @default No notification\n   */\n  failureNotification?: string;\n\n  /**\n   * The input artifact to use\n   *\n   * @default Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}
|
|
367
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Duration,\n  aws_cloudwatch as cloudwatch,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam, aws_s3 as s3,\n  aws_sns as sns,\n  aws_sns_subscriptions as sns_subs,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\n\nimport { AutoBuild, AutoBuildOptions } from './auto-build';\nimport { createBuildEnvironment } from './build-env';\nimport { Canary, CanaryProps } from './canary';\nimport { ChangeController } from './change-controller';\nimport { ChimeNotifier } from './chime-notifier';\nimport { PipelineWatcher } from './pipeline-watcher';\nimport * as publishing from './publishing';\nimport { AutoBump, AutoMergeBack, AutoBumpProps } from './pull-request';\nimport { AutoMergeBackPipelineOptions } from './pull-request/merge-back';\nimport { IRepo, WritableGitHubRepo } from './repo';\nimport { Shellable, ShellableProps } from './shellable';\nimport * as signing from './signing';\nimport { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\nconst SIGINING_STAGE_NAME = 'Sign';\nconst TEST_STAGE_NAME = 'Test';\nconst METRIC_NAMESPACE = 'CDK/Delivlib';\nconst FAILURE_METRIC_NAME = 'Failures';\n\nexport interface PipelineProps {\n  /**\n   * The source repository to build (e.g. GitHubRepo).\n   */\n  readonly repo: IRepo;\n\n  /**\n   * A display name for this pipeline.\n   */\n  readonly title?: string;\n\n  /**\n   * A physical name for this pipeline.\n   * @default - a new name will be generated.\n   */\n  readonly pipelineName?: string;\n\n  /**\n   * Branch to build.\n   * @default master\n   */\n  readonly branch?: string;\n\n  /**\n   * Email to send failure notifications.\n   * @default - No email notifications\n   */\n  readonly notificationEmail?: string;\n\n  /**\n   * The image used for the builds.\n   *\n   * @default jsii/superchain (see docs)\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The name of the CodeBuild project that will be part of this pipeline.\n   * @default - `${pipelineName}-Build`, if `pipelineName` property is specified; automatically generated, otherwise.\n   */\n  readonly buildProjectName?: string;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * @default taken from {@link #buildImage#defaultComputeType}\n   */\n  readonly computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Environment variables to pass to build\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * Optional buildspec, as an alternative to a buildspec.yml file\n   */\n  readonly buildSpec?: cbuild.BuildSpec;\n\n  /**\n   * Indicates whether to re-run the pipeline after you've updated it.\n   * @default true\n   */\n  readonly restartExecutionOnUpdate?: boolean;\n\n  /**\n   * Indicates the concurrency limit test and publish stages.\n   *\n   * For example, if this value is 2, then only two actions will execute concurrently.\n   * If this value is 1, the pipeline will not have any concurrent execution.\n   *\n   * @default - no limit\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Set the default dryRun for all publishing steps\n   *\n   * (Can still be changed when adding a step).\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Automatically build commits that are pushed to this repository, including PR builds on github.\n   *\n   * @default false\n   */\n  readonly autoBuild?: boolean;\n\n  /**\n   * Options for auto-build\n   *\n   * @default - 'autoBuildOptions.publicLogs' will be set to its default. 'autoBuildOptions.buildspec' will be configured to match with the\n   * 'buildSpec' property.\n   */\n  readonly autoBuildOptions?: AutoBuildOptions;\n\n  /**\n   * Post a notification to the given Chime webhooks if the pipeline fails\n   * @default - no Chime notifications on pipeline failure\n   * @deprecated - use `notifyOnFailure()` instead in combination with `PipelineNotification.chime()`.\n   */\n  readonly chimeFailureWebhooks?: string[];\n\n  /**\n   * The Chime message to post\n   *\n   * @default - A default message\n   */\n  readonly chimeMessage?: string;\n\n  /**\n   * Build timeout\n   *\n   * How long the build can take at maximum (before failing with an error).\n   *\n   * @default - Duration.hours(8)\n   */\n  readonly buildTimeout?: Duration;\n}\n\nexport interface PipelineNotificationBindOptions {\n  readonly pipeline: Pipeline;\n}\n\nexport interface IPipelineNotification {\n  bind(pipeline: PipelineNotificationBindOptions): void;\n}\n\n/**\n * Options for configuring an auto bump for this pipeline.\n */\nexport interface AutoBumpOptions extends Omit<AutoBumpProps, 'repo'> {\n}\n\n/**\n * Defines a delivlib CI/CD pipeline.\n */\nexport class Pipeline extends Construct {\n  public buildRole?: iam.IRole;\n  public readonly failureAlarm: cloudwatch.Alarm;\n  public readonly buildOutput: cpipeline.Artifact;\n  public readonly sourceArtifact: cpipeline.Artifact;\n\n  /**\n   * The primary CodeBuild project of this pipeline.\n   */\n  public readonly buildProject: cbuild.IProject;\n\n  /**\n   * The auto build project. undefined if 'autoBuild' is disabled for this pipeline.\n   */\n  public readonly autoBuildProject?: cbuild.Project;\n\n  /*\n   * The underlying CodePipeline Pipeline object that models this pipeline.\n   */\n  public readonly pipeline: cpipeline.Pipeline;\n  private readonly branch: string;\n  private readonly notify?: sns.Topic;\n  private stages: { [name: string]: cpipeline.IStage } = { };\n  private _signingOutput?: cpipeline.Artifact;\n\n  private readonly concurrency?: number;\n  private readonly repo: IRepo;\n  private readonly dryRun: boolean;\n  private readonly buildEnvironment: cbuild.BuildEnvironment;\n  private readonly buildSpec?: cbuild.BuildSpec;\n  private firstPublishStageName?: string;\n\n  constructor(parent: Construct, name: string, props: PipelineProps) {\n    super(parent, name);\n\n    this.concurrency = props.concurrency;\n    this.repo = props.repo;\n    this.dryRun = !!props.dryRun;\n\n    this.pipeline = new cpipeline.Pipeline(this, 'BuildPipeline', {\n      pipelineName: props.pipelineName,\n      restartExecutionOnUpdate: props.restartExecutionOnUpdate === undefined ? true : props.restartExecutionOnUpdate,\n    });\n\n    this.branch = props.branch || 'master';\n    this.sourceArtifact = props.repo.createSourceStage(this.pipeline, this.branch);\n\n    this.buildEnvironment = createBuildEnvironment(props);\n    this.buildSpec = props.buildSpec;\n\n    let buildProjectName = props.buildProjectName;\n    if (buildProjectName === undefined && props.pipelineName !== undefined) {\n      buildProjectName = `${props.pipelineName}-Build`;\n    }\n    this.buildProject = new cbuild.PipelineProject(this, 'BuildProject', {\n      projectName: buildProjectName,\n      environment: this.buildEnvironment,\n      buildSpec: this.buildSpec,\n      timeout: props.buildTimeout ?? Duration.hours(8),\n      ssmSessionPermissions: true,\n    });\n\n    this.buildRole = this.buildProject.role;\n    this.buildRole!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    const buildStage = this.getOrCreateStage('Build');\n    const buildOutput = new cpipeline.Artifact();\n    buildStage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: 'Build',\n      project: this.buildProject,\n      input: this.sourceArtifact,\n      outputs: [buildOutput],\n    }));\n    this.buildOutput = buildOutput;\n\n    if (props.notificationEmail) {\n      this.notify = new sns.Topic(this, 'NotificationsTopic');\n      this.notify.addSubscription(new sns_subs.EmailSubscription(props.notificationEmail));\n    }\n\n    // add a failure alarm for the entire pipeline.\n    this.failureAlarm = this.addFailureAlarm(props.title);\n\n    // emit an SNS notification every time build fails.\n    this.addBuildFailureNotification(this.buildProject, `${props.title} build failed`);\n\n    // Also emit to Chime webhooks if configured\n    if (props.chimeFailureWebhooks) {\n      new ChimeNotifier(this, 'ChimeNotifier', {\n        pipeline: this.pipeline,\n        message: props.chimeMessage,\n        webhookUrls: props.chimeFailureWebhooks,\n      });\n    }\n\n    if (props.autoBuild) {\n      this.autoBuildProject = this.autoBuild(props.autoBuildOptions).project;\n    }\n  }\n\n  /**\n   * Signing output artifact\n   */\n  public get signingOutput() {\n    return this._signingOutput;\n  }\n\n  public notifyOnFailure(notification: IPipelineNotification) {\n    notification.bind({\n      pipeline: this,\n    });\n  }\n\n  /**\n   * Add an action to run a shell script to the pipeline\n   *\n   * @return The Shellable and the Action added to the pipeline.\n   */\n  public addShellable(stageName: string, id: string, options: AddShellableOptions): {\n    shellable: Shellable; action: cpipeline_actions.CodeBuildAction;} {\n    const stage = this.getOrCreateStage(stageName);\n\n    const sh = new Shellable(this, id, options);\n    const action = sh.addToPipeline(\n      stage,\n      options.actionName || `Action${id}`,\n      options.inputArtifact || this.buildOutput,\n      this.determineRunOrderForNewAction(stage));\n\n    if (options.failureNotification) {\n      this.addBuildFailureNotification(sh.project, options.failureNotification);\n    }\n\n    return { shellable: sh, action };\n  }\n\n  public addTest(id: string, props: ShellableProps): {shellable: Shellable; action: cpipeline_actions.CodeBuildAction} {\n    return this.addShellable(TEST_STAGE_NAME, id, {\n      actionName: `Test${id}`,\n      failureNotification: `Test ${id} failed`,\n      ...props,\n    });\n  }\n\n  /**\n   * Convenience/discovery method that defines a canary test in your account.\n   * @param id the construct id\n   * @param props canary options\n   */\n  public addCanary(id: string, props: CanaryProps) {\n    return new Canary(this, `Canary${id}`, props);\n  }\n\n  public addPublish(publisher: IPublisher, options: AddPublishOptions = {}) {\n    const publishStageName = options.stageName ?? PUBLISH_STAGE_NAME;\n    if (!this.firstPublishStageName) {\n      this.firstPublishStageName = publishStageName;\n    }\n    const stage = this.getOrCreateStage(publishStageName);\n\n    publisher.addToPipeline(stage, `${publisher.node.id}Publish`, {\n      inputArtifact: options.inputArtifact || this.buildOutput,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n  }\n\n  /**\n   * Adds a change control policy to block transitions into the publish stage during certain time windows.\n   * @param options the options to configure the change control policy.\n   */\n  public addChangeControl(options: AddChangeControlOptions = { }): ChangeController {\n    const publishStage = this.getStage(this.firstPublishStageName ?? PUBLISH_STAGE_NAME);\n    if (!publishStage) {\n      throw new Error(`This pipeline does not have a ${PUBLISH_STAGE_NAME} stage yet. Add one first.`);\n    }\n\n    return new ChangeController(this, 'ChangeController', {\n      ...options,\n      pipelineStage: publishStage,\n    });\n  }\n\n  public addSigning(signer: signing.ISigner, options: signing.AddSigningOptions = {}) {\n    const signingStageName = options.stageName ?? SIGINING_STAGE_NAME;\n    const stage = this.getOrCreateStage(signingStageName);\n\n    this._signingOutput = signer.addToPipeline(stage, `${signer.node.id}Sign`, {\n      inputArtifact: options.inputArtifact || this.buildOutput,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n  }\n\n  public signNuGetWithSigner(options: signing.SignNuGetWithSignerProps & signing.AddSigningOptions) {\n    this.addSigning(new signing.SignNuGetWithSigner(this, 'NuGetSigning', {\n      ...options,\n    }), options);\n  }\n\n  public publishToNpm(options: publishing.PublishToNpmProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToMaven(options: publishing.PublishToMavenProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToMavenProject(this, 'Maven', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToNuGet(options: publishing.PublishToNuGetProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNuGetProject(this, 'NuGet', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHubPages(options: publishing.PublishDocsToGitHubProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishDocsToGitHubProject(this, 'GitHubPages', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHub(options: publishing.PublishToGitHubProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToGitHub(this, 'GitHub', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToPyPI(options: publishing.PublishToPyPiProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToPyPi(this, 'PyPI', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToS3(id: string, options: publishing.PublishToS3Props & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToS3(this, id, {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  /**\n   * Publish Golang code from `go` directory in build artifact to a GitHub repository.\n   */\n  public publishToGolang(options: publishing.PublishToGolangProps) {\n    this.addPublish(new publishing.PublishToGolang(this, 'Golang', {\n      dryRun: this.dryRun,\n      ...options,\n    }));\n  }\n\n  /**\n   * Enables automatic bumps for the source repo.\n   * @param options Options for auto bump (see AutoBumpOptions for description of defaults)\n   */\n  public autoBump(options?: AutoBumpOptions): AutoBump {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-bump');\n    }\n\n    const autoBump = new AutoBump(this, 'AutoBump', {\n      repo: this.repo,\n      ...options,\n    });\n\n    return autoBump;\n  }\n\n  /**\n   * Enables automatic merge backs for the source repo.\n   * @param options Options for auto bump (see AutoMergeBackPipelineOptions for description of defaults)\n   */\n  public autoMergeBack(options?: AutoMergeBackPipelineOptions) {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-merge-back');\n    }\n\n    const mergeBack = new AutoMergeBack(this, 'MergeBack', {\n      repo: this.repo,\n      ...options,\n    });\n\n    if (options?.stage) {\n\n      const afterStage = this.getStage(options.stage.after);\n\n      if (!afterStage) {\n        throw new Error(`'options.stage.after' must be configured to an existing stage: ${options.stage.after}`);\n      }\n\n      const stage = this.getOrCreateStage(options.stage.name ?? 'MergeBack', { justAfter: afterStage });\n      stage.addAction(new cpipeline_actions.CodeBuildAction({\n        actionName: 'CreateMergeBackPullRequest',\n        project: mergeBack.pr.project,\n        input: this.sourceArtifact,\n      }));\n    }\n  }\n\n  /**\n   * Enables automatic builds of pull requests in the Github repository and posts the\n   * results back as a comment with a public link to the build logs.\n   */\n  public autoBuild(options: AutoBuildOptions = { }): AutoBuild {\n    return new AutoBuild(this, 'AutoBuild', {\n      environment: this.buildEnvironment,\n      repo: this.repo,\n      buildSpec: options.buildSpec || this.buildSpec,\n      ...options,\n    });\n  }\n\n  /**\n   * The metric that tracks pipeline failures.\n   */\n  public metricFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: METRIC_NAMESPACE,\n      metricName: FAILURE_METRIC_NAME,\n      dimensionsMap: {\n        Pipeline: this.pipeline.pipelineName,\n      },\n      statistic: 'Sum',\n      ...options,\n    });\n  }\n\n  /**\n   * The metrics that track failure of each action within the pipeline.\n   */\n  public metricActionFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric[] {\n    return flatMap(this.pipeline.stages, stage => stage.actions.map(action => {\n      return new cloudwatch.Metric({\n        namespace: METRIC_NAMESPACE,\n        metricName: FAILURE_METRIC_NAME,\n        dimensionsMap: {\n          Pipeline: this.pipeline.pipelineName,\n          Action: action.actionProperties.actionName,\n        },\n        statistic: 'Sum',\n        ...options,\n      });\n    }));\n  }\n\n  public addManualApprovalToStage(stageName: string, props?: cpipeline_actions.ManualApprovalActionProps) {\n    const stage = this.getOrCreateStage(stageName);\n    stage.addAction(new cpipeline_actions.ManualApprovalAction(props ?? {\n      actionName: 'ManualApprovalAction',\n    }));\n  }\n\n  private addFailureAlarm(title?: string): cloudwatch.Alarm {\n    return new PipelineWatcher(this, 'PipelineWatcher', {\n      pipeline: this.pipeline,\n      metricNamespace: METRIC_NAMESPACE,\n      failureMetricName: FAILURE_METRIC_NAME,\n      title,\n    }).alarm;\n  }\n\n  private addBuildFailureNotification(buildProject: cbuild.IProject, message: string) {\n    if (!this.notify) {\n      return;\n    }\n\n    buildProject.onBuildFailed('OnBuildFailed').addTarget(new events_targets.SnsTopic(this.notify, {\n      message: events.RuleTargetInput.fromText(message),\n    }));\n  }\n\n  /**\n   * @returns the stage or undefined if the stage doesn't exist\n   */\n  private getStage(stageName: string): cpipeline.IStage | undefined {\n    return this.stages[stageName];\n  }\n\n  private getOrCreateStage(stageName: string, placement?: cpipeline.StagePlacement): cpipeline.IStage {\n    // otherwise, group all actions so they run concurrently.\n    let stage = this.getStage(stageName);\n    if (!stage) {\n      stage = this.pipeline.addStage({\n        stageName,\n        placement,\n      });\n      this.stages[stageName] = stage;\n    }\n    return stage;\n  }\n\n  private determineRunOrderForNewAction(stage: cpipeline.IStage): number | undefined {\n    return determineRunOrder(stage.actions.length, this.concurrency);\n  }\n}\n\nexport interface IPublisher extends IConstruct {\n  addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void;\n}\n\nexport interface AddToPipelineOptions {\n  inputArtifact?: cpipeline.Artifact;\n  runOrder?: number;\n}\n\nexport interface AddChangeControlOptions {\n  /**\n   * The bucket in which the ChangeControl iCal document will be stored.\n   *\n   * @default a new bucket will be provisioned.\n   */\n  changeControlBucket?: s3.IBucket;\n\n  /**\n   * The key in which the iCal fille will be stored.\n   *\n   * @default 'change-control.ical'\n   */\n  changeControlObjectKey?: string;\n\n  /**\n   * Schedule to run the change controller on\n   *\n   * @default rate(15 minutes)\n   */\n  scheduleExpression?: string;\n}\n\nexport interface AddPublishOptions {\n  /**\n   * The input artifact to use\n   *\n   * @default Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n\n  /**\n   * Stage name to add publishing job to\n   *\n   * By default, this will be the stage name `'Publish'`, but if you want to\n   * separate out the publishing actions into different stages (in order to\n   * block/unblock them separately for example) you can change this.\n   *\n   * Stages appear in the pipeline in the order they are referenced for\n   * the first time.\n   *\n   * @default \"Publish\"\n   */\n  readonly stageName?: string;\n}\n\nexport interface AddShellableOptions extends ShellableProps {\n  /**\n   * String to use as action name\n   *\n   * @default Id\n   */\n  actionName?: string;\n\n  /**\n   * Message to use as failure notification\n   *\n   * @default No notification\n   */\n  failureNotification?: string;\n\n  /**\n   * The input artifact to use\n   *\n   * @default Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
set -euo pipefail
|
|
3
|
+
|
|
4
|
+
echo "Installing required CLI tools: jq"
|
|
5
|
+
if command -v yum &>/dev/null; then
|
|
6
|
+
yum install -y jq
|
|
7
|
+
elif command -v apt-get &>/dev/null; then
|
|
8
|
+
apt-get update
|
|
9
|
+
apt-get install -y jq
|
|
10
|
+
else
|
|
11
|
+
echo "!!! Neither an apt nor yum distribution - could not install jq, things might break!"
|
|
12
|
+
fi
|
|
13
|
+
|
|
14
|
+
if [ -n "${SIGNING_ACCESS_ROLE_ARN:-}" ]; then
|
|
15
|
+
ROLE=$(aws sts assume-role --role-arn "${SIGNING_ACCESS_ROLE_ARN:-}" --role-session-name "signer_access")
|
|
16
|
+
export AWS_ACCESS_KEY_ID=$(echo $ROLE | jq -r .Credentials.AccessKeyId)
|
|
17
|
+
export AWS_SECRET_ACCESS_KEY=$(echo $ROLE | jq -r .Credentials.SecretAccessKey)
|
|
18
|
+
export AWS_SESSION_TOKEN=$(echo $ROLE | jq -r .Credentials.SessionToken)
|
|
19
|
+
fi
|
|
20
|
+
|
|
21
|
+
found=false
|
|
22
|
+
for nuget_package_path in $(find dotnet -name *.nupkg -not -iname *.symbols.nupkg); do
|
|
23
|
+
found=true
|
|
24
|
+
echo "🔑 Applying authenticode signatures to assemblies in ${nuget_package_path}"
|
|
25
|
+
for file in $(unzip -Z1 ${nuget_package_path} '*.dll'); do
|
|
26
|
+
echo "📄 Assembly: ${file}"
|
|
27
|
+
tmp=$(mktemp -d)
|
|
28
|
+
# extract the dll from the zip file
|
|
29
|
+
unzip -q ${nuget_package_path} -d ${tmp} ${file}
|
|
30
|
+
# need to set appropriate permissions, otherwise the file has none
|
|
31
|
+
chmod u+rw ${tmp}/${file}
|
|
32
|
+
# upload dll to signer bucket
|
|
33
|
+
version_id=$(aws s3api put-object \
|
|
34
|
+
--bucket ${SIGNING_BUCKET_NAME:-} \
|
|
35
|
+
--key unsigned/${file} \
|
|
36
|
+
--body ${file} | jq -r '.VersionId')
|
|
37
|
+
# invoke signer lambda
|
|
38
|
+
aws lambda invoke \
|
|
39
|
+
--function-name ${SIGNING_LAMBDA_ARN:-} \
|
|
40
|
+
--invocation-type RequestResponse \
|
|
41
|
+
--cli-binary-format raw-in-base64-out \
|
|
42
|
+
--payload '{ "artifactKey": "'"unsigned/${file}"'", "artifactVersion": "'"${version_id}"'" }' \
|
|
43
|
+
${tmp}/response.json >/dev/null
|
|
44
|
+
signed_artifact_key=$(cat ${tmp}/response.json | jq -r '.signedArtifactKey')
|
|
45
|
+
# download signed dll from signer bucket
|
|
46
|
+
aws s3api get-object \
|
|
47
|
+
--bucket ${SIGNING_BUCKET_NAME:-} \
|
|
48
|
+
--key ${signed_artifact_key} \
|
|
49
|
+
${tmp}/${file} >/dev/null
|
|
50
|
+
# replace the dll in the nuget package
|
|
51
|
+
(
|
|
52
|
+
cd ${tmp}
|
|
53
|
+
zip -qfr ${nuget_package_path} ${file}
|
|
54
|
+
)
|
|
55
|
+
# clean up temporary directory
|
|
56
|
+
rm -rf ${tmp}
|
|
57
|
+
done
|
|
58
|
+
echo "🔐 All Done!"
|
|
59
|
+
done
|
|
60
|
+
|
|
61
|
+
if ! ${found}; then
|
|
62
|
+
echo "❌ No nupkg files found under the dotnet/ directory. Nothing to sign"
|
|
63
|
+
exit 1
|
|
64
|
+
fi
|
package/lib/signing.d.ts
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { IBuildImage, Project } from 'aws-cdk-lib/aws-codebuild';
|
|
2
|
+
import { Artifact, IStage } from 'aws-cdk-lib/aws-codepipeline';
|
|
3
|
+
import { IRole } from 'aws-cdk-lib/aws-iam';
|
|
4
|
+
import { IFunction } from 'aws-cdk-lib/aws-lambda';
|
|
5
|
+
import { IBucket } from 'aws-cdk-lib/aws-s3';
|
|
6
|
+
import { Construct, IConstruct } from 'constructs';
|
|
7
|
+
import { AddToPipelineOptions } from './pipeline';
|
|
8
|
+
export interface ISigner extends IConstruct {
|
|
9
|
+
addToPipeline(stage: IStage, id: string, options: AddToPipelineOptions): Artifact;
|
|
10
|
+
}
|
|
11
|
+
export interface AddSigningOptions {
|
|
12
|
+
/**
|
|
13
|
+
* The input artifact to use
|
|
14
|
+
*
|
|
15
|
+
* @default Build output artifact
|
|
16
|
+
*/
|
|
17
|
+
readonly inputArtifact?: Artifact;
|
|
18
|
+
/**
|
|
19
|
+
* Stage name to add signing job to
|
|
20
|
+
*
|
|
21
|
+
* @default "Sign"
|
|
22
|
+
*/
|
|
23
|
+
readonly stageName?: string;
|
|
24
|
+
}
|
|
25
|
+
export interface SignNuGetWithSignerProps {
|
|
26
|
+
/**
|
|
27
|
+
* An S3 bucket used to store signed and unsigned DLL files
|
|
28
|
+
*/
|
|
29
|
+
readonly signingBucket: IBucket;
|
|
30
|
+
/**
|
|
31
|
+
* A Lambda function used to perform signing operations with AWS Signer
|
|
32
|
+
*/
|
|
33
|
+
readonly signingLambda: IFunction;
|
|
34
|
+
/**
|
|
35
|
+
* A role used provide access to the signing bucket and signing lambda
|
|
36
|
+
*/
|
|
37
|
+
readonly signingAccessRole: IRole;
|
|
38
|
+
/**
|
|
39
|
+
* The build image to do the signing in
|
|
40
|
+
*
|
|
41
|
+
* Needs to have NuGet preinstalled.
|
|
42
|
+
*
|
|
43
|
+
* @default Latest superchain
|
|
44
|
+
*/
|
|
45
|
+
readonly buildImage?: IBuildImage;
|
|
46
|
+
}
|
|
47
|
+
export declare class SignNuGetWithSigner extends Construct implements ISigner {
|
|
48
|
+
readonly role: IRole;
|
|
49
|
+
readonly project: Project;
|
|
50
|
+
constructor(scope: Construct, id: string, props: SignNuGetWithSignerProps);
|
|
51
|
+
addToPipeline(stage: IStage, id: string, options: AddToPipelineOptions): Artifact;
|
|
52
|
+
}
|
package/lib/signing.js
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.SignNuGetWithSigner = void 0;
|
|
27
|
+
const path = __importStar(require("path"));
|
|
28
|
+
const aws_codebuild_1 = require("aws-cdk-lib/aws-codebuild");
|
|
29
|
+
const aws_codepipeline_1 = require("aws-cdk-lib/aws-codepipeline");
|
|
30
|
+
const aws_codepipeline_actions_1 = require("aws-cdk-lib/aws-codepipeline-actions");
|
|
31
|
+
const constructs_1 = require("constructs");
|
|
32
|
+
const build_spec_1 = require("./build-spec");
|
|
33
|
+
const shellable_1 = require("./shellable");
|
|
34
|
+
class SignNuGetWithSigner extends constructs_1.Construct {
|
|
35
|
+
constructor(scope, id, props) {
|
|
36
|
+
var _a;
|
|
37
|
+
super(scope, id);
|
|
38
|
+
const environment = {
|
|
39
|
+
SIGNING_BUCKET_NAME: props.signingBucket.bucketName,
|
|
40
|
+
SIGNING_LAMBDA_ARN: props.signingLambda.functionArn,
|
|
41
|
+
SIGNING_ACCESS_ROLE_ARN: props.signingAccessRole.roleArn,
|
|
42
|
+
};
|
|
43
|
+
const shellable = new shellable_1.Shellable(this, 'Default', {
|
|
44
|
+
platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_codebuild_1.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-buster-slim-node18')),
|
|
45
|
+
scriptDirectory: path.join(__dirname, 'signing', 'nuget'),
|
|
46
|
+
entrypoint: 'sign.sh',
|
|
47
|
+
buildSpec: build_spec_1.BuildSpec.literal({
|
|
48
|
+
version: '0.2',
|
|
49
|
+
artifacts: {
|
|
50
|
+
files: ['**/*'],
|
|
51
|
+
['base-directory']: '.',
|
|
52
|
+
},
|
|
53
|
+
}),
|
|
54
|
+
environment,
|
|
55
|
+
});
|
|
56
|
+
this.role = shellable.role;
|
|
57
|
+
this.project = shellable.project;
|
|
58
|
+
}
|
|
59
|
+
addToPipeline(stage, id, options) {
|
|
60
|
+
const signingInput = options.inputArtifact || new aws_codepipeline_1.Artifact();
|
|
61
|
+
const signingOutput = new aws_codepipeline_1.Artifact();
|
|
62
|
+
stage.addAction(new aws_codepipeline_actions_1.CodeBuildAction({
|
|
63
|
+
actionName: id,
|
|
64
|
+
input: signingInput,
|
|
65
|
+
runOrder: options.runOrder,
|
|
66
|
+
project: this.project,
|
|
67
|
+
outputs: [signingOutput],
|
|
68
|
+
}));
|
|
69
|
+
return signingOutput;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
exports.SignNuGetWithSigner = SignNuGetWithSigner;
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpZ25pbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBNkI7QUFDN0IsNkRBQWtGO0FBQ2xGLG1FQUFnRTtBQUNoRSxtRkFBdUU7QUFJdkUsMkNBQW1EO0FBQ25ELDZDQUF5QztBQUV6QywyQ0FBdUQ7QUFnRHZELE1BQWEsbUJBQW9CLFNBQVEsc0JBQVM7SUFJaEQsWUFBbUIsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBK0I7O1FBQzlFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsTUFBTSxXQUFXLEdBQUc7WUFDbEIsbUJBQW1CLEVBQUUsS0FBSyxDQUFDLGFBQWEsQ0FBQyxVQUFVO1lBQ25ELGtCQUFrQixFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsV0FBVztZQUNuRCx1QkFBdUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCLENBQUMsT0FBTztTQUN6RCxDQUFDO1FBRUYsTUFBTSxTQUFTLEdBQUcsSUFBSSxxQkFBUyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDL0MsUUFBUSxFQUFFLElBQUkseUJBQWEsQ0FBQyxNQUFBLEtBQUssQ0FBQyxVQUFVLG1DQUFJLCtCQUFlLENBQUMsa0JBQWtCLENBQUMscURBQXFELENBQUMsQ0FBQztZQUMxSSxlQUFlLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLE9BQU8sQ0FBQztZQUN6RCxVQUFVLEVBQUUsU0FBUztZQUNyQixTQUFTLEVBQUUsc0JBQVMsQ0FBQyxPQUFPLENBQUM7Z0JBQzNCLE9BQU8sRUFBRSxLQUFLO2dCQUNkLFNBQVMsRUFBRTtvQkFDVCxLQUFLLEVBQUUsQ0FBQyxNQUFNLENBQUM7b0JBQ2YsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUc7aUJBQ3hCO2FBQ0YsQ0FBQztZQUNGLFdBQVc7U0FDWixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUM7UUFDM0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDO0lBQ25DLENBQUM7SUFFTSxhQUFhLENBQUMsS0FBYSxFQUFFLEVBQVUsRUFBRSxPQUE2QjtRQUMzRSxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsYUFBYSxJQUFJLElBQUksMkJBQVEsRUFBRSxDQUFDO1FBQzdELE1BQU0sYUFBYSxHQUFHLElBQUksMkJBQVEsRUFBRSxDQUFDO1FBRXJDLEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSwwQ0FBZSxDQUFDO1lBQ2xDLFVBQVUsRUFBRSxFQUFFO1lBQ2QsS0FBSyxFQUFFLFlBQVk7WUFDbkIsUUFBUSxFQUFFLE9BQU8sQ0FBQyxRQUFRO1lBQzFCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixPQUFPLEVBQUUsQ0FBQyxhQUFhLENBQUM7U0FDekIsQ0FBQyxDQUFDLENBQUM7UUFFSixPQUFPLGFBQWEsQ0FBQztJQUN2QixDQUFDO0NBQ0Y7QUE3Q0Qsa0RBNkNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IElCdWlsZEltYWdlLCBMaW51eEJ1aWxkSW1hZ2UsIFByb2plY3QgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZWJ1aWxkJztcbmltcG9ydCB7IEFydGlmYWN0LCBJU3RhZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZXBpcGVsaW5lJztcbmltcG9ydCB7IENvZGVCdWlsZEFjdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jb2RlcGlwZWxpbmUtYWN0aW9ucyc7XG5pbXBvcnQgeyBJUm9sZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgSUZ1bmN0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWxhbWJkYSc7XG5pbXBvcnQgeyBJQnVja2V0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzJztcbmltcG9ydCB7IENvbnN0cnVjdCwgSUNvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQnVpbGRTcGVjIH0gZnJvbSAnLi9idWlsZC1zcGVjJztcbmltcG9ydCB7IEFkZFRvUGlwZWxpbmVPcHRpb25zIH0gZnJvbSAnLi9waXBlbGluZSc7XG5pbXBvcnQgeyBMaW51eFBsYXRmb3JtLCBTaGVsbGFibGUgfSBmcm9tICcuL3NoZWxsYWJsZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVNpZ25lciBleHRlbmRzIElDb25zdHJ1Y3Qge1xuICBhZGRUb1BpcGVsaW5lKHN0YWdlOiBJU3RhZ2UsIGlkOiBzdHJpbmcsIG9wdGlvbnM6IEFkZFRvUGlwZWxpbmVPcHRpb25zKTogQXJ0aWZhY3Q7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkU2lnbmluZ09wdGlvbnMge1xuICAvKipcbiAgICogVGhlIGlucHV0IGFydGlmYWN0IHRvIHVzZVxuICAgKlxuICAgKiBAZGVmYXVsdCBCdWlsZCBvdXRwdXQgYXJ0aWZhY3RcbiAgICovXG4gIHJlYWRvbmx5IGlucHV0QXJ0aWZhY3Q/OiBBcnRpZmFjdDtcblxuICAvKipcbiAgICogU3RhZ2UgbmFtZSB0byBhZGQgc2lnbmluZyBqb2IgdG9cbiAgICpcbiAgICogQGRlZmF1bHQgXCJTaWduXCJcbiAgICovXG4gIHJlYWRvbmx5IHN0YWdlTmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTaWduTnVHZXRXaXRoU2lnbmVyUHJvcHMge1xuICAvKipcbiAgICogQW4gUzMgYnVja2V0IHVzZWQgdG8gc3RvcmUgc2lnbmVkIGFuZCB1bnNpZ25lZCBETEwgZmlsZXNcbiAgICovXG4gIHJlYWRvbmx5IHNpZ25pbmdCdWNrZXQ6IElCdWNrZXQ7XG5cbiAgLyoqXG4gICAqIEEgTGFtYmRhIGZ1bmN0aW9uIHVzZWQgdG8gcGVyZm9ybSBzaWduaW5nIG9wZXJhdGlvbnMgd2l0aCBBV1MgU2lnbmVyXG4gICAqL1xuICByZWFkb25seSBzaWduaW5nTGFtYmRhOiBJRnVuY3Rpb247XG5cbiAgLyoqXG4gICAqIEEgcm9sZSB1c2VkIHByb3ZpZGUgYWNjZXNzIHRvIHRoZSBzaWduaW5nIGJ1Y2tldCBhbmQgc2lnbmluZyBsYW1iZGFcbiAgICovXG4gIHJlYWRvbmx5IHNpZ25pbmdBY2Nlc3NSb2xlOiBJUm9sZTtcblxuICAvKipcbiAgICogVGhlIGJ1aWxkIGltYWdlIHRvIGRvIHRoZSBzaWduaW5nIGluXG4gICAqXG4gICAqIE5lZWRzIHRvIGhhdmUgTnVHZXQgcHJlaW5zdGFsbGVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCBMYXRlc3Qgc3VwZXJjaGFpblxuICAgKi9cbiAgcmVhZG9ubHkgYnVpbGRJbWFnZT86IElCdWlsZEltYWdlO1xufVxuXG5leHBvcnQgY2xhc3MgU2lnbk51R2V0V2l0aFNpZ25lciBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElTaWduZXIge1xuICBwdWJsaWMgcmVhZG9ubHkgcm9sZTogSVJvbGU7XG4gIHB1YmxpYyByZWFkb25seSBwcm9qZWN0OiBQcm9qZWN0O1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2lnbk51R2V0V2l0aFNpZ25lclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IGVudmlyb25tZW50ID0ge1xuICAgICAgU0lHTklOR19CVUNLRVRfTkFNRTogcHJvcHMuc2lnbmluZ0J1Y2tldC5idWNrZXROYW1lLFxuICAgICAgU0lHTklOR19MQU1CREFfQVJOOiBwcm9wcy5zaWduaW5nTGFtYmRhLmZ1bmN0aW9uQXJuLFxuICAgICAgU0lHTklOR19BQ0NFU1NfUk9MRV9BUk46IHByb3BzLnNpZ25pbmdBY2Nlc3NSb2xlLnJvbGVBcm4sXG4gICAgfTtcblxuICAgIGNvbnN0IHNoZWxsYWJsZSA9IG5ldyBTaGVsbGFibGUodGhpcywgJ0RlZmF1bHQnLCB7XG4gICAgICBwbGF0Zm9ybTogbmV3IExpbnV4UGxhdGZvcm0ocHJvcHMuYnVpbGRJbWFnZSA/PyBMaW51eEJ1aWxkSW1hZ2UuZnJvbURvY2tlclJlZ2lzdHJ5KCdwdWJsaWMuZWNyLmF3cy9qc2lpL3N1cGVyY2hhaW46MS1idXN0ZXItc2xpbS1ub2RlMTgnKSksXG4gICAgICBzY3JpcHREaXJlY3Rvcnk6IHBhdGguam9pbihfX2Rpcm5hbWUsICdzaWduaW5nJywgJ251Z2V0JyksXG4gICAgICBlbnRyeXBvaW50OiAnc2lnbi5zaCcsXG4gICAgICBidWlsZFNwZWM6IEJ1aWxkU3BlYy5saXRlcmFsKHtcbiAgICAgICAgdmVyc2lvbjogJzAuMicsXG4gICAgICAgIGFydGlmYWN0czoge1xuICAgICAgICAgIGZpbGVzOiBbJyoqLyonXSxcbiAgICAgICAgICBbJ2Jhc2UtZGlyZWN0b3J5J106ICcuJyxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgZW52aXJvbm1lbnQsXG4gICAgfSk7XG5cbiAgICB0aGlzLnJvbGUgPSBzaGVsbGFibGUucm9sZTtcbiAgICB0aGlzLnByb2plY3QgPSBzaGVsbGFibGUucHJvamVjdDtcbiAgfVxuXG4gIHB1YmxpYyBhZGRUb1BpcGVsaW5lKHN0YWdlOiBJU3RhZ2UsIGlkOiBzdHJpbmcsIG9wdGlvbnM6IEFkZFRvUGlwZWxpbmVPcHRpb25zKSB7XG4gICAgY29uc3Qgc2lnbmluZ0lucHV0ID0gb3B0aW9ucy5pbnB1dEFydGlmYWN0IHx8IG5ldyBBcnRpZmFjdCgpO1xuICAgIGNvbnN0IHNpZ25pbmdPdXRwdXQgPSBuZXcgQXJ0aWZhY3QoKTtcblxuICAgIHN0YWdlLmFkZEFjdGlvbihuZXcgQ29kZUJ1aWxkQWN0aW9uKHtcbiAgICAgIGFjdGlvbk5hbWU6IGlkLFxuICAgICAgaW5wdXQ6IHNpZ25pbmdJbnB1dCxcbiAgICAgIHJ1bk9yZGVyOiBvcHRpb25zLnJ1bk9yZGVyLFxuICAgICAgcHJvamVjdDogdGhpcy5wcm9qZWN0LFxuICAgICAgb3V0cHV0czogW3NpZ25pbmdPdXRwdXRdLFxuICAgIH0pKTtcblxuICAgIHJldHVybiBzaWduaW5nT3V0cHV0O1xuICB9XG59Il19
|