construct-hub 0.4.4 → 0.4.7

Sign up to get free protection for your applications and to get access to all the features.
@@ -666,6 +666,38 @@ If there is a reason why a tracked version cannot possibly be ingested, the S3
666
666
  object backing the canary state can be deleted, which will effectively
667
667
  re-initialize the canary to track only the latest available version.
668
668
 
669
+ ### `ConstructHub/Sources/NpmJs/Canary/NotRunningOrFailing`
670
+
671
+ #### Description
672
+
673
+ This alarm is only provisioned in case the [NpmJs package canary][package-canary]
674
+ was configured. It triggers when the canary is not running as expected, or is
675
+ reporting failures.
676
+
677
+ When the [NpmJs package canary][package-canary] does not successfully run, the
678
+ `ConstructHub/Sources/NpmJs/Canary/SLA-Breached` alarm cannot be triggered due
679
+ to lack of data. This may hence hide customer-visible problems.
680
+
681
+ #### Investigation
682
+
683
+ In the AWS Console, verify whether the alarm triggered due to
684
+ `ConstructHub/Sources/NpmJs/Canary/Failing` or
685
+ `ConstructHub/Sources/NpmJs/Canary/NotRunning`.
686
+
687
+ If the canary is not running, verify that the scheduled trigger for the [NpmJs
688
+ package canary][package-canary] is correctly enabled. If it is, and the canary
689
+ is not running, the account might have run out of available AWS Lambda
690
+ concurrency, and a limit increase request might be necessary. When that is the
691
+ case, the function will report this via the `Throttled` metric.
692
+
693
+ Otherwise, [dive into the Lambda logs][#lambda-log-dive] of the Canary function
694
+ to determine what is happening and resolve the problem.
695
+
696
+ #### Resolution
697
+
698
+ Once the canary starts unning normally again, the alarm will clear itself
699
+ without requiring any further intervention.
700
+
669
701
  ## :information_source: General Recommendations
670
702
 
671
703
  ### Diving into Lambda Function logs in CloudWatch Logs
@@ -85,6 +85,10 @@ class CatalogBuilder extends constructs_1.Construct {
85
85
  evaluationPeriods: 1,
86
86
  threshold: -5,
87
87
  });
88
+ // This is a high-severity alarm because it is indicative of a possible mass-extinction event
89
+ // in the catalog. This should definitely prompt immediate investigation, although it can also
90
+ // be caused by the recent addition of enough packages in the deny-list to cause the alarm to
91
+ // trigger.
88
92
  props.monitoring.addHighSeverityAlarm('Catalog Size Shrunk', alarmShrinkingCatalog);
89
93
  }
90
94
  metricMissingConstructFrameworkCount(opts) {
@@ -116,4 +120,4 @@ class CatalogBuilder extends constructs_1.Construct {
116
120
  }
117
121
  }
118
122
  exports.CatalogBuilder = CatalogBuilder;
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/backend/catalog-builder/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { AssemblyTargets } from '@jsii/spec';\nimport { ArnFormat, Duration, Stack } from 'aws-cdk-lib';\nimport {\n  ComparisonOperator,\n  MathExpression,\n  Metric,\n  MetricOptions,\n  Statistic,\n} from 'aws-cdk-lib/aws-cloudwatch';\nimport { Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { IFunction, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\nimport { lambdaFunctionUrl, s3ObjectUrl } from '../../deep-link';\n\nimport { Monitoring } from '../../monitoring';\nimport { OverviewDashboard } from '../../overview-dashboard';\nimport { RUNBOOK_URL } from '../../runbook-url';\nimport { DenyList } from '../deny-list';\nimport { FeedBuilder } from '../feed-builder';\nimport type { ConstructFramework } from '../ingestion/framework-detection.lambda-shared';\nimport { CatalogBuilder as Handler } from './catalog-builder';\nimport { MetricName, METRICS_NAMESPACE } from './constants';\n\n/**\n * Props for `CatalogBuilder`.\n */\nexport interface CatalogBuilderProps {\n  /**\n   * The package store bucket.\n   */\n  readonly bucket: IBucket;\n\n  /**\n   * The monitoring handler to register alarms with.\n   */\n  readonly monitoring: Monitoring;\n\n  /**\n   * The overview dashboard to add widgets to.\n   */\n  readonly overviewDashboard: OverviewDashboard;\n\n  /**\n   * How long should execution logs be retained?\n   *\n   * @default RetentionDays.TEN_YEARS\n   */\n  readonly logRetention?: RetentionDays;\n\n  /**\n   * The deny list construct.\n   */\n  readonly denyList: DenyList;\n\n  /**\n   * Construct that generates RSS/ATOM feed after catalog is updated\n   */\n  readonly feedBuilder: FeedBuilder;\n}\n\n/**\n * Builds or re-builds the `catalog.json` object in the designated bucket.\n */\nexport class CatalogBuilder extends Construct {\n  public readonly function: IFunction;\n\n  public constructor(scope: Construct, id: string, props: CatalogBuilderProps) {\n    super(scope, id);\n\n    const handler = new Handler(this, 'Default', {\n      description: `Creates the catalog.json object in ${props.bucket.bucketName}`,\n      environment: {\n        BUCKET_NAME: props.bucket.bucketName,\n        AWS_EMF_ENVIRONMENT: 'Local',\n        FEED_BUILDER_FUNCTION_NAME:\n          props.feedBuilder.updateFeedFunction.functionName,\n      },\n      logRetention: props.logRetention ?? RetentionDays.TEN_YEARS,\n      memorySize: 10_240, // Currently the maximum possible setting\n      reservedConcurrentExecutions: 1,\n      timeout: Duration.minutes(15),\n      tracing: Tracing.PASS_THROUGH,\n    });\n    this.function = handler;\n    props.overviewDashboard.addConcurrentExecutionMetricToDashboard(\n      handler,\n      'CatalogBuilderLambda'\n    );\n\n    // This function may invoke itself in case it needs to continue it's work in\n    // a \"child\" invocation. We must hence allow it to invoke itself. We cannot\n    // use grantInvoke as this would (naturally) cause a circular reference\n    // (Function -> Role -> Function).\n    handler.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['lambda:InvokeFunction'],\n        effect: Effect.ALLOW,\n        resources: [\n          Stack.of(this).formatArn({\n            arnFormat: ArnFormat.COLON_RESOURCE_NAME,\n            service: 'lambda',\n            resource: 'function',\n            resourceName: '*',\n          }),\n        ],\n      })\n    );\n\n    // using handler.grantInvoke(props.feedBuilder.updateFeedFunction)\n    // causes circular dependency error\n    handler.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['lambda:InvokeFunction'],\n        effect: Effect.ALLOW,\n        resources: [props.feedBuilder.updateFeedFunction.functionArn],\n      })\n    );\n\n    // allow the catalog builder to use the client.\n    props.denyList.grantRead(handler);\n\n    props.bucket.grantReadWrite(this.function);\n\n    // Monitor the derivative of the catalog size, and alarm if the catalog\n    // loses more than 5 items. Catalog elements can disappear if they are added\n    // to the deny-list, or if they get un-published from the origin repository.\n    // Such cases are normal and shouldn't typically result in a significant\n    // contraction of the catalog size.\n    const catalogSizeChange = new MathExpression({\n      expression: 'DIFF(FILL(m1, REPEAT))',\n      period: Duration.minutes(15),\n      usingMetrics: { m1: this.metricRegisteredPackageMajorVersions() },\n    });\n    const alarmShrinkingCatalog = catalogSizeChange.createAlarm(\n      this,\n      'ShrinkingCatalogAlarm',\n      {\n        alarmName: `${this.node.path}/ShrinkingCatalog`,\n        alarmDescription: [\n          'The number of packages registered in the catalog.json object has shrunk by more than 5',\n          'elements. There might be a mass extinction event going on. This should be investigated',\n          'as soon as possible.',\n          '',\n          `Catalog.json: ${s3ObjectUrl(props.bucket, 'catalog.json')}`,\n          `Catalog Builder: ${lambdaFunctionUrl(handler)}`,\n          '',\n          `RUNBOOK: ${RUNBOOK_URL}`,\n        ].join('\\n'),\n        comparisonOperator: ComparisonOperator.LESS_THAN_THRESHOLD,\n        evaluationPeriods: 1,\n        threshold: -5,\n      }\n    );\n    props.monitoring.addHighSeverityAlarm(\n      'Catalog Size Shrunk',\n      alarmShrinkingCatalog\n    );\n  }\n\n  public metricMissingConstructFrameworkCount(opts?: MetricOptions): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.MISSING_CONSTRUCT_FRAMEWORK_COUNT,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n\n  public metricMissingConstructFrameworkVersionCount(\n    opts?: MetricOptions\n  ): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.MISSING_CONSTRUCT_FRAMEWORK_VERSION_COUNT,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n\n  public metricRegisteredPackageMajorVersions(opts?: MetricOptions): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.REGISTERED_PACKAGES_MAJOR_VERSION,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n}\n\n/**\n * Data format for catalog object.\n */\nexport interface CatalogModel {\n  /**\n   * Packages in the catalog.\n   */\n  readonly packages: PackageInfo[];\n  /**\n   * Date the catalog was last updated, in ISO 8601 format.\n   */\n  readonly updated: string;\n}\n\n/**\n * Data format for packages stored in the catalog.\n */\nexport interface PackageInfo {\n  /**\n   * The name of the assembly.\n   */\n  readonly name: string;\n\n  /**\n   * The major version of this assembly, according to SemVer.\n   */\n  readonly major: number;\n\n  /**\n   * The complete SemVer version string for this package's major version stream,\n   * including pre-release identifiers, but excluding additional metadata\n   * (everything starting at `+`, if there is any).\n   */\n  readonly version: string;\n\n  /**\n   * The SPDX license identifier for the package's license.\n   */\n  readonly license: string;\n\n  /**\n   * The list of keywords configured on the package.\n   */\n  readonly keywords: readonly string[];\n\n  /**\n   * Metadata assigned by the discovery function to the latest release of this\n   * package's major version stream, if any.\n   */\n  readonly metadata?: { readonly [key: string]: string };\n\n  /**\n   * The construct framework, if present.\n   */\n  readonly constructFramework?: ConstructFramework | undefined;\n\n  /**\n   * The author of the package.\n   */\n  readonly author: {\n    readonly name: string;\n    readonly email?: string;\n    readonly url?: string;\n  };\n\n  /**\n   * The list of languages configured on the package, and the corresponding\n   * configuration.\n   */\n  readonly languages: AssemblyTargets;\n\n  /**\n   * The timestamp at which this version was created.\n   */\n  readonly time: Date;\n\n  /**\n   * The description of the package.\n   */\n  readonly description?: string;\n}\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/backend/catalog-builder/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { AssemblyTargets } from '@jsii/spec';\nimport { ArnFormat, Duration, Stack } from 'aws-cdk-lib';\nimport {\n  ComparisonOperator,\n  MathExpression,\n  Metric,\n  MetricOptions,\n  Statistic,\n} from 'aws-cdk-lib/aws-cloudwatch';\nimport { Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { IFunction, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\nimport { lambdaFunctionUrl, s3ObjectUrl } from '../../deep-link';\n\nimport { Monitoring } from '../../monitoring';\nimport { OverviewDashboard } from '../../overview-dashboard';\nimport { RUNBOOK_URL } from '../../runbook-url';\nimport { DenyList } from '../deny-list';\nimport { FeedBuilder } from '../feed-builder';\nimport type { ConstructFramework } from '../ingestion/framework-detection.lambda-shared';\nimport { CatalogBuilder as Handler } from './catalog-builder';\nimport { MetricName, METRICS_NAMESPACE } from './constants';\n\n/**\n * Props for `CatalogBuilder`.\n */\nexport interface CatalogBuilderProps {\n  /**\n   * The package store bucket.\n   */\n  readonly bucket: IBucket;\n\n  /**\n   * The monitoring handler to register alarms with.\n   */\n  readonly monitoring: Monitoring;\n\n  /**\n   * The overview dashboard to add widgets to.\n   */\n  readonly overviewDashboard: OverviewDashboard;\n\n  /**\n   * How long should execution logs be retained?\n   *\n   * @default RetentionDays.TEN_YEARS\n   */\n  readonly logRetention?: RetentionDays;\n\n  /**\n   * The deny list construct.\n   */\n  readonly denyList: DenyList;\n\n  /**\n   * Construct that generates RSS/ATOM feed after catalog is updated\n   */\n  readonly feedBuilder: FeedBuilder;\n}\n\n/**\n * Builds or re-builds the `catalog.json` object in the designated bucket.\n */\nexport class CatalogBuilder extends Construct {\n  public readonly function: IFunction;\n\n  public constructor(scope: Construct, id: string, props: CatalogBuilderProps) {\n    super(scope, id);\n\n    const handler = new Handler(this, 'Default', {\n      description: `Creates the catalog.json object in ${props.bucket.bucketName}`,\n      environment: {\n        BUCKET_NAME: props.bucket.bucketName,\n        AWS_EMF_ENVIRONMENT: 'Local',\n        FEED_BUILDER_FUNCTION_NAME:\n          props.feedBuilder.updateFeedFunction.functionName,\n      },\n      logRetention: props.logRetention ?? RetentionDays.TEN_YEARS,\n      memorySize: 10_240, // Currently the maximum possible setting\n      reservedConcurrentExecutions: 1,\n      timeout: Duration.minutes(15),\n      tracing: Tracing.PASS_THROUGH,\n    });\n    this.function = handler;\n    props.overviewDashboard.addConcurrentExecutionMetricToDashboard(\n      handler,\n      'CatalogBuilderLambda'\n    );\n\n    // This function may invoke itself in case it needs to continue it's work in\n    // a \"child\" invocation. We must hence allow it to invoke itself. We cannot\n    // use grantInvoke as this would (naturally) cause a circular reference\n    // (Function -> Role -> Function).\n    handler.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['lambda:InvokeFunction'],\n        effect: Effect.ALLOW,\n        resources: [\n          Stack.of(this).formatArn({\n            arnFormat: ArnFormat.COLON_RESOURCE_NAME,\n            service: 'lambda',\n            resource: 'function',\n            resourceName: '*',\n          }),\n        ],\n      })\n    );\n\n    // using handler.grantInvoke(props.feedBuilder.updateFeedFunction)\n    // causes circular dependency error\n    handler.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['lambda:InvokeFunction'],\n        effect: Effect.ALLOW,\n        resources: [props.feedBuilder.updateFeedFunction.functionArn],\n      })\n    );\n\n    // allow the catalog builder to use the client.\n    props.denyList.grantRead(handler);\n\n    props.bucket.grantReadWrite(this.function);\n\n    // Monitor the derivative of the catalog size, and alarm if the catalog\n    // loses more than 5 items. Catalog elements can disappear if they are added\n    // to the deny-list, or if they get un-published from the origin repository.\n    // Such cases are normal and shouldn't typically result in a significant\n    // contraction of the catalog size.\n    const catalogSizeChange = new MathExpression({\n      expression: 'DIFF(FILL(m1, REPEAT))',\n      period: Duration.minutes(15),\n      usingMetrics: { m1: this.metricRegisteredPackageMajorVersions() },\n    });\n    const alarmShrinkingCatalog = catalogSizeChange.createAlarm(\n      this,\n      'ShrinkingCatalogAlarm',\n      {\n        alarmName: `${this.node.path}/ShrinkingCatalog`,\n        alarmDescription: [\n          'The number of packages registered in the catalog.json object has shrunk by more than 5',\n          'elements. There might be a mass extinction event going on. This should be investigated',\n          'as soon as possible.',\n          '',\n          `Catalog.json: ${s3ObjectUrl(props.bucket, 'catalog.json')}`,\n          `Catalog Builder: ${lambdaFunctionUrl(handler)}`,\n          '',\n          `RUNBOOK: ${RUNBOOK_URL}`,\n        ].join('\\n'),\n        comparisonOperator: ComparisonOperator.LESS_THAN_THRESHOLD,\n        evaluationPeriods: 1,\n        threshold: -5,\n      }\n    );\n    // This is a high-severity alarm because it is indicative of a possible mass-extinction event\n    // in the catalog. This should definitely prompt immediate investigation, although it can also\n    // be caused by the recent addition of enough packages in the deny-list to cause the alarm to\n    // trigger.\n    props.monitoring.addHighSeverityAlarm(\n      'Catalog Size Shrunk',\n      alarmShrinkingCatalog\n    );\n  }\n\n  public metricMissingConstructFrameworkCount(opts?: MetricOptions): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.MISSING_CONSTRUCT_FRAMEWORK_COUNT,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n\n  public metricMissingConstructFrameworkVersionCount(\n    opts?: MetricOptions\n  ): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.MISSING_CONSTRUCT_FRAMEWORK_VERSION_COUNT,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n\n  public metricRegisteredPackageMajorVersions(opts?: MetricOptions): Metric {\n    return new Metric({\n      period: Duration.minutes(15),\n      statistic: Statistic.MAXIMUM,\n      ...opts,\n      metricName: MetricName.REGISTERED_PACKAGES_MAJOR_VERSION,\n      namespace: METRICS_NAMESPACE,\n    });\n  }\n}\n\n/**\n * Data format for catalog object.\n */\nexport interface CatalogModel {\n  /**\n   * Packages in the catalog.\n   */\n  readonly packages: PackageInfo[];\n  /**\n   * Date the catalog was last updated, in ISO 8601 format.\n   */\n  readonly updated: string;\n}\n\n/**\n * Data format for packages stored in the catalog.\n */\nexport interface PackageInfo {\n  /**\n   * The name of the assembly.\n   */\n  readonly name: string;\n\n  /**\n   * The major version of this assembly, according to SemVer.\n   */\n  readonly major: number;\n\n  /**\n   * The complete SemVer version string for this package's major version stream,\n   * including pre-release identifiers, but excluding additional metadata\n   * (everything starting at `+`, if there is any).\n   */\n  readonly version: string;\n\n  /**\n   * The SPDX license identifier for the package's license.\n   */\n  readonly license: string;\n\n  /**\n   * The list of keywords configured on the package.\n   */\n  readonly keywords: readonly string[];\n\n  /**\n   * Metadata assigned by the discovery function to the latest release of this\n   * package's major version stream, if any.\n   */\n  readonly metadata?: { readonly [key: string]: string };\n\n  /**\n   * The construct framework, if present.\n   */\n  readonly constructFramework?: ConstructFramework | undefined;\n\n  /**\n   * The author of the package.\n   */\n  readonly author: {\n    readonly name: string;\n    readonly email?: string;\n    readonly url?: string;\n  };\n\n  /**\n   * The list of languages configured on the package, and the corresponding\n   * configuration.\n   */\n  readonly languages: AssemblyTargets;\n\n  /**\n   * The timestamp at which this version was created.\n   */\n  readonly time: Date;\n\n  /**\n   * The description of the package.\n   */\n  readonly description?: string;\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  import { Duration } from 'aws-cdk-lib';
2
+ import * as cw from 'aws-cdk-lib/aws-cloudwatch';
2
3
  import * as iam from 'aws-cdk-lib/aws-iam';
3
4
  import { RetentionDays } from 'aws-cdk-lib/aws-logs';
4
5
  import * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';
@@ -206,7 +207,25 @@ export interface CodeArtifactDomainProps {
206
207
  */
207
208
  export declare class ConstructHub extends Construct implements iam.IGrantable {
208
209
  private readonly ingestion;
210
+ private readonly monitoring;
209
211
  constructor(scope: Construct, id: string, props?: ConstructHubProps);
212
+ /**
213
+ * Returns a list of all high-severity alarms from this ConstructHub instance.
214
+ * These warrant immediate attention as they are indicative of a system health
215
+ * issue.
216
+ */
217
+ get highSeverityAlarms(): cw.IAlarm[];
218
+ /**
219
+ * Returns a list of all low-severity alarms from this ConstructHub instance.
220
+ * These do not necessitate immediate attention, as they do not have direct
221
+ * customer-visible impact, or handling is not time-sensitive. They indicate
222
+ * that something unusual (not necessarily bad) is happening.
223
+ */
224
+ get lowSeverityAlarms(): cw.IAlarm[];
225
+ /**
226
+ * Returns a list of all alarms configured by this ConstructHub instance.
227
+ */
228
+ get allAlarms(): cw.IAlarm[];
210
229
  get grantPrincipal(): iam.IPrincipal;
211
230
  get ingestionQueue(): sqs.IQueue;
212
231
  private createVpc;
@@ -45,7 +45,7 @@ class ConstructHub extends constructs_1.Construct {
45
45
  const storageFactory = storage_1.S3StorageFactory.getOrCreate(this, {
46
46
  failover: props.failoverStorage,
47
47
  });
48
- const monitoring = new monitoring_1.Monitoring(this, 'Monitoring', {
48
+ this.monitoring = new monitoring_1.Monitoring(this, 'Monitoring', {
49
49
  alarmActions: props.alarmActions,
50
50
  });
51
51
  const overviewDashboard = new overview_dashboard_1.OverviewDashboard(this, 'OverviewDashboard', {
@@ -98,7 +98,7 @@ class ConstructHub extends constructs_1.Construct {
98
98
  rules: (_f = props.denyList) !== null && _f !== void 0 ? _f : [],
99
99
  packageDataBucket: packageData,
100
100
  packageDataKeyPrefix: constants_1.STORAGE_KEY_PREFIX,
101
- monitoring: monitoring,
101
+ monitoring: this.monitoring,
102
102
  overviewDashboard: overviewDashboard,
103
103
  });
104
104
  // disable fetching package stats by default if a different package
@@ -109,14 +109,14 @@ class ConstructHub extends constructs_1.Construct {
109
109
  if (fetchPackageStats) {
110
110
  packageStats = new package_stats_1.PackageStats(this, 'Stats', {
111
111
  bucket: packageData,
112
- monitoring,
112
+ monitoring: this.monitoring,
113
113
  logRetention: props.logRetention,
114
114
  objectKey: statsKey,
115
115
  });
116
116
  }
117
117
  const versionTracker = new version_tracker_1.VersionTracker(this, 'VersionTracker', {
118
118
  bucket: packageData,
119
- monitoring,
119
+ monitoring: this.monitoring,
120
120
  logRetention: props.logRetention,
121
121
  });
122
122
  const feedBuilder = new feed_builder_1.FeedBuilder(this, 'FeedBuilder', {
@@ -130,7 +130,7 @@ class ConstructHub extends constructs_1.Construct {
130
130
  codeArtifact,
131
131
  denyList,
132
132
  logRetention: props.logRetention,
133
- monitoring,
133
+ monitoring: this.monitoring,
134
134
  overviewDashboard: overviewDashboard,
135
135
  vpc,
136
136
  vpcEndpoints,
@@ -152,7 +152,7 @@ class ConstructHub extends constructs_1.Construct {
152
152
  bucket: packageData,
153
153
  gitHubCredentialsSecret: (_m = props.feedConfiguration) === null || _m === void 0 ? void 0 : _m.githubTokenSecret,
154
154
  feedBuilder,
155
- monitoring,
155
+ monitoring: this.monitoring,
156
156
  overviewDashboard,
157
157
  });
158
158
  }
@@ -161,7 +161,7 @@ class ConstructHub extends constructs_1.Construct {
161
161
  codeArtifact,
162
162
  orchestration,
163
163
  logRetention: props.logRetention,
164
- monitoring,
164
+ monitoring: this.monitoring,
165
165
  packageLinks: props.packageLinks,
166
166
  packageTags: packageTagsSerialized,
167
167
  reprocessFrequency: props.reprocessFrequency,
@@ -181,7 +181,7 @@ class ConstructHub extends constructs_1.Construct {
181
181
  });
182
182
  const webApp = new webapp_1.WebApp(this, 'WebApp', {
183
183
  domain: props.domain,
184
- monitoring,
184
+ monitoring: this.monitoring,
185
185
  packageData,
186
186
  packageLinks: props.packageLinks,
187
187
  packageTags: packageTagsSerialized,
@@ -202,7 +202,7 @@ class ConstructHub extends constructs_1.Construct {
202
202
  denyList,
203
203
  ingestion: this.ingestion,
204
204
  licenseList,
205
- monitoring,
205
+ monitoring: this.monitoring,
206
206
  queue: this.ingestion.queue,
207
207
  repository: codeArtifact,
208
208
  overviewDashboard: overviewDashboard,
@@ -210,7 +210,7 @@ class ConstructHub extends constructs_1.Construct {
210
210
  const inventory = new inventory_1.Inventory(this, 'InventoryCanary', {
211
211
  bucket: packageData,
212
212
  logRetention: props.logRetention,
213
- monitoring,
213
+ monitoring: this.monitoring,
214
214
  overviewDashboard: overviewDashboard,
215
215
  });
216
216
  new backend_dashboard_1.BackendDashboard(this, 'BackendDashboard', {
@@ -246,6 +246,31 @@ class ConstructHub extends constructs_1.Construct {
246
246
  application.associateStack(aws_cdk_lib_1.Stack.of(this));
247
247
  }
248
248
  }
249
+ /**
250
+ * Returns a list of all high-severity alarms from this ConstructHub instance.
251
+ * These warrant immediate attention as they are indicative of a system health
252
+ * issue.
253
+ */
254
+ get highSeverityAlarms() {
255
+ // Note: the array is already returned by-copy by Monitoring, so not copying again.
256
+ return this.monitoring.highSeverityAlarms;
257
+ }
258
+ /**
259
+ * Returns a list of all low-severity alarms from this ConstructHub instance.
260
+ * These do not necessitate immediate attention, as they do not have direct
261
+ * customer-visible impact, or handling is not time-sensitive. They indicate
262
+ * that something unusual (not necessarily bad) is happening.
263
+ */
264
+ get lowSeverityAlarms() {
265
+ // Note: the array is already returned by-copy by Monitoring, so not copying again.
266
+ return this.monitoring.lowSeverityAlarms;
267
+ }
268
+ /**
269
+ * Returns a list of all alarms configured by this ConstructHub instance.
270
+ */
271
+ get allAlarms() {
272
+ return [...this.highSeverityAlarms, ...this.lowSeverityAlarms];
273
+ }
249
274
  get grantPrincipal() {
250
275
  return this.ingestion.grantPrincipal;
251
276
  }
@@ -363,7 +388,7 @@ class ConstructHub extends constructs_1.Construct {
363
388
  }
364
389
  exports.ConstructHub = ConstructHub;
365
390
  _a = JSII_RTTI_SYMBOL_1;
366
- ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.4.4" };
391
+ ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.4.7" };
367
392
  /**
368
393
  * How possibly risky operations (such as doc-generation, which requires
369
394
  * installing the indexed packages in order to trans-literate sample code) are
@@ -403,4 +428,4 @@ var Isolation;
403
428
  */
404
429
  Isolation[Isolation["NO_INTERNET_ACCESS"] = 2] = "NO_INTERNET_ACCESS";
405
430
  })(Isolation = exports.Isolation || (exports.Isolation = {}));
406
- //# 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 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 { BackendDashboard } from './backend-dashboard';\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 { 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';\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   * 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  private readonly ingestion: Ingestion;\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    const 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: 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,\n        logRetention: props.logRetention,\n        objectKey: statsKey,\n      });\n    }\n\n    const versionTracker = new VersionTracker(this, 'VersionTracker', {\n      bucket: packageData,\n      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    });\n\n    const orchestration = new Orchestration(this, 'Orchestration', {\n      bucket: packageData,\n      codeArtifact,\n      denyList,\n      logRetention: props.logRetention,\n      monitoring,\n      overviewDashboard: overviewDashboard,\n      vpc,\n      vpcEndpoints,\n      vpcSubnets,\n      vpcSecurityGroups,\n      feedBuilder,\n    });\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,\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,\n      packageLinks: props.packageLinks,\n      packageTags: packageTagsSerialized,\n      reprocessFrequency: props.reprocessFrequency,\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,\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,\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,\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.associateStack(Stack.of(this));\n    }\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.ISOLATED\n        : ec2.SubnetType.PRIVATE_WITH_NAT;\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: subnetType === ec2.SubnetType.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.ISOLATED,\n        },\n        {\n          name: 'Private',\n          subnetType: ec2.SubnetType.PRIVATE_WITH_NAT,\n          reserved: subnetType === ec2.SubnetType.ISOLATED,\n        },\n        {\n          name: 'Isolated',\n          subnetType: ec2.SubnetType.ISOLATED,\n          reserved: subnetType !== ec2.SubnetType.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_NAT\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"]}
431
+ //# 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 { BackendDashboard } from './backend-dashboard';\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 { 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';\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   * 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  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    });\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\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      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.associateStack(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.ISOLATED\n        : ec2.SubnetType.PRIVATE_WITH_NAT;\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: subnetType === ec2.SubnetType.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.ISOLATED,\n        },\n        {\n          name: 'Private',\n          subnetType: ec2.SubnetType.PRIVATE_WITH_NAT,\n          reserved: subnetType === ec2.SubnetType.ISOLATED,\n        },\n        {\n          name: 'Isolated',\n          subnetType: ec2.SubnetType.ISOLATED,\n          reserved: subnetType !== ec2.SubnetType.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_NAT\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"]}
@@ -1,4 +1,4 @@
1
- import type { Alarm } from 'aws-cdk-lib/aws-cloudwatch';
1
+ import type { AlarmBase } from 'aws-cdk-lib/aws-cloudwatch';
2
2
  /**
3
3
  * ConstructHub monitoring features exposed to extension points.
4
4
  */
@@ -11,7 +11,7 @@ export interface IMonitoring {
11
11
  * high-severity CloudWatch dashboard)
12
12
  * @param alarm the alarm to be added to the high-severity dashboard.
13
13
  */
14
- addHighSeverityAlarm(title: string, alarm: Alarm): void;
14
+ addHighSeverityAlarm(title: string, alarm: AlarmBase): void;
15
15
  /**
16
16
  * Adds a low-severity alarm. If this alarm goes off, the action specified in
17
17
  * `normalAlarmAction` is triggered.
@@ -19,5 +19,5 @@ export interface IMonitoring {
19
19
  * @param title a user-friendly title for the alarm (not currently used).
20
20
  * @param alarm the alarm to be added.
21
21
  */
22
- addLowSeverityAlarm(title: string, alarm: Alarm): void;
22
+ addLowSeverityAlarm(title: string, alarm: AlarmBase): void;
23
23
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vbml0b3JpbmcvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEFsYXJtIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2gnO1xuXG4vKipcbiAqIENvbnN0cnVjdEh1YiBtb25pdG9yaW5nIGZlYXR1cmVzIGV4cG9zZWQgdG8gZXh0ZW5zaW9uIHBvaW50cy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJTW9uaXRvcmluZyB7XG4gIC8qKlxuICAgKiBBZGRzIGEgaGlnaC1zZXZlcml0eSBhbGFybS4gSWYgdGhpcyBhbGFybSBnb2VzIG9mZiwgdGhlIGFjdGlvbiBzcGVjaWZpZWQgaW5cbiAgICogYGhpZ2hTZXZlcml0eUFsYXJtQWN0aW9uQXJuYCBpcyB0cmlnZ2VyZWQuXG4gICAqXG4gICAqIEBwYXJhbSB0aXRsZSBhIHVzZXItZnJpZW5kbHkgdGl0bGUgZm9yIHRoZSBhbGFybSAod2lsbCBiZSByZW5kZXJlZCBvbiB0aGVcbiAgICogICAgICAgICAgICAgIGhpZ2gtc2V2ZXJpdHkgQ2xvdWRXYXRjaCBkYXNoYm9hcmQpXG4gICAqIEBwYXJhbSBhbGFybSB0aGUgYWxhcm0gdG8gYmUgYWRkZWQgdG8gdGhlIGhpZ2gtc2V2ZXJpdHkgZGFzaGJvYXJkLlxuICAgKi9cbiAgYWRkSGlnaFNldmVyaXR5QWxhcm0odGl0bGU6IHN0cmluZywgYWxhcm06IEFsYXJtKTogdm9pZDtcblxuICAvKipcbiAgICogQWRkcyBhIGxvdy1zZXZlcml0eSBhbGFybS4gSWYgdGhpcyBhbGFybSBnb2VzIG9mZiwgdGhlIGFjdGlvbiBzcGVjaWZpZWQgaW5cbiAgICogYG5vcm1hbEFsYXJtQWN0aW9uYCBpcyB0cmlnZ2VyZWQuXG4gICAqXG4gICAqIEBwYXJhbSB0aXRsZSBhIHVzZXItZnJpZW5kbHkgdGl0bGUgZm9yIHRoZSBhbGFybSAobm90IGN1cnJlbnRseSB1c2VkKS5cbiAgICogQHBhcmFtIGFsYXJtIHRoZSBhbGFybSB0byBiZSBhZGRlZC5cbiAgICovXG4gIGFkZExvd1NldmVyaXR5QWxhcm0odGl0bGU6IHN0cmluZywgYWxhcm06IEFsYXJtKTogdm9pZDtcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vbml0b3JpbmcvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEFsYXJtQmFzZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcblxuLyoqXG4gKiBDb25zdHJ1Y3RIdWIgbW9uaXRvcmluZyBmZWF0dXJlcyBleHBvc2VkIHRvIGV4dGVuc2lvbiBwb2ludHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSU1vbml0b3Jpbmcge1xuICAvKipcbiAgICogQWRkcyBhIGhpZ2gtc2V2ZXJpdHkgYWxhcm0uIElmIHRoaXMgYWxhcm0gZ29lcyBvZmYsIHRoZSBhY3Rpb24gc3BlY2lmaWVkIGluXG4gICAqIGBoaWdoU2V2ZXJpdHlBbGFybUFjdGlvbkFybmAgaXMgdHJpZ2dlcmVkLlxuICAgKlxuICAgKiBAcGFyYW0gdGl0bGUgYSB1c2VyLWZyaWVuZGx5IHRpdGxlIGZvciB0aGUgYWxhcm0gKHdpbGwgYmUgcmVuZGVyZWQgb24gdGhlXG4gICAqICAgICAgICAgICAgICBoaWdoLXNldmVyaXR5IENsb3VkV2F0Y2ggZGFzaGJvYXJkKVxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkIHRvIHRoZSBoaWdoLXNldmVyaXR5IGRhc2hib2FyZC5cbiAgICovXG4gIGFkZEhpZ2hTZXZlcml0eUFsYXJtKHRpdGxlOiBzdHJpbmcsIGFsYXJtOiBBbGFybUJhc2UpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgbG93LXNldmVyaXR5IGFsYXJtLiBJZiB0aGlzIGFsYXJtIGdvZXMgb2ZmLCB0aGUgYWN0aW9uIHNwZWNpZmllZCBpblxuICAgKiBgbm9ybWFsQWxhcm1BY3Rpb25gIGlzIHRyaWdnZXJlZC5cbiAgICpcbiAgICogQHBhcmFtIHRpdGxlIGEgdXNlci1mcmllbmRseSB0aXRsZSBmb3IgdGhlIGFsYXJtIChub3QgY3VycmVudGx5IHVzZWQpLlxuICAgKiBAcGFyYW0gYWxhcm0gdGhlIGFsYXJtIHRvIGJlIGFkZGVkLlxuICAgKi9cbiAgYWRkTG93U2V2ZXJpdHlBbGFybSh0aXRsZTogc3RyaW5nLCBhbGFybTogQWxhcm1CYXNlKTogdm9pZDtcbn1cbiJdfQ==
@@ -37,10 +37,10 @@ export declare class Monitoring extends Construct implements IMonitoring {
37
37
  * Adds a high-severity alarm. If this alarm goes off, the action specified in `highSeverityAlarmActionArn`
38
38
  * @param alarm
39
39
  */
40
- addHighSeverityAlarm(title: string, alarm: cw.Alarm): void;
41
- addLowSeverityAlarm(_title: string, alarm: cw.Alarm): void;
42
- get highSeverityAlarms(): cw.Alarm[];
43
- get lowSeverityAlarms(): cw.Alarm[];
40
+ addHighSeverityAlarm(title: string, alarm: cw.AlarmBase): void;
41
+ addLowSeverityAlarm(_title: string, alarm: cw.AlarmBase): void;
42
+ get highSeverityAlarms(): cw.AlarmBase[];
43
+ get lowSeverityAlarms(): cw.AlarmBase[];
44
44
  /**
45
45
  * Adds a canary that pings a certain URL and raises an alarm in case the URL
46
46
  * responds with an error over 80% of the times.