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
- - 2292 Condition keys
21
+ - 2298 Condition keys
22
22
  <!-- /stats -->
23
23
 
24
24
  ![EXPERIMENTAL](https://img.shields.io/badge/stability-experimantal-orange?style=for-the-badge)**<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
@@ -7,7 +7,7 @@
7
7
  },
8
8
  "name": "cdk-iam-floyd",
9
9
  "description": "AWS IAM policy statement generator with fluent interface for AWS CDK",
10
- "version": "0.763.0",
10
+ "version": "0.764.0",
11
11
  "license": "Apache-2.0",
12
12
  "author": {
13
13
  "name": "Daniel Schroeder",