cdk-iam-floyd 0.763.0 → 0.764.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/README.md
CHANGED
|
@@ -18,7 +18,7 @@ Support for:
|
|
|
18
18
|
- 445 Services
|
|
19
19
|
- 20450 Actions
|
|
20
20
|
- 2170 Resource Types
|
|
21
|
-
-
|
|
21
|
+
- 2298 Condition keys
|
|
22
22
|
<!-- /stats -->
|
|
23
23
|
|
|
24
24
|
**<br>This is an early version of the package. The API will change while I implement new features. Therefore make sure you use an exact version in your `package.json` before it reaches 1.0.0.**
|
|
@@ -16,6 +16,7 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
16
16
|
* Possible conditions:
|
|
17
17
|
* - .ifAwsRequestTag()
|
|
18
18
|
* - .ifAwsTagKeys()
|
|
19
|
+
* - .ifResourceIds()
|
|
19
20
|
*
|
|
20
21
|
* Dependent actions:
|
|
21
22
|
* - ec2:DescribeVpcs
|
|
@@ -28,6 +29,13 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
28
29
|
*
|
|
29
30
|
* Access Level: Write
|
|
30
31
|
*
|
|
32
|
+
* Possible conditions:
|
|
33
|
+
* - .ifResourceTypes()
|
|
34
|
+
* - .ifHostedZoneDomains()
|
|
35
|
+
* - .ifResolverRuleDomains()
|
|
36
|
+
* - .ifFirewallRuleGroupPriority()
|
|
37
|
+
* - .ifResourceArns()
|
|
38
|
+
*
|
|
31
39
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html
|
|
32
40
|
*/
|
|
33
41
|
toAssociateResourceToProfile(): this;
|
|
@@ -56,6 +64,9 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
56
64
|
*
|
|
57
65
|
* Access Level: Write
|
|
58
66
|
*
|
|
67
|
+
* Possible conditions:
|
|
68
|
+
* - .ifResourceIds()
|
|
69
|
+
*
|
|
59
70
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html
|
|
60
71
|
*/
|
|
61
72
|
toDisassociateProfile(): this;
|
|
@@ -64,6 +75,13 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
64
75
|
*
|
|
65
76
|
* Access Level: Write
|
|
66
77
|
*
|
|
78
|
+
* Possible conditions:
|
|
79
|
+
* - .ifResourceTypes()
|
|
80
|
+
* - .ifHostedZoneDomains()
|
|
81
|
+
* - .ifResolverRuleDomains()
|
|
82
|
+
* - .ifFirewallRuleGroupPriority()
|
|
83
|
+
* - .ifResourceArns()
|
|
84
|
+
*
|
|
67
85
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html
|
|
68
86
|
*/
|
|
69
87
|
toDisassociateResourceFromProfile(): this;
|
|
@@ -167,6 +185,12 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
167
185
|
*
|
|
168
186
|
* Access Level: Write
|
|
169
187
|
*
|
|
188
|
+
* Possible conditions:
|
|
189
|
+
* - .ifResourceTypes()
|
|
190
|
+
* - .ifHostedZoneDomains()
|
|
191
|
+
* - .ifResolverRuleDomains()
|
|
192
|
+
* - .ifFirewallRuleGroupPriority()
|
|
193
|
+
*
|
|
170
194
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html
|
|
171
195
|
*/
|
|
172
196
|
toUpdateProfileResourceAssociation(): this;
|
|
@@ -243,6 +267,88 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
243
267
|
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
244
268
|
*/
|
|
245
269
|
ifAwsTagKeys(value: string | string[], operator?: Operator | string): this;
|
|
270
|
+
/**
|
|
271
|
+
* Filters access by priority range of a Firewall Rule Group
|
|
272
|
+
*
|
|
273
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
274
|
+
*
|
|
275
|
+
* Applies to actions:
|
|
276
|
+
* - .toAssociateResourceToProfile()
|
|
277
|
+
* - .toDisassociateResourceFromProfile()
|
|
278
|
+
* - .toUpdateProfileResourceAssociation()
|
|
279
|
+
*
|
|
280
|
+
* @param value The value(s) to check
|
|
281
|
+
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
|
|
282
|
+
*/
|
|
283
|
+
ifFirewallRuleGroupPriority(value: number | number[], operator?: Operator | string): this;
|
|
284
|
+
/**
|
|
285
|
+
* Filters access by Hosted Zone domains
|
|
286
|
+
*
|
|
287
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
288
|
+
*
|
|
289
|
+
* Applies to actions:
|
|
290
|
+
* - .toAssociateResourceToProfile()
|
|
291
|
+
* - .toDisassociateResourceFromProfile()
|
|
292
|
+
* - .toUpdateProfileResourceAssociation()
|
|
293
|
+
*
|
|
294
|
+
* @param value The value(s) to check
|
|
295
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
296
|
+
*/
|
|
297
|
+
ifHostedZoneDomains(value: string | string[], operator?: Operator | string): this;
|
|
298
|
+
/**
|
|
299
|
+
* Filters access by Resolver Rule domains
|
|
300
|
+
*
|
|
301
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
302
|
+
*
|
|
303
|
+
* Applies to actions:
|
|
304
|
+
* - .toAssociateResourceToProfile()
|
|
305
|
+
* - .toDisassociateResourceFromProfile()
|
|
306
|
+
* - .toUpdateProfileResourceAssociation()
|
|
307
|
+
*
|
|
308
|
+
* @param value The value(s) to check
|
|
309
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
310
|
+
*/
|
|
311
|
+
ifResolverRuleDomains(value: string | string[], operator?: Operator | string): this;
|
|
312
|
+
/**
|
|
313
|
+
* Filters access by specific resource ARNs
|
|
314
|
+
*
|
|
315
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
316
|
+
*
|
|
317
|
+
* Applies to actions:
|
|
318
|
+
* - .toAssociateResourceToProfile()
|
|
319
|
+
* - .toDisassociateResourceFromProfile()
|
|
320
|
+
*
|
|
321
|
+
* @param value The value(s) to check
|
|
322
|
+
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
|
|
323
|
+
*/
|
|
324
|
+
ifResourceArns(value: string | string[], operator?: Operator | string): this;
|
|
325
|
+
/**
|
|
326
|
+
* Filters access by given VPCs
|
|
327
|
+
*
|
|
328
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
329
|
+
*
|
|
330
|
+
* Applies to actions:
|
|
331
|
+
* - .toAssociateProfile()
|
|
332
|
+
* - .toDisassociateProfile()
|
|
333
|
+
*
|
|
334
|
+
* @param value The value(s) to check
|
|
335
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
336
|
+
*/
|
|
337
|
+
ifResourceIds(value: string | string[], operator?: Operator | string): this;
|
|
338
|
+
/**
|
|
339
|
+
* Filters access by specific resource type. Possible options include 'HostedZone', 'FirewallRuleGroup', 'ResolverQueryLoggingConfig', 'ResolverRule', and 'VpcEndpoint'
|
|
340
|
+
*
|
|
341
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
342
|
+
*
|
|
343
|
+
* Applies to actions:
|
|
344
|
+
* - .toAssociateResourceToProfile()
|
|
345
|
+
* - .toDisassociateResourceFromProfile()
|
|
346
|
+
* - .toUpdateProfileResourceAssociation()
|
|
347
|
+
*
|
|
348
|
+
* @param value The value(s) to check
|
|
349
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
350
|
+
*/
|
|
351
|
+
ifResourceTypes(value: string | string[], operator?: Operator | string): this;
|
|
246
352
|
/**
|
|
247
353
|
* Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).
|
|
248
354
|
*
|
|
@@ -16,6 +16,7 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
16
16
|
* Possible conditions:
|
|
17
17
|
* - .ifAwsRequestTag()
|
|
18
18
|
* - .ifAwsTagKeys()
|
|
19
|
+
* - .ifResourceIds()
|
|
19
20
|
*
|
|
20
21
|
* Dependent actions:
|
|
21
22
|
* - ec2:DescribeVpcs
|
|
@@ -30,6 +31,13 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
30
31
|
*
|
|
31
32
|
* Access Level: Write
|
|
32
33
|
*
|
|
34
|
+
* Possible conditions:
|
|
35
|
+
* - .ifResourceTypes()
|
|
36
|
+
* - .ifHostedZoneDomains()
|
|
37
|
+
* - .ifResolverRuleDomains()
|
|
38
|
+
* - .ifFirewallRuleGroupPriority()
|
|
39
|
+
* - .ifResourceArns()
|
|
40
|
+
*
|
|
33
41
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html
|
|
34
42
|
*/
|
|
35
43
|
toAssociateResourceToProfile() {
|
|
@@ -64,6 +72,9 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
64
72
|
*
|
|
65
73
|
* Access Level: Write
|
|
66
74
|
*
|
|
75
|
+
* Possible conditions:
|
|
76
|
+
* - .ifResourceIds()
|
|
77
|
+
*
|
|
67
78
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html
|
|
68
79
|
*/
|
|
69
80
|
toDisassociateProfile() {
|
|
@@ -74,6 +85,13 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
74
85
|
*
|
|
75
86
|
* Access Level: Write
|
|
76
87
|
*
|
|
88
|
+
* Possible conditions:
|
|
89
|
+
* - .ifResourceTypes()
|
|
90
|
+
* - .ifHostedZoneDomains()
|
|
91
|
+
* - .ifResolverRuleDomains()
|
|
92
|
+
* - .ifFirewallRuleGroupPriority()
|
|
93
|
+
* - .ifResourceArns()
|
|
94
|
+
*
|
|
77
95
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html
|
|
78
96
|
*/
|
|
79
97
|
toDisassociateResourceFromProfile() {
|
|
@@ -201,6 +219,12 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
201
219
|
*
|
|
202
220
|
* Access Level: Write
|
|
203
221
|
*
|
|
222
|
+
* Possible conditions:
|
|
223
|
+
* - .ifResourceTypes()
|
|
224
|
+
* - .ifHostedZoneDomains()
|
|
225
|
+
* - .ifResolverRuleDomains()
|
|
226
|
+
* - .ifFirewallRuleGroupPriority()
|
|
227
|
+
*
|
|
204
228
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html
|
|
205
229
|
*/
|
|
206
230
|
toUpdateProfileResourceAssociation() {
|
|
@@ -288,6 +312,100 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
288
312
|
ifAwsTagKeys(value, operator) {
|
|
289
313
|
return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');
|
|
290
314
|
}
|
|
315
|
+
/**
|
|
316
|
+
* Filters access by priority range of a Firewall Rule Group
|
|
317
|
+
*
|
|
318
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
319
|
+
*
|
|
320
|
+
* Applies to actions:
|
|
321
|
+
* - .toAssociateResourceToProfile()
|
|
322
|
+
* - .toDisassociateResourceFromProfile()
|
|
323
|
+
* - .toUpdateProfileResourceAssociation()
|
|
324
|
+
*
|
|
325
|
+
* @param value The value(s) to check
|
|
326
|
+
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
|
|
327
|
+
*/
|
|
328
|
+
ifFirewallRuleGroupPriority(value, operator) {
|
|
329
|
+
return this.if(`FirewallRuleGroupPriority`, value, operator ?? 'NumericEquals');
|
|
330
|
+
}
|
|
331
|
+
/**
|
|
332
|
+
* Filters access by Hosted Zone domains
|
|
333
|
+
*
|
|
334
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
335
|
+
*
|
|
336
|
+
* Applies to actions:
|
|
337
|
+
* - .toAssociateResourceToProfile()
|
|
338
|
+
* - .toDisassociateResourceFromProfile()
|
|
339
|
+
* - .toUpdateProfileResourceAssociation()
|
|
340
|
+
*
|
|
341
|
+
* @param value The value(s) to check
|
|
342
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
343
|
+
*/
|
|
344
|
+
ifHostedZoneDomains(value, operator) {
|
|
345
|
+
return this.if(`HostedZoneDomains`, value, operator ?? 'StringLike');
|
|
346
|
+
}
|
|
347
|
+
/**
|
|
348
|
+
* Filters access by Resolver Rule domains
|
|
349
|
+
*
|
|
350
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
351
|
+
*
|
|
352
|
+
* Applies to actions:
|
|
353
|
+
* - .toAssociateResourceToProfile()
|
|
354
|
+
* - .toDisassociateResourceFromProfile()
|
|
355
|
+
* - .toUpdateProfileResourceAssociation()
|
|
356
|
+
*
|
|
357
|
+
* @param value The value(s) to check
|
|
358
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
359
|
+
*/
|
|
360
|
+
ifResolverRuleDomains(value, operator) {
|
|
361
|
+
return this.if(`ResolverRuleDomains`, value, operator ?? 'StringLike');
|
|
362
|
+
}
|
|
363
|
+
/**
|
|
364
|
+
* Filters access by specific resource ARNs
|
|
365
|
+
*
|
|
366
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
367
|
+
*
|
|
368
|
+
* Applies to actions:
|
|
369
|
+
* - .toAssociateResourceToProfile()
|
|
370
|
+
* - .toDisassociateResourceFromProfile()
|
|
371
|
+
*
|
|
372
|
+
* @param value The value(s) to check
|
|
373
|
+
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
|
|
374
|
+
*/
|
|
375
|
+
ifResourceArns(value, operator) {
|
|
376
|
+
return this.if(`ResourceArns`, value, operator ?? 'ArnLike');
|
|
377
|
+
}
|
|
378
|
+
/**
|
|
379
|
+
* Filters access by given VPCs
|
|
380
|
+
*
|
|
381
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
382
|
+
*
|
|
383
|
+
* Applies to actions:
|
|
384
|
+
* - .toAssociateProfile()
|
|
385
|
+
* - .toDisassociateProfile()
|
|
386
|
+
*
|
|
387
|
+
* @param value The value(s) to check
|
|
388
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
389
|
+
*/
|
|
390
|
+
ifResourceIds(value, operator) {
|
|
391
|
+
return this.if(`ResourceIds`, value, operator ?? 'StringLike');
|
|
392
|
+
}
|
|
393
|
+
/**
|
|
394
|
+
* Filters access by specific resource type. Possible options include 'HostedZone', 'FirewallRuleGroup', 'ResolverQueryLoggingConfig', 'ResolverRule', and 'VpcEndpoint'
|
|
395
|
+
*
|
|
396
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
397
|
+
*
|
|
398
|
+
* Applies to actions:
|
|
399
|
+
* - .toAssociateResourceToProfile()
|
|
400
|
+
* - .toDisassociateResourceFromProfile()
|
|
401
|
+
* - .toUpdateProfileResourceAssociation()
|
|
402
|
+
*
|
|
403
|
+
* @param value The value(s) to check
|
|
404
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
405
|
+
*/
|
|
406
|
+
ifResourceTypes(value, operator) {
|
|
407
|
+
return this.if(`ResourceTypes`, value, operator ?? 'StringLike');
|
|
408
|
+
}
|
|
291
409
|
/**
|
|
292
410
|
* Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).
|
|
293
411
|
*
|
|
@@ -326,4 +444,4 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
326
444
|
}
|
|
327
445
|
}
|
|
328
446
|
exports.Route53profiles = Route53profiles;
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route53profiles.js","sourceRoot":"","sources":["route53profiles.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\nimport { aws_iam as iam } from \"aws-cdk-lib\";\n\n/**\n * Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).\n *\n * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n */\nexport class Route53profiles extends PolicyStatement {\n  public servicePrefix = 'route53profiles';\n\n  /**\n   * Grants permission to associates a Profile to the customer VPC\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * Dependent actions:\n   * - ec2:DescribeVpcs\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateProfile.html\n   */\n  public toAssociateProfile() {\n    return this.to('AssociateProfile');\n  }\n\n  /**\n   * Grants permission to associates a resource, such as DNS Firewall rule group, private hosted zone, resolver rule, etc. to a specified Profile\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html\n   */\n  public toAssociateResourceToProfile() {\n    return this.to('AssociateResourceToProfile');\n  }\n\n  /**\n   * Grants permission to create a new Profile resource\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_CreateProfile.html\n   */\n  public toCreateProfile() {\n    return this.to('CreateProfile');\n  }\n\n  /**\n   * Grants permission to delete a Profile specified by the ProfileId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DeleteProfile.html\n   */\n  public toDeleteProfile() {\n    return this.to('DeleteProfile');\n  }\n\n  /**\n   * Grants permission to delete an association between a customer VPC and the specified Profile\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html\n   */\n  public toDisassociateProfile() {\n    return this.to('DisassociateProfile');\n  }\n\n  /**\n   * Grants permission to delete the asoociation between the resource. such as DNS Firewall rule group, private hosted zone, resolver rule, etc. and the specified Profile\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html\n   */\n  public toDisassociateResourceFromProfile() {\n    return this.to('DisassociateResourceFromProfile');\n  }\n\n  /**\n   * Grants permission to get a Profile\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfile.html\n   */\n  public toGetProfile() {\n    return this.to('GetProfile');\n  }\n\n  /**\n   * Grants permission to get a Profile to a VPC association specified by the Profile association ID\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfileAssociation.html\n   */\n  public toGetProfileAssociation() {\n    return this.to('GetProfileAssociation');\n  }\n\n  /**\n   * Grants permission to read the RAM access control policy for a Profile\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/sharing-profiles.html\n   */\n  public toGetProfilePolicy() {\n    return this.to('GetProfilePolicy');\n  }\n\n  /**\n   * Grants permission to get a Profile resource association based on the ProfileResourceAssociationId\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfileResourceAssociation.html\n   */\n  public toGetProfileResourceAssociation() {\n    return this.to('GetProfileResourceAssociation');\n  }\n\n  /**\n   * Grants permission to list all VPCs the specified Profile is associated to\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfileAssociations.html\n   */\n  public toListProfileAssociations() {\n    return this.to('ListProfileAssociations');\n  }\n\n  /**\n   * Grants permission to list all the associations between the resources, such as DNS Firewall rule groups, private hosted zones, resolver rules, etc. for the given Profile ID\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfileResourceAssociations.html\n   */\n  public toListProfileResourceAssociations() {\n    return this.to('ListProfileResourceAssociations');\n  }\n\n  /**\n   * Grants permission to list all the Profiles created by, and shared to the customer\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfiles.html\n   */\n  public toListProfiles() {\n    return this.to('ListProfiles');\n  }\n\n  /**\n   * Grants permission to list all tags associated with the resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to define the RAM access control policy for a Profile\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/sharing-profiles.html\n   */\n  public toPutProfilePolicy() {\n    return this.to('PutProfilePolicy');\n  }\n\n  /**\n   * Grants permission to add a tag to the given resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to delete a tag from the given resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update the Profile resource association name or the resource properties or both, if both name and resource properties are null, the api returns the existing Profile resource association\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html\n   */\n  public toUpdateProfileResourceAssociation() {\n    return this.to('UpdateProfileResourceAssociation');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AssociateProfile',\n      'AssociateResourceToProfile',\n      'CreateProfile',\n      'DeleteProfile',\n      'DisassociateProfile',\n      'DisassociateResourceFromProfile',\n      'PutProfilePolicy',\n      'UpdateProfileResourceAssociation'\n    ],\n    Read: [\n      'GetProfile',\n      'GetProfileAssociation',\n      'GetProfilePolicy',\n      'GetProfileResourceAssociation'\n    ],\n    List: [\n      'ListProfileAssociations',\n      'ListProfileResourceAssociations',\n      'ListProfiles',\n      'ListTagsForResource'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type profile to the statement\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/#access-control-resources\n   *\n   * @param resourceId - Identifier for the resourceId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onProfile(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:route53profiles:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:profile/${ resourceId }`);\n  }\n\n  /**\n   * Adds a resource of type profile-association to the statement\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/#access-control-resources\n   *\n   * @param resourceId - Identifier for the resourceId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onProfileAssociation(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:route53profiles:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:profile-association/${ resourceId }`);\n  }\n\n  /**\n   * Filters access by the presence of tag key-value pairs in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .toAssociateProfile()\n   * - .toCreateProfile()\n   * - .toTagResource()\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsRequestTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:RequestTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the presence of tag key-value pairs attached to the resource\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag\n   *\n   * Applies to resource types:\n   * - profile\n   * - profile-association\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the presence of tag keys in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .toAssociateProfile()\n   * - .toCreateProfile()\n   * - .toTagResource()\n   * - .toUntagResource()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsTagKeys(value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
|
|
447
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route53profiles.js","sourceRoot":"","sources":["route53profiles.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\nimport { aws_iam as iam } from \"aws-cdk-lib\";\n\n/**\n * Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).\n *\n * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n */\nexport class Route53profiles extends PolicyStatement {\n  public servicePrefix = 'route53profiles';\n\n  /**\n   * Grants permission to associates a Profile to the customer VPC\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   * - .ifResourceIds()\n   *\n   * Dependent actions:\n   * - ec2:DescribeVpcs\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateProfile.html\n   */\n  public toAssociateProfile() {\n    return this.to('AssociateProfile');\n  }\n\n  /**\n   * Grants permission to associates a resource, such as DNS Firewall rule group, private hosted zone, resolver rule, etc. to a specified Profile\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifResourceTypes()\n   * - .ifHostedZoneDomains()\n   * - .ifResolverRuleDomains()\n   * - .ifFirewallRuleGroupPriority()\n   * - .ifResourceArns()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html\n   */\n  public toAssociateResourceToProfile() {\n    return this.to('AssociateResourceToProfile');\n  }\n\n  /**\n   * Grants permission to create a new Profile resource\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_CreateProfile.html\n   */\n  public toCreateProfile() {\n    return this.to('CreateProfile');\n  }\n\n  /**\n   * Grants permission to delete a Profile specified by the ProfileId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DeleteProfile.html\n   */\n  public toDeleteProfile() {\n    return this.to('DeleteProfile');\n  }\n\n  /**\n   * Grants permission to delete an association between a customer VPC and the specified Profile\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifResourceIds()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html\n   */\n  public toDisassociateProfile() {\n    return this.to('DisassociateProfile');\n  }\n\n  /**\n   * Grants permission to delete the asoociation between the resource. such as DNS Firewall rule group, private hosted zone, resolver rule, etc. and the specified Profile\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifResourceTypes()\n   * - .ifHostedZoneDomains()\n   * - .ifResolverRuleDomains()\n   * - .ifFirewallRuleGroupPriority()\n   * - .ifResourceArns()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html\n   */\n  public toDisassociateResourceFromProfile() {\n    return this.to('DisassociateResourceFromProfile');\n  }\n\n  /**\n   * Grants permission to get a Profile\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfile.html\n   */\n  public toGetProfile() {\n    return this.to('GetProfile');\n  }\n\n  /**\n   * Grants permission to get a Profile to a VPC association specified by the Profile association ID\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfileAssociation.html\n   */\n  public toGetProfileAssociation() {\n    return this.to('GetProfileAssociation');\n  }\n\n  /**\n   * Grants permission to read the RAM access control policy for a Profile\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/sharing-profiles.html\n   */\n  public toGetProfilePolicy() {\n    return this.to('GetProfilePolicy');\n  }\n\n  /**\n   * Grants permission to get a Profile resource association based on the ProfileResourceAssociationId\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_GetProfileResourceAssociation.html\n   */\n  public toGetProfileResourceAssociation() {\n    return this.to('GetProfileResourceAssociation');\n  }\n\n  /**\n   * Grants permission to list all VPCs the specified Profile is associated to\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfileAssociations.html\n   */\n  public toListProfileAssociations() {\n    return this.to('ListProfileAssociations');\n  }\n\n  /**\n   * Grants permission to list all the associations between the resources, such as DNS Firewall rule groups, private hosted zones, resolver rules, etc. for the given Profile ID\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfileResourceAssociations.html\n   */\n  public toListProfileResourceAssociations() {\n    return this.to('ListProfileResourceAssociations');\n  }\n\n  /**\n   * Grants permission to list all the Profiles created by, and shared to the customer\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListProfiles.html\n   */\n  public toListProfiles() {\n    return this.to('ListProfiles');\n  }\n\n  /**\n   * Grants permission to list all tags associated with the resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to define the RAM access control policy for a Profile\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/sharing-profiles.html\n   */\n  public toPutProfilePolicy() {\n    return this.to('PutProfilePolicy');\n  }\n\n  /**\n   * Grants permission to add a tag to the given resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to delete a tag from the given resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update the Profile resource association name or the resource properties or both, if both name and resource properties are null, the api returns the existing Profile resource association\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifResourceTypes()\n   * - .ifHostedZoneDomains()\n   * - .ifResolverRuleDomains()\n   * - .ifFirewallRuleGroupPriority()\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html\n   */\n  public toUpdateProfileResourceAssociation() {\n    return this.to('UpdateProfileResourceAssociation');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AssociateProfile',\n      'AssociateResourceToProfile',\n      'CreateProfile',\n      'DeleteProfile',\n      'DisassociateProfile',\n      'DisassociateResourceFromProfile',\n      'PutProfilePolicy',\n      'UpdateProfileResourceAssociation'\n    ],\n    Read: [\n      'GetProfile',\n      'GetProfileAssociation',\n      'GetProfilePolicy',\n      'GetProfileResourceAssociation'\n    ],\n    List: [\n      'ListProfileAssociations',\n      'ListProfileResourceAssociations',\n      'ListProfiles',\n      'ListTagsForResource'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type profile to the statement\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/#access-control-resources\n   *\n   * @param resourceId - Identifier for the resourceId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onProfile(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:route53profiles:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:profile/${ resourceId }`);\n  }\n\n  /**\n   * Adds a resource of type profile-association to the statement\n   *\n   * https://docs.aws.amazon.com/Route53/latest/APIReference/#access-control-resources\n   *\n   * @param resourceId - Identifier for the resourceId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onProfileAssociation(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:route53profiles:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:profile-association/${ resourceId }`);\n  }\n\n  /**\n   * Filters access by the presence of tag key-value pairs in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .toAssociateProfile()\n   * - .toCreateProfile()\n   * - .toTagResource()\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsRequestTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:RequestTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the presence of tag key-value pairs attached to the resource\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag\n   *\n   * Applies to resource types:\n   * - profile\n   * - profile-association\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the presence of tag keys in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .toAssociateProfile()\n   * - .toCreateProfile()\n   * - .toTagResource()\n   * - .toUntagResource()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsTagKeys(value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by priority range of a Firewall Rule Group\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateResourceToProfile()\n   * - .toDisassociateResourceFromProfile()\n   * - .toUpdateProfileResourceAssociation()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`\n   */\n  public ifFirewallRuleGroupPriority(value: number | number[], operator?: Operator | string) {\n    return this.if(`FirewallRuleGroupPriority`, value, operator ?? 'NumericEquals');\n  }\n\n  /**\n   * Filters access by Hosted Zone domains\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateResourceToProfile()\n   * - .toDisassociateResourceFromProfile()\n   * - .toUpdateProfileResourceAssociation()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifHostedZoneDomains(value: string | string[], operator?: Operator | string) {\n    return this.if(`HostedZoneDomains`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by Resolver Rule domains\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateResourceToProfile()\n   * - .toDisassociateResourceFromProfile()\n   * - .toUpdateProfileResourceAssociation()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifResolverRuleDomains(value: string | string[], operator?: Operator | string) {\n    return this.if(`ResolverRuleDomains`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by specific resource ARNs\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateResourceToProfile()\n   * - .toDisassociateResourceFromProfile()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`\n   */\n  public ifResourceArns(value: string | string[], operator?: Operator | string) {\n    return this.if(`ResourceArns`, value, operator ?? 'ArnLike');\n  }\n\n  /**\n   * Filters access by given VPCs\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateProfile()\n   * - .toDisassociateProfile()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifResourceIds(value: string | string[], operator?: Operator | string) {\n    return this.if(`ResourceIds`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by specific resource type. Possible options include 'HostedZone', 'FirewallRuleGroup', 'ResolverQueryLoggingConfig', 'ResolverRule', and 'VpcEndpoint'\n   *\n   * https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html\n   *\n   * Applies to actions:\n   * - .toAssociateResourceToProfile()\n   * - .toDisassociateResourceFromProfile()\n   * - .toUpdateProfileResourceAssociation()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifResourceTypes(value: string | string[], operator?: Operator | string) {\n    return this.if(`ResourceTypes`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Statement provider for service [route53profiles](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
|
package/package.json
CHANGED