@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/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 not have a synthesize-time region literal available (all you have is `{ "Ref": "AWS::Region" }`).
9
- *
10
- * @stability stable
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 the region in which the service principal is needed.
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 the region in which the service principal is needed.
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.12.0" };
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 not have a synthesize-time region literal available (all you have is `{ "Ref": "AWS::Region" }`).
116
- *
117
- * @stability stable
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,{"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                                                                           \nexport class Default {\n\n                                                                                                                                                                                                      \n  public static readonly VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'com.amazonaws.vpce';\n\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"]}
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
- * may not be an exhaustive list of all available AWS regions.
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 the name of the fact being looked up (see the `FactName` class for details).
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 the new fact to be registered.
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 the name of the fact to remove.
46
- * @param value the value that should be removed (removal will fail if the value is specified, but does not match the current stored value).
47
- * @stability stable
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, cn.com.amazonaws.vpce for China regions, com.amazonaws.vpce otherwise.
127
- *
128
- * @stability stable
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 AWS Deep Learning Containers images in a given region.
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 AWS App Mesh Envoy Proxy images in a given region.
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`). The `.amazonaws.com` and `.amazonaws.com.cn` domains are stripped from service names, so they are canonicalized in that respect.
165
- * @stability stable
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
- * may not be an exhaustive list of all available AWS regions.
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 the name of the fact being looked up (see the `FactName` class for details).
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 the new fact to be registered.
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 the name of the fact to remove.
77
- * @param value the value that should be removed (removal will fail if the value is specified, but does not match the current stored value).
78
- * @stability stable
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.12.0" };
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`). The `.amazonaws.com` and `.amazonaws.com.cn` domains are stripped from service names, so they are canonicalized in that respect.
113
- * @stability stable
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.12.0" };
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, cn.com.amazonaws.vpce for China regions, com.amazonaws.vpce otherwise.
163
- *
164
- * @stability stable
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 AWS Deep Learning Containers images in a given region.
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 AWS App Mesh Envoy Proxy images in a given region.
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"]}