@liflig/cdk 2.21.1 → 2.21.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +18 -2
- package/lib/cdk-deploy/cdk-deploy.js +10 -11
- package/lib/cdk-deploy/start-deploy-handler.d.ts +1 -1
- package/lib/cdk-deploy/start-deploy-handler.js +19 -26
- package/lib/cdk-deploy/status-handler.d.ts +1 -1
- package/lib/cdk-deploy/status-handler.js +17 -20
- package/lib/cdk-pipelines/cloud-assembly-lookup-handler.d.ts +1 -1
- package/lib/cdk-pipelines/cloud-assembly-lookup-handler.js +46 -35
- package/lib/cdk-pipelines/liflig-cdk-pipeline.js +6 -6
- package/lib/ecs-update-image/ecs-update-image.js +10 -11
- package/lib/ecs-update-image/start-deploy-handler.d.ts +1 -1
- package/lib/ecs-update-image/start-deploy-handler.js +16 -25
- package/lib/ecs-update-image/status-handler.d.ts +1 -1
- package/lib/ecs-update-image/status-handler.js +10 -17
- package/lib/pipelines/pipeline.js +34 -29
- package/lib/ses/configurationsetsnsdestination/handler.d.ts +1 -1
- package/lib/ses/configurationsetsnsdestination/handler.js +15 -25
- package/lib/ses/configurationsetsnsdestination/index.js +7 -7
- package/lib/ses/sesdomain/handler.d.ts +1 -1
- package/lib/ses/sesdomain/handler.js +31 -31
- package/lib/ses/sesdomain/index.js +6 -6
- package/lib/ses/sesverifyemail/handler.d.ts +1 -1
- package/lib/ses/sesverifyemail/handler.js +12 -10
- package/lib/ses/sesverifyemail/index.js +6 -6
- package/package.json +19 -8
package/README.md
CHANGED
|
@@ -32,18 +32,34 @@ are not yet resolved. Some relevant information:
|
|
|
32
32
|
|
|
33
33
|
## Testing library changes before releasing
|
|
34
34
|
|
|
35
|
-
1
|
|
35
|
+
### Alternative 1: Install liflig-cdk from tarball
|
|
36
|
+
|
|
37
|
+
1. Assemble artifact, which emits a tarball
|
|
36
38
|
|
|
37
39
|
```bash
|
|
38
40
|
npm pack
|
|
39
41
|
```
|
|
40
42
|
|
|
41
|
-
|
|
43
|
+
2. Install the library in an application from a tarball
|
|
42
44
|
|
|
43
45
|
```bash
|
|
44
46
|
npm install /path/to/liflig-cdk/liflig-cdk-0.0.0-development.tgz
|
|
45
47
|
```
|
|
46
48
|
|
|
49
|
+
### Alternative 2: Install liflig-cdk from a Git branch
|
|
50
|
+
|
|
51
|
+
1. Navigate to the project where you want to test the changes
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
cd /path/to/other/project
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
2. Install the library in an application from a Git branch
|
|
58
|
+
|
|
59
|
+
```bash
|
|
60
|
+
npm install "https://github.com/capralifecycle/liflig-cdk.git#my-feature-branch"
|
|
61
|
+
```
|
|
62
|
+
|
|
47
63
|
Note: `npm link` cannot be used, since it will lead to multiple
|
|
48
64
|
declarations of the same classes from CDK, breaking the `instanceof`
|
|
49
65
|
operator.
|
|
@@ -8,8 +8,7 @@ const lambda = require("aws-cdk-lib/aws-lambda");
|
|
|
8
8
|
const s3 = require("aws-cdk-lib/aws-s3");
|
|
9
9
|
const cdk = require("aws-cdk-lib");
|
|
10
10
|
const secretsmanager = require("aws-cdk-lib/aws-secretsmanager");
|
|
11
|
-
const
|
|
12
|
-
const status_handler_1 = require("./status-handler");
|
|
11
|
+
const aws_lambda_nodejs_1 = require("aws-cdk-lib/aws-lambda-nodejs");
|
|
13
12
|
/**
|
|
14
13
|
* This construct is responsible for the privileges and logic of
|
|
15
14
|
* automatically deploying stack resources in an account.
|
|
@@ -121,11 +120,11 @@ class CdkDeploy extends constructs.Construct {
|
|
|
121
120
|
artifactsBucket.grantRead(codebuildProject);
|
|
122
121
|
cloudFormationRole.grantPassRole(codebuildProject.role);
|
|
123
122
|
codebuildBucket.grantReadWrite(codebuildProject);
|
|
124
|
-
const startDeployFn = new
|
|
125
|
-
|
|
126
|
-
runtime: lambda.Runtime.
|
|
127
|
-
handler: "index.handler",
|
|
123
|
+
const startDeployFn = new aws_lambda_nodejs_1.NodejsFunction(this, "StartDeployFunction", {
|
|
124
|
+
entry: require.resolve("./start-deploy-handler"),
|
|
125
|
+
runtime: lambda.Runtime.NODEJS_18_X,
|
|
128
126
|
functionName: props.startDeployFunctionName,
|
|
127
|
+
awsSdkConnectionReuse: false,
|
|
129
128
|
environment: {
|
|
130
129
|
PROJECT_NAME: codebuildProject.projectName,
|
|
131
130
|
BUCKET_NAME: codebuildBucket.bucketName,
|
|
@@ -139,11 +138,11 @@ class CdkDeploy extends constructs.Construct {
|
|
|
139
138
|
actions: ["codebuild:StartBuild", "codebuild:BatchGetBuilds"],
|
|
140
139
|
resources: [codebuildProject.projectArn],
|
|
141
140
|
}));
|
|
142
|
-
const statusFn = new
|
|
143
|
-
|
|
144
|
-
runtime: lambda.Runtime.
|
|
145
|
-
handler: "index.handler",
|
|
141
|
+
const statusFn = new aws_lambda_nodejs_1.NodejsFunction(this, "StatusFunction", {
|
|
142
|
+
entry: require.resolve("./status-handler"),
|
|
143
|
+
runtime: lambda.Runtime.NODEJS_18_X,
|
|
146
144
|
functionName: props.statusFunctionName,
|
|
145
|
+
awsSdkConnectionReuse: false,
|
|
147
146
|
environment: {
|
|
148
147
|
PROJECT_NAME: codebuildProject.projectName,
|
|
149
148
|
},
|
|
@@ -172,4 +171,4 @@ class CdkDeploy extends constructs.Construct {
|
|
|
172
171
|
}
|
|
173
172
|
}
|
|
174
173
|
exports.CdkDeploy = CdkDeploy;
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-deploy.js","sourceRoot":"","sources":["../../src/cdk-deploy/cdk-deploy.ts"],"names":[],"mappings":"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","sourcesContent":["import * as constructs from \"constructs\"\nimport * as codebuild from \"aws-cdk-lib/aws-codebuild\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as lambda from \"aws-cdk-lib/aws-lambda\"\nimport * as s3 from \"aws-cdk-lib/aws-s3\"\nimport * as cdk from \"aws-cdk-lib\"\nimport * as secretsmanager from \"aws-cdk-lib/aws-secretsmanager\"\nimport { startDeployHandler } from \"./start-deploy-handler\"\nimport { statusHandler } from \"./status-handler\"\n\ninterface Props extends cdk.StackProps {\n  /**\n   * The role that will be granted permission to assume the deploy\n   * role. This role must have permission to assume the deploy role.\n   */\n  callerRoleArn: string\n  /**\n   * The name that will be used for the deploy role. This is the role\n   * that the caller will assume in order to have permission to invoke\n   * the Lambda Functions.\n   */\n  roleName: string\n  /**\n   * The bucket used for storing artifacts. This is used to grant\n   * permission to the role to read artifact. If the bucket is in\n   * another account, it must have a policy which allows the target\n   * account to use IAM permissions from target account.\n   */\n  artifactsBucketName: string\n  startDeployFunctionName: string\n  statusFunctionName: string\n  /**\n   * This is the stack name used with `cdk bootstrap` and can e\n   * found in cdk.json as \"toolkitStackName\".\n   */\n  cdkToolkitStackName: string\n  /**\n   * We pass the CDK context values as they contain feature flags\n   * used by the CDK CLI.\n   */\n  cdkContext: Record<string, string | string[]>\n  /**\n   * The secret containing username and password (or access token)\n   * for a valid docker user. This is used to access private\n   * repositories or to handle docker hub's pull rate limiting.\n   */\n  dockerCredentialsSecretName?: string\n}\n\n/**\n * This construct is responsible for the privileges and logic of\n * automatically deploying stack resources in an account.\n * Its resources are used from a deployment pipeline.\n *\n * The deployment is performed by invoking the \"start deploy\"\n * lambda with details of what should be deployed. As this is\n * responsible for deploying infrastructure, the principal invoking\n * might be able to cause privilege escalation. The principal invoking\n * should be assumed to have full administrator access.\n *\n * The process deploying the infrastructure is locked down so this\n * is only possibly by deployment through CloudFormation, and as\n * such removes a lot of possible escalation paths (e.g. no role\n * can be created by direct API call).\n *\n * The \"status\" lambda can be used to poll for completion, and will\n * also return logs from the job upon completion.\n */\nexport class CdkDeploy extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n\n    const account = cdk.Stack.of(this).account\n    const region = cdk.Stack.of(this).region\n\n    const artifactsBucket = s3.Bucket.fromBucketName(\n      this,\n      \"ArtifactsBucket\",\n      props.artifactsBucketName,\n    )\n\n    const roleToBeAssumed = new iam.Role(this, \"Role\", {\n      roleName: props.roleName,\n      assumedBy: new iam.ArnPrincipal(props.callerRoleArn),\n    })\n\n    // Bucked used for input to CodeBuild.\n    // We let CloudFormation manage the bucket name.\n    const codebuildBucket = new s3.Bucket(this, \"CodebuildSourceBucket\", {\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,\n      lifecycleRules: [\n        {\n          expiration: cdk.Duration.days(5),\n        },\n      ],\n    })\n\n    // The role used for CloudFormation deployment.\n    const cloudFormationRole = new iam.Role(this, \"CloudFormationRole\", {\n      assumedBy: new iam.ServicePrincipal(\"cloudformation.amazonaws.com\"),\n      managedPolicies: [\n        // TODO: Can we restrict this a bit more? E.g. look into how Griid has\n        //  limited what the individual stack deployments have permissions to do.\n        iam.ManagedPolicy.fromAwsManagedPolicyName(\"AdministratorAccess\"),\n      ],\n    })\n\n    // Replace CodeBuild with ECS task?\n    // See https://aws.amazon.com/blogs/devops/using-aws-codebuild-to-execute-administrative-tasks/\n    const codebuildProject = new codebuild.Project(this, \"CodebuildProject\", {\n      environment: {\n        buildImage:\n          props.dockerCredentialsSecretName == null\n            ? codebuild.LinuxBuildImage.fromDockerRegistry(\"node:16\")\n            : codebuild.LinuxBuildImage.fromDockerRegistry(\"node:16\", {\n                secretsManagerCredentials:\n                  secretsmanager.Secret.fromSecretNameV2(\n                    this,\n                    \"dockerCredentialsSecretName\",\n                    props.dockerCredentialsSecretName,\n                  ),\n              }),\n      },\n      buildSpec: codebuild.BuildSpec.fromObject({\n        version: \"0.2\",\n        env: {\n          variables: {\n            CDK_DEPLOY_ROLE_ARN: cloudFormationRole.roleArn,\n            CDK_TOOLKIT_STACK_NAME: props.cdkToolkitStackName,\n          },\n        },\n        phases: {\n          build: {\n            commands: [\n              \"npm install -g aws-cdk\",\n              'cdk --app \"$CODEBUILD_SRC_DIR_CLOUDASSEMBLY\" --role-arn \"$CDK_DEPLOY_ROLE_ARN\" --toolkit-stack-name \"$CDK_TOOLKIT_STACK_NAME\" --require-approval never deploy --exclusively $(cat stack-names.txt)',\n            ],\n          },\n        },\n      }),\n      timeout: cdk.Duration.hours(4),\n    })\n\n    // Grant access to CloudFormation.\n    codebuildProject.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\n          // For diff.\n          \"cloudformation:DescribeStacks\",\n          \"cloudformation:GetTemplate\",\n          // For deploy.\n          \"cloudformation:CreateChangeSet\",\n          \"cloudformation:DeleteStack\",\n          \"cloudformation:DescribeChangeSet\",\n          \"cloudformation:ExecuteChangeSet\",\n          \"cloudformation:DescribeStackEvents\",\n          \"cloudformation:DeleteChangeSet\",\n        ],\n        resources: [\"*\"],\n      }),\n    )\n\n    // Grant access to the CDK Toolkit bucket.\n    codebuildProject.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\n          \"s3:GetObject*\",\n          \"s3:GetBucket*\",\n          \"s3:List*\",\n          \"s3:PutObject*\",\n          \"s3:Abort*\",\n          \"s3:DeleteObject*\",\n        ],\n        resources: [\n          `arn:aws:s3:::${props.cdkToolkitStackName.toLowerCase()}-stagingbucket-*`,\n        ],\n      }),\n    )\n\n    artifactsBucket.grantRead(codebuildProject)\n\n    cloudFormationRole.grantPassRole(codebuildProject.role!)\n\n    codebuildBucket.grantReadWrite(codebuildProject)\n\n    const startDeployFn = new lambda.Function(this, \"StartDeployFunction\", {\n      code: new lambda.InlineCode(\n        `exports.handler = ${startDeployHandler.toString()};`,\n      ),\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      functionName: props.startDeployFunctionName,\n      environment: {\n        PROJECT_NAME: codebuildProject.projectName,\n        BUCKET_NAME: codebuildBucket.bucketName,\n        CDK_CONTEXT: JSON.stringify(props.cdkContext),\n      },\n      timeout: cdk.Duration.seconds(30),\n    })\n\n    startDeployFn.grantInvoke(roleToBeAssumed)\n    codebuildBucket.grantReadWrite(startDeployFn)\n\n    startDeployFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"codebuild:StartBuild\", \"codebuild:BatchGetBuilds\"],\n        resources: [codebuildProject.projectArn],\n      }),\n    )\n\n    const statusFn = new lambda.Function(this, \"StatusFunction\", {\n      code: new lambda.InlineCode(\n        `exports.handler = ${statusHandler.toString()};`,\n      ),\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      functionName: props.statusFunctionName,\n      environment: {\n        PROJECT_NAME: codebuildProject.projectName,\n      },\n      timeout: cdk.Duration.seconds(30),\n    })\n\n    statusFn.grantInvoke(roleToBeAssumed)\n\n    statusFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"codebuild:BatchGetBuilds\"],\n        resources: [codebuildProject.projectArn],\n      }),\n    )\n\n    statusFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"logs:GetLogEvents\"],\n        resources: [\n          `arn:aws:logs:${region}:${account}:log-group:/aws/codebuild/${codebuildProject.projectName}:log-stream:*`,\n        ],\n      }),\n    )\n\n    new cdk.CfnOutput(this, \"RoleToBeAssumedArn\", {\n      value: roleToBeAssumed.roleArn,\n    })\n    new cdk.CfnOutput(this, \"StatusFunctionArn\", {\n      value: statusFn.functionArn,\n    })\n    new cdk.CfnOutput(this, \"StartDeployFunctionArn\", {\n      value: startDeployFn.functionArn,\n    })\n  }\n}\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-deploy.js","sourceRoot":"","sources":["../../src/cdk-deploy/cdk-deploy.ts"],"names":[],"mappings":"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","sourcesContent":["import * as constructs from \"constructs\"\nimport * as codebuild from \"aws-cdk-lib/aws-codebuild\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as lambda from \"aws-cdk-lib/aws-lambda\"\nimport * as s3 from \"aws-cdk-lib/aws-s3\"\nimport * as cdk from \"aws-cdk-lib\"\nimport * as secretsmanager from \"aws-cdk-lib/aws-secretsmanager\"\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\"\n\ninterface Props extends cdk.StackProps {\n  /**\n   * The role that will be granted permission to assume the deploy\n   * role. This role must have permission to assume the deploy role.\n   */\n  callerRoleArn: string\n  /**\n   * The name that will be used for the deploy role. This is the role\n   * that the caller will assume in order to have permission to invoke\n   * the Lambda Functions.\n   */\n  roleName: string\n  /**\n   * The bucket used for storing artifacts. This is used to grant\n   * permission to the role to read artifact. If the bucket is in\n   * another account, it must have a policy which allows the target\n   * account to use IAM permissions from target account.\n   */\n  artifactsBucketName: string\n  startDeployFunctionName: string\n  statusFunctionName: string\n  /**\n   * This is the stack name used with `cdk bootstrap` and can e\n   * found in cdk.json as \"toolkitStackName\".\n   */\n  cdkToolkitStackName: string\n  /**\n   * We pass the CDK context values as they contain feature flags\n   * used by the CDK CLI.\n   */\n  cdkContext: Record<string, string | string[]>\n  /**\n   * The secret containing username and password (or access token)\n   * for a valid docker user. This is used to access private\n   * repositories or to handle docker hub's pull rate limiting.\n   */\n  dockerCredentialsSecretName?: string\n}\n\n/**\n * This construct is responsible for the privileges and logic of\n * automatically deploying stack resources in an account.\n * Its resources are used from a deployment pipeline.\n *\n * The deployment is performed by invoking the \"start deploy\"\n * lambda with details of what should be deployed. As this is\n * responsible for deploying infrastructure, the principal invoking\n * might be able to cause privilege escalation. The principal invoking\n * should be assumed to have full administrator access.\n *\n * The process deploying the infrastructure is locked down so this\n * is only possibly by deployment through CloudFormation, and as\n * such removes a lot of possible escalation paths (e.g. no role\n * can be created by direct API call).\n *\n * The \"status\" lambda can be used to poll for completion, and will\n * also return logs from the job upon completion.\n */\nexport class CdkDeploy extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n\n    const account = cdk.Stack.of(this).account\n    const region = cdk.Stack.of(this).region\n\n    const artifactsBucket = s3.Bucket.fromBucketName(\n      this,\n      \"ArtifactsBucket\",\n      props.artifactsBucketName,\n    )\n\n    const roleToBeAssumed = new iam.Role(this, \"Role\", {\n      roleName: props.roleName,\n      assumedBy: new iam.ArnPrincipal(props.callerRoleArn),\n    })\n\n    // Bucked used for input to CodeBuild.\n    // We let CloudFormation manage the bucket name.\n    const codebuildBucket = new s3.Bucket(this, \"CodebuildSourceBucket\", {\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,\n      lifecycleRules: [\n        {\n          expiration: cdk.Duration.days(5),\n        },\n      ],\n    })\n\n    // The role used for CloudFormation deployment.\n    const cloudFormationRole = new iam.Role(this, \"CloudFormationRole\", {\n      assumedBy: new iam.ServicePrincipal(\"cloudformation.amazonaws.com\"),\n      managedPolicies: [\n        // TODO: Can we restrict this a bit more? E.g. look into how Griid has\n        //  limited what the individual stack deployments have permissions to do.\n        iam.ManagedPolicy.fromAwsManagedPolicyName(\"AdministratorAccess\"),\n      ],\n    })\n\n    // Replace CodeBuild with ECS task?\n    // See https://aws.amazon.com/blogs/devops/using-aws-codebuild-to-execute-administrative-tasks/\n    const codebuildProject = new codebuild.Project(this, \"CodebuildProject\", {\n      environment: {\n        buildImage:\n          props.dockerCredentialsSecretName == null\n            ? codebuild.LinuxBuildImage.fromDockerRegistry(\"node:16\")\n            : codebuild.LinuxBuildImage.fromDockerRegistry(\"node:16\", {\n                secretsManagerCredentials:\n                  secretsmanager.Secret.fromSecretNameV2(\n                    this,\n                    \"dockerCredentialsSecretName\",\n                    props.dockerCredentialsSecretName,\n                  ),\n              }),\n      },\n      buildSpec: codebuild.BuildSpec.fromObject({\n        version: \"0.2\",\n        env: {\n          variables: {\n            CDK_DEPLOY_ROLE_ARN: cloudFormationRole.roleArn,\n            CDK_TOOLKIT_STACK_NAME: props.cdkToolkitStackName,\n          },\n        },\n        phases: {\n          build: {\n            commands: [\n              \"npm install -g aws-cdk\",\n              'cdk --app \"$CODEBUILD_SRC_DIR_CLOUDASSEMBLY\" --role-arn \"$CDK_DEPLOY_ROLE_ARN\" --toolkit-stack-name \"$CDK_TOOLKIT_STACK_NAME\" --require-approval never deploy --exclusively $(cat stack-names.txt)',\n            ],\n          },\n        },\n      }),\n      timeout: cdk.Duration.hours(4),\n    })\n\n    // Grant access to CloudFormation.\n    codebuildProject.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\n          // For diff.\n          \"cloudformation:DescribeStacks\",\n          \"cloudformation:GetTemplate\",\n          // For deploy.\n          \"cloudformation:CreateChangeSet\",\n          \"cloudformation:DeleteStack\",\n          \"cloudformation:DescribeChangeSet\",\n          \"cloudformation:ExecuteChangeSet\",\n          \"cloudformation:DescribeStackEvents\",\n          \"cloudformation:DeleteChangeSet\",\n        ],\n        resources: [\"*\"],\n      }),\n    )\n\n    // Grant access to the CDK Toolkit bucket.\n    codebuildProject.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\n          \"s3:GetObject*\",\n          \"s3:GetBucket*\",\n          \"s3:List*\",\n          \"s3:PutObject*\",\n          \"s3:Abort*\",\n          \"s3:DeleteObject*\",\n        ],\n        resources: [\n          `arn:aws:s3:::${props.cdkToolkitStackName.toLowerCase()}-stagingbucket-*`,\n        ],\n      }),\n    )\n\n    artifactsBucket.grantRead(codebuildProject)\n\n    cloudFormationRole.grantPassRole(codebuildProject.role!)\n\n    codebuildBucket.grantReadWrite(codebuildProject)\n\n    const startDeployFn = new NodejsFunction(this, \"StartDeployFunction\", {\n      entry: require.resolve(\"./start-deploy-handler\"),\n      runtime: lambda.Runtime.NODEJS_18_X,\n      functionName: props.startDeployFunctionName,\n      awsSdkConnectionReuse: false,\n      environment: {\n        PROJECT_NAME: codebuildProject.projectName,\n        BUCKET_NAME: codebuildBucket.bucketName,\n        CDK_CONTEXT: JSON.stringify(props.cdkContext),\n      },\n      timeout: cdk.Duration.seconds(30),\n    })\n\n    startDeployFn.grantInvoke(roleToBeAssumed)\n    codebuildBucket.grantReadWrite(startDeployFn)\n\n    startDeployFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"codebuild:StartBuild\", \"codebuild:BatchGetBuilds\"],\n        resources: [codebuildProject.projectArn],\n      }),\n    )\n\n    const statusFn = new NodejsFunction(this, \"StatusFunction\", {\n      entry: require.resolve(\"./status-handler\"),\n      runtime: lambda.Runtime.NODEJS_18_X,\n      functionName: props.statusFunctionName,\n      awsSdkConnectionReuse: false,\n      environment: {\n        PROJECT_NAME: codebuildProject.projectName,\n      },\n      timeout: cdk.Duration.seconds(30),\n    })\n\n    statusFn.grantInvoke(roleToBeAssumed)\n\n    statusFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"codebuild:BatchGetBuilds\"],\n        resources: [codebuildProject.projectArn],\n      }),\n    )\n\n    statusFn.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"logs:GetLogEvents\"],\n        resources: [\n          `arn:aws:logs:${region}:${account}:log-group:/aws/codebuild/${codebuildProject.projectName}:log-stream:*`,\n        ],\n      }),\n    )\n\n    new cdk.CfnOutput(this, \"RoleToBeAssumedArn\", {\n      value: roleToBeAssumed.roleArn,\n    })\n    new cdk.CfnOutput(this, \"StatusFunctionArn\", {\n      value: statusFn.functionArn,\n    })\n    new cdk.CfnOutput(this, \"StartDeployFunctionArn\", {\n      value: startDeployFn.functionArn,\n    })\n  }\n}\n"]}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const s3 = new AWS.S3();
|
|
3
|
+
exports.handler = void 0;
|
|
4
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
5
|
+
const client_codebuild_1 = require("@aws-sdk/client-codebuild");
|
|
6
|
+
// noinspection JSUnusedGlobalSymbols
|
|
7
|
+
const handler = async (event, context) => {
|
|
8
|
+
const codeBuildClient = new client_codebuild_1.CodeBuildClient();
|
|
9
|
+
const s3Client = new client_s3_1.S3Client();
|
|
11
10
|
function requireEnv(name) {
|
|
12
11
|
const value = process.env[name];
|
|
13
12
|
if (value === undefined) {
|
|
@@ -29,35 +28,29 @@ const startDeployHandler = async (event, context) => {
|
|
|
29
28
|
!event.stackNames.every((it) => typeof it === "string" && validStackName.test(it))) {
|
|
30
29
|
throw new Error("Input invalid: " + JSON.stringify(event, undefined, " "));
|
|
31
30
|
}
|
|
32
|
-
async function
|
|
33
|
-
await
|
|
34
|
-
.putObject({
|
|
31
|
+
async function putObject(name, data) {
|
|
32
|
+
await s3Client.send(new client_s3_1.PutObjectCommand({
|
|
35
33
|
Bucket: bucketName,
|
|
36
34
|
Key: `${s3KeyPrefix}${name}`,
|
|
37
35
|
Body: data,
|
|
38
|
-
})
|
|
39
|
-
.promise();
|
|
36
|
+
}));
|
|
40
37
|
}
|
|
41
|
-
await
|
|
38
|
+
await putObject("stack-names.txt", event.stackNames.join(" "));
|
|
42
39
|
// Ensure that we run the script using same feature flags.
|
|
43
|
-
await
|
|
44
|
-
|
|
45
|
-
}));
|
|
46
|
-
const build = await codebuild
|
|
47
|
-
.startBuild({
|
|
40
|
+
await putObject("cdk.json", JSON.stringify({ context: cdkContext }));
|
|
41
|
+
const { build } = await codeBuildClient.send(new client_codebuild_1.StartBuildCommand({
|
|
48
42
|
projectName,
|
|
49
|
-
sourceTypeOverride:
|
|
43
|
+
sourceTypeOverride: client_codebuild_1.SourceType.S3,
|
|
50
44
|
sourceLocationOverride: `${bucketName}/${s3KeyPrefix}`,
|
|
51
45
|
secondarySourcesOverride: [
|
|
52
46
|
{
|
|
53
|
-
type:
|
|
47
|
+
type: client_codebuild_1.SourceType.S3,
|
|
54
48
|
location: `${event.bucketName}/${event.bucketKey}`,
|
|
55
49
|
sourceIdentifier: "CLOUDASSEMBLY",
|
|
56
50
|
},
|
|
57
51
|
],
|
|
58
|
-
})
|
|
59
|
-
|
|
60
|
-
const buildId = (_a = build.build) === null || _a === void 0 ? void 0 : _a.id;
|
|
52
|
+
}));
|
|
53
|
+
const buildId = build === null || build === void 0 ? void 0 : build.id;
|
|
61
54
|
if (buildId == null) {
|
|
62
55
|
throw new Error("Unknown build ID");
|
|
63
56
|
}
|
|
@@ -68,5 +61,5 @@ const startDeployHandler = async (event, context) => {
|
|
|
68
61
|
jobId: buildId,
|
|
69
62
|
};
|
|
70
63
|
};
|
|
71
|
-
exports.
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
exports.handler = handler;
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhcnQtZGVwbG95LWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2RrLWRlcGxveS9zdGFydC1kZXBsb3ktaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFHQSxrREFBK0Q7QUFDL0QsZ0VBSWtDO0FBUWxDLHFDQUFxQztBQUM5QixNQUFNLE9BQU8sR0FBK0MsS0FBSyxFQUN0RSxLQUFLLEVBQ0wsT0FBTyxFQUNQLEVBQUU7SUFDRixNQUFNLGVBQWUsR0FBRyxJQUFJLGtDQUFlLEVBQUUsQ0FBQTtJQUM3QyxNQUFNLFFBQVEsR0FBRyxJQUFJLG9CQUFRLEVBQUUsQ0FBQTtJQUUvQixTQUFTLFVBQVUsQ0FBQyxJQUFZO1FBQzlCLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDL0IsSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxXQUFXLElBQUksRUFBRSxDQUFDLENBQUE7UUFDcEMsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFBO0lBQ2QsQ0FBQztJQUVELE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxjQUFjLENBQUMsQ0FBQTtJQUM5QyxNQUFNLFVBQVUsR0FBRyxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUE7SUFDNUMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQTtJQUV4RCx5REFBeUQ7SUFDekQsdURBQXVEO0lBQ3ZELE1BQU0sY0FBYyxHQUFHLDBCQUEwQixDQUFBO0lBQ2pELE1BQU0sV0FBVyxHQUFHLEdBQUcsT0FBTyxDQUFDLFlBQVksR0FBRyxDQUFBO0lBRTlDLHNCQUFzQjtJQUN0QixJQUNFLE9BQU8sS0FBSyxDQUFDLFVBQVUsS0FBSyxRQUFRO1FBQ3BDLE9BQU8sS0FBSyxDQUFDLFNBQVMsS0FBSyxRQUFRO1FBQ25DLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDO1FBQ2hDLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQ3JCLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxPQUFPLEVBQUUsS0FBSyxRQUFRLElBQUksY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FDMUQsRUFDRCxDQUFDO1FBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUM3RSxDQUFDO0lBRUQsS0FBSyxVQUFVLFNBQVMsQ0FBQyxJQUFZLEVBQUUsSUFBWTtRQUNqRCxNQUFNLFFBQVEsQ0FBQyxJQUFJLENBQ2pCLElBQUksNEJBQWdCLENBQUM7WUFDbkIsTUFBTSxFQUFFLFVBQVU7WUFDbEIsR0FBRyxFQUFFLEdBQUcsV0FBVyxHQUFHLElBQUksRUFBRTtZQUM1QixJQUFJLEVBQUUsSUFBSTtTQUNYLENBQUMsQ0FDSCxDQUFBO0lBQ0gsQ0FBQztJQUVELE1BQU0sU0FBUyxDQUFDLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUE7SUFDOUQsMERBQTBEO0lBQzFELE1BQU0sU0FBUyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQTtJQUVwRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsTUFBTSxlQUFlLENBQUMsSUFBSSxDQUMxQyxJQUFJLG9DQUFpQixDQUFDO1FBQ3BCLFdBQVc7UUFDWCxrQkFBa0IsRUFBRSw2QkFBVSxDQUFDLEVBQUU7UUFDakMsc0JBQXNCLEVBQUUsR0FBRyxVQUFVLElBQUksV0FBVyxFQUFFO1FBQ3RELHdCQUF3QixFQUFFO1lBQ3hCO2dCQUNFLElBQUksRUFBRSw2QkFBVSxDQUFDLEVBQUU7Z0JBQ25CLFFBQVEsRUFBRSxHQUFHLEtBQUssQ0FBQyxVQUFVLElBQUksS0FBSyxDQUFDLFNBQVMsRUFBRTtnQkFDbEQsZ0JBQWdCLEVBQUUsZUFBZTthQUNsQztTQUNGO0tBQ0YsQ0FBQyxDQUNILENBQUE7SUFDRCxNQUFNLE9BQU8sR0FBRyxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsRUFBRSxDQUFBO0lBRXpCLElBQUksT0FBTyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtJQUNyQyxDQUFDO0lBRUQsT0FBTztRQUNMLGlFQUFpRTtRQUNqRSxvRUFBb0U7UUFDcEUsb0NBQW9DO1FBQ3BDLEtBQUssRUFBRSxPQUFPO0tBQ2YsQ0FBQTtBQUNILENBQUMsQ0FBQTtBQTVFWSxRQUFBLE9BQU8sV0E0RW5CIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1hc3NpZ25tZW50ICovXG5pbXBvcnQgeyBIYW5kbGVyIH0gZnJvbSBcImF3cy1sYW1iZGFcIlxuXG5pbXBvcnQgeyBTM0NsaWVudCwgUHV0T2JqZWN0Q29tbWFuZCB9IGZyb20gXCJAYXdzLXNkay9jbGllbnQtczNcIlxuaW1wb3J0IHtcbiAgQ29kZUJ1aWxkQ2xpZW50LFxuICBTdGFydEJ1aWxkQ29tbWFuZCxcbiAgU291cmNlVHlwZSxcbn0gZnJvbSBcIkBhd3Mtc2RrL2NsaWVudC1jb2RlYnVpbGRcIlxuXG5pbnRlcmZhY2UgU3RhcnREZXBsb3lFeHBlY3RlZElucHV0IHtcbiAgYnVja2V0TmFtZTogc3RyaW5nXG4gIGJ1Y2tldEtleTogc3RyaW5nXG4gIHN0YWNrTmFtZXM6IHN0cmluZ1tdXG59XG5cbi8vIG5vaW5zcGVjdGlvbiBKU1VudXNlZEdsb2JhbFN5bWJvbHNcbmV4cG9ydCBjb25zdCBoYW5kbGVyOiBIYW5kbGVyPFBhcnRpYWw8U3RhcnREZXBsb3lFeHBlY3RlZElucHV0Pj4gPSBhc3luYyAoXG4gIGV2ZW50LFxuICBjb250ZXh0LFxuKSA9PiB7XG4gIGNvbnN0IGNvZGVCdWlsZENsaWVudCA9IG5ldyBDb2RlQnVpbGRDbGllbnQoKVxuICBjb25zdCBzM0NsaWVudCA9IG5ldyBTM0NsaWVudCgpXG5cbiAgZnVuY3Rpb24gcmVxdWlyZUVudihuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHZhbHVlID0gcHJvY2Vzcy5lbnZbbmFtZV1cbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nICR7bmFtZX1gKVxuICAgIH1cbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIGNvbnN0IHByb2plY3ROYW1lID0gcmVxdWlyZUVudihcIlBST0pFQ1RfTkFNRVwiKVxuICBjb25zdCBidWNrZXROYW1lID0gcmVxdWlyZUVudihcIkJVQ0tFVF9OQU1FXCIpXG4gIGNvbnN0IGNka0NvbnRleHQgPSBKU09OLnBhcnNlKHJlcXVpcmVFbnYoXCJDREtfQ09OVEVYVFwiKSlcblxuICAvLyBTaW5jZSB3ZSBwYXNzIHRoZSBzdGFjayBuYW1lcyBhcyBzdHJpbmdzIHRvIHRoZSBzaGVsbCxcbiAgLy8gYmUgYSBiaXQgcmVzdHJpY3RpdmUgb2YgdGhlIHZhbGlkIHZhbHVlcyB3ZSBjYW4gdXNlLlxuICBjb25zdCB2YWxpZFN0YWNrTmFtZSA9IC9eW2EtejAtOV9dW2EtejAtOVxcLV9dKiQvaVxuICBjb25zdCBzM0tleVByZWZpeCA9IGAke2NvbnRleHQuYXdzUmVxdWVzdElkfS9gXG5cbiAgLy8gVmFsaWRhdGUgdGhlIGlucHV0LlxuICBpZiAoXG4gICAgdHlwZW9mIGV2ZW50LmJ1Y2tldE5hbWUgIT09IFwic3RyaW5nXCIgfHxcbiAgICB0eXBlb2YgZXZlbnQuYnVja2V0S2V5ICE9PSBcInN0cmluZ1wiIHx8XG4gICAgIUFycmF5LmlzQXJyYXkoZXZlbnQuc3RhY2tOYW1lcykgfHxcbiAgICAhZXZlbnQuc3RhY2tOYW1lcy5ldmVyeShcbiAgICAgIChpdCkgPT4gdHlwZW9mIGl0ID09PSBcInN0cmluZ1wiICYmIHZhbGlkU3RhY2tOYW1lLnRlc3QoaXQpLFxuICAgIClcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiSW5wdXQgaW52YWxpZDogXCIgKyBKU09OLnN0cmluZ2lmeShldmVudCwgdW5kZWZpbmVkLCBcIiAgXCIpKVxuICB9XG5cbiAgYXN5bmMgZnVuY3Rpb24gcHV0T2JqZWN0KG5hbWU6IHN0cmluZywgZGF0YTogc3RyaW5nKSB7XG4gICAgYXdhaXQgczNDbGllbnQuc2VuZChcbiAgICAgIG5ldyBQdXRPYmplY3RDb21tYW5kKHtcbiAgICAgICAgQnVja2V0OiBidWNrZXROYW1lLFxuICAgICAgICBLZXk6IGAke3MzS2V5UHJlZml4fSR7bmFtZX1gLFxuICAgICAgICBCb2R5OiBkYXRhLFxuICAgICAgfSksXG4gICAgKVxuICB9XG5cbiAgYXdhaXQgcHV0T2JqZWN0KFwic3RhY2stbmFtZXMudHh0XCIsIGV2ZW50LnN0YWNrTmFtZXMuam9pbihcIiBcIikpXG4gIC8vIEVuc3VyZSB0aGF0IHdlIHJ1biB0aGUgc2NyaXB0IHVzaW5nIHNhbWUgZmVhdHVyZSBmbGFncy5cbiAgYXdhaXQgcHV0T2JqZWN0KFwiY2RrLmpzb25cIiwgSlNPTi5zdHJpbmdpZnkoeyBjb250ZXh0OiBjZGtDb250ZXh0IH0pKVxuXG4gIGNvbnN0IHsgYnVpbGQgfSA9IGF3YWl0IGNvZGVCdWlsZENsaWVudC5zZW5kKFxuICAgIG5ldyBTdGFydEJ1aWxkQ29tbWFuZCh7XG4gICAgICBwcm9qZWN0TmFtZSxcbiAgICAgIHNvdXJjZVR5cGVPdmVycmlkZTogU291cmNlVHlwZS5TMyxcbiAgICAgIHNvdXJjZUxvY2F0aW9uT3ZlcnJpZGU6IGAke2J1Y2tldE5hbWV9LyR7czNLZXlQcmVmaXh9YCxcbiAgICAgIHNlY29uZGFyeVNvdXJjZXNPdmVycmlkZTogW1xuICAgICAgICB7XG4gICAgICAgICAgdHlwZTogU291cmNlVHlwZS5TMyxcbiAgICAgICAgICBsb2NhdGlvbjogYCR7ZXZlbnQuYnVja2V0TmFtZX0vJHtldmVudC5idWNrZXRLZXl9YCxcbiAgICAgICAgICBzb3VyY2VJZGVudGlmaWVyOiBcIkNMT1VEQVNTRU1CTFlcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfSksXG4gIClcbiAgY29uc3QgYnVpbGRJZCA9IGJ1aWxkPy5pZFxuXG4gIGlmIChidWlsZElkID09IG51bGwpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJVbmtub3duIGJ1aWxkIElEXCIpXG4gIH1cblxuICByZXR1cm4ge1xuICAgIC8vIFRoaXMgaXMgdGhlIHZhbHVlIHRoZSBjYWxsZXIgd2lsbCB1c2UgdG8gZmV0Y2ggdXBkYXRlZCBzdGF0dXMuXG4gICAgLy8gQXZvaWQgZXhwb3Npbmcgd2hhdCBraW5kIG9mIElEIHRoaXMgaXMsIGJlY2F1c2Ugd2Ugc2hvdWxkIGJlIGZyZWVcbiAgICAvLyB0byBjaGFuZ2UgaW1wbGVtZW50YXRpb24gZGV0YWlscy5cbiAgICBqb2JJZDogYnVpbGRJZCxcbiAgfVxufVxuIl19
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
3
|
+
exports.handler = void 0;
|
|
4
|
+
const client_codebuild_1 = require("@aws-sdk/client-codebuild");
|
|
5
|
+
const client_cloudwatch_logs_1 = require("@aws-sdk/client-cloudwatch-logs");
|
|
6
|
+
const handler = async (event) => {
|
|
7
|
+
const codeBuildClient = new client_codebuild_1.CodeBuildClient();
|
|
8
|
+
const cloudWatchLogsClient = new client_cloudwatch_logs_1.CloudWatchLogsClient();
|
|
8
9
|
function requireEnv(name) {
|
|
9
10
|
const value = process.env[name];
|
|
10
11
|
if (value === undefined) {
|
|
@@ -31,13 +32,12 @@ const statusHandler = async (event) => {
|
|
|
31
32
|
return false;
|
|
32
33
|
}
|
|
33
34
|
async function getBuild(buildId) {
|
|
34
|
-
var _a
|
|
35
|
-
const
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
throw new Error(`Expected 1 item, found ${(_c = (_b = result.builds) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : "unknown"}`);
|
|
35
|
+
var _a;
|
|
36
|
+
const { builds } = await codeBuildClient.send(new client_codebuild_1.BatchGetBuildsCommand({ ids: [buildId] }));
|
|
37
|
+
if ((builds === null || builds === void 0 ? void 0 : builds.length) !== 1) {
|
|
38
|
+
throw new Error(`Expected 1 item, found ${(_a = builds === null || builds === void 0 ? void 0 : builds.length) !== null && _a !== void 0 ? _a : "unknown"}`);
|
|
39
39
|
}
|
|
40
|
-
return
|
|
40
|
+
return builds[0];
|
|
41
41
|
}
|
|
42
42
|
async function getLogs(build) {
|
|
43
43
|
if (build.logs == null) {
|
|
@@ -49,19 +49,16 @@ const statusHandler = async (event) => {
|
|
|
49
49
|
if (build.logs.streamName == null) {
|
|
50
50
|
throw new Error("Missing log streamName");
|
|
51
51
|
}
|
|
52
|
-
const
|
|
53
|
-
const data = await cloudwatchlogs
|
|
54
|
-
.getLogEvents({
|
|
52
|
+
const { events } = await cloudWatchLogsClient.send(new client_cloudwatch_logs_1.GetLogEventsCommand({
|
|
55
53
|
logGroupName: build.logs.groupName,
|
|
56
54
|
logStreamName: build.logs.streamName,
|
|
57
55
|
startFromHead: true,
|
|
58
|
-
})
|
|
59
|
-
|
|
60
|
-
if (data.events == null) {
|
|
56
|
+
}));
|
|
57
|
+
if (events == null) {
|
|
61
58
|
throw new Error("Failed to fetch log events");
|
|
62
59
|
}
|
|
63
60
|
// The logs contain newlines, so no need to add more.
|
|
64
|
-
return
|
|
61
|
+
return events.map((it) => it.message).join("");
|
|
65
62
|
}
|
|
66
63
|
const projectName = requireEnv("PROJECT_NAME");
|
|
67
64
|
// Validate the input.
|
|
@@ -79,5 +76,5 @@ const statusHandler = async (event) => {
|
|
|
79
76
|
logs,
|
|
80
77
|
};
|
|
81
78
|
};
|
|
82
|
-
exports.
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
exports.handler = handler;
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2RrLWRlcGxveS9zdGF0dXMtaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxnRUFLa0M7QUFFbEMsNEVBR3dDO0FBTWpDLE1BQU0sT0FBTyxHQUEwQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUU7SUFDNUUsTUFBTSxlQUFlLEdBQUcsSUFBSSxrQ0FBZSxFQUFFLENBQUE7SUFDN0MsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLDZDQUFvQixFQUFFLENBQUE7SUFFdkQsU0FBUyxVQUFVLENBQUMsSUFBWTtRQUM5QixNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQy9CLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsV0FBVyxJQUFJLEVBQUUsQ0FBQyxDQUFBO1FBQ3BDLENBQUM7UUFDRCxPQUFPLEtBQUssQ0FBQTtJQUNkLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNILFNBQVMsVUFBVSxDQUFDLE1BQWtCO1FBQ3BDLElBQUksTUFBTSxJQUFJLFdBQVcsRUFBRSxDQUFDO1lBQzFCLE9BQU8sSUFBSSxDQUFBO1FBQ2IsQ0FBQztRQUVELElBQUksTUFBTSxJQUFJLGFBQWEsRUFBRSxDQUFDO1lBQzVCLE9BQU8sSUFBSSxDQUFBO1FBQ2IsQ0FBQztRQUVELE9BQU8sS0FBSyxDQUFBO0lBQ2QsQ0FBQztJQUVELEtBQUssVUFBVSxRQUFRLENBQUMsT0FBZTs7UUFDckMsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLE1BQU0sZUFBZSxDQUFDLElBQUksQ0FDM0MsSUFBSSx3Q0FBcUIsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FDOUMsQ0FBQTtRQUVELElBQUksQ0FBQSxNQUFNLGFBQU4sTUFBTSx1QkFBTixNQUFNLENBQUUsTUFBTSxNQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLE1BQUEsTUFBTSxhQUFOLE1BQU0sdUJBQU4sTUFBTSxDQUFFLE1BQU0sbUNBQUksU0FBUyxFQUFFLENBQUMsQ0FBQTtRQUMxRSxDQUFDO1FBRUQsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDbEIsQ0FBQztJQUVELEtBQUssVUFBVSxPQUFPLENBQUMsS0FBWTtRQUNqQyxJQUFJLEtBQUssQ0FBQyxJQUFJLElBQUksSUFBSSxFQUFFLENBQUM7WUFDdkIsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFBO1FBQ3BELENBQUM7UUFFRCxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2pDLE1BQU0sSUFBSSxLQUFLLENBQUMsdUJBQXVCLENBQUMsQ0FBQTtRQUMxQyxDQUFDO1FBRUQsSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNsQyxNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUE7UUFDM0MsQ0FBQztRQUVELE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLG9CQUFvQixDQUFDLElBQUksQ0FDaEQsSUFBSSw0Q0FBbUIsQ0FBQztZQUN0QixZQUFZLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTO1lBQ2xDLGFBQWEsRUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVU7WUFDcEMsYUFBYSxFQUFFLElBQUk7U0FDcEIsQ0FBQyxDQUNILENBQUE7UUFFRCxJQUFJLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNuQixNQUFNLElBQUksS0FBSyxDQUFDLDRCQUE0QixDQUFDLENBQUE7UUFDL0MsQ0FBQztRQUVELHFEQUFxRDtRQUNyRCxPQUFPLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUE7SUFDaEQsQ0FBQztJQUVELE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxjQUFjLENBQUMsQ0FBQTtJQUU5QyxzQkFBc0I7SUFDdEIsSUFDRSxPQUFPLEtBQUssQ0FBQyxLQUFLLEtBQUssUUFBUTtRQUMvQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLEdBQUcsV0FBVyxHQUFHLENBQUMsRUFDMUMsQ0FBQztRQUNELE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUE7SUFDN0UsQ0FBQztJQUVELE1BQU0sS0FBSyxHQUFHLE1BQU0sUUFBUSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUV6QyxNQUFNLE9BQU8sR0FDWCxLQUFLLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBRWxFLDBDQUEwQztJQUMxQyxNQUFNLElBQUksR0FBRyxPQUFPLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFBO0lBRTFELE9BQU87UUFDTCxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUs7UUFDbEIsT0FBTztRQUNQLElBQUk7S0FDTCxDQUFBO0FBQ0gsQ0FBQyxDQUFBO0FBakdZLFFBQUEsT0FBTyxXQWlHbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIYW5kbGVyIH0gZnJvbSBcImF3cy1sYW1iZGFcIlxuXG5pbXBvcnQge1xuICBDb2RlQnVpbGRDbGllbnQsXG4gIEJhdGNoR2V0QnVpbGRzQ29tbWFuZCxcbiAgU3RhdHVzVHlwZSxcbiAgQnVpbGQsXG59IGZyb20gXCJAYXdzLXNkay9jbGllbnQtY29kZWJ1aWxkXCJcblxuaW1wb3J0IHtcbiAgQ2xvdWRXYXRjaExvZ3NDbGllbnQsXG4gIEdldExvZ0V2ZW50c0NvbW1hbmQsXG59IGZyb20gXCJAYXdzLXNkay9jbGllbnQtY2xvdWR3YXRjaC1sb2dzXCJcblxuaW50ZXJmYWNlIFN0YXR1c0V4cGVjdGVkSW5wdXQge1xuICBqb2JJZDogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBoYW5kbGVyOiBIYW5kbGVyPFBhcnRpYWw8U3RhdHVzRXhwZWN0ZWRJbnB1dD4+ID0gYXN5bmMgKGV2ZW50KSA9PiB7XG4gIGNvbnN0IGNvZGVCdWlsZENsaWVudCA9IG5ldyBDb2RlQnVpbGRDbGllbnQoKVxuICBjb25zdCBjbG91ZFdhdGNoTG9nc0NsaWVudCA9IG5ldyBDbG91ZFdhdGNoTG9nc0NsaWVudCgpXG5cbiAgZnVuY3Rpb24gcmVxdWlyZUVudihuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIGNvbnN0IHZhbHVlID0gcHJvY2Vzcy5lbnZbbmFtZV1cbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nICR7bmFtZX1gKVxuICAgIH1cbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgc3VjY2VzcyBzdGF0dXMuXG4gICAqXG4gICAqIEEgdmFsdWUgb2YgdHJ1ZSBtZWFucyB0aGUgam9iIGhhcyBjb21wbGV0ZWQgc3VjY2Vzc2Z1bGx5LCB3aGlsZVxuICAgKiBhIHZhbHVlIG9mIGZhbHNlIG1lYW5zIHRoZSBqb2IgZGlkIGNvbXBsZXRlIGJ1dCBub3Qgc3VjY2Vzc2Z1bGx5LlxuICAgKlxuICAgKiBBIG51bGwgdmFsdWUgbWVhbnMgdGhlIGpvYiBpcyBzdGlsbCBpbiBwcm9ncmVzcyBhbmQgdGhlXG4gICAqIGNvbXBsZXRpb24gc3RhdHVzIGlzIG5vdCB5ZXQga25vd24uXG4gICAqL1xuICBmdW5jdGlvbiBnZXRTdWNjZXNzKHN0YXR1czogU3RhdHVzVHlwZSk6IGJvb2xlYW4gfCBudWxsIHtcbiAgICBpZiAoc3RhdHVzID09IFwiU1VDQ0VFREVEXCIpIHtcbiAgICAgIHJldHVybiB0cnVlXG4gICAgfVxuXG4gICAgaWYgKHN0YXR1cyA9PSBcIklOX1BST0dSRVNTXCIpIHtcbiAgICAgIHJldHVybiBudWxsXG4gICAgfVxuXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICBhc3luYyBmdW5jdGlvbiBnZXRCdWlsZChidWlsZElkOiBzdHJpbmcpOiBQcm9taXNlPEJ1aWxkPiB7XG4gICAgY29uc3QgeyBidWlsZHMgfSA9IGF3YWl0IGNvZGVCdWlsZENsaWVudC5zZW5kKFxuICAgICAgbmV3IEJhdGNoR2V0QnVpbGRzQ29tbWFuZCh7IGlkczogW2J1aWxkSWRdIH0pLFxuICAgIClcblxuICAgIGlmIChidWlsZHM/Lmxlbmd0aCAhPT0gMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBFeHBlY3RlZCAxIGl0ZW0sIGZvdW5kICR7YnVpbGRzPy5sZW5ndGggPz8gXCJ1bmtub3duXCJ9YClcbiAgICB9XG5cbiAgICByZXR1cm4gYnVpbGRzWzBdXG4gIH1cblxuICBhc3luYyBmdW5jdGlvbiBnZXRMb2dzKGJ1aWxkOiBCdWlsZCk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgaWYgKGJ1aWxkLmxvZ3MgPT0gbnVsbCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiTWlzc2luZyBsb2dzIGF0dHJpYnV0ZSBvbiBidWlsZFwiKVxuICAgIH1cblxuICAgIGlmIChidWlsZC5sb2dzLmdyb3VwTmFtZSA9PSBudWxsKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJNaXNzaW5nIGxvZyBncm91cE5hbWVcIilcbiAgICB9XG5cbiAgICBpZiAoYnVpbGQubG9ncy5zdHJlYW1OYW1lID09IG51bGwpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcIk1pc3NpbmcgbG9nIHN0cmVhbU5hbWVcIilcbiAgICB9XG5cbiAgICBjb25zdCB7IGV2ZW50cyB9ID0gYXdhaXQgY2xvdWRXYXRjaExvZ3NDbGllbnQuc2VuZChcbiAgICAgIG5ldyBHZXRMb2dFdmVudHNDb21tYW5kKHtcbiAgICAgICAgbG9nR3JvdXBOYW1lOiBidWlsZC5sb2dzLmdyb3VwTmFtZSxcbiAgICAgICAgbG9nU3RyZWFtTmFtZTogYnVpbGQubG9ncy5zdHJlYW1OYW1lLFxuICAgICAgICBzdGFydEZyb21IZWFkOiB0cnVlLFxuICAgICAgfSksXG4gICAgKVxuXG4gICAgaWYgKGV2ZW50cyA9PSBudWxsKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJGYWlsZWQgdG8gZmV0Y2ggbG9nIGV2ZW50c1wiKVxuICAgIH1cblxuICAgIC8vIFRoZSBsb2dzIGNvbnRhaW4gbmV3bGluZXMsIHNvIG5vIG5lZWQgdG8gYWRkIG1vcmUuXG4gICAgcmV0dXJuIGV2ZW50cy5tYXAoKGl0KSA9PiBpdC5tZXNzYWdlKS5qb2luKFwiXCIpXG4gIH1cblxuICBjb25zdCBwcm9qZWN0TmFtZSA9IHJlcXVpcmVFbnYoXCJQUk9KRUNUX05BTUVcIilcblxuICAvLyBWYWxpZGF0ZSB0aGUgaW5wdXQuXG4gIGlmIChcbiAgICB0eXBlb2YgZXZlbnQuam9iSWQgIT09IFwic3RyaW5nXCIgfHxcbiAgICAhZXZlbnQuam9iSWQuc3RhcnRzV2l0aChgJHtwcm9qZWN0TmFtZX06YClcbiAgKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiSW5wdXQgaW52YWxpZDogXCIgKyBKU09OLnN0cmluZ2lmeShldmVudCwgdW5kZWZpbmVkLCBcIiAgXCIpKVxuICB9XG5cbiAgY29uc3QgYnVpbGQgPSBhd2FpdCBnZXRCdWlsZChldmVudC5qb2JJZClcblxuICBjb25zdCBzdWNjZXNzID1cbiAgICBidWlsZC5idWlsZFN0YXR1cyA9PSBudWxsID8gbnVsbCA6IGdldFN1Y2Nlc3MoYnVpbGQuYnVpbGRTdGF0dXMpXG5cbiAgLy8gUmVhZCBsb2dzIGZyb20gQ2xvdWRXYXRjaCBpZiBjb21wbGV0ZWQuXG4gIGNvbnN0IGxvZ3MgPSBzdWNjZXNzICE9IG51bGwgPyBhd2FpdCBnZXRMb2dzKGJ1aWxkKSA6IG51bGxcblxuICByZXR1cm4ge1xuICAgIGpvYklkOiBldmVudC5qb2JJZCxcbiAgICBzdWNjZXNzLFxuICAgIGxvZ3MsXG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,63 +1,74 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
const
|
|
3
|
+
exports.handler = void 0;
|
|
4
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
5
|
+
const client_codepipeline_1 = require("@aws-sdk/client-codepipeline");
|
|
6
|
+
const lib_storage_1 = require("@aws-sdk/lib-storage");
|
|
7
|
+
const handler = async (event, context) => {
|
|
8
|
+
const s3Client = new client_s3_1.S3Client();
|
|
9
|
+
const codepipelineClient = new client_codepipeline_1.CodePipelineClient();
|
|
9
10
|
const jobId = event["CodePipeline.job"].id;
|
|
10
11
|
try {
|
|
11
12
|
const userParametersRaw = event["CodePipeline.job"].data.actionConfiguration.configuration
|
|
12
13
|
.UserParameters;
|
|
13
14
|
console.log("User parameters", userParametersRaw);
|
|
15
|
+
console.log("Parsing user parameters");
|
|
14
16
|
const userParameters = JSON.parse(userParametersRaw);
|
|
15
|
-
|
|
16
|
-
|
|
17
|
+
console.log("Fetching reference data from S3");
|
|
18
|
+
const getReferenceDataResp = await s3Client.send(new client_s3_1.GetObjectCommand({
|
|
17
19
|
Bucket: userParameters.bucketName,
|
|
18
20
|
Key: userParameters.objectKey,
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
|
|
21
|
+
}));
|
|
22
|
+
const referenceData = await getReferenceDataResp.Body.transformToString("utf-8");
|
|
23
|
+
console.log("Parsing reference data from S3");
|
|
22
24
|
const cloudAssemblyReference = JSON.parse(referenceData);
|
|
23
25
|
const outputArtifact = event["CodePipeline.job"].data.outputArtifacts[0];
|
|
24
26
|
const s3Loc = outputArtifact.location.s3Location;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
+
console.log("Fetching Cloud Assembly ZIP data from S3");
|
|
28
|
+
const cloudAssemblyZipData = await s3Client.send(new client_s3_1.GetObjectCommand({
|
|
27
29
|
Bucket: cloudAssemblyReference.cloudAssemblyBucketName,
|
|
28
30
|
Key: cloudAssemblyReference.cloudAssemblyBucketKey,
|
|
29
|
-
})
|
|
30
|
-
|
|
31
|
-
console.log("
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
})
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
31
|
+
}));
|
|
32
|
+
console.log("Content-Length of Cloud Assembly (bytes)", cloudAssemblyZipData.ContentLength);
|
|
33
|
+
console.log("Creating authenticated S3 client for artifact upload");
|
|
34
|
+
const artifactCreds = event["CodePipeline.job"].data.artifactCredentials;
|
|
35
|
+
if (artifactCreds === undefined) {
|
|
36
|
+
console.error("No artifact credentials found in job event");
|
|
37
|
+
}
|
|
38
|
+
const authedS3Client = new client_s3_1.S3Client({
|
|
39
|
+
credentials: artifactCreds,
|
|
40
|
+
});
|
|
41
|
+
console.log(`Uploading Cloud Assembly ZIP to s3://${s3Loc.bucketName}/${s3Loc.objectKey}`);
|
|
42
|
+
const upload = new lib_storage_1.Upload({
|
|
43
|
+
client: authedS3Client,
|
|
44
|
+
params: {
|
|
45
|
+
Bucket: s3Loc.bucketName,
|
|
46
|
+
Key: s3Loc.objectKey,
|
|
47
|
+
Body: cloudAssemblyZipData.Body,
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
upload.on("httpUploadProgress", (progress) => {
|
|
51
|
+
console.log(progress);
|
|
52
|
+
});
|
|
53
|
+
await upload.done();
|
|
54
|
+
console.log("Sending success result to CodePipeline");
|
|
55
|
+
await codepipelineClient.send(new client_codepipeline_1.PutJobSuccessResultCommand({
|
|
43
56
|
jobId,
|
|
44
|
-
})
|
|
45
|
-
.promise();
|
|
57
|
+
}));
|
|
46
58
|
console.log("Success");
|
|
47
59
|
}
|
|
48
60
|
catch (e) {
|
|
49
|
-
|
|
50
|
-
|
|
61
|
+
console.log("Sending failure result to CodePipeline");
|
|
62
|
+
await codepipelineClient.send(new client_codepipeline_1.PutJobFailureResultCommand({
|
|
51
63
|
failureDetails: {
|
|
52
64
|
message: JSON.stringify(e),
|
|
53
65
|
type: "JobFailed",
|
|
54
66
|
externalExecutionId: context.awsRequestId,
|
|
55
67
|
},
|
|
56
68
|
jobId,
|
|
57
|
-
})
|
|
58
|
-
.promise();
|
|
69
|
+
}));
|
|
59
70
|
console.error("Failed", e);
|
|
60
71
|
}
|
|
61
72
|
};
|
|
62
|
-
exports.
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
exports.handler = handler;
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-assembly-lookup-handler.js","sourceRoot":"","sources":["../../src/cdk-pipelines/cloud-assembly-lookup-handler.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-var-requires */\nimport type { Handler } from \"aws-lambda\"\nimport { GetObjectCommand, S3Client } from \"@aws-sdk/client-s3\"\nimport {\n  CodePipelineClient,\n  PutJobFailureResultCommand,\n  PutJobSuccessResultCommand,\n} from \"@aws-sdk/client-codepipeline\"\nimport { Upload } from \"@aws-sdk/lib-storage\"\n\n// Relevant fields from\n// https://docs.amazonaws.cn/en_us/lambda/latest/dg/services-codepipeline.html\ninterface CodePipelineEvent {\n  \"CodePipeline.job\": {\n    id: string\n    data: {\n      actionConfiguration: {\n        configuration: {\n          // JSON\n          UserParameters: string\n        }\n      }\n      outputArtifacts: {\n        name: string\n        location: {\n          s3Location: {\n            bucketName: string\n            objectKey: string\n          }\n        }\n      }[]\n      artifactCredentials: {\n        accessKeyId: string\n        secretAccessKey: string\n        sessionToken: string\n      }\n    }\n  }\n}\n\ninterface CloudAssemblyReference {\n  cloudAssemblyBucketName: string\n  cloudAssemblyBucketKey: string\n}\n\nexport interface CloudAssemblyLookupUserParameters {\n  bucketName: string\n  objectKey: string\n}\n\nexport const handler: Handler = async (event: CodePipelineEvent, context) => {\n  const s3Client = new S3Client()\n  const codepipelineClient = new CodePipelineClient()\n\n  const jobId = event[\"CodePipeline.job\"].id\n\n  try {\n    const userParametersRaw =\n      event[\"CodePipeline.job\"].data.actionConfiguration.configuration\n        .UserParameters\n\n    console.log(\"User parameters\", userParametersRaw)\n\n    console.log(\"Parsing user parameters\")\n    const userParameters = JSON.parse(\n      userParametersRaw,\n    ) as CloudAssemblyLookupUserParameters\n\n    console.log(\"Fetching reference data from S3\")\n    const getReferenceDataResp = await s3Client.send(\n      new GetObjectCommand({\n        Bucket: userParameters.bucketName,\n        Key: userParameters.objectKey,\n      }),\n    )\n    const referenceData =\n      await getReferenceDataResp.Body!.transformToString(\"utf-8\")\n\n    console.log(\"Parsing reference data from S3\")\n    const cloudAssemblyReference = JSON.parse(\n      referenceData,\n    ) as CloudAssemblyReference\n\n    const outputArtifact = event[\"CodePipeline.job\"].data.outputArtifacts[0]\n    const s3Loc = outputArtifact.location.s3Location\n\n    console.log(\"Fetching Cloud Assembly ZIP data from S3\")\n    const cloudAssemblyZipData = await s3Client.send(\n      new GetObjectCommand({\n        Bucket: cloudAssemblyReference.cloudAssemblyBucketName,\n        Key: cloudAssemblyReference.cloudAssemblyBucketKey,\n      }),\n    )\n    console.log(\n      \"Content-Length of Cloud Assembly (bytes)\",\n      cloudAssemblyZipData.ContentLength,\n    )\n\n    console.log(\"Creating authenticated S3 client for artifact upload\")\n    const artifactCreds = event[\"CodePipeline.job\"].data.artifactCredentials\n    if (artifactCreds === undefined) {\n      console.error(\"No artifact credentials found in job event\")\n    }\n    const authedS3Client = new S3Client({\n      credentials: artifactCreds,\n    })\n\n    console.log(\n      `Uploading Cloud Assembly ZIP to s3://${s3Loc.bucketName}/${s3Loc.objectKey}`,\n    )\n\n    const upload = new Upload({\n      client: authedS3Client,\n      params: {\n        Bucket: s3Loc.bucketName,\n        Key: s3Loc.objectKey,\n        Body: cloudAssemblyZipData.Body,\n      },\n    })\n\n    upload.on(\"httpUploadProgress\", (progress) => {\n      console.log(progress)\n    })\n\n    await upload.done()\n\n    console.log(\"Sending success result to CodePipeline\")\n    await codepipelineClient.send(\n      new PutJobSuccessResultCommand({\n        jobId,\n      }),\n    )\n    console.log(\"Success\")\n  } catch (e) {\n    console.log(\"Sending failure result to CodePipeline\")\n    await codepipelineClient.send(\n      new PutJobFailureResultCommand({\n        failureDetails: {\n          message: JSON.stringify(e),\n          type: \"JobFailed\",\n          externalExecutionId: context.awsRequestId,\n        },\n        jobId,\n      }),\n    )\n    console.error(\"Failed\", e)\n  }\n}\n"]}
|