@liflig/cdk 2.18.5 → 2.18.6
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/assets/cloudtrail-slack-integration-lambda/main.py +267 -0
- package/assets/pipeline-slack-notification-lambda/index.py +300 -0
- package/assets/prepare-cdk-source-lambda/index.py +159 -0
- package/assets/slack-alarm-lambda/index.py +103 -0
- package/lib/alarms/database-alarms.d.ts +125 -0
- package/lib/alarms/database-alarms.js +171 -0
- package/lib/alarms/index.d.ts +3 -0
- package/lib/alarms/index.js +10 -0
- package/lib/alarms/service-alarms.d.ts +145 -0
- package/lib/alarms/service-alarms.js +148 -0
- package/lib/alarms/ses-alarms.d.ts +67 -0
- package/lib/alarms/ses-alarms.js +49 -0
- package/lib/alarms/slack-alarm.d.ts +25 -0
- package/lib/alarms/slack-alarm.js +47 -0
- package/lib/bastion-host.d.ts +41 -0
- package/lib/bastion-host.js +86 -0
- package/lib/bin/cdk-create-snapshots.d.ts +2 -0
- package/lib/bin/fetch-pipeline-variables.d.ts +2 -0
- package/lib/build-artifacts/index.d.ts +68 -0
- package/lib/build-artifacts/index.js +118 -0
- package/lib/cdk-deploy/cdk-deploy.d.ts +63 -0
- package/lib/cdk-deploy/cdk-deploy.js +175 -0
- package/lib/cdk-deploy/index.d.ts +1 -0
- package/lib/cdk-deploy/index.js +6 -0
- package/lib/cdk-deploy/start-deploy-handler.d.ts +8 -0
- package/lib/cdk-deploy/start-deploy-handler.js +72 -0
- package/lib/cdk-deploy/status-handler.d.ts +6 -0
- package/lib/cdk-deploy/status-handler.js +83 -0
- package/lib/cdk-pipelines/cloud-assembly-lookup-handler.d.ts +6 -0
- package/lib/cdk-pipelines/cloud-assembly-lookup-handler.js +63 -0
- package/lib/cdk-pipelines/index.d.ts +3 -0
- package/lib/cdk-pipelines/index.js +10 -0
- package/lib/cdk-pipelines/liflig-cdk-pipeline.d.ts +110 -0
- package/lib/cdk-pipelines/liflig-cdk-pipeline.js +232 -0
- package/lib/cdk-pipelines/slack-notification.d.ts +51 -0
- package/lib/cdk-pipelines/slack-notification.js +54 -0
- package/lib/cdk-pipelines/variables.d.ts +15 -0
- package/lib/cdk-pipelines/variables.js +80 -0
- package/lib/cloudtrail-slack-integration/cloudtrail-slack-integration.d.ts +47 -0
- package/lib/cloudtrail-slack-integration/cloudtrail-slack-integration.js +211 -0
- package/lib/cloudtrail-slack-integration/index.d.ts +1 -0
- package/lib/cloudtrail-slack-integration/index.js +6 -0
- package/lib/configure-parameters/configure-parameters.d.ts +61 -0
- package/lib/configure-parameters/configure-parameters.js +94 -0
- package/lib/configure-parameters/index.d.ts +1 -0
- package/lib/configure-parameters/index.js +6 -0
- package/lib/cross-region-ssm-parameter.d.ts +13 -0
- package/lib/cross-region-ssm-parameter.js +46 -0
- package/lib/ecs/cluster.d.ts +25 -0
- package/lib/ecs/cluster.js +70 -0
- package/lib/ecs/fargate-service.d.ts +63 -0
- package/lib/ecs/fargate-service.js +98 -0
- package/lib/ecs/index.d.ts +3 -0
- package/lib/ecs/index.js +10 -0
- package/lib/ecs/listener-rule.d.ts +25 -0
- package/lib/ecs/listener-rule.js +27 -0
- package/lib/ecs-update-image/artifact-status.d.ts +39 -0
- package/lib/ecs-update-image/artifact-status.js +41 -0
- package/lib/ecs-update-image/ecs-update-image.d.ts +41 -0
- package/lib/ecs-update-image/ecs-update-image.js +98 -0
- package/lib/ecs-update-image/index.d.ts +3 -0
- package/lib/ecs-update-image/index.js +10 -0
- package/lib/ecs-update-image/start-deploy-handler.d.ts +6 -0
- package/lib/ecs-update-image/start-deploy-handler.js +104 -0
- package/lib/ecs-update-image/status-handler.d.ts +11 -0
- package/lib/ecs-update-image/status-handler.js +74 -0
- package/lib/ecs-update-image/tag.d.ts +47 -0
- package/lib/ecs-update-image/tag.js +67 -0
- package/lib/feature-flags.d.ts +18 -0
- package/lib/feature-flags.js +48 -0
- package/lib/griid/artefact-bucket.d.ts +7 -0
- package/lib/griid/artefact-bucket.js +30 -0
- package/lib/griid/index.d.ts +4 -0
- package/lib/griid/index.js +18 -0
- package/lib/hosted-zone-with-param.d.ts +29 -0
- package/lib/hosted-zone-with-param.js +65 -0
- package/lib/index.d.ts +32 -0
- package/lib/kinesis/index.d.ts +1 -0
- package/lib/kinesis/index.js +6 -0
- package/lib/kinesis/kinesis-to-datadog-stream.d.ts +28 -0
- package/lib/kinesis/kinesis-to-datadog-stream.js +126 -0
- package/lib/load-balancer/index.d.ts +1 -0
- package/lib/load-balancer/index.js +6 -0
- package/lib/load-balancer/load-balancer.d.ts +16 -0
- package/lib/load-balancer/load-balancer.js +60 -0
- package/lib/pipelines/conventions.d.ts +14 -0
- package/lib/pipelines/conventions.js +24 -0
- package/lib/pipelines/deploy-env.d.ts +18 -0
- package/lib/pipelines/deploy-env.js +96 -0
- package/lib/pipelines/index.d.ts +2 -0
- package/lib/pipelines/index.js +8 -0
- package/lib/pipelines/liflig-cdk-deployer-deps.d.ts +13 -0
- package/lib/pipelines/liflig-cdk-deployer-deps.js +35 -0
- package/lib/pipelines/pipeline.d.ts +78 -0
- package/lib/pipelines/pipeline.js +224 -0
- package/lib/platform/index.d.ts +1 -0
- package/lib/platform/index.js +7 -0
- package/lib/platform/platform.d.ts +37 -0
- package/lib/platform/platform.js +57 -0
- package/lib/rds/database.d.ts +49 -0
- package/lib/rds/database.js +60 -0
- package/lib/rds/index.d.ts +1 -0
- package/lib/rds/index.js +6 -0
- package/lib/ses/configurationsetdeliveryoptions/index.d.ts +26 -0
- package/lib/ses/configurationsetdeliveryoptions/index.js +48 -0
- package/lib/ses/configurationsetsnsdestination/handler.d.ts +17 -0
- package/lib/ses/configurationsetsnsdestination/handler.js +75 -0
- package/lib/ses/configurationsetsnsdestination/index.d.ts +29 -0
- package/lib/ses/configurationsetsnsdestination/index.js +75 -0
- package/lib/ses/index.d.ts +4 -0
- package/lib/ses/index.js +12 -0
- package/lib/ses/sesdomain/handler.d.ts +10 -0
- package/lib/ses/sesdomain/handler.js +82 -0
- package/lib/ses/sesdomain/index.d.ts +57 -0
- package/lib/ses/sesdomain/index.js +94 -0
- package/lib/ses/sesverifyemail/handler.d.ts +9 -0
- package/lib/ses/sesverifyemail/handler.js +25 -0
- package/lib/ses/sesverifyemail/index.d.ts +13 -0
- package/lib/ses/sesverifyemail/index.js +51 -0
- package/lib/snapshots.d.ts +4 -0
- package/lib/snapshots.js +214 -0
- package/lib/ssm-parameter-backed-resource.d.ts +45 -0
- package/lib/ssm-parameter-backed-resource.js +67 -0
- package/lib/ssm-parameter-reader.d.ts +21 -0
- package/lib/ssm-parameter-reader.js +48 -0
- package/lib/tags.d.ts +8 -0
- package/lib/tags.js +36 -0
- package/lib/utils.d.ts +2 -0
- package/lib/utils.js +17 -0
- package/lib/webapp/index.d.ts +3 -0
- package/lib/webapp/index.js +10 -0
- package/lib/webapp/monitor.d.ts +187 -0
- package/lib/webapp/monitor.js +156 -0
- package/lib/webapp/security-headers.d.ts +38 -0
- package/lib/webapp/security-headers.js +129 -0
- package/lib/webapp/webapp.d.ts +116 -0
- package/lib/webapp/webapp.js +118 -0
- package/lib/webapp-deploy-via-role.d.ts +25 -0
- package/lib/webapp-deploy-via-role.js +32 -0
- package/package.json +3 -2
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Pipeline = void 0;
|
|
4
|
+
const constructs = require("constructs");
|
|
5
|
+
const events = require("aws-cdk-lib/aws-events");
|
|
6
|
+
const eventsTargets = require("aws-cdk-lib/aws-events-targets");
|
|
7
|
+
const iam = require("aws-cdk-lib/aws-iam");
|
|
8
|
+
const lambda = require("aws-cdk-lib/aws-lambda");
|
|
9
|
+
const sfn = require("aws-cdk-lib/aws-stepfunctions");
|
|
10
|
+
const aws_stepfunctions_1 = 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 griid_1 = require("../griid");
|
|
14
|
+
const conventions_1 = require("./conventions");
|
|
15
|
+
const deploy_env_1 = require("./deploy-env");
|
|
16
|
+
/**
|
|
17
|
+
* Pipeline for doing a multi-account CDK deployment based
|
|
18
|
+
* on a built CDK Cloud Assembly and parameters stored in S3.
|
|
19
|
+
*
|
|
20
|
+
* The accounts being deployed to must be provisioned with
|
|
21
|
+
* the LifligCdkDeployerDeps construct so expected IAM
|
|
22
|
+
* roles is present.
|
|
23
|
+
*
|
|
24
|
+
* The pipeline starts by writing an empty file to
|
|
25
|
+
* s3://<artifacts-bucket>/pipelines/<pipeline-name>/trigger
|
|
26
|
+
*
|
|
27
|
+
* The CDK deploy process is handled by liflig-cdk-deployer.
|
|
28
|
+
* See https://github.com/capralifecycle/liflig-cdk-deployer
|
|
29
|
+
*
|
|
30
|
+
* Configuration files are read from S3 at the path
|
|
31
|
+
* s3://<artifacts-bucket>/pipelines/<pipeline-name>/
|
|
32
|
+
*
|
|
33
|
+
* - cloud-assembly.json which has the format described as
|
|
34
|
+
* CDK_CLOUD_ASSEMBLY in liflig-cdk-deployer
|
|
35
|
+
*
|
|
36
|
+
* - variables*.json which can be zero or more files
|
|
37
|
+
* with string-string map that will be concatenated to
|
|
38
|
+
* form the format described as CDK_VARIABLES in
|
|
39
|
+
* liflig-cdk-deployer
|
|
40
|
+
*
|
|
41
|
+
* The separation of Cloud Assembly details and variables enables
|
|
42
|
+
* separation of IaC code and application code if they are not
|
|
43
|
+
* colocated in the same repository.
|
|
44
|
+
*/
|
|
45
|
+
class Pipeline extends constructs.Construct {
|
|
46
|
+
constructor(scope, id, props) {
|
|
47
|
+
var _a, _b;
|
|
48
|
+
super(scope, id);
|
|
49
|
+
const s3Prefix = (0, conventions_1.pipelineS3Prefix)(props.pipelineName);
|
|
50
|
+
const s3TriggerKey = (0, conventions_1.pipelineS3TriggerKey)(props.pipelineName);
|
|
51
|
+
const artifactsBucket = (_a = props.artifactsBucket) !== null && _a !== void 0 ? _a : (0, griid_1.getGriidArtefactBucket)(this);
|
|
52
|
+
const checkCanRunFn = new lambda.SingletonFunction(this, "CheckCanRunFn", {
|
|
53
|
+
uuid: "30ad3abb-f774-4804-a6ef-2c2f4a247362",
|
|
54
|
+
code: new lambda.InlineCode(`exports.handler = ${checkCanRunHandler.toString()};`),
|
|
55
|
+
runtime: lambda.Runtime.NODEJS_16_X,
|
|
56
|
+
handler: "index.handler",
|
|
57
|
+
timeout: cdk.Duration.seconds(10),
|
|
58
|
+
});
|
|
59
|
+
const checkCanRunTask = new tasks.LambdaInvoke(this, "Check if the process can run", {
|
|
60
|
+
lambdaFunction: checkCanRunFn,
|
|
61
|
+
outputPath: "$.Payload",
|
|
62
|
+
payload: sfn.TaskInput.fromObject({
|
|
63
|
+
"stateMachineId.$": "$$.StateMachine.Id",
|
|
64
|
+
"executionId.$": "$$.Execution.Id",
|
|
65
|
+
}),
|
|
66
|
+
});
|
|
67
|
+
const wait = new sfn.Wait(this, "Wait before rechecking status", {
|
|
68
|
+
time: sfn.WaitTime.duration(cdk.Duration.seconds(15)),
|
|
69
|
+
});
|
|
70
|
+
const skip = new sfn.Succeed(this, "Skip");
|
|
71
|
+
const collectFilesFn = new lambda.SingletonFunction(this, "CollectFilesFn", {
|
|
72
|
+
uuid: "c49cbfe1-50e0-4721-8964-fb20f4e5a7ad",
|
|
73
|
+
code: new lambda.InlineCode(`exports.handler = ${collectFilesHandler.toString()};`),
|
|
74
|
+
runtime: lambda.Runtime.NODEJS_16_X,
|
|
75
|
+
handler: "index.handler",
|
|
76
|
+
timeout: cdk.Duration.seconds(30),
|
|
77
|
+
});
|
|
78
|
+
artifactsBucket.grantRead(collectFilesFn);
|
|
79
|
+
const collectFilesTask = new tasks.LambdaInvoke(this, "Collect files from S3", {
|
|
80
|
+
lambdaFunction: collectFilesFn,
|
|
81
|
+
outputPath: "$.Payload",
|
|
82
|
+
payload: sfn.TaskInput.fromObject({
|
|
83
|
+
bucketName: artifactsBucket.bucketName,
|
|
84
|
+
bucketPrefix: s3Prefix,
|
|
85
|
+
envNames: props.environments.map((it) => it.name),
|
|
86
|
+
}),
|
|
87
|
+
});
|
|
88
|
+
let run = sfn.Chain.start(collectFilesTask);
|
|
89
|
+
const ifHavingStacks = (name, work) => new sfn.Choice(this, `Check if ${name} has stacks`)
|
|
90
|
+
.when(aws_stepfunctions_1.Condition.or(aws_stepfunctions_1.Condition.isNull(`$.StackCountPerEnv.${name}`), aws_stepfunctions_1.Condition.numberEquals(`$.StackCountPerEnv.${name}`, 0)), new sfn.Pass(this, `Skip ${name}`))
|
|
91
|
+
.otherwise(work)
|
|
92
|
+
.afterwards();
|
|
93
|
+
for (const env of props.environments) {
|
|
94
|
+
const it = new deploy_env_1.DeployEnv(this, env.name, {
|
|
95
|
+
accountId: env.accountId,
|
|
96
|
+
afterSuccessfulDeploy: env.afterSuccessfulDeploy,
|
|
97
|
+
artefactBucket: artifactsBucket,
|
|
98
|
+
envName: env.name,
|
|
99
|
+
vpc: props.vpc,
|
|
100
|
+
});
|
|
101
|
+
run = run.next(ifHavingStacks(env.name, it.chain));
|
|
102
|
+
}
|
|
103
|
+
const definition = sfn.Chain.start(checkCanRunTask).next(new sfn.Choice(this, "Can run?")
|
|
104
|
+
.when(aws_stepfunctions_1.Condition.stringEquals("$.CanRunState", "CONTINUE"), run)
|
|
105
|
+
.when(aws_stepfunctions_1.Condition.stringEquals("$.CanRunState", "SKIP"), skip)
|
|
106
|
+
.otherwise(wait.next(checkCanRunTask)));
|
|
107
|
+
const machine = new sfn.StateMachine(this, "StateMachine", {
|
|
108
|
+
definition,
|
|
109
|
+
// https://docs.aws.amazon.com/step-functions/latest/dg/sfn-stuck-execution.html
|
|
110
|
+
timeout: cdk.Duration.hours(3),
|
|
111
|
+
});
|
|
112
|
+
new iam.Policy(this, "CheckCanRunPolicy", {
|
|
113
|
+
roles: [checkCanRunFn.role],
|
|
114
|
+
statements: [
|
|
115
|
+
new iam.PolicyStatement({
|
|
116
|
+
actions: ["states:ListExecutions"],
|
|
117
|
+
resources: [machine.stateMachineArn],
|
|
118
|
+
}),
|
|
119
|
+
],
|
|
120
|
+
});
|
|
121
|
+
if ((_b = props.triggerEnabled) !== null && _b !== void 0 ? _b : true) {
|
|
122
|
+
artifactsBucket.onCloudTrailWriteObject("Trigger", {
|
|
123
|
+
paths: [s3TriggerKey],
|
|
124
|
+
target: new eventsTargets.SfnStateMachine(machine, {
|
|
125
|
+
input: events.RuleTargetInput.fromObject({}),
|
|
126
|
+
}),
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
exports.Pipeline = Pipeline;
|
|
132
|
+
// This is a self-contained function that will be serialized as a lambda.
|
|
133
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
134
|
+
const collectFilesHandler = async (event) => {
|
|
135
|
+
var _a;
|
|
136
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unsafe-assignment
|
|
137
|
+
const AWS = require("aws-sdk");
|
|
138
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
139
|
+
const s3 = new AWS.S3();
|
|
140
|
+
console.log("Event received: ", event);
|
|
141
|
+
const bucketName = event.bucketName;
|
|
142
|
+
const bucketPrefix = event.bucketPrefix;
|
|
143
|
+
const envNames = event.envNames;
|
|
144
|
+
if (bucketPrefix.slice(-1) !== "/") {
|
|
145
|
+
throw new Error(`Expected bucket prefix to end with '/' but its value is '${bucketPrefix}'`);
|
|
146
|
+
}
|
|
147
|
+
const files = await s3
|
|
148
|
+
.listObjectsV2({
|
|
149
|
+
Bucket: bucketName,
|
|
150
|
+
Prefix: bucketPrefix,
|
|
151
|
+
})
|
|
152
|
+
.promise();
|
|
153
|
+
async function getData(key) {
|
|
154
|
+
const result = await s3
|
|
155
|
+
.getObject({
|
|
156
|
+
Bucket: bucketName,
|
|
157
|
+
Key: key,
|
|
158
|
+
})
|
|
159
|
+
.promise();
|
|
160
|
+
return result.Body.toString();
|
|
161
|
+
}
|
|
162
|
+
let cloudAssembly = null;
|
|
163
|
+
let variables = {};
|
|
164
|
+
for (const file of (_a = files.Contents) !== null && _a !== void 0 ? _a : []) {
|
|
165
|
+
const key = file.Key;
|
|
166
|
+
const filename = key.slice(bucketPrefix.length);
|
|
167
|
+
console.log(`File: ${filename}`);
|
|
168
|
+
if (filename === "cloud-assembly.json") {
|
|
169
|
+
console.log("Found Cloud Assembly");
|
|
170
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
171
|
+
cloudAssembly = JSON.parse(await getData(key));
|
|
172
|
+
}
|
|
173
|
+
else if (/^variables.*\.json$/.test(filename)) {
|
|
174
|
+
console.log("Found variables file");
|
|
175
|
+
variables = {
|
|
176
|
+
...variables,
|
|
177
|
+
...JSON.parse(await getData(key)),
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
console.log("Ignoring unknown file");
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
if (cloudAssembly === null) {
|
|
185
|
+
throw new Error("cloud-assembly.json not found");
|
|
186
|
+
}
|
|
187
|
+
return {
|
|
188
|
+
CloudAssembly: JSON.stringify(cloudAssembly),
|
|
189
|
+
Variables: JSON.stringify(variables),
|
|
190
|
+
StackCountPerEnv: Object.fromEntries(envNames.map((name) => {
|
|
191
|
+
var _a, _b;
|
|
192
|
+
return [
|
|
193
|
+
name,
|
|
194
|
+
(_b = (_a = cloudAssembly.environments.find((it) => it.name === name)) === null || _a === void 0 ? void 0 : _a.stackNames.length) !== null && _b !== void 0 ? _b : 0,
|
|
195
|
+
];
|
|
196
|
+
})),
|
|
197
|
+
};
|
|
198
|
+
};
|
|
199
|
+
// This is a self-contained function that will be serialized as a lambda.
|
|
200
|
+
const checkCanRunHandler = async (event) => {
|
|
201
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unsafe-assignment
|
|
202
|
+
const AWS = require("aws-sdk");
|
|
203
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
204
|
+
const sf = new AWS.StepFunctions();
|
|
205
|
+
console.log("Event received: ", event);
|
|
206
|
+
const stateMachineArn = event["stateMachineId"];
|
|
207
|
+
const currentExecutionArn = event["executionId"];
|
|
208
|
+
const executions = (await sf
|
|
209
|
+
.listExecutions({
|
|
210
|
+
stateMachineArn,
|
|
211
|
+
statusFilter: "RUNNING",
|
|
212
|
+
})
|
|
213
|
+
.promise()).executions;
|
|
214
|
+
console.log("Executions: ", executions);
|
|
215
|
+
const currentExecution = executions.find((it) => it.executionArn == currentExecutionArn);
|
|
216
|
+
if (!currentExecution) {
|
|
217
|
+
throw new Error("Could not find current execution");
|
|
218
|
+
}
|
|
219
|
+
const newer = executions.filter((it) => it.startDate > currentExecution.startDate).length;
|
|
220
|
+
return {
|
|
221
|
+
CanRunState: newer > 0 ? "SKIP" : executions.length == 1 ? "CONTINUE" : "WAIT",
|
|
222
|
+
};
|
|
223
|
+
};
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["../../src/pipelines/pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import * as constructs from \"constructs\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as events from \"aws-cdk-lib/aws-events\"\nimport * as eventsTargets from \"aws-cdk-lib/aws-events-targets\"\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 sfn from \"aws-cdk-lib/aws-stepfunctions\"\nimport { Condition } from \"aws-cdk-lib/aws-stepfunctions\"\nimport * as tasks from \"aws-cdk-lib/aws-stepfunctions-tasks\"\nimport * as cdk from \"aws-cdk-lib\"\nimport type { Handler } from \"aws-lambda\"\nimport type * as _AWS from \"aws-sdk\"\nimport { getGriidArtefactBucket } from \"../griid\"\nimport { pipelineS3Prefix, pipelineS3TriggerKey } from \"./conventions\"\nimport { DeployEnv } from \"./deploy-env\"\n\nexport interface PipelineProps {\n  /**\n   * Bucket holding pipeline configuration and trigger file.\n   *\n   * @default - use existing bucket based on Griid conventions\n   */\n  artifactsBucket?: s3.IBucket\n  /**\n   * Environments for this pipeline. Each environment is deployed sequentially\n   * in the order given.\n   */\n  environments: PipelineEnvironment[]\n  /**\n   * Name of pipeline. This is used for the path where configuration\n   * is stored in S3.\n   */\n  pipelineName: string\n  /**\n   * Trigger the pipeline when the trigger file is written.\n   *\n   * @default - true\n   */\n  triggerEnabled?: boolean\n  /**\n   * VPC used for Fargate resources.\n   */\n  vpc: ec2.IVpc\n}\n\nexport interface PipelineEnvironment {\n  /**\n   * Account number hosting the environment.\n   */\n  accountId: string\n  /**\n   * Additional tasks to run after the environment has been deployed.\n   */\n  afterSuccessfulDeploy?: sfn.Chain\n  /**\n   * Name of environment.\n   */\n  name: string\n}\n\n/**\n * Pipeline for doing a multi-account CDK deployment based\n * on a built CDK Cloud Assembly and parameters stored in S3.\n *\n * The accounts being deployed to must be provisioned with\n * the LifligCdkDeployerDeps construct so expected IAM\n * roles is present.\n *\n * The pipeline starts by writing an empty file to\n * s3://<artifacts-bucket>/pipelines/<pipeline-name>/trigger\n *\n * The CDK deploy process is handled by liflig-cdk-deployer.\n * See https://github.com/capralifecycle/liflig-cdk-deployer\n *\n * Configuration files are read from S3 at the path\n * s3://<artifacts-bucket>/pipelines/<pipeline-name>/\n *\n *  - cloud-assembly.json which has the format described as\n *    CDK_CLOUD_ASSEMBLY in liflig-cdk-deployer\n *\n *  - variables*.json which can be zero or more files\n *    with string-string map that will be concatenated to\n *    form the format described as CDK_VARIABLES in\n *    liflig-cdk-deployer\n *\n * The separation of Cloud Assembly details and variables enables\n * separation of IaC code and application code if they are not\n * colocated in the same repository.\n */\nexport class Pipeline extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: PipelineProps) {\n    super(scope, id)\n\n    const s3Prefix = pipelineS3Prefix(props.pipelineName)\n    const s3TriggerKey = pipelineS3TriggerKey(props.pipelineName)\n\n    const artifactsBucket =\n      props.artifactsBucket ?? getGriidArtefactBucket(this)\n\n    const checkCanRunFn = new lambda.SingletonFunction(this, \"CheckCanRunFn\", {\n      uuid: \"30ad3abb-f774-4804-a6ef-2c2f4a247362\",\n      code: new lambda.InlineCode(\n        `exports.handler = ${checkCanRunHandler.toString()};`,\n      ),\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      timeout: cdk.Duration.seconds(10),\n    })\n\n    const checkCanRunTask = new tasks.LambdaInvoke(\n      this,\n      \"Check if the process can run\",\n      {\n        lambdaFunction: checkCanRunFn,\n        outputPath: \"$.Payload\",\n        payload: sfn.TaskInput.fromObject({\n          \"stateMachineId.$\": \"$$.StateMachine.Id\",\n          \"executionId.$\": \"$$.Execution.Id\",\n        }),\n      },\n    )\n\n    const wait = new sfn.Wait(this, \"Wait before rechecking status\", {\n      time: sfn.WaitTime.duration(cdk.Duration.seconds(15)),\n    })\n\n    const skip = new sfn.Succeed(this, \"Skip\")\n\n    const collectFilesFn = new lambda.SingletonFunction(\n      this,\n      \"CollectFilesFn\",\n      {\n        uuid: \"c49cbfe1-50e0-4721-8964-fb20f4e5a7ad\",\n        code: new lambda.InlineCode(\n          `exports.handler = ${collectFilesHandler.toString()};`,\n        ),\n        runtime: lambda.Runtime.NODEJS_16_X,\n        handler: \"index.handler\",\n        timeout: cdk.Duration.seconds(30),\n      },\n    )\n\n    artifactsBucket.grantRead(collectFilesFn)\n\n    const collectFilesTask = new tasks.LambdaInvoke(\n      this,\n      \"Collect files from S3\",\n      {\n        lambdaFunction: collectFilesFn,\n        outputPath: \"$.Payload\",\n        payload: sfn.TaskInput.fromObject({\n          bucketName: artifactsBucket.bucketName,\n          bucketPrefix: s3Prefix,\n          envNames: props.environments.map((it) => it.name),\n        }),\n      },\n    )\n\n    let run: sfn.Chain = sfn.Chain.start(collectFilesTask)\n\n    const ifHavingStacks = (name: string, work: sfn.Chain) =>\n      new sfn.Choice(this, `Check if ${name} has stacks`)\n        .when(\n          Condition.or(\n            Condition.isNull(`$.StackCountPerEnv.${name}`),\n            Condition.numberEquals(`$.StackCountPerEnv.${name}`, 0),\n          ),\n          new sfn.Pass(this, `Skip ${name}`),\n        )\n        .otherwise(work)\n        .afterwards()\n\n    for (const env of props.environments) {\n      const it = new DeployEnv(this, env.name, {\n        accountId: env.accountId,\n        afterSuccessfulDeploy: env.afterSuccessfulDeploy,\n        artefactBucket: artifactsBucket,\n        envName: env.name,\n        vpc: props.vpc,\n      })\n\n      run = run.next(ifHavingStacks(env.name, it.chain))\n    }\n\n    const definition: sfn.Chain = sfn.Chain.start(checkCanRunTask).next(\n      new sfn.Choice(this, \"Can run?\")\n        .when(Condition.stringEquals(\"$.CanRunState\", \"CONTINUE\"), run)\n        .when(Condition.stringEquals(\"$.CanRunState\", \"SKIP\"), skip)\n        .otherwise(wait.next(checkCanRunTask)),\n    )\n\n    const machine = new sfn.StateMachine(this, \"StateMachine\", {\n      definition,\n      // https://docs.aws.amazon.com/step-functions/latest/dg/sfn-stuck-execution.html\n      timeout: cdk.Duration.hours(3),\n    })\n\n    new iam.Policy(this, \"CheckCanRunPolicy\", {\n      roles: [checkCanRunFn.role!],\n      statements: [\n        new iam.PolicyStatement({\n          actions: [\"states:ListExecutions\"],\n          resources: [machine.stateMachineArn],\n        }),\n      ],\n    })\n\n    if (props.triggerEnabled ?? true) {\n      artifactsBucket.onCloudTrailWriteObject(\"Trigger\", {\n        paths: [s3TriggerKey],\n        target: new eventsTargets.SfnStateMachine(machine, {\n          input: events.RuleTargetInput.fromObject({}),\n        }),\n      })\n    }\n  }\n}\n\ninterface CloudAssembly {\n  cloudAssemblyBucketName: string\n  cloudAssemblyBucketKey: string\n  environments: {\n    name: string\n    stackNames: string[]\n  }[]\n  parameters: {\n    name: string\n    value: unknown | { type: \"variable\"; variable: string }\n  }[]\n}\n\n// This is a self-contained function that will be serialized as a lambda.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst collectFilesHandler: Handler = async (event: Record<string, any>) => {\n  // eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unsafe-assignment\n  const AWS = require(\"aws-sdk\")\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access\n  const s3 = new AWS.S3() as _AWS.S3\n\n  console.log(\"Event received: \", event)\n\n  const bucketName = event.bucketName as string\n  const bucketPrefix = event.bucketPrefix as string\n  const envNames = event.envNames as string[]\n\n  if (bucketPrefix.slice(-1) !== \"/\") {\n    throw new Error(\n      `Expected bucket prefix to end with '/' but its value is '${bucketPrefix}'`,\n    )\n  }\n\n  const files = await s3\n    .listObjectsV2({\n      Bucket: bucketName,\n      Prefix: bucketPrefix,\n    })\n    .promise()\n\n  async function getData(key: string): Promise<string> {\n    const result = await s3\n      .getObject({\n        Bucket: bucketName,\n        Key: key,\n      })\n      .promise()\n    return result.Body!.toString()\n  }\n\n  let cloudAssembly: CloudAssembly | null = null\n  let variables: Record<string, string> = {}\n\n  for (const file of files.Contents ?? []) {\n    const key = file.Key!\n    const filename = key.slice(bucketPrefix.length)\n\n    console.log(`File: ${filename}`)\n\n    if (filename === \"cloud-assembly.json\") {\n      console.log(\"Found Cloud Assembly\")\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n      cloudAssembly = JSON.parse(await getData(key))\n    } else if (/^variables.*\\.json$/.test(filename)) {\n      console.log(\"Found variables file\")\n      variables = {\n        ...variables,\n        ...(JSON.parse(await getData(key)) as Record<string, string>),\n      }\n    } else {\n      console.log(\"Ignoring unknown file\")\n    }\n  }\n\n  if (cloudAssembly === null) {\n    throw new Error(\"cloud-assembly.json not found\")\n  }\n\n  return {\n    CloudAssembly: JSON.stringify(cloudAssembly),\n    Variables: JSON.stringify(variables),\n    StackCountPerEnv: Object.fromEntries(\n      envNames.map((name) => [\n        name,\n        cloudAssembly!.environments.find((it) => it.name === name)?.stackNames\n          .length ?? 0,\n      ]),\n    ),\n  }\n}\n\n// This is a self-contained function that will be serialized as a lambda.\nconst checkCanRunHandler: Handler = async (event: Record<string, string>) => {\n  // eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unsafe-assignment\n  const AWS = require(\"aws-sdk\")\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access\n  const sf = new AWS.StepFunctions() as _AWS.StepFunctions\n\n  console.log(\"Event received: \", event)\n\n  const stateMachineArn = event[\"stateMachineId\"]\n  const currentExecutionArn = event[\"executionId\"]\n\n  const executions = (\n    await sf\n      .listExecutions({\n        stateMachineArn,\n        statusFilter: \"RUNNING\",\n      })\n      .promise()\n  ).executions\n\n  console.log(\"Executions: \", executions)\n\n  const currentExecution = executions.find(\n    (it) => it.executionArn == currentExecutionArn,\n  )\n\n  if (!currentExecution) {\n    throw new Error(\"Could not find current execution\")\n  }\n\n  const newer = executions.filter(\n    (it) => it.startDate > currentExecution.startDate,\n  ).length\n\n  return {\n    CanRunState:\n      newer > 0 ? \"SKIP\" : executions.length == 1 ? \"CONTINUE\" : \"WAIT\",\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { PlatformProducer, PlatformConsumer, PlatformProducerProps, PlatformConsumerProps, } from "./platform";
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PlatformConsumer = exports.PlatformProducer = void 0;
|
|
4
|
+
var platform_1 = require("./platform");
|
|
5
|
+
Object.defineProperty(exports, "PlatformProducer", { enumerable: true, get: function () { return platform_1.PlatformProducer; } });
|
|
6
|
+
Object.defineProperty(exports, "PlatformConsumer", { enumerable: true, get: function () { return platform_1.PlatformConsumer; } });
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBS21CO0FBSmpCLDRHQUFBLGdCQUFnQixPQUFBO0FBQ2hCLDRHQUFBLGdCQUFnQixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtcbiAgUGxhdGZvcm1Qcm9kdWNlcixcbiAgUGxhdGZvcm1Db25zdW1lcixcbiAgUGxhdGZvcm1Qcm9kdWNlclByb3BzLFxuICBQbGF0Zm9ybUNvbnN1bWVyUHJvcHMsXG59IGZyb20gXCIuL3BsYXRmb3JtXCJcbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import * as constructs from "constructs";
|
|
2
|
+
import * as ssm from "aws-cdk-lib/aws-ssm";
|
|
3
|
+
export interface PlatformProducerProps {
|
|
4
|
+
platformNamespace: string;
|
|
5
|
+
platformName: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
*
|
|
9
|
+
* Produces the resources that will be consumed in PlatformConsumer.
|
|
10
|
+
* In other words; this must run before PlatformConsumer.
|
|
11
|
+
*
|
|
12
|
+
* Used for producing references to the core resources.
|
|
13
|
+
*/
|
|
14
|
+
export declare abstract class PlatformProducer extends constructs.Construct {
|
|
15
|
+
private platformNamespace;
|
|
16
|
+
private platformName;
|
|
17
|
+
constructor(scope: constructs.Construct, id: string, props: PlatformProducerProps);
|
|
18
|
+
protected putParam(name: string, value: string): ssm.StringParameter;
|
|
19
|
+
}
|
|
20
|
+
export interface PlatformConsumerProps {
|
|
21
|
+
platformNamespace: string;
|
|
22
|
+
platformName: string;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
*
|
|
26
|
+
* Consumes the resources that have been produced by PlatformProducer.
|
|
27
|
+
* In other words; this must run after PlatformProducer.
|
|
28
|
+
*
|
|
29
|
+
* Used for consuming the core resources, which PlatformProducer creates references to.
|
|
30
|
+
*/
|
|
31
|
+
export declare abstract class PlatformConsumer extends constructs.Construct {
|
|
32
|
+
private platformNamespace;
|
|
33
|
+
private platformName;
|
|
34
|
+
constructor(scope: constructs.Construct, id: string, props: PlatformConsumerProps);
|
|
35
|
+
protected lazy<T>(producer: () => T): () => T;
|
|
36
|
+
protected getParam(name: string): string;
|
|
37
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PlatformConsumer = exports.PlatformProducer = void 0;
|
|
4
|
+
const constructs = require("constructs");
|
|
5
|
+
const ssm = require("aws-cdk-lib/aws-ssm");
|
|
6
|
+
function paramName(platformNamespace, platformName, resourceName) {
|
|
7
|
+
return `/liflig-cdk/${platformNamespace}/platform/${platformName}/${resourceName}`;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
*
|
|
11
|
+
* Produces the resources that will be consumed in PlatformConsumer.
|
|
12
|
+
* In other words; this must run before PlatformConsumer.
|
|
13
|
+
*
|
|
14
|
+
* Used for producing references to the core resources.
|
|
15
|
+
*/
|
|
16
|
+
class PlatformProducer extends constructs.Construct {
|
|
17
|
+
constructor(scope, id, props) {
|
|
18
|
+
super(scope, id);
|
|
19
|
+
this.platformNamespace = props.platformNamespace;
|
|
20
|
+
this.platformName = props.platformName;
|
|
21
|
+
}
|
|
22
|
+
putParam(name, value) {
|
|
23
|
+
return new ssm.StringParameter(this, name, {
|
|
24
|
+
stringValue: value,
|
|
25
|
+
parameterName: paramName(this.platformNamespace, this.platformName, name),
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
exports.PlatformProducer = PlatformProducer;
|
|
30
|
+
/**
|
|
31
|
+
*
|
|
32
|
+
* Consumes the resources that have been produced by PlatformProducer.
|
|
33
|
+
* In other words; this must run after PlatformProducer.
|
|
34
|
+
*
|
|
35
|
+
* Used for consuming the core resources, which PlatformProducer creates references to.
|
|
36
|
+
*/
|
|
37
|
+
class PlatformConsumer extends constructs.Construct {
|
|
38
|
+
constructor(scope, id, props) {
|
|
39
|
+
super(scope, id);
|
|
40
|
+
this.platformNamespace = props.platformNamespace;
|
|
41
|
+
this.platformName = props.platformName;
|
|
42
|
+
}
|
|
43
|
+
lazy(producer) {
|
|
44
|
+
let value = null;
|
|
45
|
+
return () => {
|
|
46
|
+
if (value == null) {
|
|
47
|
+
value = producer();
|
|
48
|
+
}
|
|
49
|
+
return value;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
getParam(name) {
|
|
53
|
+
return ssm.StringParameter.valueForStringParameter(this, paramName(this.platformNamespace, this.platformName, name));
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
exports.PlatformConsumer = PlatformConsumer;
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdGZvcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vcGxhdGZvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUNBQXdDO0FBQ3hDLDJDQUEwQztBQUUxQyxTQUFTLFNBQVMsQ0FDaEIsaUJBQXlCLEVBQ3pCLFlBQW9CLEVBQ3BCLFlBQW9CO0lBRXBCLE9BQU8sZUFBZSxpQkFBaUIsYUFBYSxZQUFZLElBQUksWUFBWSxFQUFFLENBQUE7QUFDcEYsQ0FBQztBQU9EOzs7Ozs7R0FNRztBQUNILE1BQXNCLGdCQUFpQixTQUFRLFVBQVUsQ0FBQyxTQUFTO0lBSWpFLFlBQ0UsS0FBMkIsRUFDM0IsRUFBVSxFQUNWLEtBQTRCO1FBRTVCLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7UUFFaEIsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQTtRQUVoRCxJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUE7SUFDeEMsQ0FBQztJQUVTLFFBQVEsQ0FBQyxJQUFZLEVBQUUsS0FBYTtRQUM1QyxPQUFPLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFO1lBQ3pDLFdBQVcsRUFBRSxLQUFLO1lBQ2xCLGFBQWEsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDO1NBQzFFLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRjtBQXRCRCw0Q0FzQkM7QUFNRDs7Ozs7O0dBTUc7QUFDSCxNQUFzQixnQkFBaUIsU0FBUSxVQUFVLENBQUMsU0FBUztJQUlqRSxZQUNFLEtBQTJCLEVBQzNCLEVBQVUsRUFDVixLQUE0QjtRQUU1QixLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFBO1FBRWhCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxLQUFLLENBQUMsaUJBQWlCLENBQUE7UUFFaEQsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFBO0lBQ3hDLENBQUM7SUFFUyxJQUFJLENBQUksUUFBaUI7UUFDakMsSUFBSSxLQUFLLEdBQWEsSUFBSSxDQUFBO1FBRTFCLE9BQU8sR0FBRyxFQUFFO1lBQ1YsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFLENBQUM7Z0JBQ2xCLEtBQUssR0FBRyxRQUFRLEVBQUUsQ0FBQTtZQUNwQixDQUFDO1lBQ0QsT0FBTyxLQUFLLENBQUE7UUFDZCxDQUFDLENBQUE7SUFDSCxDQUFDO0lBRVMsUUFBUSxDQUFDLElBQVk7UUFDN0IsT0FBTyxHQUFHLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUNoRCxJQUFJLEVBQ0osU0FBUyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxDQUMzRCxDQUFBO0lBQ0gsQ0FBQztDQUNGO0FBakNELDRDQWlDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNvbnN0cnVjdHMgZnJvbSBcImNvbnN0cnVjdHNcIlxuaW1wb3J0ICogYXMgc3NtIGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtc3NtXCJcblxuZnVuY3Rpb24gcGFyYW1OYW1lKFxuICBwbGF0Zm9ybU5hbWVzcGFjZTogc3RyaW5nLFxuICBwbGF0Zm9ybU5hbWU6IHN0cmluZyxcbiAgcmVzb3VyY2VOYW1lOiBzdHJpbmcsXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYC9saWZsaWctY2RrLyR7cGxhdGZvcm1OYW1lc3BhY2V9L3BsYXRmb3JtLyR7cGxhdGZvcm1OYW1lfS8ke3Jlc291cmNlTmFtZX1gXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhdGZvcm1Qcm9kdWNlclByb3BzIHtcbiAgcGxhdGZvcm1OYW1lc3BhY2U6IHN0cmluZ1xuICBwbGF0Zm9ybU5hbWU6IHN0cmluZ1xufVxuXG4vKipcbiAqXG4gKiBQcm9kdWNlcyB0aGUgcmVzb3VyY2VzIHRoYXQgd2lsbCBiZSBjb25zdW1lZCBpbiBQbGF0Zm9ybUNvbnN1bWVyLlxuICogSW4gb3RoZXIgd29yZHM7IHRoaXMgbXVzdCBydW4gYmVmb3JlIFBsYXRmb3JtQ29uc3VtZXIuXG4gKlxuICogVXNlZCBmb3IgcHJvZHVjaW5nIHJlZmVyZW5jZXMgdG8gdGhlIGNvcmUgcmVzb3VyY2VzLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUGxhdGZvcm1Qcm9kdWNlciBleHRlbmRzIGNvbnN0cnVjdHMuQ29uc3RydWN0IHtcbiAgcHJpdmF0ZSBwbGF0Zm9ybU5hbWVzcGFjZTogc3RyaW5nXG4gIHByaXZhdGUgcGxhdGZvcm1OYW1lOiBzdHJpbmdcblxuICBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsXG4gICAgaWQ6IHN0cmluZyxcbiAgICBwcm9wczogUGxhdGZvcm1Qcm9kdWNlclByb3BzLFxuICApIHtcbiAgICBzdXBlcihzY29wZSwgaWQpXG5cbiAgICB0aGlzLnBsYXRmb3JtTmFtZXNwYWNlID0gcHJvcHMucGxhdGZvcm1OYW1lc3BhY2VcblxuICAgIHRoaXMucGxhdGZvcm1OYW1lID0gcHJvcHMucGxhdGZvcm1OYW1lXG4gIH1cblxuICBwcm90ZWN0ZWQgcHV0UGFyYW0obmFtZTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKTogc3NtLlN0cmluZ1BhcmFtZXRlciB7XG4gICAgcmV0dXJuIG5ldyBzc20uU3RyaW5nUGFyYW1ldGVyKHRoaXMsIG5hbWUsIHtcbiAgICAgIHN0cmluZ1ZhbHVlOiB2YWx1ZSxcbiAgICAgIHBhcmFtZXRlck5hbWU6IHBhcmFtTmFtZSh0aGlzLnBsYXRmb3JtTmFtZXNwYWNlLCB0aGlzLnBsYXRmb3JtTmFtZSwgbmFtZSksXG4gICAgfSlcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBsYXRmb3JtQ29uc3VtZXJQcm9wcyB7XG4gIHBsYXRmb3JtTmFtZXNwYWNlOiBzdHJpbmdcbiAgcGxhdGZvcm1OYW1lOiBzdHJpbmdcbn1cbi8qKlxuICpcbiAqIENvbnN1bWVzIHRoZSByZXNvdXJjZXMgdGhhdCBoYXZlIGJlZW4gcHJvZHVjZWQgYnkgUGxhdGZvcm1Qcm9kdWNlci5cbiAqIEluIG90aGVyIHdvcmRzOyB0aGlzIG11c3QgcnVuIGFmdGVyIFBsYXRmb3JtUHJvZHVjZXIuXG4gKlxuICogVXNlZCBmb3IgY29uc3VtaW5nIHRoZSBjb3JlIHJlc291cmNlcywgd2hpY2ggUGxhdGZvcm1Qcm9kdWNlciBjcmVhdGVzIHJlZmVyZW5jZXMgdG8uXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBQbGF0Zm9ybUNvbnN1bWVyIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBwcml2YXRlIHBsYXRmb3JtTmFtZXNwYWNlOiBzdHJpbmdcbiAgcHJpdmF0ZSBwbGF0Zm9ybU5hbWU6IHN0cmluZ1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHNjb3BlOiBjb25zdHJ1Y3RzLkNvbnN0cnVjdCxcbiAgICBpZDogc3RyaW5nLFxuICAgIHByb3BzOiBQbGF0Zm9ybUNvbnN1bWVyUHJvcHMsXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIHRoaXMucGxhdGZvcm1OYW1lc3BhY2UgPSBwcm9wcy5wbGF0Zm9ybU5hbWVzcGFjZVxuXG4gICAgdGhpcy5wbGF0Zm9ybU5hbWUgPSBwcm9wcy5wbGF0Zm9ybU5hbWVcbiAgfVxuXG4gIHByb3RlY3RlZCBsYXp5PFQ+KHByb2R1Y2VyOiAoKSA9PiBUKTogKCkgPT4gVCB7XG4gICAgbGV0IHZhbHVlOiBUIHwgbnVsbCA9IG51bGxcblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBpZiAodmFsdWUgPT0gbnVsbCkge1xuICAgICAgICB2YWx1ZSA9IHByb2R1Y2VyKClcbiAgICAgIH1cbiAgICAgIHJldHVybiB2YWx1ZVxuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBnZXRQYXJhbShuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBzc20uU3RyaW5nUGFyYW1ldGVyLnZhbHVlRm9yU3RyaW5nUGFyYW1ldGVyKFxuICAgICAgdGhpcyxcbiAgICAgIHBhcmFtTmFtZSh0aGlzLnBsYXRmb3JtTmFtZXNwYWNlLCB0aGlzLnBsYXRmb3JtTmFtZSwgbmFtZSksXG4gICAgKVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import * as constructs from "constructs";
|
|
2
|
+
import * as ec2 from "aws-cdk-lib/aws-ec2";
|
|
3
|
+
import * as rds from "aws-cdk-lib/aws-rds";
|
|
4
|
+
import * as sm from "aws-cdk-lib/aws-secretsmanager";
|
|
5
|
+
import * as cdk from "aws-cdk-lib";
|
|
6
|
+
export interface DatabaseProps extends cdk.StackProps {
|
|
7
|
+
vpc: ec2.IVpc;
|
|
8
|
+
engine: rds.IInstanceEngine;
|
|
9
|
+
/**
|
|
10
|
+
* @default master
|
|
11
|
+
*/
|
|
12
|
+
masterUsername?: string;
|
|
13
|
+
/**
|
|
14
|
+
* @default app
|
|
15
|
+
*/
|
|
16
|
+
databaseName?: string;
|
|
17
|
+
/**
|
|
18
|
+
* @default 25
|
|
19
|
+
*/
|
|
20
|
+
allocatedStorageGb?: number;
|
|
21
|
+
instanceType: ec2.InstanceType;
|
|
22
|
+
instanceIdentifier: string;
|
|
23
|
+
/**
|
|
24
|
+
* @default true
|
|
25
|
+
*/
|
|
26
|
+
isMultiAz?: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* Must not be removed once it has been set, as changing this
|
|
29
|
+
* results in a new DB instance being created.
|
|
30
|
+
*
|
|
31
|
+
* Also, remember to give database a new name when changing this prop, or else
|
|
32
|
+
* the new instance name will crash with the existing instance.
|
|
33
|
+
*/
|
|
34
|
+
snapshotIdentifier?: string;
|
|
35
|
+
/**
|
|
36
|
+
* @default false
|
|
37
|
+
*/
|
|
38
|
+
usePublicSubnets?: boolean;
|
|
39
|
+
overrideDbOptions?: Partial<rds.DatabaseInstanceSourceProps>;
|
|
40
|
+
}
|
|
41
|
+
export declare class Database extends constructs.Construct {
|
|
42
|
+
readonly secret: sm.ISecret;
|
|
43
|
+
readonly connections: ec2.Connections;
|
|
44
|
+
readonly databaseInstance: rds.IDatabaseInstance;
|
|
45
|
+
readonly instanceType: ec2.InstanceType;
|
|
46
|
+
readonly allocatedStorage: cdk.Size;
|
|
47
|
+
constructor(scope: constructs.Construct, id: string, props: DatabaseProps);
|
|
48
|
+
allowConnectionFrom(source: ec2.ISecurityGroup): void;
|
|
49
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Database = void 0;
|
|
4
|
+
const constructs = require("constructs");
|
|
5
|
+
const ec2 = require("aws-cdk-lib/aws-ec2");
|
|
6
|
+
const rds = require("aws-cdk-lib/aws-rds");
|
|
7
|
+
const cdk = require("aws-cdk-lib");
|
|
8
|
+
class Database extends constructs.Construct {
|
|
9
|
+
constructor(scope, id, props) {
|
|
10
|
+
var _a, _b, _c, _d;
|
|
11
|
+
super(scope, id);
|
|
12
|
+
const masterUsername = (_a = props.masterUsername) !== null && _a !== void 0 ? _a : "master";
|
|
13
|
+
const databaseName = (_b = props.databaseName) !== null && _b !== void 0 ? _b : "app";
|
|
14
|
+
const secret = new rds.DatabaseSecret(this, "Secret", {
|
|
15
|
+
username: masterUsername,
|
|
16
|
+
});
|
|
17
|
+
const options = {
|
|
18
|
+
engine: props.engine,
|
|
19
|
+
allowMajorVersionUpgrade: true,
|
|
20
|
+
instanceIdentifier: props.instanceIdentifier,
|
|
21
|
+
instanceType: props.instanceType,
|
|
22
|
+
vpc: props.vpc,
|
|
23
|
+
vpcSubnets: props.usePublicSubnets
|
|
24
|
+
? {
|
|
25
|
+
subnetType: ec2.SubnetType.PUBLIC,
|
|
26
|
+
}
|
|
27
|
+
: undefined,
|
|
28
|
+
multiAz: (_c = props.isMultiAz) !== null && _c !== void 0 ? _c : true,
|
|
29
|
+
// We default to 25 GiB storage instead of 100 GiB
|
|
30
|
+
// if we do not specify.
|
|
31
|
+
allocatedStorage: (_d = props.allocatedStorageGb) !== null && _d !== void 0 ? _d : 25,
|
|
32
|
+
// We specify maximum backup retention.
|
|
33
|
+
backupRetention: cdk.Duration.days(35),
|
|
34
|
+
...props.overrideDbOptions,
|
|
35
|
+
};
|
|
36
|
+
this.allocatedStorage = cdk.Size.gibibytes(options.allocatedStorage);
|
|
37
|
+
this.instanceType = options.instanceType;
|
|
38
|
+
const db = props.snapshotIdentifier
|
|
39
|
+
? new rds.DatabaseInstanceFromSnapshot(this, "Resource", {
|
|
40
|
+
...options,
|
|
41
|
+
snapshotIdentifier: props.snapshotIdentifier,
|
|
42
|
+
credentials: rds.SnapshotCredentials.fromSecret(secret),
|
|
43
|
+
})
|
|
44
|
+
: new rds.DatabaseInstance(this, "Resource", {
|
|
45
|
+
...options,
|
|
46
|
+
databaseName,
|
|
47
|
+
credentials: rds.Credentials.fromSecret(secret),
|
|
48
|
+
storageEncrypted: true,
|
|
49
|
+
});
|
|
50
|
+
this.databaseInstance = db;
|
|
51
|
+
this.secret = db.secret;
|
|
52
|
+
this.connections = db.connections;
|
|
53
|
+
db.node.defaultChild.publiclyAccessible = false;
|
|
54
|
+
}
|
|
55
|
+
allowConnectionFrom(source) {
|
|
56
|
+
this.connections.allowDefaultPortFrom(source);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.Database = Database;
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmRzL2RhdGFiYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUF3QztBQUN4QywyQ0FBMEM7QUFDMUMsMkNBQTBDO0FBRTFDLG1DQUFrQztBQXNDbEMsTUFBYSxRQUFTLFNBQVEsVUFBVSxDQUFDLFNBQVM7SUFPaEQsWUFBWSxLQUEyQixFQUFFLEVBQVUsRUFBRSxLQUFvQjs7UUFDdkUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQTtRQUVoQixNQUFNLGNBQWMsR0FBRyxNQUFBLEtBQUssQ0FBQyxjQUFjLG1DQUFJLFFBQVEsQ0FBQTtRQUN2RCxNQUFNLFlBQVksR0FBRyxNQUFBLEtBQUssQ0FBQyxZQUFZLG1DQUFJLEtBQUssQ0FBQTtRQUVoRCxNQUFNLE1BQU0sR0FBRyxJQUFJLEdBQUcsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUNwRCxRQUFRLEVBQUUsY0FBYztTQUN6QixDQUFDLENBQUE7UUFFRixNQUFNLE9BQU8sR0FBb0M7WUFDL0MsTUFBTSxFQUFFLEtBQUssQ0FBQyxNQUFNO1lBQ3BCLHdCQUF3QixFQUFFLElBQUk7WUFDOUIsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLGtCQUFrQjtZQUM1QyxZQUFZLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDaEMsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsVUFBVSxFQUFFLEtBQUssQ0FBQyxnQkFBZ0I7Z0JBQ2hDLENBQUMsQ0FBQztvQkFDRSxVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNO2lCQUNsQztnQkFDSCxDQUFDLENBQUMsU0FBUztZQUNiLE9BQU8sRUFBRSxNQUFBLEtBQUssQ0FBQyxTQUFTLG1DQUFJLElBQUk7WUFDaEMsa0RBQWtEO1lBQ2xELHdCQUF3QjtZQUN4QixnQkFBZ0IsRUFBRSxNQUFBLEtBQUssQ0FBQyxrQkFBa0IsbUNBQUksRUFBRTtZQUNoRCx1Q0FBdUM7WUFDdkMsZUFBZSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUN0QyxHQUFHLEtBQUssQ0FBQyxpQkFBaUI7U0FDM0IsQ0FBQTtRQUNELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsZ0JBQWlCLENBQUMsQ0FBQTtRQUNyRSxJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFhLENBQUE7UUFFekMsTUFBTSxFQUFFLEdBQUcsS0FBSyxDQUFDLGtCQUFrQjtZQUNqQyxDQUFDLENBQUMsSUFBSSxHQUFHLENBQUMsNEJBQTRCLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtnQkFDckQsR0FBRyxPQUFPO2dCQUNWLGtCQUFrQixFQUFFLEtBQUssQ0FBQyxrQkFBa0I7Z0JBQzVDLFdBQVcsRUFBRSxHQUFHLENBQUMsbUJBQW1CLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQzthQUN4RCxDQUFDO1lBQ0osQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7Z0JBQ3pDLEdBQUcsT0FBTztnQkFDVixZQUFZO2dCQUNaLFdBQVcsRUFBRSxHQUFHLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUM7Z0JBQy9DLGdCQUFnQixFQUFFLElBQUk7YUFDdkIsQ0FBQyxDQUFBO1FBRU4sSUFBSSxDQUFDLGdCQUFnQixHQUFHLEVBQUUsQ0FBQTtRQUUxQixJQUFJLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQyxNQUFPLENBQUE7UUFDeEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxFQUFFLENBQUMsV0FBVyxDQUloQztRQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBa0MsQ0FBQyxrQkFBa0IsR0FBRyxLQUFLLENBQUE7SUFDekUsQ0FBQztJQUVNLG1CQUFtQixDQUFDLE1BQTBCO1FBQ25ELElBQUksQ0FBQyxXQUFXLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDL0MsQ0FBQztDQUNGO0FBakVELDRCQWlFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNvbnN0cnVjdHMgZnJvbSBcImNvbnN0cnVjdHNcIlxuaW1wb3J0ICogYXMgZWMyIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWMyXCJcbmltcG9ydCAqIGFzIHJkcyBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXJkc1wiXG5pbXBvcnQgKiBhcyBzbSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXNlY3JldHNtYW5hZ2VyXCJcbmltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIlxuXG5leHBvcnQgaW50ZXJmYWNlIERhdGFiYXNlUHJvcHMgZXh0ZW5kcyBjZGsuU3RhY2tQcm9wcyB7XG4gIHZwYzogZWMyLklWcGNcbiAgZW5naW5lOiByZHMuSUluc3RhbmNlRW5naW5lXG4gIC8qKlxuICAgKiBAZGVmYXVsdCBtYXN0ZXJcbiAgICovXG4gIG1hc3RlclVzZXJuYW1lPzogc3RyaW5nXG4gIC8qKlxuICAgKiBAZGVmYXVsdCBhcHBcbiAgICovXG4gIGRhdGFiYXNlTmFtZT86IHN0cmluZ1xuICAvKipcbiAgICogQGRlZmF1bHQgMjVcbiAgICovXG4gIGFsbG9jYXRlZFN0b3JhZ2VHYj86IG51bWJlclxuICBpbnN0YW5jZVR5cGU6IGVjMi5JbnN0YW5jZVR5cGVcbiAgaW5zdGFuY2VJZGVudGlmaWVyOiBzdHJpbmdcbiAgLyoqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIGlzTXVsdGlBej86IGJvb2xlYW5cbiAgLyoqXG4gICAqIE11c3Qgbm90IGJlIHJlbW92ZWQgb25jZSBpdCBoYXMgYmVlbiBzZXQsIGFzIGNoYW5naW5nIHRoaXNcbiAgICogcmVzdWx0cyBpbiBhIG5ldyBEQiBpbnN0YW5jZSBiZWluZyBjcmVhdGVkLlxuICAgKlxuICAgKiBBbHNvLCByZW1lbWJlciB0byBnaXZlIGRhdGFiYXNlIGEgbmV3IG5hbWUgd2hlbiBjaGFuZ2luZyB0aGlzIHByb3AsIG9yIGVsc2VcbiAgICogdGhlIG5ldyBpbnN0YW5jZSBuYW1lIHdpbGwgY3Jhc2ggd2l0aCB0aGUgZXhpc3RpbmcgaW5zdGFuY2UuXG4gICAqL1xuICBzbmFwc2hvdElkZW50aWZpZXI/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICB1c2VQdWJsaWNTdWJuZXRzPzogYm9vbGVhblxuICBvdmVycmlkZURiT3B0aW9ucz86IFBhcnRpYWw8cmRzLkRhdGFiYXNlSW5zdGFuY2VTb3VyY2VQcm9wcz5cbn1cblxuZXhwb3J0IGNsYXNzIERhdGFiYXNlIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgc2VjcmV0OiBzbS5JU2VjcmV0XG4gIHB1YmxpYyByZWFkb25seSBjb25uZWN0aW9uczogZWMyLkNvbm5lY3Rpb25zXG4gIHB1YmxpYyByZWFkb25seSBkYXRhYmFzZUluc3RhbmNlOiByZHMuSURhdGFiYXNlSW5zdGFuY2VcbiAgcHVibGljIHJlYWRvbmx5IGluc3RhbmNlVHlwZTogZWMyLkluc3RhbmNlVHlwZVxuICBwdWJsaWMgcmVhZG9ubHkgYWxsb2NhdGVkU3RvcmFnZTogY2RrLlNpemVcblxuICBjb25zdHJ1Y3RvcihzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBEYXRhYmFzZVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKVxuXG4gICAgY29uc3QgbWFzdGVyVXNlcm5hbWUgPSBwcm9wcy5tYXN0ZXJVc2VybmFtZSA/PyBcIm1hc3RlclwiXG4gICAgY29uc3QgZGF0YWJhc2VOYW1lID0gcHJvcHMuZGF0YWJhc2VOYW1lID8/IFwiYXBwXCJcblxuICAgIGNvbnN0IHNlY3JldCA9IG5ldyByZHMuRGF0YWJhc2VTZWNyZXQodGhpcywgXCJTZWNyZXRcIiwge1xuICAgICAgdXNlcm5hbWU6IG1hc3RlclVzZXJuYW1lLFxuICAgIH0pXG5cbiAgICBjb25zdCBvcHRpb25zOiByZHMuRGF0YWJhc2VJbnN0YW5jZVNvdXJjZVByb3BzID0ge1xuICAgICAgZW5naW5lOiBwcm9wcy5lbmdpbmUsXG4gICAgICBhbGxvd01ham9yVmVyc2lvblVwZ3JhZGU6IHRydWUsXG4gICAgICBpbnN0YW5jZUlkZW50aWZpZXI6IHByb3BzLmluc3RhbmNlSWRlbnRpZmllcixcbiAgICAgIGluc3RhbmNlVHlwZTogcHJvcHMuaW5zdGFuY2VUeXBlLFxuICAgICAgdnBjOiBwcm9wcy52cGMsXG4gICAgICB2cGNTdWJuZXRzOiBwcm9wcy51c2VQdWJsaWNTdWJuZXRzXG4gICAgICAgID8ge1xuICAgICAgICAgICAgc3VibmV0VHlwZTogZWMyLlN1Ym5ldFR5cGUuUFVCTElDLFxuICAgICAgICAgIH1cbiAgICAgICAgOiB1bmRlZmluZWQsXG4gICAgICBtdWx0aUF6OiBwcm9wcy5pc011bHRpQXogPz8gdHJ1ZSxcbiAgICAgIC8vIFdlIGRlZmF1bHQgdG8gMjUgR2lCIHN0b3JhZ2UgaW5zdGVhZCBvZiAxMDAgR2lCXG4gICAgICAvLyBpZiB3ZSBkbyBub3Qgc3BlY2lmeS5cbiAgICAgIGFsbG9jYXRlZFN0b3JhZ2U6IHByb3BzLmFsbG9jYXRlZFN0b3JhZ2VHYiA/PyAyNSxcbiAgICAgIC8vIFdlIHNwZWNpZnkgbWF4aW11bSBiYWNrdXAgcmV0ZW50aW9uLlxuICAgICAgYmFja3VwUmV0ZW50aW9uOiBjZGsuRHVyYXRpb24uZGF5cygzNSksXG4gICAgICAuLi5wcm9wcy5vdmVycmlkZURiT3B0aW9ucyxcbiAgICB9XG4gICAgdGhpcy5hbGxvY2F0ZWRTdG9yYWdlID0gY2RrLlNpemUuZ2liaWJ5dGVzKG9wdGlvbnMuYWxsb2NhdGVkU3RvcmFnZSEpXG4gICAgdGhpcy5pbnN0YW5jZVR5cGUgPSBvcHRpb25zLmluc3RhbmNlVHlwZSFcblxuICAgIGNvbnN0IGRiID0gcHJvcHMuc25hcHNob3RJZGVudGlmaWVyXG4gICAgICA/IG5ldyByZHMuRGF0YWJhc2VJbnN0YW5jZUZyb21TbmFwc2hvdCh0aGlzLCBcIlJlc291cmNlXCIsIHtcbiAgICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgICAgIHNuYXBzaG90SWRlbnRpZmllcjogcHJvcHMuc25hcHNob3RJZGVudGlmaWVyLFxuICAgICAgICAgIGNyZWRlbnRpYWxzOiByZHMuU25hcHNob3RDcmVkZW50aWFscy5mcm9tU2VjcmV0KHNlY3JldCksXG4gICAgICAgIH0pXG4gICAgICA6IG5ldyByZHMuRGF0YWJhc2VJbnN0YW5jZSh0aGlzLCBcIlJlc291cmNlXCIsIHtcbiAgICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgICAgIGRhdGFiYXNlTmFtZSxcbiAgICAgICAgICBjcmVkZW50aWFsczogcmRzLkNyZWRlbnRpYWxzLmZyb21TZWNyZXQoc2VjcmV0KSxcbiAgICAgICAgICBzdG9yYWdlRW5jcnlwdGVkOiB0cnVlLFxuICAgICAgICB9KVxuXG4gICAgdGhpcy5kYXRhYmFzZUluc3RhbmNlID0gZGJcblxuICAgIHRoaXMuc2VjcmV0ID0gZGIuc2VjcmV0IVxuICAgIHRoaXMuY29ubmVjdGlvbnMgPSBkYi5jb25uZWN0aW9uc1xuXG4gICAgLy8gT3ZlcnJpZGUgaW4gY2FzZSB3ZSBoYXZlIHBsYWNlZCBpdCBpbiBhIHB1YmxpYyBzdWJuZXQuXG4gICAgLy8gSXQgd291bGQgZGVmYXVsdCB0byBiZWluZyBwdWJsaWMgYWNjZXNzaWJsZSB3aGljaCB3ZSBkbyBub3Qgd2FudC5cbiAgICA7KGRiLm5vZGUuZGVmYXVsdENoaWxkIGFzIHJkcy5DZm5EQkluc3RhbmNlKS5wdWJsaWNseUFjY2Vzc2libGUgPSBmYWxzZVxuICB9XG5cbiAgcHVibGljIGFsbG93Q29ubmVjdGlvbkZyb20oc291cmNlOiBlYzIuSVNlY3VyaXR5R3JvdXApOiB2b2lkIHtcbiAgICB0aGlzLmNvbm5lY3Rpb25zLmFsbG93RGVmYXVsdFBvcnRGcm9tKHNvdXJjZSlcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Database, DatabaseProps } from "./database";
|
package/lib/rds/index.js
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Database = void 0;
|
|
4
|
+
var database_1 = require("./database");
|
|
5
|
+
Object.defineProperty(exports, "Database", { enumerable: true, get: function () { return database_1.Database; } });
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHVDQUFvRDtBQUEzQyxvR0FBQSxRQUFRLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEYXRhYmFzZSwgRGF0YWJhc2VQcm9wcyB9IGZyb20gXCIuL2RhdGFiYXNlXCJcbiJdfQ==
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import * as constructs from "constructs";
|
|
2
|
+
export type TlsPolicy = "Require" | "Optional";
|
|
3
|
+
export interface ConfigurationSetDeliveryOptionsProps {
|
|
4
|
+
/**
|
|
5
|
+
* The name of an existing SES configuration set to update delivery options on
|
|
6
|
+
*/
|
|
7
|
+
configurationSetName: string;
|
|
8
|
+
/**
|
|
9
|
+
* The TLS policy for outgoing emails
|
|
10
|
+
*
|
|
11
|
+
* Setting this to "Require" will make mail delivery fail if SES cannot
|
|
12
|
+
* establish a TLS-encrypted connection to the receiving mail server.
|
|
13
|
+
*/
|
|
14
|
+
tlsPolicy: TlsPolicy;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Set Delivery Options for a SES Configuration Set.
|
|
18
|
+
*
|
|
19
|
+
* Currently the only delivery option that can be set is the TLS Policy, which
|
|
20
|
+
* can be set to either "Require" or "Optional". If set to "Require" SES
|
|
21
|
+
* will refuse to deliver mail to mail servers it cannot connect to using
|
|
22
|
+
* an encrypted connection.
|
|
23
|
+
*/
|
|
24
|
+
export declare class ConfigurationSetDeliveryOptions extends constructs.Construct {
|
|
25
|
+
constructor(scope: constructs.Construct, id: string, props: ConfigurationSetDeliveryOptionsProps);
|
|
26
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConfigurationSetDeliveryOptions = void 0;
|
|
4
|
+
const constructs = require("constructs");
|
|
5
|
+
const cr = require("aws-cdk-lib/custom-resources");
|
|
6
|
+
const iam = require("aws-cdk-lib/aws-iam");
|
|
7
|
+
/**
|
|
8
|
+
* Set Delivery Options for a SES Configuration Set.
|
|
9
|
+
*
|
|
10
|
+
* Currently the only delivery option that can be set is the TLS Policy, which
|
|
11
|
+
* can be set to either "Require" or "Optional". If set to "Require" SES
|
|
12
|
+
* will refuse to deliver mail to mail servers it cannot connect to using
|
|
13
|
+
* an encrypted connection.
|
|
14
|
+
*/
|
|
15
|
+
class ConfigurationSetDeliveryOptions extends constructs.Construct {
|
|
16
|
+
constructor(scope, id, props) {
|
|
17
|
+
super(scope, id);
|
|
18
|
+
new cr.AwsCustomResource(this, "Resource", {
|
|
19
|
+
policy: cr.AwsCustomResourcePolicy.fromStatements([
|
|
20
|
+
new iam.PolicyStatement({
|
|
21
|
+
actions: ["ses:PutConfigurationSetDeliveryOptions"],
|
|
22
|
+
resources: ["*"],
|
|
23
|
+
}),
|
|
24
|
+
]),
|
|
25
|
+
// Handles both onCreate and onUpdate
|
|
26
|
+
onUpdate: {
|
|
27
|
+
service: "SES",
|
|
28
|
+
action: "putConfigurationSetDeliveryOptions",
|
|
29
|
+
parameters: {
|
|
30
|
+
ConfigurationSetName: props.configurationSetName,
|
|
31
|
+
DeliveryOptions: {
|
|
32
|
+
TlsPolicy: props.tlsPolicy,
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
physicalResourceId: cr.PhysicalResourceId.of(props.configurationSetName),
|
|
36
|
+
},
|
|
37
|
+
onDelete: {
|
|
38
|
+
service: "SES",
|
|
39
|
+
action: "putConfigurationSetDeliveryOptions",
|
|
40
|
+
parameters: {
|
|
41
|
+
ConfigurationSetName: props.configurationSetName,
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
exports.ConfigurationSetDeliveryOptions = ConfigurationSetDeliveryOptions;
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VzL2NvbmZpZ3VyYXRpb25zZXRkZWxpdmVyeW9wdGlvbnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUNBQXdDO0FBQ3hDLG1EQUFrRDtBQUNsRCwyQ0FBMEM7QUFrQjFDOzs7Ozs7O0dBT0c7QUFDSCxNQUFhLCtCQUFnQyxTQUFRLFVBQVUsQ0FBQyxTQUFTO0lBQ3ZFLFlBQ0UsS0FBMkIsRUFDM0IsRUFBVSxFQUNWLEtBQTJDO1FBRTNDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7UUFFaEIsSUFBSSxFQUFFLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUN6QyxNQUFNLEVBQUUsRUFBRSxDQUFDLHVCQUF1QixDQUFDLGNBQWMsQ0FBQztnQkFDaEQsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDO29CQUN0QixPQUFPLEVBQUUsQ0FBQyx3Q0FBd0MsQ0FBQztvQkFDbkQsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDO2lCQUNqQixDQUFDO2FBQ0gsQ0FBQztZQUNGLHFDQUFxQztZQUNyQyxRQUFRLEVBQUU7Z0JBQ1IsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsTUFBTSxFQUFFLG9DQUFvQztnQkFDNUMsVUFBVSxFQUFFO29CQUNWLG9CQUFvQixFQUFFLEtBQUssQ0FBQyxvQkFBb0I7b0JBQ2hELGVBQWUsRUFBRTt3QkFDZixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7cUJBQzNCO2lCQUNGO2dCQUNELGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQzFDLEtBQUssQ0FBQyxvQkFBb0IsQ0FDM0I7YUFDRjtZQUNELFFBQVEsRUFBRTtnQkFDUixPQUFPLEVBQUUsS0FBSztnQkFDZCxNQUFNLEVBQUUsb0NBQW9DO2dCQUM1QyxVQUFVLEVBQUU7b0JBQ1Ysb0JBQW9CLEVBQUUsS0FBSyxDQUFDLG9CQUFvQjtpQkFDakQ7YUFDRjtTQUNGLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRjtBQXRDRCwwRUFzQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjb25zdHJ1Y3RzIGZyb20gXCJjb25zdHJ1Y3RzXCJcbmltcG9ydCAqIGFzIGNyIGZyb20gXCJhd3MtY2RrLWxpYi9jdXN0b20tcmVzb3VyY2VzXCJcbmltcG9ydCAqIGFzIGlhbSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWlhbVwiXG5cbmV4cG9ydCB0eXBlIFRsc1BvbGljeSA9IFwiUmVxdWlyZVwiIHwgXCJPcHRpb25hbFwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlndXJhdGlvblNldERlbGl2ZXJ5T3B0aW9uc1Byb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIGFuIGV4aXN0aW5nIFNFUyBjb25maWd1cmF0aW9uIHNldCB0byB1cGRhdGUgZGVsaXZlcnkgb3B0aW9ucyBvblxuICAgKi9cbiAgY29uZmlndXJhdGlvblNldE5hbWU6IHN0cmluZ1xuICAvKipcbiAgICogVGhlIFRMUyBwb2xpY3kgZm9yIG91dGdvaW5nIGVtYWlsc1xuICAgKlxuICAgKiBTZXR0aW5nIHRoaXMgdG8gXCJSZXF1aXJlXCIgd2lsbCBtYWtlIG1haWwgZGVsaXZlcnkgZmFpbCBpZiBTRVMgY2Fubm90XG4gICAqIGVzdGFibGlzaCBhIFRMUy1lbmNyeXB0ZWQgY29ubmVjdGlvbiB0byB0aGUgcmVjZWl2aW5nIG1haWwgc2VydmVyLlxuICAgKi9cbiAgdGxzUG9saWN5OiBUbHNQb2xpY3lcbn1cblxuLyoqXG4gKiBTZXQgRGVsaXZlcnkgT3B0aW9ucyBmb3IgYSBTRVMgQ29uZmlndXJhdGlvbiBTZXQuXG4gKlxuICogQ3VycmVudGx5IHRoZSBvbmx5IGRlbGl2ZXJ5IG9wdGlvbiB0aGF0IGNhbiBiZSBzZXQgaXMgdGhlIFRMUyBQb2xpY3ksIHdoaWNoXG4gKiBjYW4gYmUgc2V0IHRvIGVpdGhlciBcIlJlcXVpcmVcIiBvciBcIk9wdGlvbmFsXCIuIElmIHNldCB0byBcIlJlcXVpcmVcIiBTRVNcbiAqIHdpbGwgcmVmdXNlIHRvIGRlbGl2ZXIgbWFpbCB0byBtYWlsIHNlcnZlcnMgaXQgY2Fubm90IGNvbm5lY3QgdG8gdXNpbmdcbiAqIGFuIGVuY3J5cHRlZCBjb25uZWN0aW9uLlxuICovXG5leHBvcnQgY2xhc3MgQ29uZmlndXJhdGlvblNldERlbGl2ZXJ5T3B0aW9ucyBleHRlbmRzIGNvbnN0cnVjdHMuQ29uc3RydWN0IHtcbiAgY29uc3RydWN0b3IoXG4gICAgc2NvcGU6IGNvbnN0cnVjdHMuQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IENvbmZpZ3VyYXRpb25TZXREZWxpdmVyeU9wdGlvbnNQcm9wcyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKVxuXG4gICAgbmV3IGNyLkF3c0N1c3RvbVJlc291cmNlKHRoaXMsIFwiUmVzb3VyY2VcIiwge1xuICAgICAgcG9saWN5OiBjci5Bd3NDdXN0b21SZXNvdXJjZVBvbGljeS5mcm9tU3RhdGVtZW50cyhbXG4gICAgICAgIG5ldyBpYW0uUG9saWN5U3RhdGVtZW50KHtcbiAgICAgICAgICBhY3Rpb25zOiBbXCJzZXM6UHV0Q29uZmlndXJhdGlvblNldERlbGl2ZXJ5T3B0aW9uc1wiXSxcbiAgICAgICAgICByZXNvdXJjZXM6IFtcIipcIl0sXG4gICAgICAgIH0pLFxuICAgICAgXSksXG4gICAgICAvLyBIYW5kbGVzIGJvdGggb25DcmVhdGUgYW5kIG9uVXBkYXRlXG4gICAgICBvblVwZGF0ZToge1xuICAgICAgICBzZXJ2aWNlOiBcIlNFU1wiLFxuICAgICAgICBhY3Rpb246IFwicHV0Q29uZmlndXJhdGlvblNldERlbGl2ZXJ5T3B0aW9uc1wiLFxuICAgICAgICBwYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgQ29uZmlndXJhdGlvblNldE5hbWU6IHByb3BzLmNvbmZpZ3VyYXRpb25TZXROYW1lLFxuICAgICAgICAgIERlbGl2ZXJ5T3B0aW9uczoge1xuICAgICAgICAgICAgVGxzUG9saWN5OiBwcm9wcy50bHNQb2xpY3ksXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcGh5c2ljYWxSZXNvdXJjZUlkOiBjci5QaHlzaWNhbFJlc291cmNlSWQub2YoXG4gICAgICAgICAgcHJvcHMuY29uZmlndXJhdGlvblNldE5hbWUsXG4gICAgICAgICksXG4gICAgICB9LFxuICAgICAgb25EZWxldGU6IHtcbiAgICAgICAgc2VydmljZTogXCJTRVNcIixcbiAgICAgICAgYWN0aW9uOiBcInB1dENvbmZpZ3VyYXRpb25TZXREZWxpdmVyeU9wdGlvbnNcIixcbiAgICAgICAgcGFyYW1ldGVyczoge1xuICAgICAgICAgIENvbmZpZ3VyYXRpb25TZXROYW1lOiBwcm9wcy5jb25maWd1cmF0aW9uU2V0TmFtZSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSlcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
interface ResourceProps {
|
|
2
|
+
ConfigurationSetName: string;
|
|
3
|
+
EventDestinationName: string;
|
|
4
|
+
SnsTopicArn: string;
|
|
5
|
+
MatchingEventTypes: string[];
|
|
6
|
+
}
|
|
7
|
+
type OnEventHandler = (event: {
|
|
8
|
+
PhysicalResourceId?: string;
|
|
9
|
+
RequestType: "Create" | "Update" | "Delete";
|
|
10
|
+
ResourceProperties: ResourceProps;
|
|
11
|
+
OldResourceProperties?: ResourceProps;
|
|
12
|
+
}) => Promise<{
|
|
13
|
+
PhysicalResourceId?: string;
|
|
14
|
+
Data?: Record<string, any>;
|
|
15
|
+
}>;
|
|
16
|
+
export declare const configurationSetSnsDestinationHandler: OnEventHandler;
|
|
17
|
+
export {};
|