@aws-cdk/region-info 2.0.0 → 2.4.0
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/.jsii +125 -49
- package/.jsii.tabl.json +357 -0
- package/LICENSE +1 -1
- package/NOTICE +1 -1
- package/build-tools/fact-tables.d.ts +0 -1
- package/build-tools/fact-tables.js +150 -83
- package/build-tools/generate-static-data.js +11 -7
- package/lib/aws-entities.d.ts +56 -0
- package/lib/aws-entities.js +143 -0
- package/lib/built-ins.generated.d.ts +1 -1
- package/lib/built-ins.generated.js +275 -110
- package/lib/default.d.ts +3 -3
- package/lib/default.js +24 -15
- package/lib/fact.d.ts +1 -1
- package/lib/fact.js +10 -6
- package/lib/region-info.d.ts +14 -1
- package/lib/region-info.js +24 -4
- package/package.json +4 -4
- package/rosetta/_generated.ts-fixture +6 -0
- package/build-tools/aws-entities.d.ts +0 -12
- package/build-tools/aws-entities.js +0 -56
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.generateRegionMap = exports.partitionInformation = exports.regionsBefore = exports.before = exports.AWS_SERVICES = exports.AWS_REGIONS = exports.AWS_REGIONS_AND_RULES = exports.RULE_S3_WEBSITE_REGIONAL_SUBDOMAIN = exports.RULE_SSM_PRINCIPALS_ARE_REGIONAL = void 0;
|
|
4
|
+
// Rule prefix
|
|
5
|
+
const RULE_ = 'RULE_';
|
|
6
|
+
/**
|
|
7
|
+
* After this point, SSM only creates regional principals
|
|
8
|
+
*/
|
|
9
|
+
exports.RULE_SSM_PRINCIPALS_ARE_REGIONAL = `${RULE_}SSM_PRINCIPALS_ARE_REGIONAL`;
|
|
10
|
+
/**
|
|
11
|
+
* After this point, S3 website domains look like `s3-website.REGION.s3.amazonaws.com`
|
|
12
|
+
*
|
|
13
|
+
* Before this point, S3 website domains look like `s3-website-REGION.s3.amazonaws.com`.
|
|
14
|
+
*/
|
|
15
|
+
exports.RULE_S3_WEBSITE_REGIONAL_SUBDOMAIN = `${RULE_}S3_WEBSITE_REGIONAL_SUBDOMAIN`;
|
|
16
|
+
/**
|
|
17
|
+
* List of AWS region, ordered by launch date (oldest to newest)
|
|
18
|
+
*
|
|
19
|
+
* The significance of this is that standards and conventions change over time.
|
|
20
|
+
* Generally, as rules are changed they only apply to new regions, and old
|
|
21
|
+
* regions are left as-is.
|
|
22
|
+
*
|
|
23
|
+
* We mix the list of regions with a list of rules that were introduced over
|
|
24
|
+
* time (rules are strings starting with `RULE_`).
|
|
25
|
+
*
|
|
26
|
+
* Therefore, if we want to know if a rule applies to a certain region, we
|
|
27
|
+
* only need to check its position in the list and compare it to when a
|
|
28
|
+
* rule was introduced.
|
|
29
|
+
*/
|
|
30
|
+
exports.AWS_REGIONS_AND_RULES = [
|
|
31
|
+
'us-east-1',
|
|
32
|
+
'eu-west-1',
|
|
33
|
+
'us-west-1',
|
|
34
|
+
'ap-southeast-1',
|
|
35
|
+
'ap-northeast-1',
|
|
36
|
+
'us-gov-west-1',
|
|
37
|
+
'us-west-2',
|
|
38
|
+
'sa-east-1',
|
|
39
|
+
'ap-southeast-2',
|
|
40
|
+
exports.RULE_S3_WEBSITE_REGIONAL_SUBDOMAIN,
|
|
41
|
+
'cn-north-1',
|
|
42
|
+
'us-iso-east-1',
|
|
43
|
+
'eu-central-1',
|
|
44
|
+
'ap-northeast-2',
|
|
45
|
+
'ap-south-1',
|
|
46
|
+
'us-east-2',
|
|
47
|
+
'ca-central-1',
|
|
48
|
+
'eu-west-2',
|
|
49
|
+
'us-isob-east-1',
|
|
50
|
+
'cn-northwest-1',
|
|
51
|
+
'eu-west-3',
|
|
52
|
+
'ap-northeast-3',
|
|
53
|
+
'us-gov-east-1',
|
|
54
|
+
'eu-north-1',
|
|
55
|
+
exports.RULE_SSM_PRINCIPALS_ARE_REGIONAL,
|
|
56
|
+
'ap-east-1',
|
|
57
|
+
'me-south-1',
|
|
58
|
+
'eu-south-1',
|
|
59
|
+
'af-south-1',
|
|
60
|
+
'us-iso-west-1',
|
|
61
|
+
'eu-south-2',
|
|
62
|
+
'ap-southeast-3',
|
|
63
|
+
];
|
|
64
|
+
/**
|
|
65
|
+
* The names of all (known) AWS regions
|
|
66
|
+
*
|
|
67
|
+
* Not in the list ==> no built-in data for that region.
|
|
68
|
+
*/
|
|
69
|
+
exports.AWS_REGIONS = exports.AWS_REGIONS_AND_RULES
|
|
70
|
+
.filter((x) => !x.startsWith(RULE_))
|
|
71
|
+
.sort();
|
|
72
|
+
/**
|
|
73
|
+
* Possibly non-exaustive list of all service names, used to locate service principals.
|
|
74
|
+
*
|
|
75
|
+
* Not in the list ==> default service principal mappings.
|
|
76
|
+
*/
|
|
77
|
+
exports.AWS_SERVICES = [
|
|
78
|
+
'application-autoscaling',
|
|
79
|
+
'autoscaling',
|
|
80
|
+
'codedeploy',
|
|
81
|
+
'ec2',
|
|
82
|
+
'events',
|
|
83
|
+
'lambda',
|
|
84
|
+
'logs',
|
|
85
|
+
's3',
|
|
86
|
+
'ssm',
|
|
87
|
+
'sns',
|
|
88
|
+
'sqs',
|
|
89
|
+
'states',
|
|
90
|
+
].sort();
|
|
91
|
+
/**
|
|
92
|
+
* Whether or not a region predates a given rule (or region).
|
|
93
|
+
*
|
|
94
|
+
* Unknown region => we have to assume no.
|
|
95
|
+
*/
|
|
96
|
+
function before(region, ruleOrRegion) {
|
|
97
|
+
const ruleIx = exports.AWS_REGIONS_AND_RULES.indexOf(ruleOrRegion);
|
|
98
|
+
if (ruleIx === -1) {
|
|
99
|
+
throw new Error(`Unknown rule: ${ruleOrRegion}`);
|
|
100
|
+
}
|
|
101
|
+
const regionIx = exports.AWS_REGIONS_AND_RULES.indexOf(region);
|
|
102
|
+
return regionIx === -1 ? false : regionIx < ruleIx;
|
|
103
|
+
}
|
|
104
|
+
exports.before = before;
|
|
105
|
+
/**
|
|
106
|
+
* Return all regions before a given rule was introduced (or region)
|
|
107
|
+
*/
|
|
108
|
+
function regionsBefore(ruleOrRegion) {
|
|
109
|
+
const ruleIx = exports.AWS_REGIONS_AND_RULES.indexOf(ruleOrRegion);
|
|
110
|
+
if (ruleIx === -1) {
|
|
111
|
+
throw new Error(`Unknown rule: ${ruleOrRegion}`);
|
|
112
|
+
}
|
|
113
|
+
return exports.AWS_REGIONS_AND_RULES.filter((_, i) => i < ruleIx).sort();
|
|
114
|
+
}
|
|
115
|
+
exports.regionsBefore = regionsBefore;
|
|
116
|
+
const PARTITION_MAP = {
|
|
117
|
+
'default': { partition: 'aws', domainSuffix: 'amazonaws.com' },
|
|
118
|
+
'cn-': { partition: 'aws-cn', domainSuffix: 'amazonaws.com.cn' },
|
|
119
|
+
'us-gov-': { partition: 'aws-us-gov', domainSuffix: 'amazonaws.com' },
|
|
120
|
+
'us-iso-': { partition: 'aws-iso', domainSuffix: 'c2s.ic.gov' },
|
|
121
|
+
'us-isob-': { partition: 'aws-iso-b', domainSuffix: 'sc2s.sgov.gov' },
|
|
122
|
+
};
|
|
123
|
+
function partitionInformation(region) {
|
|
124
|
+
for (const [prefix, info] of Object.entries(PARTITION_MAP)) {
|
|
125
|
+
if (region.startsWith(prefix)) {
|
|
126
|
+
return info;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return PARTITION_MAP.default;
|
|
130
|
+
}
|
|
131
|
+
exports.partitionInformation = partitionInformation;
|
|
132
|
+
/**
|
|
133
|
+
* Build a lookup map for all regions
|
|
134
|
+
*/
|
|
135
|
+
function generateRegionMap(cb) {
|
|
136
|
+
const ret = {};
|
|
137
|
+
for (const region of exports.AWS_REGIONS) {
|
|
138
|
+
ret[region] = cb(region);
|
|
139
|
+
}
|
|
140
|
+
return ret;
|
|
141
|
+
}
|
|
142
|
+
exports.generateRegionMap = generateRegionMap;
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-entities.js","sourceRoot":"","sources":["aws-entities.ts"],"names":[],"mappings":"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","sourcesContent":["// Rule prefix\nconst RULE_ = 'RULE_';\n\n/**\n * After this point, SSM only creates regional principals\n */\nexport const RULE_SSM_PRINCIPALS_ARE_REGIONAL = `${RULE_}SSM_PRINCIPALS_ARE_REGIONAL`;\n\n/**\n * After this point, S3 website domains look like `s3-website.REGION.s3.amazonaws.com`\n *\n * Before this point, S3 website domains look like `s3-website-REGION.s3.amazonaws.com`.\n */\nexport const RULE_S3_WEBSITE_REGIONAL_SUBDOMAIN = `${RULE_}S3_WEBSITE_REGIONAL_SUBDOMAIN`;\n\n/**\n * List of AWS region, ordered by launch date (oldest to newest)\n *\n * The significance of this is that standards and conventions change over time.\n * Generally, as rules are changed they only apply to new regions, and old\n * regions are left as-is.\n *\n * We mix the list of regions with a list of rules that were introduced over\n * time (rules are strings starting with `RULE_`).\n *\n * Therefore, if we want to know if a rule applies to a certain region, we\n * only need to check its position in the list and compare it to when a\n * rule was introduced.\n */\nexport const AWS_REGIONS_AND_RULES = [\n  'us-east-1', // US East (N. Virginia)\n  'eu-west-1', // Europe (Ireland)\n  'us-west-1', // US West (N. California)\n  'ap-southeast-1', // Asia Pacific (Singapore)\n  'ap-northeast-1', // Asia Pacific (Tokyo)\n  'us-gov-west-1', // AWS GovCloud (US-West)\n  'us-west-2', // US West (Oregon)\n  'sa-east-1', // South America (São Paulo)\n  'ap-southeast-2', // Asia Pacific (Sydney)\n  RULE_S3_WEBSITE_REGIONAL_SUBDOMAIN,\n  'cn-north-1', // China (Beijing)\n  'us-iso-east-1', // AWS ISO\n  'eu-central-1', // Europe (Frankfurt)\n  'ap-northeast-2', // Asia Pacific (Seoul)\n  'ap-south-1', // Asia Pacific (Mumbai)\n  'us-east-2', // US East (Ohio)\n  'ca-central-1', // Canada (Central)\n  'eu-west-2', // Europe (London)\n  'us-isob-east-1', // AWS ISO-B\n  'cn-northwest-1', // China (Ningxia)\n  'eu-west-3', // Europe (Paris)\n  'ap-northeast-3', // Asia Pacific (Osaka)\n  'us-gov-east-1', // AWS GovCloud (US-East)\n  'eu-north-1', // Europe (Stockholm)\n  RULE_SSM_PRINCIPALS_ARE_REGIONAL,\n  'ap-east-1', // Asia Pacific (Hong Kong)\n  'me-south-1', // Middle East (Bahrain)\n  'eu-south-1', // Europe (Milan)\n  'af-south-1', // Africa (Cape Town)\n  'us-iso-west-1', // US ISO West\n  'eu-south-2', // Europe (Spain)\n  'ap-southeast-3', // Asia Pacific (Jakarta)\n];\n\n/**\n * The names of all (known) AWS regions\n *\n * Not in the list ==> no built-in data for that region.\n */\nexport const AWS_REGIONS = AWS_REGIONS_AND_RULES\n  .filter((x) => !x.startsWith(RULE_))\n  .sort();\n\n/**\n * Possibly non-exaustive list of all service names, used to locate service principals.\n *\n * Not in the list ==> default service principal mappings.\n */\nexport const AWS_SERVICES = [\n  'application-autoscaling',\n  'autoscaling',\n  'codedeploy',\n  'ec2',\n  'events',\n  'lambda',\n  'logs',\n  's3',\n  'ssm',\n  'sns',\n  'sqs',\n  'states',\n].sort();\n\n/**\n * Whether or not a region predates a given rule (or region).\n *\n * Unknown region => we have to assume no.\n */\nexport function before(region: string, ruleOrRegion: string) {\n  const ruleIx = AWS_REGIONS_AND_RULES.indexOf(ruleOrRegion);\n  if (ruleIx === -1) {\n    throw new Error(`Unknown rule: ${ruleOrRegion}`);\n  }\n  const regionIx = AWS_REGIONS_AND_RULES.indexOf(region);\n  return regionIx === -1 ? false : regionIx < ruleIx;\n}\n\n/**\n * Return all regions before a given rule was introduced (or region)\n */\nexport function regionsBefore(ruleOrRegion: string): string[] {\n  const ruleIx = AWS_REGIONS_AND_RULES.indexOf(ruleOrRegion);\n  if (ruleIx === -1) {\n    throw new Error(`Unknown rule: ${ruleOrRegion}`);\n  }\n  return AWS_REGIONS_AND_RULES.filter((_, i) => i < ruleIx).sort();\n}\n\nexport interface Region { partition: string, domainSuffix: string }\n\nconst PARTITION_MAP: { [region: string]: Region } = {\n  'default': { partition: 'aws', domainSuffix: 'amazonaws.com' },\n  'cn-': { partition: 'aws-cn', domainSuffix: 'amazonaws.com.cn' },\n  'us-gov-': { partition: 'aws-us-gov', domainSuffix: 'amazonaws.com' },\n  'us-iso-': { partition: 'aws-iso', domainSuffix: 'c2s.ic.gov' },\n  'us-isob-': { partition: 'aws-iso-b', domainSuffix: 'sc2s.sgov.gov' },\n};\n\nexport function partitionInformation(region: string): Region {\n  for (const [prefix, info] of Object.entries(PARTITION_MAP)) {\n    if (region.startsWith(prefix)) {\n      return info;\n    }\n  }\n  return PARTITION_MAP.default;\n}\n\n/**\n * Build a lookup map for all regions\n */\nexport function generateRegionMap(cb: (region: string) => string): Record<string, string> {\n  const ret: Record<string, string> = {};\n  for (const region of AWS_REGIONS) {\n    ret[region] = cb(region);\n  }\n  return ret;\n}\n"]}
|