@liflig/cdk 2.18.5 → 2.18.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (140) hide show
  1. package/assets/cloudtrail-slack-integration-lambda/main.py +267 -0
  2. package/assets/pipeline-slack-notification-lambda/index.py +300 -0
  3. package/assets/prepare-cdk-source-lambda/index.py +159 -0
  4. package/assets/slack-alarm-lambda/index.py +103 -0
  5. package/lib/alarms/database-alarms.d.ts +125 -0
  6. package/lib/alarms/database-alarms.js +171 -0
  7. package/lib/alarms/index.d.ts +3 -0
  8. package/lib/alarms/index.js +10 -0
  9. package/lib/alarms/service-alarms.d.ts +145 -0
  10. package/lib/alarms/service-alarms.js +148 -0
  11. package/lib/alarms/ses-alarms.d.ts +67 -0
  12. package/lib/alarms/ses-alarms.js +49 -0
  13. package/lib/alarms/slack-alarm.d.ts +25 -0
  14. package/lib/alarms/slack-alarm.js +47 -0
  15. package/lib/bastion-host.d.ts +41 -0
  16. package/lib/bastion-host.js +86 -0
  17. package/lib/bin/cdk-create-snapshots.d.ts +2 -0
  18. package/lib/bin/fetch-pipeline-variables.d.ts +2 -0
  19. package/lib/build-artifacts/index.d.ts +68 -0
  20. package/lib/build-artifacts/index.js +118 -0
  21. package/lib/cdk-deploy/cdk-deploy.d.ts +63 -0
  22. package/lib/cdk-deploy/cdk-deploy.js +175 -0
  23. package/lib/cdk-deploy/index.d.ts +1 -0
  24. package/lib/cdk-deploy/index.js +6 -0
  25. package/lib/cdk-deploy/start-deploy-handler.d.ts +8 -0
  26. package/lib/cdk-deploy/start-deploy-handler.js +72 -0
  27. package/lib/cdk-deploy/status-handler.d.ts +6 -0
  28. package/lib/cdk-deploy/status-handler.js +83 -0
  29. package/lib/cdk-pipelines/cloud-assembly-lookup-handler.d.ts +6 -0
  30. package/lib/cdk-pipelines/cloud-assembly-lookup-handler.js +63 -0
  31. package/lib/cdk-pipelines/index.d.ts +3 -0
  32. package/lib/cdk-pipelines/index.js +10 -0
  33. package/lib/cdk-pipelines/liflig-cdk-pipeline.d.ts +110 -0
  34. package/lib/cdk-pipelines/liflig-cdk-pipeline.js +232 -0
  35. package/lib/cdk-pipelines/slack-notification.d.ts +51 -0
  36. package/lib/cdk-pipelines/slack-notification.js +54 -0
  37. package/lib/cdk-pipelines/variables.d.ts +15 -0
  38. package/lib/cdk-pipelines/variables.js +80 -0
  39. package/lib/cloudtrail-slack-integration/cloudtrail-slack-integration.d.ts +47 -0
  40. package/lib/cloudtrail-slack-integration/cloudtrail-slack-integration.js +211 -0
  41. package/lib/cloudtrail-slack-integration/index.d.ts +1 -0
  42. package/lib/cloudtrail-slack-integration/index.js +6 -0
  43. package/lib/configure-parameters/configure-parameters.d.ts +61 -0
  44. package/lib/configure-parameters/configure-parameters.js +94 -0
  45. package/lib/configure-parameters/index.d.ts +1 -0
  46. package/lib/configure-parameters/index.js +6 -0
  47. package/lib/cross-region-ssm-parameter.d.ts +13 -0
  48. package/lib/cross-region-ssm-parameter.js +46 -0
  49. package/lib/ecs/cluster.d.ts +25 -0
  50. package/lib/ecs/cluster.js +70 -0
  51. package/lib/ecs/fargate-service.d.ts +63 -0
  52. package/lib/ecs/fargate-service.js +98 -0
  53. package/lib/ecs/index.d.ts +3 -0
  54. package/lib/ecs/index.js +10 -0
  55. package/lib/ecs/listener-rule.d.ts +25 -0
  56. package/lib/ecs/listener-rule.js +27 -0
  57. package/lib/ecs-update-image/artifact-status.d.ts +39 -0
  58. package/lib/ecs-update-image/artifact-status.js +41 -0
  59. package/lib/ecs-update-image/ecs-update-image.d.ts +41 -0
  60. package/lib/ecs-update-image/ecs-update-image.js +98 -0
  61. package/lib/ecs-update-image/index.d.ts +3 -0
  62. package/lib/ecs-update-image/index.js +10 -0
  63. package/lib/ecs-update-image/start-deploy-handler.d.ts +6 -0
  64. package/lib/ecs-update-image/start-deploy-handler.js +104 -0
  65. package/lib/ecs-update-image/status-handler.d.ts +11 -0
  66. package/lib/ecs-update-image/status-handler.js +74 -0
  67. package/lib/ecs-update-image/tag.d.ts +47 -0
  68. package/lib/ecs-update-image/tag.js +67 -0
  69. package/lib/feature-flags.d.ts +18 -0
  70. package/lib/feature-flags.js +48 -0
  71. package/lib/griid/artefact-bucket.d.ts +7 -0
  72. package/lib/griid/artefact-bucket.js +30 -0
  73. package/lib/griid/index.d.ts +4 -0
  74. package/lib/griid/index.js +18 -0
  75. package/lib/hosted-zone-with-param.d.ts +29 -0
  76. package/lib/hosted-zone-with-param.js +65 -0
  77. package/lib/index.d.ts +32 -0
  78. package/lib/kinesis/index.d.ts +1 -0
  79. package/lib/kinesis/index.js +6 -0
  80. package/lib/kinesis/kinesis-to-datadog-stream.d.ts +28 -0
  81. package/lib/kinesis/kinesis-to-datadog-stream.js +126 -0
  82. package/lib/load-balancer/index.d.ts +1 -0
  83. package/lib/load-balancer/index.js +6 -0
  84. package/lib/load-balancer/load-balancer.d.ts +16 -0
  85. package/lib/load-balancer/load-balancer.js +60 -0
  86. package/lib/pipelines/conventions.d.ts +14 -0
  87. package/lib/pipelines/conventions.js +24 -0
  88. package/lib/pipelines/deploy-env.d.ts +18 -0
  89. package/lib/pipelines/deploy-env.js +96 -0
  90. package/lib/pipelines/index.d.ts +2 -0
  91. package/lib/pipelines/index.js +8 -0
  92. package/lib/pipelines/liflig-cdk-deployer-deps.d.ts +13 -0
  93. package/lib/pipelines/liflig-cdk-deployer-deps.js +35 -0
  94. package/lib/pipelines/pipeline.d.ts +78 -0
  95. package/lib/pipelines/pipeline.js +224 -0
  96. package/lib/platform/index.d.ts +1 -0
  97. package/lib/platform/index.js +7 -0
  98. package/lib/platform/platform.d.ts +37 -0
  99. package/lib/platform/platform.js +57 -0
  100. package/lib/rds/database.d.ts +49 -0
  101. package/lib/rds/database.js +60 -0
  102. package/lib/rds/index.d.ts +1 -0
  103. package/lib/rds/index.js +6 -0
  104. package/lib/ses/configurationsetdeliveryoptions/index.d.ts +26 -0
  105. package/lib/ses/configurationsetdeliveryoptions/index.js +48 -0
  106. package/lib/ses/configurationsetsnsdestination/handler.d.ts +17 -0
  107. package/lib/ses/configurationsetsnsdestination/handler.js +75 -0
  108. package/lib/ses/configurationsetsnsdestination/index.d.ts +29 -0
  109. package/lib/ses/configurationsetsnsdestination/index.js +75 -0
  110. package/lib/ses/index.d.ts +4 -0
  111. package/lib/ses/index.js +12 -0
  112. package/lib/ses/sesdomain/handler.d.ts +10 -0
  113. package/lib/ses/sesdomain/handler.js +82 -0
  114. package/lib/ses/sesdomain/index.d.ts +57 -0
  115. package/lib/ses/sesdomain/index.js +94 -0
  116. package/lib/ses/sesverifyemail/handler.d.ts +9 -0
  117. package/lib/ses/sesverifyemail/handler.js +25 -0
  118. package/lib/ses/sesverifyemail/index.d.ts +13 -0
  119. package/lib/ses/sesverifyemail/index.js +51 -0
  120. package/lib/snapshots.d.ts +4 -0
  121. package/lib/snapshots.js +214 -0
  122. package/lib/ssm-parameter-backed-resource.d.ts +45 -0
  123. package/lib/ssm-parameter-backed-resource.js +67 -0
  124. package/lib/ssm-parameter-reader.d.ts +21 -0
  125. package/lib/ssm-parameter-reader.js +48 -0
  126. package/lib/tags.d.ts +8 -0
  127. package/lib/tags.js +36 -0
  128. package/lib/utils.d.ts +2 -0
  129. package/lib/utils.js +17 -0
  130. package/lib/webapp/index.d.ts +3 -0
  131. package/lib/webapp/index.js +10 -0
  132. package/lib/webapp/monitor.d.ts +187 -0
  133. package/lib/webapp/monitor.js +156 -0
  134. package/lib/webapp/security-headers.d.ts +38 -0
  135. package/lib/webapp/security-headers.js +129 -0
  136. package/lib/webapp/webapp.d.ts +116 -0
  137. package/lib/webapp/webapp.js +118 -0
  138. package/lib/webapp-deploy-via-role.d.ts +25 -0
  139. package/lib/webapp-deploy-via-role.js +32 -0
  140. package/package.json +4 -3
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KinesisToDatadogStream = void 0;
4
+ var kinesis_to_datadog_stream_1 = require("./kinesis-to-datadog-stream");
5
+ Object.defineProperty(exports, "KinesisToDatadogStream", { enumerable: true, get: function () { return kinesis_to_datadog_stream_1.KinesisToDatadogStream; } });
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMva2luZXNpcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5RUFHb0M7QUFGbEMsbUlBQUEsc0JBQXNCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge1xuICBLaW5lc2lzVG9EYXRhZG9nU3RyZWFtLFxuICBLaW5lc2lzVG9EYXRhZG9nU3RyZWFtUHJvcHMsXG59IGZyb20gXCIuL2tpbmVzaXMtdG8tZGF0YWRvZy1zdHJlYW1cIlxuIl19
@@ -0,0 +1,28 @@
1
+ import * as constructs from "constructs";
2
+ import * as logs from "aws-cdk-lib/aws-logs";
3
+ export interface KinesisToDatadogStreamProps {
4
+ /**
5
+ *
6
+ * The name of the SecretsManager secret where your Datadog API key is saved.
7
+ *
8
+ * The secret must be a JSON object on the format { "value": "SECRET" }
9
+ *
10
+ */
11
+ datadogApiKeySecretName: string;
12
+ /**
13
+ *
14
+ * The CloudWatch log groups from you are streaming to Datadog
15
+ *
16
+ */
17
+ logGroups: logs.ILogGroup[];
18
+ }
19
+ /**
20
+ *
21
+ * Forwards logs from log-groups in CloudWatch to a Datadog account.
22
+ * The logs are delivered through a Firehose delivery stream, which is being subscribed to the log-groups in CloudWatch.
23
+ *
24
+ * @author Stein-Aage
25
+ */
26
+ export declare class KinesisToDatadogStream extends constructs.Construct {
27
+ constructor(scope: constructs.Construct, id: string, props: KinesisToDatadogStreamProps);
28
+ }
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KinesisToDatadogStream = void 0;
4
+ const constructs = require("constructs");
5
+ const iam = require("aws-cdk-lib/aws-iam");
6
+ const firehose = require("aws-cdk-lib/aws-kinesisfirehose");
7
+ const logs = require("aws-cdk-lib/aws-logs");
8
+ const s3 = require("aws-cdk-lib/aws-s3");
9
+ const aws_s3_1 = require("aws-cdk-lib/aws-s3");
10
+ const secretsmanager = require("aws-cdk-lib/aws-secretsmanager");
11
+ const cdk = require("aws-cdk-lib");
12
+ /**
13
+ *
14
+ * Forwards logs from log-groups in CloudWatch to a Datadog account.
15
+ * The logs are delivered through a Firehose delivery stream, which is being subscribed to the log-groups in CloudWatch.
16
+ *
17
+ * @author Stein-Aage
18
+ */
19
+ class KinesisToDatadogStream extends constructs.Construct {
20
+ constructor(scope, id, props) {
21
+ super(scope, id);
22
+ const deliveryStreamLogGroup = new logs.LogGroup(this, "DeliveryStreamLogGroup");
23
+ const deliveryStreamLogStream = new logs.LogStream(this, "DeliveryStreamLogStream", {
24
+ logGroup: deliveryStreamLogGroup,
25
+ });
26
+ const failedDataBucket = new s3.Bucket(this, "FailedDataBucket", {
27
+ blockPublicAccess: aws_s3_1.BlockPublicAccess.BLOCK_ALL,
28
+ });
29
+ const cloudWatchLogsRole = new iam.Role(this, "CloudWatchLogsRole", {
30
+ assumedBy: new iam.ServicePrincipal(`logs.${cdk.Stack.of(this).region}.amazonaws.com`),
31
+ });
32
+ const firehoseLogsRole = new iam.Role(this, "FirehoseLogsRole", {
33
+ assumedBy: new iam.ServicePrincipal("firehose.amazonaws.com"),
34
+ });
35
+ const datadogDeliveryStream = new firehose.CfnDeliveryStream(this, "DeliveryStream", {
36
+ deliveryStreamType: "DirectPut",
37
+ httpEndpointDestinationConfiguration: {
38
+ roleArn: firehoseLogsRole.roleArn,
39
+ endpointConfiguration: {
40
+ url: "https://aws-kinesis-http-intake.logs.datadoghq.eu/v1/input",
41
+ accessKey: secretsmanager.Secret.fromSecretNameV2(scope, "DatadogApiKey", props.datadogApiKeySecretName)
42
+ .secretValueFromJson("value")
43
+ .toString(),
44
+ name: "datadog-logs-endpoint",
45
+ },
46
+ requestConfiguration: {
47
+ contentEncoding: "GZIP",
48
+ },
49
+ cloudWatchLoggingOptions: {
50
+ enabled: true,
51
+ logGroupName: deliveryStreamLogGroup.logGroupName,
52
+ logStreamName: deliveryStreamLogStream.logStreamName,
53
+ },
54
+ bufferingHints: {
55
+ intervalInSeconds: 60,
56
+ sizeInMBs: 4,
57
+ },
58
+ retryOptions: {
59
+ durationInSeconds: 60,
60
+ },
61
+ s3BackupMode: "FailedDataOnly",
62
+ s3Configuration: {
63
+ bucketArn: failedDataBucket.bucketArn,
64
+ compressionFormat: "UNCOMPRESSED",
65
+ roleArn: firehoseLogsRole.roleArn,
66
+ },
67
+ },
68
+ });
69
+ new iam.Policy(this, "CloudWatchLogsPolicy", {
70
+ document: new iam.PolicyDocument({
71
+ statements: [
72
+ new iam.PolicyStatement({
73
+ actions: ["firehose:PutRecord", "firehose:PutRecordBatch"],
74
+ resources: [datadogDeliveryStream.attrArn],
75
+ }),
76
+ ],
77
+ }),
78
+ roles: [cloudWatchLogsRole],
79
+ });
80
+ new iam.Policy(this, "FirehoseLogsPolicy", {
81
+ document: new iam.PolicyDocument({
82
+ statements: [
83
+ new iam.PolicyStatement({
84
+ actions: [
85
+ "s3:AbortMultipartUpload",
86
+ "s3:GetBucketLocation",
87
+ "s3:GetObject",
88
+ "s3:ListBucket",
89
+ "s3:ListBucketMultipartUploads",
90
+ "s3:PutObject",
91
+ ],
92
+ resources: [
93
+ failedDataBucket.bucketArn,
94
+ `${failedDataBucket.bucketArn}/*`,
95
+ ],
96
+ }),
97
+ new iam.PolicyStatement({
98
+ actions: ["logs:PutLogEvents"],
99
+ resources: [
100
+ `arn:aws:logs:${cdk.Stack.of(this).region}:${cdk.Stack.of(this).account}:log-group:${deliveryStreamLogGroup.logGroupName}:log-stream:${deliveryStreamLogStream.logStreamName}`,
101
+ ],
102
+ }),
103
+ new iam.PolicyStatement({
104
+ actions: [
105
+ "kinesis:DescribeStream",
106
+ "kinesis:GetShardIterator",
107
+ "kinesis:GetRecords",
108
+ ],
109
+ resources: [datadogDeliveryStream.attrArn],
110
+ }),
111
+ ],
112
+ }),
113
+ roles: [firehoseLogsRole],
114
+ });
115
+ props.logGroups.forEach((logGroup, index) => {
116
+ new logs.CfnSubscriptionFilter(this, `SubscriptionFilter${index}`, {
117
+ logGroupName: logGroup.logGroupName,
118
+ destinationArn: datadogDeliveryStream.attrArn,
119
+ filterPattern: logs.FilterPattern.allEvents().logPatternString,
120
+ roleArn: cloudWatchLogsRole.roleArn,
121
+ });
122
+ });
123
+ }
124
+ }
125
+ exports.KinesisToDatadogStream = KinesisToDatadogStream;
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kinesis-to-datadog-stream.js","sourceRoot":"","sources":["../../src/kinesis/kinesis-to-datadog-stream.ts"],"names":[],"mappings":"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","sourcesContent":["import * as constructs from \"constructs\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as firehose from \"aws-cdk-lib/aws-kinesisfirehose\"\nimport * as logs from \"aws-cdk-lib/aws-logs\"\nimport * as s3 from \"aws-cdk-lib/aws-s3\"\nimport { BlockPublicAccess } from \"aws-cdk-lib/aws-s3\"\nimport * as secretsmanager from \"aws-cdk-lib/aws-secretsmanager\"\nimport * as cdk from \"aws-cdk-lib\"\n\nexport interface KinesisToDatadogStreamProps {\n  /**\n   *\n   * The name of the SecretsManager secret where your Datadog API key is saved.\n   *\n   * The secret must be a JSON object on the format { \"value\": \"SECRET\" }\n   *\n   */\n  datadogApiKeySecretName: string\n  /**\n   *\n   * The CloudWatch log groups from you are streaming to Datadog\n   *\n   */\n  logGroups: logs.ILogGroup[]\n}\n\n/**\n *\n * Forwards logs from log-groups in CloudWatch to a Datadog account.\n * The logs are delivered through a Firehose delivery stream, which is being subscribed to the log-groups in CloudWatch.\n *\n * @author Stein-Aage\n */\nexport class KinesisToDatadogStream extends constructs.Construct {\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: KinesisToDatadogStreamProps,\n  ) {\n    super(scope, id)\n\n    const deliveryStreamLogGroup = new logs.LogGroup(\n      this,\n      \"DeliveryStreamLogGroup\",\n    )\n\n    const deliveryStreamLogStream = new logs.LogStream(\n      this,\n      \"DeliveryStreamLogStream\",\n      {\n        logGroup: deliveryStreamLogGroup,\n      },\n    )\n\n    const failedDataBucket = new s3.Bucket(this, \"FailedDataBucket\", {\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n    })\n\n    const cloudWatchLogsRole = new iam.Role(this, \"CloudWatchLogsRole\", {\n      assumedBy: new iam.ServicePrincipal(\n        `logs.${cdk.Stack.of(this).region}.amazonaws.com`,\n      ),\n    })\n\n    const firehoseLogsRole = new iam.Role(this, \"FirehoseLogsRole\", {\n      assumedBy: new iam.ServicePrincipal(\"firehose.amazonaws.com\"),\n    })\n\n    const datadogDeliveryStream = new firehose.CfnDeliveryStream(\n      this,\n      \"DeliveryStream\",\n      {\n        deliveryStreamType: \"DirectPut\",\n        httpEndpointDestinationConfiguration: {\n          roleArn: firehoseLogsRole.roleArn,\n          endpointConfiguration: {\n            url: \"https://aws-kinesis-http-intake.logs.datadoghq.eu/v1/input\",\n            accessKey: secretsmanager.Secret.fromSecretNameV2(\n              scope,\n              \"DatadogApiKey\",\n              props.datadogApiKeySecretName,\n            )\n              .secretValueFromJson(\"value\")\n              .toString(),\n            name: \"datadog-logs-endpoint\",\n          },\n          requestConfiguration: {\n            contentEncoding: \"GZIP\",\n          },\n          cloudWatchLoggingOptions: {\n            enabled: true,\n            logGroupName: deliveryStreamLogGroup.logGroupName,\n            logStreamName: deliveryStreamLogStream.logStreamName,\n          },\n          bufferingHints: {\n            intervalInSeconds: 60,\n            sizeInMBs: 4,\n          },\n          retryOptions: {\n            durationInSeconds: 60,\n          },\n          s3BackupMode: \"FailedDataOnly\",\n          s3Configuration: {\n            bucketArn: failedDataBucket.bucketArn,\n            compressionFormat: \"UNCOMPRESSED\",\n            roleArn: firehoseLogsRole.roleArn,\n          },\n        },\n      },\n    )\n\n    new iam.Policy(this, \"CloudWatchLogsPolicy\", {\n      document: new iam.PolicyDocument({\n        statements: [\n          new iam.PolicyStatement({\n            actions: [\"firehose:PutRecord\", \"firehose:PutRecordBatch\"],\n            resources: [datadogDeliveryStream.attrArn],\n          }),\n        ],\n      }),\n      roles: [cloudWatchLogsRole],\n    })\n\n    new iam.Policy(this, \"FirehoseLogsPolicy\", {\n      document: new iam.PolicyDocument({\n        statements: [\n          new iam.PolicyStatement({\n            actions: [\n              \"s3:AbortMultipartUpload\",\n              \"s3:GetBucketLocation\",\n              \"s3:GetObject\",\n              \"s3:ListBucket\",\n              \"s3:ListBucketMultipartUploads\",\n              \"s3:PutObject\",\n            ],\n            resources: [\n              failedDataBucket.bucketArn,\n              `${failedDataBucket.bucketArn}/*`,\n            ],\n          }),\n          new iam.PolicyStatement({\n            actions: [\"logs:PutLogEvents\"],\n            resources: [\n              `arn:aws:logs:${cdk.Stack.of(this).region}:${\n                cdk.Stack.of(this).account\n              }:log-group:${deliveryStreamLogGroup.logGroupName}:log-stream:${\n                deliveryStreamLogStream.logStreamName\n              }`,\n            ],\n          }),\n          new iam.PolicyStatement({\n            actions: [\n              \"kinesis:DescribeStream\",\n              \"kinesis:GetShardIterator\",\n              \"kinesis:GetRecords\",\n            ],\n            resources: [datadogDeliveryStream.attrArn],\n          }),\n        ],\n      }),\n      roles: [firehoseLogsRole],\n    })\n\n    props.logGroups.forEach((logGroup, index) => {\n      new logs.CfnSubscriptionFilter(this, `SubscriptionFilter${index}`, {\n        logGroupName: logGroup.logGroupName,\n        destinationArn: datadogDeliveryStream.attrArn,\n        filterPattern: logs.FilterPattern.allEvents().logPatternString,\n        roleArn: cloudWatchLogsRole.roleArn,\n      })\n    })\n  }\n}\n"]}
@@ -0,0 +1 @@
1
+ export { LoadBalancer, LoadBalancerProps } from "./load-balancer";
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LoadBalancer = void 0;
4
+ var load_balancer_1 = require("./load-balancer");
5
+ Object.defineProperty(exports, "LoadBalancer", { enumerable: true, get: function () { return load_balancer_1.LoadBalancer; } });
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbG9hZC1iYWxhbmNlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpREFBaUU7QUFBeEQsNkdBQUEsWUFBWSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgTG9hZEJhbGFuY2VyLCBMb2FkQmFsYW5jZXJQcm9wcyB9IGZyb20gXCIuL2xvYWQtYmFsYW5jZXJcIlxuIl19
@@ -0,0 +1,16 @@
1
+ import * as constructs from "constructs";
2
+ import * as certificatemanager from "aws-cdk-lib/aws-certificatemanager";
3
+ import * as ec2 from "aws-cdk-lib/aws-ec2";
4
+ import * as elb from "aws-cdk-lib/aws-elasticloadbalancingv2";
5
+ import * as s3 from "aws-cdk-lib/aws-s3";
6
+ export interface LoadBalancerProps {
7
+ certificates: certificatemanager.ICertificate[];
8
+ vpc: ec2.IVpc;
9
+ overrideLoadBalancerProps?: Partial<elb.ApplicationLoadBalancerProps>;
10
+ }
11
+ export declare class LoadBalancer extends constructs.Construct {
12
+ readonly loadBalancer: elb.ApplicationLoadBalancer;
13
+ readonly httpsListener: elb.ApplicationListener;
14
+ readonly accessLogsBucket: s3.Bucket;
15
+ constructor(scope: constructs.Construct, id: string, props: LoadBalancerProps);
16
+ }
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LoadBalancer = void 0;
4
+ const constructs = require("constructs");
5
+ const ec2 = require("aws-cdk-lib/aws-ec2");
6
+ const elb = require("aws-cdk-lib/aws-elasticloadbalancingv2");
7
+ const aws_elasticloadbalancingv2_1 = require("aws-cdk-lib/aws-elasticloadbalancingv2");
8
+ const s3 = require("aws-cdk-lib/aws-s3");
9
+ const cdk = require("aws-cdk-lib");
10
+ class LoadBalancer extends constructs.Construct {
11
+ constructor(scope, id, props) {
12
+ super(scope, id);
13
+ this.loadBalancer = new elb.ApplicationLoadBalancer(this, "LoadBalancer", {
14
+ vpc: props.vpc,
15
+ internetFacing: true,
16
+ vpcSubnets: props.vpc.selectSubnets({
17
+ subnetType: ec2.SubnetType.PUBLIC,
18
+ }),
19
+ ...props.overrideLoadBalancerProps,
20
+ });
21
+ this.loadBalancer
22
+ .addListener("HttpListener", {
23
+ port: 80,
24
+ })
25
+ .addAction("HttpsRedirect", {
26
+ action: aws_elasticloadbalancingv2_1.ListenerAction.redirect({
27
+ port: "443",
28
+ protocol: "HTTPS",
29
+ permanent: true,
30
+ }),
31
+ });
32
+ // The Load Balancer require a default target group.
33
+ // We will not connect anything to the default target group.
34
+ const defaultTargetGroup = new elb.ApplicationTargetGroup(this, "DefaultTargetGroup", {
35
+ protocol: elb.ApplicationProtocol.HTTP,
36
+ port: 80,
37
+ vpc: props.vpc,
38
+ targetType: elb.TargetType.INSTANCE,
39
+ });
40
+ this.httpsListener = this.loadBalancer.addListener("HttpsListener", {
41
+ sslPolicy: elb.SslPolicy.TLS12,
42
+ protocol: elb.ApplicationProtocol.HTTPS,
43
+ port: 443,
44
+ certificates: props.certificates,
45
+ defaultTargetGroups: [defaultTargetGroup],
46
+ });
47
+ this.accessLogsBucket = new s3.Bucket(this, "AccessLogsBucket", {
48
+ encryption: s3.BucketEncryption.S3_MANAGED,
49
+ blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,
50
+ lifecycleRules: [
51
+ {
52
+ expiration: cdk.Duration.days(30),
53
+ },
54
+ ],
55
+ });
56
+ this.loadBalancer.logAccessLogs(this.accessLogsBucket);
57
+ }
58
+ }
59
+ exports.LoadBalancer = LoadBalancer;
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1iYWxhbmNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9sb2FkLWJhbGFuY2VyL2xvYWQtYmFsYW5jZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUNBQXdDO0FBRXhDLDJDQUEwQztBQUMxQyw4REFBNkQ7QUFDN0QsdUZBQXVFO0FBQ3ZFLHlDQUF3QztBQUN4QyxtQ0FBa0M7QUFRbEMsTUFBYSxZQUFhLFNBQVEsVUFBVSxDQUFDLFNBQVM7SUFLcEQsWUFDRSxLQUEyQixFQUMzQixFQUFVLEVBQ1YsS0FBd0I7UUFFeEIsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQTtRQUVoQixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksR0FBRyxDQUFDLHVCQUF1QixDQUFDLElBQUksRUFBRSxjQUFjLEVBQUU7WUFDeEUsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsY0FBYyxFQUFFLElBQUk7WUFDcEIsVUFBVSxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDO2dCQUNsQyxVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNO2FBQ2xDLENBQUM7WUFDRixHQUFHLEtBQUssQ0FBQyx5QkFBeUI7U0FDbkMsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLFlBQVk7YUFDZCxXQUFXLENBQUMsY0FBYyxFQUFFO1lBQzNCLElBQUksRUFBRSxFQUFFO1NBQ1QsQ0FBQzthQUNELFNBQVMsQ0FBQyxlQUFlLEVBQUU7WUFDMUIsTUFBTSxFQUFFLDJDQUFjLENBQUMsUUFBUSxDQUFDO2dCQUM5QixJQUFJLEVBQUUsS0FBSztnQkFDWCxRQUFRLEVBQUUsT0FBTztnQkFDakIsU0FBUyxFQUFFLElBQUk7YUFDaEIsQ0FBQztTQUNILENBQUMsQ0FBQTtRQUVKLG9EQUFvRDtRQUNwRCw0REFBNEQ7UUFDNUQsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLEdBQUcsQ0FBQyxzQkFBc0IsQ0FDdkQsSUFBSSxFQUNKLG9CQUFvQixFQUNwQjtZQUNFLFFBQVEsRUFBRSxHQUFHLENBQUMsbUJBQW1CLENBQUMsSUFBSTtZQUN0QyxJQUFJLEVBQUUsRUFBRTtZQUNSLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRztZQUNkLFVBQVUsRUFBRSxHQUFHLENBQUMsVUFBVSxDQUFDLFFBQVE7U0FDcEMsQ0FDRixDQUFBO1FBRUQsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxlQUFlLEVBQUU7WUFDbEUsU0FBUyxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsS0FBSztZQUM5QixRQUFRLEVBQUUsR0FBRyxDQUFDLG1CQUFtQixDQUFDLEtBQUs7WUFDdkMsSUFBSSxFQUFFLEdBQUc7WUFDVCxZQUFZLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDaEMsbUJBQW1CLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztTQUMxQyxDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxrQkFBa0IsRUFBRTtZQUM5RCxVQUFVLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFVBQVU7WUFDMUMsaUJBQWlCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDLFNBQVM7WUFDakQsY0FBYyxFQUFFO2dCQUNkO29CQUNFLFVBQVUsRUFBRSxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7aUJBQ2xDO2FBQ0Y7U0FDRixDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtJQUN4RCxDQUFDO0NBQ0Y7QUFsRUQsb0NBa0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY29uc3RydWN0cyBmcm9tIFwiY29uc3RydWN0c1wiXG5pbXBvcnQgKiBhcyBjZXJ0aWZpY2F0ZW1hbmFnZXIgZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIlxuaW1wb3J0ICogYXMgZWMyIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWMyXCJcbmltcG9ydCAqIGFzIGVsYiBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVsYXN0aWNsb2FkYmFsYW5jaW5ndjJcIlxuaW1wb3J0IHsgTGlzdGVuZXJBY3Rpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVsYXN0aWNsb2FkYmFsYW5jaW5ndjJcIlxuaW1wb3J0ICogYXMgczMgZnJvbSBcImF3cy1jZGstbGliL2F3cy1zM1wiXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSBcImF3cy1jZGstbGliXCJcblxuZXhwb3J0IGludGVyZmFjZSBMb2FkQmFsYW5jZXJQcm9wcyB7XG4gIGNlcnRpZmljYXRlczogY2VydGlmaWNhdGVtYW5hZ2VyLklDZXJ0aWZpY2F0ZVtdXG4gIHZwYzogZWMyLklWcGNcbiAgb3ZlcnJpZGVMb2FkQmFsYW5jZXJQcm9wcz86IFBhcnRpYWw8ZWxiLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHM+XG59XG5cbmV4cG9ydCBjbGFzcyBMb2FkQmFsYW5jZXIgZXh0ZW5kcyBjb25zdHJ1Y3RzLkNvbnN0cnVjdCB7XG4gIHB1YmxpYyByZWFkb25seSBsb2FkQmFsYW5jZXI6IGVsYi5BcHBsaWNhdGlvbkxvYWRCYWxhbmNlclxuICBwdWJsaWMgcmVhZG9ubHkgaHR0cHNMaXN0ZW5lcjogZWxiLkFwcGxpY2F0aW9uTGlzdGVuZXJcbiAgcHVibGljIHJlYWRvbmx5IGFjY2Vzc0xvZ3NCdWNrZXQ6IHMzLkJ1Y2tldFxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHNjb3BlOiBjb25zdHJ1Y3RzLkNvbnN0cnVjdCxcbiAgICBpZDogc3RyaW5nLFxuICAgIHByb3BzOiBMb2FkQmFsYW5jZXJQcm9wcyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKVxuXG4gICAgdGhpcy5sb2FkQmFsYW5jZXIgPSBuZXcgZWxiLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyKHRoaXMsIFwiTG9hZEJhbGFuY2VyXCIsIHtcbiAgICAgIHZwYzogcHJvcHMudnBjLFxuICAgICAgaW50ZXJuZXRGYWNpbmc6IHRydWUsXG4gICAgICB2cGNTdWJuZXRzOiBwcm9wcy52cGMuc2VsZWN0U3VibmV0cyh7XG4gICAgICAgIHN1Ym5ldFR5cGU6IGVjMi5TdWJuZXRUeXBlLlBVQkxJQyxcbiAgICAgIH0pLFxuICAgICAgLi4ucHJvcHMub3ZlcnJpZGVMb2FkQmFsYW5jZXJQcm9wcyxcbiAgICB9KVxuXG4gICAgdGhpcy5sb2FkQmFsYW5jZXJcbiAgICAgIC5hZGRMaXN0ZW5lcihcIkh0dHBMaXN0ZW5lclwiLCB7XG4gICAgICAgIHBvcnQ6IDgwLFxuICAgICAgfSlcbiAgICAgIC5hZGRBY3Rpb24oXCJIdHRwc1JlZGlyZWN0XCIsIHtcbiAgICAgICAgYWN0aW9uOiBMaXN0ZW5lckFjdGlvbi5yZWRpcmVjdCh7XG4gICAgICAgICAgcG9ydDogXCI0NDNcIixcbiAgICAgICAgICBwcm90b2NvbDogXCJIVFRQU1wiLFxuICAgICAgICAgIHBlcm1hbmVudDogdHJ1ZSxcbiAgICAgICAgfSksXG4gICAgICB9KVxuXG4gICAgLy8gVGhlIExvYWQgQmFsYW5jZXIgcmVxdWlyZSBhIGRlZmF1bHQgdGFyZ2V0IGdyb3VwLlxuICAgIC8vIFdlIHdpbGwgbm90IGNvbm5lY3QgYW55dGhpbmcgdG8gdGhlIGRlZmF1bHQgdGFyZ2V0IGdyb3VwLlxuICAgIGNvbnN0IGRlZmF1bHRUYXJnZXRHcm91cCA9IG5ldyBlbGIuQXBwbGljYXRpb25UYXJnZXRHcm91cChcbiAgICAgIHRoaXMsXG4gICAgICBcIkRlZmF1bHRUYXJnZXRHcm91cFwiLFxuICAgICAge1xuICAgICAgICBwcm90b2NvbDogZWxiLkFwcGxpY2F0aW9uUHJvdG9jb2wuSFRUUCxcbiAgICAgICAgcG9ydDogODAsXG4gICAgICAgIHZwYzogcHJvcHMudnBjLFxuICAgICAgICB0YXJnZXRUeXBlOiBlbGIuVGFyZ2V0VHlwZS5JTlNUQU5DRSxcbiAgICAgIH0sXG4gICAgKVxuXG4gICAgdGhpcy5odHRwc0xpc3RlbmVyID0gdGhpcy5sb2FkQmFsYW5jZXIuYWRkTGlzdGVuZXIoXCJIdHRwc0xpc3RlbmVyXCIsIHtcbiAgICAgIHNzbFBvbGljeTogZWxiLlNzbFBvbGljeS5UTFMxMixcbiAgICAgIHByb3RvY29sOiBlbGIuQXBwbGljYXRpb25Qcm90b2NvbC5IVFRQUyxcbiAgICAgIHBvcnQ6IDQ0MyxcbiAgICAgIGNlcnRpZmljYXRlczogcHJvcHMuY2VydGlmaWNhdGVzLFxuICAgICAgZGVmYXVsdFRhcmdldEdyb3VwczogW2RlZmF1bHRUYXJnZXRHcm91cF0sXG4gICAgfSlcblxuICAgIHRoaXMuYWNjZXNzTG9nc0J1Y2tldCA9IG5ldyBzMy5CdWNrZXQodGhpcywgXCJBY2Nlc3NMb2dzQnVja2V0XCIsIHtcbiAgICAgIGVuY3J5cHRpb246IHMzLkJ1Y2tldEVuY3J5cHRpb24uUzNfTUFOQUdFRCxcbiAgICAgIGJsb2NrUHVibGljQWNjZXNzOiBzMy5CbG9ja1B1YmxpY0FjY2Vzcy5CTE9DS19BTEwsXG4gICAgICBsaWZlY3ljbGVSdWxlczogW1xuICAgICAgICB7XG4gICAgICAgICAgZXhwaXJhdGlvbjogY2RrLkR1cmF0aW9uLmRheXMoMzApLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9KVxuXG4gICAgdGhpcy5sb2FkQmFsYW5jZXIubG9nQWNjZXNzTG9ncyh0aGlzLmFjY2Vzc0xvZ3NCdWNrZXQpXG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,14 @@
1
+ /**
2
+ * The role used when running "cdk deploy".
3
+ */
4
+ export declare const cdkDeployRoleName = "liflig-cdk-deployer-cdk";
5
+ /**
6
+ * Path on S3 for pipeline configuration.
7
+ */
8
+ export declare function pipelineS3Prefix(pipelineName: string): string;
9
+ /**
10
+ * Key in S3 bucket used to trigger pipeline.
11
+ *
12
+ * This is an empty file within the pipeline path.
13
+ */
14
+ export declare function pipelineS3TriggerKey(pipelineName: string): string;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.pipelineS3TriggerKey = exports.pipelineS3Prefix = exports.cdkDeployRoleName = void 0;
4
+ /**
5
+ * The role used when running "cdk deploy".
6
+ */
7
+ exports.cdkDeployRoleName = "liflig-cdk-deployer-cdk";
8
+ /**
9
+ * Path on S3 for pipeline configuration.
10
+ */
11
+ function pipelineS3Prefix(pipelineName) {
12
+ return `pipelines/${pipelineName}/`;
13
+ }
14
+ exports.pipelineS3Prefix = pipelineS3Prefix;
15
+ /**
16
+ * Key in S3 bucket used to trigger pipeline.
17
+ *
18
+ * This is an empty file within the pipeline path.
19
+ */
20
+ function pipelineS3TriggerKey(pipelineName) {
21
+ return `pipelines/${pipelineName}/trigger`;
22
+ }
23
+ exports.pipelineS3TriggerKey = pipelineS3TriggerKey;
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVudGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGlwZWxpbmVzL2NvbnZlbnRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ1UsUUFBQSxpQkFBaUIsR0FBRyx5QkFBeUIsQ0FBQTtBQUUxRDs7R0FFRztBQUNILFNBQWdCLGdCQUFnQixDQUFDLFlBQW9CO0lBQ25ELE9BQU8sYUFBYSxZQUFZLEdBQUcsQ0FBQTtBQUNyQyxDQUFDO0FBRkQsNENBRUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0Isb0JBQW9CLENBQUMsWUFBb0I7SUFDdkQsT0FBTyxhQUFhLFlBQVksVUFBVSxDQUFBO0FBQzVDLENBQUM7QUFGRCxvREFFQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhlIHJvbGUgdXNlZCB3aGVuIHJ1bm5pbmcgXCJjZGsgZGVwbG95XCIuXG4gKi9cbmV4cG9ydCBjb25zdCBjZGtEZXBsb3lSb2xlTmFtZSA9IFwibGlmbGlnLWNkay1kZXBsb3llci1jZGtcIlxuXG4vKipcbiAqIFBhdGggb24gUzMgZm9yIHBpcGVsaW5lIGNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwaXBlbGluZVMzUHJlZml4KHBpcGVsaW5lTmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGBwaXBlbGluZXMvJHtwaXBlbGluZU5hbWV9L2Bcbn1cblxuLyoqXG4gKiBLZXkgaW4gUzMgYnVja2V0IHVzZWQgdG8gdHJpZ2dlciBwaXBlbGluZS5cbiAqXG4gKiBUaGlzIGlzIGFuIGVtcHR5IGZpbGUgd2l0aGluIHRoZSBwaXBlbGluZSBwYXRoLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcGlwZWxpbmVTM1RyaWdnZXJLZXkocGlwZWxpbmVOYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gYHBpcGVsaW5lcy8ke3BpcGVsaW5lTmFtZX0vdHJpZ2dlcmBcbn1cbiJdfQ==
@@ -0,0 +1,18 @@
1
+ import * as constructs from "constructs";
2
+ import * as ec2 from "aws-cdk-lib/aws-ec2";
3
+ import * as s3 from "aws-cdk-lib/aws-s3";
4
+ import * as sfn from "aws-cdk-lib/aws-stepfunctions";
5
+ interface DeployEnvProps {
6
+ accountId: string;
7
+ afterSuccessfulDeploy?: sfn.Chain;
8
+ artefactBucket: s3.IBucket;
9
+ envName: string;
10
+ vpc: ec2.IVpc;
11
+ }
12
+ export declare class DeployEnv extends constructs.Construct {
13
+ chain: sfn.Chain;
14
+ constructor(scope: constructs.Construct, id: string, props: DeployEnvProps);
15
+ private getOrCreateCluster;
16
+ private getOrCreateTaskSecurityGroup;
17
+ }
18
+ export {};
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DeployEnv = void 0;
4
+ const constructs = require("constructs");
5
+ const ec2 = require("aws-cdk-lib/aws-ec2");
6
+ const ecr = require("aws-cdk-lib/aws-ecr");
7
+ const ecs = require("aws-cdk-lib/aws-ecs");
8
+ const iam = require("aws-cdk-lib/aws-iam");
9
+ const logs = require("aws-cdk-lib/aws-logs");
10
+ const sfn = require("aws-cdk-lib/aws-stepfunctions");
11
+ const tasks = require("aws-cdk-lib/aws-stepfunctions-tasks");
12
+ const cdk = require("aws-cdk-lib");
13
+ const conventions_1 = require("./conventions");
14
+ class DeployEnv extends constructs.Construct {
15
+ constructor(scope, id, props) {
16
+ super(scope, id);
17
+ const cluster = this.getOrCreateCluster(props.vpc);
18
+ // We don't reuse the task definition across multiple pipelines
19
+ // so that we can easier find the correct logs for each pipeline.
20
+ const taskDefinition = new ecs.TaskDefinition(this, "TaskDefinition", {
21
+ memoryMiB: "1024",
22
+ cpu: "256",
23
+ compatibility: ecs.Compatibility.FARGATE,
24
+ });
25
+ const containerDefinition = taskDefinition.addContainer("app", {
26
+ image: ecs.ContainerImage.fromEcrRepository(ecr.Repository.fromRepositoryArn(this, "Repository",
27
+ // See https://github.com/capralifecycle/liflig-cdk-deployer
28
+ "arn:aws:ecr:eu-west-1:001112238813:repository/incub-common-liflig-cdk-deployer"), "1-experimental.2"),
29
+ logging: ecs.LogDriver.awsLogs({
30
+ logGroup: new logs.LogGroup(this, "LogGroup", {
31
+ removalPolicy: cdk.RemovalPolicy.DESTROY,
32
+ retention: logs.RetentionDays.ONE_MONTH,
33
+ }),
34
+ streamPrefix: "app",
35
+ }),
36
+ });
37
+ const cdkRole = iam.Role.fromRoleArn(this, `CdkRole-${props.envName}`, `arn:aws:iam::${props.accountId}:role/${conventions_1.cdkDeployRoleName}`);
38
+ cdkRole.grant(taskDefinition.taskRole, "sts:AssumeRole");
39
+ props.artefactBucket.grantRead(taskDefinition.taskRole);
40
+ this.chain = sfn.Chain.start(new tasks.EcsRunTask(this, `Deploy ${props.envName}`, {
41
+ resultPath: sfn.JsonPath.DISCARD,
42
+ securityGroups: [this.getOrCreateTaskSecurityGroup(props.vpc)],
43
+ integrationPattern: sfn.IntegrationPattern.RUN_JOB,
44
+ cluster,
45
+ assignPublicIp: true,
46
+ launchTarget: new tasks.EcsFargateLaunchTarget(),
47
+ taskDefinition,
48
+ containerOverrides: [
49
+ {
50
+ containerDefinition,
51
+ environment: [
52
+ {
53
+ name: "CDK_TARGET_ROLE_ARN",
54
+ value: cdkRole.roleArn,
55
+ },
56
+ {
57
+ name: "CDK_ENV_NAME",
58
+ value: props.envName,
59
+ },
60
+ {
61
+ name: "CDK_CLOUD_ASSEMBLY",
62
+ value: sfn.JsonPath.stringAt("$.CloudAssembly"),
63
+ },
64
+ {
65
+ name: "CDK_VARIABLES",
66
+ value: sfn.JsonPath.stringAt("$.Variables"),
67
+ },
68
+ ],
69
+ },
70
+ ],
71
+ }));
72
+ if (props.afterSuccessfulDeploy != null) {
73
+ this.chain = this.chain.next(props.afterSuccessfulDeploy);
74
+ }
75
+ }
76
+ // Reuse ECS cluster for multiple pipelines in same stack.
77
+ getOrCreateCluster(vpc) {
78
+ var _a;
79
+ const stack = cdk.Stack.of(this);
80
+ const uniqueId = "pipeline.04ad36b1.cluster";
81
+ return ((_a = stack.node.tryFindChild(uniqueId)) !== null && _a !== void 0 ? _a : new ecs.Cluster(stack, uniqueId, {
82
+ vpc,
83
+ }));
84
+ }
85
+ // Reuse security group for multiple pipelines in same stack.
86
+ getOrCreateTaskSecurityGroup(vpc) {
87
+ var _a;
88
+ const stack = cdk.Stack.of(this);
89
+ const uniqueId = "pipeline.04ad36b1.security-group";
90
+ return ((_a = stack.node.tryFindChild(uniqueId)) !== null && _a !== void 0 ? _a : new ec2.SecurityGroup(stack, uniqueId, {
91
+ vpc,
92
+ }));
93
+ }
94
+ }
95
+ exports.DeployEnv = DeployEnv;
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy-env.js","sourceRoot":"","sources":["../../src/pipelines/deploy-env.ts"],"names":[],"mappings":"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","sourcesContent":["import * as constructs from \"constructs\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as ecr from \"aws-cdk-lib/aws-ecr\"\nimport * as ecs from \"aws-cdk-lib/aws-ecs\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as logs from \"aws-cdk-lib/aws-logs\"\nimport * as s3 from \"aws-cdk-lib/aws-s3\"\nimport * as sfn from \"aws-cdk-lib/aws-stepfunctions\"\nimport * as tasks from \"aws-cdk-lib/aws-stepfunctions-tasks\"\nimport * as cdk from \"aws-cdk-lib\"\nimport { cdkDeployRoleName } from \"./conventions\"\n\ninterface DeployEnvProps {\n  accountId: string\n  afterSuccessfulDeploy?: sfn.Chain\n  artefactBucket: s3.IBucket\n  envName: string\n  vpc: ec2.IVpc\n}\n\nexport class DeployEnv extends constructs.Construct {\n  public chain: sfn.Chain\n\n  constructor(scope: constructs.Construct, id: string, props: DeployEnvProps) {\n    super(scope, id)\n\n    const cluster = this.getOrCreateCluster(props.vpc)\n\n    // We don't reuse the task definition across multiple pipelines\n    // so that we can easier find the correct logs for each pipeline.\n\n    const taskDefinition = new ecs.TaskDefinition(this, \"TaskDefinition\", {\n      memoryMiB: \"1024\",\n      cpu: \"256\",\n      compatibility: ecs.Compatibility.FARGATE,\n    })\n\n    const containerDefinition = taskDefinition.addContainer(\"app\", {\n      image: ecs.ContainerImage.fromEcrRepository(\n        ecr.Repository.fromRepositoryArn(\n          this,\n          \"Repository\",\n          // See https://github.com/capralifecycle/liflig-cdk-deployer\n          \"arn:aws:ecr:eu-west-1:001112238813:repository/incub-common-liflig-cdk-deployer\",\n        ),\n        \"1-experimental.2\",\n      ),\n      logging: ecs.LogDriver.awsLogs({\n        logGroup: new logs.LogGroup(this, \"LogGroup\", {\n          removalPolicy: cdk.RemovalPolicy.DESTROY,\n          retention: logs.RetentionDays.ONE_MONTH,\n        }),\n        streamPrefix: \"app\",\n      }),\n    })\n\n    const cdkRole = iam.Role.fromRoleArn(\n      this,\n      `CdkRole-${props.envName}`,\n      `arn:aws:iam::${props.accountId}:role/${cdkDeployRoleName}`,\n    )\n\n    cdkRole.grant(taskDefinition.taskRole, \"sts:AssumeRole\")\n\n    props.artefactBucket.grantRead(taskDefinition.taskRole)\n\n    this.chain = sfn.Chain.start(\n      new tasks.EcsRunTask(this, `Deploy ${props.envName}`, {\n        resultPath: sfn.JsonPath.DISCARD,\n        securityGroups: [this.getOrCreateTaskSecurityGroup(props.vpc)],\n        integrationPattern: sfn.IntegrationPattern.RUN_JOB,\n        cluster,\n        assignPublicIp: true,\n        launchTarget: new tasks.EcsFargateLaunchTarget(),\n        taskDefinition,\n        containerOverrides: [\n          {\n            containerDefinition,\n            environment: [\n              {\n                name: \"CDK_TARGET_ROLE_ARN\",\n                value: cdkRole.roleArn,\n              },\n              {\n                name: \"CDK_ENV_NAME\",\n                value: props.envName,\n              },\n              {\n                name: \"CDK_CLOUD_ASSEMBLY\",\n                value: sfn.JsonPath.stringAt(\"$.CloudAssembly\"),\n              },\n              {\n                name: \"CDK_VARIABLES\",\n                value: sfn.JsonPath.stringAt(\"$.Variables\"),\n              },\n            ],\n          },\n        ],\n      }),\n    )\n\n    if (props.afterSuccessfulDeploy != null) {\n      this.chain = this.chain.next(props.afterSuccessfulDeploy)\n    }\n  }\n\n  // Reuse ECS cluster for multiple pipelines in same stack.\n  private getOrCreateCluster(vpc: ec2.IVpc): ecs.Cluster {\n    const stack = cdk.Stack.of(this)\n    const uniqueId = \"pipeline.04ad36b1.cluster\"\n    return (\n      (stack.node.tryFindChild(uniqueId) as ecs.Cluster) ??\n      new ecs.Cluster(stack, uniqueId, {\n        vpc,\n      })\n    )\n  }\n\n  // Reuse security group for multiple pipelines in same stack.\n  private getOrCreateTaskSecurityGroup(vpc: ec2.IVpc): ec2.SecurityGroup {\n    const stack = cdk.Stack.of(this)\n    const uniqueId = \"pipeline.04ad36b1.security-group\"\n    return (\n      (stack.node.tryFindChild(uniqueId) as ec2.SecurityGroup) ??\n      new ec2.SecurityGroup(stack, uniqueId, {\n        vpc,\n      })\n    )\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export { LifligCdkDeployerDeps, LifligCdkDeployerDepsProps, } from "./liflig-cdk-deployer-deps";
2
+ export { Pipeline, PipelineEnvironment, PipelineProps } from "./pipeline";
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Pipeline = exports.LifligCdkDeployerDeps = void 0;
4
+ var liflig_cdk_deployer_deps_1 = require("./liflig-cdk-deployer-deps");
5
+ Object.defineProperty(exports, "LifligCdkDeployerDeps", { enumerable: true, get: function () { return liflig_cdk_deployer_deps_1.LifligCdkDeployerDeps; } });
6
+ var pipeline_1 = require("./pipeline");
7
+ Object.defineProperty(exports, "Pipeline", { enumerable: true, get: function () { return pipeline_1.Pipeline; } });
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGlwZWxpbmVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHVFQUdtQztBQUZqQyxpSUFBQSxxQkFBcUIsT0FBQTtBQUd2Qix1Q0FBeUU7QUFBaEUsb0dBQUEsUUFBUSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtcbiAgTGlmbGlnQ2RrRGVwbG95ZXJEZXBzLFxuICBMaWZsaWdDZGtEZXBsb3llckRlcHNQcm9wcyxcbn0gZnJvbSBcIi4vbGlmbGlnLWNkay1kZXBsb3llci1kZXBzXCJcbmV4cG9ydCB7IFBpcGVsaW5lLCBQaXBlbGluZUVudmlyb25tZW50LCBQaXBlbGluZVByb3BzIH0gZnJvbSBcIi4vcGlwZWxpbmVcIlxuIl19
@@ -0,0 +1,13 @@
1
+ import * as constructs from "constructs";
2
+ export interface LifligCdkDeployerDepsProps {
3
+ trustedAccountIds: string[];
4
+ }
5
+ /**
6
+ * Resources needed so liflig-cdk-deployer can deploy to the account.
7
+ *
8
+ * This must exist in each target account that the pipeline should
9
+ * be able to deploy into.
10
+ */
11
+ export declare class LifligCdkDeployerDeps extends constructs.Construct {
12
+ constructor(scope: constructs.Construct, id: string, props: LifligCdkDeployerDepsProps);
13
+ }
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LifligCdkDeployerDeps = void 0;
4
+ const constructs = require("constructs");
5
+ const iam = require("aws-cdk-lib/aws-iam");
6
+ const cdk = require("aws-cdk-lib");
7
+ const conventions_1 = require("./conventions");
8
+ /**
9
+ * Resources needed so liflig-cdk-deployer can deploy to the account.
10
+ *
11
+ * This must exist in each target account that the pipeline should
12
+ * be able to deploy into.
13
+ */
14
+ class LifligCdkDeployerDeps extends constructs.Construct {
15
+ constructor(scope, id, props) {
16
+ super(scope, id);
17
+ const account = cdk.Stack.of(this).account;
18
+ // The role used when running "cdk deploy".
19
+ const cdkRole = new iam.Role(this, "CdkRole", {
20
+ roleName: conventions_1.cdkDeployRoleName,
21
+ assumedBy: new iam.CompositePrincipal(...props.trustedAccountIds.map((it) => new iam.AccountPrincipal(it))),
22
+ });
23
+ // Roles used by CDK CLI for the actual deployment.
24
+ // (For use under new-style synthesize.)
25
+ cdkRole.addToPolicy(new iam.PolicyStatement({
26
+ actions: ["sts:AssumeRole"],
27
+ resources: [
28
+ `arn:aws:iam::${account}:role/*-deploy-role-*`,
29
+ `arn:aws:iam::${account}:role/*-publishing-role-*`,
30
+ ],
31
+ }));
32
+ }
33
+ }
34
+ exports.LifligCdkDeployerDeps = LifligCdkDeployerDeps;
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlmbGlnLWNkay1kZXBsb3llci1kZXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BpcGVsaW5lcy9saWZsaWctY2RrLWRlcGxveWVyLWRlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUNBQXdDO0FBQ3hDLDJDQUEwQztBQUMxQyxtQ0FBa0M7QUFDbEMsK0NBQWlEO0FBTWpEOzs7OztHQUtHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSxVQUFVLENBQUMsU0FBUztJQUM3RCxZQUNFLEtBQTJCLEVBQzNCLEVBQVUsRUFDVixLQUFpQztRQUVqQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFBO1FBRWhCLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQTtRQUUxQywyQ0FBMkM7UUFDM0MsTUFBTSxPQUFPLEdBQUcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDNUMsUUFBUSxFQUFFLCtCQUFpQjtZQUMzQixTQUFTLEVBQUUsSUFBSSxHQUFHLENBQUMsa0JBQWtCLENBQ25DLEdBQUcsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FDckU7U0FDRixDQUFDLENBQUE7UUFFRixtREFBbUQ7UUFDbkQsd0NBQXdDO1FBQ3hDLE9BQU8sQ0FBQyxXQUFXLENBQ2pCLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQztZQUN0QixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztZQUMzQixTQUFTLEVBQUU7Z0JBQ1QsZ0JBQWdCLE9BQU8sdUJBQXVCO2dCQUM5QyxnQkFBZ0IsT0FBTywyQkFBMkI7YUFDbkQ7U0FDRixDQUFDLENBQ0gsQ0FBQTtJQUNILENBQUM7Q0FDRjtBQTlCRCxzREE4QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjb25zdHJ1Y3RzIGZyb20gXCJjb25zdHJ1Y3RzXCJcbmltcG9ydCAqIGFzIGlhbSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWlhbVwiXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSBcImF3cy1jZGstbGliXCJcbmltcG9ydCB7IGNka0RlcGxveVJvbGVOYW1lIH0gZnJvbSBcIi4vY29udmVudGlvbnNcIlxuXG5leHBvcnQgaW50ZXJmYWNlIExpZmxpZ0Nka0RlcGxveWVyRGVwc1Byb3BzIHtcbiAgdHJ1c3RlZEFjY291bnRJZHM6IHN0cmluZ1tdXG59XG5cbi8qKlxuICogUmVzb3VyY2VzIG5lZWRlZCBzbyBsaWZsaWctY2RrLWRlcGxveWVyIGNhbiBkZXBsb3kgdG8gdGhlIGFjY291bnQuXG4gKlxuICogVGhpcyBtdXN0IGV4aXN0IGluIGVhY2ggdGFyZ2V0IGFjY291bnQgdGhhdCB0aGUgcGlwZWxpbmUgc2hvdWxkXG4gKiBiZSBhYmxlIHRvIGRlcGxveSBpbnRvLlxuICovXG5leHBvcnQgY2xhc3MgTGlmbGlnQ2RrRGVwbG95ZXJEZXBzIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsXG4gICAgaWQ6IHN0cmluZyxcbiAgICBwcm9wczogTGlmbGlnQ2RrRGVwbG95ZXJEZXBzUHJvcHMsXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIGNvbnN0IGFjY291bnQgPSBjZGsuU3RhY2sub2YodGhpcykuYWNjb3VudFxuXG4gICAgLy8gVGhlIHJvbGUgdXNlZCB3aGVuIHJ1bm5pbmcgXCJjZGsgZGVwbG95XCIuXG4gICAgY29uc3QgY2RrUm9sZSA9IG5ldyBpYW0uUm9sZSh0aGlzLCBcIkNka1JvbGVcIiwge1xuICAgICAgcm9sZU5hbWU6IGNka0RlcGxveVJvbGVOYW1lLFxuICAgICAgYXNzdW1lZEJ5OiBuZXcgaWFtLkNvbXBvc2l0ZVByaW5jaXBhbChcbiAgICAgICAgLi4ucHJvcHMudHJ1c3RlZEFjY291bnRJZHMubWFwKChpdCkgPT4gbmV3IGlhbS5BY2NvdW50UHJpbmNpcGFsKGl0KSksXG4gICAgICApLFxuICAgIH0pXG5cbiAgICAvLyBSb2xlcyB1c2VkIGJ5IENESyBDTEkgZm9yIHRoZSBhY3R1YWwgZGVwbG95bWVudC5cbiAgICAvLyAoRm9yIHVzZSB1bmRlciBuZXctc3R5bGUgc3ludGhlc2l6ZS4pXG4gICAgY2RrUm9sZS5hZGRUb1BvbGljeShcbiAgICAgIG5ldyBpYW0uUG9saWN5U3RhdGVtZW50KHtcbiAgICAgICAgYWN0aW9uczogW1wic3RzOkFzc3VtZVJvbGVcIl0sXG4gICAgICAgIHJlc291cmNlczogW1xuICAgICAgICAgIGBhcm46YXdzOmlhbTo6JHthY2NvdW50fTpyb2xlLyotZGVwbG95LXJvbGUtKmAsXG4gICAgICAgICAgYGFybjphd3M6aWFtOjoke2FjY291bnR9OnJvbGUvKi1wdWJsaXNoaW5nLXJvbGUtKmAsXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICApXG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,78 @@
1
+ import * as constructs from "constructs";
2
+ import * as ec2 from "aws-cdk-lib/aws-ec2";
3
+ import * as s3 from "aws-cdk-lib/aws-s3";
4
+ import * as sfn from "aws-cdk-lib/aws-stepfunctions";
5
+ export interface PipelineProps {
6
+ /**
7
+ * Bucket holding pipeline configuration and trigger file.
8
+ *
9
+ * @default - use existing bucket based on Griid conventions
10
+ */
11
+ artifactsBucket?: s3.IBucket;
12
+ /**
13
+ * Environments for this pipeline. Each environment is deployed sequentially
14
+ * in the order given.
15
+ */
16
+ environments: PipelineEnvironment[];
17
+ /**
18
+ * Name of pipeline. This is used for the path where configuration
19
+ * is stored in S3.
20
+ */
21
+ pipelineName: string;
22
+ /**
23
+ * Trigger the pipeline when the trigger file is written.
24
+ *
25
+ * @default - true
26
+ */
27
+ triggerEnabled?: boolean;
28
+ /**
29
+ * VPC used for Fargate resources.
30
+ */
31
+ vpc: ec2.IVpc;
32
+ }
33
+ export interface PipelineEnvironment {
34
+ /**
35
+ * Account number hosting the environment.
36
+ */
37
+ accountId: string;
38
+ /**
39
+ * Additional tasks to run after the environment has been deployed.
40
+ */
41
+ afterSuccessfulDeploy?: sfn.Chain;
42
+ /**
43
+ * Name of environment.
44
+ */
45
+ name: string;
46
+ }
47
+ /**
48
+ * Pipeline for doing a multi-account CDK deployment based
49
+ * on a built CDK Cloud Assembly and parameters stored in S3.
50
+ *
51
+ * The accounts being deployed to must be provisioned with
52
+ * the LifligCdkDeployerDeps construct so expected IAM
53
+ * roles is present.
54
+ *
55
+ * The pipeline starts by writing an empty file to
56
+ * s3://<artifacts-bucket>/pipelines/<pipeline-name>/trigger
57
+ *
58
+ * The CDK deploy process is handled by liflig-cdk-deployer.
59
+ * See https://github.com/capralifecycle/liflig-cdk-deployer
60
+ *
61
+ * Configuration files are read from S3 at the path
62
+ * s3://<artifacts-bucket>/pipelines/<pipeline-name>/
63
+ *
64
+ * - cloud-assembly.json which has the format described as
65
+ * CDK_CLOUD_ASSEMBLY in liflig-cdk-deployer
66
+ *
67
+ * - variables*.json which can be zero or more files
68
+ * with string-string map that will be concatenated to
69
+ * form the format described as CDK_VARIABLES in
70
+ * liflig-cdk-deployer
71
+ *
72
+ * The separation of Cloud Assembly details and variables enables
73
+ * separation of IaC code and application code if they are not
74
+ * colocated in the same repository.
75
+ */
76
+ export declare class Pipeline extends constructs.Construct {
77
+ constructor(scope: constructs.Construct, id: string, props: PipelineProps);
78
+ }