@fjall/components-infrastructure 0.88.3 → 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/app.d.ts +33 -10
- package/dist/lib/app.js +79 -36
- package/dist/lib/aspects/index.d.ts +1 -0
- package/dist/lib/aspects/index.js +6 -0
- package/dist/lib/config/aws/accountAuditRole.d.ts +20 -0
- package/dist/lib/config/aws/accountAuditRole.js +38 -0
- package/dist/lib/config/aws/accountMonitoringRole.d.ts +22 -0
- package/dist/lib/config/aws/accountMonitoringRole.js +133 -0
- package/dist/lib/config/aws/cloudTrail.d.ts +0 -3
- package/dist/lib/config/aws/cloudTrail.js +2 -2
- package/dist/lib/config/aws/disasterRecovery.js +53 -20
- package/dist/lib/config/aws/ecrDefaultImage.js +4 -3
- package/dist/lib/config/aws/index.d.ts +4 -0
- package/dist/lib/config/aws/index.js +5 -1
- package/dist/lib/config/aws/oidcConnector.d.ts +8 -0
- package/dist/lib/config/aws/oidcConnector.js +46 -0
- package/dist/lib/config/aws/platform.d.ts +2 -0
- package/dist/lib/config/aws/platform.js +6 -0
- package/dist/lib/config/index.d.ts +2 -0
- package/dist/lib/config/index.js +21 -0
- package/dist/lib/patterns/aws/account.js +22 -10
- package/dist/lib/patterns/aws/cdn.d.ts +19 -40
- package/dist/lib/patterns/aws/cdn.js +21 -17
- package/dist/lib/patterns/aws/compute.d.ts +9 -720
- package/dist/lib/patterns/aws/compute.js +27 -432
- 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/database.d.ts +7 -87
- package/dist/lib/patterns/aws/database.js +15 -38
- 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 +4 -1
- package/dist/lib/patterns/aws/index.js +6 -2
- package/dist/lib/patterns/aws/interfaces/cdn.d.ts +26 -0
- package/dist/lib/patterns/aws/interfaces/cdn.js +14 -0
- package/dist/lib/patterns/aws/interfaces/connector.d.ts +4 -181
- package/dist/lib/patterns/aws/interfaces/connector.js +16 -113
- 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 +2 -0
- package/dist/lib/patterns/aws/interfaces/index.js +5 -2
- package/dist/lib/patterns/aws/interfaces/pattern.d.ts +9 -6
- package/dist/lib/patterns/aws/interfaces/pattern.js +1 -1
- package/dist/lib/patterns/aws/network.js +6 -9
- package/dist/lib/patterns/aws/organisation.d.ts +4 -2
- package/dist/lib/patterns/aws/organisation.js +21 -8
- package/dist/lib/patterns/aws/payload.js +21 -12
- package/dist/lib/patterns/aws/storage.d.ts +3 -2
- package/dist/lib/patterns/aws/storage.js +1 -1
- package/dist/lib/resources/aws/audit/auditRole.js +4 -4
- package/dist/lib/resources/aws/audit/index.d.ts +1 -0
- package/dist/lib/resources/aws/audit/index.js +6 -0
- package/dist/lib/resources/aws/backup/backupPlan.js +3 -2
- package/dist/lib/resources/aws/backup/backupVault.js +5 -3
- package/dist/lib/resources/aws/base/awsStack.d.ts +4 -2
- package/dist/lib/resources/aws/base/awsStack.js +8 -2
- package/dist/lib/resources/aws/cdn/cloudFront.d.ts +14 -0
- package/dist/lib/resources/aws/cdn/cloudFront.js +52 -18
- package/dist/lib/resources/aws/compute/ec2.js +18 -22
- package/dist/lib/resources/aws/compute/ecs.d.ts +23 -10
- package/dist/lib/resources/aws/compute/ecs.js +121 -64
- package/dist/lib/resources/aws/compute/index.d.ts +1 -0
- package/dist/lib/resources/aws/compute/index.js +2 -1
- package/dist/lib/resources/aws/compute/lambda.d.ts +0 -2
- package/dist/lib/resources/aws/compute/lambda.js +12 -27
- package/dist/lib/resources/aws/database/dynamodb.js +3 -13
- package/dist/lib/resources/aws/database/index.d.ts +8 -2
- package/dist/lib/resources/aws/database/index.js +19 -3
- package/dist/lib/resources/aws/database/rdsAurora.d.ts +2 -3
- package/dist/lib/resources/aws/database/rdsAurora.js +32 -68
- package/dist/lib/resources/aws/database/rdsAuroraGlobal.d.ts +6 -6
- package/dist/lib/resources/aws/database/rdsAuroraGlobal.js +25 -29
- package/dist/lib/resources/aws/database/rdsDefaults.d.ts +11 -0
- package/dist/lib/resources/aws/database/rdsDefaults.js +15 -0
- package/dist/lib/resources/aws/database/rdsHelpers.d.ts +39 -0
- package/dist/lib/resources/aws/database/rdsHelpers.js +75 -0
- package/dist/lib/resources/aws/database/rdsInstance.d.ts +7 -8
- package/dist/lib/resources/aws/database/rdsInstance.js +40 -84
- package/dist/lib/resources/aws/database/rdsProxyOutput.d.ts +7 -0
- package/dist/lib/resources/aws/database/rdsProxyOutput.js +18 -0
- package/dist/lib/resources/aws/iam/index.d.ts +0 -1
- package/dist/lib/resources/aws/iam/index.js +1 -2
- package/dist/lib/resources/aws/index.d.ts +0 -1
- package/dist/lib/resources/aws/index.js +1 -2
- package/dist/lib/resources/aws/logging/cloudTrail.js +13 -3
- package/dist/lib/resources/aws/logging/index.d.ts +2 -0
- package/dist/lib/resources/aws/logging/index.js +19 -0
- package/dist/lib/resources/aws/messaging/index.d.ts +3 -2
- package/dist/lib/resources/aws/messaging/index.js +4 -3
- package/dist/lib/resources/aws/messaging/sqs.js +14 -11
- package/dist/lib/resources/aws/messaging/utils.d.ts +1 -2
- package/dist/lib/resources/aws/messaging/utils.js +3 -4
- package/dist/lib/resources/aws/monitoring/index.d.ts +0 -1
- package/dist/lib/resources/aws/monitoring/index.js +4 -17
- 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.d.ts +28 -0
- package/dist/lib/resources/aws/networking/hostedZone.js +150 -0
- package/dist/lib/resources/aws/networking/index.d.ts +4 -0
- package/dist/lib/resources/aws/networking/index.js +5 -1
- package/dist/lib/resources/aws/networking/ipamPool.js +57 -31
- package/dist/lib/resources/aws/networking/securityGroup.d.ts +5 -0
- package/dist/lib/resources/aws/networking/securityGroup.js +14 -0
- package/dist/lib/resources/aws/networking/vpc.js +9 -4
- package/dist/lib/resources/aws/organisation/costAllocationTagActivator.d.ts +17 -0
- package/dist/lib/resources/aws/organisation/costAllocationTagActivator.js +66 -0
- package/dist/lib/resources/aws/organisation/index.d.ts +1 -0
- package/dist/lib/resources/aws/organisation/index.js +4 -2
- package/dist/lib/resources/aws/secrets/index.d.ts +0 -1
- package/dist/lib/resources/aws/secrets/index.js +1 -2
- package/dist/lib/resources/aws/storage/ecr.d.ts +0 -1
- package/dist/lib/resources/aws/storage/ecr.js +5 -5
- package/dist/lib/resources/aws/storage/s3.d.ts +3 -3
- package/dist/lib/resources/aws/storage/s3.js +1 -1
- package/dist/lib/resources/aws/utilities/index.d.ts +5 -0
- package/dist/lib/resources/aws/utilities/index.js +22 -0
- package/dist/lib/utils/backupTierMapping.d.ts +11 -0
- package/dist/lib/utils/backupTierMapping.js +17 -0
- package/dist/lib/utils/capitaliseString.d.ts +1 -12
- package/dist/lib/utils/capitaliseString.js +8 -28
- package/dist/lib/utils/connections.d.ts +46 -0
- package/dist/lib/utils/connections.js +159 -0
- package/dist/lib/utils/connector.d.ts +183 -0
- package/dist/lib/utils/connector.js +117 -0
- package/dist/lib/utils/databaseTypes.d.ts +85 -0
- package/dist/lib/utils/databaseTypes.js +34 -0
- 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.d.ts +42 -0
- package/dist/lib/utils/env.js +122 -0
- package/dist/lib/utils/getConfig.d.ts +0 -5
- package/dist/lib/utils/getConfig.js +42 -19
- package/dist/lib/utils/index.d.ts +7 -0
- package/dist/lib/utils/index.js +8 -1
- package/dist/lib/utils/removalPolicy.d.ts +2 -0
- package/dist/lib/utils/removalPolicy.js +16 -0
- package/dist/lib/utils/standardTagsAspect.d.ts +4 -0
- package/dist/lib/utils/standardTagsAspect.js +8 -8
- package/dist/lib/utils/vpcUtils.d.ts +14 -0
- package/dist/lib/utils/vpcUtils.js +28 -0
- package/package.json +7 -6
|
@@ -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":";;AAmBA,sCA8GC;AAhID,6CAAuC;AACvC,yDAYiC;AACjC,yDAAmE;AAEnE,+CAA2D;AAE3D,SAAgB,aAAa,CAC3B,KAAgB,EAChB,IAAiB,EACjB,QAAgB,EAChB,OAAyB;IAEzB,MAAM,QAAQ,GAAG,IAAA,+BAAY,EAAC,IAAA,kCAAe,EAAC,QAAQ,CAAC,CAAC,CAAC;IAEzD,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;QAChC,IAAI,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,8BAAgB,CAAC,EAAE,CAAC;YAC9C,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,IAAA,+BAAY,EAC3B,MAAM,CAAC,IAAI,KAAK,sBAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAChD,CAAC;QACF,MAAM,WAAW,GAAG,GAAG,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC,IAAI,SAAS,KAAK,EAAE,CAAC;QACzE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,sBAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAClE,MAAM,UAAU,GACd,MAAM,CAAC,IAAI,KAAK,sBAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE,CAAC;QAErE,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;YACpB,KAAK,GAAG;gBACN,IAAI,qBAAO,CAAC,KAAK,EAAE,WAAW,EAAE;oBAC9B,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE,0BAAY,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC;oBAClD,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,MAAM;gBACT,IAAI,wBAAU,CAAC,KAAK,EAAE,WAAW,EAAE;oBACjC,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE,0BAAY,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC;oBAClD,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,OAAO;gBACV,IAAI,yBAAW,CAAC,KAAK,EAAE,WAAW,EAAE;oBAClC,IAAI;oBACJ,UAAU;oBACV,UAAU,EAAE,MAAM,CAAC,KAAK;oBACxB,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,IAAI;gBACP,IAAI,sBAAQ,CAAC,KAAK,EAAE,WAAW,EAAE;oBAC/B,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE;wBACN;4BACE,QAAQ,EAAE,MAAM,CAAC,KAAK;4BACtB,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE;yBAChC;qBACF;oBACD,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,uBAAS,CAAC,KAAK,EAAE,WAAW,EAAE;oBAChC,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;oBACtB,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,IAAI;gBACP,IAAI,sBAAQ,CAAC,KAAK,EAAE,WAAW,EAAE;oBAC/B,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;oBACtB,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,uBAAS,CAAC,KAAK,EAAE,WAAW,EAAE;oBAChC,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE;wBACN;4BACE,QAAQ,EAAE,MAAM,CAAC,KAAK;4BACtB,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE;4BAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,CAAC;4BAC1B,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,GAAG;yBACzB;qBACF;oBACD,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,uBAAS,CAAC,KAAK,EAAE,WAAW,EAAE;oBAChC,IAAI;oBACJ,UAAU;oBACV,MAAM,EAAE;wBACN;4BACE,IAAI,EAAE,CAAC;4BACP,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;gCACrC,CAAC,CAAC,oBAAM,CAAC,SAAS;gCAClB,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;oCAC9B,CAAC,CAAC,oBAAM,CAAC,KAAK;oCACd,CAAC,CAAC,oBAAM,CAAC,KAAK;4BAClB,KAAK,EAAE,MAAM,CAAC,KAAK;yBACpB;qBACF;oBACD,GAAG;iBACJ,CAAC,CAAC;gBACH,MAAM;QACV,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC","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=
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Declarative environment configuration utility.
|
|
3
|
+
*
|
|
4
|
+
* Resolves environment-specific values at CDK synth time without requiring
|
|
5
|
+
* an App instance. This allows `env()` to be used in `App.getApp()` arguments.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```ts
|
|
9
|
+
* import { App, env } from "@fjall/components-infrastructure";
|
|
10
|
+
*
|
|
11
|
+
* const app = App.getApp("myapp", {
|
|
12
|
+
* network: { maxAzs: env({ default: 2, production: 3 }) }
|
|
13
|
+
* });
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
type EnvConfig<T> = {
|
|
17
|
+
default: T;
|
|
18
|
+
} & Partial<Record<string, T>>;
|
|
19
|
+
/**
|
|
20
|
+
* Resolve the current deployment environment without App dependency.
|
|
21
|
+
*
|
|
22
|
+
* Resolution order:
|
|
23
|
+
* 1. Module cache (cached after first call)
|
|
24
|
+
* 2. `process.env.ENVIRONMENT`
|
|
25
|
+
* 3. `-c environment=<value>` from process.argv
|
|
26
|
+
* 4. `CDK_DEFAULT_ACCOUNT` → providerAccounts lookup
|
|
27
|
+
* 5. `-c accountName=<value>` → providerAccounts lookup
|
|
28
|
+
* 6. `"unknown"` (with warning)
|
|
29
|
+
*/
|
|
30
|
+
export declare function getEnvironment(): string;
|
|
31
|
+
/**
|
|
32
|
+
* Resolve an environment-specific value at CDK synth time.
|
|
33
|
+
*
|
|
34
|
+
* @param config - Object with `default` key and optional environment overrides
|
|
35
|
+
* @returns The value for the current environment, or the default
|
|
36
|
+
*/
|
|
37
|
+
export declare function env<T>(config: EnvConfig<T>): T;
|
|
38
|
+
/**
|
|
39
|
+
* Reset the environment cache. For testing only.
|
|
40
|
+
*/
|
|
41
|
+
export declare function _resetEnvironmentCache(): void;
|
|
42
|
+
export {};
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getEnvironment = getEnvironment;
|
|
4
|
+
exports.env = env;
|
|
5
|
+
exports._resetEnvironmentCache = _resetEnvironmentCache;
|
|
6
|
+
const validationLogger_1 = require("./validationLogger");
|
|
7
|
+
let cachedEnvironment;
|
|
8
|
+
/**
|
|
9
|
+
* Resolve the current deployment environment without App dependency.
|
|
10
|
+
*
|
|
11
|
+
* Resolution order:
|
|
12
|
+
* 1. Module cache (cached after first call)
|
|
13
|
+
* 2. `process.env.ENVIRONMENT`
|
|
14
|
+
* 3. `-c environment=<value>` from process.argv
|
|
15
|
+
* 4. `CDK_DEFAULT_ACCOUNT` → providerAccounts lookup
|
|
16
|
+
* 5. `-c accountName=<value>` → providerAccounts lookup
|
|
17
|
+
* 6. `"unknown"` (with warning)
|
|
18
|
+
*/
|
|
19
|
+
function getEnvironment() {
|
|
20
|
+
if (cachedEnvironment !== undefined) {
|
|
21
|
+
return cachedEnvironment;
|
|
22
|
+
}
|
|
23
|
+
// 1. process.env.ENVIRONMENT
|
|
24
|
+
if (process.env.ENVIRONMENT) {
|
|
25
|
+
cachedEnvironment = process.env.ENVIRONMENT;
|
|
26
|
+
return cachedEnvironment;
|
|
27
|
+
}
|
|
28
|
+
// 2. -c environment=<value> from process.argv
|
|
29
|
+
const envFromArgv = parseContextArg("environment");
|
|
30
|
+
if (envFromArgv) {
|
|
31
|
+
cachedEnvironment = envFromArgv;
|
|
32
|
+
return cachedEnvironment;
|
|
33
|
+
}
|
|
34
|
+
// 3. CDK_DEFAULT_ACCOUNT → providerAccounts lookup
|
|
35
|
+
const accountId = process.env.CDK_DEFAULT_ACCOUNT;
|
|
36
|
+
if (accountId) {
|
|
37
|
+
const env = resolveEnvironmentFromAccountId(accountId);
|
|
38
|
+
if (env) {
|
|
39
|
+
cachedEnvironment = env;
|
|
40
|
+
return cachedEnvironment;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
// 4. -c accountName=<value> → providerAccounts lookup
|
|
44
|
+
const accountName = parseContextArg("accountName");
|
|
45
|
+
if (accountName) {
|
|
46
|
+
const env = resolveEnvironmentFromAccountName(accountName);
|
|
47
|
+
if (env) {
|
|
48
|
+
cachedEnvironment = env;
|
|
49
|
+
return cachedEnvironment;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
// 5. Fallback
|
|
53
|
+
validationLogger_1.FjallLogger.warn("[fjall] Could not determine environment. " +
|
|
54
|
+
"Set ENVIRONMENT env var or pass -c environment=<value>.");
|
|
55
|
+
cachedEnvironment = "unknown";
|
|
56
|
+
return cachedEnvironment;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Resolve an environment-specific value at CDK synth time.
|
|
60
|
+
*
|
|
61
|
+
* @param config - Object with `default` key and optional environment overrides
|
|
62
|
+
* @returns The value for the current environment, or the default
|
|
63
|
+
*/
|
|
64
|
+
function env(config) {
|
|
65
|
+
const environment = getEnvironment();
|
|
66
|
+
if (environment in config) {
|
|
67
|
+
return config[environment];
|
|
68
|
+
}
|
|
69
|
+
return config.default;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Reset the environment cache. For testing only.
|
|
73
|
+
*/
|
|
74
|
+
function _resetEnvironmentCache() {
|
|
75
|
+
cachedEnvironment = undefined;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Parse a `-c key=value` argument from process.argv.
|
|
79
|
+
*/
|
|
80
|
+
function parseContextArg(key) {
|
|
81
|
+
const args = process.argv;
|
|
82
|
+
for (let i = 0; i < args.length - 1; i++) {
|
|
83
|
+
if (args[i] === "-c") {
|
|
84
|
+
const parts = args[i + 1].split("=");
|
|
85
|
+
if (parts[0] === key && parts.length >= 2) {
|
|
86
|
+
return parts.slice(1).join("=");
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return undefined;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Parse orgConfig from CDK context (-c orgConfig=<json>) in process.argv.
|
|
94
|
+
*/
|
|
95
|
+
function getProviderAccountsFromContext() {
|
|
96
|
+
try {
|
|
97
|
+
const raw = parseContextArg("orgConfig");
|
|
98
|
+
if (!raw)
|
|
99
|
+
return [];
|
|
100
|
+
const parsed = JSON.parse(raw);
|
|
101
|
+
return parsed.providerAccounts ?? [];
|
|
102
|
+
}
|
|
103
|
+
catch (error) {
|
|
104
|
+
validationLogger_1.FjallLogger.warn(`[fjall] Failed to parse orgConfig from CDK context: ${error instanceof Error ? error.message : String(error)}`);
|
|
105
|
+
return [];
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Look up environment from account ID via orgConfig CDK context.
|
|
110
|
+
*/
|
|
111
|
+
function resolveEnvironmentFromAccountId(accountId) {
|
|
112
|
+
const accounts = getProviderAccountsFromContext();
|
|
113
|
+
return accounts.find((pa) => pa.id === accountId)?.environment;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Look up environment from account name via orgConfig CDK context.
|
|
117
|
+
*/
|
|
118
|
+
function resolveEnvironmentFromAccountName(accountName) {
|
|
119
|
+
const accounts = getProviderAccountsFromContext();
|
|
120
|
+
return accounts.find((pa) => pa.name === accountName)?.environment;
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"env.js","sourceRoot":"","sources":["../../../lib/utils/env.ts"],"names":[],"mappings":"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","sourcesContent":["import { type ProviderAccount } from \"@fjall/util\";\nimport { FjallLogger } from \"./validationLogger\";\n\n/**\n * Declarative environment configuration utility.\n *\n * Resolves environment-specific values at CDK synth time without requiring\n * an App instance. This allows `env()` to be used in `App.getApp()` arguments.\n *\n * @example\n * ```ts\n * import { App, env } from \"@fjall/components-infrastructure\";\n *\n * const app = App.getApp(\"myapp\", {\n *   network: { maxAzs: env({ default: 2, production: 3 }) }\n * });\n * ```\n */\n\ntype EnvConfig<T> = { default: T } & Partial<Record<string, T>>;\n\nlet cachedEnvironment: string | undefined;\n\n/**\n * Resolve the current deployment environment without App dependency.\n *\n * Resolution order:\n * 1. Module cache (cached after first call)\n * 2. `process.env.ENVIRONMENT`\n * 3. `-c environment=<value>` from process.argv\n * 4. `CDK_DEFAULT_ACCOUNT` → providerAccounts lookup\n * 5. `-c accountName=<value>` → providerAccounts lookup\n * 6. `\"unknown\"` (with warning)\n */\nexport function getEnvironment(): string {\n  if (cachedEnvironment !== undefined) {\n    return cachedEnvironment;\n  }\n\n  // 1. process.env.ENVIRONMENT\n  if (process.env.ENVIRONMENT) {\n    cachedEnvironment = process.env.ENVIRONMENT;\n    return cachedEnvironment;\n  }\n\n  // 2. -c environment=<value> from process.argv\n  const envFromArgv = parseContextArg(\"environment\");\n  if (envFromArgv) {\n    cachedEnvironment = envFromArgv;\n    return cachedEnvironment;\n  }\n\n  // 3. CDK_DEFAULT_ACCOUNT → providerAccounts lookup\n  const accountId = process.env.CDK_DEFAULT_ACCOUNT;\n  if (accountId) {\n    const env = resolveEnvironmentFromAccountId(accountId);\n    if (env) {\n      cachedEnvironment = env;\n      return cachedEnvironment;\n    }\n  }\n\n  // 4. -c accountName=<value> → providerAccounts lookup\n  const accountName = parseContextArg(\"accountName\");\n  if (accountName) {\n    const env = resolveEnvironmentFromAccountName(accountName);\n    if (env) {\n      cachedEnvironment = env;\n      return cachedEnvironment;\n    }\n  }\n\n  // 5. Fallback\n  FjallLogger.warn(\n    \"[fjall] Could not determine environment. \" +\n      \"Set ENVIRONMENT env var or pass -c environment=<value>.\"\n  );\n  cachedEnvironment = \"unknown\";\n  return cachedEnvironment;\n}\n\n/**\n * Resolve an environment-specific value at CDK synth time.\n *\n * @param config - Object with `default` key and optional environment overrides\n * @returns The value for the current environment, or the default\n */\nexport function env<T>(config: EnvConfig<T>): T {\n  const environment = getEnvironment();\n\n  if (environment in config) {\n    return config[environment] as T;\n  }\n\n  return config.default;\n}\n\n/**\n * Reset the environment cache. For testing only.\n */\nexport function _resetEnvironmentCache(): void {\n  cachedEnvironment = undefined;\n}\n\n/**\n * Parse a `-c key=value` argument from process.argv.\n */\nfunction parseContextArg(key: string): string | undefined {\n  const args = process.argv;\n  for (let i = 0; i < args.length - 1; i++) {\n    if (args[i] === \"-c\") {\n      const parts = args[i + 1].split(\"=\");\n      if (parts[0] === key && parts.length >= 2) {\n        return parts.slice(1).join(\"=\");\n      }\n    }\n  }\n  return undefined;\n}\n\n/**\n * Parse orgConfig from CDK context (-c orgConfig=<json>) in process.argv.\n */\nfunction getProviderAccountsFromContext(): ProviderAccount[] {\n  try {\n    const raw = parseContextArg(\"orgConfig\");\n    if (!raw) return [];\n    const parsed = JSON.parse(raw) as { providerAccounts?: ProviderAccount[] };\n    return parsed.providerAccounts ?? [];\n  } catch (error) {\n    FjallLogger.warn(\n      `[fjall] Failed to parse orgConfig from CDK context: ${error instanceof Error ? error.message : String(error)}`\n    );\n    return [];\n  }\n}\n\n/**\n * Look up environment from account ID via orgConfig CDK context.\n */\nfunction resolveEnvironmentFromAccountId(\n  accountId: string\n): string | undefined {\n  const accounts = getProviderAccountsFromContext();\n  return accounts.find((pa) => pa.id === accountId)?.environment;\n}\n\n/**\n * Look up environment from account name via orgConfig CDK context.\n */\nfunction resolveEnvironmentFromAccountName(\n  accountName: string\n): string | undefined {\n  const accounts = getProviderAccountsFromContext();\n  return accounts.find((pa) => pa.name === accountName)?.environment;\n}\n"]}
|
|
@@ -1,13 +1,8 @@
|
|
|
1
1
|
import { type Account } from "@aws-sdk/client-organizations";
|
|
2
|
-
export interface ICostAllocationTags {
|
|
3
|
-
TagKey: string;
|
|
4
|
-
Status: string;
|
|
5
|
-
}
|
|
6
2
|
export interface Config {
|
|
7
3
|
region: string;
|
|
8
4
|
environment: string;
|
|
9
5
|
existingAccounts: Account[];
|
|
10
|
-
costAllocationTags: ICostAllocationTags[];
|
|
11
6
|
accountId?: string;
|
|
12
7
|
accountName?: string;
|
|
13
8
|
accountIds?: Record<string, string>;
|
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getConfig = getConfig;
|
|
4
4
|
const app_1 = require("../app");
|
|
5
|
-
const util_1 = require("@fjall/util");
|
|
6
5
|
const validationLogger_1 = require("./validationLogger");
|
|
7
6
|
function getConfig(accountName) {
|
|
8
7
|
const app = app_1.default.getInstance();
|
|
@@ -10,37 +9,61 @@ function getConfig(accountName) {
|
|
|
10
9
|
region: process.env.AWS_REGION || "us-east-1",
|
|
11
10
|
environment: "unknown",
|
|
12
11
|
existingAccounts: [],
|
|
13
|
-
costAllocationTags: [],
|
|
14
12
|
secondaryRegions: [],
|
|
15
13
|
allRegions: []
|
|
16
14
|
};
|
|
17
15
|
if (!process.env.AWS_REGION)
|
|
18
16
|
validationLogger_1.FjallLogger.warn("AWS_REGION is not set, defaulting to us-east-1");
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
17
|
+
let providerAccounts = [];
|
|
18
|
+
// Primary: read org config from CDK context (injected by CLI/worker)
|
|
19
|
+
const orgConfigRaw = app.node.tryGetContext("orgConfig");
|
|
20
|
+
if (typeof orgConfigRaw === "string") {
|
|
21
|
+
try {
|
|
22
|
+
const orgConfig = JSON.parse(orgConfigRaw);
|
|
23
|
+
providerAccounts = Array.isArray(orgConfig.providerAccounts)
|
|
24
|
+
? orgConfig.providerAccounts
|
|
25
|
+
: [];
|
|
26
|
+
config.primaryRegion =
|
|
27
|
+
typeof orgConfig.primaryRegion === "string"
|
|
28
|
+
? orgConfig.primaryRegion
|
|
29
|
+
: undefined;
|
|
30
|
+
config.secondaryRegions = Array.isArray(orgConfig.secondaryRegions)
|
|
31
|
+
? orgConfig.secondaryRegions
|
|
32
|
+
: [];
|
|
33
|
+
config.disasterRecoveryRegion =
|
|
34
|
+
typeof orgConfig.disasterRecoveryRegion === "string"
|
|
35
|
+
? orgConfig.disasterRecoveryRegion
|
|
36
|
+
: undefined;
|
|
37
|
+
// Compute allRegions from org config fields
|
|
38
|
+
const regions = new Set();
|
|
39
|
+
if (config.primaryRegion)
|
|
40
|
+
regions.add(config.primaryRegion);
|
|
41
|
+
for (const r of config.secondaryRegions)
|
|
42
|
+
regions.add(r);
|
|
43
|
+
if (config.disasterRecoveryRegion)
|
|
44
|
+
regions.add(config.disasterRecoveryRegion);
|
|
45
|
+
config.allRegions = [...regions];
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
validationLogger_1.FjallLogger.warn(`Failed to parse orgConfig from CDK context: ${error instanceof Error ? error.message : String(error)}`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
validationLogger_1.FjallLogger.warn("No orgConfig context provided — org-level config (accounts, regions) will be empty");
|
|
53
|
+
}
|
|
23
54
|
// Build account IDs map from provider accounts (name → id)
|
|
24
|
-
const providerAccounts = fjallConfig.rootConfig.providerAccounts || [];
|
|
25
55
|
if (providerAccounts.length > 0) {
|
|
26
56
|
config.accountIds = {};
|
|
27
57
|
for (const pa of providerAccounts) {
|
|
28
58
|
config.accountIds[pa.name] = pa.id;
|
|
29
59
|
}
|
|
30
60
|
}
|
|
31
|
-
// Get cost allocation tags
|
|
32
|
-
config.costAllocationTags = fjallConfig.getCostAllocationTags();
|
|
33
|
-
// Get regions configuration
|
|
34
|
-
config.primaryRegion = fjallConfig.getPrimaryRegion();
|
|
35
|
-
config.secondaryRegions = fjallConfig.getSecondaryRegions() || [];
|
|
36
|
-
config.allRegions = fjallConfig.getAllRegions();
|
|
37
|
-
config.disasterRecoveryRegion = fjallConfig.getDisasterRecoveryRegion();
|
|
38
61
|
// If unspecified account name - try to retrieve from context
|
|
39
62
|
if (!accountName)
|
|
40
63
|
accountName = app.node.tryGetContext("accountName");
|
|
41
64
|
// If we have an account name - look for associated provider account
|
|
42
65
|
if (accountName) {
|
|
43
|
-
const providerAccount =
|
|
66
|
+
const providerAccount = providerAccounts.find((pa) => pa.name === accountName);
|
|
44
67
|
if (providerAccount) {
|
|
45
68
|
config.accountId = providerAccount.id;
|
|
46
69
|
config.accountName = providerAccount.name;
|
|
@@ -51,9 +74,9 @@ function getConfig(accountName) {
|
|
|
51
74
|
if (!config.accountName) {
|
|
52
75
|
const accountId = app.node.tryGetContext("accountId");
|
|
53
76
|
// If we find an accountId - retrieve the associated account from config
|
|
54
|
-
if (accountId) {
|
|
77
|
+
if (typeof accountId === "string") {
|
|
55
78
|
config.accountId = accountId;
|
|
56
|
-
const providerAccount =
|
|
79
|
+
const providerAccount = providerAccounts.find((pa) => pa.id === accountId);
|
|
57
80
|
if (providerAccount) {
|
|
58
81
|
config.accountName = providerAccount.name;
|
|
59
82
|
config.environment = providerAccount.environment;
|
|
@@ -62,7 +85,7 @@ function getConfig(accountName) {
|
|
|
62
85
|
}
|
|
63
86
|
// Check for environment from context (highest priority)
|
|
64
87
|
const contextEnvironment = app.node.tryGetContext("environment");
|
|
65
|
-
if (contextEnvironment) {
|
|
88
|
+
if (typeof contextEnvironment === "string") {
|
|
66
89
|
config.environment = contextEnvironment;
|
|
67
90
|
}
|
|
68
91
|
else if (process.env.ENVIRONMENT && config.environment === "unknown") {
|
|
@@ -72,4 +95,4 @@ function getConfig(accountName) {
|
|
|
72
95
|
return config;
|
|
73
96
|
}
|
|
74
97
|
exports.default = getConfig;
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0Q29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL3V0aWxzL2dldENvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQXlCQSw4QkE0RUM7QUFuR0QsZ0NBQXlCO0FBQ3pCLHNDQUFvRDtBQUNwRCx5REFBaUQ7QUFxQmpELFNBQWdCLFNBQVMsQ0FBQyxXQUFvQjtJQUM1QyxNQUFNLEdBQUcsR0FBRyxhQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7SUFFOUIsTUFBTSxNQUFNLEdBQVc7UUFDckIsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxJQUFJLFdBQVc7UUFDN0MsV0FBVyxFQUFFLFNBQVM7UUFDdEIsZ0JBQWdCLEVBQUUsRUFBRTtRQUNwQixrQkFBa0IsRUFBRSxFQUFFO1FBQ3RCLGdCQUFnQixFQUFFLEVBQUU7UUFDcEIsVUFBVSxFQUFFLEVBQUU7S0FDZixDQUFDO0lBRUYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVTtRQUN6Qiw4QkFBVyxDQUFDLElBQUksQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0lBRXJFLDJDQUEyQztJQUMzQyxNQUFNLFdBQVcsR0FBRyxhQUFXLENBQUMsVUFBVSxFQUFFLENBQUM7SUFFN0Msd0JBQXdCO0lBQ3hCLE1BQU0sQ0FBQyxnQkFBZ0IsR0FBRyxXQUFXLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUU1RCwyREFBMkQ7SUFDM0QsTUFBTSxnQkFBZ0IsR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDLGdCQUFnQixJQUFJLEVBQUUsQ0FBQztJQUN2RSxJQUFJLGdCQUFnQixDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNoQyxNQUFNLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztRQUN2QixLQUFLLE1BQU0sRUFBRSxJQUFJLGdCQUFnQixFQUFFLENBQUM7WUFDbEMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNyQyxDQUFDO0lBQ0gsQ0FBQztJQUVELDJCQUEyQjtJQUMzQixNQUFNLENBQUMsa0JBQWtCLEdBQUcsV0FBVyxDQUFDLHFCQUFxQixFQUFFLENBQUM7SUFFaEUsNEJBQTRCO0lBQzVCLE1BQU0sQ0FBQyxhQUFhLEdBQUcsV0FBVyxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDdEQsTUFBTSxDQUFDLGdCQUFnQixHQUFHLFdBQVcsQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUNsRSxNQUFNLENBQUMsVUFBVSxHQUFHLFdBQVcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNoRCxNQUFNLENBQUMsc0JBQXNCLEdBQUcsV0FBVyxDQUFDLHlCQUF5QixFQUFFLENBQUM7SUFFeEUsNkRBQTZEO0lBQzdELElBQUksQ0FBQyxXQUFXO1FBQUUsV0FBVyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3RFLG9FQUFvRTtJQUNwRSxJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQ2hCLE1BQU0sZUFBZSxHQUFHLFdBQVcsQ0FBQyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNwRSxJQUFJLGVBQWUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sQ0FBQyxTQUFTLEdBQUcsZUFBZSxDQUFDLEVBQUUsQ0FBQztZQUN0QyxNQUFNLENBQUMsV0FBVyxHQUFHLGVBQWUsQ0FBQyxJQUFJLENBQUM7WUFDMUMsTUFBTSxDQUFDLFdBQVcsR0FBRyxlQUFlLENBQUMsV0FBVyxDQUFDO1FBQ25ELENBQUM7SUFDSCxDQUFDO0lBRUQsa0ZBQWtGO0lBQ2xGLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDeEIsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDdEQsd0VBQXdFO1FBQ3hFLElBQUksU0FBUyxFQUFFLENBQUM7WUFDZCxNQUFNLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztZQUU3QixNQUFNLGVBQWUsR0FBRyxXQUFXLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDdEUsSUFBSSxlQUFlLEVBQUUsQ0FBQztnQkFDcEIsTUFBTSxDQUFDLFdBQVcsR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDO2dCQUMxQyxNQUFNLENBQUMsV0FBVyxHQUFHLGVBQWUsQ0FBQyxXQUFXLENBQUM7WUFDbkQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsd0RBQXdEO0lBQ3hELE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakUsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO1FBQ3ZCLE1BQU0sQ0FBQyxXQUFXLEdBQUcsa0JBQWtCLENBQUM7SUFDMUMsQ0FBQztTQUFNLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksTUFBTSxDQUFDLFdBQVcsS0FBSyxTQUFTLEVBQUUsQ0FBQztRQUN2RSw2REFBNkQ7UUFDN0QsTUFBTSxDQUFDLFdBQVcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQztJQUMvQyxDQUFDO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELGtCQUFlLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgQWNjb3VudCB9IGZyb20gXCJAYXdzLXNkay9jbGllbnQtb3JnYW5pemF0aW9uc1wiO1xuXG5pbXBvcnQgQXBwIGZyb20gXCIuLi9hcHBcIjtcbmltcG9ydCB7IENvbmZpZyBhcyBGamFsbENvbmZpZyB9IGZyb20gXCJAZmphbGwvdXRpbFwiO1xuaW1wb3J0IHsgRmphbGxMb2dnZXIgfSBmcm9tIFwiLi92YWxpZGF0aW9uTG9nZ2VyXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNvc3RBbGxvY2F0aW9uVGFncyB7XG4gIFRhZ0tleTogc3RyaW5nO1xuICBTdGF0dXM6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICByZWdpb246IHN0cmluZztcbiAgZW52aXJvbm1lbnQ6IHN0cmluZztcbiAgZXhpc3RpbmdBY2NvdW50czogQWNjb3VudFtdO1xuICBjb3N0QWxsb2NhdGlvblRhZ3M6IElDb3N0QWxsb2NhdGlvblRhZ3NbXTtcbiAgYWNjb3VudElkPzogc3RyaW5nO1xuICBhY2NvdW50TmFtZT86IHN0cmluZztcbiAgYWNjb3VudElkcz86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gIHByaW1hcnlSZWdpb24/OiBzdHJpbmc7XG4gIHNlY29uZGFyeVJlZ2lvbnM6IHN0cmluZ1tdO1xuICBhbGxSZWdpb25zOiBzdHJpbmdbXTtcbiAgZGlzYXN0ZXJSZWNvdmVyeVJlZ2lvbj86IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldENvbmZpZyhhY2NvdW50TmFtZT86IHN0cmluZyk6IENvbmZpZyB7XG4gIGNvbnN0IGFwcCA9IEFwcC5nZXRJbnN0YW5jZSgpO1xuXG4gIGNvbnN0IGNvbmZpZzogQ29uZmlnID0ge1xuICAgIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQVdTX1JFR0lPTiB8fCBcInVzLWVhc3QtMVwiLFxuICAgIGVudmlyb25tZW50OiBcInVua25vd25cIixcbiAgICBleGlzdGluZ0FjY291bnRzOiBbXSxcbiAgICBjb3N0QWxsb2NhdGlvblRhZ3M6IFtdLFxuICAgIHNlY29uZGFyeVJlZ2lvbnM6IFtdLFxuICAgIGFsbFJlZ2lvbnM6IFtdXG4gIH07XG5cbiAgaWYgKCFwcm9jZXNzLmVudi5BV1NfUkVHSU9OKVxuICAgIEZqYWxsTG9nZ2VyLndhcm4oXCJBV1NfUkVHSU9OIGlzIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gdXMtZWFzdC0xXCIpO1xuXG4gIC8vIFJldHJpZXZlIGFueSBwcmUtZXhpc3RpbmcgYWNjb3VudCBjb25maWdcbiAgY29uc3QgZmphbGxDb25maWcgPSBGamFsbENvbmZpZy5sb2FkQ29uZmlnKCk7XG5cbiAgLy8gR2V0IGV4aXN0aW5nIGFjY291bnRzXG4gIGNvbmZpZy5leGlzdGluZ0FjY291bnRzID0gZmphbGxDb25maWcuZ2V0RXhpc3RpbmdBY2NvdW50cygpO1xuXG4gIC8vIEJ1aWxkIGFjY291bnQgSURzIG1hcCBmcm9tIHByb3ZpZGVyIGFjY291bnRzIChuYW1lIOKGkiBpZClcbiAgY29uc3QgcHJvdmlkZXJBY2NvdW50cyA9IGZqYWxsQ29uZmlnLnJvb3RDb25maWcucHJvdmlkZXJBY2NvdW50cyB8fCBbXTtcbiAgaWYgKHByb3ZpZGVyQWNjb3VudHMubGVuZ3RoID4gMCkge1xuICAgIGNvbmZpZy5hY2NvdW50SWRzID0ge307XG4gICAgZm9yIChjb25zdCBwYSBvZiBwcm92aWRlckFjY291bnRzKSB7XG4gICAgICBjb25maWcuYWNjb3VudElkc1twYS5uYW1lXSA9IHBhLmlkO1xuICAgIH1cbiAgfVxuXG4gIC8vIEdldCBjb3N0IGFsbG9jYXRpb24gdGFnc1xuICBjb25maWcuY29zdEFsbG9jYXRpb25UYWdzID0gZmphbGxDb25maWcuZ2V0Q29zdEFsbG9jYXRpb25UYWdzKCk7XG5cbiAgLy8gR2V0IHJlZ2lvbnMgY29uZmlndXJhdGlvblxuICBjb25maWcucHJpbWFyeVJlZ2lvbiA9IGZqYWxsQ29uZmlnLmdldFByaW1hcnlSZWdpb24oKTtcbiAgY29uZmlnLnNlY29uZGFyeVJlZ2lvbnMgPSBmamFsbENvbmZpZy5nZXRTZWNvbmRhcnlSZWdpb25zKCkgfHwgW107XG4gIGNvbmZpZy5hbGxSZWdpb25zID0gZmphbGxDb25maWcuZ2V0QWxsUmVnaW9ucygpO1xuICBjb25maWcuZGlzYXN0ZXJSZWNvdmVyeVJlZ2lvbiA9IGZqYWxsQ29uZmlnLmdldERpc2FzdGVyUmVjb3ZlcnlSZWdpb24oKTtcblxuICAvLyBJZiB1bnNwZWNpZmllZCBhY2NvdW50IG5hbWUgLSB0cnkgdG8gcmV0cmlldmUgZnJvbSBjb250ZXh0XG4gIGlmICghYWNjb3VudE5hbWUpIGFjY291bnROYW1lID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dChcImFjY291bnROYW1lXCIpO1xuICAvLyBJZiB3ZSBoYXZlIGFuIGFjY291bnQgbmFtZSAtIGxvb2sgZm9yIGFzc29jaWF0ZWQgcHJvdmlkZXIgYWNjb3VudFxuICBpZiAoYWNjb3VudE5hbWUpIHtcbiAgICBjb25zdCBwcm92aWRlckFjY291bnQgPSBmamFsbENvbmZpZy5nZXRQcm92aWRlckFjY291bnQoYWNjb3VudE5hbWUpO1xuICAgIGlmIChwcm92aWRlckFjY291bnQpIHtcbiAgICAgIGNvbmZpZy5hY2NvdW50SWQgPSBwcm92aWRlckFjY291bnQuaWQ7XG4gICAgICBjb25maWcuYWNjb3VudE5hbWUgPSBwcm92aWRlckFjY291bnQubmFtZTtcbiAgICAgIGNvbmZpZy5lbnZpcm9ubWVudCA9IHByb3ZpZGVyQWNjb3VudC5lbnZpcm9ubWVudDtcbiAgICB9XG4gIH1cblxuICAvLyBJZiB3ZSBzdGlsbCBkb24ndCBoYXZlIGFuIGFjY291bnQgbmFtZSAtIHRyeSB0byByZXRyaWV2ZSBhY2NvdW50SWQgZnJvbSBjb250ZXh0XG4gIGlmICghY29uZmlnLmFjY291bnROYW1lKSB7XG4gICAgY29uc3QgYWNjb3VudElkID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dChcImFjY291bnRJZFwiKTtcbiAgICAvLyBJZiB3ZSBmaW5kIGFuIGFjY291bnRJZCAtIHJldHJpZXZlIHRoZSBhc3NvY2lhdGVkIGFjY291bnQgZnJvbSBjb25maWdcbiAgICBpZiAoYWNjb3VudElkKSB7XG4gICAgICBjb25maWcuYWNjb3VudElkID0gYWNjb3VudElkO1xuXG4gICAgICBjb25zdCBwcm92aWRlckFjY291bnQgPSBmamFsbENvbmZpZy5nZXRQcm92aWRlckFjY291bnRCeUlkKGFjY291bnRJZCk7XG4gICAgICBpZiAocHJvdmlkZXJBY2NvdW50KSB7XG4gICAgICAgIGNvbmZpZy5hY2NvdW50TmFtZSA9IHByb3ZpZGVyQWNjb3VudC5uYW1lO1xuICAgICAgICBjb25maWcuZW52aXJvbm1lbnQgPSBwcm92aWRlckFjY291bnQuZW52aXJvbm1lbnQ7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLy8gQ2hlY2sgZm9yIGVudmlyb25tZW50IGZyb20gY29udGV4dCAoaGlnaGVzdCBwcmlvcml0eSlcbiAgY29uc3QgY29udGV4dEVudmlyb25tZW50ID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dChcImVudmlyb25tZW50XCIpO1xuICBpZiAoY29udGV4dEVudmlyb25tZW50KSB7XG4gICAgY29uZmlnLmVudmlyb25tZW50ID0gY29udGV4dEVudmlyb25tZW50O1xuICB9IGVsc2UgaWYgKHByb2Nlc3MuZW52LkVOVklST05NRU5UICYmIGNvbmZpZy5lbnZpcm9ubWVudCA9PT0gXCJ1bmtub3duXCIpIHtcbiAgICAvLyBGYWxsIGJhY2sgdG8gRU5WSVJPTk1FTlQgdmFyaWFibGUgaWYgbm8gb3RoZXIgc291cmNlIGZvdW5kXG4gICAgY29uZmlnLmVudmlyb25tZW50ID0gcHJvY2Vzcy5lbnYuRU5WSVJPTk1FTlQ7XG4gIH1cblxuICByZXR1cm4gY29uZmlnO1xufVxuXG5leHBvcnQgZGVmYXVsdCBnZXRDb25maWc7XG4iXX0=
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"getConfig.js","sourceRoot":"","sources":["../../../lib/utils/getConfig.ts"],"names":[],"mappings":"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","sourcesContent":["import { type Account } from \"@aws-sdk/client-organizations\";\n\nimport App from \"../app\";\nimport { type ProviderAccount } from \"@fjall/util\";\nimport { FjallLogger } from \"./validationLogger\";\n\nexport interface Config {\n  region: string;\n  environment: string;\n  existingAccounts: Account[];\n  accountId?: string;\n  accountName?: string;\n  accountIds?: Record<string, string>;\n  primaryRegion?: string;\n  secondaryRegions: string[];\n  allRegions: string[];\n  disasterRecoveryRegion?: string;\n}\n\nexport function getConfig(accountName?: string): Config {\n  const app = App.getInstance();\n\n  const config: Config = {\n    region: process.env.AWS_REGION || \"us-east-1\",\n    environment: \"unknown\",\n    existingAccounts: [],\n    secondaryRegions: [],\n    allRegions: []\n  };\n\n  if (!process.env.AWS_REGION)\n    FjallLogger.warn(\"AWS_REGION is not set, defaulting to us-east-1\");\n\n  let providerAccounts: ProviderAccount[] = [];\n\n  // Primary: read org config from CDK context (injected by CLI/worker)\n  const orgConfigRaw = app.node.tryGetContext(\"orgConfig\");\n\n  if (typeof orgConfigRaw === \"string\") {\n    try {\n      const orgConfig = JSON.parse(orgConfigRaw) as Record<string, unknown>;\n      providerAccounts = Array.isArray(orgConfig.providerAccounts)\n        ? (orgConfig.providerAccounts as ProviderAccount[])\n        : [];\n      config.primaryRegion =\n        typeof orgConfig.primaryRegion === \"string\"\n          ? orgConfig.primaryRegion\n          : undefined;\n      config.secondaryRegions = Array.isArray(orgConfig.secondaryRegions)\n        ? (orgConfig.secondaryRegions as string[])\n        : [];\n      config.disasterRecoveryRegion =\n        typeof orgConfig.disasterRecoveryRegion === \"string\"\n          ? orgConfig.disasterRecoveryRegion\n          : undefined;\n\n      // Compute allRegions from org config fields\n      const regions = new Set<string>();\n      if (config.primaryRegion) regions.add(config.primaryRegion);\n      for (const r of config.secondaryRegions) regions.add(r);\n      if (config.disasterRecoveryRegion)\n        regions.add(config.disasterRecoveryRegion);\n      config.allRegions = [...regions];\n    } catch (error) {\n      FjallLogger.warn(\n        `Failed to parse orgConfig from CDK context: ${error instanceof Error ? error.message : String(error)}`\n      );\n    }\n  } else {\n    FjallLogger.warn(\n      \"No orgConfig context provided — org-level config (accounts, regions) will be empty\"\n    );\n  }\n\n  // Build account IDs map from provider accounts (name → id)\n  if (providerAccounts.length > 0) {\n    config.accountIds = {};\n    for (const pa of providerAccounts) {\n      config.accountIds[pa.name] = pa.id;\n    }\n  }\n\n  // If unspecified account name - try to retrieve from context\n  if (!accountName) accountName = app.node.tryGetContext(\"accountName\");\n  // If we have an account name - look for associated provider account\n  if (accountName) {\n    const providerAccount = providerAccounts.find(\n      (pa) => pa.name === accountName\n    );\n    if (providerAccount) {\n      config.accountId = providerAccount.id;\n      config.accountName = providerAccount.name;\n      config.environment = providerAccount.environment;\n    }\n  }\n\n  // If we still don't have an account name - try to retrieve accountId from context\n  if (!config.accountName) {\n    const accountId = app.node.tryGetContext(\"accountId\");\n    // If we find an accountId - retrieve the associated account from config\n    if (typeof accountId === \"string\") {\n      config.accountId = accountId;\n\n      const providerAccount = providerAccounts.find(\n        (pa) => pa.id === accountId\n      );\n      if (providerAccount) {\n        config.accountName = providerAccount.name;\n        config.environment = providerAccount.environment;\n      }\n    }\n  }\n\n  // Check for environment from context (highest priority)\n  const contextEnvironment = app.node.tryGetContext(\"environment\");\n  if (typeof contextEnvironment === \"string\") {\n    config.environment = contextEnvironment;\n  } else if (process.env.ENVIRONMENT && config.environment === \"unknown\") {\n    // Fall back to ENVIRONMENT variable if no other source found\n    config.environment = process.env.ENVIRONMENT;\n  }\n\n  return config;\n}\n\nexport default getConfig;\n"]}
|
|
@@ -1,5 +1,12 @@
|
|
|
1
|
+
export * from "./backupTierMapping";
|
|
1
2
|
export * from "./capitaliseString";
|
|
3
|
+
export * from "./connections";
|
|
4
|
+
export * from "./databaseTypes";
|
|
2
5
|
export * from "./getConfig";
|
|
6
|
+
export * from "./removalPolicy";
|
|
3
7
|
export * from "./resourceNaming";
|
|
4
8
|
export * from "./standardTagsAspect";
|
|
5
9
|
export * from "./validationLogger";
|
|
10
|
+
export * from "./env";
|
|
11
|
+
export * from "./vpcUtils";
|
|
12
|
+
export * from "./domainTypes";
|
package/dist/lib/utils/index.js
CHANGED
|
@@ -14,9 +14,16 @@ 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("./backupTierMapping"), exports);
|
|
17
18
|
__exportStar(require("./capitaliseString"), exports);
|
|
19
|
+
__exportStar(require("./connections"), exports);
|
|
20
|
+
__exportStar(require("./databaseTypes"), exports);
|
|
18
21
|
__exportStar(require("./getConfig"), exports);
|
|
22
|
+
__exportStar(require("./removalPolicy"), exports);
|
|
19
23
|
__exportStar(require("./resourceNaming"), exports);
|
|
20
24
|
__exportStar(require("./standardTagsAspect"), exports);
|
|
21
25
|
__exportStar(require("./validationLogger"), exports);
|
|
22
|
-
|
|
26
|
+
__exportStar(require("./env"), exports);
|
|
27
|
+
__exportStar(require("./vpcUtils"), exports);
|
|
28
|
+
__exportStar(require("./domainTypes"), exports);
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHNEQUFvQztBQUNwQyxxREFBbUM7QUFDbkMsZ0RBQThCO0FBQzlCLGtEQUFnQztBQUNoQyw4Q0FBNEI7QUFDNUIsa0RBQWdDO0FBQ2hDLG1EQUFpQztBQUNqQyx1REFBcUM7QUFDckMscURBQW1DO0FBQ25DLHdDQUFzQjtBQUN0Qiw2Q0FBMkI7QUFDM0IsZ0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYmFja3VwVGllck1hcHBpbmdcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NhcGl0YWxpc2VTdHJpbmdcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Nvbm5lY3Rpb25zXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kYXRhYmFzZVR5cGVzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9nZXRDb25maWdcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3JlbW92YWxQb2xpY3lcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Jlc291cmNlTmFtaW5nXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zdGFuZGFyZFRhZ3NBc3BlY3RcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZhbGlkYXRpb25Mb2dnZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2VudlwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdnBjVXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RvbWFpblR5cGVzXCI7XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toRemovalPolicy = toRemovalPolicy;
|
|
4
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
5
|
+
function toRemovalPolicy(value) {
|
|
6
|
+
switch (value) {
|
|
7
|
+
case "DESTROY":
|
|
8
|
+
return aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
9
|
+
case "SNAPSHOT":
|
|
10
|
+
return aws_cdk_lib_1.RemovalPolicy.SNAPSHOT;
|
|
11
|
+
case "RETAIN":
|
|
12
|
+
default:
|
|
13
|
+
return aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3ZhbFBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2xpYi91dGlscy9yZW1vdmFsUG9saWN5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsMENBWUM7QUFkRCw2Q0FBNEM7QUFFNUMsU0FBZ0IsZUFBZSxDQUM3QixLQUF5QztJQUV6QyxRQUFRLEtBQUssRUFBRSxDQUFDO1FBQ2QsS0FBSyxTQUFTO1lBQ1osT0FBTywyQkFBYSxDQUFDLE9BQU8sQ0FBQztRQUMvQixLQUFLLFVBQVU7WUFDYixPQUFPLDJCQUFhLENBQUMsUUFBUSxDQUFDO1FBQ2hDLEtBQUssUUFBUSxDQUFDO1FBQ2Q7WUFDRSxPQUFPLDJCQUFhLENBQUMsTUFBTSxDQUFDO0lBQ2hDLENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVtb3ZhbFBvbGljeSB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuXG5leHBvcnQgZnVuY3Rpb24gdG9SZW1vdmFsUG9saWN5KFxuICB2YWx1ZT86IFwiREVTVFJPWVwiIHwgXCJSRVRBSU5cIiB8IFwiU05BUFNIT1RcIlxuKTogUmVtb3ZhbFBvbGljeSB7XG4gIHN3aXRjaCAodmFsdWUpIHtcbiAgICBjYXNlIFwiREVTVFJPWVwiOlxuICAgICAgcmV0dXJuIFJlbW92YWxQb2xpY3kuREVTVFJPWTtcbiAgICBjYXNlIFwiU05BUFNIT1RcIjpcbiAgICAgIHJldHVybiBSZW1vdmFsUG9saWN5LlNOQVBTSE9UO1xuICAgIGNhc2UgXCJSRVRBSU5cIjpcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIFJlbW92YWxQb2xpY3kuUkVUQUlOO1xuICB9XG59XG4iXX0=
|
|
@@ -23,6 +23,10 @@ export declare class StandardTagsAspect implements IAspect {
|
|
|
23
23
|
private addIpamPoolTag;
|
|
24
24
|
/**
|
|
25
25
|
* Add disaster recovery tier tag to S3 buckets with backupVaultTier property.
|
|
26
|
+
* This serves as a per-resource override when `backupVaultTier` is set on a
|
|
27
|
+
* specific S3 bucket. CDK child tags override parent tags, so this takes
|
|
28
|
+
* precedence over the app-level backup tag set via `App.getApp({ backup })`.
|
|
29
|
+
*
|
|
26
30
|
* Tag format: fjall:disasterRecovery:tier = "{tier}"
|
|
27
31
|
*
|
|
28
32
|
* Tier mapping:
|