@fjall/components-infrastructure 0.88.4 → 0.89.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/lib/config/aws/disasterRecovery.js +28 -7
- package/dist/lib/patterns/aws/compute.d.ts +6 -716
- package/dist/lib/patterns/aws/compute.js +24 -427
- package/dist/lib/patterns/aws/computeEc2.d.ts +67 -0
- package/dist/lib/patterns/aws/computeEc2.js +46 -0
- package/dist/lib/patterns/aws/computeEcs.d.ts +446 -0
- package/dist/lib/patterns/aws/computeEcs.js +246 -0
- package/dist/lib/patterns/aws/computeLambda.d.ts +220 -0
- package/dist/lib/patterns/aws/computeLambda.js +147 -0
- package/dist/lib/patterns/aws/domainDelegation.d.ts +8 -0
- package/dist/lib/patterns/aws/domainDelegation.js +54 -0
- package/dist/lib/patterns/aws/domainFactory.d.ts +8 -0
- package/dist/lib/patterns/aws/domainFactory.js +23 -0
- package/dist/lib/patterns/aws/index.d.ts +3 -0
- package/dist/lib/patterns/aws/index.js +5 -1
- package/dist/lib/patterns/aws/interfaces/domain.d.ts +2 -0
- package/dist/lib/patterns/aws/interfaces/domain.js +6 -0
- package/dist/lib/patterns/aws/interfaces/index.d.ts +1 -0
- package/dist/lib/patterns/aws/interfaces/index.js +1 -1
- package/dist/lib/patterns/aws/interfaces/pattern.d.ts +3 -0
- package/dist/lib/patterns/aws/interfaces/pattern.js +1 -1
- package/dist/lib/patterns/aws/payload.js +11 -1
- package/dist/lib/resources/aws/compute/ecs.d.ts +14 -2
- package/dist/lib/resources/aws/compute/ecs.js +69 -24
- package/dist/lib/resources/aws/networking/domain.d.ts +13 -0
- package/dist/lib/resources/aws/networking/domain.js +102 -0
- package/dist/lib/resources/aws/networking/domainCertificate.d.ts +13 -0
- package/dist/lib/resources/aws/networking/domainCertificate.js +28 -0
- package/dist/lib/resources/aws/networking/hostedZone.js +3 -6
- package/dist/lib/resources/aws/networking/index.d.ts +2 -0
- package/dist/lib/resources/aws/networking/index.js +3 -1
- package/dist/lib/utils/capitaliseString.d.ts +1 -18
- package/dist/lib/utils/capitaliseString.js +8 -37
- package/dist/lib/utils/dnsRecords.d.ts +4 -0
- package/dist/lib/utils/dnsRecords.js +108 -0
- package/dist/lib/utils/domainTypes.d.ts +37 -0
- package/dist/lib/utils/domainTypes.js +10 -0
- package/dist/lib/utils/env.js +23 -29
- package/dist/lib/utils/getConfig.js +42 -16
- package/dist/lib/utils/index.d.ts +1 -0
- package/dist/lib/utils/index.js +2 -1
- package/package.json +4 -3
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Construct } from "constructs";
|
|
2
|
+
import { type IHostedZone } from "aws-cdk-lib/aws-route53";
|
|
3
|
+
import type { DomainApexProps } from "../../../utils/domainTypes";
|
|
4
|
+
export declare class Domain extends Construct {
|
|
5
|
+
readonly hostedZoneId: string;
|
|
6
|
+
readonly hostedZone: IHostedZone;
|
|
7
|
+
private readonly zoneName;
|
|
8
|
+
constructor(scope: Construct, id: string, props: DomainApexProps);
|
|
9
|
+
private addDelegationRole;
|
|
10
|
+
private addZoneIdOutput;
|
|
11
|
+
private addNameserverOutput;
|
|
12
|
+
private addCertificates;
|
|
13
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Domain = void 0;
|
|
4
|
+
const constructs_1 = require("constructs");
|
|
5
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
6
|
+
const capitaliseString_1 = require("../../../utils/capitaliseString");
|
|
7
|
+
const iam_1 = require("../iam");
|
|
8
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
9
|
+
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
10
|
+
const domainTypes_1 = require("../../../utils/domainTypes");
|
|
11
|
+
const domainCertificate_1 = require("./domainCertificate");
|
|
12
|
+
class Domain extends constructs_1.Construct {
|
|
13
|
+
constructor(scope, id, props) {
|
|
14
|
+
super(scope, id);
|
|
15
|
+
this.zoneName = props.zoneName;
|
|
16
|
+
if (!props.hostedZoneId) {
|
|
17
|
+
const createdZone = new aws_route53_1.HostedZone(this, `${(0, capitaliseString_1.getSafeZoneName)(props.zoneName)}HostedZone`, {
|
|
18
|
+
zoneName: props.zoneName,
|
|
19
|
+
comment: `Hosted Zone for ${props.zoneName}`
|
|
20
|
+
});
|
|
21
|
+
this.hostedZone = createdZone;
|
|
22
|
+
this.hostedZoneId = createdZone.hostedZoneId;
|
|
23
|
+
this.addDelegationRole(createdZone);
|
|
24
|
+
this.addNameserverOutput(createdZone);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.hostedZoneId = props.hostedZoneId;
|
|
28
|
+
this.hostedZone = aws_route53_1.HostedZone.fromHostedZoneAttributes(this, `${(0, capitaliseString_1.getSafeZoneName)(props.zoneName)}ImportedHostedZone`, {
|
|
29
|
+
hostedZoneId: props.hostedZoneId,
|
|
30
|
+
zoneName: props.zoneName
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
this.addZoneIdOutput();
|
|
34
|
+
if (props.records) {
|
|
35
|
+
(0, domainTypes_1.addDnsRecords)(this, this.hostedZone, this.zoneName, props.records);
|
|
36
|
+
}
|
|
37
|
+
if (props.certificates) {
|
|
38
|
+
this.addCertificates(props.certificates);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
addDelegationRole(zone) {
|
|
42
|
+
const domainLabel = this.zoneName.split(".")[0] ?? "default";
|
|
43
|
+
const safeDomainLabel = (0, capitaliseString_1.toPascalCase)(domainLabel);
|
|
44
|
+
const role = new iam_1.Role(this, `${safeDomainLabel}DelegateHostedZoneRole`, {
|
|
45
|
+
assumedBy: new aws_iam_1.OrganizationPrincipal(aws_cdk_lib_1.Fn.importValue("OrganisationId")),
|
|
46
|
+
roleName: `${domainLabel}DelegateHostedZoneRole`,
|
|
47
|
+
inlinePolicies: {
|
|
48
|
+
["listHostedZones"]: new aws_iam_1.PolicyDocument({
|
|
49
|
+
statements: [
|
|
50
|
+
new aws_iam_1.PolicyStatement({
|
|
51
|
+
actions: ["route53:ListHostedZonesByName"],
|
|
52
|
+
resources: ["*"]
|
|
53
|
+
})
|
|
54
|
+
]
|
|
55
|
+
}),
|
|
56
|
+
["changeResourceRecordSets"]: new aws_iam_1.PolicyDocument({
|
|
57
|
+
statements: [
|
|
58
|
+
new aws_iam_1.PolicyStatement({
|
|
59
|
+
actions: ["route53:ChangeResourceRecordSets"],
|
|
60
|
+
resources: [`arn:aws:route53:::hostedzone/${zone.hostedZoneId}`]
|
|
61
|
+
})
|
|
62
|
+
]
|
|
63
|
+
})
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
zone.grantDelegation(role);
|
|
67
|
+
new aws_cdk_lib_1.CfnOutput(this, `${safeDomainLabel}DelegateHostedZoneRoleArn`, {
|
|
68
|
+
key: `${safeDomainLabel}DelegateHostedZoneRoleArn`,
|
|
69
|
+
value: role.roleArn,
|
|
70
|
+
exportName: `${domainLabel}DelegateHostedZoneRoleArn`
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
addZoneIdOutput() {
|
|
74
|
+
const safeKey = (0, capitaliseString_1.toPascalCase)((0, capitaliseString_1.getSafeZoneName)(this.zoneName));
|
|
75
|
+
const exports = (0, domainTypes_1.getDomainExportNames)(this.zoneName);
|
|
76
|
+
new aws_cdk_lib_1.CfnOutput(this, `${safeKey}HostedZoneId`, {
|
|
77
|
+
key: `${safeKey}HostedZoneId`,
|
|
78
|
+
value: this.hostedZoneId,
|
|
79
|
+
exportName: exports.hostedZoneId
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
addNameserverOutput(zone) {
|
|
83
|
+
const safeKey = (0, capitaliseString_1.toPascalCase)((0, capitaliseString_1.getSafeZoneName)(this.zoneName));
|
|
84
|
+
new aws_cdk_lib_1.CfnOutput(this, `${safeKey}Nameservers`, {
|
|
85
|
+
key: `${safeKey}Nameservers`,
|
|
86
|
+
value: aws_cdk_lib_1.Fn.join(",", zone.hostedZoneNameServers ?? [])
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
addCertificates(certificates) {
|
|
90
|
+
const safeZone = (0, capitaliseString_1.toPascalCase)((0, capitaliseString_1.getSafeZoneName)(this.zoneName));
|
|
91
|
+
certificates.forEach((cert, index) => {
|
|
92
|
+
const safeCertName = (0, capitaliseString_1.toPascalCase)(cert.domainName.split(".").join(""));
|
|
93
|
+
new domainCertificate_1.DomainCertificate(this, `${safeZone}${safeCertName}Cert${index}`, {
|
|
94
|
+
domainName: cert.domainName,
|
|
95
|
+
subjectAlternativeNames: cert.subjectAlternativeNames,
|
|
96
|
+
hostedZone: this.hostedZone
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.Domain = Domain;
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain.js","sourceRoot":"","sources":["../../../../../lib/resources/aws/networking/domain.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { CfnOutput, Fn } from \"aws-cdk-lib\";\nimport { toPascalCase, getSafeZoneName } from \"../../../utils/capitaliseString\";\nimport { Role } from \"../iam\";\nimport {\n  OrganizationPrincipal,\n  PolicyDocument,\n  PolicyStatement\n} from \"aws-cdk-lib/aws-iam\";\nimport {\n  HostedZone as AWSHostedZone,\n  type IHostedZone\n} from \"aws-cdk-lib/aws-route53\";\nimport type {\n  DomainApexProps,\n  CertificateInput\n} from \"../../../utils/domainTypes\";\nimport {\n  getDomainExportNames,\n  addDnsRecords\n} from \"../../../utils/domainTypes\";\nimport { DomainCertificate } from \"./domainCertificate\";\n\nexport class Domain extends Construct {\n  public readonly hostedZoneId: string;\n  public readonly hostedZone: IHostedZone;\n  private readonly zoneName: string;\n\n  constructor(scope: Construct, id: string, props: DomainApexProps) {\n    super(scope, id);\n\n    this.zoneName = props.zoneName;\n\n    if (!props.hostedZoneId) {\n      const createdZone = new AWSHostedZone(\n        this,\n        `${getSafeZoneName(props.zoneName)}HostedZone`,\n        {\n          zoneName: props.zoneName,\n          comment: `Hosted Zone for ${props.zoneName}`\n        }\n      );\n      this.hostedZone = createdZone;\n      this.hostedZoneId = createdZone.hostedZoneId;\n      this.addDelegationRole(createdZone);\n      this.addNameserverOutput(createdZone);\n    } else {\n      this.hostedZoneId = props.hostedZoneId;\n      this.hostedZone = AWSHostedZone.fromHostedZoneAttributes(\n        this,\n        `${getSafeZoneName(props.zoneName)}ImportedHostedZone`,\n        {\n          hostedZoneId: props.hostedZoneId,\n          zoneName: props.zoneName\n        }\n      );\n    }\n\n    this.addZoneIdOutput();\n\n    if (props.records) {\n      addDnsRecords(this, this.hostedZone, this.zoneName, props.records);\n    }\n\n    if (props.certificates) {\n      this.addCertificates(props.certificates);\n    }\n  }\n\n  private addDelegationRole(zone: AWSHostedZone) {\n    const domainLabel = this.zoneName.split(\".\")[0] ?? \"default\";\n    const safeDomainLabel = toPascalCase(domainLabel);\n\n    const role = new Role(this, `${safeDomainLabel}DelegateHostedZoneRole`, {\n      assumedBy: new OrganizationPrincipal(Fn.importValue(\"OrganisationId\")),\n      roleName: `${domainLabel}DelegateHostedZoneRole`,\n      inlinePolicies: {\n        [\"listHostedZones\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ListHostedZonesByName\"],\n              resources: [\"*\"]\n            })\n          ]\n        }),\n        [\"changeResourceRecordSets\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ChangeResourceRecordSets\"],\n              resources: [`arn:aws:route53:::hostedzone/${zone.hostedZoneId}`]\n            })\n          ]\n        })\n      }\n    });\n\n    zone.grantDelegation(role);\n\n    new CfnOutput(this, `${safeDomainLabel}DelegateHostedZoneRoleArn`, {\n      key: `${safeDomainLabel}DelegateHostedZoneRoleArn`,\n      value: role.roleArn,\n      exportName: `${domainLabel}DelegateHostedZoneRoleArn`\n    });\n  }\n\n  private addZoneIdOutput() {\n    const safeKey = toPascalCase(getSafeZoneName(this.zoneName));\n    const exports = getDomainExportNames(this.zoneName);\n\n    new CfnOutput(this, `${safeKey}HostedZoneId`, {\n      key: `${safeKey}HostedZoneId`,\n      value: this.hostedZoneId,\n      exportName: exports.hostedZoneId\n    });\n  }\n\n  private addNameserverOutput(zone: AWSHostedZone) {\n    const safeKey = toPascalCase(getSafeZoneName(this.zoneName));\n\n    new CfnOutput(this, `${safeKey}Nameservers`, {\n      key: `${safeKey}Nameservers`,\n      value: Fn.join(\",\", zone.hostedZoneNameServers ?? [])\n    });\n  }\n\n  private addCertificates(certificates: CertificateInput[]) {\n    const safeZone = toPascalCase(getSafeZoneName(this.zoneName));\n\n    certificates.forEach((cert, index) => {\n      const safeCertName = toPascalCase(cert.domainName.split(\".\").join(\"\"));\n      new DomainCertificate(this, `${safeZone}${safeCertName}Cert${index}`, {\n        domainName: cert.domainName,\n        subjectAlternativeNames: cert.subjectAlternativeNames,\n        hostedZone: this.hostedZone\n      });\n    });\n  }\n}\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Construct } from "constructs";
|
|
2
|
+
import { Certificate } from "aws-cdk-lib/aws-certificatemanager";
|
|
3
|
+
import { type IHostedZone } from "aws-cdk-lib/aws-route53";
|
|
4
|
+
export interface DomainCertificateProps {
|
|
5
|
+
domainName: string;
|
|
6
|
+
subjectAlternativeNames?: string[];
|
|
7
|
+
hostedZone: IHostedZone;
|
|
8
|
+
}
|
|
9
|
+
export declare class DomainCertificate extends Construct {
|
|
10
|
+
readonly certificate: Certificate;
|
|
11
|
+
readonly certificateArn: string;
|
|
12
|
+
constructor(scope: Construct, id: string, props: DomainCertificateProps);
|
|
13
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DomainCertificate = void 0;
|
|
4
|
+
const constructs_1 = require("constructs");
|
|
5
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
6
|
+
const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
|
|
7
|
+
const capitaliseString_1 = require("../../../utils/capitaliseString");
|
|
8
|
+
const domainTypes_1 = require("../../../utils/domainTypes");
|
|
9
|
+
class DomainCertificate extends constructs_1.Construct {
|
|
10
|
+
constructor(scope, id, props) {
|
|
11
|
+
super(scope, id);
|
|
12
|
+
this.certificate = new aws_certificatemanager_1.Certificate(this, "Certificate", {
|
|
13
|
+
domainName: props.domainName,
|
|
14
|
+
subjectAlternativeNames: props.subjectAlternativeNames,
|
|
15
|
+
validation: aws_certificatemanager_1.CertificateValidation.fromDns(props.hostedZone)
|
|
16
|
+
});
|
|
17
|
+
this.certificateArn = this.certificate.certificateArn;
|
|
18
|
+
const safeKey = (0, capitaliseString_1.toPascalCase)(props.domainName.split(".").join(""));
|
|
19
|
+
const exports = (0, domainTypes_1.getDomainExportNames)(props.domainName);
|
|
20
|
+
new aws_cdk_lib_1.CfnOutput(this, `${safeKey}CertificateArn`, {
|
|
21
|
+
key: `${safeKey}CertificateArn`,
|
|
22
|
+
value: this.certificateArn,
|
|
23
|
+
exportName: exports.certificateArn
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.DomainCertificate = DomainCertificate;
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tYWluQ2VydGlmaWNhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvcmVzb3VyY2VzL2F3cy9uZXR3b3JraW5nL2RvbWFpbkNlcnRpZmljYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJDQUF1QztBQUN2Qyw2Q0FBd0M7QUFDeEMsK0VBRzRDO0FBRTVDLHNFQUErRDtBQUMvRCw0REFBa0U7QUFRbEUsTUFBYSxpQkFBa0IsU0FBUSxzQkFBUztJQUk5QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTZCO1FBQ3JFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLG9DQUFXLENBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRTtZQUN0RCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7WUFDNUIsdUJBQXVCLEVBQUUsS0FBSyxDQUFDLHVCQUF1QjtZQUN0RCxVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUM7U0FDNUQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGNBQWMsQ0FBQztRQUV0RCxNQUFNLE9BQU8sR0FBRyxJQUFBLCtCQUFZLEVBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbkUsTUFBTSxPQUFPLEdBQUcsSUFBQSxrQ0FBb0IsRUFBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdkQsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxHQUFHLE9BQU8sZ0JBQWdCLEVBQUU7WUFDOUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxnQkFBZ0I7WUFDL0IsS0FBSyxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQzFCLFVBQVUsRUFBRSxPQUFPLENBQUMsY0FBYztTQUNuQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUF2QkQsOENBdUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IENmbk91dHB1dCB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvblxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNlcnRpZmljYXRlbWFuYWdlclwiO1xuaW1wb3J0IHsgdHlwZSBJSG9zdGVkWm9uZSB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgdG9QYXNjYWxDYXNlIH0gZnJvbSBcIi4uLy4uLy4uL3V0aWxzL2NhcGl0YWxpc2VTdHJpbmdcIjtcbmltcG9ydCB7IGdldERvbWFpbkV4cG9ydE5hbWVzIH0gZnJvbSBcIi4uLy4uLy4uL3V0aWxzL2RvbWFpblR5cGVzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRG9tYWluQ2VydGlmaWNhdGVQcm9wcyB7XG4gIGRvbWFpbk5hbWU6IHN0cmluZztcbiAgc3ViamVjdEFsdGVybmF0aXZlTmFtZXM/OiBzdHJpbmdbXTtcbiAgaG9zdGVkWm9uZTogSUhvc3RlZFpvbmU7XG59XG5cbmV4cG9ydCBjbGFzcyBEb21haW5DZXJ0aWZpY2F0ZSBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHB1YmxpYyByZWFkb25seSBjZXJ0aWZpY2F0ZTogQ2VydGlmaWNhdGU7XG4gIHB1YmxpYyByZWFkb25seSBjZXJ0aWZpY2F0ZUFybjogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBEb21haW5DZXJ0aWZpY2F0ZVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMuY2VydGlmaWNhdGUgPSBuZXcgQ2VydGlmaWNhdGUodGhpcywgXCJDZXJ0aWZpY2F0ZVwiLCB7XG4gICAgICBkb21haW5OYW1lOiBwcm9wcy5kb21haW5OYW1lLFxuICAgICAgc3ViamVjdEFsdGVybmF0aXZlTmFtZXM6IHByb3BzLnN1YmplY3RBbHRlcm5hdGl2ZU5hbWVzLFxuICAgICAgdmFsaWRhdGlvbjogQ2VydGlmaWNhdGVWYWxpZGF0aW9uLmZyb21EbnMocHJvcHMuaG9zdGVkWm9uZSlcbiAgICB9KTtcblxuICAgIHRoaXMuY2VydGlmaWNhdGVBcm4gPSB0aGlzLmNlcnRpZmljYXRlLmNlcnRpZmljYXRlQXJuO1xuXG4gICAgY29uc3Qgc2FmZUtleSA9IHRvUGFzY2FsQ2FzZShwcm9wcy5kb21haW5OYW1lLnNwbGl0KFwiLlwiKS5qb2luKFwiXCIpKTtcbiAgICBjb25zdCBleHBvcnRzID0gZ2V0RG9tYWluRXhwb3J0TmFtZXMocHJvcHMuZG9tYWluTmFtZSk7XG4gICAgbmV3IENmbk91dHB1dCh0aGlzLCBgJHtzYWZlS2V5fUNlcnRpZmljYXRlQXJuYCwge1xuICAgICAga2V5OiBgJHtzYWZlS2V5fUNlcnRpZmljYXRlQXJuYCxcbiAgICAgIHZhbHVlOiB0aGlzLmNlcnRpZmljYXRlQXJuLFxuICAgICAgZXhwb3J0TmFtZTogZXhwb3J0cy5jZXJ0aWZpY2F0ZUFyblxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -7,12 +7,9 @@ const capitaliseString_1 = require("../../../utils/capitaliseString");
|
|
|
7
7
|
const iam_1 = require("../iam");
|
|
8
8
|
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
9
9
|
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
10
|
-
function getSafeZoneName(zoneName) {
|
|
11
|
-
return zoneName.split(".").join("");
|
|
12
|
-
}
|
|
13
10
|
class HostedZoneFactory {
|
|
14
11
|
static import(stack, hostedZoneId, zoneName) {
|
|
15
|
-
const safeZoneName = getSafeZoneName(zoneName);
|
|
12
|
+
const safeZoneName = (0, capitaliseString_1.getSafeZoneName)(zoneName);
|
|
16
13
|
return new HostedZone(stack.getStack(), `${safeZoneName}HostedZone`, {
|
|
17
14
|
hostedZoneId: hostedZoneId,
|
|
18
15
|
zoneName: zoneName
|
|
@@ -40,7 +37,7 @@ class HostedZone extends constructs_1.Construct {
|
|
|
40
37
|
return this.hostedZone || this.importedHostedZone;
|
|
41
38
|
}
|
|
42
39
|
safeZoneName() {
|
|
43
|
-
return getSafeZoneName(this.zoneName);
|
|
40
|
+
return (0, capitaliseString_1.getSafeZoneName)(this.zoneName);
|
|
44
41
|
}
|
|
45
42
|
addHostedZone(zoneName) {
|
|
46
43
|
this.hostedZone = new aws_route53_1.HostedZone(this, `${this.safeZoneName()}HostedZone`, {
|
|
@@ -150,4 +147,4 @@ class HostedZone extends constructs_1.Construct {
|
|
|
150
147
|
}
|
|
151
148
|
}
|
|
152
149
|
exports.HostedZone = HostedZone;
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hostedZone.js","sourceRoot":"","sources":["../../../../../lib/resources/aws/networking/hostedZone.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { CfnOutput, Fn, Stack, Tags } from \"aws-cdk-lib\";\nimport { toPascalCase } from \"../../../utils/capitaliseString\";\nimport { Role } from \"../iam\";\nimport {\n  OrganizationPrincipal,\n  PolicyDocument,\n  PolicyStatement\n} from \"aws-cdk-lib/aws-iam\";\nimport {\n  ARecord,\n  type ARecordProps,\n  CnameRecord,\n  type CnameRecordProps,\n  HostedZone as AWSHostedZone,\n  type IHostedZone,\n  MxRecord,\n  type MxRecordProps,\n  NsRecord,\n  type NsRecordProps,\n  TxtRecord,\n  type TxtRecordProps\n} from \"aws-cdk-lib/aws-route53\";\n\nimport { type AwsStack } from \"../base/awsStack\";\n\nfunction getSafeZoneName(zoneName: string) {\n  return zoneName.split(\".\").join(\"\");\n}\n\nexport interface HostedZoneProps {\n  zoneName: string;\n  hostedZoneId?: string;\n}\n\nexport class HostedZoneFactory {\n  static import(stack: AwsStack, hostedZoneId: string, zoneName: string) {\n    const safeZoneName = getSafeZoneName(zoneName);\n\n    return new HostedZone(stack.getStack(), `${safeZoneName}HostedZone`, {\n      hostedZoneId: hostedZoneId,\n      zoneName: zoneName\n    });\n  }\n}\n\nexport class HostedZone extends Construct {\n  private hostedZone!: AWSHostedZone;\n  private hostedZoneId!: string;\n  private importedHostedZone!: IHostedZone;\n  private zoneName: string;\n\n  private scope: Construct;\n\n  constructor(scope: Construct, id: string, props: HostedZoneProps) {\n    super(scope, id);\n\n    this.scope = scope;\n    this.zoneName = props.zoneName;\n\n    // If a hostedZoneId is provided import it, unless create a new hosted zone\n    if (!props.hostedZoneId) {\n      this.addHostedZone(props.zoneName);\n      this.hostedZoneId = this.hostedZone.hostedZoneId;\n      this.delegateHostedZone();\n    } else {\n      this.hostedZoneId = props.hostedZoneId;\n      this.importHostedZone(props.zoneName);\n    }\n  }\n\n  getInternalHostedZone() {\n    return this.hostedZone || this.importedHostedZone;\n  }\n\n  safeZoneName() {\n    return getSafeZoneName(this.zoneName);\n  }\n\n  private addHostedZone(zoneName: string) {\n    this.hostedZone = new AWSHostedZone(\n      this,\n      `${this.safeZoneName()}HostedZone`,\n      {\n        zoneName: zoneName,\n        comment: `Hosted Zone for ${zoneName}`\n      }\n    );\n  }\n\n  private importHostedZone(zoneName: string) {\n    this.importedHostedZone = AWSHostedZone.fromHostedZoneAttributes(\n      // HostedZone.fromHostedZoneAttributes explicitly must be passed a stack as parent scope\n      this.scope,\n\n      // Use safeZoneName in the id so we can theoretically\n      //  import multiple hosted zones in a single app\n      `${this.safeZoneName()}ImportedHostedZone`,\n      {\n        hostedZoneId: this.hostedZoneId,\n        zoneName: zoneName\n      }\n    );\n\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:environment\",\n      \"management\"\n    );\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:service\",\n      \"hostedZone\"\n    );\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:domain\",\n      zoneName\n    );\n\n    // Make export name unique by including the stack name to avoid conflicts\n    // when multiple stacks import the same hosted zone\n    const stack = Stack.of(this);\n    const stackName = stack.stackName;\n    const exportName = `${stackName}${this.safeZoneName()}HostedZoneId`;\n\n    const safeKey = toPascalCase(this.safeZoneName());\n    new CfnOutput(this, `${safeKey}HostedZoneId`, {\n      key: `${safeKey}HostedZoneId`,\n      value: this.hostedZoneId,\n      exportName: exportName\n    });\n  }\n\n  private delegateHostedZone() {\n    const domainLabel = this.hostedZone.zoneName.split(\".\")[0] ?? \"default\";\n    const safeDomainLabel = toPascalCase(domainLabel);\n    const role = new Role(this, `${safeDomainLabel}DelegateHostedZoneRole`, {\n      assumedBy: new OrganizationPrincipal(Fn.importValue(\"OrganisationId\")),\n      roleName: `${domainLabel}DelegateHostedZoneRole`,\n      inlinePolicies: {\n        [\"listHostedZones\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ListHostedZonesByName\"],\n              resources: [\"*\"]\n            })\n          ]\n        }),\n        [\"changeResourceRecordSets\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ChangeResourceRecordSets\"],\n              resources: [\n                `arn:aws:route53:::hostedzone/${this.hostedZone.hostedZoneId}`\n              ]\n            })\n          ]\n        })\n      }\n    });\n\n    this.hostedZone.grantDelegation(role);\n\n    new CfnOutput(this, \"DelegateHostedZoneRoleArn\", {\n      key: `${safeDomainLabel}DelegateHostedZoneRoleArn`,\n      value: role.roleArn,\n      exportName: `${domainLabel}DelegateHostedZoneRoleArn`\n    });\n  }\n\n  public addARecord(props: Omit<ARecordProps, \"zone\">) {\n    new ARecord(this, \"ARecord\", {\n      zone: this.importedHostedZone,\n      recordName: props.recordName,\n      comment:\n        props.comment || `A Record for ${this.importedHostedZone.zoneName}`,\n      target: props.target,\n      ttl: props.ttl\n    });\n  }\n\n  public addCname(props: Omit<CnameRecordProps, \"zone\">) {\n    new CnameRecord(this, \"CnameRecord\", {\n      domainName: props.domainName,\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `CNAME Record for ${this.importedHostedZone.zoneName}`,\n      ttl: props.ttl\n    });\n  }\n\n  public addMx(props: Omit<MxRecordProps, \"zone\">) {\n    new MxRecord(this, \"MxRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `MX Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n\n  public addNS(props: Omit<NsRecordProps, \"zone\">) {\n    new NsRecord(this, \"NsRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `NS Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n\n  public addTxt(props: Omit<TxtRecordProps, \"zone\">) {\n    new TxtRecord(this, \"TxtRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `TXT Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n}\n"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hostedZone.js","sourceRoot":"","sources":["../../../../../lib/resources/aws/networking/hostedZone.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { CfnOutput, Fn, Stack, Tags } from \"aws-cdk-lib\";\nimport { toPascalCase, getSafeZoneName } from \"../../../utils/capitaliseString\";\nimport { Role } from \"../iam\";\nimport {\n  OrganizationPrincipal,\n  PolicyDocument,\n  PolicyStatement\n} from \"aws-cdk-lib/aws-iam\";\nimport {\n  ARecord,\n  type ARecordProps,\n  CnameRecord,\n  type CnameRecordProps,\n  HostedZone as AWSHostedZone,\n  type IHostedZone,\n  MxRecord,\n  type MxRecordProps,\n  NsRecord,\n  type NsRecordProps,\n  TxtRecord,\n  type TxtRecordProps\n} from \"aws-cdk-lib/aws-route53\";\n\nimport { type AwsStack } from \"../base/awsStack\";\n\nexport interface HostedZoneProps {\n  zoneName: string;\n  hostedZoneId?: string;\n}\n\nexport class HostedZoneFactory {\n  static import(stack: AwsStack, hostedZoneId: string, zoneName: string) {\n    const safeZoneName = getSafeZoneName(zoneName);\n\n    return new HostedZone(stack.getStack(), `${safeZoneName}HostedZone`, {\n      hostedZoneId: hostedZoneId,\n      zoneName: zoneName\n    });\n  }\n}\n\nexport class HostedZone extends Construct {\n  private hostedZone!: AWSHostedZone;\n  private hostedZoneId!: string;\n  private importedHostedZone!: IHostedZone;\n  private zoneName: string;\n\n  private scope: Construct;\n\n  constructor(scope: Construct, id: string, props: HostedZoneProps) {\n    super(scope, id);\n\n    this.scope = scope;\n    this.zoneName = props.zoneName;\n\n    // If a hostedZoneId is provided import it, unless create a new hosted zone\n    if (!props.hostedZoneId) {\n      this.addHostedZone(props.zoneName);\n      this.hostedZoneId = this.hostedZone.hostedZoneId;\n      this.delegateHostedZone();\n    } else {\n      this.hostedZoneId = props.hostedZoneId;\n      this.importHostedZone(props.zoneName);\n    }\n  }\n\n  getInternalHostedZone() {\n    return this.hostedZone || this.importedHostedZone;\n  }\n\n  safeZoneName() {\n    return getSafeZoneName(this.zoneName);\n  }\n\n  private addHostedZone(zoneName: string) {\n    this.hostedZone = new AWSHostedZone(\n      this,\n      `${this.safeZoneName()}HostedZone`,\n      {\n        zoneName: zoneName,\n        comment: `Hosted Zone for ${zoneName}`\n      }\n    );\n  }\n\n  private importHostedZone(zoneName: string) {\n    this.importedHostedZone = AWSHostedZone.fromHostedZoneAttributes(\n      // HostedZone.fromHostedZoneAttributes explicitly must be passed a stack as parent scope\n      this.scope,\n\n      // Use safeZoneName in the id so we can theoretically\n      //  import multiple hosted zones in a single app\n      `${this.safeZoneName()}ImportedHostedZone`,\n      {\n        hostedZoneId: this.hostedZoneId,\n        zoneName: zoneName\n      }\n    );\n\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:environment\",\n      \"management\"\n    );\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:service\",\n      \"hostedZone\"\n    );\n    Tags.of(this.importedHostedZone).add(\n      \"fjall:costAllocation:domain\",\n      zoneName\n    );\n\n    // Make export name unique by including the stack name to avoid conflicts\n    // when multiple stacks import the same hosted zone\n    const stack = Stack.of(this);\n    const stackName = stack.stackName;\n    const exportName = `${stackName}${this.safeZoneName()}HostedZoneId`;\n\n    const safeKey = toPascalCase(this.safeZoneName());\n    new CfnOutput(this, `${safeKey}HostedZoneId`, {\n      key: `${safeKey}HostedZoneId`,\n      value: this.hostedZoneId,\n      exportName: exportName\n    });\n  }\n\n  private delegateHostedZone() {\n    const domainLabel = this.hostedZone.zoneName.split(\".\")[0] ?? \"default\";\n    const safeDomainLabel = toPascalCase(domainLabel);\n    const role = new Role(this, `${safeDomainLabel}DelegateHostedZoneRole`, {\n      assumedBy: new OrganizationPrincipal(Fn.importValue(\"OrganisationId\")),\n      roleName: `${domainLabel}DelegateHostedZoneRole`,\n      inlinePolicies: {\n        [\"listHostedZones\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ListHostedZonesByName\"],\n              resources: [\"*\"]\n            })\n          ]\n        }),\n        [\"changeResourceRecordSets\"]: new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"route53:ChangeResourceRecordSets\"],\n              resources: [\n                `arn:aws:route53:::hostedzone/${this.hostedZone.hostedZoneId}`\n              ]\n            })\n          ]\n        })\n      }\n    });\n\n    this.hostedZone.grantDelegation(role);\n\n    new CfnOutput(this, \"DelegateHostedZoneRoleArn\", {\n      key: `${safeDomainLabel}DelegateHostedZoneRoleArn`,\n      value: role.roleArn,\n      exportName: `${domainLabel}DelegateHostedZoneRoleArn`\n    });\n  }\n\n  public addARecord(props: Omit<ARecordProps, \"zone\">) {\n    new ARecord(this, \"ARecord\", {\n      zone: this.importedHostedZone,\n      recordName: props.recordName,\n      comment:\n        props.comment || `A Record for ${this.importedHostedZone.zoneName}`,\n      target: props.target,\n      ttl: props.ttl\n    });\n  }\n\n  public addCname(props: Omit<CnameRecordProps, \"zone\">) {\n    new CnameRecord(this, \"CnameRecord\", {\n      domainName: props.domainName,\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `CNAME Record for ${this.importedHostedZone.zoneName}`,\n      ttl: props.ttl\n    });\n  }\n\n  public addMx(props: Omit<MxRecordProps, \"zone\">) {\n    new MxRecord(this, \"MxRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `MX Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n\n  public addNS(props: Omit<NsRecordProps, \"zone\">) {\n    new NsRecord(this, \"NsRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `NS Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n\n  public addTxt(props: Omit<TxtRecordProps, \"zone\">) {\n    new TxtRecord(this, \"TxtRecord\", {\n      zone: this.importedHostedZone,\n      comment:\n        props.comment || `TXT Record for ${this.importedHostedZone.zoneName}`,\n      values: props.values,\n      ttl: props.ttl\n    });\n  }\n}\n"]}
|
|
@@ -14,9 +14,11 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./domain"), exports);
|
|
18
|
+
__exportStar(require("./domainCertificate"), exports);
|
|
17
19
|
__exportStar(require("./hostedZone"), exports);
|
|
18
20
|
__exportStar(require("./ipam"), exports);
|
|
19
21
|
__exportStar(require("./ipamPool"), exports);
|
|
20
22
|
__exportStar(require("./securityGroup"), exports);
|
|
21
23
|
__exportStar(require("./vpc"), exports);
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvcmVzb3VyY2VzL2F3cy9uZXR3b3JraW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBeUI7QUFDekIsc0RBQW9DO0FBQ3BDLCtDQUE2QjtBQUM3Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLGtEQUFnQztBQUNoQyx3Q0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9kb21haW5cIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RvbWFpbkNlcnRpZmljYXRlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3N0ZWRab25lXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pcGFtXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pcGFtUG9vbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VjdXJpdHlHcm91cFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdnBjXCI7XG4iXX0=
|
|
@@ -1,18 +1 @@
|
|
|
1
|
-
export
|
|
2
|
-
/**
|
|
3
|
-
* Convert a kebab-case or snake_case name to PascalCase.
|
|
4
|
-
* e.g., "my-app" -> "MyApp", "my_app" -> "MyApp"
|
|
5
|
-
*/
|
|
6
|
-
export declare function toPascalCase(name: string): string;
|
|
7
|
-
/**
|
|
8
|
-
* Convert any case (PascalCase, camelCase, kebab-case, snake_case) to kebab-case.
|
|
9
|
-
* Three-pass regex: split acronyms, split camel boundaries, replace separators.
|
|
10
|
-
* e.g., "MyApp" -> "my-app", "AWSLambda" -> "aws-lambda", "myApp" -> "my-app"
|
|
11
|
-
*/
|
|
12
|
-
export declare function toKebab(str: string): string;
|
|
13
|
-
/**
|
|
14
|
-
* Convert a name to a valid RDS database name (snake_case).
|
|
15
|
-
* RDS API allows letters, numbers, and underscores for PostgreSQL/MySQL DatabaseName.
|
|
16
|
-
* Hyphens are rejected, so convert them to underscores.
|
|
17
|
-
*/
|
|
18
|
-
export declare function toValidDatabaseName(name: string): string;
|
|
1
|
+
export { capitalise as capitaliseString, toPascalCase, toKebab, toValidDatabaseName, getSafeZoneName } from "@fjall/util";
|
|
@@ -1,39 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.capitaliseString =
|
|
4
|
-
|
|
5
|
-
exports.
|
|
6
|
-
exports.
|
|
7
|
-
function
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
* Convert a kebab-case or snake_case name to PascalCase.
|
|
12
|
-
* e.g., "my-app" -> "MyApp", "my_app" -> "MyApp"
|
|
13
|
-
*/
|
|
14
|
-
function toPascalCase(name) {
|
|
15
|
-
return name
|
|
16
|
-
.replace(/[-_](.)/g, (_, c) => c.toUpperCase())
|
|
17
|
-
.replace(/^./, (c) => c.toUpperCase());
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Convert any case (PascalCase, camelCase, kebab-case, snake_case) to kebab-case.
|
|
21
|
-
* Three-pass regex: split acronyms, split camel boundaries, replace separators.
|
|
22
|
-
* e.g., "MyApp" -> "my-app", "AWSLambda" -> "aws-lambda", "myApp" -> "my-app"
|
|
23
|
-
*/
|
|
24
|
-
function toKebab(str) {
|
|
25
|
-
return str
|
|
26
|
-
.replace(/([A-Z]+)([A-Z][a-z])/g, "$1-$2")
|
|
27
|
-
.replace(/([a-z\d])([A-Z])/g, "$1-$2")
|
|
28
|
-
.replace(/[\s_]+/g, "-")
|
|
29
|
-
.toLowerCase();
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Convert a name to a valid RDS database name (snake_case).
|
|
33
|
-
* RDS API allows letters, numbers, and underscores for PostgreSQL/MySQL DatabaseName.
|
|
34
|
-
* Hyphens are rejected, so convert them to underscores.
|
|
35
|
-
*/
|
|
36
|
-
function toValidDatabaseName(name) {
|
|
37
|
-
return toKebab(name).replace(/-/g, "_");
|
|
38
|
-
}
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwaXRhbGlzZVN0cmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi91dGlscy9jYXBpdGFsaXNlU3RyaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNENBRUM7QUFNRCxvQ0FJQztBQU9ELDBCQU1DO0FBT0Qsa0RBRUM7QUFsQ0QsU0FBZ0IsZ0JBQWdCLENBQUMsTUFBYztJQUM3QyxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMxRSxDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLElBQVk7SUFDdkMsT0FBTyxJQUFJO1NBQ1IsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUM5QyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztBQUMzQyxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLE9BQU8sQ0FBQyxHQUFXO0lBQ2pDLE9BQU8sR0FBRztTQUNQLE9BQU8sQ0FBQyx1QkFBdUIsRUFBRSxPQUFPLENBQUM7U0FDekMsT0FBTyxDQUFDLG1CQUFtQixFQUFFLE9BQU8sQ0FBQztTQUNyQyxPQUFPLENBQUMsU0FBUyxFQUFFLEdBQUcsQ0FBQztTQUN2QixXQUFXLEVBQUUsQ0FBQztBQUNuQixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLG1CQUFtQixDQUFDLElBQVk7SUFDOUMsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztBQUMxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGNhcGl0YWxpc2VTdHJpbmcoc3RyaW5nOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gU3RyaW5nKHN0cmluZykuY2hhckF0KDApLnRvVXBwZXJDYXNlKCkgKyBTdHJpbmcoc3RyaW5nKS5zbGljZSgxKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEga2ViYWItY2FzZSBvciBzbmFrZV9jYXNlIG5hbWUgdG8gUGFzY2FsQ2FzZS5cbiAqIGUuZy4sIFwibXktYXBwXCIgLT4gXCJNeUFwcFwiLCBcIm15X2FwcFwiIC0+IFwiTXlBcHBcIlxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9QYXNjYWxDYXNlKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBuYW1lXG4gICAgLnJlcGxhY2UoL1stX10oLikvZywgKF8sIGMpID0+IGMudG9VcHBlckNhc2UoKSlcbiAgICAucmVwbGFjZSgvXi4vLCAoYykgPT4gYy50b1VwcGVyQ2FzZSgpKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGFueSBjYXNlIChQYXNjYWxDYXNlLCBjYW1lbENhc2UsIGtlYmFiLWNhc2UsIHNuYWtlX2Nhc2UpIHRvIGtlYmFiLWNhc2UuXG4gKiBUaHJlZS1wYXNzIHJlZ2V4OiBzcGxpdCBhY3Jvbnltcywgc3BsaXQgY2FtZWwgYm91bmRhcmllcywgcmVwbGFjZSBzZXBhcmF0b3JzLlxuICogZS5nLiwgXCJNeUFwcFwiIC0+IFwibXktYXBwXCIsIFwiQVdTTGFtYmRhXCIgLT4gXCJhd3MtbGFtYmRhXCIsIFwibXlBcHBcIiAtPiBcIm15LWFwcFwiXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0b0tlYmFiKHN0cjogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIHN0clxuICAgIC5yZXBsYWNlKC8oW0EtWl0rKShbQS1aXVthLXpdKS9nLCBcIiQxLSQyXCIpXG4gICAgLnJlcGxhY2UoLyhbYS16XFxkXSkoW0EtWl0pL2csIFwiJDEtJDJcIilcbiAgICAucmVwbGFjZSgvW1xcc19dKy9nLCBcIi1cIilcbiAgICAudG9Mb3dlckNhc2UoKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgbmFtZSB0byBhIHZhbGlkIFJEUyBkYXRhYmFzZSBuYW1lIChzbmFrZV9jYXNlKS5cbiAqIFJEUyBBUEkgYWxsb3dzIGxldHRlcnMsIG51bWJlcnMsIGFuZCB1bmRlcnNjb3JlcyBmb3IgUG9zdGdyZVNRTC9NeVNRTCBEYXRhYmFzZU5hbWUuXG4gKiBIeXBoZW5zIGFyZSByZWplY3RlZCwgc28gY29udmVydCB0aGVtIHRvIHVuZGVyc2NvcmVzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9WYWxpZERhdGFiYXNlTmFtZShuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gdG9LZWJhYihuYW1lKS5yZXBsYWNlKC8tL2csIFwiX1wiKTtcbn1cbiJdfQ==
|
|
3
|
+
exports.getSafeZoneName = exports.toValidDatabaseName = exports.toKebab = exports.toPascalCase = exports.capitaliseString = void 0;
|
|
4
|
+
var util_1 = require("@fjall/util");
|
|
5
|
+
Object.defineProperty(exports, "capitaliseString", { enumerable: true, get: function () { return util_1.capitalise; } });
|
|
6
|
+
Object.defineProperty(exports, "toPascalCase", { enumerable: true, get: function () { return util_1.toPascalCase; } });
|
|
7
|
+
Object.defineProperty(exports, "toKebab", { enumerable: true, get: function () { return util_1.toKebab; } });
|
|
8
|
+
Object.defineProperty(exports, "toValidDatabaseName", { enumerable: true, get: function () { return util_1.toValidDatabaseName; } });
|
|
9
|
+
Object.defineProperty(exports, "getSafeZoneName", { enumerable: true, get: function () { return util_1.getSafeZoneName; } });
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwaXRhbGlzZVN0cmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi91dGlscy9jYXBpdGFsaXNlU3RyaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG9DQU1xQjtBQUxuQix3R0FBQSxVQUFVLE9BQW9CO0FBQzlCLG9HQUFBLFlBQVksT0FBQTtBQUNaLCtGQUFBLE9BQU8sT0FBQTtBQUNQLDJHQUFBLG1CQUFtQixPQUFBO0FBQ25CLHVHQUFBLGVBQWUsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7XG4gIGNhcGl0YWxpc2UgYXMgY2FwaXRhbGlzZVN0cmluZyxcbiAgdG9QYXNjYWxDYXNlLFxuICB0b0tlYmFiLFxuICB0b1ZhbGlkRGF0YWJhc2VOYW1lLFxuICBnZXRTYWZlWm9uZU5hbWVcbn0gZnJvbSBcIkBmamFsbC91dGlsXCI7XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type Construct } from "constructs";
|
|
2
|
+
import { type IHostedZone } from "aws-cdk-lib/aws-route53";
|
|
3
|
+
import type { DnsRecordInput } from "./domainTypes";
|
|
4
|
+
export declare function addDnsRecords(scope: Construct, zone: IHostedZone, zoneName: string, records: DnsRecordInput[]): void;
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.addDnsRecords = addDnsRecords;
|
|
4
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
5
|
+
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
6
|
+
const capitaliseString_1 = require("./capitaliseString");
|
|
7
|
+
const domainTypes_1 = require("./domainTypes");
|
|
8
|
+
function addDnsRecords(scope, zone, zoneName, records) {
|
|
9
|
+
const safeZone = (0, capitaliseString_1.toPascalCase)((0, capitaliseString_1.getSafeZoneName)(zoneName));
|
|
10
|
+
records.forEach((record, index) => {
|
|
11
|
+
if (record.value.startsWith(domainTypes_1.ALIAS_CDK_PREFIX)) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
const safeName = (0, capitaliseString_1.toPascalCase)(record.name === domainTypes_1.DNS_APEX ? "Apex" : record.name);
|
|
15
|
+
const constructId = `${safeZone}${safeName}${record.type}Record${index}`;
|
|
16
|
+
const ttl = record.ttl ? aws_cdk_lib_1.Duration.seconds(record.ttl) : undefined;
|
|
17
|
+
const recordName = record.name === domainTypes_1.DNS_APEX ? zoneName : `${record.name}.${zoneName}`;
|
|
18
|
+
switch (record.type) {
|
|
19
|
+
case "A":
|
|
20
|
+
new aws_route53_1.ARecord(scope, constructId, {
|
|
21
|
+
zone,
|
|
22
|
+
recordName,
|
|
23
|
+
target: aws_route53_1.RecordTarget.fromIpAddresses(record.value),
|
|
24
|
+
ttl
|
|
25
|
+
});
|
|
26
|
+
break;
|
|
27
|
+
case "AAAA":
|
|
28
|
+
new aws_route53_1.AaaaRecord(scope, constructId, {
|
|
29
|
+
zone,
|
|
30
|
+
recordName,
|
|
31
|
+
target: aws_route53_1.RecordTarget.fromIpAddresses(record.value),
|
|
32
|
+
ttl
|
|
33
|
+
});
|
|
34
|
+
break;
|
|
35
|
+
case "CNAME":
|
|
36
|
+
new aws_route53_1.CnameRecord(scope, constructId, {
|
|
37
|
+
zone,
|
|
38
|
+
recordName,
|
|
39
|
+
domainName: record.value,
|
|
40
|
+
ttl
|
|
41
|
+
});
|
|
42
|
+
break;
|
|
43
|
+
case "MX":
|
|
44
|
+
new aws_route53_1.MxRecord(scope, constructId, {
|
|
45
|
+
zone,
|
|
46
|
+
recordName,
|
|
47
|
+
values: [
|
|
48
|
+
{
|
|
49
|
+
hostName: record.value,
|
|
50
|
+
priority: record.priority ?? 10
|
|
51
|
+
}
|
|
52
|
+
],
|
|
53
|
+
ttl
|
|
54
|
+
});
|
|
55
|
+
break;
|
|
56
|
+
case "TXT":
|
|
57
|
+
new aws_route53_1.TxtRecord(scope, constructId, {
|
|
58
|
+
zone,
|
|
59
|
+
recordName,
|
|
60
|
+
values: [record.value],
|
|
61
|
+
ttl
|
|
62
|
+
});
|
|
63
|
+
break;
|
|
64
|
+
case "NS":
|
|
65
|
+
new aws_route53_1.NsRecord(scope, constructId, {
|
|
66
|
+
zone,
|
|
67
|
+
recordName,
|
|
68
|
+
values: [record.value],
|
|
69
|
+
ttl
|
|
70
|
+
});
|
|
71
|
+
break;
|
|
72
|
+
case "SRV":
|
|
73
|
+
new aws_route53_1.SrvRecord(scope, constructId, {
|
|
74
|
+
zone,
|
|
75
|
+
recordName,
|
|
76
|
+
values: [
|
|
77
|
+
{
|
|
78
|
+
hostName: record.value,
|
|
79
|
+
priority: record.priority ?? 10,
|
|
80
|
+
weight: record.weight ?? 0,
|
|
81
|
+
port: record.port ?? 443
|
|
82
|
+
}
|
|
83
|
+
],
|
|
84
|
+
ttl
|
|
85
|
+
});
|
|
86
|
+
break;
|
|
87
|
+
case "CAA":
|
|
88
|
+
new aws_route53_1.CaaRecord(scope, constructId, {
|
|
89
|
+
zone,
|
|
90
|
+
recordName,
|
|
91
|
+
values: [
|
|
92
|
+
{
|
|
93
|
+
flag: 0,
|
|
94
|
+
tag: record.value.includes("issuewild")
|
|
95
|
+
? aws_route53_1.CaaTag.ISSUEWILD
|
|
96
|
+
: record.value.includes("iodef")
|
|
97
|
+
? aws_route53_1.CaaTag.IODEF
|
|
98
|
+
: aws_route53_1.CaaTag.ISSUE,
|
|
99
|
+
value: record.value
|
|
100
|
+
}
|
|
101
|
+
],
|
|
102
|
+
ttl
|
|
103
|
+
});
|
|
104
|
+
break;
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dnsRecords.js","sourceRoot":"","sources":["../../../lib/utils/dnsRecords.ts"],"names":[],"mappings":"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","sourcesContent":["import { type Construct } from \"constructs\";\nimport { Duration } from \"aws-cdk-lib\";\nimport {\n  ARecord,\n  AaaaRecord,\n  CnameRecord,\n  MxRecord,\n  TxtRecord,\n  NsRecord,\n  SrvRecord,\n  CaaRecord,\n  CaaTag,\n  RecordTarget,\n  type IHostedZone\n} from \"aws-cdk-lib/aws-route53\";\nimport { toPascalCase, getSafeZoneName } from \"./capitaliseString\";\nimport type { DnsRecordInput } from \"./domainTypes\";\nimport { ALIAS_CDK_PREFIX, DNS_APEX } from \"./domainTypes\";\n\nexport function addDnsRecords(\n  scope: Construct,\n  zone: IHostedZone,\n  zoneName: string,\n  records: DnsRecordInput[]\n): void {\n  const safeZone = toPascalCase(getSafeZoneName(zoneName));\n\n  records.forEach((record, index) => {\n    if (record.value.startsWith(ALIAS_CDK_PREFIX)) {\n      return;\n    }\n\n    const safeName = toPascalCase(\n      record.name === DNS_APEX ? \"Apex\" : record.name\n    );\n    const constructId = `${safeZone}${safeName}${record.type}Record${index}`;\n    const ttl = record.ttl ? Duration.seconds(record.ttl) : undefined;\n    const recordName =\n      record.name === DNS_APEX ? zoneName : `${record.name}.${zoneName}`;\n\n    switch (record.type) {\n      case \"A\":\n        new ARecord(scope, constructId, {\n          zone,\n          recordName,\n          target: RecordTarget.fromIpAddresses(record.value),\n          ttl\n        });\n        break;\n      case \"AAAA\":\n        new AaaaRecord(scope, constructId, {\n          zone,\n          recordName,\n          target: RecordTarget.fromIpAddresses(record.value),\n          ttl\n        });\n        break;\n      case \"CNAME\":\n        new CnameRecord(scope, constructId, {\n          zone,\n          recordName,\n          domainName: record.value,\n          ttl\n        });\n        break;\n      case \"MX\":\n        new MxRecord(scope, constructId, {\n          zone,\n          recordName,\n          values: [\n            {\n              hostName: record.value,\n              priority: record.priority ?? 10\n            }\n          ],\n          ttl\n        });\n        break;\n      case \"TXT\":\n        new TxtRecord(scope, constructId, {\n          zone,\n          recordName,\n          values: [record.value],\n          ttl\n        });\n        break;\n      case \"NS\":\n        new NsRecord(scope, constructId, {\n          zone,\n          recordName,\n          values: [record.value],\n          ttl\n        });\n        break;\n      case \"SRV\":\n        new SrvRecord(scope, constructId, {\n          zone,\n          recordName,\n          values: [\n            {\n              hostName: record.value,\n              priority: record.priority ?? 10,\n              weight: record.weight ?? 0,\n              port: record.port ?? 443\n            }\n          ],\n          ttl\n        });\n        break;\n      case \"CAA\":\n        new CaaRecord(scope, constructId, {\n          zone,\n          recordName,\n          values: [\n            {\n              flag: 0,\n              tag: record.value.includes(\"issuewild\")\n                ? CaaTag.ISSUEWILD\n                : record.value.includes(\"iodef\")\n                  ? CaaTag.IODEF\n                  : CaaTag.ISSUE,\n              value: record.value\n            }\n          ],\n          ttl\n        });\n        break;\n    }\n  });\n}\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export { DNS_APEX, getDomainExportNames, type ManagedDomainExports } from "@fjall/util";
|
|
2
|
+
export interface DnsRecordInput {
|
|
3
|
+
type: "A" | "AAAA" | "CNAME" | "MX" | "TXT" | "NS" | "SRV" | "CAA";
|
|
4
|
+
name: string;
|
|
5
|
+
value: string;
|
|
6
|
+
ttl?: number;
|
|
7
|
+
priority?: number;
|
|
8
|
+
weight?: number;
|
|
9
|
+
port?: number;
|
|
10
|
+
}
|
|
11
|
+
export interface DelegationInput {
|
|
12
|
+
subdomain: string;
|
|
13
|
+
targetAccount: string;
|
|
14
|
+
}
|
|
15
|
+
export interface CertificateInput {
|
|
16
|
+
domainName: string;
|
|
17
|
+
subjectAlternativeNames?: string[];
|
|
18
|
+
}
|
|
19
|
+
export interface DomainApexProps {
|
|
20
|
+
type: "domain";
|
|
21
|
+
zoneName: string;
|
|
22
|
+
records?: DnsRecordInput[];
|
|
23
|
+
delegations?: DelegationInput[];
|
|
24
|
+
certificates?: CertificateInput[];
|
|
25
|
+
hostedZoneId?: string;
|
|
26
|
+
}
|
|
27
|
+
export interface DomainDelegatedProps {
|
|
28
|
+
type: "delegated";
|
|
29
|
+
zoneName: string;
|
|
30
|
+
parentZoneName: string;
|
|
31
|
+
parentAccountName: string;
|
|
32
|
+
records?: DnsRecordInput[];
|
|
33
|
+
certificates?: CertificateInput[];
|
|
34
|
+
}
|
|
35
|
+
export type IDomainProps = DomainApexProps | DomainDelegatedProps;
|
|
36
|
+
export declare const ALIAS_CDK_PREFIX: "ALIAS:";
|
|
37
|
+
export { addDnsRecords } from "./dnsRecords";
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.addDnsRecords = exports.ALIAS_CDK_PREFIX = exports.getDomainExportNames = exports.DNS_APEX = void 0;
|
|
4
|
+
var util_1 = require("@fjall/util");
|
|
5
|
+
Object.defineProperty(exports, "DNS_APEX", { enumerable: true, get: function () { return util_1.DNS_APEX; } });
|
|
6
|
+
Object.defineProperty(exports, "getDomainExportNames", { enumerable: true, get: function () { return util_1.getDomainExportNames; } });
|
|
7
|
+
exports.ALIAS_CDK_PREFIX = "ALIAS:";
|
|
8
|
+
var dnsRecords_1 = require("./dnsRecords");
|
|
9
|
+
Object.defineProperty(exports, "addDnsRecords", { enumerable: true, get: function () { return dnsRecords_1.addDnsRecords; } });
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tYWluVHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvdXRpbHMvZG9tYWluVHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsb0NBSXFCO0FBSG5CLGdHQUFBLFFBQVEsT0FBQTtBQUNSLDRHQUFBLG9CQUFvQixPQUFBO0FBNENULFFBQUEsZ0JBQWdCLEdBQUcsUUFBaUIsQ0FBQztBQUVsRCwyQ0FBNkM7QUFBcEMsMkdBQUEsYUFBYSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtcbiAgRE5TX0FQRVgsXG4gIGdldERvbWFpbkV4cG9ydE5hbWVzLFxuICB0eXBlIE1hbmFnZWREb21haW5FeHBvcnRzXG59IGZyb20gXCJAZmphbGwvdXRpbFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIERuc1JlY29yZElucHV0IHtcbiAgdHlwZTogXCJBXCIgfCBcIkFBQUFcIiB8IFwiQ05BTUVcIiB8IFwiTVhcIiB8IFwiVFhUXCIgfCBcIk5TXCIgfCBcIlNSVlwiIHwgXCJDQUFcIjtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZTogc3RyaW5nO1xuICB0dGw/OiBudW1iZXI7XG4gIHByaW9yaXR5PzogbnVtYmVyO1xuICB3ZWlnaHQ/OiBudW1iZXI7XG4gIHBvcnQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVsZWdhdGlvbklucHV0IHtcbiAgc3ViZG9tYWluOiBzdHJpbmc7XG4gIHRhcmdldEFjY291bnQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDZXJ0aWZpY2F0ZUlucHV0IHtcbiAgZG9tYWluTmFtZTogc3RyaW5nO1xuICBzdWJqZWN0QWx0ZXJuYXRpdmVOYW1lcz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERvbWFpbkFwZXhQcm9wcyB7XG4gIHR5cGU6IFwiZG9tYWluXCI7XG4gIHpvbmVOYW1lOiBzdHJpbmc7XG4gIHJlY29yZHM/OiBEbnNSZWNvcmRJbnB1dFtdO1xuICBkZWxlZ2F0aW9ucz86IERlbGVnYXRpb25JbnB1dFtdO1xuICBjZXJ0aWZpY2F0ZXM/OiBDZXJ0aWZpY2F0ZUlucHV0W107XG4gIGhvc3RlZFpvbmVJZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEb21haW5EZWxlZ2F0ZWRQcm9wcyB7XG4gIHR5cGU6IFwiZGVsZWdhdGVkXCI7XG4gIHpvbmVOYW1lOiBzdHJpbmc7XG4gIHBhcmVudFpvbmVOYW1lOiBzdHJpbmc7XG4gIHBhcmVudEFjY291bnROYW1lOiBzdHJpbmc7XG4gIHJlY29yZHM/OiBEbnNSZWNvcmRJbnB1dFtdO1xuICBjZXJ0aWZpY2F0ZXM/OiBDZXJ0aWZpY2F0ZUlucHV0W107XG59XG5cbmV4cG9ydCB0eXBlIElEb21haW5Qcm9wcyA9IERvbWFpbkFwZXhQcm9wcyB8IERvbWFpbkRlbGVnYXRlZFByb3BzO1xuXG5leHBvcnQgY29uc3QgQUxJQVNfQ0RLX1BSRUZJWCA9IFwiQUxJQVM6XCIgYXMgY29uc3Q7XG5cbmV4cG9ydCB7IGFkZERuc1JlY29yZHMgfSBmcm9tIFwiLi9kbnNSZWNvcmRzXCI7XG4iXX0=
|