@aws-cdk/region-info 2.12.0 → 2.13.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 +2 -2
- package/.jsii.tabl.json +1 -1
- package/lib/built-ins.generated.d.ts +1 -1
- package/lib/built-ins.generated.js +2 -2
- package/lib/default.d.ts +6 -11
- package/lib/default.js +8 -13
- package/lib/fact.d.ts +30 -71
- package/lib/fact.js +32 -63
- package/lib/region-info.d.ts +24 -48
- package/lib/region-info.js +26 -50
- package/package.json +3 -3
package/lib/default.d.ts
CHANGED
|
@@ -1,27 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Provides default values for certain regional information points.
|
|
3
|
-
*
|
|
4
|
-
* @stability stable
|
|
5
3
|
*/
|
|
6
4
|
export declare class Default {
|
|
7
5
|
/**
|
|
8
|
-
* The default value for a VPC Endpoint Service name prefix, useful if you do
|
|
9
|
-
*
|
|
10
|
-
*
|
|
6
|
+
* The default value for a VPC Endpoint Service name prefix, useful if you do
|
|
7
|
+
* not have a synthesize-time region literal available (all you have is
|
|
8
|
+
* `{ "Ref": "AWS::Region" }`)
|
|
11
9
|
*/
|
|
12
10
|
static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = "com.amazonaws.vpce";
|
|
13
11
|
/**
|
|
14
|
-
* Computes a "standard" AWS Service principal for a given service, region and suffix.
|
|
15
|
-
*
|
|
16
|
-
* This is useful for example when
|
|
12
|
+
* Computes a "standard" AWS Service principal for a given service, region and suffix. This is useful for example when
|
|
17
13
|
* you need to compute a service principal name, but you do not have a synthesize-time region literal available (so
|
|
18
14
|
* all you have is `{ "Ref": "AWS::Region" }`). This way you get the same defaulting behavior that is normally used
|
|
19
15
|
* for built-in data.
|
|
20
16
|
*
|
|
21
|
-
* @param serviceFqn the name of the service (s3, s3.amazonaws.com, ...)
|
|
22
|
-
* @param region
|
|
17
|
+
* @param serviceFqn the name of the service (s3, s3.amazonaws.com, ...)
|
|
18
|
+
* @param region the region in which the service principal is needed.
|
|
23
19
|
* @param urlSuffix deprecated and ignored.
|
|
24
|
-
* @stability stable
|
|
25
20
|
*/
|
|
26
21
|
static servicePrincipal(serviceFqn: string, region: string, urlSuffix: string): string;
|
|
27
22
|
private constructor();
|
package/lib/default.js
CHANGED
|
@@ -6,23 +6,18 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
6
6
|
const aws_entities_1 = require("./aws-entities");
|
|
7
7
|
/**
|
|
8
8
|
* Provides default values for certain regional information points.
|
|
9
|
-
*
|
|
10
|
-
* @stability stable
|
|
11
9
|
*/
|
|
12
10
|
class Default {
|
|
13
11
|
constructor() { }
|
|
14
12
|
/**
|
|
15
|
-
* Computes a "standard" AWS Service principal for a given service, region and suffix.
|
|
16
|
-
*
|
|
17
|
-
* This is useful for example when
|
|
13
|
+
* Computes a "standard" AWS Service principal for a given service, region and suffix. This is useful for example when
|
|
18
14
|
* you need to compute a service principal name, but you do not have a synthesize-time region literal available (so
|
|
19
15
|
* all you have is `{ "Ref": "AWS::Region" }`). This way you get the same defaulting behavior that is normally used
|
|
20
16
|
* for built-in data.
|
|
21
17
|
*
|
|
22
|
-
* @param serviceFqn the name of the service (s3, s3.amazonaws.com, ...)
|
|
23
|
-
* @param region
|
|
18
|
+
* @param serviceFqn the name of the service (s3, s3.amazonaws.com, ...)
|
|
19
|
+
* @param region the region in which the service principal is needed.
|
|
24
20
|
* @param urlSuffix deprecated and ignored.
|
|
25
|
-
* @stability stable
|
|
26
21
|
*/
|
|
27
22
|
static servicePrincipal(serviceFqn, region, urlSuffix) {
|
|
28
23
|
const serviceName = extractSimpleName(serviceFqn);
|
|
@@ -110,15 +105,15 @@ class Default {
|
|
|
110
105
|
}
|
|
111
106
|
exports.Default = Default;
|
|
112
107
|
_a = JSII_RTTI_SYMBOL_1;
|
|
113
|
-
Default[_a] = { fqn: "@aws-cdk/region-info.Default", version: "2.
|
|
108
|
+
Default[_a] = { fqn: "@aws-cdk/region-info.Default", version: "2.13.0" };
|
|
114
109
|
/**
|
|
115
|
-
* The default value for a VPC Endpoint Service name prefix, useful if you do
|
|
116
|
-
*
|
|
117
|
-
*
|
|
110
|
+
* The default value for a VPC Endpoint Service name prefix, useful if you do
|
|
111
|
+
* not have a synthesize-time region literal available (all you have is
|
|
112
|
+
* `{ "Ref": "AWS::Region" }`)
|
|
118
113
|
*/
|
|
119
114
|
Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'com.amazonaws.vpce';
|
|
120
115
|
function extractSimpleName(serviceFqn) {
|
|
121
116
|
const matches = serviceFqn.match(/^([^.]+)(?:(?:\.amazonaws\.com(?:\.cn)?)|(?:\.c2s\.ic\.gov)|(?:\.sc2s\.sgov\.gov))?$/);
|
|
122
117
|
return matches ? matches[1] : undefined;
|
|
123
118
|
}
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default.js","sourceRoot":"","sources":["default.ts"],"names":[],"mappings":"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","sourcesContent":["import { before, RULE_SSM_PRINCIPALS_ARE_REGIONAL } from './aws-entities';\n\n/**\n * Provides default values for certain regional information points.\n */\nexport class Default {\n\n  /**\n   * The default value for a VPC Endpoint Service name prefix, useful if you do\n   * not have a synthesize-time region literal available (all you have is\n   * `{ \"Ref\": \"AWS::Region\" }`)\n   */\n  public static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'com.amazonaws.vpce';\n\n  /**\n   * Computes a \"standard\" AWS Service principal for a given service, region and suffix. This is useful for example when\n   * you need to compute a service principal name, but you do not have a synthesize-time region literal available (so\n   * all you have is `{ \"Ref\": \"AWS::Region\" }`). This way you get the same defaulting behavior that is normally used\n   * for built-in data.\n   *\n   * @param serviceFqn the name of the service (s3, s3.amazonaws.com, ...)\n   * @param region    the region in which the service principal is needed.\n   * @param urlSuffix deprecated and ignored.\n   */\n  public static servicePrincipal(serviceFqn: string, region: string, urlSuffix: string): string {\n    const serviceName = extractSimpleName(serviceFqn);\n    if (!serviceName) {\n      // Return \"service\" if it does not look like any of the following:\n      // - s3\n      // - s3.amazonaws.com\n      // - s3.amazonaws.com.cn\n      // - s3.c2s.ic.gov\n      // - s3.sc2s.sgov.gov\n      return serviceFqn;\n    }\n\n    function determineConfiguration(service: string): (service: string, region: string, urlSuffix: string) => string {\n      function universal(s: string) { return `${s}.amazonaws.com`; };\n      function partitional(s: string, _: string, u: string) { return `${s}.${u}`; };\n      function regional(s: string, r: string) { return `${s}.${r}.amazonaws.com`; };\n      function regionalPartitional(s: string, r: string, u: string) { return `${s}.${r}.${u}`; };\n\n      // Exceptions for Service Principals in us-iso-*\n      const US_ISO_EXCEPTIONS = new Set([\n        'cloudhsm',\n        'config',\n        'states',\n        'workspaces',\n      ]);\n\n      // Account for idiosyncratic Service Principals in `us-iso-*` regions\n      if (region.startsWith('us-iso-') && US_ISO_EXCEPTIONS.has(service)) {\n        switch (service) {\n          // Services with universal principal\n          case ('states'):\n            return universal;\n\n          // Services with a partitional principal\n          default:\n            return partitional;\n        }\n      }\n\n      // Exceptions for Service Principals in us-isob-*\n      const US_ISOB_EXCEPTIONS = new Set([\n        'dms',\n        'states',\n      ]);\n\n      // Account for idiosyncratic Service Principals in `us-isob-*` regions\n      if (region.startsWith('us-isob-') && US_ISOB_EXCEPTIONS.has(service)) {\n        switch (service) {\n          // Services with universal principal\n          case ('states'):\n            return universal;\n\n          // Services with a partitional principal\n          default:\n            return partitional;\n        }\n      }\n\n      switch (service) {\n        // SSM turned from global to regional at some point\n        case 'ssm':\n          return before(region, RULE_SSM_PRINCIPALS_ARE_REGIONAL)\n            ? universal\n            : regional;\n\n        // CodeDeploy is regional+partitional in CN, only regional everywhere else\n        case 'codedeploy':\n          return region.startsWith('cn-')\n            ? regionalPartitional\n            : regional;\n\n        // Services with a regional AND partitional principal\n        case 'logs':\n          return regionalPartitional;\n\n        // Services with a regional principal\n        case 'states':\n          return regional;\n\n        // Services with a partitional principal\n        case 'ec2':\n          return partitional;\n\n        // Services with a universal principal across all regions/partitions (the default case)\n        default:\n          return universal;\n\n      }\n    };\n\n    const configuration = determineConfiguration(serviceName);\n    return configuration(serviceName, region, urlSuffix);\n  }\n\n  private constructor() { }\n}\n\nfunction extractSimpleName(serviceFqn: string) {\n  const matches = serviceFqn.match(/^([^.]+)(?:(?:\\.amazonaws\\.com(?:\\.cn)?)|(?:\\.c2s\\.ic\\.gov)|(?:\\.sc2s\\.sgov\\.gov))?$/);\n  return matches ? matches[1] : undefined;\n}\n"]}
|
package/lib/fact.d.ts
CHANGED
|
@@ -1,50 +1,42 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* A database of regional information.
|
|
3
|
-
*
|
|
4
|
-
* @stability stable
|
|
5
3
|
*/
|
|
6
4
|
export declare class Fact {
|
|
7
5
|
/**
|
|
8
6
|
* @returns the list of names of AWS regions for which there is at least one registered fact. This
|
|
9
|
-
*
|
|
10
|
-
* @stability stable
|
|
7
|
+
* may not be an exhaustive list of all available AWS regions.
|
|
11
8
|
*/
|
|
12
9
|
static get regions(): string[];
|
|
13
10
|
/**
|
|
14
11
|
* Retrieves a fact from this Fact database.
|
|
15
12
|
*
|
|
16
|
-
* @param region the name of the region (e.g: `us-east-1`)
|
|
17
|
-
* @param name
|
|
13
|
+
* @param region the name of the region (e.g: `us-east-1`)
|
|
14
|
+
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
15
|
+
*
|
|
18
16
|
* @returns the fact value if it is known, and `undefined` otherwise.
|
|
19
|
-
* @stability stable
|
|
20
17
|
*/
|
|
21
18
|
static find(region: string, name: string): string | undefined;
|
|
22
19
|
/**
|
|
23
|
-
* Retrieve a fact from the Fact database.
|
|
24
|
-
*
|
|
25
|
-
* (retrieval will fail if the specified region or
|
|
20
|
+
* Retrieve a fact from the Fact database. (retrieval will fail if the specified region or
|
|
26
21
|
* fact name does not exist.)
|
|
27
22
|
*
|
|
28
|
-
* @param region the name of the region (e.g: `us-east-1`)
|
|
29
|
-
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
30
|
-
* @stability stable
|
|
23
|
+
* @param region the name of the region (e.g: `us-east-1`)
|
|
24
|
+
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
31
25
|
*/
|
|
32
26
|
static requireFact(region: string, name: string): string;
|
|
33
27
|
/**
|
|
34
28
|
* Registers a new fact in this Fact database.
|
|
35
29
|
*
|
|
36
|
-
* @param fact
|
|
30
|
+
* @param fact the new fact to be registered.
|
|
37
31
|
* @param allowReplacing whether new facts can replace existing facts or not.
|
|
38
|
-
* @stability stable
|
|
39
32
|
*/
|
|
40
33
|
static register(fact: IFact, allowReplacing?: boolean): void;
|
|
41
34
|
/**
|
|
42
35
|
* Removes a fact from the database.
|
|
43
|
-
*
|
|
44
36
|
* @param region the region for which the fact is to be removed.
|
|
45
|
-
* @param name
|
|
46
|
-
* @param value
|
|
47
|
-
*
|
|
37
|
+
* @param name the name of the fact to remove.
|
|
38
|
+
* @param value the value that should be removed (removal will fail if the value is specified, but does not match the
|
|
39
|
+
* current stored value).
|
|
48
40
|
*/
|
|
49
41
|
static unregister(region: string, name: string, value?: string): void;
|
|
50
42
|
private static readonly database;
|
|
@@ -52,117 +44,84 @@ export declare class Fact {
|
|
|
52
44
|
}
|
|
53
45
|
/**
|
|
54
46
|
* A fact that can be registered about a particular region.
|
|
55
|
-
*
|
|
56
|
-
* @stability stable
|
|
57
47
|
*/
|
|
58
48
|
export interface IFact {
|
|
59
49
|
/**
|
|
60
50
|
* The region for which this fact applies.
|
|
61
|
-
*
|
|
62
|
-
* @stability stable
|
|
63
51
|
*/
|
|
64
52
|
readonly region: string;
|
|
65
53
|
/**
|
|
66
|
-
* The name of this fact.
|
|
67
|
-
*
|
|
68
|
-
* Standardized values are provided by the `Facts` class.
|
|
69
|
-
*
|
|
70
|
-
* @stability stable
|
|
54
|
+
* The name of this fact. Standardized values are provided by the `Facts` class.
|
|
71
55
|
*/
|
|
72
56
|
readonly name: string;
|
|
73
57
|
/**
|
|
74
58
|
* The value of this fact.
|
|
75
|
-
*
|
|
76
|
-
* @stability stable
|
|
77
59
|
*/
|
|
78
60
|
readonly value: string | undefined;
|
|
79
61
|
}
|
|
80
62
|
/**
|
|
81
63
|
* All standardized fact names.
|
|
82
|
-
*
|
|
83
|
-
* @stability stable
|
|
84
64
|
*/
|
|
85
65
|
export declare class FactName {
|
|
86
66
|
/**
|
|
87
|
-
* The name of the partition for a region (e.g: 'aws', 'aws-cn', ...)
|
|
88
|
-
*
|
|
89
|
-
* @stability stable
|
|
67
|
+
* The name of the partition for a region (e.g: 'aws', 'aws-cn', ...)
|
|
90
68
|
*/
|
|
91
69
|
static readonly PARTITION = "partition";
|
|
92
70
|
/**
|
|
93
|
-
* The domain suffix for a region (e.g: 'amazonaws.com`)
|
|
94
|
-
*
|
|
95
|
-
* @stability stable
|
|
71
|
+
* The domain suffix for a region (e.g: 'amazonaws.com`)
|
|
96
72
|
*/
|
|
97
73
|
static readonly DOMAIN_SUFFIX = "domainSuffix";
|
|
98
74
|
/**
|
|
99
|
-
* Whether the AWS::CDK::Metadata CloudFormation Resource is available in-region or not.
|
|
100
|
-
*
|
|
101
|
-
* The value is a boolean
|
|
75
|
+
* Whether the AWS::CDK::Metadata CloudFormation Resource is available in-region or not. The value is a boolean
|
|
102
76
|
* modelled as `YES` or `NO`.
|
|
103
|
-
*
|
|
104
|
-
* @stability stable
|
|
105
77
|
*/
|
|
106
78
|
static readonly CDK_METADATA_RESOURCE_AVAILABLE = "cdk:metadata-resource:available";
|
|
107
79
|
/**
|
|
108
|
-
* The endpoint used for hosting S3 static websites
|
|
109
|
-
*
|
|
110
|
-
* @stability stable
|
|
80
|
+
* The endpoint used for hosting S3 static websites
|
|
111
81
|
*/
|
|
112
82
|
static readonly S3_STATIC_WEBSITE_ENDPOINT = "s3-static-website:endpoint";
|
|
113
83
|
/**
|
|
114
|
-
* The endpoint used for aliasing S3 static websites in Route 53
|
|
115
|
-
*
|
|
116
|
-
* @stability stable
|
|
84
|
+
* The endpoint used for aliasing S3 static websites in Route 53
|
|
117
85
|
*/
|
|
118
86
|
static readonly S3_STATIC_WEBSITE_ZONE_53_HOSTED_ZONE_ID = "s3-static-website:route-53-hosted-zone-id";
|
|
119
87
|
/**
|
|
120
|
-
* The hosted zone ID used by Route 53 to alias a EBS environment endpoint in this region (e.g: Z2O1EMRO9K5GLX)
|
|
121
|
-
*
|
|
122
|
-
* @stability stable
|
|
88
|
+
* The hosted zone ID used by Route 53 to alias a EBS environment endpoint in this region (e.g: Z2O1EMRO9K5GLX)
|
|
123
89
|
*/
|
|
124
90
|
static readonly EBS_ENV_ENDPOINT_HOSTED_ZONE_ID = "ebs-environment:route-53-hosted-zone-id";
|
|
125
91
|
/**
|
|
126
|
-
* The prefix for VPC Endpoint Service names,
|
|
127
|
-
*
|
|
128
|
-
*
|
|
92
|
+
* The prefix for VPC Endpoint Service names,
|
|
93
|
+
* cn.com.amazonaws.vpce for China regions,
|
|
94
|
+
* com.amazonaws.vpce otherwise.
|
|
129
95
|
*/
|
|
130
96
|
static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = "vpcEndpointServiceNamePrefix";
|
|
131
97
|
/**
|
|
132
|
-
* The account for ELBv2 in this region
|
|
133
|
-
*
|
|
134
|
-
* @stability stable
|
|
98
|
+
* The account for ELBv2 in this region
|
|
135
99
|
*/
|
|
136
100
|
static readonly ELBV2_ACCOUNT = "elbv2Account";
|
|
137
101
|
/**
|
|
138
|
-
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
139
|
-
*
|
|
140
|
-
* @stability stable
|
|
102
|
+
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
103
|
+
* AWS Deep Learning Containers images in a given region.
|
|
141
104
|
*/
|
|
142
105
|
static readonly DLC_REPOSITORY_ACCOUNT = "dlcRepositoryAccount";
|
|
143
106
|
/**
|
|
144
|
-
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
145
|
-
*
|
|
146
|
-
* @stability stable
|
|
107
|
+
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
108
|
+
* AWS App Mesh Envoy Proxy images in a given region.
|
|
147
109
|
*/
|
|
148
110
|
static readonly APPMESH_ECR_ACCOUNT = "appMeshRepositoryAccount";
|
|
149
111
|
/**
|
|
150
112
|
* The CIDR block used by Kinesis Data Firehose servers.
|
|
151
|
-
*
|
|
152
|
-
* @stability stable
|
|
153
113
|
*/
|
|
154
114
|
static readonly FIREHOSE_CIDR_BLOCK = "firehoseCidrBlock";
|
|
155
115
|
/**
|
|
156
|
-
* The ARN of CloudWatch Lambda Insights for a version (e.g. 1.0.98.0)
|
|
157
|
-
*
|
|
158
|
-
* @stability stable
|
|
116
|
+
* The ARN of CloudWatch Lambda Insights for a version (e.g. 1.0.98.0)
|
|
159
117
|
*/
|
|
160
118
|
static cloudwatchLambdaInsightsVersion(version: string, arch?: string): string;
|
|
161
119
|
/**
|
|
162
120
|
* The name of the regional service principal for a given service.
|
|
163
121
|
*
|
|
164
|
-
* @param service the service name, either simple (e.g: `s3`, `codedeploy`) or qualified (e.g: `s3.amazonaws.com`).
|
|
165
|
-
*
|
|
122
|
+
* @param service the service name, either simple (e.g: `s3`, `codedeploy`) or qualified (e.g: `s3.amazonaws.com`).
|
|
123
|
+
* The `.amazonaws.com` and `.amazonaws.com.cn` domains are stripped from service names, so they are
|
|
124
|
+
* canonicalized in that respect.
|
|
166
125
|
*/
|
|
167
126
|
static servicePrincipal(service: string): string;
|
|
168
127
|
}
|
package/lib/fact.js
CHANGED
|
@@ -7,8 +7,6 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
7
7
|
const aws_entities_1 = require("./aws-entities");
|
|
8
8
|
/**
|
|
9
9
|
* A database of regional information.
|
|
10
|
-
*
|
|
11
|
-
* @stability stable
|
|
12
10
|
*/
|
|
13
11
|
class Fact {
|
|
14
12
|
constructor() {
|
|
@@ -16,8 +14,7 @@ class Fact {
|
|
|
16
14
|
}
|
|
17
15
|
/**
|
|
18
16
|
* @returns the list of names of AWS regions for which there is at least one registered fact. This
|
|
19
|
-
*
|
|
20
|
-
* @stability stable
|
|
17
|
+
* may not be an exhaustive list of all available AWS regions.
|
|
21
18
|
*/
|
|
22
19
|
static get regions() {
|
|
23
20
|
// Return by copy to ensure no modifications can be made to the undelying constant.
|
|
@@ -26,24 +23,21 @@ class Fact {
|
|
|
26
23
|
/**
|
|
27
24
|
* Retrieves a fact from this Fact database.
|
|
28
25
|
*
|
|
29
|
-
* @param region the name of the region (e.g: `us-east-1`)
|
|
30
|
-
* @param name
|
|
26
|
+
* @param region the name of the region (e.g: `us-east-1`)
|
|
27
|
+
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
28
|
+
*
|
|
31
29
|
* @returns the fact value if it is known, and `undefined` otherwise.
|
|
32
|
-
* @stability stable
|
|
33
30
|
*/
|
|
34
31
|
static find(region, name) {
|
|
35
32
|
const regionFacts = this.database[region];
|
|
36
33
|
return regionFacts && regionFacts[name];
|
|
37
34
|
}
|
|
38
35
|
/**
|
|
39
|
-
* Retrieve a fact from the Fact database.
|
|
40
|
-
*
|
|
41
|
-
* (retrieval will fail if the specified region or
|
|
36
|
+
* Retrieve a fact from the Fact database. (retrieval will fail if the specified region or
|
|
42
37
|
* fact name does not exist.)
|
|
43
38
|
*
|
|
44
|
-
* @param region the name of the region (e.g: `us-east-1`)
|
|
45
|
-
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
46
|
-
* @stability stable
|
|
39
|
+
* @param region the name of the region (e.g: `us-east-1`)
|
|
40
|
+
* @param name the name of the fact being looked up (see the `FactName` class for details)
|
|
47
41
|
*/
|
|
48
42
|
static requireFact(region, name) {
|
|
49
43
|
const foundFact = this.find(region, name);
|
|
@@ -55,9 +49,8 @@ class Fact {
|
|
|
55
49
|
/**
|
|
56
50
|
* Registers a new fact in this Fact database.
|
|
57
51
|
*
|
|
58
|
-
* @param fact
|
|
52
|
+
* @param fact the new fact to be registered.
|
|
59
53
|
* @param allowReplacing whether new facts can replace existing facts or not.
|
|
60
|
-
* @stability stable
|
|
61
54
|
*/
|
|
62
55
|
static register(fact, allowReplacing = false) {
|
|
63
56
|
jsiiDeprecationWarnings._aws_cdk_region_info_IFact(fact);
|
|
@@ -71,11 +64,10 @@ class Fact {
|
|
|
71
64
|
}
|
|
72
65
|
/**
|
|
73
66
|
* Removes a fact from the database.
|
|
74
|
-
*
|
|
75
67
|
* @param region the region for which the fact is to be removed.
|
|
76
|
-
* @param name
|
|
77
|
-
* @param value
|
|
78
|
-
*
|
|
68
|
+
* @param name the name of the fact to remove.
|
|
69
|
+
* @param value the value that should be removed (removal will fail if the value is specified, but does not match the
|
|
70
|
+
* current stored value).
|
|
79
71
|
*/
|
|
80
72
|
static unregister(region, name, value) {
|
|
81
73
|
const regionFacts = this.database[region] || {};
|
|
@@ -87,18 +79,14 @@ class Fact {
|
|
|
87
79
|
}
|
|
88
80
|
exports.Fact = Fact;
|
|
89
81
|
_a = JSII_RTTI_SYMBOL_1;
|
|
90
|
-
Fact[_a] = { fqn: "@aws-cdk/region-info.Fact", version: "2.
|
|
82
|
+
Fact[_a] = { fqn: "@aws-cdk/region-info.Fact", version: "2.13.0" };
|
|
91
83
|
Fact.database = {};
|
|
92
84
|
/**
|
|
93
85
|
* All standardized fact names.
|
|
94
|
-
*
|
|
95
|
-
* @stability stable
|
|
96
86
|
*/
|
|
97
87
|
class FactName {
|
|
98
88
|
/**
|
|
99
|
-
* The ARN of CloudWatch Lambda Insights for a version (e.g. 1.0.98.0)
|
|
100
|
-
*
|
|
101
|
-
* @stability stable
|
|
89
|
+
* The ARN of CloudWatch Lambda Insights for a version (e.g. 1.0.98.0)
|
|
102
90
|
*/
|
|
103
91
|
static cloudwatchLambdaInsightsVersion(version, arch) {
|
|
104
92
|
// if we are provided an architecture use that, otherwise
|
|
@@ -109,8 +97,9 @@ class FactName {
|
|
|
109
97
|
/**
|
|
110
98
|
* The name of the regional service principal for a given service.
|
|
111
99
|
*
|
|
112
|
-
* @param service the service name, either simple (e.g: `s3`, `codedeploy`) or qualified (e.g: `s3.amazonaws.com`).
|
|
113
|
-
*
|
|
100
|
+
* @param service the service name, either simple (e.g: `s3`, `codedeploy`) or qualified (e.g: `s3.amazonaws.com`).
|
|
101
|
+
* The `.amazonaws.com` and `.amazonaws.com.cn` domains are stripped from service names, so they are
|
|
102
|
+
* canonicalized in that respect.
|
|
114
103
|
*/
|
|
115
104
|
static servicePrincipal(service) {
|
|
116
105
|
return `service-principal:${service.replace(/\.amazonaws\.com(\.cn)?$/, '')}`;
|
|
@@ -118,74 +107,54 @@ class FactName {
|
|
|
118
107
|
}
|
|
119
108
|
exports.FactName = FactName;
|
|
120
109
|
_b = JSII_RTTI_SYMBOL_1;
|
|
121
|
-
FactName[_b] = { fqn: "@aws-cdk/region-info.FactName", version: "2.
|
|
110
|
+
FactName[_b] = { fqn: "@aws-cdk/region-info.FactName", version: "2.13.0" };
|
|
122
111
|
/**
|
|
123
|
-
* The name of the partition for a region (e.g: 'aws', 'aws-cn', ...)
|
|
124
|
-
*
|
|
125
|
-
* @stability stable
|
|
112
|
+
* The name of the partition for a region (e.g: 'aws', 'aws-cn', ...)
|
|
126
113
|
*/
|
|
127
114
|
FactName.PARTITION = 'partition';
|
|
128
115
|
/**
|
|
129
|
-
* The domain suffix for a region (e.g: 'amazonaws.com`)
|
|
130
|
-
*
|
|
131
|
-
* @stability stable
|
|
116
|
+
* The domain suffix for a region (e.g: 'amazonaws.com`)
|
|
132
117
|
*/
|
|
133
118
|
FactName.DOMAIN_SUFFIX = 'domainSuffix';
|
|
134
119
|
/**
|
|
135
|
-
* Whether the AWS::CDK::Metadata CloudFormation Resource is available in-region or not.
|
|
136
|
-
*
|
|
137
|
-
* The value is a boolean
|
|
120
|
+
* Whether the AWS::CDK::Metadata CloudFormation Resource is available in-region or not. The value is a boolean
|
|
138
121
|
* modelled as `YES` or `NO`.
|
|
139
|
-
*
|
|
140
|
-
* @stability stable
|
|
141
122
|
*/
|
|
142
123
|
FactName.CDK_METADATA_RESOURCE_AVAILABLE = 'cdk:metadata-resource:available';
|
|
143
124
|
/**
|
|
144
|
-
* The endpoint used for hosting S3 static websites
|
|
145
|
-
*
|
|
146
|
-
* @stability stable
|
|
125
|
+
* The endpoint used for hosting S3 static websites
|
|
147
126
|
*/
|
|
148
127
|
FactName.S3_STATIC_WEBSITE_ENDPOINT = 's3-static-website:endpoint';
|
|
149
128
|
/**
|
|
150
|
-
* The endpoint used for aliasing S3 static websites in Route 53
|
|
151
|
-
*
|
|
152
|
-
* @stability stable
|
|
129
|
+
* The endpoint used for aliasing S3 static websites in Route 53
|
|
153
130
|
*/
|
|
154
131
|
FactName.S3_STATIC_WEBSITE_ZONE_53_HOSTED_ZONE_ID = 's3-static-website:route-53-hosted-zone-id';
|
|
155
132
|
/**
|
|
156
|
-
* The hosted zone ID used by Route 53 to alias a EBS environment endpoint in this region (e.g: Z2O1EMRO9K5GLX)
|
|
157
|
-
*
|
|
158
|
-
* @stability stable
|
|
133
|
+
* The hosted zone ID used by Route 53 to alias a EBS environment endpoint in this region (e.g: Z2O1EMRO9K5GLX)
|
|
159
134
|
*/
|
|
160
135
|
FactName.EBS_ENV_ENDPOINT_HOSTED_ZONE_ID = 'ebs-environment:route-53-hosted-zone-id';
|
|
161
136
|
/**
|
|
162
|
-
* The prefix for VPC Endpoint Service names,
|
|
163
|
-
*
|
|
164
|
-
*
|
|
137
|
+
* The prefix for VPC Endpoint Service names,
|
|
138
|
+
* cn.com.amazonaws.vpce for China regions,
|
|
139
|
+
* com.amazonaws.vpce otherwise.
|
|
165
140
|
*/
|
|
166
141
|
FactName.VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'vpcEndpointServiceNamePrefix';
|
|
167
142
|
/**
|
|
168
|
-
* The account for ELBv2 in this region
|
|
169
|
-
*
|
|
170
|
-
* @stability stable
|
|
143
|
+
* The account for ELBv2 in this region
|
|
171
144
|
*/
|
|
172
145
|
FactName.ELBV2_ACCOUNT = 'elbv2Account';
|
|
173
146
|
/**
|
|
174
|
-
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
175
|
-
*
|
|
176
|
-
* @stability stable
|
|
147
|
+
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
148
|
+
* AWS Deep Learning Containers images in a given region.
|
|
177
149
|
*/
|
|
178
150
|
FactName.DLC_REPOSITORY_ACCOUNT = 'dlcRepositoryAccount';
|
|
179
151
|
/**
|
|
180
|
-
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
181
|
-
*
|
|
182
|
-
* @stability stable
|
|
152
|
+
* The ID of the AWS account that owns the public ECR repository that contains the
|
|
153
|
+
* AWS App Mesh Envoy Proxy images in a given region.
|
|
183
154
|
*/
|
|
184
155
|
FactName.APPMESH_ECR_ACCOUNT = 'appMeshRepositoryAccount';
|
|
185
156
|
/**
|
|
186
157
|
* The CIDR block used by Kinesis Data Firehose servers.
|
|
187
|
-
*
|
|
188
|
-
* @stability stable
|
|
189
158
|
*/
|
|
190
159
|
FactName.FIREHOSE_CIDR_BLOCK = 'firehoseCidrBlock';
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fact.js","sourceRoot":"","sources":["fact.ts"],"names":[],"mappings":"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","sourcesContent":["import { AWS_REGIONS } from './aws-entities';\n\n                                              \nexport class Fact {\n                                                                                                                                                                                          \n  public static get regions(): string[] {\n    // Return by copy to ensure no modifications can be made to the undelying constant.\n    return Array.from(AWS_REGIONS);\n  }\n\n                                                                                                                                                                                                                                                                                                        \n  public static find(region: string, name: string): string | undefined {\n    const regionFacts = this.database[region];\n    return regionFacts && regionFacts[name];\n  }\n\n                                                                                                                                                                                                                                                                                                       \n  public static requireFact(region: string, name: string): string {\n    const foundFact = this.find(region, name);\n\n    if (!foundFact) {\n      throw new Error(`No fact ${name} could be found for region: ${region} and name: ${name}`);\n    }\n\n    return foundFact;\n  }\n\n                                                                                                                                                                                                           \n  public static register(fact: IFact, allowReplacing = false): void {\n    const regionFacts = this.database[fact.region] || (this.database[fact.region] = {});\n    if (fact.name in regionFacts && regionFacts[fact.name] !== fact.value && !allowReplacing) {\n      throw new Error(`Region ${fact.region} already has a fact ${fact.name}, with value ${regionFacts[fact.name]}`);\n    }\n    if (fact.value !== undefined) {\n      regionFacts[fact.name] = fact.value;\n    }\n  }\n\n                                                                                                                                                                                                                                                                                                                                           \n  public static unregister(region: string, name: string, value?: string): void {\n    const regionFacts = this.database[region] || {};\n    if (name in regionFacts && value && regionFacts[name] !== value) {\n      throw new Error(`Attempted to remove ${name} from ${region} with value ${value}, but the fact's value is ${regionFacts[name]}`);\n    }\n    delete regionFacts[name];\n  }\n\n  private static readonly database: { [region: string]: { [name: string]: string } } = {};\n\n  private constructor() {\n    throw new Error('Use the static methods of Fact instead!');\n  }\n}\n\n                                                                   \nexport interface IFact {\n                                                        \n  readonly region: string;\n\n                                                                                              \n  readonly name: string;\n\n                                        \n  readonly value: string | undefined;\n}\n\n                                       \nexport class FactName {\n                                                                                   \n  public static readonly PARTITION = 'partition';\n\n                                                                      \n  public static readonly DOMAIN_SUFFIX = 'domainSuffix';\n\n                                                                                                                                                             \n  public static readonly CDK_METADATA_RESOURCE_AVAILABLE = 'cdk:metadata-resource:available';\n\n                                                                 \n  public static readonly S3_STATIC_WEBSITE_ENDPOINT = 's3-static-website:endpoint';\n\n                                                                              \n  public static readonly S3_STATIC_WEBSITE_ZONE_53_HOSTED_ZONE_ID = 's3-static-website:route-53-hosted-zone-id';\n\n                                                                                                                             \n  public static readonly EBS_ENV_ENDPOINT_HOSTED_ZONE_ID = 'ebs-environment:route-53-hosted-zone-id';\n\n                                                                                                                                            \n  public static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'vpcEndpointServiceNamePrefix';\n\n                                                     \n  public static readonly ELBV2_ACCOUNT = 'elbv2Account';\n\n                                                                                                                                                            \n  public static readonly DLC_REPOSITORY_ACCOUNT = 'dlcRepositoryAccount';\n\n                                                                                                                                                        \n  public static readonly APPMESH_ECR_ACCOUNT = 'appMeshRepositoryAccount';\n\n                                                                      \n  public static readonly FIREHOSE_CIDR_BLOCK = 'firehoseCidrBlock';\n\n                                                                                    \n  public static cloudwatchLambdaInsightsVersion(version: string, arch?: string) {\n    // if we are provided an architecture use that, otherwise\n    // default to x86_64 for backwards compatibility\n    const suffix = version.split('.').join('_') + `_${arch ?? 'x86_64'}`;\n    return `cloudwatch-lambda-insights-version:${suffix}`;\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                    \n  public static servicePrincipal(service: string) {\n    return `service-principal:${service.replace(/\\.amazonaws\\.com(\\.cn)?$/, '')}`;\n  }\n}\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fact.js","sourceRoot":"","sources":["fact.ts"],"names":[],"mappings":"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","sourcesContent":["import { AWS_REGIONS } from './aws-entities';\n\n/**\n * A database of regional information.\n */\nexport class Fact {\n  /**\n   * @returns the list of names of AWS regions for which there is at least one registered fact. This\n   *          may not be an exhaustive list of all available AWS regions.\n   */\n  public static get regions(): string[] {\n    // Return by copy to ensure no modifications can be made to the undelying constant.\n    return Array.from(AWS_REGIONS);\n  }\n\n  /**\n   * Retrieves a fact from this Fact database.\n   *\n   * @param region the name of the region (e.g: `us-east-1`)\n   * @param name   the name of the fact being looked up (see the `FactName` class for details)\n   *\n   * @returns the fact value if it is known, and `undefined` otherwise.\n   */\n  public static find(region: string, name: string): string | undefined {\n    const regionFacts = this.database[region];\n    return regionFacts && regionFacts[name];\n  }\n\n  /**\n   * Retrieve a fact from the Fact database. (retrieval will fail if the specified region or\n   * fact name does not exist.)\n   *\n   * @param region the name of the region (e.g: `us-east-1`)\n   * @param name the name of the fact being looked up (see the `FactName` class for details)\n   */\n  public static requireFact(region: string, name: string): string {\n    const foundFact = this.find(region, name);\n\n    if (!foundFact) {\n      throw new Error(`No fact ${name} could be found for region: ${region} and name: ${name}`);\n    }\n\n    return foundFact;\n  }\n\n  /**\n   * Registers a new fact in this Fact database.\n   *\n   * @param fact           the new fact to be registered.\n   * @param allowReplacing whether new facts can replace existing facts or not.\n   */\n  public static register(fact: IFact, allowReplacing = false): void {\n    const regionFacts = this.database[fact.region] || (this.database[fact.region] = {});\n    if (fact.name in regionFacts && regionFacts[fact.name] !== fact.value && !allowReplacing) {\n      throw new Error(`Region ${fact.region} already has a fact ${fact.name}, with value ${regionFacts[fact.name]}`);\n    }\n    if (fact.value !== undefined) {\n      regionFacts[fact.name] = fact.value;\n    }\n  }\n\n  /**\n   * Removes a fact from the database.\n   * @param region the region for which the fact is to be removed.\n   * @param name   the name of the fact to remove.\n   * @param value  the value that should be removed (removal will fail if the value is specified, but does not match the\n   *               current stored value).\n   */\n  public static unregister(region: string, name: string, value?: string): void {\n    const regionFacts = this.database[region] || {};\n    if (name in regionFacts && value && regionFacts[name] !== value) {\n      throw new Error(`Attempted to remove ${name} from ${region} with value ${value}, but the fact's value is ${regionFacts[name]}`);\n    }\n    delete regionFacts[name];\n  }\n\n  private static readonly database: { [region: string]: { [name: string]: string } } = {};\n\n  private constructor() {\n    throw new Error('Use the static methods of Fact instead!');\n  }\n}\n\n/**\n * A fact that can be registered about a particular region.\n */\nexport interface IFact {\n  /**\n   * The region for which this fact applies.\n   */\n  readonly region: string;\n\n  /**\n   * The name of this fact. Standardized values are provided by the `Facts` class.\n   */\n  readonly name: string;\n\n  /**\n   * The value of this fact.\n   */\n  readonly value: string | undefined;\n}\n\n/**\n * All standardized fact names.\n */\nexport class FactName {\n  /**\n   * The name of the partition for a region (e.g: 'aws', 'aws-cn', ...)\n   */\n  public static readonly PARTITION = 'partition';\n\n  /**\n   * The domain suffix for a region (e.g: 'amazonaws.com`)\n   */\n  public static readonly DOMAIN_SUFFIX = 'domainSuffix';\n\n  /**\n   * Whether the AWS::CDK::Metadata CloudFormation Resource is available in-region or not. The value is a boolean\n   * modelled as `YES` or `NO`.\n   */\n  public static readonly CDK_METADATA_RESOURCE_AVAILABLE = 'cdk:metadata-resource:available';\n\n  /**\n   * The endpoint used for hosting S3 static websites\n   */\n  public static readonly S3_STATIC_WEBSITE_ENDPOINT = 's3-static-website:endpoint';\n\n  /**\n   * The endpoint used for aliasing S3 static websites in Route 53\n   */\n  public static readonly S3_STATIC_WEBSITE_ZONE_53_HOSTED_ZONE_ID = 's3-static-website:route-53-hosted-zone-id';\n\n  /**\n   * The hosted zone ID used by Route 53 to alias a EBS environment endpoint in this region (e.g: Z2O1EMRO9K5GLX)\n   */\n  public static readonly EBS_ENV_ENDPOINT_HOSTED_ZONE_ID = 'ebs-environment:route-53-hosted-zone-id';\n\n  /**\n   * The prefix for VPC Endpoint Service names,\n   * cn.com.amazonaws.vpce for China regions,\n   * com.amazonaws.vpce otherwise.\n   */\n  public static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'vpcEndpointServiceNamePrefix';\n\n  /**\n   * The account for ELBv2 in this region\n   */\n  public static readonly ELBV2_ACCOUNT = 'elbv2Account';\n\n  /**\n   * The ID of the AWS account that owns the public ECR repository that contains the\n   * AWS Deep Learning Containers images in a given region.\n   */\n  public static readonly DLC_REPOSITORY_ACCOUNT = 'dlcRepositoryAccount';\n\n  /**\n   * The ID of the AWS account that owns the public ECR repository that contains the\n   * AWS App Mesh Envoy Proxy images in a given region.\n   */\n  public static readonly APPMESH_ECR_ACCOUNT = 'appMeshRepositoryAccount';\n\n  /**\n   * The CIDR block used by Kinesis Data Firehose servers.\n   */\n  public static readonly FIREHOSE_CIDR_BLOCK = 'firehoseCidrBlock';\n\n  /**\n   * The ARN of CloudWatch Lambda Insights for a version (e.g. 1.0.98.0)\n   */\n  public static cloudwatchLambdaInsightsVersion(version: string, arch?: string) {\n    // if we are provided an architecture use that, otherwise\n    // default to x86_64 for backwards compatibility\n    const suffix = version.split('.').join('_') + `_${arch ?? 'x86_64'}`;\n    return `cloudwatch-lambda-insights-version:${suffix}`;\n  }\n\n  /**\n   * The name of the regional service principal for a given service.\n   *\n   * @param service the service name, either simple (e.g: `s3`, `codedeploy`) or qualified (e.g: `s3.amazonaws.com`).\n   *                The `.amazonaws.com` and `.amazonaws.com.cn` domains are stripped from service names, so they are\n   *                canonicalized in that respect.\n   */\n  public static servicePrincipal(service: string) {\n    return `service-principal:${service.replace(/\\.amazonaws\\.com(\\.cn)?$/, '')}`;\n  }\n}\n"]}
|