construct-hub 0.3.182 → 0.3.183

Sign up to get free protection for your applications and to get access to all the features.
package/API.md CHANGED
@@ -357,6 +357,7 @@ const constructHubProps: ConstructHubProps = { ... }
357
357
  | [`logRetention`](#constructhubconstructhubpropspropertylogretention) | [`@aws-cdk/aws-logs.RetentionDays`](#@aws-cdk/aws-logs.RetentionDays) | How long to retain CloudWatch logs for. |
358
358
  | [`packageLinks`](#constructhubconstructhubpropspropertypackagelinks) | [`construct-hub.PackageLinkConfig`](#construct-hub.PackageLinkConfig)[] | Configuration for custom package page links. |
359
359
  | [`packageSources`](#constructhubconstructhubpropspropertypackagesources) | [`construct-hub.IPackageSource`](#construct-hub.IPackageSource)[] | The package sources to register with this ConstructHub instance. |
360
+ | [`packageTagGroups`](#constructhubconstructhubpropspropertypackagetaggroups) | [`construct-hub.PackageTagGroup`](#construct-hub.PackageTagGroup)[] | Optional configuration for grouping custom package tags. |
360
361
  | [`packageTags`](#constructhubconstructhubpropspropertypackagetags) | [`construct-hub.PackageTag`](#construct-hub.PackageTag)[] | Configuration for custom package tags. |
361
362
  | [`preloadScript`](#constructhubconstructhubpropspropertypreloadscript) | `string` | Defines source code for a preload.js script inserted at the top of the <head /> of the webapp. |
362
363
  | [`reprocessFrequency`](#constructhubconstructhubpropspropertyreprocessfrequency) | [`@aws-cdk/core.Duration`](#@aws-cdk/core.Duration) | How frequently all packages should get fully reprocessed. |
@@ -576,6 +577,18 @@ The package sources to register with this ConstructHub instance.
576
577
 
577
578
  ---
578
579
 
580
+ ##### `packageTagGroups`<sup>Optional</sup> <a name="construct-hub.ConstructHubProps.property.packageTagGroups" id="constructhubconstructhubpropspropertypackagetaggroups"></a>
581
+
582
+ ```typescript
583
+ public readonly packageTagGroups: PackageTagGroup[];
584
+ ```
585
+
586
+ - *Type:* [`construct-hub.PackageTagGroup`](#construct-hub.PackageTagGroup)[]
587
+
588
+ Optional configuration for grouping custom package tags.
589
+
590
+ ---
591
+
579
592
  ##### `packageTags`<sup>Optional</sup> <a name="construct-hub.ConstructHubProps.property.packageTags" id="constructhubconstructhubpropspropertypackagetags"></a>
580
593
 
581
594
  ```typescript
@@ -992,6 +1005,34 @@ public readonly searchRedesign: boolean;
992
1005
 
993
1006
  ---
994
1007
 
1008
+ ### FilterTypeValue <a name="construct-hub.FilterTypeValue" id="constructhubfiltertypevalue"></a>
1009
+
1010
+ #### Initializer <a name="[object Object].Initializer" id="object-objectinitializer"></a>
1011
+
1012
+ ```typescript
1013
+ import { FilterTypeValue } from 'construct-hub'
1014
+
1015
+ const filterTypeValue: FilterTypeValue = { ... }
1016
+ ```
1017
+
1018
+ #### Properties <a name="Properties" id="properties"></a>
1019
+
1020
+ | **Name** | **Type** | **Description** |
1021
+ | --- | --- | --- |
1022
+ | [`type`](#constructhubfiltertypevaluepropertytype)<span title="Required">*</span> | `string` | *No description.* |
1023
+
1024
+ ---
1025
+
1026
+ ##### `type`<sup>Required</sup> <a name="construct-hub.FilterTypeValue.property.type" id="constructhubfiltertypevaluepropertytype"></a>
1027
+
1028
+ ```typescript
1029
+ public readonly type: string;
1030
+ ```
1031
+
1032
+ - *Type:* `string`
1033
+
1034
+ ---
1035
+
995
1036
  ### Highlight <a name="construct-hub.Highlight" id="constructhubhighlight"></a>
996
1037
 
997
1038
  #### Initializer <a name="[object Object].Initializer" id="object-objectinitializer"></a>
@@ -1652,6 +1693,127 @@ public readonly condition: TagConditionConfig;
1652
1693
 
1653
1694
  ---
1654
1695
 
1696
+ ### PackageTagGroupConfig <a name="construct-hub.PackageTagGroupConfig" id="constructhubpackagetaggroupconfig"></a>
1697
+
1698
+ #### Initializer <a name="[object Object].Initializer" id="object-objectinitializer"></a>
1699
+
1700
+ ```typescript
1701
+ import { PackageTagGroupConfig } from 'construct-hub'
1702
+
1703
+ const packageTagGroupConfig: PackageTagGroupConfig = { ... }
1704
+ ```
1705
+
1706
+ #### Properties <a name="Properties" id="properties"></a>
1707
+
1708
+ | **Name** | **Type** | **Description** |
1709
+ | --- | --- | --- |
1710
+ | [`id`](#constructhubpackagetaggroupconfigpropertyid)<span title="Required">*</span> | `string` | *No description.* |
1711
+ | [`filterType`](#constructhubpackagetaggroupconfigpropertyfiltertype) | `string` | *No description.* |
1712
+ | [`label`](#constructhubpackagetaggroupconfigpropertylabel) | `string` | *No description.* |
1713
+ | [`tooltip`](#constructhubpackagetaggroupconfigpropertytooltip) | `string` | *No description.* |
1714
+
1715
+ ---
1716
+
1717
+ ##### `id`<sup>Required</sup> <a name="construct-hub.PackageTagGroupConfig.property.id" id="constructhubpackagetaggroupconfigpropertyid"></a>
1718
+
1719
+ ```typescript
1720
+ public readonly id: string;
1721
+ ```
1722
+
1723
+ - *Type:* `string`
1724
+
1725
+ ---
1726
+
1727
+ ##### `filterType`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupConfig.property.filterType" id="constructhubpackagetaggroupconfigpropertyfiltertype"></a>
1728
+
1729
+ ```typescript
1730
+ public readonly filterType: string;
1731
+ ```
1732
+
1733
+ - *Type:* `string`
1734
+
1735
+ ---
1736
+
1737
+ ##### `label`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupConfig.property.label" id="constructhubpackagetaggroupconfigpropertylabel"></a>
1738
+
1739
+ ```typescript
1740
+ public readonly label: string;
1741
+ ```
1742
+
1743
+ - *Type:* `string`
1744
+
1745
+ ---
1746
+
1747
+ ##### `tooltip`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupConfig.property.tooltip" id="constructhubpackagetaggroupconfigpropertytooltip"></a>
1748
+
1749
+ ```typescript
1750
+ public readonly tooltip: string;
1751
+ ```
1752
+
1753
+ - *Type:* `string`
1754
+
1755
+ ---
1756
+
1757
+ ### PackageTagGroupProps <a name="construct-hub.PackageTagGroupProps" id="constructhubpackagetaggroupprops"></a>
1758
+
1759
+ #### Initializer <a name="[object Object].Initializer" id="object-objectinitializer"></a>
1760
+
1761
+ ```typescript
1762
+ import { PackageTagGroupProps } from 'construct-hub'
1763
+
1764
+ const packageTagGroupProps: PackageTagGroupProps = { ... }
1765
+ ```
1766
+
1767
+ #### Properties <a name="Properties" id="properties"></a>
1768
+
1769
+ | **Name** | **Type** | **Description** |
1770
+ | --- | --- | --- |
1771
+ | [`filterType`](#constructhubpackagetaggrouppropspropertyfiltertype) | [`construct-hub.FilterType`](#construct-hub.FilterType) | Allows to specify the group filter type. |
1772
+ | [`label`](#constructhubpackagetaggrouppropspropertylabel) | `string` | Group label to display. |
1773
+ | [`tooltip`](#constructhubpackagetaggrouppropspropertytooltip) | `string` | Optional message to show within a tooltip next to the filter label. |
1774
+
1775
+ ---
1776
+
1777
+ ##### `filterType`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupProps.property.filterType" id="constructhubpackagetaggrouppropspropertyfiltertype"></a>
1778
+
1779
+ ```typescript
1780
+ public readonly filterType: FilterType;
1781
+ ```
1782
+
1783
+ - *Type:* [`construct-hub.FilterType`](#construct-hub.FilterType)
1784
+
1785
+ Allows to specify the group filter type.
1786
+
1787
+ Defaults to checkbox if not specified
1788
+
1789
+ ---
1790
+
1791
+ ##### `label`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupProps.property.label" id="constructhubpackagetaggrouppropspropertylabel"></a>
1792
+
1793
+ ```typescript
1794
+ public readonly label: string;
1795
+ ```
1796
+
1797
+ - *Type:* `string`
1798
+
1799
+ Group label to display.
1800
+
1801
+ Falls back to id if not provided
1802
+
1803
+ ---
1804
+
1805
+ ##### `tooltip`<sup>Optional</sup> <a name="construct-hub.PackageTagGroupProps.property.tooltip" id="constructhubpackagetaggrouppropspropertytooltip"></a>
1806
+
1807
+ ```typescript
1808
+ public readonly tooltip: string;
1809
+ ```
1810
+
1811
+ - *Type:* `string`
1812
+
1813
+ Optional message to show within a tooltip next to the filter label.
1814
+
1815
+ ---
1816
+
1655
1817
  ### S3StorageFactoryProps <a name="construct-hub.S3StorageFactoryProps" id="constructhubs3storagefactoryprops"></a>
1656
1818
 
1657
1819
  Properties for `S3StorageFactory`.
@@ -1700,7 +1862,8 @@ const searchFilter: SearchFilter = { ... }
1700
1862
  | **Name** | **Type** | **Description** |
1701
1863
  | --- | --- | --- |
1702
1864
  | [`display`](#constructhubsearchfilterpropertydisplay)<span title="Required">*</span> | `string` | Display name for filter. |
1703
- | [`groupBy`](#constructhubsearchfilterpropertygroupby)<span title="Required">*</span> | `string` | Name of group to include filter in. |
1865
+ | [`group`](#constructhubsearchfilterpropertygroup) | [`construct-hub.PackageTagGroup`](#construct-hub.PackageTagGroup) | PackageTagGroup to include filter in. |
1866
+ | [`groupBy`](#constructhubsearchfilterpropertygroupby) | `string` | Name of group to include filter in. |
1704
1867
 
1705
1868
  ---
1706
1869
 
@@ -1716,7 +1879,21 @@ Display name for filter.
1716
1879
 
1717
1880
  ---
1718
1881
 
1719
- ##### `groupBy`<sup>Required</sup> <a name="construct-hub.SearchFilter.property.groupBy" id="constructhubsearchfilterpropertygroupby"></a>
1882
+ ##### `group`<sup>Optional</sup> <a name="construct-hub.SearchFilter.property.group" id="constructhubsearchfilterpropertygroup"></a>
1883
+
1884
+ ```typescript
1885
+ public readonly group: PackageTagGroup;
1886
+ ```
1887
+
1888
+ - *Type:* [`construct-hub.PackageTagGroup`](#construct-hub.PackageTagGroup)
1889
+
1890
+ PackageTagGroup to include filter in.
1891
+
1892
+ ---
1893
+
1894
+ ##### ~~`groupBy`~~<sup>Optional</sup> <a name="construct-hub.SearchFilter.property.groupBy" id="constructhubsearchfilterpropertygroupby"></a>
1895
+
1896
+ - *Deprecated:* use `group` instead
1720
1897
 
1721
1898
  ```typescript
1722
1899
  public readonly groupBy: string;
@@ -1793,6 +1970,160 @@ public readonly value: string;
1793
1970
 
1794
1971
  ## Classes <a name="Classes" id="classes"></a>
1795
1972
 
1973
+ ### FilterType <a name="construct-hub.FilterType" id="constructhubfiltertype"></a>
1974
+
1975
+ #### Initializers <a name="construct-hub.FilterType.Initializer" id="constructhubfiltertypeinitializer"></a>
1976
+
1977
+ ```typescript
1978
+ import { FilterType } from 'construct-hub'
1979
+
1980
+ new FilterType()
1981
+ ```
1982
+
1983
+ | **Name** | **Type** | **Description** |
1984
+ | --- | --- | --- |
1985
+
1986
+ ---
1987
+
1988
+ #### Methods <a name="Methods" id="methods"></a>
1989
+
1990
+ | **Name** | **Description** |
1991
+ | --- | --- |
1992
+ | [`bind`](#constructhubfiltertypebind) | *No description.* |
1993
+
1994
+ ---
1995
+
1996
+ ##### `bind` <a name="construct-hub.FilterType.bind" id="constructhubfiltertypebind"></a>
1997
+
1998
+ ```typescript
1999
+ public bind()
2000
+ ```
2001
+
2002
+ #### Static Functions <a name="Static Functions" id="static-functions"></a>
2003
+
2004
+ | **Name** | **Description** |
2005
+ | --- | --- |
2006
+ | [`checkbox`](#constructhubfiltertypecheckbox) | *No description.* |
2007
+ | [`radio`](#constructhubfiltertyperadio) | *No description.* |
2008
+
2009
+ ---
2010
+
2011
+ ##### `checkbox` <a name="construct-hub.FilterType.checkbox" id="constructhubfiltertypecheckbox"></a>
2012
+
2013
+ ```typescript
2014
+ import { FilterType } from 'construct-hub'
2015
+
2016
+ FilterType.checkbox()
2017
+ ```
2018
+
2019
+ ##### `radio` <a name="construct-hub.FilterType.radio" id="constructhubfiltertyperadio"></a>
2020
+
2021
+ ```typescript
2022
+ import { FilterType } from 'construct-hub'
2023
+
2024
+ FilterType.radio()
2025
+ ```
2026
+
2027
+
2028
+
2029
+ ### PackageTagGroup <a name="construct-hub.PackageTagGroup" id="constructhubpackagetaggroup"></a>
2030
+
2031
+ Defines a custom package tag group.
2032
+
2033
+ #### Initializers <a name="construct-hub.PackageTagGroup.Initializer" id="constructhubpackagetaggroupinitializer"></a>
2034
+
2035
+ ```typescript
2036
+ import { PackageTagGroup } from 'construct-hub'
2037
+
2038
+ new PackageTagGroup(id: string, props?: PackageTagGroupProps)
2039
+ ```
2040
+
2041
+ | **Name** | **Type** | **Description** |
2042
+ | --- | --- | --- |
2043
+ | [`id`](#constructhubpackagetaggroupparameterid)<span title="Required">*</span> | `string` | *No description.* |
2044
+ | [`props`](#constructhubpackagetaggroupparameterprops) | [`construct-hub.PackageTagGroupProps`](#construct-hub.PackageTagGroupProps) | *No description.* |
2045
+
2046
+ ---
2047
+
2048
+ ##### `id`<sup>Required</sup> <a name="construct-hub.PackageTagGroup.parameter.id" id="constructhubpackagetaggroupparameterid"></a>
2049
+
2050
+ - *Type:* `string`
2051
+
2052
+ ---
2053
+
2054
+ ##### `props`<sup>Optional</sup> <a name="construct-hub.PackageTagGroup.parameter.props" id="constructhubpackagetaggroupparameterprops"></a>
2055
+
2056
+ - *Type:* [`construct-hub.PackageTagGroupProps`](#construct-hub.PackageTagGroupProps)
2057
+
2058
+ ---
2059
+
2060
+ #### Methods <a name="Methods" id="methods"></a>
2061
+
2062
+ | **Name** | **Description** |
2063
+ | --- | --- |
2064
+ | [`bind`](#constructhubpackagetaggroupbind) | *No description.* |
2065
+
2066
+ ---
2067
+
2068
+ ##### `bind` <a name="construct-hub.PackageTagGroup.bind" id="constructhubpackagetaggroupbind"></a>
2069
+
2070
+ ```typescript
2071
+ public bind()
2072
+ ```
2073
+
2074
+
2075
+ #### Properties <a name="Properties" id="properties"></a>
2076
+
2077
+ | **Name** | **Type** | **Description** |
2078
+ | --- | --- | --- |
2079
+ | [`id`](#constructhubpackagetaggrouppropertyid)<span title="Required">*</span> | `string` | *No description.* |
2080
+ | [`filterType`](#constructhubpackagetaggrouppropertyfiltertype) | `string` | *No description.* |
2081
+ | [`label`](#constructhubpackagetaggrouppropertylabel) | `string` | *No description.* |
2082
+ | [`tooltip`](#constructhubpackagetaggrouppropertytooltip) | `string` | *No description.* |
2083
+
2084
+ ---
2085
+
2086
+ ##### `id`<sup>Required</sup> <a name="construct-hub.PackageTagGroup.property.id" id="constructhubpackagetaggrouppropertyid"></a>
2087
+
2088
+ ```typescript
2089
+ public readonly id: string;
2090
+ ```
2091
+
2092
+ - *Type:* `string`
2093
+
2094
+ ---
2095
+
2096
+ ##### `filterType`<sup>Optional</sup> <a name="construct-hub.PackageTagGroup.property.filterType" id="constructhubpackagetaggrouppropertyfiltertype"></a>
2097
+
2098
+ ```typescript
2099
+ public readonly filterType: string;
2100
+ ```
2101
+
2102
+ - *Type:* `string`
2103
+
2104
+ ---
2105
+
2106
+ ##### `label`<sup>Optional</sup> <a name="construct-hub.PackageTagGroup.property.label" id="constructhubpackagetaggrouppropertylabel"></a>
2107
+
2108
+ ```typescript
2109
+ public readonly label: string;
2110
+ ```
2111
+
2112
+ - *Type:* `string`
2113
+
2114
+ ---
2115
+
2116
+ ##### `tooltip`<sup>Optional</sup> <a name="construct-hub.PackageTagGroup.property.tooltip" id="constructhubpackagetaggrouppropertytooltip"></a>
2117
+
2118
+ ```typescript
2119
+ public readonly tooltip: string;
2120
+ ```
2121
+
2122
+ - *Type:* `string`
2123
+
2124
+ ---
2125
+
2126
+
1796
2127
  ### SpdxLicense <a name="construct-hub.SpdxLicense" id="constructhubspdxlicense"></a>
1797
2128
 
1798
2129
  Valid SPDX License identifiers.
package/README.md CHANGED
@@ -285,6 +285,12 @@ The `searchFilter` key can also be used to show tags as search filters grouped
285
285
  together.
286
286
 
287
287
  ```ts
288
+ const authorsGroup = new PackageTagGroup("authors", {
289
+ label: "Authors",
290
+ tooltip: "Information about the authors filter",
291
+ filterType: FilterType.checkbox(),
292
+ });
293
+
288
294
  const isAws = TagCondition.field('name').eq('construct-hub');
289
295
  new ConstructHub(this, "ConstructHub", {
290
296
  ...myProps,
@@ -292,14 +298,14 @@ new ConstructHub(this, "ConstructHub", {
292
298
  id: 'AWS',
293
299
  condition: isAws,
294
300
  searchFilter: {
295
- groupBy: 'Authors',
301
+ group: authorsGroup,
296
302
  display: 'AWS',
297
303
  },
298
304
  }, {
299
305
  id: 'Community',
300
306
  condition: TagCondition.not(isAws),
301
307
  searchFilter: {
302
- groupBy: 'Authors',
308
+ group: authorsGroup,
303
309
  display: 'AWS',
304
310
  },
305
311
  }]
package/changelog.md CHANGED
@@ -1,2 +1,7 @@
1
1
 
2
- ### [0.3.182](https://github.com/cdklabs/construct-hub/compare/v0.3.181...v0.3.182) (2022-01-03)
2
+ ### [0.3.183](https://github.com/cdklabs/construct-hub/compare/v0.3.182...v0.3.183) (2022-01-03)
3
+
4
+
5
+ ### Features
6
+
7
+ * support search group labels ([5461e54](https://github.com/cdklabs/construct-hub/commit/5461e548f8392053705690f0e578d15c95671b70))
@@ -8,6 +8,7 @@ import { DenyListRule } from './backend/deny-list/api';
8
8
  import { DomainRedirectSource } from './domain-redirect';
9
9
  import { IPackageSource } from './package-source';
10
10
  import { PackageTag } from './package-tag';
11
+ import { PackageTagGroup } from './package-tag-group';
11
12
  import { SpdxLicense } from './spdx-license';
12
13
  import { PackageLinkConfig, FeaturedPackages, FeatureFlags, Category } from './webapp';
13
14
  /**
@@ -109,6 +110,12 @@ export interface ConstructHubProps {
109
110
  * @experimental
110
111
  */
111
112
  readonly packageTags?: PackageTag[];
113
+ /**
114
+ * (experimental) Optional configuration for grouping custom package tags.
115
+ *
116
+ * @experimental
117
+ */
118
+ readonly packageTagGroups?: PackageTagGroup[];
112
119
  /**
113
120
  * (experimental) Configuration for packages to feature on the home page.
114
121
  *
@@ -152,6 +152,7 @@ class ConstructHub extends core_1.Construct {
152
152
  packageData,
153
153
  packageLinks: props.packageLinks,
154
154
  packageTags: packageTagsSerialized,
155
+ packageTagGroups: props.packageTagGroups,
155
156
  featuredPackages: props.featuredPackages,
156
157
  packageStats,
157
158
  featureFlags: props.featureFlags,
@@ -308,7 +309,7 @@ class ConstructHub extends core_1.Construct {
308
309
  }
309
310
  exports.ConstructHub = ConstructHub;
310
311
  _a = JSII_RTTI_SYMBOL_1;
311
- ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.3.182" };
312
+ ConstructHub[_a] = { fqn: "construct-hub.ConstructHub", version: "0.3.183" };
312
313
  /**
313
314
  * (experimental) How possibly risky operations (such as doc-generation, which requires installing the indexed packages in order to trans-literate sample code) are isolated to mitigate possible arbitrary code execution vulnerabilities in and around `npm install` or the transliterator's use of the TypeScript compiler.
314
315
  *
@@ -320,4 +321,4 @@ var Isolation;
320
321
  Isolation[Isolation["LIMITED_INTERNET_ACCESS"] = 1] = "LIMITED_INTERNET_ACCESS";
321
322
  Isolation[Isolation["NO_INTERNET_ACCESS"] = 2] = "NO_INTERNET_ACCESS";
322
323
  })(Isolation = exports.Isolation || (exports.Isolation = {}));
323
- //# 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 * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { AnyPrincipal, Effect, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { RetentionDays } from '@aws-cdk/aws-logs';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport { BlockPublicAccess } from '@aws-cdk/aws-s3';\nimport * as sqs from '@aws-cdk/aws-sqs';\nimport { Construct as CoreConstruct, Duration, Stack, Tags } from '@aws-cdk/core';\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 { Inventory } from './backend/inventory';\nimport { LicenseList } from './backend/license-list';\nimport { Orchestration } from './backend/orchestration';\nimport { PackageStats } from './backend/package-stats';\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 { IPackageSource } from './package-source';\nimport { NpmJs } from './package-sources';\nimport { PackageTag } from './package-tag';\nimport { S3StorageFactory } from './s3/storage';\nimport { SpdxLicense } from './spdx-license';\nimport { WebApp, PackageLinkConfig, FeaturedPackages, FeatureFlags, Category } from './webapp';\n\n                                    \nexport interface ConstructHubProps {\n                                                                                        \n  readonly domain?: Domain;\n\n                                                        \n  readonly alarmActions?: AlarmActions;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                \n  readonly isolateSensitiveTasks?: boolean;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \n  readonly sensitiveTaskIsolation?: Isolation;\n\n                                                                                                    \n  readonly logRetention?: RetentionDays;\n\n                                                                                                         \n  readonly backendDashboardName?: string;\n\n                                                                                          \n  readonly denyList?: DenyListRule[];\n\n                                                                                                                                                              \n  readonly packageSources?: IPackageSource[];\n\n                                                                                                                                                                                                                                                                  \n  readonly allowedLicenses?: SpdxLicense[];\n\n                                                                                                                                                                                                                                                                                                                                                                                                                        \n  readonly codeArtifactDomain?: CodeArtifactDomainProps;\n\n                                                             \n  readonly packageLinks?: PackageLinkConfig[];\n\n                                                      \n  readonly packageTags?: PackageTag[];\n\n                                                                                                                                      \n  readonly featuredPackages?: FeaturedPackages;\n\n                                                         \n  readonly featureFlags?: FeatureFlags;\n\n                                                                                                                                                                                                                                                                                                                \n  readonly fetchPackageStats?: boolean;\n\n                                                                                                                                         \n  readonly categories?: Category[];\n\n                                                                                                                                                                                                                                                                                                                          \n  readonly failoverStorage?: boolean;\n\n                                                                                                                                                                                                                                                                       \n  readonly reprocessFrequency?: Duration;\n\n                                                                                                                                    \n  readonly additionalDomains?: DomainRedirectSource[];\n\n                                                                                                              \n  readonly preloadScript?: string;\n}\n\n                                                                     \nexport interface CodeArtifactDomainProps {\n                                                     \n  readonly name: string;\n\n                                                                                                                                              \n  readonly upstreams?: string[];\n}\n\n                         \nexport class ConstructHub extends CoreConstruct 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 (props.isolateSensitiveTasks != null && props.sensitiveTaskIsolation != null) {\n      throw new Error('Supplying both isolateSensitiveTasks and sensitiveTaskIsolation is not supported. Remove usage of isolateSensitiveTasks.');\n    }\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 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 = props.sensitiveTaskIsolation\n      ?? (props.isolateSensitiveTasks ? Isolation.NO_INTERNET_ACCESS : 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 = isolation === Isolation.NO_INTERNET_ACCESS || 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(isolation, codeArtifact);\n\n    const denyList = new DenyList(this, 'DenyList', {\n      rules: props.denyList ?? [],\n      packageDataBucket: packageData,\n      packageDataKeyPrefix: STORAGE_KEY_PREFIX,\n      monitoring: monitoring,\n    });\n\n    // disable fetching package stats by default if a different package\n    // source is configured\n    const fetchPackageStats = props.fetchPackageStats ?? (\n      props.packageSources ? false : true\n    );\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 orchestration = new Orchestration(this, 'Orchestration', {\n      bucket: packageData,\n      codeArtifact,\n      denyList,\n      logRetention: props.logRetention,\n      monitoring,\n      vpc,\n      vpcEndpoints,\n      vpcSubnets,\n      vpcSecurityGroups,\n    });\n\n    // rebuild the catalog when the deny list changes.\n    denyList.prune.onChangeInvoke(orchestration.catalogBuilder.function);\n\n    const packageTagsSerialized = props.packageTags?.map((config) => {\n      return {\n        ...config,\n        condition: config.condition.bind(),\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    });\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      featuredPackages: props.featuredPackages,\n      packageStats,\n      featureFlags: props.featureFlags,\n      categories: props.categories,\n      preloadScript: props.preloadScript,\n    });\n\n    const sources = new CoreConstruct(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        }),\n    );\n\n    const inventory = new Inventory(this, 'InventoryCanary', { bucket: packageData, logRetention: props.logRetention, monitoring });\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    });\n\n    // add domain redirects\n    if (props.domain) {\n      for (const redirctSource of props.additionalDomains ?? []) {\n        new DomainRedirect(this, `Redirect-${redirctSource.hostedZone.zoneName}`, {\n          source: redirctSource,\n          targetDomainName: props.domain?.zone.zoneName,\n        });\n      }\n    } else {\n      if (props.additionalDomains && props.additionalDomains.length > 0) {\n        throw new Error('Cannot specify \"domainRedirects\" if a domain is not specified');\n      }\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(isolation: Isolation, codeArtifact: Repository | undefined) {\n    if (isolation === Isolation.UNLIMITED_INTERNET_ACCESS) {\n      return { vpc: undefined, vpcEndpoints: undefined, vpcSubnets: undefined };\n    }\n\n    const subnetType = 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        { name: 'Public', subnetType: ec2.SubnetType.PUBLIC, reserved: subnetType === ec2.SubnetType.ISOLATED },\n        { name: 'Private', subnetType: ec2.SubnetType.PRIVATE_WITH_NAT, reserved: subnetType === ec2.SubnetType.ISOLATED },\n        { name: 'Isolated', subnetType: ec2.SubnetType.ISOLATED, reserved: subnetType !== ec2.SubnetType.ISOLATED },\n      ],\n    });\n    Tags.of(vpc.node.defaultChild!).add('Name', vpc.node.path);\n\n    const securityGroups = 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('codeartifact.repositories'),\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(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    return { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups: securityGroups };\n  }\n}\n\n                                                                                                                                                                                                                                                                                                                                \nexport enum Isolation {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n  UNLIMITED_INTERNET_ACCESS,\n\n                                                                                                                                                                                                       \n  LIMITED_INTERNET_ACCESS,\n\n                                                                                                                                                                                                                                                                                                                                                                              \n  NO_INTERNET_ACCESS,\n}\n\n"]}
324
+ //# 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 * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { AnyPrincipal, Effect, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { RetentionDays } from '@aws-cdk/aws-logs';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport { BlockPublicAccess } from '@aws-cdk/aws-s3';\nimport * as sqs from '@aws-cdk/aws-sqs';\nimport { Construct as CoreConstruct, Duration, Stack, Tags } from '@aws-cdk/core';\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 { Inventory } from './backend/inventory';\nimport { LicenseList } from './backend/license-list';\nimport { Orchestration } from './backend/orchestration';\nimport { PackageStats } from './backend/package-stats';\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 { IPackageSource } from './package-source';\nimport { NpmJs } from './package-sources';\nimport { PackageTag } from './package-tag';\nimport { PackageTagGroup } from './package-tag-group';\nimport { S3StorageFactory } from './s3/storage';\nimport { SpdxLicense } from './spdx-license';\nimport { WebApp, PackageLinkConfig, FeaturedPackages, FeatureFlags, Category } from './webapp';\n\n                                    \nexport interface ConstructHubProps {\n                                                                                        \n  readonly domain?: Domain;\n\n                                                        \n  readonly alarmActions?: AlarmActions;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                \n  readonly isolateSensitiveTasks?: boolean;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \n  readonly sensitiveTaskIsolation?: Isolation;\n\n                                                                                                    \n  readonly logRetention?: RetentionDays;\n\n                                                                                                         \n  readonly backendDashboardName?: string;\n\n                                                                                          \n  readonly denyList?: DenyListRule[];\n\n                                                                                                                                                              \n  readonly packageSources?: IPackageSource[];\n\n                                                                                                                                                                                                                                                                  \n  readonly allowedLicenses?: SpdxLicense[];\n\n                                                                                                                                                                                                                                                                                                                                                                                                                        \n  readonly codeArtifactDomain?: CodeArtifactDomainProps;\n\n                                                             \n  readonly packageLinks?: PackageLinkConfig[];\n\n                                                      \n  readonly packageTags?: PackageTag[];\n\n                                                                        \n  readonly packageTagGroups?: PackageTagGroup[];\n\n                                                                                                                                      \n  readonly featuredPackages?: FeaturedPackages;\n\n                                                         \n  readonly featureFlags?: FeatureFlags;\n\n                                                                                                                                                                                                                                                                                                                \n  readonly fetchPackageStats?: boolean;\n\n                                                                                                                                         \n  readonly categories?: Category[];\n\n                                                                                                                                                                                                                                                                                                                          \n  readonly failoverStorage?: boolean;\n\n                                                                                                                                                                                                                                                                       \n  readonly reprocessFrequency?: Duration;\n\n                                                                                                                                    \n  readonly additionalDomains?: DomainRedirectSource[];\n\n                                                                                                              \n  readonly preloadScript?: string;\n}\n\n                                                                     \nexport interface CodeArtifactDomainProps {\n                                                     \n  readonly name: string;\n\n                                                                                                                                              \n  readonly upstreams?: string[];\n}\n\n                         \nexport class ConstructHub extends CoreConstruct 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 (props.isolateSensitiveTasks != null && props.sensitiveTaskIsolation != null) {\n      throw new Error('Supplying both isolateSensitiveTasks and sensitiveTaskIsolation is not supported. Remove usage of isolateSensitiveTasks.');\n    }\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 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 = props.sensitiveTaskIsolation\n      ?? (props.isolateSensitiveTasks ? Isolation.NO_INTERNET_ACCESS : 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 = isolation === Isolation.NO_INTERNET_ACCESS || 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(isolation, codeArtifact);\n\n    const denyList = new DenyList(this, 'DenyList', {\n      rules: props.denyList ?? [],\n      packageDataBucket: packageData,\n      packageDataKeyPrefix: STORAGE_KEY_PREFIX,\n      monitoring: monitoring,\n    });\n\n    // disable fetching package stats by default if a different package\n    // source is configured\n    const fetchPackageStats = props.fetchPackageStats ?? (\n      props.packageSources ? false : true\n    );\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 orchestration = new Orchestration(this, 'Orchestration', {\n      bucket: packageData,\n      codeArtifact,\n      denyList,\n      logRetention: props.logRetention,\n      monitoring,\n      vpc,\n      vpcEndpoints,\n      vpcSubnets,\n      vpcSecurityGroups,\n    });\n\n    // rebuild the catalog when the deny list changes.\n    denyList.prune.onChangeInvoke(orchestration.catalogBuilder.function);\n\n    const packageTagsSerialized = props.packageTags?.map((config) => {\n      return {\n        ...config,\n        condition: config.condition.bind(),\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    });\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    });\n\n    const sources = new CoreConstruct(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        }),\n    );\n\n    const inventory = new Inventory(this, 'InventoryCanary', { bucket: packageData, logRetention: props.logRetention, monitoring });\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    });\n\n    // add domain redirects\n    if (props.domain) {\n      for (const redirctSource of props.additionalDomains ?? []) {\n        new DomainRedirect(this, `Redirect-${redirctSource.hostedZone.zoneName}`, {\n          source: redirctSource,\n          targetDomainName: props.domain?.zone.zoneName,\n        });\n      }\n    } else {\n      if (props.additionalDomains && props.additionalDomains.length > 0) {\n        throw new Error('Cannot specify \"domainRedirects\" if a domain is not specified');\n      }\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(isolation: Isolation, codeArtifact: Repository | undefined) {\n    if (isolation === Isolation.UNLIMITED_INTERNET_ACCESS) {\n      return { vpc: undefined, vpcEndpoints: undefined, vpcSubnets: undefined };\n    }\n\n    const subnetType = 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        { name: 'Public', subnetType: ec2.SubnetType.PUBLIC, reserved: subnetType === ec2.SubnetType.ISOLATED },\n        { name: 'Private', subnetType: ec2.SubnetType.PRIVATE_WITH_NAT, reserved: subnetType === ec2.SubnetType.ISOLATED },\n        { name: 'Isolated', subnetType: ec2.SubnetType.ISOLATED, reserved: subnetType !== ec2.SubnetType.ISOLATED },\n      ],\n    });\n    Tags.of(vpc.node.defaultChild!).add('Name', vpc.node.path);\n\n    const securityGroups = 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('codeartifact.repositories'),\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(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    return { vpc, vpcEndpoints, vpcSubnets, vpcSecurityGroups: securityGroups };\n  }\n}\n\n                                                                                                                                                                                                                                                                                                                                \nexport enum Isolation {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n  UNLIMITED_INTERNET_ACCESS,\n\n                                                                                                                                                                                                       \n  LIMITED_INTERNET_ACCESS,\n\n                                                                                                                                                                                                                                                                                                                                                                              \n  NO_INTERNET_ACCESS,\n}\n\n"]}
package/lib/index.d.ts CHANGED
@@ -4,6 +4,7 @@ export * from './package-source';
4
4
  export * as sources from './package-sources';
5
5
  export * from './spdx-license';
6
6
  export * from './package-tag';
7
+ export * from './package-tag-group';
7
8
  export * from './s3/storage';
8
- export { PackageLinkConfig, FeaturedPackages, FeaturedPackagesSection, FeaturedPackagesDetail, FeatureFlags, Category } from './webapp';
9
+ export { PackageLinkConfig, FeaturedPackages, FeaturedPackagesSection, FeaturedPackagesDetail, FeatureFlags, Category, } from './webapp';
9
10
  export { DomainRedirectSource } from './domain-redirect';