@liflig/cdk 2.23.1 → 2.25.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/alarms/database-alarms.js +29 -30
- package/lib/alarms/index.d.ts +6 -3
- package/lib/alarms/index.js +4 -10
- package/lib/alarms/service-alarms.js +38 -38
- package/lib/alarms/ses-alarms.js +16 -20
- package/lib/alarms/slack-alarm.js +18 -17
- package/lib/bastion-host.js +12 -15
- package/lib/bin/cdk-create-snapshots.js +3 -5
- package/lib/bin/fetch-pipeline-variables.js +4 -6
- package/lib/build-artifacts/github-actions-role.js +9 -14
- package/lib/build-artifacts/index.js +25 -26
- package/lib/cdk-pipelines/cloud-assembly-lookup-handler.js +13 -17
- package/lib/cdk-pipelines/index.d.ts +4 -2
- package/lib/cdk-pipelines/index.js +4 -10
- package/lib/cdk-pipelines/liflig-cdk-pipeline.js +29 -24
- package/lib/cdk-pipelines/slack-notification.js +12 -14
- package/lib/cdk-pipelines/variables.js +12 -18
- package/lib/cloudtrail-slack-integration/cloudtrail-slack-integration.js +16 -17
- package/lib/cloudtrail-slack-integration/index.d.ts +2 -1
- package/lib/cloudtrail-slack-integration/index.js +2 -6
- package/lib/configure-parameters/configure-parameters.js +12 -11
- package/lib/configure-parameters/index.d.ts +2 -1
- package/lib/configure-parameters/index.js +2 -6
- package/lib/cross-region-ssm-parameter.js +4 -8
- package/lib/ecs/cluster.js +11 -13
- package/lib/ecs/fargate-service.js +25 -25
- package/lib/ecs/index.d.ts +6 -3
- package/lib/ecs/index.js +4 -10
- package/lib/ecs/listener-rule.js +13 -10
- package/lib/feature-flags.js +5 -10
- package/lib/hosted-zone-with-param.js +15 -16
- package/lib/index.js +22 -56
- package/lib/kinesis/index.d.ts +2 -1
- package/lib/kinesis/index.js +2 -6
- package/lib/kinesis/kinesis-to-datadog-stream.js +11 -15
- package/lib/load-balancer/index.d.ts +2 -1
- package/lib/load-balancer/index.js +2 -6
- package/lib/load-balancer/load-balancer.js +12 -13
- package/lib/platform/index.d.ts +2 -1
- package/lib/platform/index.js +2 -7
- package/lib/platform/platform.js +9 -10
- package/lib/rds/database.js +15 -15
- package/lib/rds/index.d.ts +2 -1
- package/lib/rds/index.js +2 -6
- package/lib/ses/configurationsetdeliveryoptions/index.js +5 -9
- package/lib/ses/configurationsetsnsdestination/handler.js +8 -12
- package/lib/ses/configurationsetsnsdestination/index.js +22 -19
- package/lib/ses/index.d.ts +2 -1
- package/lib/ses/index.js +5 -12
- package/lib/ses/sesdomain/handler.js +11 -16
- package/lib/ses/sesdomain/index.js +24 -19
- package/lib/ses/sesverifyemail/handler.js +6 -10
- package/lib/ses/sesverifyemail/index.js +19 -14
- package/lib/snapshots.js +13 -19
- package/lib/ssm-parameter-backed-resource.js +15 -15
- package/lib/ssm-parameter-reader.js +5 -10
- package/lib/tags.js +4 -7
- package/lib/utils.js +3 -6
- package/lib/webapp/index.d.ts +2 -1
- package/lib/webapp/index.js +4 -10
- package/lib/webapp/monitor.js +32 -33
- package/lib/webapp/security-headers.js +7 -11
- package/lib/webapp/webapp.js +20 -22
- package/lib/webapp-deploy-via-role.js +7 -11
- package/package.json +29 -25
package/lib/alarms/ses-alarms.js
CHANGED
|
@@ -1,49 +1,45 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const cdk = require("aws-cdk-lib");
|
|
5
|
-
const cloudwatch = require("aws-cdk-lib/aws-cloudwatch");
|
|
6
|
-
const constructs = require("constructs");
|
|
1
|
+
import * as cdk from "aws-cdk-lib";
|
|
2
|
+
import * as cloudwatch from "aws-cdk-lib/aws-cloudwatch";
|
|
3
|
+
import * as constructs from "constructs";
|
|
7
4
|
/**
|
|
8
5
|
*
|
|
9
6
|
* Construct that configures various sensible CloudWatch alarms for AWS SES
|
|
10
7
|
*/
|
|
11
|
-
class SesAlarms extends constructs.Construct {
|
|
8
|
+
export class SesAlarms extends constructs.Construct {
|
|
9
|
+
action;
|
|
12
10
|
constructor(scope, id, props) {
|
|
13
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
|
|
14
11
|
super(scope, id);
|
|
15
12
|
this.action = props.action;
|
|
16
13
|
const bouncedMessagesAlarm = new cloudwatch.Metric({
|
|
17
14
|
metricName: "Reputation.BounceRate",
|
|
18
15
|
namespace: "AWS/SES",
|
|
19
16
|
statistic: "Maximum",
|
|
20
|
-
period:
|
|
17
|
+
period: props?.bouncedMessagesAlarm?.period ?? cdk.Duration.minutes(10),
|
|
21
18
|
}).createAlarm(this, "BouncedMessagesAlarm", {
|
|
22
|
-
alarmDescription: `The SES bounce rate is over ${
|
|
19
|
+
alarmDescription: `The SES bounce rate is over ${props?.bouncedMessagesAlarm?.threshold ?? 2.5}%`,
|
|
23
20
|
comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,
|
|
24
21
|
evaluationPeriods: 1,
|
|
25
22
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
26
|
-
threshold: (
|
|
23
|
+
threshold: (props?.bouncedMessagesAlarm?.threshold ?? 2.5) / 100,
|
|
27
24
|
});
|
|
28
|
-
if (
|
|
29
|
-
bouncedMessagesAlarm.addAlarmAction(
|
|
25
|
+
if (props?.bouncedMessagesAlarm?.enabled ?? true) {
|
|
26
|
+
bouncedMessagesAlarm.addAlarmAction(props?.bouncedMessagesAlarm?.action || this.action);
|
|
30
27
|
}
|
|
31
28
|
const complaintMessagesAlarm = new cloudwatch.Metric({
|
|
32
29
|
metricName: "Reputation.ComplaintRate",
|
|
33
30
|
namespace: "AWS/SES",
|
|
34
31
|
statistic: "Maximum",
|
|
35
|
-
period:
|
|
32
|
+
period: props?.complaintRateAlarm?.period ?? cdk.Duration.minutes(10),
|
|
36
33
|
}).createAlarm(this, "ComplaintMessagesAlarm", {
|
|
37
|
-
alarmDescription: `The SES complaint rate is over ${
|
|
34
|
+
alarmDescription: `The SES complaint rate is over ${props?.complaintRateAlarm?.threshold ?? 0.05}%`,
|
|
38
35
|
comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,
|
|
39
36
|
evaluationPeriods: 1,
|
|
40
|
-
threshold: (
|
|
37
|
+
threshold: (props?.complaintRateAlarm?.threshold ?? 0.05) / 100,
|
|
41
38
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
42
39
|
});
|
|
43
|
-
if (
|
|
44
|
-
complaintMessagesAlarm.addAlarmAction(
|
|
40
|
+
if (props?.complaintRateAlarm?.enabled ?? true) {
|
|
41
|
+
complaintMessagesAlarm.addAlarmAction(props?.complaintRateAlarm?.action || this.action);
|
|
45
42
|
}
|
|
46
43
|
}
|
|
47
44
|
}
|
|
48
|
-
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VzLWFsYXJtcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hbGFybXMvc2VzLWFsYXJtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBa0M7QUFDbEMseURBQXdEO0FBQ3hELHlDQUF3QztBQTJEeEM7OztHQUdHO0FBQ0gsTUFBYSxTQUFVLFNBQVEsVUFBVSxDQUFDLFNBQVM7SUFHakQsWUFBWSxLQUEyQixFQUFFLEVBQVUsRUFBRSxLQUFxQjs7UUFDeEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQTtRQUVoQixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUE7UUFFMUIsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUM7WUFDakQsVUFBVSxFQUFFLHVCQUF1QjtZQUNuQyxTQUFTLEVBQUUsU0FBUztZQUNwQixTQUFTLEVBQUUsU0FBUztZQUNwQixNQUFNLEVBQUUsTUFBQSxNQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxvQkFBb0IsMENBQUUsTUFBTSxtQ0FBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7U0FDeEUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsc0JBQXNCLEVBQUU7WUFDM0MsZ0JBQWdCLEVBQUUsK0JBQ2hCLE1BQUEsTUFBQSxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsb0JBQW9CLDBDQUFFLFNBQVMsbUNBQUksR0FDNUMsR0FBRztZQUNILGtCQUFrQixFQUFFLFVBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDeEUsaUJBQWlCLEVBQUUsQ0FBQztZQUNwQixnQkFBZ0IsRUFBRSxVQUFVLENBQUMsZ0JBQWdCLENBQUMsTUFBTTtZQUNwRCxTQUFTLEVBQUUsQ0FBQyxNQUFBLE1BQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLG9CQUFvQiwwQ0FBRSxTQUFTLG1DQUFJLEdBQUcsQ0FBQyxHQUFHLEdBQUc7U0FDakUsQ0FBQyxDQUFBO1FBRUYsSUFBSSxNQUFBLE1BQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLG9CQUFvQiwwQ0FBRSxPQUFPLG1DQUFJLElBQUksRUFBRSxDQUFDO1lBQ2pELG9CQUFvQixDQUFDLGNBQWMsQ0FDakMsQ0FBQSxNQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxvQkFBb0IsMENBQUUsTUFBTSxLQUFJLElBQUksQ0FBQyxNQUFNLENBQ25ELENBQUE7UUFDSCxDQUFDO1FBRUQsTUFBTSxzQkFBc0IsR0FBRyxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUM7WUFDbkQsVUFBVSxFQUFFLDBCQUEwQjtZQUN0QyxTQUFTLEVBQUUsU0FBUztZQUNwQixTQUFTLEVBQUUsU0FBUztZQUNwQixNQUFNLEVBQUUsTUFBQSxNQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxrQkFBa0IsMENBQUUsTUFBTSxtQ0FBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7U0FDdEUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsd0JBQXdCLEVBQUU7WUFDN0MsZ0JBQWdCLEVBQUUsa0NBQ2hCLE1BQUEsTUFBQSxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsa0JBQWtCLDBDQUFFLFNBQVMsbUNBQUksSUFDMUMsR0FBRztZQUNILGtCQUFrQixFQUFFLFVBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDeEUsaUJBQWlCLEVBQUUsQ0FBQztZQUNwQixTQUFTLEVBQUUsQ0FBQyxNQUFBLE1BQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLGtCQUFrQiwwQ0FBRSxTQUFTLG1DQUFJLElBQUksQ0FBQyxHQUFHLEdBQUc7WUFDL0QsZ0JBQWdCLEVBQUUsVUFBVSxDQUFDLGdCQUFnQixDQUFDLE1BQU07U0FDckQsQ0FBQyxDQUFBO1FBRUYsSUFBSSxNQUFBLE1BQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLGtCQUFrQiwwQ0FBRSxPQUFPLG1DQUFJLElBQUksRUFBRSxDQUFDO1lBQy9DLHNCQUFzQixDQUFDLGNBQWMsQ0FDbkMsQ0FBQSxNQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxrQkFBa0IsMENBQUUsTUFBTSxLQUFJLElBQUksQ0FBQyxNQUFNLENBQ2pELENBQUE7UUFDSCxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBbERELDhCQWtEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIlxuaW1wb3J0ICogYXMgY2xvdWR3YXRjaCBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2hcIlxuaW1wb3J0ICogYXMgY29uc3RydWN0cyBmcm9tIFwiY29uc3RydWN0c1wiXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VzQWxhcm1zUHJvcHMgZXh0ZW5kcyBjZGsuU3RhY2tQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXNcbiAgICovXG4gIGFjdGlvbjogY2xvdWR3YXRjaC5JQWxhcm1BY3Rpb25cbiAgLyoqXG4gICAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIGFsYXJtIGZvciBoaWdoIHJhdGUgYm91bmNlZCBtZXNzYWdlcy5cbiAgICpcbiAgICogQGRlZmF1bHQgQ29uZmlndXJlZCB3aXRoIHJlYXNvbmFibGUgZGVmYXVsdHMuXG4gICAqL1xuICBib3VuY2VkTWVzc2FnZXNBbGFybT86IHtcbiAgICAvKipcbiAgICAgKiBAZGVmYXVsdCB0cnVlXG4gICAgICovXG4gICAgZW5hYmxlZD86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBBbiBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXMgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBhY3Rpb25cbiAgICAgKi9cbiAgICBhY3Rpb24/OiBjbG91ZHdhdGNoLklBbGFybUFjdGlvblxuICAgIC8qKlxuICAgICAqIEBkZWZhdWx0IDEwIG1pbnV0ZXNcbiAgICAgKi9cbiAgICBwZXJpb2Q/OiBjZGsuRHVyYXRpb25cbiAgICAvKipcbiAgICAgKiBUaHJlc2hvbGQgdmFsdWUgZm9yIGFsYXJtIGFzIGEgcGVyY2VudFxuICAgICAqIEBkZWZhdWx0IDIuNSglKVxuICAgICAqIDUlIGlzIHRoZSB0aHJlc2hvbGQgYXQgd2hpY2ggQVdTIGNvbnNpZGVycyBwdXR0aW5nIGFuIGFjY291bnQgdW5kZXIgcmV2aWV3XG4gICAgICovXG4gICAgdGhyZXNob2xkPzogbnVtYmVyXG4gIH1cbiAgLyoqXG4gICAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIGFsYXJtIGZvciBoaWdoIGNvbXBsYWludCByYXRlLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDb25maWd1cmVkIHdpdGggc2FuZSBkZWZhdWx0cy5cbiAgICovXG4gIGNvbXBsYWludFJhdGVBbGFybT86IHtcbiAgICAvKipcbiAgICAgKiBAZGVmYXVsdCB0cnVlXG4gICAgICovXG4gICAgZW5hYmxlZD86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBBbiBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXMgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBhY3Rpb25cbiAgICAgKi9cbiAgICBhY3Rpb24/OiBjbG91ZHdhdGNoLklBbGFybUFjdGlvblxuICAgIC8qKlxuICAgICAqIEBkZWZhdWx0IDEwIG1pbnV0ZXNcbiAgICAgKi9cbiAgICBwZXJpb2Q/OiBjZGsuRHVyYXRpb25cbiAgICAvKipcbiAgICAgKiBUaHJlc2hvbGQgdmFsdWUgZm9yIGFsYXJtIGFzIGEgcGVyY2VudFxuICAgICAqIEBkZWZhdWx0IDAuMDUoJSlcbiAgICAgKiAwLjEwJSBpcyB0aGUgdGhyZXNob2xkIGF0IHdoaWNoIEFXUyBjb25zaWRlcnMgcHV0dGluZyBhbiBhY2NvdW50IHVuZGVyIHJldmlld1xuICAgICAqL1xuICAgIHRocmVzaG9sZD86IG51bWJlclxuICB9XG59XG5cbi8qKlxuICpcbiAqIENvbnN0cnVjdCB0aGF0IGNvbmZpZ3VyZXMgdmFyaW91cyBzZW5zaWJsZSBDbG91ZFdhdGNoIGFsYXJtcyBmb3IgQVdTIFNFU1xuICovXG5leHBvcnQgY2xhc3MgU2VzQWxhcm1zIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBwcml2YXRlIHJlYWRvbmx5IGFjdGlvbjogY2xvdWR3YXRjaC5JQWxhcm1BY3Rpb25cblxuICBjb25zdHJ1Y3RvcihzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTZXNBbGFybXNQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIHRoaXMuYWN0aW9uID0gcHJvcHMuYWN0aW9uXG5cbiAgICBjb25zdCBib3VuY2VkTWVzc2FnZXNBbGFybSA9IG5ldyBjbG91ZHdhdGNoLk1ldHJpYyh7XG4gICAgICBtZXRyaWNOYW1lOiBcIlJlcHV0YXRpb24uQm91bmNlUmF0ZVwiLFxuICAgICAgbmFtZXNwYWNlOiBcIkFXUy9TRVNcIixcbiAgICAgIHN0YXRpc3RpYzogXCJNYXhpbXVtXCIsXG4gICAgICBwZXJpb2Q6IHByb3BzPy5ib3VuY2VkTWVzc2FnZXNBbGFybT8ucGVyaW9kID8/IGNkay5EdXJhdGlvbi5taW51dGVzKDEwKSxcbiAgICB9KS5jcmVhdGVBbGFybSh0aGlzLCBcIkJvdW5jZWRNZXNzYWdlc0FsYXJtXCIsIHtcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246IGBUaGUgU0VTIGJvdW5jZSByYXRlIGlzIG92ZXIgJHtcbiAgICAgICAgcHJvcHM/LmJvdW5jZWRNZXNzYWdlc0FsYXJtPy50aHJlc2hvbGQgPz8gMi41XG4gICAgICB9JWAsXG4gICAgICBjb21wYXJpc29uT3BlcmF0b3I6IGNsb3Vkd2F0Y2guQ29tcGFyaXNvbk9wZXJhdG9yLkdSRUFURVJfVEhBTl9USFJFU0hPTEQsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICAgIHRyZWF0TWlzc2luZ0RhdGE6IGNsb3Vkd2F0Y2guVHJlYXRNaXNzaW5nRGF0YS5JR05PUkUsXG4gICAgICB0aHJlc2hvbGQ6IChwcm9wcz8uYm91bmNlZE1lc3NhZ2VzQWxhcm0/LnRocmVzaG9sZCA/PyAyLjUpIC8gMTAwLFxuICAgIH0pXG5cbiAgICBpZiAocHJvcHM/LmJvdW5jZWRNZXNzYWdlc0FsYXJtPy5lbmFibGVkID8/IHRydWUpIHtcbiAgICAgIGJvdW5jZWRNZXNzYWdlc0FsYXJtLmFkZEFsYXJtQWN0aW9uKFxuICAgICAgICBwcm9wcz8uYm91bmNlZE1lc3NhZ2VzQWxhcm0/LmFjdGlvbiB8fCB0aGlzLmFjdGlvbixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBjb21wbGFpbnRNZXNzYWdlc0FsYXJtID0gbmV3IGNsb3Vkd2F0Y2guTWV0cmljKHtcbiAgICAgIG1ldHJpY05hbWU6IFwiUmVwdXRhdGlvbi5Db21wbGFpbnRSYXRlXCIsXG4gICAgICBuYW1lc3BhY2U6IFwiQVdTL1NFU1wiLFxuICAgICAgc3RhdGlzdGljOiBcIk1heGltdW1cIixcbiAgICAgIHBlcmlvZDogcHJvcHM/LmNvbXBsYWludFJhdGVBbGFybT8ucGVyaW9kID8/IGNkay5EdXJhdGlvbi5taW51dGVzKDEwKSxcbiAgICB9KS5jcmVhdGVBbGFybSh0aGlzLCBcIkNvbXBsYWludE1lc3NhZ2VzQWxhcm1cIiwge1xuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYFRoZSBTRVMgY29tcGxhaW50IHJhdGUgaXMgb3ZlciAke1xuICAgICAgICBwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy50aHJlc2hvbGQgPz8gMC4wNVxuICAgICAgfSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjbG91ZHdhdGNoLkNvbXBhcmlzb25PcGVyYXRvci5HUkVBVEVSX1RIQU5fVEhSRVNIT0xELFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgICB0aHJlc2hvbGQ6IChwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy50aHJlc2hvbGQgPz8gMC4wNSkgLyAxMDAsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjbG91ZHdhdGNoLlRyZWF0TWlzc2luZ0RhdGEuSUdOT1JFLFxuICAgIH0pXG5cbiAgICBpZiAocHJvcHM/LmNvbXBsYWludFJhdGVBbGFybT8uZW5hYmxlZCA/PyB0cnVlKSB7XG4gICAgICBjb21wbGFpbnRNZXNzYWdlc0FsYXJtLmFkZEFsYXJtQWN0aW9uKFxuICAgICAgICBwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy5hY3Rpb24gfHwgdGhpcy5hY3Rpb24sXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VzLWFsYXJtcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hbGFybXMvc2VzLWFsYXJtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssR0FBRyxNQUFNLGFBQWEsQ0FBQTtBQUNsQyxPQUFPLEtBQUssVUFBVSxNQUFNLDRCQUE0QixDQUFBO0FBQ3hELE9BQU8sS0FBSyxVQUFVLE1BQU0sWUFBWSxDQUFBO0FBMkR4Qzs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sU0FBVSxTQUFRLFVBQVUsQ0FBQyxTQUFTO0lBQ2hDLE1BQU0sQ0FBeUI7SUFFaEQsWUFBWSxLQUEyQixFQUFFLEVBQVUsRUFBRSxLQUFxQjtRQUN4RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFBO1FBRWhCLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQTtRQUUxQixNQUFNLG9CQUFvQixHQUFHLElBQUksVUFBVSxDQUFDLE1BQU0sQ0FBQztZQUNqRCxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLFNBQVMsRUFBRSxTQUFTO1lBQ3BCLFNBQVMsRUFBRSxTQUFTO1lBQ3BCLE1BQU0sRUFBRSxLQUFLLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxJQUFJLEdBQUcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztTQUN4RSxDQUFDLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxzQkFBc0IsRUFBRTtZQUMzQyxnQkFBZ0IsRUFBRSwrQkFDaEIsS0FBSyxFQUFFLG9CQUFvQixFQUFFLFNBQVMsSUFBSSxHQUM1QyxHQUFHO1lBQ0gsa0JBQWtCLEVBQUUsVUFBVSxDQUFDLGtCQUFrQixDQUFDLHNCQUFzQjtZQUN4RSxpQkFBaUIsRUFBRSxDQUFDO1lBQ3BCLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNO1lBQ3BELFNBQVMsRUFBRSxDQUFDLEtBQUssRUFBRSxvQkFBb0IsRUFBRSxTQUFTLElBQUksR0FBRyxDQUFDLEdBQUcsR0FBRztTQUNqRSxDQUFDLENBQUE7UUFFRixJQUFJLEtBQUssRUFBRSxvQkFBb0IsRUFBRSxPQUFPLElBQUksSUFBSSxFQUFFLENBQUM7WUFDakQsb0JBQW9CLENBQUMsY0FBYyxDQUNqQyxLQUFLLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQ25ELENBQUE7UUFDSCxDQUFDO1FBRUQsTUFBTSxzQkFBc0IsR0FBRyxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUM7WUFDbkQsVUFBVSxFQUFFLDBCQUEwQjtZQUN0QyxTQUFTLEVBQUUsU0FBUztZQUNwQixTQUFTLEVBQUUsU0FBUztZQUNwQixNQUFNLEVBQUUsS0FBSyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7U0FDdEUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsd0JBQXdCLEVBQUU7WUFDN0MsZ0JBQWdCLEVBQUUsa0NBQ2hCLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxTQUFTLElBQUksSUFDMUMsR0FBRztZQUNILGtCQUFrQixFQUFFLFVBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDeEUsaUJBQWlCLEVBQUUsQ0FBQztZQUNwQixTQUFTLEVBQUUsQ0FBQyxLQUFLLEVBQUUsa0JBQWtCLEVBQUUsU0FBUyxJQUFJLElBQUksQ0FBQyxHQUFHLEdBQUc7WUFDL0QsZ0JBQWdCLEVBQUUsVUFBVSxDQUFDLGdCQUFnQixDQUFDLE1BQU07U0FDckQsQ0FBQyxDQUFBO1FBRUYsSUFBSSxLQUFLLEVBQUUsa0JBQWtCLEVBQUUsT0FBTyxJQUFJLElBQUksRUFBRSxDQUFDO1lBQy9DLHNCQUFzQixDQUFDLGNBQWMsQ0FDbkMsS0FBSyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUNqRCxDQUFBO1FBQ0gsQ0FBQztJQUNILENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIlxuaW1wb3J0ICogYXMgY2xvdWR3YXRjaCBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2hcIlxuaW1wb3J0ICogYXMgY29uc3RydWN0cyBmcm9tIFwiY29uc3RydWN0c1wiXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VzQWxhcm1zUHJvcHMgZXh0ZW5kcyBjZGsuU3RhY2tQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXNcbiAgICovXG4gIGFjdGlvbjogY2xvdWR3YXRjaC5JQWxhcm1BY3Rpb25cbiAgLyoqXG4gICAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIGFsYXJtIGZvciBoaWdoIHJhdGUgYm91bmNlZCBtZXNzYWdlcy5cbiAgICpcbiAgICogQGRlZmF1bHQgQ29uZmlndXJlZCB3aXRoIHJlYXNvbmFibGUgZGVmYXVsdHMuXG4gICAqL1xuICBib3VuY2VkTWVzc2FnZXNBbGFybT86IHtcbiAgICAvKipcbiAgICAgKiBAZGVmYXVsdCB0cnVlXG4gICAgICovXG4gICAgZW5hYmxlZD86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBBbiBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXMgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBhY3Rpb25cbiAgICAgKi9cbiAgICBhY3Rpb24/OiBjbG91ZHdhdGNoLklBbGFybUFjdGlvblxuICAgIC8qKlxuICAgICAqIEBkZWZhdWx0IDEwIG1pbnV0ZXNcbiAgICAgKi9cbiAgICBwZXJpb2Q/OiBjZGsuRHVyYXRpb25cbiAgICAvKipcbiAgICAgKiBUaHJlc2hvbGQgdmFsdWUgZm9yIGFsYXJtIGFzIGEgcGVyY2VudFxuICAgICAqIEBkZWZhdWx0IDIuNSglKVxuICAgICAqIDUlIGlzIHRoZSB0aHJlc2hvbGQgYXQgd2hpY2ggQVdTIGNvbnNpZGVycyBwdXR0aW5nIGFuIGFjY291bnQgdW5kZXIgcmV2aWV3XG4gICAgICovXG4gICAgdGhyZXNob2xkPzogbnVtYmVyXG4gIH1cbiAgLyoqXG4gICAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIGFsYXJtIGZvciBoaWdoIGNvbXBsYWludCByYXRlLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDb25maWd1cmVkIHdpdGggc2FuZSBkZWZhdWx0cy5cbiAgICovXG4gIGNvbXBsYWludFJhdGVBbGFybT86IHtcbiAgICAvKipcbiAgICAgKiBAZGVmYXVsdCB0cnVlXG4gICAgICovXG4gICAgZW5hYmxlZD86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBBbiBhY3Rpb24gdG8gdXNlIGZvciBDbG91ZFdhdGNoIGFsYXJtIHN0YXRlIGNoYW5nZXMgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBhY3Rpb25cbiAgICAgKi9cbiAgICBhY3Rpb24/OiBjbG91ZHdhdGNoLklBbGFybUFjdGlvblxuICAgIC8qKlxuICAgICAqIEBkZWZhdWx0IDEwIG1pbnV0ZXNcbiAgICAgKi9cbiAgICBwZXJpb2Q/OiBjZGsuRHVyYXRpb25cbiAgICAvKipcbiAgICAgKiBUaHJlc2hvbGQgdmFsdWUgZm9yIGFsYXJtIGFzIGEgcGVyY2VudFxuICAgICAqIEBkZWZhdWx0IDAuMDUoJSlcbiAgICAgKiAwLjEwJSBpcyB0aGUgdGhyZXNob2xkIGF0IHdoaWNoIEFXUyBjb25zaWRlcnMgcHV0dGluZyBhbiBhY2NvdW50IHVuZGVyIHJldmlld1xuICAgICAqL1xuICAgIHRocmVzaG9sZD86IG51bWJlclxuICB9XG59XG5cbi8qKlxuICpcbiAqIENvbnN0cnVjdCB0aGF0IGNvbmZpZ3VyZXMgdmFyaW91cyBzZW5zaWJsZSBDbG91ZFdhdGNoIGFsYXJtcyBmb3IgQVdTIFNFU1xuICovXG5leHBvcnQgY2xhc3MgU2VzQWxhcm1zIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBwcml2YXRlIHJlYWRvbmx5IGFjdGlvbjogY2xvdWR3YXRjaC5JQWxhcm1BY3Rpb25cblxuICBjb25zdHJ1Y3RvcihzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTZXNBbGFybXNQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIHRoaXMuYWN0aW9uID0gcHJvcHMuYWN0aW9uXG5cbiAgICBjb25zdCBib3VuY2VkTWVzc2FnZXNBbGFybSA9IG5ldyBjbG91ZHdhdGNoLk1ldHJpYyh7XG4gICAgICBtZXRyaWNOYW1lOiBcIlJlcHV0YXRpb24uQm91bmNlUmF0ZVwiLFxuICAgICAgbmFtZXNwYWNlOiBcIkFXUy9TRVNcIixcbiAgICAgIHN0YXRpc3RpYzogXCJNYXhpbXVtXCIsXG4gICAgICBwZXJpb2Q6IHByb3BzPy5ib3VuY2VkTWVzc2FnZXNBbGFybT8ucGVyaW9kID8/IGNkay5EdXJhdGlvbi5taW51dGVzKDEwKSxcbiAgICB9KS5jcmVhdGVBbGFybSh0aGlzLCBcIkJvdW5jZWRNZXNzYWdlc0FsYXJtXCIsIHtcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246IGBUaGUgU0VTIGJvdW5jZSByYXRlIGlzIG92ZXIgJHtcbiAgICAgICAgcHJvcHM/LmJvdW5jZWRNZXNzYWdlc0FsYXJtPy50aHJlc2hvbGQgPz8gMi41XG4gICAgICB9JWAsXG4gICAgICBjb21wYXJpc29uT3BlcmF0b3I6IGNsb3Vkd2F0Y2guQ29tcGFyaXNvbk9wZXJhdG9yLkdSRUFURVJfVEhBTl9USFJFU0hPTEQsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICAgIHRyZWF0TWlzc2luZ0RhdGE6IGNsb3Vkd2F0Y2guVHJlYXRNaXNzaW5nRGF0YS5JR05PUkUsXG4gICAgICB0aHJlc2hvbGQ6IChwcm9wcz8uYm91bmNlZE1lc3NhZ2VzQWxhcm0/LnRocmVzaG9sZCA/PyAyLjUpIC8gMTAwLFxuICAgIH0pXG5cbiAgICBpZiAocHJvcHM/LmJvdW5jZWRNZXNzYWdlc0FsYXJtPy5lbmFibGVkID8/IHRydWUpIHtcbiAgICAgIGJvdW5jZWRNZXNzYWdlc0FsYXJtLmFkZEFsYXJtQWN0aW9uKFxuICAgICAgICBwcm9wcz8uYm91bmNlZE1lc3NhZ2VzQWxhcm0/LmFjdGlvbiB8fCB0aGlzLmFjdGlvbixcbiAgICAgIClcbiAgICB9XG5cbiAgICBjb25zdCBjb21wbGFpbnRNZXNzYWdlc0FsYXJtID0gbmV3IGNsb3Vkd2F0Y2guTWV0cmljKHtcbiAgICAgIG1ldHJpY05hbWU6IFwiUmVwdXRhdGlvbi5Db21wbGFpbnRSYXRlXCIsXG4gICAgICBuYW1lc3BhY2U6IFwiQVdTL1NFU1wiLFxuICAgICAgc3RhdGlzdGljOiBcIk1heGltdW1cIixcbiAgICAgIHBlcmlvZDogcHJvcHM/LmNvbXBsYWludFJhdGVBbGFybT8ucGVyaW9kID8/IGNkay5EdXJhdGlvbi5taW51dGVzKDEwKSxcbiAgICB9KS5jcmVhdGVBbGFybSh0aGlzLCBcIkNvbXBsYWludE1lc3NhZ2VzQWxhcm1cIiwge1xuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYFRoZSBTRVMgY29tcGxhaW50IHJhdGUgaXMgb3ZlciAke1xuICAgICAgICBwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy50aHJlc2hvbGQgPz8gMC4wNVxuICAgICAgfSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjbG91ZHdhdGNoLkNvbXBhcmlzb25PcGVyYXRvci5HUkVBVEVSX1RIQU5fVEhSRVNIT0xELFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgICB0aHJlc2hvbGQ6IChwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy50aHJlc2hvbGQgPz8gMC4wNSkgLyAxMDAsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjbG91ZHdhdGNoLlRyZWF0TWlzc2luZ0RhdGEuSUdOT1JFLFxuICAgIH0pXG5cbiAgICBpZiAocHJvcHM/LmNvbXBsYWludFJhdGVBbGFybT8uZW5hYmxlZCA/PyB0cnVlKSB7XG4gICAgICBjb21wbGFpbnRNZXNzYWdlc0FsYXJtLmFkZEFsYXJtQWN0aW9uKFxuICAgICAgICBwcm9wcz8uY29tcGxhaW50UmF0ZUFsYXJtPy5hY3Rpb24gfHwgdGhpcy5hY3Rpb24sXG4gICAgICApXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const
|
|
11
|
-
const
|
|
1
|
+
import * as constructs from "constructs";
|
|
2
|
+
import * as cloudwatchActions from "aws-cdk-lib/aws-cloudwatch-actions";
|
|
3
|
+
import * as iam from "aws-cdk-lib/aws-iam";
|
|
4
|
+
import { Effect, PolicyStatement } from "aws-cdk-lib/aws-iam";
|
|
5
|
+
import * as lambda from "aws-cdk-lib/aws-lambda";
|
|
6
|
+
import * as sns from "aws-cdk-lib/aws-sns";
|
|
7
|
+
import { Duration } from "aws-cdk-lib";
|
|
8
|
+
import * as path from "path";
|
|
9
|
+
import { fileURLToPath } from "node:url";
|
|
10
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
11
|
+
const __dirname = path.dirname(__filename);
|
|
12
12
|
/**
|
|
13
13
|
* SNS Topic that can be used to action alarms, with a Lambda
|
|
14
14
|
* that will send a message to Slack for the alarm.
|
|
15
15
|
*/
|
|
16
|
-
class SlackAlarm extends constructs.Construct {
|
|
16
|
+
export class SlackAlarm extends constructs.Construct {
|
|
17
|
+
alarmTopic;
|
|
18
|
+
snsAction;
|
|
17
19
|
constructor(scope, id, props) {
|
|
18
20
|
super(scope, id);
|
|
19
21
|
this.alarmTopic = new sns.Topic(this, "Topic");
|
|
@@ -24,7 +26,7 @@ class SlackAlarm extends constructs.Construct {
|
|
|
24
26
|
handler: "index.handler",
|
|
25
27
|
memorySize: 128,
|
|
26
28
|
runtime: lambda.Runtime.PYTHON_3_11,
|
|
27
|
-
timeout:
|
|
29
|
+
timeout: Duration.seconds(6),
|
|
28
30
|
environment: {
|
|
29
31
|
SLACK_URL_SECRET_NAME: props.slackWebhookUrlSecret.secretName,
|
|
30
32
|
PROJECT_NAME: props.projectName,
|
|
@@ -37,9 +39,9 @@ class SlackAlarm extends constructs.Construct {
|
|
|
37
39
|
principal: new iam.ServicePrincipal("sns.amazonaws.com"),
|
|
38
40
|
sourceArn: this.alarmTopic.topicArn,
|
|
39
41
|
});
|
|
40
|
-
slackLambda.addToRolePolicy(new
|
|
42
|
+
slackLambda.addToRolePolicy(new PolicyStatement({
|
|
41
43
|
actions: ["cloudwatch:DescribeAlarms"],
|
|
42
|
-
effect:
|
|
44
|
+
effect: Effect.ALLOW,
|
|
43
45
|
resources: ["*"],
|
|
44
46
|
}));
|
|
45
47
|
new sns.Subscription(this, "Subscription", {
|
|
@@ -49,5 +51,4 @@ class SlackAlarm extends constructs.Construct {
|
|
|
49
51
|
});
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
|
-
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xhY2stYWxhcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWxhcm1zL3NsYWNrLWFsYXJtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUF3QztBQUN4Qyx3RUFBdUU7QUFDdkUsMkNBQTBDO0FBQzFDLGlEQUE2RDtBQUM3RCxpREFBZ0Q7QUFDaEQsMkNBQTBDO0FBQzFDLDZDQUFzQztBQUN0Qyw2QkFBNEI7QUFnQjVCOzs7R0FHRztBQUNILE1BQWEsVUFBVyxTQUFRLFVBQVUsQ0FBQyxTQUFTO0lBSWxELFlBQVksS0FBMkIsRUFBRSxFQUFVLEVBQUUsS0FBc0I7UUFDekUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQTtRQUVoQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFFOUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUE7UUFFakUsTUFBTSxXQUFXLEdBQUcsSUFBSSxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDeEQsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxpQ0FBaUMsQ0FBQyxDQUN4RDtZQUNELFdBQVcsRUFDVCwrRUFBK0U7WUFDakYsT0FBTyxFQUFFLGVBQWU7WUFDeEIsVUFBVSxFQUFFLEdBQUc7WUFDZixPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXO1lBQ25DLE9BQU8sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDNUIsV0FBVyxFQUFFO2dCQUNYLHFCQUFxQixFQUFFLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxVQUFVO2dCQUM3RCxZQUFZLEVBQUUsS0FBSyxDQUFDLFdBQVc7Z0JBQy9CLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxPQUFPO2FBQ2hDO1NBQ0YsQ0FBQyxDQUFBO1FBRUYsS0FBSyxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQTtRQUVsRCxXQUFXLENBQUMsYUFBYSxDQUFDLGtCQUFrQixFQUFFO1lBQzVDLE1BQU0sRUFBRSx1QkFBdUI7WUFDL0IsU0FBUyxFQUFFLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLG1CQUFtQixDQUFDO1lBQ3hELFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVE7U0FDcEMsQ0FBQyxDQUFBO1FBQ0YsV0FBVyxDQUFDLGVBQWUsQ0FDekIsSUFBSSx5QkFBZSxDQUFDO1lBQ2xCLE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO1lBQ3RDLE1BQU0sRUFBRSxnQkFBTSxDQUFDLEtBQUs7WUFDcEIsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDO1NBQ2pCLENBQUMsQ0FDSCxDQUFBO1FBRUQsSUFBSSxHQUFHLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxjQUFjLEVBQUU7WUFDekMsUUFBUSxFQUFFLFdBQVcsQ0FBQyxXQUFXO1lBQ2pDLFFBQVEsRUFBRSxHQUFHLENBQUMsb0JBQW9CLENBQUMsTUFBTTtZQUN6QyxLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVU7U0FDdkIsQ0FBQyxDQUFBO0lBQ0osQ0FBQztDQUNGO0FBakRELGdDQWlEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNvbnN0cnVjdHMgZnJvbSBcImNvbnN0cnVjdHNcIlxuaW1wb3J0ICogYXMgY2xvdWR3YXRjaEFjdGlvbnMgZnJvbSBcImF3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoLWFjdGlvbnNcIlxuaW1wb3J0ICogYXMgaWFtIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtaWFtXCJcbmltcG9ydCB7IEVmZmVjdCwgUG9saWN5U3RhdGVtZW50IH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1pYW1cIlxuaW1wb3J0ICogYXMgbGFtYmRhIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtbGFtYmRhXCJcbmltcG9ydCAqIGFzIHNucyBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXNuc1wiXG5pbXBvcnQgeyBEdXJhdGlvbiB9IGZyb20gXCJhd3MtY2RrLWxpYlwiXG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gXCJwYXRoXCJcbmltcG9ydCAqIGFzIHNlY3JldHNtYW5hZ2VyIGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtc2VjcmV0c21hbmFnZXJcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFNsYWNrQWxhcm1Qcm9wcyB7XG4gIHByb2plY3ROYW1lOiBzdHJpbmdcbiAgZW52TmFtZTogc3RyaW5nXG4gIC8qKlxuICAgKiBBIHBsYWludGV4dCBzZWNyZXQgY29udGFpbmluZyB0aGUgVVJMIG9mIGEgU2xhY2sgaW5jb21pbmcgd2ViaG9vay5cbiAgICogVGhlIHdlYmhvb2sgc2hvdWxkIGJlIGNyZWF0ZWQgdGhyb3VnaCBhIFNsYWNrIGFwcCwgYW5kIG9ubHkgYWxsb3dzIHBvc3RpbmcgdG8gb25lIHNwZWNpZmljIFNsYWNrIGNoYW5uZWwuXG4gICAqIFNlZSBTbGFjaydzIG9mZmljaWFsIGRvY3VtZW50YXRpb24gKGUuZy4sIGh0dHBzOi8vYXBpLnNsYWNrLmNvbS9tZXNzYWdpbmcvd2ViaG9va3MpIGZvciBtb3JlIGRldGFpbHMuXG4gICAqXG4gICAqIE5PVEU6IEluY29taW5nIHdlYmhvb2tzIGNyZWF0ZWQgdGhyb3VnaCBsZWdhY3kgY3VzdG9tIGludGVncmF0aW9ucyBpbiBTbGFjayBhcmUgbm90IHN1cHBvcnRlZC5cbiAgICovXG4gIHNsYWNrV2ViaG9va1VybFNlY3JldDogc2VjcmV0c21hbmFnZXIuSVNlY3JldFxufVxuXG4vKipcbiAqIFNOUyBUb3BpYyB0aGF0IGNhbiBiZSB1c2VkIHRvIGFjdGlvbiBhbGFybXMsIHdpdGggYSBMYW1iZGFcbiAqIHRoYXQgd2lsbCBzZW5kIGEgbWVzc2FnZSB0byBTbGFjayBmb3IgdGhlIGFsYXJtLlxuICovXG5leHBvcnQgY2xhc3MgU2xhY2tBbGFybSBleHRlbmRzIGNvbnN0cnVjdHMuQ29uc3RydWN0IHtcbiAgcHVibGljIHJlYWRvbmx5IGFsYXJtVG9waWM6IHNucy5Ub3BpY1xuICBwdWJsaWMgcmVhZG9ubHkgc25zQWN0aW9uOiBjbG91ZHdhdGNoQWN0aW9ucy5TbnNBY3Rpb25cblxuICBjb25zdHJ1Y3RvcihzY29wZTogY29uc3RydWN0cy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTbGFja0FsYXJtUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpXG5cbiAgICB0aGlzLmFsYXJtVG9waWMgPSBuZXcgc25zLlRvcGljKHRoaXMsIFwiVG9waWNcIilcblxuICAgIHRoaXMuc25zQWN0aW9uID0gbmV3IGNsb3Vkd2F0Y2hBY3Rpb25zLlNuc0FjdGlvbih0aGlzLmFsYXJtVG9waWMpXG5cbiAgICBjb25zdCBzbGFja0xhbWJkYSA9IG5ldyBsYW1iZGEuRnVuY3Rpb24odGhpcywgXCJGdW5jdGlvblwiLCB7XG4gICAgICBjb2RlOiBsYW1iZGEuQ29kZS5mcm9tQXNzZXQoXG4gICAgICAgIHBhdGguam9pbihfX2Rpcm5hbWUsIFwiLi4vLi4vYXNzZXRzL3NsYWNrLWFsYXJtLWxhbWJkYVwiKSxcbiAgICAgICksXG4gICAgICBkZXNjcmlwdGlvbjpcbiAgICAgICAgXCJSZWNlaXZlcyBDbG91ZFdhdGNoIEFsYXJtcyB0aHJvdWdoIFNOUyBhbmQgc2VuZHMgYSBmb3JtYXR0ZWQgdmVyc2lvbiB0byBTbGFja1wiLFxuICAgICAgaGFuZGxlcjogXCJpbmRleC5oYW5kbGVyXCIsXG4gICAgICBtZW1vcnlTaXplOiAxMjgsXG4gICAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5QWVRIT05fM18xMSxcbiAgICAgIHRpbWVvdXQ6IER1cmF0aW9uLnNlY29uZHMoNiksXG4gICAgICBlbnZpcm9ubWVudDoge1xuICAgICAgICBTTEFDS19VUkxfU0VDUkVUX05BTUU6IHByb3BzLnNsYWNrV2ViaG9va1VybFNlY3JldC5zZWNyZXROYW1lLFxuICAgICAgICBQUk9KRUNUX05BTUU6IHByb3BzLnByb2plY3ROYW1lLFxuICAgICAgICBFTlZJUk9OTUVOVF9OQU1FOiBwcm9wcy5lbnZOYW1lLFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgcHJvcHMuc2xhY2tXZWJob29rVXJsU2VjcmV0LmdyYW50UmVhZChzbGFja0xhbWJkYSlcblxuICAgIHNsYWNrTGFtYmRhLmFkZFBlcm1pc3Npb24oXCJJbnZva2VQZXJtaXNzaW9uXCIsIHtcbiAgICAgIGFjdGlvbjogXCJsYW1iZGE6SW52b2tlRnVuY3Rpb25cIixcbiAgICAgIHByaW5jaXBhbDogbmV3IGlhbS5TZXJ2aWNlUHJpbmNpcGFsKFwic25zLmFtYXpvbmF3cy5jb21cIiksXG4gICAgICBzb3VyY2VBcm46IHRoaXMuYWxhcm1Ub3BpYy50b3BpY0FybixcbiAgICB9KVxuICAgIHNsYWNrTGFtYmRhLmFkZFRvUm9sZVBvbGljeShcbiAgICAgIG5ldyBQb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgICBhY3Rpb25zOiBbXCJjbG91ZHdhdGNoOkRlc2NyaWJlQWxhcm1zXCJdLFxuICAgICAgICBlZmZlY3Q6IEVmZmVjdC5BTExPVyxcbiAgICAgICAgcmVzb3VyY2VzOiBbXCIqXCJdLFxuICAgICAgfSksXG4gICAgKVxuXG4gICAgbmV3IHNucy5TdWJzY3JpcHRpb24odGhpcywgXCJTdWJzY3JpcHRpb25cIiwge1xuICAgICAgZW5kcG9pbnQ6IHNsYWNrTGFtYmRhLmZ1bmN0aW9uQXJuLFxuICAgICAgcHJvdG9jb2w6IHNucy5TdWJzY3JpcHRpb25Qcm90b2NvbC5MQU1CREEsXG4gICAgICB0b3BpYzogdGhpcy5hbGFybVRvcGljLFxuICAgIH0pXG4gIH1cbn1cbiJdfQ==
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xhY2stYWxhcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWxhcm1zL3NsYWNrLWFsYXJtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxVQUFVLE1BQU0sWUFBWSxDQUFBO0FBQ3hDLE9BQU8sS0FBSyxpQkFBaUIsTUFBTSxvQ0FBb0MsQ0FBQTtBQUN2RSxPQUFPLEtBQUssR0FBRyxNQUFNLHFCQUFxQixDQUFBO0FBQzFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFDN0QsT0FBTyxLQUFLLE1BQU0sTUFBTSx3QkFBd0IsQ0FBQTtBQUNoRCxPQUFPLEtBQUssR0FBRyxNQUFNLHFCQUFxQixDQUFBO0FBQzFDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDdEMsT0FBTyxLQUFLLElBQUksTUFBTSxNQUFNLENBQUE7QUFFNUIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFVBQVUsQ0FBQTtBQUN4QyxNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQTtBQUNqRCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFBO0FBZTFDOzs7R0FHRztBQUNILE1BQU0sT0FBTyxVQUFXLFNBQVEsVUFBVSxDQUFDLFNBQVM7SUFDbEMsVUFBVSxDQUFXO0lBQ3JCLFNBQVMsQ0FBNkI7SUFFdEQsWUFBWSxLQUEyQixFQUFFLEVBQVUsRUFBRSxLQUFzQjtRQUN6RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFBO1FBRWhCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQTtRQUU5QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksaUJBQWlCLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUVqRSxNQUFNLFdBQVcsR0FBRyxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUN4RCxJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLGlDQUFpQyxDQUFDLENBQ3hEO1lBQ0QsV0FBVyxFQUNULCtFQUErRTtZQUNqRixPQUFPLEVBQUUsZUFBZTtZQUN4QixVQUFVLEVBQUUsR0FBRztZQUNmLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVc7WUFDbkMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQzVCLFdBQVcsRUFBRTtnQkFDWCxxQkFBcUIsRUFBRSxLQUFLLENBQUMscUJBQXFCLENBQUMsVUFBVTtnQkFDN0QsWUFBWSxFQUFFLEtBQUssQ0FBQyxXQUFXO2dCQUMvQixnQkFBZ0IsRUFBRSxLQUFLLENBQUMsT0FBTzthQUNoQztTQUNGLENBQUMsQ0FBQTtRQUVGLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUE7UUFFbEQsV0FBVyxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsRUFBRTtZQUM1QyxNQUFNLEVBQUUsdUJBQXVCO1lBQy9CLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQztZQUN4RCxTQUFTLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO1NBQ3BDLENBQUMsQ0FBQTtRQUNGLFdBQVcsQ0FBQyxlQUFlLENBQ3pCLElBQUksZUFBZSxDQUFDO1lBQ2xCLE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO1lBQ3RDLE1BQU0sRUFBRSxNQUFNLENBQUMsS0FBSztZQUNwQixTQUFTLEVBQUUsQ0FBQyxHQUFHLENBQUM7U0FDakIsQ0FBQyxDQUNILENBQUE7UUFFRCxJQUFJLEdBQUcsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLGNBQWMsRUFBRTtZQUN6QyxRQUFRLEVBQUUsV0FBVyxDQUFDLFdBQVc7WUFDakMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNO1lBQ3pDLEtBQUssRUFBRSxJQUFJLENBQUMsVUFBVTtTQUN2QixDQUFDLENBQUE7SUFDSixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjb25zdHJ1Y3RzIGZyb20gXCJjb25zdHJ1Y3RzXCJcbmltcG9ydCAqIGFzIGNsb3Vkd2F0Y2hBY3Rpb25zIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaC1hY3Rpb25zXCJcbmltcG9ydCAqIGFzIGlhbSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWlhbVwiXG5pbXBvcnQgeyBFZmZlY3QsIFBvbGljeVN0YXRlbWVudCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtaWFtXCJcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYVwiXG5pbXBvcnQgKiBhcyBzbnMgZnJvbSBcImF3cy1jZGstbGliL2F3cy1zbnNcIlxuaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tIFwiYXdzLWNkay1saWJcIlxuaW1wb3J0ICogYXMgcGF0aCBmcm9tIFwicGF0aFwiXG5pbXBvcnQgKiBhcyBzZWNyZXRzbWFuYWdlciBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXNlY3JldHNtYW5hZ2VyXCJcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tIFwibm9kZTp1cmxcIlxuY29uc3QgX19maWxlbmFtZSA9IGZpbGVVUkxUb1BhdGgoaW1wb3J0Lm1ldGEudXJsKVxuY29uc3QgX19kaXJuYW1lID0gcGF0aC5kaXJuYW1lKF9fZmlsZW5hbWUpXG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhY2tBbGFybVByb3BzIHtcbiAgcHJvamVjdE5hbWU6IHN0cmluZ1xuICBlbnZOYW1lOiBzdHJpbmdcbiAgLyoqXG4gICAqIEEgcGxhaW50ZXh0IHNlY3JldCBjb250YWluaW5nIHRoZSBVUkwgb2YgYSBTbGFjayBpbmNvbWluZyB3ZWJob29rLlxuICAgKiBUaGUgd2ViaG9vayBzaG91bGQgYmUgY3JlYXRlZCB0aHJvdWdoIGEgU2xhY2sgYXBwLCBhbmQgb25seSBhbGxvd3MgcG9zdGluZyB0byBvbmUgc3BlY2lmaWMgU2xhY2sgY2hhbm5lbC5cbiAgICogU2VlIFNsYWNrJ3Mgb2ZmaWNpYWwgZG9jdW1lbnRhdGlvbiAoZS5nLiwgaHR0cHM6Ly9hcGkuc2xhY2suY29tL21lc3NhZ2luZy93ZWJob29rcykgZm9yIG1vcmUgZGV0YWlscy5cbiAgICpcbiAgICogTk9URTogSW5jb21pbmcgd2ViaG9va3MgY3JlYXRlZCB0aHJvdWdoIGxlZ2FjeSBjdXN0b20gaW50ZWdyYXRpb25zIGluIFNsYWNrIGFyZSBub3Qgc3VwcG9ydGVkLlxuICAgKi9cbiAgc2xhY2tXZWJob29rVXJsU2VjcmV0OiBzZWNyZXRzbWFuYWdlci5JU2VjcmV0XG59XG5cbi8qKlxuICogU05TIFRvcGljIHRoYXQgY2FuIGJlIHVzZWQgdG8gYWN0aW9uIGFsYXJtcywgd2l0aCBhIExhbWJkYVxuICogdGhhdCB3aWxsIHNlbmQgYSBtZXNzYWdlIHRvIFNsYWNrIGZvciB0aGUgYWxhcm0uXG4gKi9cbmV4cG9ydCBjbGFzcyBTbGFja0FsYXJtIGV4dGVuZHMgY29uc3RydWN0cy5Db25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgYWxhcm1Ub3BpYzogc25zLlRvcGljXG4gIHB1YmxpYyByZWFkb25seSBzbnNBY3Rpb246IGNsb3Vkd2F0Y2hBY3Rpb25zLlNuc0FjdGlvblxuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjb25zdHJ1Y3RzLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNsYWNrQWxhcm1Qcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZClcblxuICAgIHRoaXMuYWxhcm1Ub3BpYyA9IG5ldyBzbnMuVG9waWModGhpcywgXCJUb3BpY1wiKVxuXG4gICAgdGhpcy5zbnNBY3Rpb24gPSBuZXcgY2xvdWR3YXRjaEFjdGlvbnMuU25zQWN0aW9uKHRoaXMuYWxhcm1Ub3BpYylcblxuICAgIGNvbnN0IHNsYWNrTGFtYmRhID0gbmV3IGxhbWJkYS5GdW5jdGlvbih0aGlzLCBcIkZ1bmN0aW9uXCIsIHtcbiAgICAgIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChcbiAgICAgICAgcGF0aC5qb2luKF9fZGlybmFtZSwgXCIuLi8uLi9hc3NldHMvc2xhY2stYWxhcm0tbGFtYmRhXCIpLFxuICAgICAgKSxcbiAgICAgIGRlc2NyaXB0aW9uOlxuICAgICAgICBcIlJlY2VpdmVzIENsb3VkV2F0Y2ggQWxhcm1zIHRocm91Z2ggU05TIGFuZCBzZW5kcyBhIGZvcm1hdHRlZCB2ZXJzaW9uIHRvIFNsYWNrXCIsXG4gICAgICBoYW5kbGVyOiBcImluZGV4LmhhbmRsZXJcIixcbiAgICAgIG1lbW9yeVNpemU6IDEyOCxcbiAgICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLlBZVEhPTl8zXzExLFxuICAgICAgdGltZW91dDogRHVyYXRpb24uc2Vjb25kcyg2KSxcbiAgICAgIGVudmlyb25tZW50OiB7XG4gICAgICAgIFNMQUNLX1VSTF9TRUNSRVRfTkFNRTogcHJvcHMuc2xhY2tXZWJob29rVXJsU2VjcmV0LnNlY3JldE5hbWUsXG4gICAgICAgIFBST0pFQ1RfTkFNRTogcHJvcHMucHJvamVjdE5hbWUsXG4gICAgICAgIEVOVklST05NRU5UX05BTUU6IHByb3BzLmVudk5hbWUsXG4gICAgICB9LFxuICAgIH0pXG5cbiAgICBwcm9wcy5zbGFja1dlYmhvb2tVcmxTZWNyZXQuZ3JhbnRSZWFkKHNsYWNrTGFtYmRhKVxuXG4gICAgc2xhY2tMYW1iZGEuYWRkUGVybWlzc2lvbihcIkludm9rZVBlcm1pc3Npb25cIiwge1xuICAgICAgYWN0aW9uOiBcImxhbWJkYTpJbnZva2VGdW5jdGlvblwiLFxuICAgICAgcHJpbmNpcGFsOiBuZXcgaWFtLlNlcnZpY2VQcmluY2lwYWwoXCJzbnMuYW1hem9uYXdzLmNvbVwiKSxcbiAgICAgIHNvdXJjZUFybjogdGhpcy5hbGFybVRvcGljLnRvcGljQXJuLFxuICAgIH0pXG4gICAgc2xhY2tMYW1iZGEuYWRkVG9Sb2xlUG9saWN5KFxuICAgICAgbmV3IFBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFtcImNsb3Vkd2F0Y2g6RGVzY3JpYmVBbGFybXNcIl0sXG4gICAgICAgIGVmZmVjdDogRWZmZWN0LkFMTE9XLFxuICAgICAgICByZXNvdXJjZXM6IFtcIipcIl0sXG4gICAgICB9KSxcbiAgICApXG5cbiAgICBuZXcgc25zLlN1YnNjcmlwdGlvbih0aGlzLCBcIlN1YnNjcmlwdGlvblwiLCB7XG4gICAgICBlbmRwb2ludDogc2xhY2tMYW1iZGEuZnVuY3Rpb25Bcm4sXG4gICAgICBwcm90b2NvbDogc25zLlN1YnNjcmlwdGlvblByb3RvY29sLkxBTUJEQSxcbiAgICAgIHRvcGljOiB0aGlzLmFsYXJtVG9waWMsXG4gICAgfSlcbiAgfVxufVxuIl19
|
package/lib/bastion-host.js
CHANGED
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
const ec2 = require("aws-cdk-lib/aws-ec2");
|
|
6
|
-
const iam = require("aws-cdk-lib/aws-iam");
|
|
7
|
-
const cdk = require("aws-cdk-lib");
|
|
1
|
+
import * as constructs from "constructs";
|
|
2
|
+
import * as ec2 from "aws-cdk-lib/aws-ec2";
|
|
3
|
+
import * as iam from "aws-cdk-lib/aws-iam";
|
|
4
|
+
import * as cdk from "aws-cdk-lib";
|
|
8
5
|
/**
|
|
9
6
|
* This creates a EC2 bastion host that can be used to connect
|
|
10
7
|
* to database instances and other internal resources.
|
|
@@ -18,18 +15,19 @@ const cdk = require("aws-cdk-lib");
|
|
|
18
15
|
* For more internal details, see
|
|
19
16
|
* https://confluence.capraconsulting.no/x/q8UBC
|
|
20
17
|
*/
|
|
21
|
-
class BastionHost extends constructs.Construct {
|
|
18
|
+
export class BastionHost extends constructs.Construct {
|
|
19
|
+
securityGroup;
|
|
22
20
|
constructor(scope, id, props) {
|
|
23
|
-
var _a, _b;
|
|
24
21
|
super(scope, id);
|
|
25
22
|
const region = cdk.Stack.of(this).region;
|
|
26
23
|
this.securityGroup =
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
24
|
+
props.securityGroup ??
|
|
25
|
+
new ec2.SecurityGroup(this, "SecurityGroup", {
|
|
26
|
+
vpc: props.vpc,
|
|
27
|
+
});
|
|
30
28
|
const instance = new ec2.Instance(this, "Instance", {
|
|
31
29
|
vpc: props.vpc,
|
|
32
|
-
vpcSubnets:
|
|
30
|
+
vpcSubnets: props.subnetSelection ?? {
|
|
33
31
|
subnetType: ec2.SubnetType.PUBLIC,
|
|
34
32
|
},
|
|
35
33
|
securityGroup: this.securityGroup,
|
|
@@ -82,5 +80,4 @@ class BastionHost extends constructs.Construct {
|
|
|
82
80
|
});
|
|
83
81
|
}
|
|
84
82
|
}
|
|
85
|
-
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bastion-host.js","sourceRoot":"","sources":["../src/bastion-host.ts"],"names":[],"mappings":";;;AAAA,yCAAwC;AACxC,2CAA0C;AAC1C,2CAA0C;AAC1C,mCAAkC;AAwBlC;;;;;;;;;;;;GAYG;AACH,MAAa,WAAY,SAAQ,UAAU,CAAC,SAAS;IAGnD,YAAY,KAA2B,EAAE,EAAU,EAAE,KAAY;;QAC/D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;QAEhB,MAAM,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,CAAA;QAExC,IAAI,CAAC,aAAa;YAChB,MAAA,KAAK,CAAC,aAAa,mCACnB,IAAI,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,eAAe,EAAE;gBAC3C,GAAG,EAAE,KAAK,CAAC,GAAG;aACf,CAAC,CAAA;QAEJ,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAClD,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,UAAU,EAAE,MAAA,KAAK,CAAC,eAAe,mCAAI;gBACnC,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM;aAClC;YACD,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,YAAY,EAAE,SAAS;YACvB,YAAY,EAAE,GAAG,CAAC,YAAY,CAAC,EAAE,CAC/B,GAAG,CAAC,aAAa,CAAC,EAAE,EACpB,GAAG,CAAC,YAAY,CAAC,IAAI,CACtB;YACD,YAAY,EAAE,GAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC;gBAC/C,UAAU,EAAE,GAAG,CAAC,qBAAqB,CAAC,cAAc;aACrD,CAAC;SACH,CAAC,CAAA;QAEF,QAAQ,CAAC,WAAW,CAClB,qCAAqC,MAAM,oFAAoF,CAChI,CAAA;QAED,eAAe;QACf,QAAQ,CAAC,eAAe;QACtB,6CAA6C;QAC7C,0CAA0C;QAC1C,EAAE;QACF,iEAAiE;QACjE,kEAAkE;QAClE,mEAAmE;QACnE,2DAA2D;QAC3D,EAAE;QACF,8DAA8D;QAC9D,oGAAoG;QACpG,IAAI,GAAG,CAAC,eAAe,CAAC;YACtB,OAAO,EAAE;gBACP,2GAA2G;gBAC3G,+EAA+E;gBAC/E,8BAA8B;gBAC9B,+BAA+B;gBAC/B,iBAAiB;gBACjB,kBAAkB;gBAClB,qCAAqC;gBACrC,2GAA2G;gBAC3G,kCAAkC;gBAClC,+BAA+B;gBAC/B,gCAAgC;gBAChC,6BAA6B;gBAC7B,0FAA0F;gBAC1F,gCAAgC;gBAChC,2BAA2B;gBAC3B,yBAAyB;gBACzB,yBAAyB;gBACzB,yBAAyB;gBACzB,uBAAuB;aACxB;YACD,8CAA8C;YAC9C,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CACH,CAAA;QAED,IAAI,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,mBAAmB,EAAE;YAC3C,KAAK,EAAE,QAAQ,CAAC,UAAU;SAC3B,CAAC,CAAA;IACJ,CAAC;CACF;AA7ED,kCA6EC","sourcesContent":["import * as constructs from \"constructs\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as cdk from \"aws-cdk-lib\"\n\ninterface Props {\n  vpc: ec2.IVpc\n  /**\n   * The security group used for the EC2 instance.\n   *\n   * @default - a security group will be created\n   */\n  securityGroup?: ec2.ISecurityGroup\n  /**\n   * The subnets to place the bastion host.\n   *\n   * Note that if placed inside private subnet, the VPC must have\n   * VPC endpoints to access relevant AWS services for Systems Manager\n   * to work in order to be able to connect to the instance.\n   *\n   * See https://aws.amazon.com/premiumsupport/knowledge-center/ec2-systems-manager-vpc-endpoints/\n   *\n   * @default - public subnets\n   */\n  subnetSelection?: ec2.SubnetSelection\n}\n\n/**\n * This creates a EC2 bastion host that can be used to connect\n * to database instances and other internal resources.\n *\n * The instance is supposed to have no open ingress ports, and users\n * are supposed to connect only through SSM Session Manager.\n *\n * The resources that the bastion host should be allowed to access\n * must have the bastion host security group as allowed ingress.\n *\n * For more internal details, see\n * https://confluence.capraconsulting.no/x/q8UBC\n */\nexport class BastionHost extends constructs.Construct {\n  public readonly securityGroup: ec2.ISecurityGroup\n\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n\n    const region = cdk.Stack.of(this).region\n\n    this.securityGroup =\n      props.securityGroup ??\n      new ec2.SecurityGroup(this, \"SecurityGroup\", {\n        vpc: props.vpc,\n      })\n\n    const instance = new ec2.Instance(this, \"Instance\", {\n      vpc: props.vpc,\n      vpcSubnets: props.subnetSelection ?? {\n        subnetType: ec2.SubnetType.PUBLIC,\n      },\n      securityGroup: this.securityGroup,\n      instanceName: \"Bastion\",\n      instanceType: ec2.InstanceType.of(\n        ec2.InstanceClass.T3,\n        ec2.InstanceSize.NANO,\n      ),\n      machineImage: ec2.MachineImage.latestAmazonLinux({\n        generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n      }),\n    })\n\n    instance.addUserData(\n      `yum install -y https://amazon-ssm-${region}.s3.amazonaws.com/latest/linux_amd64/amazon-ssm-agent.rpm socat postgresql mariadb`,\n    )\n\n    // SSM support.\n    instance.addToRolePolicy(\n      // This mimics the AmazonEC2RoleforSSM policy\n      // while granting least privileges needed.\n      //\n      // The default AmazonEC2RoleforSSM policy gives read/write access\n      // to all objects in S3, all parameters in Parameter Store, amoung\n      // more. We primarily use the SSM agent for limited remote control,\n      // and the policy here covers that as the primary use case.\n      //\n      // See https://www.cflee.com/posts/aws-ssm-iam-policy-caveats/\n      // See also https://docs.aws.amazon.com/systems-manager/latest/userguide/setup-instance-profile.html\n      new iam.PolicyStatement({\n        actions: [\n          // https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-setting-up-messageAPIs.html\n          // https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awssystemsmanager.html\n          \"ssm:ListInstanceAssociations\",\n          \"ssm:UpdateInstanceInformation\",\n          \"ssm:GetDocument\",\n          \"ssm:PutInventory\",\n          \"ssm:UpdateInstanceAssociationStatus\",\n          // https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-setting-up-messageAPIs.html\n          \"ssmmessages:CreateControlChannel\",\n          \"ssmmessages:CreateDataChannel\",\n          \"ssmmessages:OpenControlChannel\",\n          \"ssmmessages:OpenDataChannel\",\n          // https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazonmessagedeliveryservice.html\n          \"ec2messages:AcknowledgeMessage\",\n          \"ec2messages:DeleteMessage\",\n          \"ec2messages:FailMessage\",\n          \"ec2messages:GetEndpoint\",\n          \"ec2messages:GetMessages\",\n          \"ec2messages:SendReply\",\n        ],\n        // Seems this is needed for the given actions.\n        resources: [\"*\"],\n      }),\n    )\n\n    new cdk.CfnOutput(this, \"BastionInstanceId\", {\n      value: instance.instanceId,\n    })\n  }\n}\n"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bastion-host.js","sourceRoot":"","sources":["../src/bastion-host.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,YAAY,CAAA;AACxC,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAA;AAC1C,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAA;AAC1C,OAAO,KAAK,GAAG,MAAM,aAAa,CAAA;AAwBlC;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,WAAY,SAAQ,UAAU,CAAC,SAAS;IACnC,aAAa,CAAoB;IAEjD,YAAY,KAA2B,EAAE,EAAU,EAAE,KAAY;QAC/D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;QAEhB,MAAM,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,CAAA;QAExC,IAAI,CAAC,aAAa;YAChB,KAAK,CAAC,aAAa;gBACnB,IAAI,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,eAAe,EAAE;oBAC3C,GAAG,EAAE,KAAK,CAAC,GAAG;iBACf,CAAC,CAAA;QAEJ,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAClD,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,UAAU,EAAE,KAAK,CAAC,eAAe,IAAI;gBACnC,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM;aAClC;YACD,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,YAAY,EAAE,SAAS;YACvB,YAAY,EAAE,GAAG,CAAC,YAAY,CAAC,EAAE,CAC/B,GAAG,CAAC,aAAa,CAAC,EAAE,EACpB,GAAG,CAAC,YAAY,CAAC,IAAI,CACtB;YACD,YAAY,EAAE,GAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC;gBAC/C,UAAU,EAAE,GAAG,CAAC,qBAAqB,CAAC,cAAc;aACrD,CAAC;SACH,CAAC,CAAA;QAEF,QAAQ,CAAC,WAAW,CAClB,qCAAqC,MAAM,oFAAoF,CAChI,CAAA;QAED,eAAe;QACf,QAAQ,CAAC,eAAe;QACtB,6CAA6C;QAC7C,0CAA0C;QAC1C,EAAE;QACF,iEAAiE;QACjE,kEAAkE;QAClE,mEAAmE;QACnE,2DAA2D;QAC3D,EAAE;QACF,8DAA8D;QAC9D,oGAAoG;QACpG,IAAI,GAAG,CAAC,eAAe,CAAC;YACtB,OAAO,EAAE;gBACP,2GAA2G;gBAC3G,+EAA+E;gBAC/E,8BAA8B;gBAC9B,+BAA+B;gBAC/B,iBAAiB;gBACjB,kBAAkB;gBAClB,qCAAqC;gBACrC,2GAA2G;gBAC3G,kCAAkC;gBAClC,+BAA+B;gBAC/B,gCAAgC;gBAChC,6BAA6B;gBAC7B,0FAA0F;gBAC1F,gCAAgC;gBAChC,2BAA2B;gBAC3B,yBAAyB;gBACzB,yBAAyB;gBACzB,yBAAyB;gBACzB,uBAAuB;aACxB;YACD,8CAA8C;YAC9C,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CACH,CAAA;QAED,IAAI,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,mBAAmB,EAAE;YAC3C,KAAK,EAAE,QAAQ,CAAC,UAAU;SAC3B,CAAC,CAAA;IACJ,CAAC;CACF","sourcesContent":["import * as constructs from \"constructs\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as cdk from \"aws-cdk-lib\"\n\ninterface Props {\n  vpc: ec2.IVpc\n  /**\n   * The security group used for the EC2 instance.\n   *\n   * @default - a security group will be created\n   */\n  securityGroup?: ec2.ISecurityGroup\n  /**\n   * The subnets to place the bastion host.\n   *\n   * Note that if placed inside private subnet, the VPC must have\n   * VPC endpoints to access relevant AWS services for Systems Manager\n   * to work in order to be able to connect to the instance.\n   *\n   * See https://aws.amazon.com/premiumsupport/knowledge-center/ec2-systems-manager-vpc-endpoints/\n   *\n   * @default - public subnets\n   */\n  subnetSelection?: ec2.SubnetSelection\n}\n\n/**\n * This creates a EC2 bastion host that can be used to connect\n * to database instances and other internal resources.\n *\n * The instance is supposed to have no open ingress ports, and users\n * are supposed to connect only through SSM Session Manager.\n *\n * The resources that the bastion host should be allowed to access\n * must have the bastion host security group as allowed ingress.\n *\n * For more internal details, see\n * https://confluence.capraconsulting.no/x/q8UBC\n */\nexport class BastionHost extends constructs.Construct {\n  public readonly securityGroup: ec2.ISecurityGroup\n\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n\n    const region = cdk.Stack.of(this).region\n\n    this.securityGroup =\n      props.securityGroup ??\n      new ec2.SecurityGroup(this, \"SecurityGroup\", {\n        vpc: props.vpc,\n      })\n\n    const instance = new ec2.Instance(this, \"Instance\", {\n      vpc: props.vpc,\n      vpcSubnets: props.subnetSelection ?? {\n        subnetType: ec2.SubnetType.PUBLIC,\n      },\n      securityGroup: this.securityGroup,\n      instanceName: \"Bastion\",\n      instanceType: ec2.InstanceType.of(\n        ec2.InstanceClass.T3,\n        ec2.InstanceSize.NANO,\n      ),\n      machineImage: ec2.MachineImage.latestAmazonLinux({\n        generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n      }),\n    })\n\n    instance.addUserData(\n      `yum install -y https://amazon-ssm-${region}.s3.amazonaws.com/latest/linux_amd64/amazon-ssm-agent.rpm socat postgresql mariadb`,\n    )\n\n    // SSM support.\n    instance.addToRolePolicy(\n      // This mimics the AmazonEC2RoleforSSM policy\n      // while granting least privileges needed.\n      //\n      // The default AmazonEC2RoleforSSM policy gives read/write access\n      // to all objects in S3, all parameters in Parameter Store, amoung\n      // more. We primarily use the SSM agent for limited remote control,\n      // and the policy here covers that as the primary use case.\n      //\n      // See https://www.cflee.com/posts/aws-ssm-iam-policy-caveats/\n      // See also https://docs.aws.amazon.com/systems-manager/latest/userguide/setup-instance-profile.html\n      new iam.PolicyStatement({\n        actions: [\n          // https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-setting-up-messageAPIs.html\n          // https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awssystemsmanager.html\n          \"ssm:ListInstanceAssociations\",\n          \"ssm:UpdateInstanceInformation\",\n          \"ssm:GetDocument\",\n          \"ssm:PutInventory\",\n          \"ssm:UpdateInstanceAssociationStatus\",\n          // https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-setting-up-messageAPIs.html\n          \"ssmmessages:CreateControlChannel\",\n          \"ssmmessages:CreateDataChannel\",\n          \"ssmmessages:OpenControlChannel\",\n          \"ssmmessages:OpenDataChannel\",\n          // https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazonmessagedeliveryservice.html\n          \"ec2messages:AcknowledgeMessage\",\n          \"ec2messages:DeleteMessage\",\n          \"ec2messages:FailMessage\",\n          \"ec2messages:GetEndpoint\",\n          \"ec2messages:GetMessages\",\n          \"ec2messages:SendReply\",\n        ],\n        // Seems this is needed for the given actions.\n        resources: [\"*\"],\n      }),\n    )\n\n    new cdk.CfnOutput(this, \"BastionInstanceId\", {\n      value: instance.instanceId,\n    })\n  }\n}\n"]}
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
const snapshots_1 = require("../snapshots");
|
|
2
|
+
import { createCloudAssemblySnapshot } from "../snapshots.js";
|
|
5
3
|
let src;
|
|
6
4
|
let dst;
|
|
7
5
|
// If no arguments are given, use some sensible defaults.
|
|
@@ -14,9 +12,9 @@ else {
|
|
|
14
12
|
src = process.argv[2];
|
|
15
13
|
dst = process.argv[3];
|
|
16
14
|
}
|
|
17
|
-
|
|
15
|
+
createCloudAssemblySnapshot(src, dst).catch((e) => {
|
|
18
16
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
19
17
|
console.error(e.stack || e.message || e);
|
|
20
18
|
process.exitCode = 1;
|
|
21
19
|
});
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLWNyZWF0ZS1zbmFwc2hvdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYmluL2Nkay1jcmVhdGUtc25hcHNob3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUU3RCxJQUFJLEdBQVcsQ0FBQTtBQUNmLElBQUksR0FBVyxDQUFBO0FBRWYseURBQXlEO0FBQ3pELElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDN0IsR0FBRyxHQUFHLFNBQVMsQ0FBQTtJQUNmLEdBQUcsR0FBRyxlQUFlLENBQUE7QUFDdkIsQ0FBQztLQUFNLENBQUM7SUFDTixpREFBaUQ7SUFDakQsR0FBRyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDckIsR0FBRyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFDdkIsQ0FBQztBQUVELDJCQUEyQixDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtJQUNoRCxzRUFBc0U7SUFDdEUsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUE7SUFDeEMsT0FBTyxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUE7QUFDdEIsQ0FBQyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG5pbXBvcnQgeyBjcmVhdGVDbG91ZEFzc2VtYmx5U25hcHNob3QgfSBmcm9tIFwiLi4vc25hcHNob3RzLmpzXCJcblxubGV0IHNyYzogc3RyaW5nXG5sZXQgZHN0OiBzdHJpbmdcblxuLy8gSWYgbm8gYXJndW1lbnRzIGFyZSBnaXZlbiwgdXNlIHNvbWUgc2Vuc2libGUgZGVmYXVsdHMuXG5pZiAocHJvY2Vzcy5hcmd2Lmxlbmd0aCA9PSAyKSB7XG4gIHNyYyA9IFwiY2RrLm91dFwiXG4gIGRzdCA9IFwiX19zbmFwc2hvdHNfX1wiXG59IGVsc2Uge1xuICAvLyBJbiBOb2RlLCBmaXJzdCBwYXJhbWV0ZXIgaXMgdGhlIHRoaXJkIGVsZW1lbnQuXG4gIHNyYyA9IHByb2Nlc3MuYXJndlsyXVxuICBkc3QgPSBwcm9jZXNzLmFyZ3ZbM11cbn1cblxuY3JlYXRlQ2xvdWRBc3NlbWJseVNuYXBzaG90KHNyYywgZHN0KS5jYXRjaCgoZSkgPT4ge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gIGNvbnNvbGUuZXJyb3IoZS5zdGFjayB8fCBlLm1lc3NhZ2UgfHwgZSlcbiAgcHJvY2Vzcy5leGl0Q29kZSA9IDFcbn0pXG4iXX0=
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const fs = require("fs");
|
|
5
|
-
const variables_1 = require("../cdk-pipelines/variables");
|
|
2
|
+
import * as fs from "fs";
|
|
3
|
+
import { getVariablesFromParameterStore } from "../cdk-pipelines/variables";
|
|
6
4
|
let namespace;
|
|
7
5
|
// If no arguments are given, use some sensible defaults.
|
|
8
6
|
if (process.argv.length == 2) {
|
|
@@ -18,7 +16,7 @@ async function main(namespace) {
|
|
|
18
16
|
// to ensure it is not stale. In the pipeline, variables
|
|
19
17
|
// will never be stale, but locally it can be.
|
|
20
18
|
variablesTimestamp: new Date().toISOString(),
|
|
21
|
-
...(await
|
|
19
|
+
...(await getVariablesFromParameterStore(`/liflig-cdk/${namespace}/pipeline-variables/`)),
|
|
22
20
|
};
|
|
23
21
|
const result = JSON.stringify(variables, undefined, " ");
|
|
24
22
|
fs.writeFileSync("variables.json", result);
|
|
@@ -30,4 +28,4 @@ main(namespace).catch((e) => {
|
|
|
30
28
|
console.error(e.stack || e.message || e);
|
|
31
29
|
process.exitCode = 1;
|
|
32
30
|
});
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmV0Y2gtcGlwZWxpbmUtdmFyaWFibGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Jpbi9mZXRjaC1waXBlbGluZS12YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLE9BQU8sS0FBSyxFQUFFLE1BQU0sSUFBSSxDQUFBO0FBQ3hCLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBRTNFLElBQUksU0FBaUIsQ0FBQTtBQUVyQix5REFBeUQ7QUFDekQsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUM3QixTQUFTLEdBQUcsU0FBUyxDQUFBO0FBQ3ZCLENBQUM7S0FBTSxDQUFDO0lBQ04saURBQWlEO0lBQ2pELFNBQVMsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBQzdCLENBQUM7QUFFRCxLQUFLLFVBQVUsSUFBSSxDQUFDLFNBQWlCO0lBQ25DLE1BQU0sU0FBUyxHQUFHO1FBQ2hCLDJEQUEyRDtRQUMzRCx3REFBd0Q7UUFDeEQsOENBQThDO1FBQzlDLGtCQUFrQixFQUFFLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFO1FBQzVDLEdBQUcsQ0FBQyxNQUFNLDhCQUE4QixDQUN0QyxlQUFlLFNBQVMsc0JBQXNCLENBQy9DLENBQUM7S0FDSCxDQUFBO0lBRUQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFBO0lBRXpELEVBQUUsQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLEVBQUUsTUFBTSxDQUFDLENBQUE7SUFDMUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyx3Q0FBd0MsQ0FBQyxDQUFBO0lBQ3JELE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQTtBQUMxQyxDQUFDO0FBRUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO0lBQzFCLHNFQUFzRTtJQUN0RSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUN4QyxPQUFPLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQTtBQUN0QixDQUFDLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcbmltcG9ydCAqIGFzIGZzIGZyb20gXCJmc1wiXG5pbXBvcnQgeyBnZXRWYXJpYWJsZXNGcm9tUGFyYW1ldGVyU3RvcmUgfSBmcm9tIFwiLi4vY2RrLXBpcGVsaW5lcy92YXJpYWJsZXNcIlxuXG5sZXQgbmFtZXNwYWNlOiBzdHJpbmdcblxuLy8gSWYgbm8gYXJndW1lbnRzIGFyZSBnaXZlbiwgdXNlIHNvbWUgc2Vuc2libGUgZGVmYXVsdHMuXG5pZiAocHJvY2Vzcy5hcmd2Lmxlbmd0aCA9PSAyKSB7XG4gIG5hbWVzcGFjZSA9IFwiZGVmYXVsdFwiXG59IGVsc2Uge1xuICAvLyBJbiBOb2RlLCBmaXJzdCBwYXJhbWV0ZXIgaXMgdGhlIHRoaXJkIGVsZW1lbnQuXG4gIG5hbWVzcGFjZSA9IHByb2Nlc3MuYXJndlsyXVxufVxuXG5hc3luYyBmdW5jdGlvbiBtYWluKG5hbWVzcGFjZTogc3RyaW5nKSB7XG4gIGNvbnN0IHZhcmlhYmxlcyA9IHtcbiAgICAvLyBTcGVjaWFsIHZhcmlhYmxlIHRoYXQgY2FuIGJlIHVzZWQgd2hlbiByZWFkaW5nIHZhcmlhYmxlc1xuICAgIC8vIHRvIGVuc3VyZSBpdCBpcyBub3Qgc3RhbGUuIEluIHRoZSBwaXBlbGluZSwgdmFyaWFibGVzXG4gICAgLy8gd2lsbCBuZXZlciBiZSBzdGFsZSwgYnV0IGxvY2FsbHkgaXQgY2FuIGJlLlxuICAgIHZhcmlhYmxlc1RpbWVzdGFtcDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgIC4uLihhd2FpdCBnZXRWYXJpYWJsZXNGcm9tUGFyYW1ldGVyU3RvcmUoXG4gICAgICBgL2xpZmxpZy1jZGsvJHtuYW1lc3BhY2V9L3BpcGVsaW5lLXZhcmlhYmxlcy9gLFxuICAgICkpLFxuICB9XG5cbiAgY29uc3QgcmVzdWx0ID0gSlNPTi5zdHJpbmdpZnkodmFyaWFibGVzLCB1bmRlZmluZWQsIFwiICBcIilcblxuICBmcy53cml0ZUZpbGVTeW5jKFwidmFyaWFibGVzLmpzb25cIiwgcmVzdWx0KVxuICBjb25zb2xlLmxvZyhcIlJldHJpZXZlZCBhbmQgc2F2ZWQgdG8gdmFyaWFibGVzLmpzb246XCIpXG4gIGNvbnNvbGUubG9nKHJlc3VsdC5yZXBsYWNlKC9eL2dtLCBcIiAgXCIpKVxufVxuXG5tYWluKG5hbWVzcGFjZSkuY2F0Y2goKGUpID0+IHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtbWVtYmVyLWFjY2Vzc1xuICBjb25zb2xlLmVycm9yKGUuc3RhY2sgfHwgZS5tZXNzYWdlIHx8IGUpXG4gIHByb2Nlc3MuZXhpdENvZGUgPSAxXG59KVxuIl19
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.GithubActionsRole = exports.validateProps = void 0;
|
|
4
|
-
const iam = require("aws-cdk-lib/aws-iam");
|
|
5
|
-
const constructs = require("constructs");
|
|
1
|
+
import * as iam from "aws-cdk-lib/aws-iam";
|
|
2
|
+
import * as constructs from "constructs";
|
|
6
3
|
/**
|
|
7
4
|
* Utility function for validating the construct properties.
|
|
8
5
|
*/
|
|
9
|
-
const validateProps = (props) => {
|
|
6
|
+
export const validateProps = (props) => {
|
|
10
7
|
let valid = true;
|
|
11
8
|
if (props.trustedOwners.length === 0) {
|
|
12
9
|
console.error("At least 1 trusted owner must be supplied, but 0 were given");
|
|
@@ -30,19 +27,18 @@ const validateProps = (props) => {
|
|
|
30
27
|
});
|
|
31
28
|
return valid;
|
|
32
29
|
};
|
|
33
|
-
exports.validateProps = validateProps;
|
|
34
30
|
/**
|
|
35
31
|
* Creates an IAM role that can be assumed by GitHub Actions workflows
|
|
36
32
|
* in specific GitHub repositories and branches using OpenID Connect.
|
|
37
33
|
*/
|
|
38
|
-
class GithubActionsRole extends constructs.Construct {
|
|
34
|
+
export class GithubActionsRole extends constructs.Construct {
|
|
35
|
+
role;
|
|
39
36
|
constructor(scope, id, props) {
|
|
40
|
-
var _a;
|
|
41
37
|
super(scope, id);
|
|
42
|
-
if (!
|
|
38
|
+
if (!validateProps(props)) {
|
|
43
39
|
throw new Error("Invalid props were supplied");
|
|
44
40
|
}
|
|
45
|
-
const subjects = props.repositories.map((repository) =>
|
|
41
|
+
const subjects = props.repositories.map((repository) => `repo:${repository.owner}/${repository.name}:ref:refs/heads/${props.trustedBranch ?? "master"}`);
|
|
46
42
|
const fullyQualifiedSubjects = subjects.filter((subject) => !(subject.includes("?") || subject.includes("*")));
|
|
47
43
|
const wildcardSubjects = subjects.filter((subject) => subject.includes("?") || subject.includes("*"));
|
|
48
44
|
const principalConditions = {
|
|
@@ -64,10 +60,9 @@ class GithubActionsRole extends constructs.Construct {
|
|
|
64
60
|
throw new Error("The principal's trust policy needs to be configured with at least one IAM condition");
|
|
65
61
|
}
|
|
66
62
|
this.role = new iam.Role(this, "Role", {
|
|
67
|
-
roleName:
|
|
63
|
+
roleName: props.roleName ?? "github-actions-role",
|
|
68
64
|
assumedBy: principal,
|
|
69
65
|
});
|
|
70
66
|
}
|
|
71
67
|
}
|
|
72
|
-
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github-actions-role.js","sourceRoot":"","sources":["../../src/build-artifacts/github-actions-role.ts"],"names":[],"mappings":"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","sourcesContent":["import * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as constructs from \"constructs\"\n\nexport interface Props {\n  /**\n   * A list of trusted GitHub repository owners.\n   *\n   * This functions as a sort of whitelist to catch\n   * potential typos in {@link repositories}.\n   */\n  trustedOwners: string[]\n  /**\n   * The name of the trusted branch.\n   *\n   * The wildcard characters '*' and '?' can be used to\n   * represent any combination of characters and any single\n   * character, respectively.\n   *\n   * @default \"master\"\n   */\n  trustedBranch?: string\n  /**\n   * The name of the role to create.\n   *\n   * @default \"github-actions-role\"\n   */\n  roleName?: string\n  /**\n   * The GitHub repositories that the principal trusts.\n   */\n  repositories: {\n    /**\n     * The name of the GitHub repository.\n     *\n     * The wildcard characters '*' and '?' can be used to\n     * represent any combination of characters and any single\n     * character, respectively.\n     *\n     * NOTE: Be careful when using wildcard characters as you\n     * may grant access to repositories you did not intend.\n     *\n     * @example \"my-repository\"\n     * @example \"my-team-*\"\n     */\n    name: string\n    /**\n     * The name of the owner of the GitHub repository.\n     *\n     * NOTE: The owner must explicitly be whitelisted in {@link trustedOwners}.\n     */\n    owner: string\n  }[]\n  /**\n   * An existing OpenID Connect Provider for GitHub Actions.\n   */\n  oidcProvider: iam.IOpenIdConnectProvider\n}\n\n/**\n * Utility function for validating the construct properties.\n */\nexport const validateProps = (props: Props) => {\n  let valid = true\n  if (props.trustedOwners.length === 0) {\n    console.error(\"At least 1 trusted owner must be supplied, but 0 were given\")\n    valid = false\n  }\n  if (props.repositories.length === 0) {\n    console.error(\"At least 1 repository must be supplied, but 0 were given\")\n    valid = false\n  }\n  props.trustedOwners.forEach((owner) => {\n    if (!owner.match(/^[a-zA-Z0-9-]+$/)) {\n      console.error(`Trusted owner ${owner} contains invalid characters`)\n      valid = false\n    }\n  })\n\n  props.repositories.forEach((repository) => {\n    if (!props.trustedOwners.includes(repository.owner)) {\n      console.error(\n        `Owner ${repository.owner} of repository ${repository.name} not configured as a trusted owner`,\n      )\n      valid = false\n    }\n  })\n  return valid\n}\n\n/**\n * Creates an IAM role that can be assumed by GitHub Actions workflows\n * in specific GitHub repositories and branches using OpenID Connect.\n */\nexport class GithubActionsRole extends constructs.Construct {\n  public readonly role: iam.Role\n\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n    if (!validateProps(props)) {\n      throw new Error(\"Invalid props were supplied\")\n    }\n\n    const subjects = props.repositories.map(\n      (repository) =>\n        `repo:${repository.owner}/${repository.name}:ref:refs/heads/${props.trustedBranch ?? \"master\"}`,\n    )\n    const fullyQualifiedSubjects = subjects.filter(\n      (subject) => !(subject.includes(\"?\") || subject.includes(\"*\")),\n    )\n\n    const wildcardSubjects = subjects.filter(\n      (subject) => subject.includes(\"?\") || subject.includes(\"*\"),\n    )\n    const principalConditions = {\n      ...(fullyQualifiedSubjects.length && {\n        StringEquals: {\n          \"token.actions.githubusercontent.com:sub\": fullyQualifiedSubjects,\n        },\n      }),\n      ...(wildcardSubjects.length && {\n        StringLike: {\n          \"token.actions.githubusercontent.com:sub\": wildcardSubjects,\n        },\n      }),\n    }\n\n    const principal = new iam.FederatedPrincipal(\n      props.oidcProvider.openIdConnectProviderArn,\n      principalConditions,\n      \"sts:AssumeRoleWithWebIdentity\",\n    )\n\n    // Verify that the principal is configured with a trust relationship\n    // that contains at least one IAM condition with a context key and values\n    if (\n      !Object.values(principalConditions).some((conditionElement) =>\n        Object.entries(conditionElement).some(\n          ([conditionKey, conditionValue]) =>\n            conditionKey && conditionValue.length,\n        ),\n      )\n    ) {\n      throw new Error(\n        \"The principal's trust policy needs to be configured with at least one IAM condition\",\n      )\n    }\n    this.role = new iam.Role(this, \"Role\", {\n      roleName: props.roleName ?? \"github-actions-role\",\n      assumedBy: principal,\n    })\n  }\n}\n"]}
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github-actions-role.js","sourceRoot":"","sources":["../../src/build-artifacts/github-actions-role.ts"],"names":[],"mappings":"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","sourcesContent":["import * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as constructs from \"constructs\"\n\nexport interface Props {\n  /**\n   * A list of trusted GitHub repository owners.\n   *\n   * This functions as a sort of whitelist to catch\n   * potential typos in {@link repositories}.\n   */\n  trustedOwners: string[]\n  /**\n   * The name of the trusted branch.\n   *\n   * The wildcard characters '*' and '?' can be used to\n   * represent any combination of characters and any single\n   * character, respectively.\n   *\n   * @default \"master\"\n   */\n  trustedBranch?: string\n  /**\n   * The name of the role to create.\n   *\n   * @default \"github-actions-role\"\n   */\n  roleName?: string\n  /**\n   * The GitHub repositories that the principal trusts.\n   */\n  repositories: {\n    /**\n     * The name of the GitHub repository.\n     *\n     * The wildcard characters '*' and '?' can be used to\n     * represent any combination of characters and any single\n     * character, respectively.\n     *\n     * NOTE: Be careful when using wildcard characters as you\n     * may grant access to repositories you did not intend.\n     *\n     * @example \"my-repository\"\n     * @example \"my-team-*\"\n     */\n    name: string\n    /**\n     * The name of the owner of the GitHub repository.\n     *\n     * NOTE: The owner must explicitly be whitelisted in {@link trustedOwners}.\n     */\n    owner: string\n  }[]\n  /**\n   * An existing OpenID Connect Provider for GitHub Actions.\n   */\n  oidcProvider: iam.IOpenIdConnectProvider\n}\n\n/**\n * Utility function for validating the construct properties.\n */\nexport const validateProps = (props: Props) => {\n  let valid = true\n  if (props.trustedOwners.length === 0) {\n    console.error(\"At least 1 trusted owner must be supplied, but 0 were given\")\n    valid = false\n  }\n  if (props.repositories.length === 0) {\n    console.error(\"At least 1 repository must be supplied, but 0 were given\")\n    valid = false\n  }\n  props.trustedOwners.forEach((owner) => {\n    if (!owner.match(/^[a-zA-Z0-9-]+$/)) {\n      console.error(`Trusted owner ${owner} contains invalid characters`)\n      valid = false\n    }\n  })\n\n  props.repositories.forEach((repository) => {\n    if (!props.trustedOwners.includes(repository.owner)) {\n      console.error(\n        `Owner ${repository.owner} of repository ${repository.name} not configured as a trusted owner`,\n      )\n      valid = false\n    }\n  })\n  return valid\n}\n\n/**\n * Creates an IAM role that can be assumed by GitHub Actions workflows\n * in specific GitHub repositories and branches using OpenID Connect.\n */\nexport class GithubActionsRole extends constructs.Construct {\n  public readonly role: iam.Role\n\n  constructor(scope: constructs.Construct, id: string, props: Props) {\n    super(scope, id)\n    if (!validateProps(props)) {\n      throw new Error(\"Invalid props were supplied\")\n    }\n\n    const subjects = props.repositories.map(\n      (repository) =>\n        `repo:${repository.owner}/${repository.name}:ref:refs/heads/${props.trustedBranch ?? \"master\"}`,\n    )\n    const fullyQualifiedSubjects = subjects.filter(\n      (subject) => !(subject.includes(\"?\") || subject.includes(\"*\")),\n    )\n\n    const wildcardSubjects = subjects.filter(\n      (subject) => subject.includes(\"?\") || subject.includes(\"*\"),\n    )\n    const principalConditions = {\n      ...(fullyQualifiedSubjects.length && {\n        StringEquals: {\n          \"token.actions.githubusercontent.com:sub\": fullyQualifiedSubjects,\n        },\n      }),\n      ...(wildcardSubjects.length && {\n        StringLike: {\n          \"token.actions.githubusercontent.com:sub\": wildcardSubjects,\n        },\n      }),\n    }\n\n    const principal = new iam.FederatedPrincipal(\n      props.oidcProvider.openIdConnectProviderArn,\n      principalConditions,\n      \"sts:AssumeRoleWithWebIdentity\",\n    )\n\n    // Verify that the principal is configured with a trust relationship\n    // that contains at least one IAM condition with a context key and values\n    if (\n      !Object.values(principalConditions).some((conditionElement) =>\n        Object.entries(conditionElement).some(\n          ([conditionKey, conditionValue]) =>\n            conditionKey && conditionValue.length,\n        ),\n      )\n    ) {\n      throw new Error(\n        \"The principal's trust policy needs to be configured with at least one IAM condition\",\n      )\n    }\n    this.role = new iam.Role(this, \"Role\", {\n      roleName: props.roleName ?? \"github-actions-role\",\n      assumedBy: principal,\n    })\n  }\n}\n"]}
|