construct-hub 0.4.412 → 0.4.413

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/API.md CHANGED
@@ -94,6 +94,7 @@ Any object.
94
94
  | <code><a href="#construct-hub.ConstructHub.property.highSeverityAlarms">highSeverityAlarms</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarm[]</code> | Returns a list of all high-severity alarms from this ConstructHub instance. |
95
95
  | <code><a href="#construct-hub.ConstructHub.property.ingestionQueue">ingestionQueue</a></code> | <code>aws-cdk-lib.aws_sqs.IQueue</code> | *No description.* |
96
96
  | <code><a href="#construct-hub.ConstructHub.property.lowSeverityAlarms">lowSeverityAlarms</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarm[]</code> | Returns a list of all low-severity alarms from this ConstructHub instance. |
97
+ | <code><a href="#construct-hub.ConstructHub.property.mediumSeverityAlarms">mediumSeverityAlarms</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarm[]</code> | Returns a list of all low-severity alarms from this ConstructHub instance. |
97
98
  | <code><a href="#construct-hub.ConstructHub.property.regenerateAllDocumentationPerPackage">regenerateAllDocumentationPerPackage</a></code> | <code>aws-cdk-lib.aws_stepfunctions.IStateMachine</code> | The function operators can use to reprocess a specific package version through the backend data pipeline. |
98
99
 
99
100
  ---
@@ -175,6 +176,22 @@ that something unusual (not necessarily bad) is happening.
175
176
 
176
177
  ---
177
178
 
179
+ ##### `mediumSeverityAlarms`<sup>Required</sup> <a name="mediumSeverityAlarms" id="construct-hub.ConstructHub.property.mediumSeverityAlarms"></a>
180
+
181
+ ```typescript
182
+ public readonly mediumSeverityAlarms: IAlarm[];
183
+ ```
184
+
185
+ - *Type:* aws-cdk-lib.aws_cloudwatch.IAlarm[]
186
+
187
+ Returns a list of all low-severity alarms from this ConstructHub instance.
188
+
189
+ These do not necessitate immediate attention, as they do not have direct
190
+ customer-visible impact, or handling is not time-sensitive. They indicate
191
+ that something unusual (not necessarily bad) is happening.
192
+
193
+ ---
194
+
178
195
  ##### `regenerateAllDocumentationPerPackage`<sup>Required</sup> <a name="regenerateAllDocumentationPerPackage" id="construct-hub.ConstructHub.property.regenerateAllDocumentationPerPackage"></a>
179
196
 
180
197
  ```typescript
@@ -327,6 +344,8 @@ const alarmActions: AlarmActions = { ... }
327
344
  | --- | --- | --- |
328
345
  | <code><a href="#construct-hub.AlarmActions.property.highSeverity">highSeverity</a></code> | <code>string</code> | The ARN of the CloudWatch alarm action to take for alarms of high-severity alarms. |
329
346
  | <code><a href="#construct-hub.AlarmActions.property.highSeverityAction">highSeverityAction</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarmAction</code> | The CloudWatch alarm action to take for alarms of high-severity alarms. |
347
+ | <code><a href="#construct-hub.AlarmActions.property.mediumSeverity">mediumSeverity</a></code> | <code>string</code> | The ARN of the CloudWatch alarm action to take for alarms of medium-severity alarms. |
348
+ | <code><a href="#construct-hub.AlarmActions.property.mediumSeverityAction">mediumSeverityAction</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarmAction</code> | The CloudWatch alarm action to take for alarms of medium-severity alarms. |
330
349
  | <code><a href="#construct-hub.AlarmActions.property.normalSeverity">normalSeverity</a></code> | <code>string</code> | The ARN of the CloudWatch alarm action to take for alarms of normal severity. |
331
350
  | <code><a href="#construct-hub.AlarmActions.property.normalSeverityAction">normalSeverityAction</a></code> | <code>aws-cdk-lib.aws_cloudwatch.IAlarmAction</code> | The CloudWatch alarm action to take for alarms of normal severity. |
332
351
 
@@ -364,6 +383,38 @@ This must be an ARN that can be used with CloudWatch alarms.
364
383
 
365
384
  ---
366
385
 
386
+ ##### `mediumSeverity`<sup>Optional</sup> <a name="mediumSeverity" id="construct-hub.AlarmActions.property.mediumSeverity"></a>
387
+
388
+ ```typescript
389
+ public readonly mediumSeverity: string;
390
+ ```
391
+
392
+ - *Type:* string
393
+
394
+ The ARN of the CloudWatch alarm action to take for alarms of medium-severity alarms.
395
+
396
+ This must be an ARN that can be used with CloudWatch alarms.
397
+
398
+ > [https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions](https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions)
399
+
400
+ ---
401
+
402
+ ##### `mediumSeverityAction`<sup>Optional</sup> <a name="mediumSeverityAction" id="construct-hub.AlarmActions.property.mediumSeverityAction"></a>
403
+
404
+ ```typescript
405
+ public readonly mediumSeverityAction: IAlarmAction;
406
+ ```
407
+
408
+ - *Type:* aws-cdk-lib.aws_cloudwatch.IAlarmAction
409
+
410
+ The CloudWatch alarm action to take for alarms of medium-severity alarms.
411
+
412
+ This must be an ARN that can be used with CloudWatch alarms.
413
+
414
+ > [https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions](https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions)
415
+
416
+ ---
417
+
367
418
  ##### `normalSeverity`<sup>Optional</sup> <a name="normalSeverity" id="construct-hub.AlarmActions.property.normalSeverity"></a>
368
419
 
369
420
  ```typescript
@@ -13679,6 +13730,7 @@ ConstructHub monitoring features exposed to extension points.
13679
13730
  | --- | --- |
13680
13731
  | <code><a href="#construct-hub.IMonitoring.addHighSeverityAlarm">addHighSeverityAlarm</a></code> | Adds a high-severity alarm. |
13681
13732
  | <code><a href="#construct-hub.IMonitoring.addLowSeverityAlarm">addLowSeverityAlarm</a></code> | Adds a low-severity alarm. |
13733
+ | <code><a href="#construct-hub.IMonitoring.addMediumSeverityAlarm">addMediumSeverityAlarm</a></code> | Adds a medium-severity alarm. |
13682
13734
 
13683
13735
  ---
13684
13736
 
@@ -13736,6 +13788,33 @@ the alarm to be added.
13736
13788
 
13737
13789
  ---
13738
13790
 
13791
+ ##### `addMediumSeverityAlarm` <a name="addMediumSeverityAlarm" id="construct-hub.IMonitoring.addMediumSeverityAlarm"></a>
13792
+
13793
+ ```typescript
13794
+ public addMediumSeverityAlarm(title: string, alarm: AlarmBase): void
13795
+ ```
13796
+
13797
+ Adds a medium-severity alarm.
13798
+
13799
+ If this alarm goes off, the action specified in
13800
+ `mediumSeverityAlarmAction` is triggered.
13801
+
13802
+ ###### `title`<sup>Required</sup> <a name="title" id="construct-hub.IMonitoring.addMediumSeverityAlarm.parameter.title"></a>
13803
+
13804
+ - *Type:* string
13805
+
13806
+ a user-friendly title for the alarm (not currently used).
13807
+
13808
+ ---
13809
+
13810
+ ###### `alarm`<sup>Required</sup> <a name="alarm" id="construct-hub.IMonitoring.addMediumSeverityAlarm.parameter.alarm"></a>
13811
+
13812
+ - *Type:* aws-cdk-lib.aws_cloudwatch.AlarmBase
13813
+
13814
+ the alarm to be added.
13815
+
13816
+ ---
13817
+
13739
13818
 
13740
13819
  ### IOverviewDashboard <a name="IOverviewDashboard" id="construct-hub.IOverviewDashboard"></a>
13741
13820
 
package/lib/api.d.ts CHANGED
@@ -48,6 +48,21 @@ export interface AlarmActions {
48
48
  * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions
49
49
  */
50
50
  readonly highSeverityAction?: IAlarmAction;
51
+ /**
52
+ * The ARN of the CloudWatch alarm action to take for alarms of medium-severity
53
+ * alarms.
54
+ *
55
+ * This must be an ARN that can be used with CloudWatch alarms.
56
+ * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions
57
+ */
58
+ readonly mediumSeverity?: string;
59
+ /**
60
+ * The CloudWatch alarm action to take for alarms of medium-severity alarms.
61
+ *
62
+ * This must be an ARN that can be used with CloudWatch alarms.
63
+ * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarms-and-actions
64
+ */
65
+ readonly mediumSeverityAction?: IAlarmAction;
51
66
  /**
52
67
  * The ARN of the CloudWatch alarm action to take for alarms of normal
53
68
  * severity.
package/lib/api.js CHANGED
@@ -20,4 +20,4 @@ __exportStar(require("./backend/license-list/api"), exports);
20
20
  __exportStar(require("./codeartifact/api"), exports);
21
21
  __exportStar(require("./monitoring/api"), exports);
22
22
  __exportStar(require("./overview-dashboard/api"), exports);
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEscUVBQXFFOzs7Ozs7Ozs7Ozs7Ozs7O0FBTXJFLDBEQUF3QztBQUN4Qyw2REFBMkM7QUFDM0MscURBQW1DO0FBQ25DLG1EQUFpQztBQUNqQywyREFBeUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0aGlzIGZpbGUgaW5jbHVkZXMgdHlwZXMgdGhhdCBhcmUgcGFydCBvZiB0aGUgbGlicmFyeSdzIHB1YmxpYyBBUElcblxuaW1wb3J0ICogYXMgY2VydGlmaWNhdGVtYW5hZ2VyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXInO1xuaW1wb3J0IHsgSUFsYXJtQWN0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2gnO1xuaW1wb3J0ICogYXMgcm91dGU1MyBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtcm91dGU1Myc7XG5cbmV4cG9ydCAqIGZyb20gJy4vYmFja2VuZC9kZW55LWxpc3QvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYmFja2VuZC9saWNlbnNlLWxpc3QvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZWFydGlmYWN0L2FwaSc7XG5leHBvcnQgKiBmcm9tICcuL21vbml0b3JpbmcvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vb3ZlcnZpZXctZGFzaGJvYXJkL2FwaSc7XG5cbi8qKlxuICogRG9tYWluIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSB3ZWJzaXRlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERvbWFpbiB7XG4gIC8qKlxuICAgKiBUaGUgcm9vdCBkb21haW4gbmFtZSB3aGVyZSB0aGlzIGluc3RhbmNlIG9mIENvbnN0cnVjdCBIdWIgd2lsbCBiZSBzZXJ2ZWQuXG4gICAqL1xuICByZWFkb25seSB6b25lOiByb3V0ZTUzLklIb3N0ZWRab25lO1xuXG4gIC8qKlxuICAgKiBUaGUgY2VydGlmaWNhdGUgdG8gdXNlIGZvciBzZXJ2aW5nIHRoZSBDb25zdHJ1Y3QgSHViIG92ZXIgYSBjdXN0b20gZG9tYWluLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGEgRE5TLVZhbGlkYXRlZCBjZXJ0aWZpY2F0ZSB3aWxsIGJlIHByb3Zpc2lvbmVkIHVzaW5nIHRoZVxuICAgKiAgICAgICAgICAgIHByb3ZpZGVkIGBob3N0ZWRab25lYC5cbiAgICovXG4gIHJlYWRvbmx5IGNlcnQ6IGNlcnRpZmljYXRlbWFuYWdlci5JQ2VydGlmaWNhdGU7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdGhlIGNlcnRpZmljYXRlIHNob3VsZCBiZSBtb25pdG9yZWQgZm9yIGV4cGlyYXRpb24sIG1lYW5pbmcgaGlnaFxuICAgKiBzZXZlcml0eSBhbGFybXMgd2lsbCBiZSByYWlzZWQgaWYgaXQgaXMgZHVlIHRvIGV4cGlyZSBpbiBsZXNzIHRoYW4gNDUgZGF5cy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgbW9uaXRvckNlcnRpZmljYXRlRXhwaXJhdGlvbj86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb25zIHRvIHBlcmZvcm0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWxhcm1BY3Rpb25zIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBoaWdoLXNldmVyaXR5XG4gICAqIGFsYXJtcy5cbiAgICpcbiAgICogVGhpcyBtdXN0IGJlIGFuIEFSTiB0aGF0IGNhbiBiZSB1c2VkIHdpdGggQ2xvdWRXYXRjaCBhbGFybXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkNsb3VkV2F0Y2gvbGF0ZXN0L21vbml0b3JpbmcvQWxhcm1UaGF0U2VuZHNFbWFpbC5odG1sI2FsYXJtcy1hbmQtYWN0aW9uc1xuICAgKi9cbiAgcmVhZG9ubHkgaGlnaFNldmVyaXR5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb24gdG8gdGFrZSBmb3IgYWxhcm1zIG9mIGhpZ2gtc2V2ZXJpdHkgYWxhcm1zLlxuICAgKlxuICAgKiBUaGlzIG11c3QgYmUgYW4gQVJOIHRoYXQgY2FuIGJlIHVzZWQgd2l0aCBDbG91ZFdhdGNoIGFsYXJtcy5cbiAgICogQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQW1hem9uQ2xvdWRXYXRjaC9sYXRlc3QvbW9uaXRvcmluZy9BbGFybVRoYXRTZW5kc0VtYWlsLmh0bWwjYWxhcm1zLWFuZC1hY3Rpb25zXG4gICAqL1xuICByZWFkb25seSBoaWdoU2V2ZXJpdHlBY3Rpb24/OiBJQWxhcm1BY3Rpb247XG5cbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBub3JtYWxcbiAgICogc2V2ZXJpdHkuXG4gICAqXG4gICAqIFRoaXMgbXVzdCBiZSBhbiBBUk4gdGhhdCBjYW4gYmUgdXNlZCB3aXRoIENsb3VkV2F0Y2ggYWxhcm1zLlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25DbG91ZFdhdGNoL2xhdGVzdC9tb25pdG9yaW5nL0FsYXJtVGhhdFNlbmRzRW1haWwuaHRtbCNhbGFybXMtYW5kLWFjdGlvbnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBhY3Rpb25zIGFyZSB0YWtlbiBpbiByZXNwb25zZSB0byBhbGFybXMgb2Ygbm9ybWFsIHNldmVyaXR5XG4gICAqL1xuICByZWFkb25seSBub3JtYWxTZXZlcml0eT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBub3JtYWwgc2V2ZXJpdHkuXG4gICAqXG4gICAqIFRoaXMgbXVzdCBiZSBhbiBBUk4gdGhhdCBjYW4gYmUgdXNlZCB3aXRoIENsb3VkV2F0Y2ggYWxhcm1zLlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25DbG91ZFdhdGNoL2xhdGVzdC9tb25pdG9yaW5nL0FsYXJtVGhhdFNlbmRzRW1haWwuaHRtbCNhbGFybXMtYW5kLWFjdGlvbnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBhY3Rpb25zIGFyZSB0YWtlbiBpbiByZXNwb25zZSB0byBhbGFybXMgb2Ygbm9ybWFsIHNldmVyaXR5XG4gICAqL1xuICByZWFkb25seSBub3JtYWxTZXZlcml0eUFjdGlvbj86IElBbGFybUFjdGlvbjtcbn1cbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEscUVBQXFFOzs7Ozs7Ozs7Ozs7Ozs7O0FBTXJFLDBEQUF3QztBQUN4Qyw2REFBMkM7QUFDM0MscURBQW1DO0FBQ25DLG1EQUFpQztBQUNqQywyREFBeUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0aGlzIGZpbGUgaW5jbHVkZXMgdHlwZXMgdGhhdCBhcmUgcGFydCBvZiB0aGUgbGlicmFyeSdzIHB1YmxpYyBBUElcblxuaW1wb3J0ICogYXMgY2VydGlmaWNhdGVtYW5hZ2VyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXInO1xuaW1wb3J0IHsgSUFsYXJtQWN0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2gnO1xuaW1wb3J0ICogYXMgcm91dGU1MyBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtcm91dGU1Myc7XG5cbmV4cG9ydCAqIGZyb20gJy4vYmFja2VuZC9kZW55LWxpc3QvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYmFja2VuZC9saWNlbnNlLWxpc3QvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZWFydGlmYWN0L2FwaSc7XG5leHBvcnQgKiBmcm9tICcuL21vbml0b3JpbmcvYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vb3ZlcnZpZXctZGFzaGJvYXJkL2FwaSc7XG5cbi8qKlxuICogRG9tYWluIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSB3ZWJzaXRlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERvbWFpbiB7XG4gIC8qKlxuICAgKiBUaGUgcm9vdCBkb21haW4gbmFtZSB3aGVyZSB0aGlzIGluc3RhbmNlIG9mIENvbnN0cnVjdCBIdWIgd2lsbCBiZSBzZXJ2ZWQuXG4gICAqL1xuICByZWFkb25seSB6b25lOiByb3V0ZTUzLklIb3N0ZWRab25lO1xuXG4gIC8qKlxuICAgKiBUaGUgY2VydGlmaWNhdGUgdG8gdXNlIGZvciBzZXJ2aW5nIHRoZSBDb25zdHJ1Y3QgSHViIG92ZXIgYSBjdXN0b20gZG9tYWluLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGEgRE5TLVZhbGlkYXRlZCBjZXJ0aWZpY2F0ZSB3aWxsIGJlIHByb3Zpc2lvbmVkIHVzaW5nIHRoZVxuICAgKiAgICAgICAgICAgIHByb3ZpZGVkIGBob3N0ZWRab25lYC5cbiAgICovXG4gIHJlYWRvbmx5IGNlcnQ6IGNlcnRpZmljYXRlbWFuYWdlci5JQ2VydGlmaWNhdGU7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdGhlIGNlcnRpZmljYXRlIHNob3VsZCBiZSBtb25pdG9yZWQgZm9yIGV4cGlyYXRpb24sIG1lYW5pbmcgaGlnaFxuICAgKiBzZXZlcml0eSBhbGFybXMgd2lsbCBiZSByYWlzZWQgaWYgaXQgaXMgZHVlIHRvIGV4cGlyZSBpbiBsZXNzIHRoYW4gNDUgZGF5cy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgbW9uaXRvckNlcnRpZmljYXRlRXhwaXJhdGlvbj86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb25zIHRvIHBlcmZvcm0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWxhcm1BY3Rpb25zIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBoaWdoLXNldmVyaXR5XG4gICAqIGFsYXJtcy5cbiAgICpcbiAgICogVGhpcyBtdXN0IGJlIGFuIEFSTiB0aGF0IGNhbiBiZSB1c2VkIHdpdGggQ2xvdWRXYXRjaCBhbGFybXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkNsb3VkV2F0Y2gvbGF0ZXN0L21vbml0b3JpbmcvQWxhcm1UaGF0U2VuZHNFbWFpbC5odG1sI2FsYXJtcy1hbmQtYWN0aW9uc1xuICAgKi9cbiAgcmVhZG9ubHkgaGlnaFNldmVyaXR5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb24gdG8gdGFrZSBmb3IgYWxhcm1zIG9mIGhpZ2gtc2V2ZXJpdHkgYWxhcm1zLlxuICAgKlxuICAgKiBUaGlzIG11c3QgYmUgYW4gQVJOIHRoYXQgY2FuIGJlIHVzZWQgd2l0aCBDbG91ZFdhdGNoIGFsYXJtcy5cbiAgICogQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQW1hem9uQ2xvdWRXYXRjaC9sYXRlc3QvbW9uaXRvcmluZy9BbGFybVRoYXRTZW5kc0VtYWlsLmh0bWwjYWxhcm1zLWFuZC1hY3Rpb25zXG4gICAqL1xuICByZWFkb25seSBoaWdoU2V2ZXJpdHlBY3Rpb24/OiBJQWxhcm1BY3Rpb247XG5cbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBtZWRpdW0tc2V2ZXJpdHlcbiAgICogYWxhcm1zLlxuICAgKlxuICAgKiBUaGlzIG11c3QgYmUgYW4gQVJOIHRoYXQgY2FuIGJlIHVzZWQgd2l0aCBDbG91ZFdhdGNoIGFsYXJtcy5cbiAgICogQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQW1hem9uQ2xvdWRXYXRjaC9sYXRlc3QvbW9uaXRvcmluZy9BbGFybVRoYXRTZW5kc0VtYWlsLmh0bWwjYWxhcm1zLWFuZC1hY3Rpb25zXG4gICAqL1xuICByZWFkb25seSBtZWRpdW1TZXZlcml0eT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIENsb3VkV2F0Y2ggYWxhcm0gYWN0aW9uIHRvIHRha2UgZm9yIGFsYXJtcyBvZiBtZWRpdW0tc2V2ZXJpdHkgYWxhcm1zLlxuICAgKlxuICAgKiBUaGlzIG11c3QgYmUgYW4gQVJOIHRoYXQgY2FuIGJlIHVzZWQgd2l0aCBDbG91ZFdhdGNoIGFsYXJtcy5cbiAgICogQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQW1hem9uQ2xvdWRXYXRjaC9sYXRlc3QvbW9uaXRvcmluZy9BbGFybVRoYXRTZW5kc0VtYWlsLmh0bWwjYWxhcm1zLWFuZC1hY3Rpb25zXG4gICAqL1xuICByZWFkb25seSBtZWRpdW1TZXZlcml0eUFjdGlvbj86IElBbGFybUFjdGlvbjtcblxuICAvKipcbiAgICogVGhlIEFSTiBvZiB0aGUgQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb24gdG8gdGFrZSBmb3IgYWxhcm1zIG9mIG5vcm1hbFxuICAgKiBzZXZlcml0eS5cbiAgICpcbiAgICogVGhpcyBtdXN0IGJlIGFuIEFSTiB0aGF0IGNhbiBiZSB1c2VkIHdpdGggQ2xvdWRXYXRjaCBhbGFybXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkNsb3VkV2F0Y2gvbGF0ZXN0L21vbml0b3JpbmcvQWxhcm1UaGF0U2VuZHNFbWFpbC5odG1sI2FsYXJtcy1hbmQtYWN0aW9uc1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGFjdGlvbnMgYXJlIHRha2VuIGluIHJlc3BvbnNlIHRvIGFsYXJtcyBvZiBub3JtYWwgc2V2ZXJpdHlcbiAgICovXG4gIHJlYWRvbmx5IG5vcm1hbFNldmVyaXR5Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQ2xvdWRXYXRjaCBhbGFybSBhY3Rpb24gdG8gdGFrZSBmb3IgYWxhcm1zIG9mIG5vcm1hbCBzZXZlcml0eS5cbiAgICpcbiAgICogVGhpcyBtdXN0IGJlIGFuIEFSTiB0aGF0IGNhbiBiZSB1c2VkIHdpdGggQ2xvdWRXYXRjaCBhbGFybXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkNsb3VkV2F0Y2gvbGF0ZXN0L21vbml0b3JpbmcvQWxhcm1UaGF0U2VuZHNFbWFpbC5odG1sI2FsYXJtcy1hbmQtYWN0aW9uc1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGFjdGlvbnMgYXJlIHRha2VuIGluIHJlc3BvbnNlIHRvIGFsYXJtcyBvZiBub3JtYWwgc2V2ZXJpdHlcbiAgICovXG4gIHJlYWRvbmx5IG5vcm1hbFNldmVyaXR5QWN0aW9uPzogSUFsYXJtQWN0aW9uO1xufVxuIl19
@@ -227,6 +227,13 @@ export declare class ConstructHub extends Construct implements iam.IGrantable {
227
227
  * issue.
228
228
  */
229
229
  get highSeverityAlarms(): cw.IAlarm[];
230
+ /**
231
+ * Returns a list of all low-severity alarms from this ConstructHub instance.
232
+ * These do not necessitate immediate attention, as they do not have direct
233
+ * customer-visible impact, or handling is not time-sensitive. They indicate
234
+ * that something unusual (not necessarily bad) is happening.
235
+ */
236
+ get mediumSeverityAlarms(): cw.IAlarm[];
230
237
  /**
231
238
  * Returns a list of all low-severity alarms from this ConstructHub instance.
232
239
  * These do not necessitate immediate attention, as they do not have direct
@@ -260,6 +260,16 @@ class ConstructHub extends constructs_1.Construct {
260
260
  // Note: the array is already returned by-copy by Monitoring, so not copying again.
261
261
  return this.monitoring.highSeverityAlarms;
262
262
  }
263
+ /**
264
+ * Returns a list of all low-severity alarms from this ConstructHub instance.
265
+ * These do not necessitate immediate attention, as they do not have direct
266
+ * customer-visible impact, or handling is not time-sensitive. They indicate
267
+ * that something unusual (not necessarily bad) is happening.
268
+ */
269
+ get mediumSeverityAlarms() {
270
+ // Note: the array is already returned by-copy by Monitoring, so not copying again.
271
+ return this.monitoring.mediumSeverityAlarms;
272
+ }
263
273
  /**
264
274
  * Returns a list of all low-severity alarms from this ConstructHub instance.
265
275
  * These do not necessitate immediate attention, as they do not have direct
@@ -274,7 +284,7 @@ class ConstructHub extends constructs_1.Construct {
274
284
  * Returns a list of all alarms configured by this ConstructHub instance.
275
285
  */
276
286
  get allAlarms() {
277
- return [...this.highSeverityAlarms, ...this.lowSeverityAlarms];
287
+ return [...this.highSeverityAlarms, ...this.lowSeverityAlarms, ...this.mediumSeverityAlarms];
278
288
  }
279
289
  get grantPrincipal() {
280
290
  return this.ingestion.grantPrincipal;
@@ -393,7 +403,7 @@ class ConstructHub extends constructs_1.Construct {
393
403
  }
394
404
  exports.ConstructHub = ConstructHub;
395
405
  _a = JSII_RTTI_SYMBOL_1;
396
- ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.4.412" };
406
+ ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.4.413" };
397
407
  /**
398
408
  * How possibly risky operations (such as doc-generation, which requires
399
409
  * installing the indexed packages in order to trans-literate sample code) are
@@ -433,4 +443,4 @@ var Isolation;
433
443
  */
434
444
  Isolation[Isolation["NO_INTERNET_ACCESS"] = 2] = "NO_INTERNET_ACCESS";
435
445
  })(Isolation || (exports.Isolation = Isolation = {}));
436
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct-hub.js","sourceRoot":"","sources":["../src/construct-hub.ts"],"names":[],"mappings":"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","sourcesContent":["import { Application } from '@aws-cdk/aws-servicecatalogappregistry-alpha';\nimport { Duration, Stack, Tags } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { AnyPrincipal, Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { BlockPublicAccess } from 'aws-cdk-lib/aws-s3';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport * as sqs from 'aws-cdk-lib/aws-sqs';\nimport { Construct } from 'constructs';\nimport { createRestrictedSecurityGroups } from './_limited-internet-access';\nimport { AlarmActions, Domain } from './api';\nimport { DenyList, Ingestion } from './backend';\nimport { DenyListRule } from './backend/deny-list/api';\nimport { FeedBuilder } from './backend/feed-builder';\nimport { Inventory } from './backend/inventory';\nimport { LicenseList } from './backend/license-list';\nimport { Orchestration } from './backend/orchestration';\nimport { PackageStats } from './backend/package-stats';\nimport { ReleaseNoteFetcher } from './backend/release-notes';\nimport { CATALOG_KEY, STORAGE_KEY_PREFIX } from './backend/shared/constants';\nimport { VersionTracker } from './backend/version-tracker';\nimport { BackendDashboard } from './backend-dashboard';\nimport { Repository } from './codeartifact/repository';\nimport { DomainRedirect, DomainRedirectSource } from './domain-redirect';\nimport { Monitoring } from './monitoring';\nimport { OverviewDashboard } from './overview-dashboard';\nimport { IPackageSource } from './package-source';\nimport { NpmJs } from './package-sources';\nimport { PackageTag } from './package-tag';\nimport { PackageTagGroup } from './package-tag-group';\nimport { PreloadFile } from './preload-file';\nimport { S3StorageFactory } from './s3/storage';\nimport { SpdxLicense } from './spdx-license';\nimport {\n  WebApp,\n  PackageLinkConfig,\n  FeaturedPackages,\n  FeatureFlags,\n  Category,\n} from './webapp';\nimport { IStateMachine } from 'aws-cdk-lib/aws-stepfunctions';\n\n/**\n * Configuration for generating RSS and ATOM feed for the latest packages\n */\nexport interface FeedConfiguration {\n  /**\n   * Github token for generating release notes. When missing no release notes will be included in the generated RSS/ATOM feed\n   */\n  readonly githubTokenSecret?: secretsmanager.ISecret;\n\n  /**\n   * Title used in the generated feed\n   */\n  readonly feedTitle?: string;\n\n  /**\n   * description used in the generated feed\n   */\n  readonly feedDescription?: string;\n}\n\n/**\n * Props for `ConstructHub`.\n */\nexport interface ConstructHubProps {\n  /**\n   * Connect the hub to a domain (requires a hosted zone and a certificate).\n   */\n  readonly domain?: Domain;\n\n  /**\n   * Actions to perform when alarms are set.\n   */\n  readonly alarmActions?: AlarmActions;\n\n  /**\n   * Whether compute environments for sensitive tasks (which operate on\n   * un-trusted complex data, such as the transliterator, which operates with\n   * externally-sourced npm package tarballs) should run in network-isolated\n   * environments. This implies the creation of additonal resources, including:\n   *\n   * - A VPC with only isolated subnets.\n   * - VPC Endpoints (CloudWatch Logs, CodeArtifact, CodeArtifact API, S3, ...)\n   * - A CodeArtifact Repository with an external connection to npmjs.com\n   *\n   * @deprecated use sensitiveTaskIsolation instead.\n   */\n  readonly isolateSensitiveTasks?: boolean;\n\n  /**\n   * Whether compute environments for sensitive tasks (which operate on\n   * un-trusted complex data, such as the transliterator, which operates with\n   * externally-sourced npm package tarballs) should run in network-isolated\n   * environments. This implies the creation of additonal resources, including:\n   *\n   * - A VPC with only isolated subnets.\n   * - VPC Endpoints (CloudWatch Logs, CodeArtifact, CodeArtifact API, S3, ...)\n   * - A CodeArtifact Repository with an external connection to npmjs.com\n   *\n   * @default Isolation.NO_INTERNET_ACCESS\n   */\n  readonly sensitiveTaskIsolation?: Isolation;\n\n  /**\n   * How long to retain CloudWatch logs for.\n   *\n   * @defaults RetentionDays.TEN_YEARS\n   */\n  readonly logRetention?: RetentionDays;\n\n  /**\n   * The name of the CloudWatch dashboard that represents the health of backend\n   * systems.\n   */\n  readonly backendDashboardName?: string;\n\n  /**\n   * A list of packages to block from the construct hub.\n   *\n   * @default []\n   */\n  readonly denyList?: DenyListRule[];\n\n  /**\n   * The package sources to register with this ConstructHub instance.\n   *\n   * @default - a standard npmjs.com package source will be configured.\n   */\n  readonly packageSources?: IPackageSource[];\n\n  /**\n   * The allowed licenses for packages indexed by this instance of ConstructHub.\n   *\n   * @default [...SpdxLicense.apache(),...SpdxLicense.bsd(),...SpdxLicense.cddl(),...SpdxLicense.epl(),SpdxLicense.ISC,...SpdxLicense.mit(),SpdxLicense.MPL_2_0]\n   */\n  readonly allowedLicenses?: SpdxLicense[];\n\n  /**\n   * When using a CodeArtifact package source, it is often desirable to have\n   * ConstructHub provision it's internal CodeArtifact repository in the same\n   * CodeArtifact domain, and to configure the package source repository as an\n   * upstream of the internal repository. This way, all packages in the source\n   * are available to ConstructHub's backend processing.\n   *\n   * @default - none.\n   */\n  readonly codeArtifactDomain?: CodeArtifactDomainProps;\n\n  /**\n   * Configuration for custom package page links.\n   */\n  readonly packageLinks?: PackageLinkConfig[];\n\n  /**\n   * Configuration for custom package tags\n   */\n  readonly packageTags?: PackageTag[];\n\n  /**\n   * Optional configuration for grouping custom package tags\n   */\n  readonly packageTagGroups?: PackageTagGroup[];\n\n  /**\n   * Configuration for packages to feature on the home page.\n   * @default - Display the 10 most recently updated packages\n   */\n  readonly featuredPackages?: FeaturedPackages;\n\n  /**\n   * Configure feature flags for the web app.\n   */\n  readonly featureFlags?: FeatureFlags;\n\n  /**\n   * Configure whether or not the backend should periodically query NPM\n   * for the number of downloads a package has in the past week, and\n   * display download counts on the web app.\n   *\n   * @default - true if packageSources is not specified (the defaults are\n   * used), false otherwise\n   */\n  readonly fetchPackageStats?: boolean;\n\n  /**\n   * Browse categories. Each category will appear in the home page as a button\n   * with a link to the relevant search query.\n   */\n  readonly categories?: Category[];\n\n  /**\n   * Wire construct hub to use the failover storage buckets.\n   *\n   * Do not activate this property until you've populated your failover buckets\n   * with the necessary data.\n   *\n   * @see https://github.com/cdklabs/construct-hub/blob/dev/docs/operator-runbook.md#storage-disaster\n   * @default false\n   */\n  readonly failoverStorage?: boolean;\n\n  /**\n   * How frequently all packages should get fully reprocessed.\n   *\n   * See the operator runbook for more information about reprocessing.\n   * @see https://github.com/cdklabs/construct-hub/blob/main/docs/operator-runbook.md\n   *\n   * @default - never\n   */\n  readonly reprocessFrequency?: Duration;\n\n  /**\n   * Package versions that have been published before this time window will not be reprocessed.\n   *\n   * @default Duration.days(90)\n   */\n  readonly reprocessAge?: Duration;\n\n  /**\n   * Additional domains which will be set up to redirect to the primary\n   * construct hub domain.\n   *\n   * @default []\n   */\n  readonly additionalDomains?: DomainRedirectSource[];\n\n  /**\n   * Javascript to run on webapp before app loads\n   *\n   * @default - create an empty file\n   */\n  readonly preloadScript?: PreloadFile;\n\n  /**\n   * Create an AppRegistry application associated with the stack containing\n   * this construct.\n   *\n   * @default true\n   */\n  readonly appRegistryApplication?: boolean;\n\n  /**\n   * Configuration for generating RSS/Atom feeds with the latest packages. If the value is missing\n   * the generated RSS/ATOM feed would not contain release notes\n   */\n  readonly feedConfiguration?: FeedConfiguration;\n}\n\n/**\n * Information pertaining to an existing CodeArtifact Domain.\n */\nexport interface CodeArtifactDomainProps {\n  /**\n   * The name of the CodeArtifact domain.\n   */\n  readonly name: string;\n\n  /**\n   * Any upstream repositories in this CodeArtifact domain that should be\n   * configured on the internal CodeArtifact repository.\n   */\n  readonly upstreams?: string[];\n}\n\n/**\n * Construct Hub.\n */\nexport class ConstructHub extends Construct implements iam.IGrantable {\n  /**\n   * The function operators can use to reprocess a specific package version\n   * through the backend data pipeline.\n   */\n  public readonly regenerateAllDocumentationPerPackage: IStateMachine;\n\n  private readonly ingestion: Ingestion;\n  private readonly monitoring: Monitoring;\n\n  public constructor(\n    scope: Construct,\n    id: string,\n    props: ConstructHubProps = {}\n  ) {\n    super(scope, id);\n\n    if (\n      props.isolateSensitiveTasks != null &&\n      props.sensitiveTaskIsolation != null\n    ) {\n      throw new Error(\n        'Supplying both isolateSensitiveTasks and sensitiveTaskIsolation is not supported. Remove usage of isolateSensitiveTasks.'\n      );\n    }\n\n    const shouldFetchReleaseNotes = props.feedConfiguration?.githubTokenSecret\n      ? true\n      : false;\n\n    const storageFactory = S3StorageFactory.getOrCreate(this, {\n      failover: props.failoverStorage,\n    });\n\n    this.monitoring = new Monitoring(this, 'Monitoring', {\n      alarmActions: props.alarmActions,\n    });\n\n    const overviewDashboard = new OverviewDashboard(this, 'OverviewDashboard', {\n      lambdaServiceAlarmThreshold: 70,\n      dashboardName: props.backendDashboardName\n        ? `${props.backendDashboardName}-overview`\n        : undefined,\n    });\n\n    const packageData = storageFactory.newBucket(this, 'PackageData', {\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      enforceSSL: true,\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      lifecycleRules: [\n        // Abort multi-part uploads after 1 day\n        { abortIncompleteMultipartUploadAfter: Duration.days(1) },\n        // Transition non-current object versions to IA after 1 month\n        {\n          noncurrentVersionTransitions: [\n            {\n              storageClass: s3.StorageClass.INFREQUENT_ACCESS,\n              transitionAfter: Duration.days(31),\n            },\n          ],\n        },\n        // Permanently delete non-current object versions after 3 months\n        {\n          noncurrentVersionExpiration: Duration.days(90),\n          expiredObjectDeleteMarker: true,\n        },\n        // Permanently delete non-current versions of catalog.json earlier\n        { noncurrentVersionExpiration: Duration.days(7), prefix: CATALOG_KEY },\n      ],\n      versioned: true,\n    });\n\n    const isolation =\n      props.sensitiveTaskIsolation ??\n      (props.isolateSensitiveTasks\n        ? Isolation.NO_INTERNET_ACCESS\n        : Isolation.UNLIMITED_INTERNET_ACCESS);\n\n    // Create an internal CodeArtifact repository if we run in network-controlled mode, or if a domain is provided.\n    const codeArtifact =\n      isolation === Isolation.NO_INTERNET_ACCESS ||\n      props.codeArtifactDomain != null\n        ? new Repository(this, 'CodeArtifact', {\n            description: 'Proxy to npmjs.com for ConstructHub',\n            domainName: props.codeArtifactDomain?.name,\n            domainExists: props.codeArtifactDomain != null,\n            upstreams: props.codeArtifactDomain?.upstreams,\n          })\n        : undefined;\n    const { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups } = this.createVpc(\n      isolation,\n      codeArtifact\n    );\n\n    const denyList = new DenyList(this, 'DenyList', {\n      rules: props.denyList ?? [],\n      packageDataBucket: packageData,\n      packageDataKeyPrefix: STORAGE_KEY_PREFIX,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n    });\n\n    // disable fetching package stats by default if a different package\n    // source is configured\n    const fetchPackageStats =\n      props.fetchPackageStats ?? (props.packageSources ? false : true);\n\n    let packageStats: PackageStats | undefined;\n    const statsKey = 'stats.json';\n    if (fetchPackageStats) {\n      packageStats = new PackageStats(this, 'Stats', {\n        bucket: packageData,\n        monitoring: this.monitoring,\n        logRetention: props.logRetention,\n        objectKey: statsKey,\n      });\n    }\n\n    const versionTracker = new VersionTracker(this, 'VersionTracker', {\n      bucket: packageData,\n      monitoring: this.monitoring,\n      logRetention: props.logRetention,\n    });\n\n    const feedBuilder = new FeedBuilder(this, 'FeedBuilder', {\n      bucket: packageData,\n      overviewDashboard,\n      feedDescription: props.feedConfiguration?.feedDescription,\n      feedTitle: props.feedConfiguration?.feedTitle,\n      monitoring: this.monitoring,\n    });\n\n    const orchestration = new Orchestration(this, 'Orchestration', {\n      bucket: packageData,\n      codeArtifact,\n      denyList,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n      vpc,\n      vpcEndpoints,\n      vpcSubnets,\n      vpcSecurityGroups,\n      feedBuilder,\n    });\n    this.regenerateAllDocumentationPerPackage =\n      orchestration.regenerateAllDocumentationPerPackage;\n\n    // rebuild the catalog when the deny list changes.\n    denyList.prune.onChangeInvoke(orchestration.catalogBuilder.function);\n\n    const packageTagsSerialized =\n      props.packageTags?.map((config) => {\n        return {\n          ...config,\n          condition: config.condition.bind(),\n        };\n      }) ?? [];\n\n    let releaseNotes;\n    if (shouldFetchReleaseNotes) {\n      releaseNotes = new ReleaseNoteFetcher(this, 'ReleaseNotes', {\n        bucket: packageData,\n        gitHubCredentialsSecret: props.feedConfiguration?.githubTokenSecret,\n        feedBuilder,\n        monitoring: this.monitoring,\n        overviewDashboard,\n      });\n    }\n\n    this.ingestion = new Ingestion(this, 'Ingestion', {\n      bucket: packageData,\n      codeArtifact,\n      orchestration,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      packageLinks: props.packageLinks,\n      packageTags: packageTagsSerialized,\n      reprocessFrequency: props.reprocessFrequency,\n      reprocessAge: props.reprocessAge,\n      releaseNotesFetchQueue: releaseNotes?.queue,\n      overviewDashboard: overviewDashboard,\n    });\n\n    const licenseList = new LicenseList(this, 'LicenseList', {\n      licenses: props.allowedLicenses ?? [\n        ...SpdxLicense.apache(),\n        ...SpdxLicense.bsd(),\n        ...SpdxLicense.cddl(),\n        ...SpdxLicense.epl(),\n        SpdxLicense.ISC,\n        ...SpdxLicense.mit(),\n        SpdxLicense.MPL_2_0,\n      ],\n    });\n\n    const webApp = new WebApp(this, 'WebApp', {\n      domain: props.domain,\n      monitoring: this.monitoring,\n      packageData,\n      packageLinks: props.packageLinks,\n      packageTags: packageTagsSerialized,\n      packageTagGroups: props.packageTagGroups,\n      featuredPackages: props.featuredPackages,\n      packageStats,\n      featureFlags: props.featureFlags,\n      categories: props.categories,\n      preloadScript: props.preloadScript,\n      overviewDashboard: overviewDashboard,\n      includeFeedLink: true,\n    });\n\n    // Set the base URL that will be used in the RSS/ATOM feed\n    feedBuilder.setConstructHubUrl(webApp.baseUrl);\n\n    const sources = new Construct(this, 'Sources');\n    const packageSources = (props.packageSources ?? [new NpmJs()]).map(\n      (source) =>\n        source.bind(sources, {\n          baseUrl: webApp.baseUrl,\n          denyList,\n          ingestion: this.ingestion,\n          licenseList,\n          monitoring: this.monitoring,\n          queue: this.ingestion.queue,\n          repository: codeArtifact,\n          overviewDashboard: overviewDashboard,\n        })\n    );\n\n    const inventory = new Inventory(this, 'InventoryCanary', {\n      bucket: packageData,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n    });\n\n    new BackendDashboard(this, 'BackendDashboard', {\n      packageData,\n      dashboardName: props.backendDashboardName,\n      packageSources,\n      ingestion: this.ingestion,\n      inventory,\n      orchestration,\n      denyList,\n      packageStats,\n      versionTracker,\n      releaseNotes,\n    });\n\n    // add domain redirects\n    if (props.domain) {\n      for (const redirctSource of props.additionalDomains ?? []) {\n        new DomainRedirect(\n          this,\n          `Redirect-${redirctSource.hostedZone.zoneName}`,\n          {\n            source: redirctSource,\n            targetDomainName: props.domain?.zone.zoneName,\n          }\n        );\n      }\n    } else {\n      if (props.additionalDomains && props.additionalDomains.length > 0) {\n        throw new Error(\n          'Cannot specify \"domainRedirects\" if a domain is not specified'\n        );\n      }\n    }\n\n    if (props.appRegistryApplication ?? true) {\n      const application = new Application(this, 'Application', {\n        applicationName: 'ConstructHub',\n      });\n      application.associateApplicationWithStack(Stack.of(this));\n    }\n  }\n\n  /**\n   * Returns a list of all high-severity alarms from this ConstructHub instance.\n   * These warrant immediate attention as they are indicative of a system health\n   * issue.\n   */\n  public get highSeverityAlarms(): cw.IAlarm[] {\n    // Note: the array is already returned by-copy by Monitoring, so not copying again.\n    return this.monitoring.highSeverityAlarms;\n  }\n\n  /**\n   * Returns a list of all low-severity alarms from this ConstructHub instance.\n   * These do not necessitate immediate attention, as they do not have direct\n   * customer-visible impact, or handling is not time-sensitive. They indicate\n   * that something unusual (not necessarily bad) is happening.\n   */\n  public get lowSeverityAlarms(): cw.IAlarm[] {\n    // Note: the array is already returned by-copy by Monitoring, so not copying again.\n    return this.monitoring.lowSeverityAlarms;\n  }\n\n  /**\n   * Returns a list of all alarms configured by this ConstructHub instance.\n   */\n  public get allAlarms(): cw.IAlarm[] {\n    return [...this.highSeverityAlarms, ...this.lowSeverityAlarms];\n  }\n\n  public get grantPrincipal(): iam.IPrincipal {\n    return this.ingestion.grantPrincipal;\n  }\n\n  public get ingestionQueue(): sqs.IQueue {\n    return this.ingestion.queue;\n  }\n\n  private createVpc(\n    isolation: Isolation,\n    codeArtifact: Repository | undefined\n  ) {\n    if (isolation === Isolation.UNLIMITED_INTERNET_ACCESS) {\n      return { vpc: undefined, vpcEndpoints: undefined, vpcSubnets: undefined };\n    }\n\n    const subnetType =\n      isolation === Isolation.NO_INTERNET_ACCESS\n        ? ec2.SubnetType.PRIVATE_ISOLATED\n        : ec2.SubnetType.PRIVATE_WITH_EGRESS;\n    const vpcSubnets = { subnetType };\n\n    const vpc = new ec2.Vpc(this, 'VPC', {\n      enableDnsHostnames: true,\n      enableDnsSupport: true,\n      // Provision no NAT gateways if we are running ISOLATED (we wouldn't have a public subnet)\n      natGateways:\n        subnetType === ec2.SubnetType.PRIVATE_ISOLATED ? 0 : undefined,\n      // Pre-allocating PUBLIC / PRIVATE / INTERNAL subnets, regardless of use, so we don't create\n      // a whole new VPC if we ever need to introduce subnets of these types.\n      subnetConfiguration: [\n        // If there is a PRIVATE subnet, there must also have a PUBLIC subnet (for NAT gateways).\n        {\n          name: 'Public',\n          subnetType: ec2.SubnetType.PUBLIC,\n          reserved: subnetType === ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n        {\n          name: 'Private',\n          subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,\n          reserved: subnetType === ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n        {\n          name: 'Isolated',\n          subnetType: ec2.SubnetType.PRIVATE_ISOLATED,\n          reserved: subnetType !== ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n      ],\n    });\n    Tags.of(vpc.node.defaultChild!).add('Name', vpc.node.path);\n\n    const securityGroups =\n      subnetType === ec2.SubnetType.PRIVATE_WITH_EGRESS\n        ? createRestrictedSecurityGroups(this, vpc)\n        : undefined;\n\n    // Creating the CodeArtifact endpoints only if a repository is present.\n    const codeArtifactEndpoints = codeArtifact && {\n      codeArtifactApi: vpc.addInterfaceEndpoint('CodeArtifact.API', {\n        privateDnsEnabled: false,\n        service: new ec2.InterfaceVpcEndpointAwsService('codeartifact.api'),\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      codeArtifact: vpc.addInterfaceEndpoint('CodeArtifact', {\n        privateDnsEnabled: true,\n        service: new ec2.InterfaceVpcEndpointAwsService(\n          'codeartifact.repositories'\n        ),\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n    };\n\n    // We'll only use VPC endpoints if we are configured to run in an ISOLATED subnet.\n    const vpcEndpoints = {\n      ...codeArtifactEndpoints,\n      // This is needed so that ECS workloads can use the awslogs driver\n      cloudWatchLogs: vpc.addInterfaceEndpoint('CloudWatch.Logs', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.CLOUDWATCH_LOGS,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      // These are needed for ECS workloads to be able to pull images\n      ecrApi: vpc.addInterfaceEndpoint('ECR.API', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.ECR,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      ecr: vpc.addInterfaceEndpoint('ECR.Docker', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.ECR_DOCKER,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      // This is needed (among others) for CodeArtifact registry usage\n      s3: vpc.addGatewayEndpoint('S3', {\n        service: ec2.GatewayVpcEndpointAwsService.S3,\n        subnets: [vpcSubnets],\n      }),\n      // This is useful for getting results from ECS tasks within workflows\n      stepFunctions: vpc.addInterfaceEndpoint('StepFunctions', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.STEP_FUNCTIONS,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n    };\n\n    // The S3 access is necessary for the CodeArtifact Repository and ECR Docker\n    // endpoints to be used (they serve objects from S3).\n    vpcEndpoints.s3.addToPolicy(\n      new PolicyStatement({\n        effect: Effect.ALLOW,\n        actions: ['s3:GetObject'],\n        resources: [\n          // The in-region CodeArtifact S3 Bucket\n          ...(codeArtifact ? [`${codeArtifact.s3BucketArn}/*`] : []),\n          // The in-region ECR layer bucket\n          `arn:aws:s3:::prod-${Stack.of(this).region}-starport-layer-bucket/*`,\n        ],\n        // It doesn't seem we can constrain principals for these grants (unclear\n        // which principal those calls are made from, or if that is something we\n        // could name here).\n        principals: [new AnyPrincipal()],\n        sid: 'Allow-CodeArtifact-and-ECR',\n      })\n    );\n\n    return { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups: securityGroups };\n  }\n}\n\n/**\n * How possibly risky operations (such as doc-generation, which requires\n * installing the indexed packages in order to trans-literate sample code) are\n * isolated to mitigate possible arbitrary code execution vulnerabilities in and\n * around `npm install` or the transliterator's use of the TypeScript compiler.\n */\nexport enum Isolation {\n  /**\n   * No isolation is done whatsoever. The doc-generation process still is\n   * provisioned with least-privilege permissions, but retains complete access\n   * to internet.\n   *\n   * While this maximizes the chances of successfully installing packages (and\n   * hence successfully generating documentation for those), it is also the\n   * least secure mode of operation.\n   *\n   * We advise you only consider using this isolation mode if you are hosting a\n   * ConstructHub instance that only indexes trusted packages (including\n   * transitive dependencies).\n   */\n  UNLIMITED_INTERNET_ACCESS,\n\n  /**\n   * The same protections as `UNLIMITED_INTERNET_ACCESS`, except outbound\n   * internet connections are limited to IP address ranges corresponding to\n   * hosting endpoints for npmjs.com.\n   */\n  LIMITED_INTERNET_ACCESS,\n\n  /**\n   * The same protections as `LIMITED_INTERNET_ACCESS`, except all remaining\n   * internet access is removed. All traffic to AWS service endpoints is routed\n   * through VPC Endpoints, as the compute nodes are jailed in a completely\n   * isolated VPC.\n   *\n   * This is the most secure (and recommended) mode of operation for\n   * ConstructHub instances.\n   */\n  NO_INTERNET_ACCESS,\n}\n"]}
446
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct-hub.js","sourceRoot":"","sources":["../src/construct-hub.ts"],"names":[],"mappings":"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","sourcesContent":["import { Application } from '@aws-cdk/aws-servicecatalogappregistry-alpha';\nimport { Duration, Stack, Tags } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { AnyPrincipal, Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { BlockPublicAccess } from 'aws-cdk-lib/aws-s3';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport * as sqs from 'aws-cdk-lib/aws-sqs';\nimport { Construct } from 'constructs';\nimport { createRestrictedSecurityGroups } from './_limited-internet-access';\nimport { AlarmActions, Domain } from './api';\nimport { DenyList, Ingestion } from './backend';\nimport { DenyListRule } from './backend/deny-list/api';\nimport { FeedBuilder } from './backend/feed-builder';\nimport { Inventory } from './backend/inventory';\nimport { LicenseList } from './backend/license-list';\nimport { Orchestration } from './backend/orchestration';\nimport { PackageStats } from './backend/package-stats';\nimport { ReleaseNoteFetcher } from './backend/release-notes';\nimport { CATALOG_KEY, STORAGE_KEY_PREFIX } from './backend/shared/constants';\nimport { VersionTracker } from './backend/version-tracker';\nimport { BackendDashboard } from './backend-dashboard';\nimport { Repository } from './codeartifact/repository';\nimport { DomainRedirect, DomainRedirectSource } from './domain-redirect';\nimport { Monitoring } from './monitoring';\nimport { OverviewDashboard } from './overview-dashboard';\nimport { IPackageSource } from './package-source';\nimport { NpmJs } from './package-sources';\nimport { PackageTag } from './package-tag';\nimport { PackageTagGroup } from './package-tag-group';\nimport { PreloadFile } from './preload-file';\nimport { S3StorageFactory } from './s3/storage';\nimport { SpdxLicense } from './spdx-license';\nimport {\n  WebApp,\n  PackageLinkConfig,\n  FeaturedPackages,\n  FeatureFlags,\n  Category,\n} from './webapp';\nimport { IStateMachine } from 'aws-cdk-lib/aws-stepfunctions';\n\n/**\n * Configuration for generating RSS and ATOM feed for the latest packages\n */\nexport interface FeedConfiguration {\n  /**\n   * Github token for generating release notes. When missing no release notes will be included in the generated RSS/ATOM feed\n   */\n  readonly githubTokenSecret?: secretsmanager.ISecret;\n\n  /**\n   * Title used in the generated feed\n   */\n  readonly feedTitle?: string;\n\n  /**\n   * description used in the generated feed\n   */\n  readonly feedDescription?: string;\n}\n\n/**\n * Props for `ConstructHub`.\n */\nexport interface ConstructHubProps {\n  /**\n   * Connect the hub to a domain (requires a hosted zone and a certificate).\n   */\n  readonly domain?: Domain;\n\n  /**\n   * Actions to perform when alarms are set.\n   */\n  readonly alarmActions?: AlarmActions;\n\n  /**\n   * Whether compute environments for sensitive tasks (which operate on\n   * un-trusted complex data, such as the transliterator, which operates with\n   * externally-sourced npm package tarballs) should run in network-isolated\n   * environments. This implies the creation of additonal resources, including:\n   *\n   * - A VPC with only isolated subnets.\n   * - VPC Endpoints (CloudWatch Logs, CodeArtifact, CodeArtifact API, S3, ...)\n   * - A CodeArtifact Repository with an external connection to npmjs.com\n   *\n   * @deprecated use sensitiveTaskIsolation instead.\n   */\n  readonly isolateSensitiveTasks?: boolean;\n\n  /**\n   * Whether compute environments for sensitive tasks (which operate on\n   * un-trusted complex data, such as the transliterator, which operates with\n   * externally-sourced npm package tarballs) should run in network-isolated\n   * environments. This implies the creation of additonal resources, including:\n   *\n   * - A VPC with only isolated subnets.\n   * - VPC Endpoints (CloudWatch Logs, CodeArtifact, CodeArtifact API, S3, ...)\n   * - A CodeArtifact Repository with an external connection to npmjs.com\n   *\n   * @default Isolation.NO_INTERNET_ACCESS\n   */\n  readonly sensitiveTaskIsolation?: Isolation;\n\n  /**\n   * How long to retain CloudWatch logs for.\n   *\n   * @defaults RetentionDays.TEN_YEARS\n   */\n  readonly logRetention?: RetentionDays;\n\n  /**\n   * The name of the CloudWatch dashboard that represents the health of backend\n   * systems.\n   */\n  readonly backendDashboardName?: string;\n\n  /**\n   * A list of packages to block from the construct hub.\n   *\n   * @default []\n   */\n  readonly denyList?: DenyListRule[];\n\n  /**\n   * The package sources to register with this ConstructHub instance.\n   *\n   * @default - a standard npmjs.com package source will be configured.\n   */\n  readonly packageSources?: IPackageSource[];\n\n  /**\n   * The allowed licenses for packages indexed by this instance of ConstructHub.\n   *\n   * @default [...SpdxLicense.apache(),...SpdxLicense.bsd(),...SpdxLicense.cddl(),...SpdxLicense.epl(),SpdxLicense.ISC,...SpdxLicense.mit(),SpdxLicense.MPL_2_0]\n   */\n  readonly allowedLicenses?: SpdxLicense[];\n\n  /**\n   * When using a CodeArtifact package source, it is often desirable to have\n   * ConstructHub provision it's internal CodeArtifact repository in the same\n   * CodeArtifact domain, and to configure the package source repository as an\n   * upstream of the internal repository. This way, all packages in the source\n   * are available to ConstructHub's backend processing.\n   *\n   * @default - none.\n   */\n  readonly codeArtifactDomain?: CodeArtifactDomainProps;\n\n  /**\n   * Configuration for custom package page links.\n   */\n  readonly packageLinks?: PackageLinkConfig[];\n\n  /**\n   * Configuration for custom package tags\n   */\n  readonly packageTags?: PackageTag[];\n\n  /**\n   * Optional configuration for grouping custom package tags\n   */\n  readonly packageTagGroups?: PackageTagGroup[];\n\n  /**\n   * Configuration for packages to feature on the home page.\n   * @default - Display the 10 most recently updated packages\n   */\n  readonly featuredPackages?: FeaturedPackages;\n\n  /**\n   * Configure feature flags for the web app.\n   */\n  readonly featureFlags?: FeatureFlags;\n\n  /**\n   * Configure whether or not the backend should periodically query NPM\n   * for the number of downloads a package has in the past week, and\n   * display download counts on the web app.\n   *\n   * @default - true if packageSources is not specified (the defaults are\n   * used), false otherwise\n   */\n  readonly fetchPackageStats?: boolean;\n\n  /**\n   * Browse categories. Each category will appear in the home page as a button\n   * with a link to the relevant search query.\n   */\n  readonly categories?: Category[];\n\n  /**\n   * Wire construct hub to use the failover storage buckets.\n   *\n   * Do not activate this property until you've populated your failover buckets\n   * with the necessary data.\n   *\n   * @see https://github.com/cdklabs/construct-hub/blob/dev/docs/operator-runbook.md#storage-disaster\n   * @default false\n   */\n  readonly failoverStorage?: boolean;\n\n  /**\n   * How frequently all packages should get fully reprocessed.\n   *\n   * See the operator runbook for more information about reprocessing.\n   * @see https://github.com/cdklabs/construct-hub/blob/main/docs/operator-runbook.md\n   *\n   * @default - never\n   */\n  readonly reprocessFrequency?: Duration;\n\n  /**\n   * Package versions that have been published before this time window will not be reprocessed.\n   *\n   * @default Duration.days(90)\n   */\n  readonly reprocessAge?: Duration;\n\n  /**\n   * Additional domains which will be set up to redirect to the primary\n   * construct hub domain.\n   *\n   * @default []\n   */\n  readonly additionalDomains?: DomainRedirectSource[];\n\n  /**\n   * Javascript to run on webapp before app loads\n   *\n   * @default - create an empty file\n   */\n  readonly preloadScript?: PreloadFile;\n\n  /**\n   * Create an AppRegistry application associated with the stack containing\n   * this construct.\n   *\n   * @default true\n   */\n  readonly appRegistryApplication?: boolean;\n\n  /**\n   * Configuration for generating RSS/Atom feeds with the latest packages. If the value is missing\n   * the generated RSS/ATOM feed would not contain release notes\n   */\n  readonly feedConfiguration?: FeedConfiguration;\n}\n\n/**\n * Information pertaining to an existing CodeArtifact Domain.\n */\nexport interface CodeArtifactDomainProps {\n  /**\n   * The name of the CodeArtifact domain.\n   */\n  readonly name: string;\n\n  /**\n   * Any upstream repositories in this CodeArtifact domain that should be\n   * configured on the internal CodeArtifact repository.\n   */\n  readonly upstreams?: string[];\n}\n\n/**\n * Construct Hub.\n */\nexport class ConstructHub extends Construct implements iam.IGrantable {\n  /**\n   * The function operators can use to reprocess a specific package version\n   * through the backend data pipeline.\n   */\n  public readonly regenerateAllDocumentationPerPackage: IStateMachine;\n\n  private readonly ingestion: Ingestion;\n  private readonly monitoring: Monitoring;\n\n  public constructor(\n    scope: Construct,\n    id: string,\n    props: ConstructHubProps = {}\n  ) {\n    super(scope, id);\n\n    if (\n      props.isolateSensitiveTasks != null &&\n      props.sensitiveTaskIsolation != null\n    ) {\n      throw new Error(\n        'Supplying both isolateSensitiveTasks and sensitiveTaskIsolation is not supported. Remove usage of isolateSensitiveTasks.'\n      );\n    }\n\n    const shouldFetchReleaseNotes = props.feedConfiguration?.githubTokenSecret\n      ? true\n      : false;\n\n    const storageFactory = S3StorageFactory.getOrCreate(this, {\n      failover: props.failoverStorage,\n    });\n\n    this.monitoring = new Monitoring(this, 'Monitoring', {\n      alarmActions: props.alarmActions,\n    });\n\n    const overviewDashboard = new OverviewDashboard(this, 'OverviewDashboard', {\n      lambdaServiceAlarmThreshold: 70,\n      dashboardName: props.backendDashboardName\n        ? `${props.backendDashboardName}-overview`\n        : undefined,\n    });\n\n    const packageData = storageFactory.newBucket(this, 'PackageData', {\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      enforceSSL: true,\n      encryption: s3.BucketEncryption.S3_MANAGED,\n      lifecycleRules: [\n        // Abort multi-part uploads after 1 day\n        { abortIncompleteMultipartUploadAfter: Duration.days(1) },\n        // Transition non-current object versions to IA after 1 month\n        {\n          noncurrentVersionTransitions: [\n            {\n              storageClass: s3.StorageClass.INFREQUENT_ACCESS,\n              transitionAfter: Duration.days(31),\n            },\n          ],\n        },\n        // Permanently delete non-current object versions after 3 months\n        {\n          noncurrentVersionExpiration: Duration.days(90),\n          expiredObjectDeleteMarker: true,\n        },\n        // Permanently delete non-current versions of catalog.json earlier\n        { noncurrentVersionExpiration: Duration.days(7), prefix: CATALOG_KEY },\n      ],\n      versioned: true,\n    });\n\n    const isolation =\n      props.sensitiveTaskIsolation ??\n      (props.isolateSensitiveTasks\n        ? Isolation.NO_INTERNET_ACCESS\n        : Isolation.UNLIMITED_INTERNET_ACCESS);\n\n    // Create an internal CodeArtifact repository if we run in network-controlled mode, or if a domain is provided.\n    const codeArtifact =\n      isolation === Isolation.NO_INTERNET_ACCESS ||\n        props.codeArtifactDomain != null\n        ? new Repository(this, 'CodeArtifact', {\n          description: 'Proxy to npmjs.com for ConstructHub',\n          domainName: props.codeArtifactDomain?.name,\n          domainExists: props.codeArtifactDomain != null,\n          upstreams: props.codeArtifactDomain?.upstreams,\n        })\n        : undefined;\n    const { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups } = this.createVpc(\n      isolation,\n      codeArtifact\n    );\n\n    const denyList = new DenyList(this, 'DenyList', {\n      rules: props.denyList ?? [],\n      packageDataBucket: packageData,\n      packageDataKeyPrefix: STORAGE_KEY_PREFIX,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n    });\n\n    // disable fetching package stats by default if a different package\n    // source is configured\n    const fetchPackageStats =\n      props.fetchPackageStats ?? (props.packageSources ? false : true);\n\n    let packageStats: PackageStats | undefined;\n    const statsKey = 'stats.json';\n    if (fetchPackageStats) {\n      packageStats = new PackageStats(this, 'Stats', {\n        bucket: packageData,\n        monitoring: this.monitoring,\n        logRetention: props.logRetention,\n        objectKey: statsKey,\n      });\n    }\n\n    const versionTracker = new VersionTracker(this, 'VersionTracker', {\n      bucket: packageData,\n      monitoring: this.monitoring,\n      logRetention: props.logRetention,\n    });\n\n    const feedBuilder = new FeedBuilder(this, 'FeedBuilder', {\n      bucket: packageData,\n      overviewDashboard,\n      feedDescription: props.feedConfiguration?.feedDescription,\n      feedTitle: props.feedConfiguration?.feedTitle,\n      monitoring: this.monitoring,\n    });\n\n    const orchestration = new Orchestration(this, 'Orchestration', {\n      bucket: packageData,\n      codeArtifact,\n      denyList,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n      vpc,\n      vpcEndpoints,\n      vpcSubnets,\n      vpcSecurityGroups,\n      feedBuilder,\n    });\n    this.regenerateAllDocumentationPerPackage =\n      orchestration.regenerateAllDocumentationPerPackage;\n\n    // rebuild the catalog when the deny list changes.\n    denyList.prune.onChangeInvoke(orchestration.catalogBuilder.function);\n\n    const packageTagsSerialized =\n      props.packageTags?.map((config) => {\n        return {\n          ...config,\n          condition: config.condition.bind(),\n        };\n      }) ?? [];\n\n    let releaseNotes;\n    if (shouldFetchReleaseNotes) {\n      releaseNotes = new ReleaseNoteFetcher(this, 'ReleaseNotes', {\n        bucket: packageData,\n        gitHubCredentialsSecret: props.feedConfiguration?.githubTokenSecret,\n        feedBuilder,\n        monitoring: this.monitoring,\n        overviewDashboard,\n      });\n    }\n\n    this.ingestion = new Ingestion(this, 'Ingestion', {\n      bucket: packageData,\n      codeArtifact,\n      orchestration,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      packageLinks: props.packageLinks,\n      packageTags: packageTagsSerialized,\n      reprocessFrequency: props.reprocessFrequency,\n      reprocessAge: props.reprocessAge,\n      releaseNotesFetchQueue: releaseNotes?.queue,\n      overviewDashboard: overviewDashboard,\n    });\n\n    const licenseList = new LicenseList(this, 'LicenseList', {\n      licenses: props.allowedLicenses ?? [\n        ...SpdxLicense.apache(),\n        ...SpdxLicense.bsd(),\n        ...SpdxLicense.cddl(),\n        ...SpdxLicense.epl(),\n        SpdxLicense.ISC,\n        ...SpdxLicense.mit(),\n        SpdxLicense.MPL_2_0,\n      ],\n    });\n\n    const webApp = new WebApp(this, 'WebApp', {\n      domain: props.domain,\n      monitoring: this.monitoring,\n      packageData,\n      packageLinks: props.packageLinks,\n      packageTags: packageTagsSerialized,\n      packageTagGroups: props.packageTagGroups,\n      featuredPackages: props.featuredPackages,\n      packageStats,\n      featureFlags: props.featureFlags,\n      categories: props.categories,\n      preloadScript: props.preloadScript,\n      overviewDashboard: overviewDashboard,\n      includeFeedLink: true,\n    });\n\n    // Set the base URL that will be used in the RSS/ATOM feed\n    feedBuilder.setConstructHubUrl(webApp.baseUrl);\n\n    const sources = new Construct(this, 'Sources');\n    const packageSources = (props.packageSources ?? [new NpmJs()]).map(\n      (source) =>\n        source.bind(sources, {\n          baseUrl: webApp.baseUrl,\n          denyList,\n          ingestion: this.ingestion,\n          licenseList,\n          monitoring: this.monitoring,\n          queue: this.ingestion.queue,\n          repository: codeArtifact,\n          overviewDashboard: overviewDashboard,\n        })\n    );\n\n    const inventory = new Inventory(this, 'InventoryCanary', {\n      bucket: packageData,\n      logRetention: props.logRetention,\n      monitoring: this.monitoring,\n      overviewDashboard: overviewDashboard,\n    });\n\n    new BackendDashboard(this, 'BackendDashboard', {\n      packageData,\n      dashboardName: props.backendDashboardName,\n      packageSources,\n      ingestion: this.ingestion,\n      inventory,\n      orchestration,\n      denyList,\n      packageStats,\n      versionTracker,\n      releaseNotes,\n    });\n\n    // add domain redirects\n    if (props.domain) {\n      for (const redirctSource of props.additionalDomains ?? []) {\n        new DomainRedirect(\n          this,\n          `Redirect-${redirctSource.hostedZone.zoneName}`,\n          {\n            source: redirctSource,\n            targetDomainName: props.domain?.zone.zoneName,\n          }\n        );\n      }\n    } else {\n      if (props.additionalDomains && props.additionalDomains.length > 0) {\n        throw new Error(\n          'Cannot specify \"domainRedirects\" if a domain is not specified'\n        );\n      }\n    }\n\n    if (props.appRegistryApplication ?? true) {\n      const application = new Application(this, 'Application', {\n        applicationName: 'ConstructHub',\n      });\n      application.associateApplicationWithStack(Stack.of(this));\n    }\n  }\n\n  /**\n   * Returns a list of all high-severity alarms from this ConstructHub instance.\n   * These warrant immediate attention as they are indicative of a system health\n   * issue.\n   */\n  public get highSeverityAlarms(): cw.IAlarm[] {\n    // Note: the array is already returned by-copy by Monitoring, so not copying again.\n    return this.monitoring.highSeverityAlarms;\n  }\n\n  /**\n   * Returns a list of all low-severity alarms from this ConstructHub instance.\n   * These do not necessitate immediate attention, as they do not have direct\n   * customer-visible impact, or handling is not time-sensitive. They indicate\n   * that something unusual (not necessarily bad) is happening.\n   */\n  public get mediumSeverityAlarms(): cw.IAlarm[] {\n    // Note: the array is already returned by-copy by Monitoring, so not copying again.\n    return this.monitoring.mediumSeverityAlarms;\n  }\n\n  /**\n   * Returns a list of all low-severity alarms from this ConstructHub instance.\n   * These do not necessitate immediate attention, as they do not have direct\n   * customer-visible impact, or handling is not time-sensitive. They indicate\n   * that something unusual (not necessarily bad) is happening.\n   */\n  public get lowSeverityAlarms(): cw.IAlarm[] {\n    // Note: the array is already returned by-copy by Monitoring, so not copying again.\n    return this.monitoring.lowSeverityAlarms;\n  }\n\n  /**\n   * Returns a list of all alarms configured by this ConstructHub instance.\n   */\n  public get allAlarms(): cw.IAlarm[] {\n    return [...this.highSeverityAlarms, ...this.lowSeverityAlarms, ...this.mediumSeverityAlarms];\n  }\n\n  public get grantPrincipal(): iam.IPrincipal {\n    return this.ingestion.grantPrincipal;\n  }\n\n  public get ingestionQueue(): sqs.IQueue {\n    return this.ingestion.queue;\n  }\n\n  private createVpc(\n    isolation: Isolation,\n    codeArtifact: Repository | undefined\n  ) {\n    if (isolation === Isolation.UNLIMITED_INTERNET_ACCESS) {\n      return { vpc: undefined, vpcEndpoints: undefined, vpcSubnets: undefined };\n    }\n\n    const subnetType =\n      isolation === Isolation.NO_INTERNET_ACCESS\n        ? ec2.SubnetType.PRIVATE_ISOLATED\n        : ec2.SubnetType.PRIVATE_WITH_EGRESS;\n    const vpcSubnets = { subnetType };\n\n    const vpc = new ec2.Vpc(this, 'VPC', {\n      enableDnsHostnames: true,\n      enableDnsSupport: true,\n      // Provision no NAT gateways if we are running ISOLATED (we wouldn't have a public subnet)\n      natGateways:\n        subnetType === ec2.SubnetType.PRIVATE_ISOLATED ? 0 : undefined,\n      // Pre-allocating PUBLIC / PRIVATE / INTERNAL subnets, regardless of use, so we don't create\n      // a whole new VPC if we ever need to introduce subnets of these types.\n      subnetConfiguration: [\n        // If there is a PRIVATE subnet, there must also have a PUBLIC subnet (for NAT gateways).\n        {\n          name: 'Public',\n          subnetType: ec2.SubnetType.PUBLIC,\n          reserved: subnetType === ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n        {\n          name: 'Private',\n          subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,\n          reserved: subnetType === ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n        {\n          name: 'Isolated',\n          subnetType: ec2.SubnetType.PRIVATE_ISOLATED,\n          reserved: subnetType !== ec2.SubnetType.PRIVATE_ISOLATED,\n        },\n      ],\n    });\n    Tags.of(vpc.node.defaultChild!).add('Name', vpc.node.path);\n\n    const securityGroups =\n      subnetType === ec2.SubnetType.PRIVATE_WITH_EGRESS\n        ? createRestrictedSecurityGroups(this, vpc)\n        : undefined;\n\n    // Creating the CodeArtifact endpoints only if a repository is present.\n    const codeArtifactEndpoints = codeArtifact && {\n      codeArtifactApi: vpc.addInterfaceEndpoint('CodeArtifact.API', {\n        privateDnsEnabled: false,\n        service: new ec2.InterfaceVpcEndpointAwsService('codeartifact.api'),\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      codeArtifact: vpc.addInterfaceEndpoint('CodeArtifact', {\n        privateDnsEnabled: true,\n        service: new ec2.InterfaceVpcEndpointAwsService(\n          'codeartifact.repositories'\n        ),\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n    };\n\n    // We'll only use VPC endpoints if we are configured to run in an ISOLATED subnet.\n    const vpcEndpoints = {\n      ...codeArtifactEndpoints,\n      // This is needed so that ECS workloads can use the awslogs driver\n      cloudWatchLogs: vpc.addInterfaceEndpoint('CloudWatch.Logs', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.CLOUDWATCH_LOGS,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      // These are needed for ECS workloads to be able to pull images\n      ecrApi: vpc.addInterfaceEndpoint('ECR.API', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.ECR,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      ecr: vpc.addInterfaceEndpoint('ECR.Docker', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.ECR_DOCKER,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n      // This is needed (among others) for CodeArtifact registry usage\n      s3: vpc.addGatewayEndpoint('S3', {\n        service: ec2.GatewayVpcEndpointAwsService.S3,\n        subnets: [vpcSubnets],\n      }),\n      // This is useful for getting results from ECS tasks within workflows\n      stepFunctions: vpc.addInterfaceEndpoint('StepFunctions', {\n        privateDnsEnabled: true,\n        service: ec2.InterfaceVpcEndpointAwsService.STEP_FUNCTIONS,\n        subnets: vpcSubnets,\n        securityGroups,\n      }),\n    };\n\n    // The S3 access is necessary for the CodeArtifact Repository and ECR Docker\n    // endpoints to be used (they serve objects from S3).\n    vpcEndpoints.s3.addToPolicy(\n      new PolicyStatement({\n        effect: Effect.ALLOW,\n        actions: ['s3:GetObject'],\n        resources: [\n          // The in-region CodeArtifact S3 Bucket\n          ...(codeArtifact ? [`${codeArtifact.s3BucketArn}/*`] : []),\n          // The in-region ECR layer bucket\n          `arn:aws:s3:::prod-${Stack.of(this).region}-starport-layer-bucket/*`,\n        ],\n        // It doesn't seem we can constrain principals for these grants (unclear\n        // which principal those calls are made from, or if that is something we\n        // could name here).\n        principals: [new AnyPrincipal()],\n        sid: 'Allow-CodeArtifact-and-ECR',\n      })\n    );\n\n    return { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups: securityGroups };\n  }\n}\n\n/**\n * How possibly risky operations (such as doc-generation, which requires\n * installing the indexed packages in order to trans-literate sample code) are\n * isolated to mitigate possible arbitrary code execution vulnerabilities in and\n * around `npm install` or the transliterator's use of the TypeScript compiler.\n */\nexport enum Isolation {\n  /**\n   * No isolation is done whatsoever. The doc-generation process still is\n   * provisioned with least-privilege permissions, but retains complete access\n   * to internet.\n   *\n   * While this maximizes the chances of successfully installing packages (and\n   * hence successfully generating documentation for those), it is also the\n   * least secure mode of operation.\n   *\n   * We advise you only consider using this isolation mode if you are hosting a\n   * ConstructHub instance that only indexes trusted packages (including\n   * transitive dependencies).\n   */\n  UNLIMITED_INTERNET_ACCESS,\n\n  /**\n   * The same protections as `UNLIMITED_INTERNET_ACCESS`, except outbound\n   * internet connections are limited to IP address ranges corresponding to\n   * hosting endpoints for npmjs.com.\n   */\n  LIMITED_INTERNET_ACCESS,\n\n  /**\n   * The same protections as `LIMITED_INTERNET_ACCESS`, except all remaining\n   * internet access is removed. All traffic to AWS service endpoints is routed\n   * through VPC Endpoints, as the compute nodes are jailed in a completely\n   * isolated VPC.\n   *\n   * This is the most secure (and recommended) mode of operation for\n   * ConstructHub instances.\n   */\n  NO_INTERNET_ACCESS,\n}\n"]}
@@ -12,6 +12,14 @@ export interface IMonitoring {
12
12
  * @param alarm the alarm to be added to the high-severity dashboard.
13
13
  */
14
14
  addHighSeverityAlarm(title: string, alarm: AlarmBase): void;
15
+ /**
16
+ * Adds a medium-severity alarm. If this alarm goes off, the action specified in
17
+ * `mediumSeverityAlarmAction` is triggered.
18
+ *
19
+ * @param title a user-friendly title for the alarm (not currently used).
20
+ * @param alarm the alarm to be added.
21
+ */
22
+ addMediumSeverityAlarm(title: string, alarm: AlarmBase): void;
15
23
  /**
16
24
  * Adds a low-severity alarm. If this alarm goes off, the action specified in
17
25
  * `normalAlarmAction` is triggered.
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vbml0b3JpbmcvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEFsYXJtQmFzZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcblxuLyoqXG4gKiBDb25zdHJ1Y3RIdWIgbW9uaXRvcmluZyBmZWF0dXJlcyBleHBvc2VkIHRvIGV4dGVuc2lvbiBwb2ludHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSU1vbml0b3Jpbmcge1xuICAvKipcbiAgICogQWRkcyBhIGhpZ2gtc2V2ZXJpdHkgYWxhcm0uIElmIHRoaXMgYWxhcm0gZ29lcyBvZmYsIHRoZSBhY3Rpb24gc3BlY2lmaWVkIGluXG4gICAqIGBoaWdoU2V2ZXJpdHlBbGFybUFjdGlvbkFybmAgaXMgdHJpZ2dlcmVkLlxuICAgKlxuICAgKiBAcGFyYW0gdGl0bGUgYSB1c2VyLWZyaWVuZGx5IHRpdGxlIGZvciB0aGUgYWxhcm0gKHdpbGwgYmUgcmVuZGVyZWQgb24gdGhlXG4gICAqICAgICAgICAgICAgICBoaWdoLXNldmVyaXR5IENsb3VkV2F0Y2ggZGFzaGJvYXJkKVxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkIHRvIHRoZSBoaWdoLXNldmVyaXR5IGRhc2hib2FyZC5cbiAgICovXG4gIGFkZEhpZ2hTZXZlcml0eUFsYXJtKHRpdGxlOiBzdHJpbmcsIGFsYXJtOiBBbGFybUJhc2UpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgbG93LXNldmVyaXR5IGFsYXJtLiBJZiB0aGlzIGFsYXJtIGdvZXMgb2ZmLCB0aGUgYWN0aW9uIHNwZWNpZmllZCBpblxuICAgKiBgbm9ybWFsQWxhcm1BY3Rpb25gIGlzIHRyaWdnZXJlZC5cbiAgICpcbiAgICogQHBhcmFtIHRpdGxlIGEgdXNlci1mcmllbmRseSB0aXRsZSBmb3IgdGhlIGFsYXJtIChub3QgY3VycmVudGx5IHVzZWQpLlxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkLlxuICAgKi9cbiAgYWRkTG93U2V2ZXJpdHlBbGFybSh0aXRsZTogc3RyaW5nLCBhbGFybTogQWxhcm1CYXNlKTogdm9pZDtcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vbml0b3JpbmcvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEFsYXJtQmFzZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcblxuLyoqXG4gKiBDb25zdHJ1Y3RIdWIgbW9uaXRvcmluZyBmZWF0dXJlcyBleHBvc2VkIHRvIGV4dGVuc2lvbiBwb2ludHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSU1vbml0b3Jpbmcge1xuICAvKipcbiAgICogQWRkcyBhIGhpZ2gtc2V2ZXJpdHkgYWxhcm0uIElmIHRoaXMgYWxhcm0gZ29lcyBvZmYsIHRoZSBhY3Rpb24gc3BlY2lmaWVkIGluXG4gICAqIGBoaWdoU2V2ZXJpdHlBbGFybUFjdGlvbkFybmAgaXMgdHJpZ2dlcmVkLlxuICAgKlxuICAgKiBAcGFyYW0gdGl0bGUgYSB1c2VyLWZyaWVuZGx5IHRpdGxlIGZvciB0aGUgYWxhcm0gKHdpbGwgYmUgcmVuZGVyZWQgb24gdGhlXG4gICAqICAgICAgICAgICAgICBoaWdoLXNldmVyaXR5IENsb3VkV2F0Y2ggZGFzaGJvYXJkKVxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkIHRvIHRoZSBoaWdoLXNldmVyaXR5IGRhc2hib2FyZC5cbiAgICovXG4gIGFkZEhpZ2hTZXZlcml0eUFsYXJtKHRpdGxlOiBzdHJpbmcsIGFsYXJtOiBBbGFybUJhc2UpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgbWVkaXVtLXNldmVyaXR5IGFsYXJtLiBJZiB0aGlzIGFsYXJtIGdvZXMgb2ZmLCB0aGUgYWN0aW9uIHNwZWNpZmllZCBpblxuICAgKiBgbWVkaXVtU2V2ZXJpdHlBbGFybUFjdGlvbmAgaXMgdHJpZ2dlcmVkLlxuICAgKlxuICAgKiBAcGFyYW0gdGl0bGUgYSB1c2VyLWZyaWVuZGx5IHRpdGxlIGZvciB0aGUgYWxhcm0gKG5vdCBjdXJyZW50bHkgdXNlZCkuXG4gICAqIEBwYXJhbSBhbGFybSB0aGUgYWxhcm0gdG8gYmUgYWRkZWQuXG4gICAqL1xuICBhZGRNZWRpdW1TZXZlcml0eUFsYXJtKHRpdGxlOiBzdHJpbmcsIGFsYXJtOiBBbGFybUJhc2UpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgbG93LXNldmVyaXR5IGFsYXJtLiBJZiB0aGlzIGFsYXJtIGdvZXMgb2ZmLCB0aGUgYWN0aW9uIHNwZWNpZmllZCBpblxuICAgKiBgbm9ybWFsQWxhcm1BY3Rpb25gIGlzIHRyaWdnZXJlZC5cbiAgICpcbiAgICogQHBhcmFtIHRpdGxlIGEgdXNlci1mcmllbmRseSB0aXRsZSBmb3IgdGhlIGFsYXJtIChub3QgY3VycmVudGx5IHVzZWQpLlxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkLlxuICAgKi9cbiAgYWRkTG93U2V2ZXJpdHlBbGFybSh0aXRsZTogc3RyaW5nLCBhbGFybTogQWxhcm1CYXNlKTogdm9pZDtcbn1cbiJdfQ==
@@ -24,6 +24,7 @@ export interface MonitoringProps {
24
24
  export declare class Monitoring extends Construct implements IMonitoring {
25
25
  private alarmActions?;
26
26
  private _highSeverityAlarms;
27
+ private _mediumSeverityAlarms;
27
28
  private _lowSeverityAlarms;
28
29
  /**
29
30
  * Allows adding automatic monitoring to standard resources. Note that
@@ -39,7 +40,9 @@ export declare class Monitoring extends Construct implements IMonitoring {
39
40
  */
40
41
  addHighSeverityAlarm(title: string, alarm: cw.AlarmBase): void;
41
42
  addLowSeverityAlarm(_title: string, alarm: cw.AlarmBase): void;
43
+ addMediumSeverityAlarm(_title: string, alarm: cw.AlarmBase): void;
42
44
  get highSeverityAlarms(): cw.AlarmBase[];
45
+ get mediumSeverityAlarms(): cw.AlarmBase[];
43
46
  get lowSeverityAlarms(): cw.AlarmBase[];
44
47
  /**
45
48
  * Adds a canary that pings a certain URL and raises an alarm in case the URL
@@ -29,6 +29,7 @@ class Monitoring extends constructs_1.Construct {
29
29
  });
30
30
  this._highSeverityAlarms = [];
31
31
  this._lowSeverityAlarms = [];
32
+ this._mediumSeverityAlarms = [];
32
33
  this.highSeverityDashboard = new cw.Dashboard(this, 'HighSeverityDashboard');
33
34
  }
34
35
  /**
@@ -66,9 +67,25 @@ class Monitoring extends constructs_1.Construct {
66
67
  }
67
68
  this._lowSeverityAlarms.push(alarm);
68
69
  }
70
+ addMediumSeverityAlarm(_title, alarm) {
71
+ const actionArn = this.alarmActions?.mediumSeverity;
72
+ if (actionArn) {
73
+ alarm.addAlarmAction({
74
+ bind: () => ({ alarmActionArn: actionArn }),
75
+ });
76
+ }
77
+ const action = this.alarmActions?.mediumSeverityAction;
78
+ if (action) {
79
+ alarm.addAlarmAction(action);
80
+ }
81
+ this._mediumSeverityAlarms.push(alarm);
82
+ }
69
83
  get highSeverityAlarms() {
70
84
  return [...this._highSeverityAlarms];
71
85
  }
86
+ get mediumSeverityAlarms() {
87
+ return [...this._mediumSeverityAlarms];
88
+ }
72
89
  get lowSeverityAlarms() {
73
90
  return [...this._lowSeverityAlarms];
74
91
  }
@@ -90,4 +107,4 @@ class Monitoring extends constructs_1.Construct {
90
107
  }
91
108
  }
92
109
  exports.Monitoring = Monitoring;
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/monitoring/index.ts"],"names":[],"mappings":";;;AAAA,iDAAiD;AACjD,+CAAwC;AACxC,2CAAuC;AAEvC,6CAAyC;AAazC;;;;;;;;GAQG;AACH,MAAa,UAAW,SAAQ,sBAAS;IAcvC,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAyB,EAAE;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;QAEvC,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAC7C,oEAAoE;YACpE,eAAe,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc;gBAChD,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC;gBACpC,CAAC,CAAC,EAAE;YACN,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,oBAAoB;gBACnD,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC;gBAC1C,CAAC,CAAC,EAAE;SACP,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;QAE7B,IAAI,CAAC,qBAAqB,GAAG,IAAI,EAAE,CAAC,SAAS,CAC3C,IAAI,EACJ,uBAAuB,CACxB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACI,oBAAoB,CAAC,KAAa,EAAE,KAAmB;QAC5D,MAAM,qBAAqB,GAAG,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC;QAC9D,IAAI,qBAAqB,EAAE,CAAC;YAC1B,KAAK,CAAC,cAAc,CAAC;gBACnB,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,cAAc,EAAE,qBAAqB,EAAE,CAAC;aACxD,CAAC,CAAC;QACL,CAAC;QACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC;QACjE,IAAI,kBAAkB,EAAE,CAAC;YACvB,KAAK,CAAC,cAAc,CAAC,kBAAkB,CAAC,CAAC;QAC3C,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,UAAU,CACnC,IAAI,EAAE,CAAC,WAAW,CAAC;YACjB,KAAK;YACL,KAAK;YACL,KAAK,EAAE,EAAE;SACV,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAEM,mBAAmB,CAAC,MAAc,EAAE,KAAmB;QAC5D,MAAM,uBAAuB,GAAG,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC;QAClE,IAAI,uBAAuB,EAAE,CAAC;YAC5B,KAAK,CAAC,cAAc,CAAC;gBACnB,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,cAAc,EAAE,uBAAuB,EAAE,CAAC;aAC1D,CAAC,CAAC;QACL,CAAC;QACD,MAAM,oBAAoB,GAAG,IAAI,CAAC,YAAY,EAAE,oBAAoB,CAAC;QACrE,IAAI,oBAAoB,EAAE,CAAC;YACzB,KAAK,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,IAAW,kBAAkB;QAC3B,OAAO,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACvC,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;IACtC,CAAC;IAED;;;;;;;;OAQG;IACI,YAAY,CAAC,IAAY,EAAE,GAAW;QAC3C,MAAM,MAAM,GAAG,IAAI,sBAAS,CAC1B,IAAI,EACJ,YAAY,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,EAAE,EAC7C;YACE,GAAG;YACH,WAAW,EAAE,IAAI;SAClB,CACF,CAAC;QAEF,IAAI,CAAC,oBAAoB,CAAC,GAAG,IAAI,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;CACF;AA5GD,gCA4GC","sourcesContent":["import * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport { Watchful } from 'cdk-watchful';\nimport { Construct } from 'constructs';\nimport { IMonitoring } from './api';\nimport { WebCanary } from './web-canary';\nimport { AlarmActions } from '../api';\n\n/**\n * Props for the monitoring construct.\n */\nexport interface MonitoringProps {\n  /**\n   * ARNs of alarm actions to take for various severities.\n   */\n  readonly alarmActions?: AlarmActions;\n}\n\n/**\n * Construct hub monitoring.\n *\n * This construct uses cdk-watchful to automatically generate a dashboard and a\n * set of standard alarms for common resources.\n *\n * Components should use the APIs of this module to add watchful monitors,\n * and add canaries and alarms as needed.\n */\nexport class Monitoring extends Construct implements IMonitoring {\n  private alarmActions?: AlarmActions;\n  private _highSeverityAlarms: cw.AlarmBase[];\n  private _lowSeverityAlarms: cw.AlarmBase[];\n\n  /**\n   * Allows adding automatic monitoring to standard resources. Note that\n   * watchful alarms are always treated as _normal_ severity. You can add\n   * high-severity alarm via `addHighSeverityAlarm()`.\n   */\n  public readonly watchful: Watchful;\n\n  private readonly highSeverityDashboard: cw.Dashboard;\n\n  constructor(scope: Construct, id: string, props: MonitoringProps = {}) {\n    super(scope, id);\n\n    this.alarmActions = props.alarmActions;\n\n    this.watchful = new Watchful(this, 'Watchful', {\n      // alarms that come from watchful are all considered normal severity\n      alarmActionArns: this.alarmActions?.normalSeverity\n        ? [this.alarmActions.normalSeverity]\n        : [],\n      alarmActions: this.alarmActions?.normalSeverityAction\n        ? [this.alarmActions.normalSeverityAction]\n        : [],\n    });\n\n    this._highSeverityAlarms = [];\n    this._lowSeverityAlarms = [];\n\n    this.highSeverityDashboard = new cw.Dashboard(\n      this,\n      'HighSeverityDashboard'\n    );\n  }\n\n  /**\n   * Adds a high-severity alarm. If this alarm goes off, the action specified in `highSeverityAlarmActionArn`\n   * @param alarm\n   */\n  public addHighSeverityAlarm(title: string, alarm: cw.AlarmBase) {\n    const highSeverityActionArn = this.alarmActions?.highSeverity;\n    if (highSeverityActionArn) {\n      alarm.addAlarmAction({\n        bind: () => ({ alarmActionArn: highSeverityActionArn }),\n      });\n    }\n    const highSeverityAction = this.alarmActions?.highSeverityAction;\n    if (highSeverityAction) {\n      alarm.addAlarmAction(highSeverityAction);\n    }\n\n    this.highSeverityDashboard.addWidgets(\n      new cw.AlarmWidget({\n        alarm,\n        title,\n        width: 24,\n      })\n    );\n\n    this._highSeverityAlarms.push(alarm);\n  }\n\n  public addLowSeverityAlarm(_title: string, alarm: cw.AlarmBase) {\n    const normalSeverityActionArn = this.alarmActions?.normalSeverity;\n    if (normalSeverityActionArn) {\n      alarm.addAlarmAction({\n        bind: () => ({ alarmActionArn: normalSeverityActionArn }),\n      });\n    }\n    const normalSeverityAction = this.alarmActions?.normalSeverityAction;\n    if (normalSeverityAction) {\n      alarm.addAlarmAction(normalSeverityAction);\n    }\n    this._lowSeverityAlarms.push(alarm);\n  }\n\n  public get highSeverityAlarms() {\n    return [...this._highSeverityAlarms];\n  }\n\n  public get lowSeverityAlarms() {\n    return [...this._lowSeverityAlarms];\n  }\n\n  /**\n   * Adds a canary that pings a certain URL and raises an alarm in case the URL\n   * responds with an error over 80% of the times.\n   *\n   * Canary failures are always considered high-severity (at this point).\n   *\n   * @param name The name of the canary\n   * @param url The URL to ping\n   */\n  public addWebCanary(name: string, url: string) {\n    const canary = new WebCanary(\n      this,\n      `WebCanary${name.replace(/[^A-Z0-9]/gi, '')}`,\n      {\n        url,\n        displayName: name,\n      }\n    );\n\n    this.addHighSeverityAlarm(`${name} Canary`, canary.alarm);\n  }\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/monitoring/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport { Watchful } from 'cdk-watchful';\nimport { Construct } from 'constructs';\nimport { IMonitoring } from './api';\nimport { WebCanary } from './web-canary';\nimport { AlarmActions } from '../api';\n\n/**\n * Props for the monitoring construct.\n */\nexport interface MonitoringProps {\n  /**\n   * ARNs of alarm actions to take for various severities.\n   */\n  readonly alarmActions?: AlarmActions;\n}\n\n/**\n * Construct hub monitoring.\n *\n * This construct uses cdk-watchful to automatically generate a dashboard and a\n * set of standard alarms for common resources.\n *\n * Components should use the APIs of this module to add watchful monitors,\n * and add canaries and alarms as needed.\n */\nexport class Monitoring extends Construct implements IMonitoring {\n  private alarmActions?: AlarmActions;\n  private _highSeverityAlarms: cw.AlarmBase[];\n  private _mediumSeverityAlarms: cw.AlarmBase[];\n  private _lowSeverityAlarms: cw.AlarmBase[];\n\n  /**\n   * Allows adding automatic monitoring to standard resources. Note that\n   * watchful alarms are always treated as _normal_ severity. You can add\n   * high-severity alarm via `addHighSeverityAlarm()`.\n   */\n  public readonly watchful: Watchful;\n\n  private readonly highSeverityDashboard: cw.Dashboard;\n\n  constructor(scope: Construct, id: string, props: MonitoringProps = {}) {\n    super(scope, id);\n\n    this.alarmActions = props.alarmActions;\n\n    this.watchful = new Watchful(this, 'Watchful', {\n      // alarms that come from watchful are all considered normal severity\n      alarmActionArns: this.alarmActions?.normalSeverity\n        ? [this.alarmActions.normalSeverity]\n        : [],\n      alarmActions: this.alarmActions?.normalSeverityAction\n        ? [this.alarmActions.normalSeverityAction]\n        : [],\n    });\n\n    this._highSeverityAlarms = [];\n    this._lowSeverityAlarms = [];\n    this._mediumSeverityAlarms = [];\n\n    this.highSeverityDashboard = new cw.Dashboard(\n      this,\n      'HighSeverityDashboard'\n    );\n  }\n\n  /**\n   * Adds a high-severity alarm. If this alarm goes off, the action specified in `highSeverityAlarmActionArn`\n   * @param alarm\n   */\n  public addHighSeverityAlarm(title: string, alarm: cw.AlarmBase) {\n    const highSeverityActionArn = this.alarmActions?.highSeverity;\n    if (highSeverityActionArn) {\n      alarm.addAlarmAction({\n        bind: () => ({ alarmActionArn: highSeverityActionArn }),\n      });\n    }\n    const highSeverityAction = this.alarmActions?.highSeverityAction;\n    if (highSeverityAction) {\n      alarm.addAlarmAction(highSeverityAction);\n    }\n\n    this.highSeverityDashboard.addWidgets(\n      new cw.AlarmWidget({\n        alarm,\n        title,\n        width: 24,\n      })\n    );\n\n    this._highSeverityAlarms.push(alarm);\n  }\n\n  public addLowSeverityAlarm(_title: string, alarm: cw.AlarmBase) {\n    const normalSeverityActionArn = this.alarmActions?.normalSeverity;\n    if (normalSeverityActionArn) {\n      alarm.addAlarmAction({\n        bind: () => ({ alarmActionArn: normalSeverityActionArn }),\n      });\n    }\n    const normalSeverityAction = this.alarmActions?.normalSeverityAction;\n    if (normalSeverityAction) {\n      alarm.addAlarmAction(normalSeverityAction);\n    }\n    this._lowSeverityAlarms.push(alarm);\n  }\n\n  public addMediumSeverityAlarm(_title: string, alarm: cw.AlarmBase) {\n    const actionArn = this.alarmActions?.mediumSeverity;\n    if (actionArn) {\n      alarm.addAlarmAction({\n        bind: () => ({ alarmActionArn: actionArn }),\n      });\n    }\n    const action = this.alarmActions?.mediumSeverityAction;\n    if (action) {\n      alarm.addAlarmAction(action);\n    }\n    this._mediumSeverityAlarms.push(alarm);\n  }\n\n  public get highSeverityAlarms() {\n    return [...this._highSeverityAlarms];\n  }\n\n  public get mediumSeverityAlarms() {\n    return [...this._mediumSeverityAlarms];\n  }\n\n  public get lowSeverityAlarms() {\n    return [...this._lowSeverityAlarms];\n  }\n\n  /**\n   * Adds a canary that pings a certain URL and raises an alarm in case the URL\n   * responds with an error over 80% of the times.\n   *\n   * Canary failures are always considered high-severity (at this point).\n   *\n   * @param name The name of the canary\n   * @param url The URL to ping\n   */\n  public addWebCanary(name: string, url: string) {\n    const canary = new WebCanary(\n      this,\n      `WebCanary${name.replace(/[^A-Z0-9]/gi, '')}`,\n      {\n        url,\n        displayName: name,\n      }\n    );\n\n    this.addHighSeverityAlarm(`${name} Canary`, canary.alarm);\n  }\n}\n"]}