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.**
|
|
@@ -21,6 +21,7 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
21
21
|
* Possible conditions:
|
|
22
22
|
* - .ifAwsRequestTag()
|
|
23
23
|
* - .ifAwsTagKeys()
|
|
24
|
+
* - .ifResourceIds()
|
|
24
25
|
*
|
|
25
26
|
* Dependent actions:
|
|
26
27
|
* - ec2:DescribeVpcs
|
|
@@ -33,6 +34,13 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
33
34
|
*
|
|
34
35
|
* Access Level: Write
|
|
35
36
|
*
|
|
37
|
+
* Possible conditions:
|
|
38
|
+
* - .ifResourceTypes()
|
|
39
|
+
* - .ifHostedZoneDomains()
|
|
40
|
+
* - .ifResolverRuleDomains()
|
|
41
|
+
* - .ifFirewallRuleGroupPriority()
|
|
42
|
+
* - .ifResourceArns()
|
|
43
|
+
*
|
|
36
44
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html
|
|
37
45
|
*/
|
|
38
46
|
toAssociateResourceToProfile(): this;
|
|
@@ -61,6 +69,9 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
61
69
|
*
|
|
62
70
|
* Access Level: Write
|
|
63
71
|
*
|
|
72
|
+
* Possible conditions:
|
|
73
|
+
* - .ifResourceIds()
|
|
74
|
+
*
|
|
64
75
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html
|
|
65
76
|
*/
|
|
66
77
|
toDisassociateProfile(): this;
|
|
@@ -69,6 +80,13 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
69
80
|
*
|
|
70
81
|
* Access Level: Write
|
|
71
82
|
*
|
|
83
|
+
* Possible conditions:
|
|
84
|
+
* - .ifResourceTypes()
|
|
85
|
+
* - .ifHostedZoneDomains()
|
|
86
|
+
* - .ifResolverRuleDomains()
|
|
87
|
+
* - .ifFirewallRuleGroupPriority()
|
|
88
|
+
* - .ifResourceArns()
|
|
89
|
+
*
|
|
72
90
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html
|
|
73
91
|
*/
|
|
74
92
|
toDisassociateResourceFromProfile(): this;
|
|
@@ -172,6 +190,12 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
172
190
|
*
|
|
173
191
|
* Access Level: Write
|
|
174
192
|
*
|
|
193
|
+
* Possible conditions:
|
|
194
|
+
* - .ifResourceTypes()
|
|
195
|
+
* - .ifHostedZoneDomains()
|
|
196
|
+
* - .ifResolverRuleDomains()
|
|
197
|
+
* - .ifFirewallRuleGroupPriority()
|
|
198
|
+
*
|
|
175
199
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html
|
|
176
200
|
*/
|
|
177
201
|
toUpdateProfileResourceAssociation(): this;
|
|
@@ -248,4 +272,86 @@ export declare class Route53profiles extends PolicyStatement {
|
|
|
248
272
|
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
249
273
|
*/
|
|
250
274
|
ifAwsTagKeys(value: string | string[], operator?: Operator | string): this;
|
|
275
|
+
/**
|
|
276
|
+
* Filters access by priority range of a Firewall Rule Group
|
|
277
|
+
*
|
|
278
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
279
|
+
*
|
|
280
|
+
* Applies to actions:
|
|
281
|
+
* - .toAssociateResourceToProfile()
|
|
282
|
+
* - .toDisassociateResourceFromProfile()
|
|
283
|
+
* - .toUpdateProfileResourceAssociation()
|
|
284
|
+
*
|
|
285
|
+
* @param value The value(s) to check
|
|
286
|
+
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
|
|
287
|
+
*/
|
|
288
|
+
ifFirewallRuleGroupPriority(value: number | number[], operator?: Operator | string): this;
|
|
289
|
+
/**
|
|
290
|
+
* Filters access by Hosted Zone domains
|
|
291
|
+
*
|
|
292
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
293
|
+
*
|
|
294
|
+
* Applies to actions:
|
|
295
|
+
* - .toAssociateResourceToProfile()
|
|
296
|
+
* - .toDisassociateResourceFromProfile()
|
|
297
|
+
* - .toUpdateProfileResourceAssociation()
|
|
298
|
+
*
|
|
299
|
+
* @param value The value(s) to check
|
|
300
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
301
|
+
*/
|
|
302
|
+
ifHostedZoneDomains(value: string | string[], operator?: Operator | string): this;
|
|
303
|
+
/**
|
|
304
|
+
* Filters access by Resolver Rule domains
|
|
305
|
+
*
|
|
306
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
307
|
+
*
|
|
308
|
+
* Applies to actions:
|
|
309
|
+
* - .toAssociateResourceToProfile()
|
|
310
|
+
* - .toDisassociateResourceFromProfile()
|
|
311
|
+
* - .toUpdateProfileResourceAssociation()
|
|
312
|
+
*
|
|
313
|
+
* @param value The value(s) to check
|
|
314
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
315
|
+
*/
|
|
316
|
+
ifResolverRuleDomains(value: string | string[], operator?: Operator | string): this;
|
|
317
|
+
/**
|
|
318
|
+
* Filters access by specific resource ARNs
|
|
319
|
+
*
|
|
320
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
321
|
+
*
|
|
322
|
+
* Applies to actions:
|
|
323
|
+
* - .toAssociateResourceToProfile()
|
|
324
|
+
* - .toDisassociateResourceFromProfile()
|
|
325
|
+
*
|
|
326
|
+
* @param value The value(s) to check
|
|
327
|
+
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
|
|
328
|
+
*/
|
|
329
|
+
ifResourceArns(value: string | string[], operator?: Operator | string): this;
|
|
330
|
+
/**
|
|
331
|
+
* Filters access by given VPCs
|
|
332
|
+
*
|
|
333
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
334
|
+
*
|
|
335
|
+
* Applies to actions:
|
|
336
|
+
* - .toAssociateProfile()
|
|
337
|
+
* - .toDisassociateProfile()
|
|
338
|
+
*
|
|
339
|
+
* @param value The value(s) to check
|
|
340
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
341
|
+
*/
|
|
342
|
+
ifResourceIds(value: string | string[], operator?: Operator | string): this;
|
|
343
|
+
/**
|
|
344
|
+
* Filters access by specific resource type. Possible options include 'HostedZone', 'FirewallRuleGroup', 'ResolverQueryLoggingConfig', 'ResolverRule', and 'VpcEndpoint'
|
|
345
|
+
*
|
|
346
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
347
|
+
*
|
|
348
|
+
* Applies to actions:
|
|
349
|
+
* - .toAssociateResourceToProfile()
|
|
350
|
+
* - .toDisassociateResourceFromProfile()
|
|
351
|
+
* - .toUpdateProfileResourceAssociation()
|
|
352
|
+
*
|
|
353
|
+
* @param value The value(s) to check
|
|
354
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
355
|
+
*/
|
|
356
|
+
ifResourceTypes(value: string | string[], operator?: Operator | string): this;
|
|
251
357
|
}
|
|
@@ -53,6 +53,7 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
53
53
|
* Possible conditions:
|
|
54
54
|
* - .ifAwsRequestTag()
|
|
55
55
|
* - .ifAwsTagKeys()
|
|
56
|
+
* - .ifResourceIds()
|
|
56
57
|
*
|
|
57
58
|
* Dependent actions:
|
|
58
59
|
* - ec2:DescribeVpcs
|
|
@@ -67,6 +68,13 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
67
68
|
*
|
|
68
69
|
* Access Level: Write
|
|
69
70
|
*
|
|
71
|
+
* Possible conditions:
|
|
72
|
+
* - .ifResourceTypes()
|
|
73
|
+
* - .ifHostedZoneDomains()
|
|
74
|
+
* - .ifResolverRuleDomains()
|
|
75
|
+
* - .ifFirewallRuleGroupPriority()
|
|
76
|
+
* - .ifResourceArns()
|
|
77
|
+
*
|
|
70
78
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_AssociateResourceToProfile.html
|
|
71
79
|
*/
|
|
72
80
|
toAssociateResourceToProfile() {
|
|
@@ -101,6 +109,9 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
101
109
|
*
|
|
102
110
|
* Access Level: Write
|
|
103
111
|
*
|
|
112
|
+
* Possible conditions:
|
|
113
|
+
* - .ifResourceIds()
|
|
114
|
+
*
|
|
104
115
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateProfile.html
|
|
105
116
|
*/
|
|
106
117
|
toDisassociateProfile() {
|
|
@@ -111,6 +122,13 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
111
122
|
*
|
|
112
123
|
* Access Level: Write
|
|
113
124
|
*
|
|
125
|
+
* Possible conditions:
|
|
126
|
+
* - .ifResourceTypes()
|
|
127
|
+
* - .ifHostedZoneDomains()
|
|
128
|
+
* - .ifResolverRuleDomains()
|
|
129
|
+
* - .ifFirewallRuleGroupPriority()
|
|
130
|
+
* - .ifResourceArns()
|
|
131
|
+
*
|
|
114
132
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_DisassociateResourceFromProfile.html
|
|
115
133
|
*/
|
|
116
134
|
toDisassociateResourceFromProfile() {
|
|
@@ -238,6 +256,12 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
238
256
|
*
|
|
239
257
|
* Access Level: Write
|
|
240
258
|
*
|
|
259
|
+
* Possible conditions:
|
|
260
|
+
* - .ifResourceTypes()
|
|
261
|
+
* - .ifHostedZoneDomains()
|
|
262
|
+
* - .ifResolverRuleDomains()
|
|
263
|
+
* - .ifFirewallRuleGroupPriority()
|
|
264
|
+
*
|
|
241
265
|
* https://docs.aws.amazon.com/Route53/latest/APIReference/API_route53profiles_UpdateProfileResourceAssociation.html
|
|
242
266
|
*/
|
|
243
267
|
toUpdateProfileResourceAssociation() {
|
|
@@ -325,6 +349,100 @@ class Route53profiles extends shared_1.PolicyStatement {
|
|
|
325
349
|
ifAwsTagKeys(value, operator) {
|
|
326
350
|
return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');
|
|
327
351
|
}
|
|
352
|
+
/**
|
|
353
|
+
* Filters access by priority range of a Firewall Rule Group
|
|
354
|
+
*
|
|
355
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
356
|
+
*
|
|
357
|
+
* Applies to actions:
|
|
358
|
+
* - .toAssociateResourceToProfile()
|
|
359
|
+
* - .toDisassociateResourceFromProfile()
|
|
360
|
+
* - .toUpdateProfileResourceAssociation()
|
|
361
|
+
*
|
|
362
|
+
* @param value The value(s) to check
|
|
363
|
+
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
|
|
364
|
+
*/
|
|
365
|
+
ifFirewallRuleGroupPriority(value, operator) {
|
|
366
|
+
return this.if(`FirewallRuleGroupPriority`, value, operator ?? 'NumericEquals');
|
|
367
|
+
}
|
|
368
|
+
/**
|
|
369
|
+
* Filters access by Hosted Zone domains
|
|
370
|
+
*
|
|
371
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
372
|
+
*
|
|
373
|
+
* Applies to actions:
|
|
374
|
+
* - .toAssociateResourceToProfile()
|
|
375
|
+
* - .toDisassociateResourceFromProfile()
|
|
376
|
+
* - .toUpdateProfileResourceAssociation()
|
|
377
|
+
*
|
|
378
|
+
* @param value The value(s) to check
|
|
379
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
380
|
+
*/
|
|
381
|
+
ifHostedZoneDomains(value, operator) {
|
|
382
|
+
return this.if(`HostedZoneDomains`, value, operator ?? 'StringLike');
|
|
383
|
+
}
|
|
384
|
+
/**
|
|
385
|
+
* Filters access by Resolver Rule domains
|
|
386
|
+
*
|
|
387
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
388
|
+
*
|
|
389
|
+
* Applies to actions:
|
|
390
|
+
* - .toAssociateResourceToProfile()
|
|
391
|
+
* - .toDisassociateResourceFromProfile()
|
|
392
|
+
* - .toUpdateProfileResourceAssociation()
|
|
393
|
+
*
|
|
394
|
+
* @param value The value(s) to check
|
|
395
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
396
|
+
*/
|
|
397
|
+
ifResolverRuleDomains(value, operator) {
|
|
398
|
+
return this.if(`ResolverRuleDomains`, value, operator ?? 'StringLike');
|
|
399
|
+
}
|
|
400
|
+
/**
|
|
401
|
+
* Filters access by specific resource ARNs
|
|
402
|
+
*
|
|
403
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
404
|
+
*
|
|
405
|
+
* Applies to actions:
|
|
406
|
+
* - .toAssociateResourceToProfile()
|
|
407
|
+
* - .toDisassociateResourceFromProfile()
|
|
408
|
+
*
|
|
409
|
+
* @param value The value(s) to check
|
|
410
|
+
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
|
|
411
|
+
*/
|
|
412
|
+
ifResourceArns(value, operator) {
|
|
413
|
+
return this.if(`ResourceArns`, value, operator ?? 'ArnLike');
|
|
414
|
+
}
|
|
415
|
+
/**
|
|
416
|
+
* Filters access by given VPCs
|
|
417
|
+
*
|
|
418
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
419
|
+
*
|
|
420
|
+
* Applies to actions:
|
|
421
|
+
* - .toAssociateProfile()
|
|
422
|
+
* - .toDisassociateProfile()
|
|
423
|
+
*
|
|
424
|
+
* @param value The value(s) to check
|
|
425
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
426
|
+
*/
|
|
427
|
+
ifResourceIds(value, operator) {
|
|
428
|
+
return this.if(`ResourceIds`, value, operator ?? 'StringLike');
|
|
429
|
+
}
|
|
430
|
+
/**
|
|
431
|
+
* Filters access by specific resource type. Possible options include 'HostedZone', 'FirewallRuleGroup', 'ResolverQueryLoggingConfig', 'ResolverRule', and 'VpcEndpoint'
|
|
432
|
+
*
|
|
433
|
+
* https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonroute53profiles.html
|
|
434
|
+
*
|
|
435
|
+
* Applies to actions:
|
|
436
|
+
* - .toAssociateResourceToProfile()
|
|
437
|
+
* - .toDisassociateResourceFromProfile()
|
|
438
|
+
* - .toUpdateProfileResourceAssociation()
|
|
439
|
+
*
|
|
440
|
+
* @param value The value(s) to check
|
|
441
|
+
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
|
|
442
|
+
*/
|
|
443
|
+
ifResourceTypes(value, operator) {
|
|
444
|
+
return this.if(`ResourceTypes`, value, operator ?? 'StringLike');
|
|
445
|
+
}
|
|
328
446
|
}
|
|
329
447
|
exports.Route53profiles = Route53profiles;
|
|
330
|
-
//# 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';\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   * 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   */\n  constructor(sid?: string) {\n    super(sid);\n  }\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"]}
|
|
448
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route53profiles.js","sourceRoot":"","sources":["route53profiles.ts"],"names":[],"mappings":";;;AACA,yCAAyD;AAEzD;;;;GAIG;AACH,MAAa,eAAgB,SAAQ,wBAAe;IAGlD;;;;OAIG;IACH,YAAY,GAAY;QACtB,KAAK,CAAC,GAAG,CAAC,CAAC;QARN,kBAAa,GAAG,iBAAiB,CAAC;QA2P/B,oBAAe,GAAoB;YAC3C,KAAK,EAAE;gBACL,kBAAkB;gBAClB,4BAA4B;gBAC5B,eAAe;gBACf,eAAe;gBACf,qBAAqB;gBACrB,iCAAiC;gBACjC,kBAAkB;gBAClB,kCAAkC;aACnC;YACD,IAAI,EAAE;gBACJ,YAAY;gBACZ,uBAAuB;gBACvB,kBAAkB;gBAClB,+BAA+B;aAChC;YACD,IAAI,EAAE;gBACJ,yBAAyB;gBACzB,iCAAiC;gBACjC,cAAc;gBACd,qBAAqB;aACtB;YACD,OAAO,EAAE;gBACP,aAAa;gBACb,eAAe;aAChB;SACF,CAAC;IA7QF,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;;;;;;;;OAaG;IACI,4BAA4B;QACjC,OAAO,IAAI,CAAC,EAAE,CAAC,4BAA4B,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;;;;;OAUG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;;;;OASG;IACI,qBAAqB;QAC1B,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;;;;;;;;OAaG;IACI,iCAAiC;QACtC,OAAO,IAAI,CAAC,EAAE,CAAC,iCAAiC,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;OAMG;IACI,YAAY;QACjB,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,+BAA+B;QACpC,OAAO,IAAI,CAAC,EAAE,CAAC,+BAA+B,CAAC,CAAC;IAClD,CAAC;IAED;;;;;;OAMG;IACI,yBAAyB;QAC9B,OAAO,IAAI,CAAC,EAAE,CAAC,yBAAyB,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;;OAMG;IACI,iCAAiC;QACtC,OAAO,IAAI,CAAC,EAAE,CAAC,iCAAiC,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;OAMG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACI,qBAAqB;QAC1B,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;;;;;OAUG;IACI,aAAa;QAClB,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;;;;OASG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,kCAAkC;QACvC,OAAO,IAAI,CAAC,EAAE,CAAC,kCAAkC,CAAC,CAAC;IACrD,CAAC;IA+BD;;;;;;;;;;;;OAYG;IACI,SAAS,CAAC,UAAkB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACxF,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,YAAa,UAAW,EAAE,CAAC,CAAC;IAC9K,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,oBAAoB,CAAC,UAAkB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACnG,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,wBAAyB,UAAW,EAAE,CAAC,CAAC;IAC1L,CAAC;IAED;;;;;;;;;;;;;OAaG;IACI,eAAe,CAAC,MAAc,EAAE,KAAwB,EAAE,QAA4B;QAC3F,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAmB,MAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IAChF,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,gBAAgB,CAAC,MAAc,EAAE,KAAwB,EAAE,QAA4B;QAC5F,OAAO,IAAI,CAAC,EAAE,CAAC,mBAAoB,MAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjF,CAAC;IAED;;;;;;;;;;;;;OAaG;IACI,YAAY,CAAC,KAAwB,EAAE,QAA4B;QACxE,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjE,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,2BAA2B,CAAC,KAAwB,EAAE,QAA4B;QACvF,OAAO,IAAI,CAAC,EAAE,CAAC,2BAA2B,EAAE,KAAK,EAAE,QAAQ,IAAI,eAAe,CAAC,CAAC;IAClF,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,mBAAmB,CAAC,KAAwB,EAAE,QAA4B;QAC/E,OAAO,IAAI,CAAC,EAAE,CAAC,mBAAmB,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACvE,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,qBAAqB,CAAC,KAAwB,EAAE,QAA4B;QACjF,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACzE,CAAC;IAED;;;;;;;;;;;OAWG;IACI,cAAc,CAAC,KAAwB,EAAE,QAA4B;QAC1E,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,IAAI,SAAS,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;;;;;;OAWG;IACI,aAAa,CAAC,KAAwB,EAAE,QAA4B;QACzE,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjE,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,eAAe,CAAC,KAAwB,EAAE,QAA4B;QAC3E,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACnE,CAAC;CACF;AAndD,0CAmdC","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\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   * 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   */\n  constructor(sid?: string) {\n    super(sid);\n  }\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"]}
|