@aws-cdk/region-info 2.9.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,27 +6,22 @@ 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
- const service = extractSimpleName(serviceFqn);
29
- if (!service) {
23
+ const serviceName = extractSimpleName(serviceFqn);
24
+ if (!serviceName) {
30
25
  // Return "service" if it does not look like any of the following:
31
26
  // - s3
32
27
  // - s3.amazonaws.com
@@ -35,74 +30,90 @@ class Default {
35
30
  // - s3.sc2s.sgov.gov
36
31
  return serviceFqn;
37
32
  }
38
- // Exceptions for Service Principals in us-iso-*
39
- const US_ISO_EXCEPTIONS = new Set([
40
- 'cloudhsm',
41
- 'config',
42
- 'states',
43
- 'workspaces',
44
- ]);
45
- // Account for idiosyncratic Service Principals in `us-iso-*` regions
46
- if (region.startsWith('us-iso-') && US_ISO_EXCEPTIONS.has(service)) {
47
- switch (service) {
48
- // Services with universal principal
49
- case ('states'):
50
- return `${service}.amazonaws.com`;
51
- // Services with a partitional principal
52
- default:
53
- return `${service}.${urlSuffix}`;
33
+ function determineConfiguration(service) {
34
+ function universal(s) { return `${s}.amazonaws.com`; }
35
+ ;
36
+ function partitional(s, _, u) { return `${s}.${u}`; }
37
+ ;
38
+ function regional(s, r) { return `${s}.${r}.amazonaws.com`; }
39
+ ;
40
+ function regionalPartitional(s, r, u) { return `${s}.${r}.${u}`; }
41
+ ;
42
+ // Exceptions for Service Principals in us-iso-*
43
+ const US_ISO_EXCEPTIONS = new Set([
44
+ 'cloudhsm',
45
+ 'config',
46
+ 'states',
47
+ 'workspaces',
48
+ ]);
49
+ // Account for idiosyncratic Service Principals in `us-iso-*` regions
50
+ if (region.startsWith('us-iso-') && US_ISO_EXCEPTIONS.has(service)) {
51
+ switch (service) {
52
+ // Services with universal principal
53
+ case ('states'):
54
+ return universal;
55
+ // Services with a partitional principal
56
+ default:
57
+ return partitional;
58
+ }
59
+ }
60
+ // Exceptions for Service Principals in us-isob-*
61
+ const US_ISOB_EXCEPTIONS = new Set([
62
+ 'dms',
63
+ 'states',
64
+ ]);
65
+ // Account for idiosyncratic Service Principals in `us-isob-*` regions
66
+ if (region.startsWith('us-isob-') && US_ISOB_EXCEPTIONS.has(service)) {
67
+ switch (service) {
68
+ // Services with universal principal
69
+ case ('states'):
70
+ return universal;
71
+ // Services with a partitional principal
72
+ default:
73
+ return partitional;
74
+ }
54
75
  }
55
- }
56
- // Exceptions for Service Principals in us-isob-*
57
- const US_ISOB_EXCEPTIONS = new Set([
58
- 'dms',
59
- 'states',
60
- ]);
61
- // Account for idiosyncratic Service Principals in `us-isob-*` regions
62
- if (region.startsWith('us-isob-') && US_ISOB_EXCEPTIONS.has(service)) {
63
76
  switch (service) {
64
- // Services with universal principal
65
- case ('states'):
66
- return `${service}.amazonaws.com`;
77
+ // SSM turned from global to regional at some point
78
+ case 'ssm':
79
+ return aws_entities_1.before(region, aws_entities_1.RULE_SSM_PRINCIPALS_ARE_REGIONAL)
80
+ ? universal
81
+ : regional;
82
+ // CodeDeploy is regional+partitional in CN, only regional everywhere else
83
+ case 'codedeploy':
84
+ return region.startsWith('cn-')
85
+ ? regionalPartitional
86
+ : regional;
87
+ // Services with a regional AND partitional principal
88
+ case 'logs':
89
+ return regionalPartitional;
90
+ // Services with a regional principal
91
+ case 'states':
92
+ return regional;
67
93
  // Services with a partitional principal
94
+ case 'ec2':
95
+ return partitional;
96
+ // Services with a universal principal across all regions/partitions (the default case)
68
97
  default:
69
- return `${service}.${urlSuffix}`;
98
+ return universal;
70
99
  }
71
100
  }
72
- // SSM turned from global to regional at some point
73
- if (service === 'ssm') {
74
- return aws_entities_1.before(region, aws_entities_1.RULE_SSM_PRINCIPALS_ARE_REGIONAL)
75
- ? `${service}.amazonaws.com`
76
- : `${service}.${region}.amazonaws.com`;
77
- }
78
- switch (service) {
79
- // Services with a regional AND partitional principal
80
- case 'codedeploy':
81
- case 'logs':
82
- return `${service}.${region}.${urlSuffix}`;
83
- // Services with a regional principal
84
- case 'states':
85
- return `${service}.${region}.amazonaws.com`;
86
- // Services with a partitional principal
87
- case 'ec2':
88
- return `${service}.${urlSuffix}`;
89
- // Services with a universal principal across all regions/partitions (the default case)
90
- default:
91
- return `${service}.amazonaws.com`;
92
- }
101
+ ;
102
+ const configuration = determineConfiguration(serviceName);
103
+ return configuration(serviceName, region, urlSuffix);
93
104
  }
94
105
  }
95
106
  exports.Default = Default;
96
107
  _a = JSII_RTTI_SYMBOL_1;
97
- Default[_a] = { fqn: "@aws-cdk/region-info.Default", version: "2.9.0" };
108
+ Default[_a] = { fqn: "@aws-cdk/region-info.Default", version: "2.13.0" };
98
109
  /**
99
- * 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" }`).
100
- *
101
- * @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" }`)
102
113
  */
103
114
  Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX = 'com.amazonaws.vpce';
104
115
  function extractSimpleName(serviceFqn) {
105
116
  const matches = serviceFqn.match(/^([^.]+)(?:(?:\.amazonaws\.com(?:\.cn)?)|(?:\.c2s\.ic\.gov)|(?:\.sc2s\.sgov\.gov))?$/);
106
117
  return matches ? matches[1] : undefined;
107
118
  }
108
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRlZmF1bHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpREFBMEU7Ozs7OztBQUcxRSxNQUFhLE9BQU87SUFzRmxCLGlCQUF5Qjs7Ozs7Ozs7Ozs7Ozs7SUFoRmxCLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFrQixFQUFFLE1BQWMsRUFBRSxTQUFpQjtRQUNsRixNQUFNLE9BQU8sR0FBRyxpQkFBaUIsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ1osa0VBQWtFO1lBQ2xFLE9BQU87WUFDUCxxQkFBcUI7WUFDckIsd0JBQXdCO1lBQ3hCLGtCQUFrQjtZQUNsQixxQkFBcUI7WUFDckIsT0FBTyxVQUFVLENBQUM7U0FDbkI7UUFFRCxnREFBZ0Q7UUFDaEQsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLEdBQUcsQ0FBQztZQUNoQyxVQUFVO1lBQ1YsUUFBUTtZQUNSLFFBQVE7WUFDUixZQUFZO1NBQ2IsQ0FBQyxDQUFDO1FBRUgscUVBQXFFO1FBQ3JFLElBQUksTUFBTSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsSUFBSSxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDbEUsUUFBUSxPQUFPLEVBQUU7Z0JBQ2Ysb0NBQW9DO2dCQUNwQyxLQUFLLENBQUMsUUFBUSxDQUFDO29CQUNiLE9BQU8sR0FBRyxPQUFPLGdCQUFnQixDQUFDO2dCQUVwQyx3Q0FBd0M7Z0JBQ3hDO29CQUNFLE9BQU8sR0FBRyxPQUFPLElBQUksU0FBUyxFQUFFLENBQUM7YUFDcEM7U0FDRjtRQUVELGlEQUFpRDtRQUNqRCxNQUFNLGtCQUFrQixHQUFHLElBQUksR0FBRyxDQUFDO1lBQ2pDLEtBQUs7WUFDTCxRQUFRO1NBQ1QsQ0FBQyxDQUFDO1FBRUgsc0VBQXNFO1FBQ3RFLElBQUksTUFBTSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDcEUsUUFBUSxPQUFPLEVBQUU7Z0JBQ2Ysb0NBQW9DO2dCQUNwQyxLQUFLLENBQUMsUUFBUSxDQUFDO29CQUNiLE9BQU8sR0FBRyxPQUFPLGdCQUFnQixDQUFDO2dCQUVwQyx3Q0FBd0M7Z0JBQ3hDO29CQUNFLE9BQU8sR0FBRyxPQUFPLElBQUksU0FBUyxFQUFFLENBQUM7YUFDcEM7U0FDRjtRQUVELG1EQUFtRDtRQUNuRCxJQUFJLE9BQU8sS0FBSyxLQUFLLEVBQUU7WUFDckIsT0FBTyxxQkFBTSxDQUFDLE1BQU0sRUFBRSwrQ0FBZ0MsQ0FBQztnQkFDckQsQ0FBQyxDQUFDLEdBQUcsT0FBTyxnQkFBZ0I7Z0JBQzVCLENBQUMsQ0FBQyxHQUFHLE9BQU8sSUFBSSxNQUFNLGdCQUFnQixDQUFDO1NBQzFDO1FBRUQsUUFBUSxPQUFPLEVBQUU7WUFDZixxREFBcUQ7WUFDckQsS0FBSyxZQUFZLENBQUM7WUFDbEIsS0FBSyxNQUFNO2dCQUNULE9BQU8sR0FBRyxPQUFPLElBQUksTUFBTSxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBRTdDLHFDQUFxQztZQUNyQyxLQUFLLFFBQVE7Z0JBQ1gsT0FBTyxHQUFHLE9BQU8sSUFBSSxNQUFNLGdCQUFnQixDQUFDO1lBRTlDLHdDQUF3QztZQUN4QyxLQUFLLEtBQUs7Z0JBQ1IsT0FBTyxHQUFHLE9BQU8sSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUVuQyx1RkFBdUY7WUFDdkY7Z0JBQ0UsT0FBTyxHQUFHLE9BQU8sZ0JBQWdCLENBQUM7U0FFckM7S0FDRjs7QUFwRkgsMEJBdUZDOzs7Ozs7OztBQXBGd0Isd0NBQWdDLEdBQUcsb0JBQW9CLENBQUM7QUFzRmpGLFNBQVMsaUJBQWlCLENBQUMsVUFBa0I7SUFDM0MsTUFBTSxPQUFPLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxzRkFBc0YsQ0FBQyxDQUFDO0lBQ3pILE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztBQUMxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmVmb3JlLCBSVUxFX1NTTV9QUklOQ0lQQUxTX0FSRV9SRUdJT05BTCB9IGZyb20gJy4vYXdzLWVudGl0aWVzJztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgRGVmYXVsdCB7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IFZQQ19FTkRQT0lOVF9TRVJWSUNFX05BTUVfUFJFRklYID0gJ2NvbS5hbWF6b25hd3MudnBjZSc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyBzdGF0aWMgc2VydmljZVByaW5jaXBhbChzZXJ2aWNlRnFuOiBzdHJpbmcsIHJlZ2lvbjogc3RyaW5nLCB1cmxTdWZmaXg6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3Qgc2VydmljZSA9IGV4dHJhY3RTaW1wbGVOYW1lKHNlcnZpY2VGcW4pO1xuICAgIGlmICghc2VydmljZSkge1xuICAgICAgLy8gUmV0dXJuIFwic2VydmljZVwiIGlmIGl0IGRvZXMgbm90IGxvb2sgbGlrZSBhbnkgb2YgdGhlIGZvbGxvd2luZzpcbiAgICAgIC8vIC0gczNcbiAgICAgIC8vIC0gczMuYW1hem9uYXdzLmNvbVxuICAgICAgLy8gLSBzMy5hbWF6b25hd3MuY29tLmNuXG4gICAgICAvLyAtIHMzLmMycy5pYy5nb3ZcbiAgICAgIC8vIC0gczMuc2Mycy5zZ292LmdvdlxuICAgICAgcmV0dXJuIHNlcnZpY2VGcW47XG4gICAgfVxuXG4gICAgLy8gRXhjZXB0aW9ucyBmb3IgU2VydmljZSBQcmluY2lwYWxzIGluIHVzLWlzby0qXG4gICAgY29uc3QgVVNfSVNPX0VYQ0VQVElPTlMgPSBuZXcgU2V0KFtcbiAgICAgICdjbG91ZGhzbScsXG4gICAgICAnY29uZmlnJyxcbiAgICAgICdzdGF0ZXMnLFxuICAgICAgJ3dvcmtzcGFjZXMnLFxuICAgIF0pO1xuXG4gICAgLy8gQWNjb3VudCBmb3IgaWRpb3N5bmNyYXRpYyBTZXJ2aWNlIFByaW5jaXBhbHMgaW4gYHVzLWlzby0qYCByZWdpb25zXG4gICAgaWYgKHJlZ2lvbi5zdGFydHNXaXRoKCd1cy1pc28tJykgJiYgVVNfSVNPX0VYQ0VQVElPTlMuaGFzKHNlcnZpY2UpKSB7XG4gICAgICBzd2l0Y2ggKHNlcnZpY2UpIHtcbiAgICAgICAgLy8gU2VydmljZXMgd2l0aCB1bml2ZXJzYWwgcHJpbmNpcGFsXG4gICAgICAgIGNhc2UgKCdzdGF0ZXMnKTpcbiAgICAgICAgICByZXR1cm4gYCR7c2VydmljZX0uYW1hem9uYXdzLmNvbWA7XG5cbiAgICAgICAgLy8gU2VydmljZXMgd2l0aCBhIHBhcnRpdGlvbmFsIHByaW5jaXBhbFxuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHJldHVybiBgJHtzZXJ2aWNlfS4ke3VybFN1ZmZpeH1gO1xuICAgICAgfVxuICAgIH1cblxuICAgIC8vIEV4Y2VwdGlvbnMgZm9yIFNlcnZpY2UgUHJpbmNpcGFscyBpbiB1cy1pc29iLSpcbiAgICBjb25zdCBVU19JU09CX0VYQ0VQVElPTlMgPSBuZXcgU2V0KFtcbiAgICAgICdkbXMnLFxuICAgICAgJ3N0YXRlcycsXG4gICAgXSk7XG5cbiAgICAvLyBBY2NvdW50IGZvciBpZGlvc3luY3JhdGljIFNlcnZpY2UgUHJpbmNpcGFscyBpbiBgdXMtaXNvYi0qYCByZWdpb25zXG4gICAgaWYgKHJlZ2lvbi5zdGFydHNXaXRoKCd1cy1pc29iLScpICYmIFVTX0lTT0JfRVhDRVBUSU9OUy5oYXMoc2VydmljZSkpIHtcbiAgICAgIHN3aXRjaCAoc2VydmljZSkge1xuICAgICAgICAvLyBTZXJ2aWNlcyB3aXRoIHVuaXZlcnNhbCBwcmluY2lwYWxcbiAgICAgICAgY2FzZSAoJ3N0YXRlcycpOlxuICAgICAgICAgIHJldHVybiBgJHtzZXJ2aWNlfS5hbWF6b25hd3MuY29tYDtcblxuICAgICAgICAvLyBTZXJ2aWNlcyB3aXRoIGEgcGFydGl0aW9uYWwgcHJpbmNpcGFsXG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgcmV0dXJuIGAke3NlcnZpY2V9LiR7dXJsU3VmZml4fWA7XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8gU1NNIHR1cm5lZCBmcm9tIGdsb2JhbCB0byByZWdpb25hbCBhdCBzb21lIHBvaW50XG4gICAgaWYgKHNlcnZpY2UgPT09ICdzc20nKSB7XG4gICAgICByZXR1cm4gYmVmb3JlKHJlZ2lvbiwgUlVMRV9TU01fUFJJTkNJUEFMU19BUkVfUkVHSU9OQUwpXG4gICAgICAgID8gYCR7c2VydmljZX0uYW1hem9uYXdzLmNvbWBcbiAgICAgICAgOiBgJHtzZXJ2aWNlfS4ke3JlZ2lvbn0uYW1hem9uYXdzLmNvbWA7XG4gICAgfVxuXG4gICAgc3dpdGNoIChzZXJ2aWNlKSB7XG4gICAgICAvLyBTZXJ2aWNlcyB3aXRoIGEgcmVnaW9uYWwgQU5EIHBhcnRpdGlvbmFsIHByaW5jaXBhbFxuICAgICAgY2FzZSAnY29kZWRlcGxveSc6XG4gICAgICBjYXNlICdsb2dzJzpcbiAgICAgICAgcmV0dXJuIGAke3NlcnZpY2V9LiR7cmVnaW9ufS4ke3VybFN1ZmZpeH1gO1xuXG4gICAgICAvLyBTZXJ2aWNlcyB3aXRoIGEgcmVnaW9uYWwgcHJpbmNpcGFsXG4gICAgICBjYXNlICdzdGF0ZXMnOlxuICAgICAgICByZXR1cm4gYCR7c2VydmljZX0uJHtyZWdpb259LmFtYXpvbmF3cy5jb21gO1xuXG4gICAgICAvLyBTZXJ2aWNlcyB3aXRoIGEgcGFydGl0aW9uYWwgcHJpbmNpcGFsXG4gICAgICBjYXNlICdlYzInOlxuICAgICAgICByZXR1cm4gYCR7c2VydmljZX0uJHt1cmxTdWZmaXh9YDtcblxuICAgICAgLy8gU2VydmljZXMgd2l0aCBhIHVuaXZlcnNhbCBwcmluY2lwYWwgYWNyb3NzIGFsbCByZWdpb25zL3BhcnRpdGlvbnMgKHRoZSBkZWZhdWx0IGNhc2UpXG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gYCR7c2VydmljZX0uYW1hem9uYXdzLmNvbWA7XG5cbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKCkgeyB9XG59XG5cbmZ1bmN0aW9uIGV4dHJhY3RTaW1wbGVOYW1lKHNlcnZpY2VGcW46IHN0cmluZykge1xuICBjb25zdCBtYXRjaGVzID0gc2VydmljZUZxbi5tYXRjaCgvXihbXi5dKykoPzooPzpcXC5hbWF6b25hd3NcXC5jb20oPzpcXC5jbik/KXwoPzpcXC5jMnNcXC5pY1xcLmdvdil8KD86XFwuc2Myc1xcLnNnb3ZcXC5nb3YpKT8kLyk7XG4gIHJldHVybiBtYXRjaGVzID8gbWF0Y2hlc1sxXSA6IHVuZGVmaW5lZDtcbn0iXX0=
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
  }