@cdklabs/multi-az-observability 0.0.0-alpha.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/.jsii +10177 -0
- package/API.md +5119 -0
- package/LICENSE +202 -0
- package/README.md +175 -0
- package/cdk.json +68 -0
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +214 -0
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +763 -0
- package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.d.ts +22 -0
- package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.js +21 -0
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +34 -0
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +39 -0
- package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.d.ts +7 -0
- package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.js +11 -0
- package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.d.ts +16 -0
- package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +17 -0
- package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.d.ts +18 -0
- package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +30 -0
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.d.ts +6 -0
- package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.d.ts +12 -0
- package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/IOperationAlarmsAndRules.d.ts +55 -0
- package/lib/alarmsandrules/IOperationAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.d.ts +15 -0
- package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.d.ts +36 -0
- package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/IServiceAlarmsAndRules.d.ts +44 -0
- package/lib/alarmsandrules/IServiceAlarmsAndRules.js +3 -0
- package/lib/alarmsandrules/InsightRuleBody.d.ts +67 -0
- package/lib/alarmsandrules/InsightRuleBody.js +46 -0
- package/lib/alarmsandrules/OperationAlarmsAndRules.d.ts +59 -0
- package/lib/alarmsandrules/OperationAlarmsAndRules.js +135 -0
- package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.d.ts +19 -0
- package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.js +22 -0
- package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.d.ts +40 -0
- package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +46 -0
- package/lib/alarmsandrules/ServiceAlarmsAndRules.d.ts +48 -0
- package/lib/alarmsandrules/ServiceAlarmsAndRules.js +166 -0
- package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.d.ts +24 -0
- package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +62 -0
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
- package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.d.ts +6 -0
- package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.d.ts +45 -0
- package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
- package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.d.ts +6 -0
- package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.js +3 -0
- package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.d.ts +13 -0
- package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.js +3 -0
- package/lib/azmapper/AvailabilityZoneMapper.d.ts +86 -0
- package/lib/azmapper/AvailabilityZoneMapper.js +200 -0
- package/lib/azmapper/IAvailabilityZoneMapper.d.ts +86 -0
- package/lib/azmapper/IAvailabilityZoneMapper.js +3 -0
- package/lib/azmapper/props/AvailabilityZoneMapperProps.d.ts +13 -0
- package/lib/azmapper/props/AvailabilityZoneMapperProps.js +3 -0
- package/lib/azmapper/src/index.py +107 -0
- package/lib/canaries/CanaryFunction.d.ts +16 -0
- package/lib/canaries/CanaryFunction.js +152 -0
- package/lib/canaries/CanaryTest.d.ts +10 -0
- package/lib/canaries/CanaryTest.js +84 -0
- package/lib/canaries/ICanaryFunction.d.ts +6 -0
- package/lib/canaries/ICanaryFunction.js +3 -0
- package/lib/canaries/props/AddCanaryTestProps.d.ts +66 -0
- package/lib/canaries/props/AddCanaryTestProps.js +3 -0
- package/lib/canaries/props/CanaryFunctionProps.d.ts +29 -0
- package/lib/canaries/props/CanaryFunctionProps.js +3 -0
- package/lib/canaries/props/CanaryTestProps.d.ts +21 -0
- package/lib/canaries/props/CanaryTestProps.js +3 -0
- package/lib/canaries/props/NetworkConfigurationProps.d.ts +16 -0
- package/lib/canaries/props/NetworkConfigurationProps.js +3 -0
- package/lib/canaries/src/canary.zip +0 -0
- package/lib/dashboards/BasicServiceDashboard.d.ts +10 -0
- package/lib/dashboards/BasicServiceDashboard.js +130 -0
- package/lib/dashboards/ContributorInsightsWidget.d.ts +22 -0
- package/lib/dashboards/ContributorInsightsWidget.js +55 -0
- package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.d.ts +10 -0
- package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.js +3 -0
- package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.d.ts +10 -0
- package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.js +3 -0
- package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +20 -0
- package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +588 -0
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +24 -0
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +475 -0
- package/lib/dashboards/props/BasicServiceDashboardProps.d.ts +23 -0
- package/lib/dashboards/props/BasicServiceDashboardProps.js +3 -0
- package/lib/dashboards/props/ContributorInsightWidgetProps.d.ts +31 -0
- package/lib/dashboards/props/ContributorInsightWidgetProps.js +3 -0
- package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +84 -0
- package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +3 -0
- package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +37 -0
- package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +3 -0
- package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +37 -0
- package/lib/dashboards/props/OperationLatencyWidgetProps.js +3 -0
- package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.d.ts +30 -0
- package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.js +3 -0
- package/lib/index.d.ts +35 -0
- package/lib/index.js +30 -0
- package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +36 -0
- package/lib/metrics/ApplicationLoadBalancerMetrics.js +150 -0
- package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +61 -0
- package/lib/metrics/AvailabilityAndLatencyMetrics.js +212 -0
- package/lib/metrics/NetworkLoadBalancerMetrics.d.ts +19 -0
- package/lib/metrics/NetworkLoadBalancerMetrics.js +48 -0
- package/lib/metrics/RegionalAvailabilityMetrics.d.ts +19 -0
- package/lib/metrics/RegionalAvailabilityMetrics.js +71 -0
- package/lib/metrics/RegionalLatencyMetrics.d.ts +33 -0
- package/lib/metrics/RegionalLatencyMetrics.js +69 -0
- package/lib/metrics/ZonalAvailabilityMetrics.d.ts +19 -0
- package/lib/metrics/ZonalAvailabilityMetrics.js +71 -0
- package/lib/metrics/ZonalLatencyMetrics.d.ts +29 -0
- package/lib/metrics/ZonalLatencyMetrics.js +65 -0
- package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +23 -0
- package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +3 -0
- package/lib/metrics/props/AvailabilityMetricProps.d.ts +11 -0
- package/lib/metrics/props/AvailabilityMetricProps.js +3 -0
- package/lib/metrics/props/LatencyMetricProps.d.ts +15 -0
- package/lib/metrics/props/LatencyMetricProps.js +3 -0
- package/lib/metrics/props/RegionalAvailabilityMetricProps.d.ts +6 -0
- package/lib/metrics/props/RegionalAvailabilityMetricProps.js +3 -0
- package/lib/metrics/props/RegionalLatencyMetricProps.d.ts +6 -0
- package/lib/metrics/props/RegionalLatencyMetricProps.js +3 -0
- package/lib/metrics/props/ServiceAvailabilityMetricProps.d.ts +23 -0
- package/lib/metrics/props/ServiceAvailabilityMetricProps.js +3 -0
- package/lib/metrics/props/ServiceLatencyMericProps.d.ts +23 -0
- package/lib/metrics/props/ServiceLatencyMericProps.js +3 -0
- package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +10 -0
- package/lib/metrics/props/ZonalAvailabilityMetricProps.js +3 -0
- package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +10 -0
- package/lib/metrics/props/ZonalLatencyMetricProps.js +3 -0
- package/lib/monitoring/src/monitoring-layer.zip +0 -0
- package/lib/outlier-detection/IOutlierDetectionFunction.d.ts +12 -0
- package/lib/outlier-detection/IOutlierDetectionFunction.js +3 -0
- package/lib/outlier-detection/OutlierDetectionFunction.d.ts +16 -0
- package/lib/outlier-detection/OutlierDetectionFunction.js +126 -0
- package/lib/outlier-detection/props/OutlierDetectionFunctionProps.d.ts +12 -0
- package/lib/outlier-detection/props/OutlierDetectionFunctionProps.js +3 -0
- package/lib/outlier-detection/src/outlier-detection.zip +0 -0
- package/lib/outlier-detection/src/scipy-layer.zip +0 -0
- package/lib/services/BasicServiceMultiAZObservability.d.ts +64 -0
- package/lib/services/BasicServiceMultiAZObservability.js +504 -0
- package/lib/services/CanaryMetrics.d.ts +17 -0
- package/lib/services/CanaryMetrics.js +19 -0
- package/lib/services/CanaryTestMetricsOverride.d.ts +39 -0
- package/lib/services/CanaryTestMetricsOverride.js +23 -0
- package/lib/services/ContributorInsightRuleDetails.d.ts +42 -0
- package/lib/services/ContributorInsightRuleDetails.js +23 -0
- package/lib/services/IBasicServiceMultiAZObservability.d.ts +45 -0
- package/lib/services/IBasicServiceMultiAZObservability.js +3 -0
- package/lib/services/ICanaryMetrics.d.ts +14 -0
- package/lib/services/ICanaryMetrics.js +3 -0
- package/lib/services/ICanaryTestMetricsOverride.d.ts +36 -0
- package/lib/services/ICanaryTestMetricsOverride.js +3 -0
- package/lib/services/IContributorInsightRuleDetails.d.ts +38 -0
- package/lib/services/IContributorInsightRuleDetails.js +3 -0
- package/lib/services/IInstrumentedServiceMultiAZObservability.d.ts +39 -0
- package/lib/services/IInstrumentedServiceMultiAZObservability.js +3 -0
- package/lib/services/IOperation.d.ts +75 -0
- package/lib/services/IOperation.js +3 -0
- package/lib/services/IOperationMetricDetails.d.ts +78 -0
- package/lib/services/IOperationMetricDetails.js +3 -0
- package/lib/services/IService.d.ts +76 -0
- package/lib/services/IService.js +3 -0
- package/lib/services/IServiceMetricDetails.d.ts +68 -0
- package/lib/services/IServiceMetricDetails.js +3 -0
- package/lib/services/InstrumentedServiceMultiAZObservability.d.ts +55 -0
- package/lib/services/InstrumentedServiceMultiAZObservability.js +310 -0
- package/lib/services/Operation.d.ts +78 -0
- package/lib/services/Operation.js +34 -0
- package/lib/services/OperationMetricDetails.d.ts +82 -0
- package/lib/services/OperationMetricDetails.js +50 -0
- package/lib/services/Service.d.ts +80 -0
- package/lib/services/Service.js +36 -0
- package/lib/services/ServiceMetricDetails.d.ts +71 -0
- package/lib/services/ServiceMetricDetails.js +28 -0
- package/lib/services/props/BasicServiceMultiAZObservabilityProps.d.ts +126 -0
- package/lib/services/props/BasicServiceMultiAZObservabilityProps.js +3 -0
- package/lib/services/props/CanaryMetricProps.d.ts +14 -0
- package/lib/services/props/CanaryMetricProps.js +3 -0
- package/lib/services/props/CanaryTestMetricsOverrideProps.d.ts +47 -0
- package/lib/services/props/CanaryTestMetricsOverrideProps.js +3 -0
- package/lib/services/props/ContributorInsightRuleDetailsProps.d.ts +38 -0
- package/lib/services/props/ContributorInsightRuleDetailsProps.js +3 -0
- package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.d.ts +88 -0
- package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.js +3 -0
- package/lib/services/props/MetricDimensions.d.ts +61 -0
- package/lib/services/props/MetricDimensions.js +63 -0
- package/lib/services/props/OperationMetricDetailsProps.d.ts +97 -0
- package/lib/services/props/OperationMetricDetailsProps.js +3 -0
- package/lib/services/props/OperationProps.d.ts +93 -0
- package/lib/services/props/OperationProps.js +3 -0
- package/lib/services/props/ServiceMetricDetailsProps.d.ts +68 -0
- package/lib/services/props/ServiceMetricDetailsProps.js +3 -0
- package/lib/services/props/ServiceProps.d.ts +69 -0
- package/lib/services/props/ServiceProps.js +3 -0
- package/lib/utilities/AvailabilityMetricType.d.ts +26 -0
- package/lib/utilities/AvailabilityMetricType.js +33 -0
- package/lib/utilities/LatencyMetricType.d.ts +13 -0
- package/lib/utilities/LatencyMetricType.js +20 -0
- package/lib/utilities/OutlierDetectionAlgorithm.d.ts +42 -0
- package/lib/utilities/OutlierDetectionAlgorithm.js +49 -0
- package/lib/utilities/StackWithDynamicSource.d.ts +14 -0
- package/lib/utilities/StackWithDynamicSource.js +82 -0
- package/package.json +176 -0
- package/rosetta/default.ts-fixture +13 -0
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.AvailabilityZoneMapper = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
7
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
8
|
+
const fs = require("fs");
|
|
9
|
+
const path = require("path");
|
|
10
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
11
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
12
|
+
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
13
|
+
const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
14
|
+
const constructs_1 = require("constructs");
|
|
15
|
+
/**
|
|
16
|
+
* A construct that allows you to map AZ names to ids and back
|
|
17
|
+
*/
|
|
18
|
+
class AvailabilityZoneMapper extends constructs_1.Construct {
|
|
19
|
+
constructor(scope, id, props) {
|
|
20
|
+
super(scope, id);
|
|
21
|
+
/*
|
|
22
|
+
let currentNode: Construct | undefined = this.node.scope;
|
|
23
|
+
|
|
24
|
+
while (currentNode !== undefined && !(currentNode instanceof Stack)) {
|
|
25
|
+
currentNode = currentNode.node.scope;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
if (currentNode !== undefined) {
|
|
29
|
+
(currentNode as Stack).addTransform('AWS::LanguageExtensions');
|
|
30
|
+
}
|
|
31
|
+
*/
|
|
32
|
+
let xrayManagedPolicy = new aws_iam_1.ManagedPolicy(this, 'XrayManagedPolicy', {
|
|
33
|
+
path: '/azmapper/',
|
|
34
|
+
statements: [
|
|
35
|
+
new aws_iam_1.PolicyStatement({
|
|
36
|
+
actions: [
|
|
37
|
+
'xray:PutTraceSegments',
|
|
38
|
+
'xray:PutTelemetryRecords',
|
|
39
|
+
'xray:GetSamplingRules',
|
|
40
|
+
'xray:GetSamplingTargets',
|
|
41
|
+
'xray:GetSamplingStatisticSummaries',
|
|
42
|
+
],
|
|
43
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
44
|
+
resources: ['*'],
|
|
45
|
+
}),
|
|
46
|
+
],
|
|
47
|
+
});
|
|
48
|
+
let ec2ManagedPolicy = new aws_iam_1.ManagedPolicy(this, 'EC2ManagedPolicy', {
|
|
49
|
+
path: '/azmapper/',
|
|
50
|
+
statements: [
|
|
51
|
+
new aws_iam_1.PolicyStatement({
|
|
52
|
+
actions: ['ec2:DescribeAvailabilityZones'],
|
|
53
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
54
|
+
resources: ['*'],
|
|
55
|
+
}),
|
|
56
|
+
],
|
|
57
|
+
});
|
|
58
|
+
let executionRole = new aws_iam_1.Role(this, 'executionRole', {
|
|
59
|
+
assumedBy: new aws_iam_1.ServicePrincipal('lambda.amazonaws.com'),
|
|
60
|
+
path: '/azmapper/',
|
|
61
|
+
managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],
|
|
62
|
+
});
|
|
63
|
+
const file = fs.readFileSync(path.resolve(__dirname, './../azmapper/src/index.py'), 'utf-8');
|
|
64
|
+
this.function = new aws_lambda_1.Function(this, 'AvailabilityZoneMapperFunction', {
|
|
65
|
+
runtime: aws_lambda_1.Runtime.PYTHON_3_12,
|
|
66
|
+
code: aws_lambda_1.Code.fromInline(file),
|
|
67
|
+
handler: 'index.handler',
|
|
68
|
+
role: executionRole,
|
|
69
|
+
architecture: aws_lambda_1.Architecture.ARM_64,
|
|
70
|
+
tracing: aws_lambda_1.Tracing.ACTIVE,
|
|
71
|
+
timeout: aws_cdk_lib_1.Duration.seconds(20),
|
|
72
|
+
memorySize: 512,
|
|
73
|
+
environment: {
|
|
74
|
+
REGION: aws_cdk_lib_1.Fn.ref('AWS::Region'),
|
|
75
|
+
PARTITION: aws_cdk_lib_1.Fn.ref('AWS::Partition'),
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
this.logGroup = new aws_logs_1.LogGroup(this, 'LogGroup', {
|
|
79
|
+
logGroupName: `/aws/lambda/${this.function.functionName}`,
|
|
80
|
+
retention: aws_logs_1.RetentionDays.ONE_DAY,
|
|
81
|
+
removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
82
|
+
});
|
|
83
|
+
new aws_iam_1.ManagedPolicy(this, 'CloudWatchManagedPolicy', {
|
|
84
|
+
path: '/azmapper/',
|
|
85
|
+
statements: [
|
|
86
|
+
new aws_iam_1.PolicyStatement({
|
|
87
|
+
actions: ['cloudwatch:PutMetricData'],
|
|
88
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
89
|
+
resources: ['*'],
|
|
90
|
+
}),
|
|
91
|
+
new aws_iam_1.PolicyStatement({
|
|
92
|
+
actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],
|
|
93
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
94
|
+
resources: [
|
|
95
|
+
aws_cdk_lib_1.Fn.sub('arn:${AWS::Partition}:logs:${AWS::Region}:${AWS::AccountId}:log-group:') +
|
|
96
|
+
this.logGroup.logGroupName +
|
|
97
|
+
':*',
|
|
98
|
+
],
|
|
99
|
+
}),
|
|
100
|
+
],
|
|
101
|
+
roles: [executionRole],
|
|
102
|
+
});
|
|
103
|
+
this.mapper = new aws_cdk_lib_1.CustomResource(this, 'AvailabilityZoneMapper', {
|
|
104
|
+
serviceToken: this.function.functionArn,
|
|
105
|
+
properties: props?.availabilityZoneNames !== undefined
|
|
106
|
+
? { AvailabilityZones: props.availabilityZoneNames }
|
|
107
|
+
: {},
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Gets the Availability Zone Id for the given Availability Zone Name in this account
|
|
112
|
+
* @param availabilityZoneName
|
|
113
|
+
* @returns
|
|
114
|
+
*/
|
|
115
|
+
availabilityZoneId(availabilityZoneName) {
|
|
116
|
+
return this.mapper.getAttString(availabilityZoneName);
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Gets the Availability Zone Name for the given Availability Zone Id in this account
|
|
120
|
+
* @param availabilityZoneId
|
|
121
|
+
* @returns
|
|
122
|
+
*/
|
|
123
|
+
availabilityZoneName(availabilityZoneId) {
|
|
124
|
+
return this.mapper.getAttString(availabilityZoneId);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Gets the prefix for the region used with Availability Zone Ids, for example
|
|
128
|
+
* in us-east-1, this returns "use1"
|
|
129
|
+
* @returns
|
|
130
|
+
*/
|
|
131
|
+
regionPrefixForAvailabilityZoneIds() {
|
|
132
|
+
return this.mapper.getAttString(aws_cdk_lib_1.Fn.ref('AWS::Region'));
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Returns an array for Availability Zone Ids for the supplied Availability Zone names,
|
|
136
|
+
* they are returned in the same order the names were provided
|
|
137
|
+
* @param availabilityZoneNames
|
|
138
|
+
* @returns
|
|
139
|
+
*/
|
|
140
|
+
availabilityZoneIdsAsArray(availabilityZoneNames) {
|
|
141
|
+
let ids = [];
|
|
142
|
+
for (let i = 0; i < availabilityZoneNames.length; i++) {
|
|
143
|
+
ids.push(this.availabilityZoneId(availabilityZoneNames[i]));
|
|
144
|
+
}
|
|
145
|
+
return ids;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Returns a comma delimited list of Availability Zone Ids for the supplied
|
|
149
|
+
* Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
150
|
+
* get a specific Availability Zone Id
|
|
151
|
+
* @param availabilityZoneNames
|
|
152
|
+
* @returns
|
|
153
|
+
*/
|
|
154
|
+
availabilityZoneIdsAsCommaDelimitedList(availabilityZoneNames) {
|
|
155
|
+
let ids = [];
|
|
156
|
+
for (let i = 0; i < availabilityZoneNames.length; i++) {
|
|
157
|
+
ids.push(this.availabilityZoneId(availabilityZoneNames[i]));
|
|
158
|
+
}
|
|
159
|
+
return ids.join(',');
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Returns a comma delimited list of Availability Zone Ids for the supplied
|
|
163
|
+
* Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
164
|
+
* get a specific Availability Zone Id
|
|
165
|
+
* @returns
|
|
166
|
+
*/
|
|
167
|
+
allAvailabilityZoneIdsAsCommaDelimitedList() {
|
|
168
|
+
return this.mapper.getAttString('AllAvailabilityZoneIds');
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Returns a reference that can be cast to a string array with all of the
|
|
172
|
+
* Availability Zone Ids
|
|
173
|
+
* @returns
|
|
174
|
+
*/
|
|
175
|
+
allAvailabilityZoneIdsAsArray() {
|
|
176
|
+
return this.mapper.getAtt('AllAvailabilityZoneIdsArray');
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Given a letter like "f" or "a", returns the Availability Zone Id for that
|
|
180
|
+
* Availability Zone name in this account
|
|
181
|
+
* @param letter
|
|
182
|
+
* @returns
|
|
183
|
+
*/
|
|
184
|
+
availabilityZoneIdFromAvailabilityZoneLetter(letter) {
|
|
185
|
+
return this.mapper.getAttString(letter);
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Gets all of the Availability Zone names in this Region as a comma delimited
|
|
189
|
+
* list. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
190
|
+
* get a specific Availability Zone Name
|
|
191
|
+
* @returns
|
|
192
|
+
*/
|
|
193
|
+
allAvailabilityZoneNamesAsCommaDelimitedList() {
|
|
194
|
+
return this.mapper.getAttString('AllAvailabilityZoneNames');
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
exports.AvailabilityZoneMapper = AvailabilityZoneMapper;
|
|
198
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
199
|
+
AvailabilityZoneMapper[_a] = { fqn: "@cdklabs/multi-az-observability.AvailabilityZoneMapper", version: "0.0.0-alpha.0" };
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AvailabilityZoneMapper.js","sourceRoot":"","sources":["../../src/azmapper/AvailabilityZoneMapper.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  CustomResource,\n  Duration,\n  Fn,\n  Reference,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport {\n  Effect,\n  IManagedPolicy,\n  IRole,\n  ManagedPolicy,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  Code,\n  Function,\n  IFunction,\n  Runtime,\n  Tracing,\n} from 'aws-cdk-lib/aws-lambda';\nimport { ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport { IAvailabilityZoneMapper } from './IAvailabilityZoneMapper';\nimport { AvailabilityZoneMapperProps } from './props/AvailabilityZoneMapperProps';\n\n/**\n * A construct that allows you to map AZ names to ids and back\n */\nexport class AvailabilityZoneMapper\n  extends Construct\n  implements IAvailabilityZoneMapper {\n  /**\n   * The function that does the mapping\n   */\n  function: IFunction;\n\n  /**\n   * The log group for the function's logs\n   */\n  logGroup: ILogGroup;\n\n  /**\n   * The custom resource that can be referenced to use\n   * Fn::GetAtt functions on to retrieve availability zone\n   * names and ids\n   */\n  mapper: CustomResource;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props?: AvailabilityZoneMapperProps,\n  ) {\n    super(scope, id);\n\n    /*\n    let currentNode: Construct | undefined = this.node.scope;\n\n    while (currentNode !== undefined && !(currentNode instanceof Stack)) {\n      currentNode = currentNode.node.scope;\n    }\n\n    if (currentNode !== undefined) {\n      (currentNode as Stack).addTransform('AWS::LanguageExtensions');\n    }\n    */\n\n    let xrayManagedPolicy: IManagedPolicy = new ManagedPolicy(\n      this,\n      'XrayManagedPolicy',\n      {\n        path: '/azmapper/',\n        statements: [\n          new PolicyStatement({\n            actions: [\n              'xray:PutTraceSegments',\n              'xray:PutTelemetryRecords',\n              'xray:GetSamplingRules',\n              'xray:GetSamplingTargets',\n              'xray:GetSamplingStatisticSummaries',\n            ],\n            effect: Effect.ALLOW,\n            resources: ['*'],\n          }),\n        ],\n      },\n    );\n\n    let ec2ManagedPolicy: IManagedPolicy = new ManagedPolicy(\n      this,\n      'EC2ManagedPolicy',\n      {\n        path: '/azmapper/',\n        statements: [\n          new PolicyStatement({\n            actions: ['ec2:DescribeAvailabilityZones'],\n            effect: Effect.ALLOW,\n            resources: ['*'],\n          }),\n        ],\n      },\n    );\n\n    let executionRole: IRole = new Role(this, 'executionRole', {\n      assumedBy: new ServicePrincipal('lambda.amazonaws.com'),\n      path: '/azmapper/',\n      managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],\n    });\n\n    const file: string = fs.readFileSync(\n      path.resolve(__dirname, './../azmapper/src/index.py'),\n      'utf-8',\n    );\n\n    this.function = new Function(this, 'AvailabilityZoneMapperFunction', {\n      runtime: Runtime.PYTHON_3_12,\n      code: Code.fromInline(file),\n      handler: 'index.handler',\n      role: executionRole,\n      architecture: Architecture.ARM_64,\n      tracing: Tracing.ACTIVE,\n      timeout: Duration.seconds(20),\n      memorySize: 512,\n      environment: {\n        REGION: Fn.ref('AWS::Region'),\n        PARTITION: Fn.ref('AWS::Partition'),\n      },\n    });\n\n    this.logGroup = new LogGroup(this, 'LogGroup', {\n      logGroupName: `/aws/lambda/${this.function.functionName}`,\n      retention: RetentionDays.ONE_DAY,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    new ManagedPolicy(this, 'CloudWatchManagedPolicy', {\n      path: '/azmapper/',\n      statements: [\n        new PolicyStatement({\n          actions: ['cloudwatch:PutMetricData'],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n        new PolicyStatement({\n          actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n          effect: Effect.ALLOW,\n          resources: [\n            Fn.sub(\n              'arn:${AWS::Partition}:logs:${AWS::Region}:${AWS::AccountId}:log-group:',\n            ) +\n              this.logGroup.logGroupName +\n              ':*',\n          ],\n        }),\n      ],\n      roles: [executionRole],\n    });\n\n    this.mapper = new CustomResource(this, 'AvailabilityZoneMapper', {\n      serviceToken: this.function.functionArn,\n      properties:\n        props?.availabilityZoneNames !== undefined\n          ? { AvailabilityZones: props.availabilityZoneNames }\n          : {},\n    });\n  }\n\n  /**\n   * Gets the Availability Zone Id for the given Availability Zone Name in this account\n   * @param availabilityZoneName\n   * @returns\n   */\n  availabilityZoneId(availabilityZoneName: string): string {\n    return this.mapper.getAttString(availabilityZoneName);\n  }\n\n  /**\n   * Gets the Availability Zone Name for the given Availability Zone Id in this account\n   * @param availabilityZoneId\n   * @returns\n   */\n  availabilityZoneName(availabilityZoneId: string): string {\n    return this.mapper.getAttString(availabilityZoneId);\n  }\n\n  /**\n   * Gets the prefix for the region used with Availability Zone Ids, for example\n   * in us-east-1, this returns \"use1\"\n   * @returns\n   */\n  regionPrefixForAvailabilityZoneIds(): string {\n    return this.mapper.getAttString(Fn.ref('AWS::Region'));\n  }\n\n  /**\n   * Returns an array for Availability Zone Ids for the supplied Availability Zone names,\n   * they are returned in the same order the names were provided\n   * @param availabilityZoneNames\n   * @returns\n   */\n  availabilityZoneIdsAsArray(availabilityZoneNames: string[]): string[] {\n    let ids: string[] = [];\n\n    for (let i = 0; i < availabilityZoneNames.length; i++) {\n      ids.push(this.availabilityZoneId(availabilityZoneNames[i]));\n    }\n\n    return ids;\n  }\n\n  /**\n   * Returns a comma delimited list of Availability Zone Ids for the supplied\n   * Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(\",\", azs)) to\n   * get a specific Availability Zone Id\n   * @param availabilityZoneNames\n   * @returns\n   */\n  availabilityZoneIdsAsCommaDelimitedList(\n    availabilityZoneNames: string[],\n  ): string {\n    let ids: string[] = [];\n\n    for (let i = 0; i < availabilityZoneNames.length; i++) {\n      ids.push(this.availabilityZoneId(availabilityZoneNames[i]));\n    }\n\n    return ids.join(',');\n  }\n\n  /**\n   * Returns a comma delimited list of Availability Zone Ids for the supplied\n   * Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(\",\", azs)) to\n   * get a specific Availability Zone Id\n   * @returns\n   */\n  allAvailabilityZoneIdsAsCommaDelimitedList(): string {\n    return this.mapper.getAttString('AllAvailabilityZoneIds');\n  }\n\n  /**\n   * Returns a reference that can be cast to a string array with all of the\n   * Availability Zone Ids\n   * @returns\n   */\n  allAvailabilityZoneIdsAsArray(): Reference {\n    return this.mapper.getAtt('AllAvailabilityZoneIdsArray');\n  }\n\n  /**\n   * Given a letter like \"f\" or \"a\", returns the Availability Zone Id for that\n   * Availability Zone name in this account\n   * @param letter\n   * @returns\n   */\n  availabilityZoneIdFromAvailabilityZoneLetter(letter: string): string {\n    return this.mapper.getAttString(letter);\n  }\n\n  /**\n   * Gets all of the Availability Zone names in this Region as a comma delimited\n   * list. You can use this string with Fn.Select(x, Fn.Split(\",\", azs)) to\n   * get a specific Availability Zone Name\n   * @returns\n   */\n  allAvailabilityZoneNamesAsCommaDelimitedList(): string {\n    return this.mapper.getAttString('AllAvailabilityZoneNames');\n  }\n}\n"]}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { CustomResource, Reference } from 'aws-cdk-lib';
|
|
2
|
+
import { IFunction } from 'aws-cdk-lib/aws-lambda';
|
|
3
|
+
import { ILogGroup } from 'aws-cdk-lib/aws-logs';
|
|
4
|
+
import { IConstruct } from 'constructs';
|
|
5
|
+
/**
|
|
6
|
+
* A wrapper for the Availability Zone mapper construct
|
|
7
|
+
* that allows you to translate Availability Zone names
|
|
8
|
+
* to Availability Zone Ids and vice a versa using the
|
|
9
|
+
* mapping in the AWS account where this is deployed.
|
|
10
|
+
*/
|
|
11
|
+
export interface IAvailabilityZoneMapper extends IConstruct {
|
|
12
|
+
/**
|
|
13
|
+
* The function that does the mapping
|
|
14
|
+
*/
|
|
15
|
+
function: IFunction;
|
|
16
|
+
/**
|
|
17
|
+
* The log group for the function's logs
|
|
18
|
+
*/
|
|
19
|
+
logGroup: ILogGroup;
|
|
20
|
+
/**
|
|
21
|
+
* The custom resource that can be referenced to use
|
|
22
|
+
* Fn::GetAtt functions on to retrieve availability zone
|
|
23
|
+
* names and ids
|
|
24
|
+
*/
|
|
25
|
+
mapper: CustomResource;
|
|
26
|
+
/**
|
|
27
|
+
* Gets the Availability Zone Id for the given Availability Zone Name in this account
|
|
28
|
+
* @param availabilityZoneName
|
|
29
|
+
* @returns
|
|
30
|
+
*/
|
|
31
|
+
availabilityZoneId(availabilityZoneName: string): string;
|
|
32
|
+
/**
|
|
33
|
+
* Gets the Availability Zone Name for the given Availability Zone Id in this account
|
|
34
|
+
* @param availabilityZoneId
|
|
35
|
+
* @returns
|
|
36
|
+
*/
|
|
37
|
+
availabilityZoneName(availabilityZoneId: string): string;
|
|
38
|
+
/**
|
|
39
|
+
* Gets the prefix for the region used with Availability Zone Ids, for example
|
|
40
|
+
* in us-east-1, this returns "use1"
|
|
41
|
+
* @returns
|
|
42
|
+
*/
|
|
43
|
+
regionPrefixForAvailabilityZoneIds(): string;
|
|
44
|
+
/**
|
|
45
|
+
* Returns an array for Availability Zone Ids for the supplied Availability Zone names,
|
|
46
|
+
* they are returned in the same order the names were provided
|
|
47
|
+
* @param availabilityZoneNames
|
|
48
|
+
* @returns
|
|
49
|
+
*/
|
|
50
|
+
availabilityZoneIdsAsArray(availabilityZoneNames: string[]): string[];
|
|
51
|
+
/**
|
|
52
|
+
* Returns a comma delimited list of Availability Zone Ids for the supplied
|
|
53
|
+
* Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
54
|
+
* get a specific Availability Zone Id
|
|
55
|
+
* @param availabilityZoneNames
|
|
56
|
+
* @returns
|
|
57
|
+
*/
|
|
58
|
+
availabilityZoneIdsAsCommaDelimitedList(availabilityZoneNames: string[]): string;
|
|
59
|
+
/**
|
|
60
|
+
* Returns a comma delimited list of Availability Zone Ids for the supplied
|
|
61
|
+
* Availability Zone names. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
62
|
+
* get a specific Availability Zone Id
|
|
63
|
+
* @returns
|
|
64
|
+
*/
|
|
65
|
+
allAvailabilityZoneIdsAsCommaDelimitedList(): string;
|
|
66
|
+
/**
|
|
67
|
+
* Returns a reference that can be cast to a string array with all of the
|
|
68
|
+
* Availability Zone Ids
|
|
69
|
+
* @returns
|
|
70
|
+
*/
|
|
71
|
+
allAvailabilityZoneIdsAsArray(): Reference;
|
|
72
|
+
/**
|
|
73
|
+
* Given a letter like "f" or "a", returns the Availability Zone Id for that
|
|
74
|
+
* Availability Zone name in this account
|
|
75
|
+
* @param letter
|
|
76
|
+
* @returns
|
|
77
|
+
*/
|
|
78
|
+
availabilityZoneIdFromAvailabilityZoneLetter(letter: string): string;
|
|
79
|
+
/**
|
|
80
|
+
* Gets all of the Availability Zone names in this Region as a comma delimited
|
|
81
|
+
* list. You can use this string with Fn.Select(x, Fn.Split(",", azs)) to
|
|
82
|
+
* get a specific Availability Zone Name
|
|
83
|
+
* @returns
|
|
84
|
+
*/
|
|
85
|
+
allAvailabilityZoneNamesAsCommaDelimitedList(): string;
|
|
86
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUF2YWlsYWJpbGl0eVpvbmVNYXBwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXptYXBwZXIvSUF2YWlsYWJpbGl0eVpvbmVNYXBwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbmltcG9ydCB7IEN1c3RvbVJlc291cmNlLCBSZWZlcmVuY2UgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBJRnVuY3Rpb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7IElMb2dHcm91cCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sb2dzJztcbmltcG9ydCB7IElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuLyoqXG4gKiBBIHdyYXBwZXIgZm9yIHRoZSBBdmFpbGFiaWxpdHkgWm9uZSBtYXBwZXIgY29uc3RydWN0XG4gKiB0aGF0IGFsbG93cyB5b3UgdG8gdHJhbnNsYXRlIEF2YWlsYWJpbGl0eSBab25lIG5hbWVzXG4gKiB0byBBdmFpbGFiaWxpdHkgWm9uZSBJZHMgYW5kIHZpY2UgYSB2ZXJzYSB1c2luZyB0aGVcbiAqIG1hcHBpbmcgaW4gdGhlIEFXUyBhY2NvdW50IHdoZXJlIHRoaXMgaXMgZGVwbG95ZWQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUF2YWlsYWJpbGl0eVpvbmVNYXBwZXIgZXh0ZW5kcyBJQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFRoZSBmdW5jdGlvbiB0aGF0IGRvZXMgdGhlIG1hcHBpbmdcbiAgICovXG4gIGZ1bmN0aW9uOiBJRnVuY3Rpb247XG5cbiAgLyoqXG4gICAqIFRoZSBsb2cgZ3JvdXAgZm9yIHRoZSBmdW5jdGlvbidzIGxvZ3NcbiAgICovXG4gIGxvZ0dyb3VwOiBJTG9nR3JvdXA7XG5cbiAgLyoqXG4gICAqIFRoZSBjdXN0b20gcmVzb3VyY2UgdGhhdCBjYW4gYmUgcmVmZXJlbmNlZCB0byB1c2VcbiAgICogRm46OkdldEF0dCBmdW5jdGlvbnMgb24gdG8gcmV0cmlldmUgYXZhaWxhYmlsaXR5IHpvbmVcbiAgICogbmFtZXMgYW5kIGlkc1xuICAgKi9cbiAgbWFwcGVyOiBDdXN0b21SZXNvdXJjZTtcblxuICAvKipcbiAgICogR2V0cyB0aGUgQXZhaWxhYmlsaXR5IFpvbmUgSWQgZm9yIHRoZSBnaXZlbiBBdmFpbGFiaWxpdHkgWm9uZSBOYW1lIGluIHRoaXMgYWNjb3VudFxuICAgKiBAcGFyYW0gYXZhaWxhYmlsaXR5Wm9uZU5hbWVcbiAgICogQHJldHVybnNcbiAgICovXG4gIGF2YWlsYWJpbGl0eVpvbmVJZChhdmFpbGFiaWxpdHlab25lTmFtZTogc3RyaW5nKTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSBBdmFpbGFiaWxpdHkgWm9uZSBOYW1lIGZvciB0aGUgZ2l2ZW4gQXZhaWxhYmlsaXR5IFpvbmUgSWQgaW4gdGhpcyBhY2NvdW50XG4gICAqIEBwYXJhbSBhdmFpbGFiaWxpdHlab25lSWRcbiAgICogQHJldHVybnNcbiAgICovXG4gIGF2YWlsYWJpbGl0eVpvbmVOYW1lKGF2YWlsYWJpbGl0eVpvbmVJZDogc3RyaW5nKTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSBwcmVmaXggZm9yIHRoZSByZWdpb24gdXNlZCB3aXRoIEF2YWlsYWJpbGl0eSBab25lIElkcywgZm9yIGV4YW1wbGVcbiAgICogaW4gdXMtZWFzdC0xLCB0aGlzIHJldHVybnMgXCJ1c2UxXCJcbiAgICogQHJldHVybnNcbiAgICovXG4gIHJlZ2lvblByZWZpeEZvckF2YWlsYWJpbGl0eVpvbmVJZHMoKTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGFuIGFycmF5IGZvciBBdmFpbGFiaWxpdHkgWm9uZSBJZHMgZm9yIHRoZSBzdXBwbGllZCBBdmFpbGFiaWxpdHkgWm9uZSBuYW1lcyxcbiAgICogdGhleSBhcmUgcmV0dXJuZWQgaW4gdGhlIHNhbWUgb3JkZXIgdGhlIG5hbWVzIHdlcmUgcHJvdmlkZWRcbiAgICogQHBhcmFtIGF2YWlsYWJpbGl0eVpvbmVOYW1lc1xuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgYXZhaWxhYmlsaXR5Wm9uZUlkc0FzQXJyYXkoYXZhaWxhYmlsaXR5Wm9uZU5hbWVzOiBzdHJpbmdbXSk6IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgY29tbWEgZGVsaW1pdGVkIGxpc3Qgb2YgQXZhaWxhYmlsaXR5IFpvbmUgSWRzIGZvciB0aGUgc3VwcGxpZWRcbiAgICogQXZhaWxhYmlsaXR5IFpvbmUgbmFtZXMuIFlvdSBjYW4gdXNlIHRoaXMgc3RyaW5nIHdpdGggRm4uU2VsZWN0KHgsIEZuLlNwbGl0KFwiLFwiLCBhenMpKSB0b1xuICAgKiBnZXQgYSBzcGVjaWZpYyBBdmFpbGFiaWxpdHkgWm9uZSBJZFxuICAgKiBAcGFyYW0gYXZhaWxhYmlsaXR5Wm9uZU5hbWVzXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBhdmFpbGFiaWxpdHlab25lSWRzQXNDb21tYURlbGltaXRlZExpc3QoXG4gICAgYXZhaWxhYmlsaXR5Wm9uZU5hbWVzOiBzdHJpbmdbXSxcbiAgKTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgY29tbWEgZGVsaW1pdGVkIGxpc3Qgb2YgQXZhaWxhYmlsaXR5IFpvbmUgSWRzIGZvciB0aGUgc3VwcGxpZWRcbiAgICogQXZhaWxhYmlsaXR5IFpvbmUgbmFtZXMuIFlvdSBjYW4gdXNlIHRoaXMgc3RyaW5nIHdpdGggRm4uU2VsZWN0KHgsIEZuLlNwbGl0KFwiLFwiLCBhenMpKSB0b1xuICAgKiBnZXQgYSBzcGVjaWZpYyBBdmFpbGFiaWxpdHkgWm9uZSBJZFxuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgYWxsQXZhaWxhYmlsaXR5Wm9uZUlkc0FzQ29tbWFEZWxpbWl0ZWRMaXN0KCk6IHN0cmluZztcblxuICAvKipcbiAgICogUmV0dXJucyBhIHJlZmVyZW5jZSB0aGF0IGNhbiBiZSBjYXN0IHRvIGEgc3RyaW5nIGFycmF5IHdpdGggYWxsIG9mIHRoZVxuICAgKiBBdmFpbGFiaWxpdHkgWm9uZSBJZHNcbiAgICogQHJldHVybnNcbiAgICovXG4gIGFsbEF2YWlsYWJpbGl0eVpvbmVJZHNBc0FycmF5KCk6IFJlZmVyZW5jZTtcblxuICAvKipcbiAgICogR2l2ZW4gYSBsZXR0ZXIgbGlrZSBcImZcIiBvciBcImFcIiwgcmV0dXJucyB0aGUgQXZhaWxhYmlsaXR5IFpvbmUgSWQgZm9yIHRoYXRcbiAgICogQXZhaWxhYmlsaXR5IFpvbmUgbmFtZSBpbiB0aGlzIGFjY291bnRcbiAgICogQHBhcmFtIGxldHRlclxuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgYXZhaWxhYmlsaXR5Wm9uZUlkRnJvbUF2YWlsYWJpbGl0eVpvbmVMZXR0ZXIobGV0dGVyOiBzdHJpbmcpOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEdldHMgYWxsIG9mIHRoZSBBdmFpbGFiaWxpdHkgWm9uZSBuYW1lcyBpbiB0aGlzIFJlZ2lvbiBhcyBhIGNvbW1hIGRlbGltaXRlZFxuICAgKiBsaXN0LiBZb3UgY2FuIHVzZSB0aGlzIHN0cmluZyB3aXRoIEZuLlNlbGVjdCh4LCBGbi5TcGxpdChcIixcIiwgYXpzKSkgdG9cbiAgICogZ2V0IGEgc3BlY2lmaWMgQXZhaWxhYmlsaXR5IFpvbmUgTmFtZVxuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgYWxsQXZhaWxhYmlsaXR5Wm9uZU5hbWVzQXNDb21tYURlbGltaXRlZExpc3QoKTogc3RyaW5nO1xufVxuIl19
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Properties for the AZ mapper
|
|
3
|
+
*/
|
|
4
|
+
export interface AvailabilityZoneMapperProps {
|
|
5
|
+
/**
|
|
6
|
+
* The currently in use Availability Zone names which
|
|
7
|
+
* constrains the list of AZ IDs that are returned
|
|
8
|
+
*
|
|
9
|
+
* @default - No names are provided and the mapper returns
|
|
10
|
+
* all AZs in the region in its lists
|
|
11
|
+
*/
|
|
12
|
+
readonly availabilityZoneNames?: string[];
|
|
13
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXZhaWxhYmlsaXR5Wm9uZU1hcHBlclByb3BzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6bWFwcGVyL3Byb3BzL0F2YWlsYWJpbGl0eVpvbmVNYXBwZXJQcm9wcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciB0aGUgQVogbWFwcGVyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXZhaWxhYmlsaXR5Wm9uZU1hcHBlclByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50bHkgaW4gdXNlIEF2YWlsYWJpbGl0eSBab25lIG5hbWVzIHdoaWNoXG4gICAqIGNvbnN0cmFpbnMgdGhlIGxpc3Qgb2YgQVogSURzIHRoYXQgYXJlIHJldHVybmVkXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gbmFtZXMgYXJlIHByb3ZpZGVkIGFuZCB0aGUgbWFwcGVyIHJldHVybnNcbiAgICogYWxsIEFacyBpbiB0aGUgcmVnaW9uIGluIGl0cyBsaXN0c1xuICAgKi9cbiAgcmVhZG9ubHkgYXZhaWxhYmlsaXR5Wm9uZU5hbWVzPzogc3RyaW5nW107XG59XG4iXX0=
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
# Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
+
# SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
import urllib3
|
|
4
|
+
import json
|
|
5
|
+
import os
|
|
6
|
+
import boto3
|
|
7
|
+
|
|
8
|
+
SUCCESS = "SUCCESS"
|
|
9
|
+
FAILED = "FAILED"
|
|
10
|
+
http = urllib3.PoolManager()
|
|
11
|
+
region = os.environ.get("AWS_REGION")
|
|
12
|
+
ec2 = boto3.client('ec2', region_name = region)
|
|
13
|
+
|
|
14
|
+
def handler(event, context):
|
|
15
|
+
try:
|
|
16
|
+
print(event)
|
|
17
|
+
if event['RequestType'] == 'Delete':
|
|
18
|
+
sendResponse(event, context, SUCCESS, {})
|
|
19
|
+
return
|
|
20
|
+
|
|
21
|
+
zone_names=[]
|
|
22
|
+
if 'ResourceProperties' in event and 'AvailabilityZones' in event['ResourceProperties'] and event['ResourceProperties']['AvailabilityZones'] != '':
|
|
23
|
+
zone_names = event['ResourceProperties']['AvailabilityZones']
|
|
24
|
+
|
|
25
|
+
in_use_azs = ec2.describe_availability_zones(Filters=[ { 'Name': 'zone-type', 'Values': [ 'availability-zone'] } ], ZoneNames = zone_names)
|
|
26
|
+
all_azs = ec2.describe_availability_zones(Filters=[ { 'Name': 'zone-type', 'Values': [ 'availability-zone'] } ])
|
|
27
|
+
|
|
28
|
+
az_map = {}
|
|
29
|
+
|
|
30
|
+
biggest_letter = sorted([x["ZoneName"][-1] for x in all_azs["AvailabilityZones"]], reverse=True)[0]
|
|
31
|
+
biggest_number = int(sorted([x["ZoneId"][-1] for x in all_azs["AvailabilityZones"]], reverse=True)[0])
|
|
32
|
+
|
|
33
|
+
for code in range(ord('a'), ord(biggest_letter) + 1):
|
|
34
|
+
az_map[chr(code)] = ""
|
|
35
|
+
|
|
36
|
+
for num in range(1, biggest_number + 1):
|
|
37
|
+
az_map["az" + str(num)] = ""
|
|
38
|
+
|
|
39
|
+
# Supply the region and get its shorthand
|
|
40
|
+
az_map[region] = all_azs["AvailabilityZones"][0]["ZoneId"].split("-")[0]
|
|
41
|
+
|
|
42
|
+
# Get the in use availability zone Ids as comma delimited list
|
|
43
|
+
az_map["InUseAvailabilityZoneIds"] = ",".join(x["ZoneId"] for x in in_use_azs["AvailabilityZones"])
|
|
44
|
+
|
|
45
|
+
# Get the in use availability zone Ids as an array
|
|
46
|
+
az_map["InUseAvailabilityZoneIdsArray"] = [x["ZoneId"] for x in in_use_azs["AvailabilityZones"]]
|
|
47
|
+
|
|
48
|
+
# Get the in use availability zone names as comma delimited list
|
|
49
|
+
az_map["InUseAvailabilityZoneNames"] = ",".join(x["ZoneName"] for x in in_use_azs["AvailabilityZones"])
|
|
50
|
+
|
|
51
|
+
# Get the in use availability zone names as an array
|
|
52
|
+
az_map["InUseAvailabilityZoneNames"] = ",".join(x["ZoneName"] for x in in_use_azs["AvailabilityZones"])
|
|
53
|
+
|
|
54
|
+
# Make a comma delimited list of name to id joined with a colon
|
|
55
|
+
az_map["InUseAvailabilityZoneNameToIdMap"] = ",".join(x["ZoneName"] + ":" + x["ZoneId"] for x in in_use_azs["AvailabilityZones"])
|
|
56
|
+
|
|
57
|
+
# Make a comma delimited list of name to id joined with a colon for all AZs
|
|
58
|
+
az_map["AllAvailabilityZoneNameToIdMap"] = ",".join(x["ZoneName"] + ":" + x["ZoneId"] for x in all_azs["AvailabilityZones"])
|
|
59
|
+
|
|
60
|
+
# All availability zones in the region
|
|
61
|
+
az_map["AllAvailabilityZoneIds"] = ",".join(x["ZoneId"] for x in all_azs["AvailabilityZones"])
|
|
62
|
+
az_map["AllAvailabilityZoneIdsArray"] = [x["ZoneId"] for x in all_azs["AvailabilityZones"]]
|
|
63
|
+
az_map["AllAvailabilityZoneNames"] = ",".join(x["ZoneName"] for x in all_azs["AvailabilityZones"])
|
|
64
|
+
az_map["AllAvailabilityZoneNamesArray"] = [x["ZoneName"] for x in all_azs["AvailabilityZones"]]
|
|
65
|
+
|
|
66
|
+
# Allow lookups for individual AZ names to Ids
|
|
67
|
+
for item in all_azs['AvailabilityZones']:
|
|
68
|
+
az_map[item['ZoneName']] = item['ZoneId']
|
|
69
|
+
az_map[item['ZoneId']] = item['ZoneName']
|
|
70
|
+
az_id = item['ZoneId'].split('-')[1].lower()
|
|
71
|
+
az_map[az_id] = item['ZoneName']
|
|
72
|
+
az_letter = item['ZoneName'][-1]
|
|
73
|
+
az_map[az_letter] = item['ZoneId']
|
|
74
|
+
|
|
75
|
+
print(json.dumps(az_map))
|
|
76
|
+
|
|
77
|
+
sendResponse(event, context, SUCCESS, az_map)
|
|
78
|
+
except Exception as e:
|
|
79
|
+
print(e)
|
|
80
|
+
sendResponse(event, context, FAILED, str(e))
|
|
81
|
+
return
|
|
82
|
+
|
|
83
|
+
def sendResponse(event, context, responseStatus, responseData, physicalResourceId=None, noEcho=False, reason=None):
|
|
84
|
+
responseUrl = event['ResponseURL']
|
|
85
|
+
print(responseUrl)
|
|
86
|
+
responseBody = {
|
|
87
|
+
'Status' : responseStatus,
|
|
88
|
+
'Reason' : reason or "See the details in CloudWatch Log Stream: {}".format(context.log_stream_name),
|
|
89
|
+
'PhysicalResourceId' : physicalResourceId or context.log_stream_name,
|
|
90
|
+
'StackId' : event['StackId'],
|
|
91
|
+
'RequestId' : event['RequestId'],
|
|
92
|
+
'LogicalResourceId' : event['LogicalResourceId'],
|
|
93
|
+
'NoEcho' : noEcho,
|
|
94
|
+
'Data' : responseData
|
|
95
|
+
}
|
|
96
|
+
json_responseBody = json.dumps(responseBody, default=str)
|
|
97
|
+
print("Response body:")
|
|
98
|
+
print(json_responseBody)
|
|
99
|
+
headers = {
|
|
100
|
+
'content-type' : '',
|
|
101
|
+
'content-length' : str(len(json_responseBody))
|
|
102
|
+
}
|
|
103
|
+
try:
|
|
104
|
+
response = http.request('PUT', responseUrl, headers=headers, body=json_responseBody)
|
|
105
|
+
print("Status code:", response.status)
|
|
106
|
+
except Exception as e:
|
|
107
|
+
print("send(...) failed executing http.request(..):", e)
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { IFunction } from 'aws-cdk-lib/aws-lambda';
|
|
2
|
+
import { ILogGroup } from 'aws-cdk-lib/aws-logs';
|
|
3
|
+
import { Construct } from 'constructs';
|
|
4
|
+
import { ICanaryFunction } from './ICanaryFunction';
|
|
5
|
+
import { CanaryFunctionProps } from './props/CanaryFunctionProps';
|
|
6
|
+
export declare class CanaryFunction extends Construct implements ICanaryFunction {
|
|
7
|
+
/**
|
|
8
|
+
* The canary function
|
|
9
|
+
*/
|
|
10
|
+
function: IFunction;
|
|
11
|
+
/**
|
|
12
|
+
* The log group where the canarty logs will be sent
|
|
13
|
+
*/
|
|
14
|
+
logGroup: ILogGroup;
|
|
15
|
+
constructor(scope: Construct, id: string, props: CanaryFunctionProps);
|
|
16
|
+
}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CanaryFunction = void 0;
|
|
4
|
+
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
5
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
6
|
+
const path = require("path");
|
|
7
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
8
|
+
const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
|
|
9
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
10
|
+
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
11
|
+
const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
12
|
+
const constructs_1 = require("constructs");
|
|
13
|
+
class CanaryFunction extends constructs_1.Construct {
|
|
14
|
+
constructor(scope, id, props) {
|
|
15
|
+
super(scope, id);
|
|
16
|
+
let xrayManagedPolicy = new aws_iam_1.ManagedPolicy(this, 'xrayManagedPolicy', {
|
|
17
|
+
path: '/canary/',
|
|
18
|
+
statements: [
|
|
19
|
+
new aws_iam_1.PolicyStatement({
|
|
20
|
+
actions: [
|
|
21
|
+
'xray:PutTraceSegments',
|
|
22
|
+
'xray:PutTelemetryRecords',
|
|
23
|
+
'xray:GetSamplingRules',
|
|
24
|
+
'xray:GetSamplingTargets',
|
|
25
|
+
'xray:GetSamplingStatisticSummaries',
|
|
26
|
+
],
|
|
27
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
28
|
+
resources: ['*'],
|
|
29
|
+
}),
|
|
30
|
+
],
|
|
31
|
+
});
|
|
32
|
+
let ec2ManagedPolicy = new aws_iam_1.ManagedPolicy(this, 'ec2ManagedPolicy', {
|
|
33
|
+
path: '/canary/',
|
|
34
|
+
statements: [
|
|
35
|
+
new aws_iam_1.PolicyStatement({
|
|
36
|
+
actions: [
|
|
37
|
+
'ec2:CreateNetworkInterface',
|
|
38
|
+
'ec2:DescribeNetworkInterfaces',
|
|
39
|
+
'ec2:DeleteNetworkInterface',
|
|
40
|
+
],
|
|
41
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
42
|
+
resources: ['*'],
|
|
43
|
+
}),
|
|
44
|
+
],
|
|
45
|
+
});
|
|
46
|
+
let executionRole = new aws_iam_1.Role(this, 'executionRole', {
|
|
47
|
+
assumedBy: new aws_iam_1.ServicePrincipal('lambda.amazonaws.com'),
|
|
48
|
+
path: '/canary/',
|
|
49
|
+
managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],
|
|
50
|
+
});
|
|
51
|
+
/*
|
|
52
|
+
let code: AssetCode = Code.fromAsset(path.join(__dirname, "src/"), {
|
|
53
|
+
bundling: {
|
|
54
|
+
//image: new Runtime('python3.12:latest-arm64', RuntimeFamily.PYTHON).bundlingImage,
|
|
55
|
+
image: Runtime.PYTHON_3_12.bundlingImage,
|
|
56
|
+
command: [
|
|
57
|
+
'bash', '-c',
|
|
58
|
+
'pip install --no-cache -r requirements.txt -t /asset-output && cp --archive --update . /asset-output',
|
|
59
|
+
],
|
|
60
|
+
platform: 'linux/arm64',
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
*/
|
|
64
|
+
let monitoringLayer = new aws_lambda_1.LayerVersion(this, 'MonitoringLayer', {
|
|
65
|
+
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, '../monitoring/src/monitoring-layer.zip')),
|
|
66
|
+
compatibleArchitectures: [aws_lambda_1.Architecture.ARM_64],
|
|
67
|
+
compatibleRuntimes: [aws_lambda_1.Runtime.PYTHON_3_12],
|
|
68
|
+
});
|
|
69
|
+
if (props.vpc !== undefined && props.vpc != null) {
|
|
70
|
+
let sg = new aws_ec2_1.SecurityGroup(this, 'canarySecurityGroup', {
|
|
71
|
+
description: 'Allow canary to communicate with load balancer',
|
|
72
|
+
vpc: props.vpc,
|
|
73
|
+
allowAllOutbound: true,
|
|
74
|
+
});
|
|
75
|
+
this.function = new aws_lambda_1.Function(this, 'canary', {
|
|
76
|
+
runtime: aws_lambda_1.Runtime.PYTHON_3_12,
|
|
77
|
+
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, 'src/canary.zip')),
|
|
78
|
+
handler: 'index.handler',
|
|
79
|
+
role: executionRole,
|
|
80
|
+
architecture: aws_lambda_1.Architecture.ARM_64,
|
|
81
|
+
tracing: aws_lambda_1.Tracing.ACTIVE,
|
|
82
|
+
timeout: aws_cdk_lib_1.Duration.seconds(240),
|
|
83
|
+
memorySize: 512,
|
|
84
|
+
layers: [monitoringLayer],
|
|
85
|
+
environment: {
|
|
86
|
+
REGION: aws_cdk_lib_1.Fn.ref('AWS::Region'),
|
|
87
|
+
PARTITION: aws_cdk_lib_1.Fn.ref('AWS::Partition'),
|
|
88
|
+
TIMEOUT: props.httpTimeout !== undefined
|
|
89
|
+
? props.httpTimeout.toSeconds().toString()
|
|
90
|
+
: '2',
|
|
91
|
+
IGNORE_SSL_ERRORS: (props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true)
|
|
92
|
+
.toString()
|
|
93
|
+
.toLowerCase(),
|
|
94
|
+
},
|
|
95
|
+
vpc: props.vpc,
|
|
96
|
+
securityGroups: [sg],
|
|
97
|
+
vpcSubnets: props.subnetSelection,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.function = new aws_lambda_1.Function(this, 'canary', {
|
|
102
|
+
runtime: aws_lambda_1.Runtime.PYTHON_3_12,
|
|
103
|
+
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, 'src/canary.zip')),
|
|
104
|
+
handler: 'index.handler',
|
|
105
|
+
role: executionRole,
|
|
106
|
+
architecture: aws_lambda_1.Architecture.ARM_64,
|
|
107
|
+
tracing: aws_lambda_1.Tracing.ACTIVE,
|
|
108
|
+
timeout: aws_cdk_lib_1.Duration.seconds(240),
|
|
109
|
+
memorySize: 512,
|
|
110
|
+
layers: [monitoringLayer],
|
|
111
|
+
environment: {
|
|
112
|
+
REGION: aws_cdk_lib_1.Fn.ref('AWS::Region'),
|
|
113
|
+
PARTITION: aws_cdk_lib_1.Fn.ref('AWS::Partition'),
|
|
114
|
+
TIMEOUT: props.httpTimeout !== undefined
|
|
115
|
+
? props.httpTimeout.toSeconds().toString()
|
|
116
|
+
: '2',
|
|
117
|
+
IGNORE_SSL_ERRORS: (props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true)
|
|
118
|
+
.toString()
|
|
119
|
+
.toLowerCase(),
|
|
120
|
+
},
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
this.function.addPermission('invokePermission', {
|
|
124
|
+
action: 'lambda:InvokeFunction',
|
|
125
|
+
principal: new aws_iam_1.ServicePrincipal('events.amazonaws.com'),
|
|
126
|
+
sourceArn: aws_cdk_lib_1.Fn.sub('arn:${AWS::Partition}:events:${AWS::Region}:${AWS::AccountId}:rule/*'),
|
|
127
|
+
});
|
|
128
|
+
this.logGroup = new aws_logs_1.LogGroup(this, 'logGroup', {
|
|
129
|
+
logGroupName: `/aws/lambda/${this.function.functionName}`,
|
|
130
|
+
retention: aws_logs_1.RetentionDays.ONE_WEEK,
|
|
131
|
+
removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
132
|
+
});
|
|
133
|
+
new aws_iam_1.ManagedPolicy(this, 'cwManagedPolicy', {
|
|
134
|
+
path: '/canary/',
|
|
135
|
+
statements: [
|
|
136
|
+
new aws_iam_1.PolicyStatement({
|
|
137
|
+
actions: ['cloudwatch:PutMetricData'],
|
|
138
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
139
|
+
resources: ['*'],
|
|
140
|
+
}),
|
|
141
|
+
new aws_iam_1.PolicyStatement({
|
|
142
|
+
actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],
|
|
143
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
144
|
+
resources: [this.logGroup.logGroupArn],
|
|
145
|
+
}),
|
|
146
|
+
],
|
|
147
|
+
roles: [executionRole],
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
exports.CanaryFunction = CanaryFunction;
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CanaryFunction.js","sourceRoot":"","sources":["../../src/canaries/CanaryFunction.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport * as path from 'path';\nimport { Duration, Fn, RemovalPolicy } from 'aws-cdk-lib';\nimport { ISecurityGroup, SecurityGroup } from 'aws-cdk-lib/aws-ec2';\nimport {\n  Effect,\n  IManagedPolicy,\n  IRole,\n  ManagedPolicy,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  Code,\n  Function,\n  IFunction,\n  ILayerVersion,\n  LayerVersion,\n  Runtime,\n  Tracing,\n} from 'aws-cdk-lib/aws-lambda';\nimport { ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport { ICanaryFunction } from './ICanaryFunction';\nimport { CanaryFunctionProps } from './props/CanaryFunctionProps';\n\nexport class CanaryFunction extends Construct implements ICanaryFunction {\n  /**\n   * The canary function\n   */\n  function: IFunction;\n\n  /**\n   * The log group where the canarty logs will be sent\n   */\n  logGroup: ILogGroup;\n\n  constructor(scope: Construct, id: string, props: CanaryFunctionProps) {\n    super(scope, id);\n\n    let xrayManagedPolicy: IManagedPolicy = new ManagedPolicy(\n      this,\n      'xrayManagedPolicy',\n      {\n        path: '/canary/',\n        statements: [\n          new PolicyStatement({\n            actions: [\n              'xray:PutTraceSegments',\n              'xray:PutTelemetryRecords',\n              'xray:GetSamplingRules',\n              'xray:GetSamplingTargets',\n              'xray:GetSamplingStatisticSummaries',\n            ],\n            effect: Effect.ALLOW,\n            resources: ['*'],\n          }),\n        ],\n      },\n    );\n    let ec2ManagedPolicy = new ManagedPolicy(this, 'ec2ManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: [\n            'ec2:CreateNetworkInterface',\n            'ec2:DescribeNetworkInterfaces',\n            'ec2:DeleteNetworkInterface',\n          ],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n      ],\n    });\n\n    let executionRole: IRole = new Role(this, 'executionRole', {\n      assumedBy: new ServicePrincipal('lambda.amazonaws.com'),\n      path: '/canary/',\n      managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],\n    });\n\n    /*\n    let code: AssetCode = Code.fromAsset(path.join(__dirname, \"src/\"), {\n      bundling: {\n        //image: new Runtime('python3.12:latest-arm64', RuntimeFamily.PYTHON).bundlingImage,\n        image: Runtime.PYTHON_3_12.bundlingImage,\n        command: [\n          'bash', '-c',\n          'pip install --no-cache -r requirements.txt -t /asset-output && cp --archive --update . /asset-output',\n        ],\n        platform: 'linux/arm64',\n      },\n    });\n    */\n    let monitoringLayer: ILayerVersion = new LayerVersion(\n      this,\n      'MonitoringLayer',\n      {\n        code: Code.fromAsset(\n          path.join(__dirname, '../monitoring/src/monitoring-layer.zip'),\n        ),\n        compatibleArchitectures: [Architecture.ARM_64],\n        compatibleRuntimes: [Runtime.PYTHON_3_12],\n      },\n    );\n\n    if (props.vpc !== undefined && props.vpc != null) {\n      let sg: ISecurityGroup = new SecurityGroup(this, 'canarySecurityGroup', {\n        description: 'Allow canary to communicate with load balancer',\n        vpc: props.vpc,\n        allowAllOutbound: true,\n      });\n\n      this.function = new Function(this, 'canary', {\n        runtime: Runtime.PYTHON_3_12,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n        vpc: props.vpc,\n        securityGroups: [sg],\n        vpcSubnets: props.subnetSelection,\n      });\n    } else {\n      this.function = new Function(this, 'canary', {\n        runtime: Runtime.PYTHON_3_12,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n      });\n    }\n\n    this.function.addPermission('invokePermission', {\n      action: 'lambda:InvokeFunction',\n      principal: new ServicePrincipal('events.amazonaws.com'),\n      sourceArn: Fn.sub(\n        'arn:${AWS::Partition}:events:${AWS::Region}:${AWS::AccountId}:rule/*',\n      ),\n    });\n\n    this.logGroup = new LogGroup(this, 'logGroup', {\n      logGroupName: `/aws/lambda/${this.function.functionName}`,\n      retention: RetentionDays.ONE_WEEK,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    new ManagedPolicy(this, 'cwManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: ['cloudwatch:PutMetricData'],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n        new PolicyStatement({\n          actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n          effect: Effect.ALLOW,\n          resources: [this.logGroup.logGroupArn],\n        }),\n      ],\n      roles: [executionRole],\n    });\n  }\n}\n"]}
|