@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.
Files changed (212) hide show
  1. package/.jsii +10177 -0
  2. package/API.md +5119 -0
  3. package/LICENSE +202 -0
  4. package/README.md +175 -0
  5. package/cdk.json +68 -0
  6. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +214 -0
  7. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +763 -0
  8. package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.d.ts +22 -0
  9. package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.js +21 -0
  10. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +34 -0
  11. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +39 -0
  12. package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.d.ts +7 -0
  13. package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.js +11 -0
  14. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.d.ts +16 -0
  15. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +17 -0
  16. package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.d.ts +18 -0
  17. package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.js +3 -0
  18. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +30 -0
  19. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +3 -0
  20. package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.d.ts +6 -0
  21. package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.js +3 -0
  22. package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.d.ts +12 -0
  23. package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.js +3 -0
  24. package/lib/alarmsandrules/IOperationAlarmsAndRules.d.ts +55 -0
  25. package/lib/alarmsandrules/IOperationAlarmsAndRules.js +3 -0
  26. package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.d.ts +15 -0
  27. package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.js +3 -0
  28. package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.d.ts +36 -0
  29. package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.js +3 -0
  30. package/lib/alarmsandrules/IServiceAlarmsAndRules.d.ts +44 -0
  31. package/lib/alarmsandrules/IServiceAlarmsAndRules.js +3 -0
  32. package/lib/alarmsandrules/InsightRuleBody.d.ts +67 -0
  33. package/lib/alarmsandrules/InsightRuleBody.js +46 -0
  34. package/lib/alarmsandrules/OperationAlarmsAndRules.d.ts +59 -0
  35. package/lib/alarmsandrules/OperationAlarmsAndRules.js +135 -0
  36. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.d.ts +19 -0
  37. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.js +22 -0
  38. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.d.ts +40 -0
  39. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +46 -0
  40. package/lib/alarmsandrules/ServiceAlarmsAndRules.d.ts +48 -0
  41. package/lib/alarmsandrules/ServiceAlarmsAndRules.js +166 -0
  42. package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.d.ts +24 -0
  43. package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.js +3 -0
  44. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +62 -0
  45. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +3 -0
  46. package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
  47. package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.js +3 -0
  48. package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.d.ts +6 -0
  49. package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.js +3 -0
  50. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.d.ts +45 -0
  51. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.js +3 -0
  52. package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
  53. package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.js +3 -0
  54. package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.d.ts +6 -0
  55. package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.js +3 -0
  56. package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.d.ts +13 -0
  57. package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.js +3 -0
  58. package/lib/azmapper/AvailabilityZoneMapper.d.ts +86 -0
  59. package/lib/azmapper/AvailabilityZoneMapper.js +200 -0
  60. package/lib/azmapper/IAvailabilityZoneMapper.d.ts +86 -0
  61. package/lib/azmapper/IAvailabilityZoneMapper.js +3 -0
  62. package/lib/azmapper/props/AvailabilityZoneMapperProps.d.ts +13 -0
  63. package/lib/azmapper/props/AvailabilityZoneMapperProps.js +3 -0
  64. package/lib/azmapper/src/index.py +107 -0
  65. package/lib/canaries/CanaryFunction.d.ts +16 -0
  66. package/lib/canaries/CanaryFunction.js +152 -0
  67. package/lib/canaries/CanaryTest.d.ts +10 -0
  68. package/lib/canaries/CanaryTest.js +84 -0
  69. package/lib/canaries/ICanaryFunction.d.ts +6 -0
  70. package/lib/canaries/ICanaryFunction.js +3 -0
  71. package/lib/canaries/props/AddCanaryTestProps.d.ts +66 -0
  72. package/lib/canaries/props/AddCanaryTestProps.js +3 -0
  73. package/lib/canaries/props/CanaryFunctionProps.d.ts +29 -0
  74. package/lib/canaries/props/CanaryFunctionProps.js +3 -0
  75. package/lib/canaries/props/CanaryTestProps.d.ts +21 -0
  76. package/lib/canaries/props/CanaryTestProps.js +3 -0
  77. package/lib/canaries/props/NetworkConfigurationProps.d.ts +16 -0
  78. package/lib/canaries/props/NetworkConfigurationProps.js +3 -0
  79. package/lib/canaries/src/canary.zip +0 -0
  80. package/lib/dashboards/BasicServiceDashboard.d.ts +10 -0
  81. package/lib/dashboards/BasicServiceDashboard.js +130 -0
  82. package/lib/dashboards/ContributorInsightsWidget.d.ts +22 -0
  83. package/lib/dashboards/ContributorInsightsWidget.js +55 -0
  84. package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.d.ts +10 -0
  85. package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.js +3 -0
  86. package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.d.ts +10 -0
  87. package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.js +3 -0
  88. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +20 -0
  89. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +588 -0
  90. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +24 -0
  91. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +475 -0
  92. package/lib/dashboards/props/BasicServiceDashboardProps.d.ts +23 -0
  93. package/lib/dashboards/props/BasicServiceDashboardProps.js +3 -0
  94. package/lib/dashboards/props/ContributorInsightWidgetProps.d.ts +31 -0
  95. package/lib/dashboards/props/ContributorInsightWidgetProps.js +3 -0
  96. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +84 -0
  97. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +3 -0
  98. package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +37 -0
  99. package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +3 -0
  100. package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +37 -0
  101. package/lib/dashboards/props/OperationLatencyWidgetProps.js +3 -0
  102. package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.d.ts +30 -0
  103. package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.js +3 -0
  104. package/lib/index.d.ts +35 -0
  105. package/lib/index.js +30 -0
  106. package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +36 -0
  107. package/lib/metrics/ApplicationLoadBalancerMetrics.js +150 -0
  108. package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +61 -0
  109. package/lib/metrics/AvailabilityAndLatencyMetrics.js +212 -0
  110. package/lib/metrics/NetworkLoadBalancerMetrics.d.ts +19 -0
  111. package/lib/metrics/NetworkLoadBalancerMetrics.js +48 -0
  112. package/lib/metrics/RegionalAvailabilityMetrics.d.ts +19 -0
  113. package/lib/metrics/RegionalAvailabilityMetrics.js +71 -0
  114. package/lib/metrics/RegionalLatencyMetrics.d.ts +33 -0
  115. package/lib/metrics/RegionalLatencyMetrics.js +69 -0
  116. package/lib/metrics/ZonalAvailabilityMetrics.d.ts +19 -0
  117. package/lib/metrics/ZonalAvailabilityMetrics.js +71 -0
  118. package/lib/metrics/ZonalLatencyMetrics.d.ts +29 -0
  119. package/lib/metrics/ZonalLatencyMetrics.js +65 -0
  120. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +23 -0
  121. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +3 -0
  122. package/lib/metrics/props/AvailabilityMetricProps.d.ts +11 -0
  123. package/lib/metrics/props/AvailabilityMetricProps.js +3 -0
  124. package/lib/metrics/props/LatencyMetricProps.d.ts +15 -0
  125. package/lib/metrics/props/LatencyMetricProps.js +3 -0
  126. package/lib/metrics/props/RegionalAvailabilityMetricProps.d.ts +6 -0
  127. package/lib/metrics/props/RegionalAvailabilityMetricProps.js +3 -0
  128. package/lib/metrics/props/RegionalLatencyMetricProps.d.ts +6 -0
  129. package/lib/metrics/props/RegionalLatencyMetricProps.js +3 -0
  130. package/lib/metrics/props/ServiceAvailabilityMetricProps.d.ts +23 -0
  131. package/lib/metrics/props/ServiceAvailabilityMetricProps.js +3 -0
  132. package/lib/metrics/props/ServiceLatencyMericProps.d.ts +23 -0
  133. package/lib/metrics/props/ServiceLatencyMericProps.js +3 -0
  134. package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +10 -0
  135. package/lib/metrics/props/ZonalAvailabilityMetricProps.js +3 -0
  136. package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +10 -0
  137. package/lib/metrics/props/ZonalLatencyMetricProps.js +3 -0
  138. package/lib/monitoring/src/monitoring-layer.zip +0 -0
  139. package/lib/outlier-detection/IOutlierDetectionFunction.d.ts +12 -0
  140. package/lib/outlier-detection/IOutlierDetectionFunction.js +3 -0
  141. package/lib/outlier-detection/OutlierDetectionFunction.d.ts +16 -0
  142. package/lib/outlier-detection/OutlierDetectionFunction.js +126 -0
  143. package/lib/outlier-detection/props/OutlierDetectionFunctionProps.d.ts +12 -0
  144. package/lib/outlier-detection/props/OutlierDetectionFunctionProps.js +3 -0
  145. package/lib/outlier-detection/src/outlier-detection.zip +0 -0
  146. package/lib/outlier-detection/src/scipy-layer.zip +0 -0
  147. package/lib/services/BasicServiceMultiAZObservability.d.ts +64 -0
  148. package/lib/services/BasicServiceMultiAZObservability.js +504 -0
  149. package/lib/services/CanaryMetrics.d.ts +17 -0
  150. package/lib/services/CanaryMetrics.js +19 -0
  151. package/lib/services/CanaryTestMetricsOverride.d.ts +39 -0
  152. package/lib/services/CanaryTestMetricsOverride.js +23 -0
  153. package/lib/services/ContributorInsightRuleDetails.d.ts +42 -0
  154. package/lib/services/ContributorInsightRuleDetails.js +23 -0
  155. package/lib/services/IBasicServiceMultiAZObservability.d.ts +45 -0
  156. package/lib/services/IBasicServiceMultiAZObservability.js +3 -0
  157. package/lib/services/ICanaryMetrics.d.ts +14 -0
  158. package/lib/services/ICanaryMetrics.js +3 -0
  159. package/lib/services/ICanaryTestMetricsOverride.d.ts +36 -0
  160. package/lib/services/ICanaryTestMetricsOverride.js +3 -0
  161. package/lib/services/IContributorInsightRuleDetails.d.ts +38 -0
  162. package/lib/services/IContributorInsightRuleDetails.js +3 -0
  163. package/lib/services/IInstrumentedServiceMultiAZObservability.d.ts +39 -0
  164. package/lib/services/IInstrumentedServiceMultiAZObservability.js +3 -0
  165. package/lib/services/IOperation.d.ts +75 -0
  166. package/lib/services/IOperation.js +3 -0
  167. package/lib/services/IOperationMetricDetails.d.ts +78 -0
  168. package/lib/services/IOperationMetricDetails.js +3 -0
  169. package/lib/services/IService.d.ts +76 -0
  170. package/lib/services/IService.js +3 -0
  171. package/lib/services/IServiceMetricDetails.d.ts +68 -0
  172. package/lib/services/IServiceMetricDetails.js +3 -0
  173. package/lib/services/InstrumentedServiceMultiAZObservability.d.ts +55 -0
  174. package/lib/services/InstrumentedServiceMultiAZObservability.js +310 -0
  175. package/lib/services/Operation.d.ts +78 -0
  176. package/lib/services/Operation.js +34 -0
  177. package/lib/services/OperationMetricDetails.d.ts +82 -0
  178. package/lib/services/OperationMetricDetails.js +50 -0
  179. package/lib/services/Service.d.ts +80 -0
  180. package/lib/services/Service.js +36 -0
  181. package/lib/services/ServiceMetricDetails.d.ts +71 -0
  182. package/lib/services/ServiceMetricDetails.js +28 -0
  183. package/lib/services/props/BasicServiceMultiAZObservabilityProps.d.ts +126 -0
  184. package/lib/services/props/BasicServiceMultiAZObservabilityProps.js +3 -0
  185. package/lib/services/props/CanaryMetricProps.d.ts +14 -0
  186. package/lib/services/props/CanaryMetricProps.js +3 -0
  187. package/lib/services/props/CanaryTestMetricsOverrideProps.d.ts +47 -0
  188. package/lib/services/props/CanaryTestMetricsOverrideProps.js +3 -0
  189. package/lib/services/props/ContributorInsightRuleDetailsProps.d.ts +38 -0
  190. package/lib/services/props/ContributorInsightRuleDetailsProps.js +3 -0
  191. package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.d.ts +88 -0
  192. package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.js +3 -0
  193. package/lib/services/props/MetricDimensions.d.ts +61 -0
  194. package/lib/services/props/MetricDimensions.js +63 -0
  195. package/lib/services/props/OperationMetricDetailsProps.d.ts +97 -0
  196. package/lib/services/props/OperationMetricDetailsProps.js +3 -0
  197. package/lib/services/props/OperationProps.d.ts +93 -0
  198. package/lib/services/props/OperationProps.js +3 -0
  199. package/lib/services/props/ServiceMetricDetailsProps.d.ts +68 -0
  200. package/lib/services/props/ServiceMetricDetailsProps.js +3 -0
  201. package/lib/services/props/ServiceProps.d.ts +69 -0
  202. package/lib/services/props/ServiceProps.js +3 -0
  203. package/lib/utilities/AvailabilityMetricType.d.ts +26 -0
  204. package/lib/utilities/AvailabilityMetricType.js +33 -0
  205. package/lib/utilities/LatencyMetricType.d.ts +13 -0
  206. package/lib/utilities/LatencyMetricType.js +20 -0
  207. package/lib/utilities/OutlierDetectionAlgorithm.d.ts +42 -0
  208. package/lib/utilities/OutlierDetectionAlgorithm.js +49 -0
  209. package/lib/utilities/StackWithDynamicSource.d.ts +14 -0
  210. package/lib/utilities/StackWithDynamicSource.js +82 -0
  211. package/package.json +176 -0
  212. 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"]}