@ndlib/ndlib-cdk2 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -116,7 +116,7 @@ class SummaryDashboard extends aws_cdk_lib_1.aws_cloudwatch.Dashboard {
|
|
|
116
116
|
}
|
|
117
117
|
static visit(node, services, lambdaNames, includeLambdas, serviceLabels) {
|
|
118
118
|
const customLabel = serviceLabels[node.node.addr];
|
|
119
|
-
if (node instanceof aws_cdk_lib_1.
|
|
119
|
+
if (node instanceof aws_cdk_lib_1.aws_opensearchservice.CfnDomain) {
|
|
120
120
|
if (node.domainName != undefined) {
|
|
121
121
|
services.push({
|
|
122
122
|
typeName: 'ElasticSearchApi',
|
|
@@ -20,9 +20,10 @@ export interface IStaticHostProps {
|
|
|
20
20
|
*/
|
|
21
21
|
readonly createDns?: boolean;
|
|
22
22
|
/**
|
|
23
|
-
* Hosted zone
|
|
23
|
+
* Hosted zone ids for the route53 record. Is required if createDns is true.
|
|
24
|
+
* This is now an array to accommodate both a public hosted zone id and a private hosted zone id
|
|
24
25
|
*/
|
|
25
|
-
readonly
|
|
26
|
+
readonly hostedZoneIds?: string[];
|
|
26
27
|
/**
|
|
27
28
|
* Root page to be served.
|
|
28
29
|
*/
|
|
@@ -9,9 +9,19 @@ class StaticHost extends constructs_1.Construct {
|
|
|
9
9
|
super(scope, id);
|
|
10
10
|
this.inProps = props;
|
|
11
11
|
// removed .validate() and replaced with this error to enforce hostedZondId when createDNS is true
|
|
12
|
-
if (this.inProps.createDns && !this.inProps.
|
|
13
|
-
|
|
14
|
-
|
|
12
|
+
// if (this.inProps.createDns && !this.inProps.hostedZoneIds) {
|
|
13
|
+
// Annotations.of(this).addError('hostedZoneIds is required when createDns is true')
|
|
14
|
+
// throw new Error('hostedZoneIds is required when createDns is true')
|
|
15
|
+
// }
|
|
16
|
+
if (this.inProps.createDns) {
|
|
17
|
+
if (!this.inProps.hostedZoneIds) {
|
|
18
|
+
aws_cdk_lib_1.Annotations.of(this).addError('hostedZoneIds is required when createDns is true');
|
|
19
|
+
throw new Error('hostedZoneIds is required when createDns is true');
|
|
20
|
+
}
|
|
21
|
+
if (this.inProps.hostedZoneIds.length == 0) {
|
|
22
|
+
aws_cdk_lib_1.Annotations.of(this).addError('hostedZoneIds is required when createDns is true, and must contain at least one hostedZoneId');
|
|
23
|
+
throw new Error('hostedZoneIds is required when createDns is true, and must contain at least one hostedZoneId');
|
|
24
|
+
}
|
|
15
25
|
}
|
|
16
26
|
const stack = aws_cdk_lib_1.Stack.of(this);
|
|
17
27
|
this.hostname = `${props.hostnamePrefix}.${props.domainName}`;
|
|
@@ -105,16 +115,18 @@ class StaticHost extends constructs_1.Construct {
|
|
|
105
115
|
});
|
|
106
116
|
// Create DNS record (conditionally)
|
|
107
117
|
if (props.createDns) {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
+
for (const hostedZoneId of props.hostedZoneIds || ['']) {
|
|
119
|
+
new aws_cdk_lib_1.aws_route53.CnameRecord(this, `ServiceCNAME${hostedZoneId}`, {
|
|
120
|
+
recordName: this.hostname,
|
|
121
|
+
comment: this.hostname,
|
|
122
|
+
domainName: this.cloudfront.distributionDomainName,
|
|
123
|
+
zone: aws_cdk_lib_1.aws_route53.HostedZone.fromHostedZoneAttributes(this, `ImportedHostedZone${hostedZoneId}`, {
|
|
124
|
+
hostedZoneId: hostedZoneId,
|
|
125
|
+
zoneName: props.domainName,
|
|
126
|
+
}),
|
|
127
|
+
ttl: aws_cdk_lib_1.Duration.minutes(15),
|
|
128
|
+
});
|
|
129
|
+
}
|
|
118
130
|
}
|
|
119
131
|
this.bucketNameParam = new aws_cdk_lib_1.aws_ssm.StringParameter(this, 'BucketParameter', {
|
|
120
132
|
parameterName: `/all/stacks/${stack.stackName}/site-bucket-name`,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ndlib/ndlib-cdk2",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.3",
|
|
4
4
|
"description": "Reusable CDK2 modules used within Hesburgh Libraries of Notre Dame",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"types": "lib/index.d.ts",
|
|
@@ -38,19 +38,19 @@
|
|
|
38
38
|
"homepage": "https://github.com/ndlib/ndlib-cdk2#readme",
|
|
39
39
|
"peerDependencies": {
|
|
40
40
|
"aws-cdk-lib": "^2.24.1",
|
|
41
|
-
"constructs": "^10.1.
|
|
41
|
+
"constructs": "^10.1.12"
|
|
42
42
|
},
|
|
43
43
|
"devDependencies": {
|
|
44
44
|
"@types/jest": "^27.5.1",
|
|
45
|
-
"@types/node": "^17.0.
|
|
46
|
-
"@typescript-eslint/eslint-plugin": "^5.
|
|
47
|
-
"@typescript-eslint/parser": "^5.
|
|
48
|
-
"aws-sdk": "^2.
|
|
45
|
+
"@types/node": "^17.0.35",
|
|
46
|
+
"@typescript-eslint/eslint-plugin": "^5.25.0",
|
|
47
|
+
"@typescript-eslint/parser": "^5.25.0",
|
|
48
|
+
"aws-sdk": "^2.1140.0",
|
|
49
49
|
"aws-sdk-client-mock": "^0.6.2",
|
|
50
50
|
"eslint": "^8.15.0",
|
|
51
51
|
"eslint-config-standard": "^17.0.0",
|
|
52
52
|
"eslint-plugin-import": "^2.26.0",
|
|
53
|
-
"eslint-plugin-jest": "^26.
|
|
53
|
+
"eslint-plugin-jest": "^26.2.2",
|
|
54
54
|
"eslint-plugin-n": "^15.2.0",
|
|
55
55
|
"eslint-plugin-node": "^11.1.0",
|
|
56
56
|
"eslint-plugin-promise": "^6.0.0",
|
|
@@ -69,7 +69,7 @@
|
|
|
69
69
|
"dependencies": {
|
|
70
70
|
"@aws-cdk/aws-appsync-alpha": "^2.24.1-alpha.0",
|
|
71
71
|
"aws-cdk-lib": "^2.24.1",
|
|
72
|
-
"constructs": "^10.1.
|
|
72
|
+
"constructs": "^10.1.12",
|
|
73
73
|
"jest-mock": "^28.1.0",
|
|
74
74
|
"node-fetch": "^3.2.4"
|
|
75
75
|
},
|