cdk-iam-floyd 0.627.0 → 0.628.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
@@ -17,8 +17,8 @@
17
17
  Support for:
18
18
 
19
19
  - 390 Services
20
- - 16542 Actions
21
- - 1773 Resource Types
20
+ - 16552 Actions
21
+ - 1775 Resource Types
22
22
  - 1721 Condition keys
23
23
  <!-- /stats -->
24
24
 
@@ -36,6 +36,14 @@ export declare class Internetmonitor extends PolicyStatement {
36
36
  * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetHealthEvent.html
37
37
  */
38
38
  toGetHealthEvent(): this;
39
+ /**
40
+ * Grants permission to get information about a specified internet event
41
+ *
42
+ * Access Level: Read
43
+ *
44
+ * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetInternetEvent.html
45
+ */
46
+ toGetInternetEvent(): this;
39
47
  /**
40
48
  * Grants permission to get information about a monitor
41
49
  *
@@ -76,6 +84,14 @@ export declare class Internetmonitor extends PolicyStatement {
76
84
  * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListHealthEvents.html
77
85
  */
78
86
  toListHealthEvents(): this;
87
+ /**
88
+ * Grants permission to list all internet events
89
+ *
90
+ * Access Level: List
91
+ *
92
+ * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListInternetEvents.html
93
+ */
94
+ toListInternetEvents(): this;
79
95
  /**
80
96
  * Grants permission to list all monitors in an account and their statuses
81
97
  *
@@ -166,6 +182,16 @@ export declare class Internetmonitor extends PolicyStatement {
166
182
  * - .ifAwsResourceTag()
167
183
  */
168
184
  onMonitor(monitorName: string, account?: string, region?: string, partition?: string): this;
185
+ /**
186
+ * Adds a resource of type InternetEvent to the statement
187
+ *
188
+ * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html
189
+ *
190
+ * @param internetEventId - Identifier for the internetEventId.
191
+ * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
192
+ * @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.
193
+ */
194
+ onInternetEvent(internetEventId: string, account?: string, partition?: string): this;
169
195
  /**
170
196
  * Filters access by tag key-value pairs in the request
171
197
  *
@@ -42,6 +42,16 @@ class Internetmonitor extends shared_1.PolicyStatement {
42
42
  toGetHealthEvent() {
43
43
  return this.to('GetHealthEvent');
44
44
  }
45
+ /**
46
+ * Grants permission to get information about a specified internet event
47
+ *
48
+ * Access Level: Read
49
+ *
50
+ * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetInternetEvent.html
51
+ */
52
+ toGetInternetEvent() {
53
+ return this.to('GetInternetEvent');
54
+ }
45
55
  /**
46
56
  * Grants permission to get information about a monitor
47
57
  *
@@ -92,6 +102,16 @@ class Internetmonitor extends shared_1.PolicyStatement {
92
102
  toListHealthEvents() {
93
103
  return this.to('ListHealthEvents');
94
104
  }
105
+ /**
106
+ * Grants permission to list all internet events
107
+ *
108
+ * Access Level: List
109
+ *
110
+ * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListInternetEvents.html
111
+ */
112
+ toListInternetEvents() {
113
+ return this.to('ListInternetEvents');
114
+ }
95
115
  /**
96
116
  * Grants permission to list all monitors in an account and their statuses
97
117
  *
@@ -199,6 +219,18 @@ class Internetmonitor extends shared_1.PolicyStatement {
199
219
  onMonitor(monitorName, account, region, partition) {
200
220
  return this.on(`arn:${partition ?? this.defaultPartition}:internetmonitor:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:monitor/${monitorName}`);
201
221
  }
222
+ /**
223
+ * Adds a resource of type InternetEvent to the statement
224
+ *
225
+ * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html
226
+ *
227
+ * @param internetEventId - Identifier for the internetEventId.
228
+ * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
229
+ * @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.
230
+ */
231
+ onInternetEvent(internetEventId, account, partition) {
232
+ return this.on(`arn:${partition ?? this.defaultPartition}:internetmonitor::${account ?? this.defaultAccount}:internet-event/${internetEventId}`);
233
+ }
202
234
  /**
203
235
  * Filters access by tag key-value pairs in the request
204
236
  *
@@ -262,6 +294,7 @@ class Internetmonitor extends shared_1.PolicyStatement {
262
294
  ],
263
295
  Read: [
264
296
  'GetHealthEvent',
297
+ 'GetInternetEvent',
265
298
  'GetMonitor',
266
299
  'GetQueryResults',
267
300
  'GetQueryStatus',
@@ -271,6 +304,7 @@ class Internetmonitor extends shared_1.PolicyStatement {
271
304
  ],
272
305
  List: [
273
306
  'ListHealthEvents',
307
+ 'ListInternetEvents',
274
308
  'ListMonitors'
275
309
  ],
276
310
  Tagging: [
@@ -281,4 +315,4 @@ class Internetmonitor extends shared_1.PolicyStatement {
281
315
  }
282
316
  }
283
317
  exports.Internetmonitor = Internetmonitor;
284
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudwatchinternetmonitor.js","sourceRoot":"","sources":["cloudwatchinternetmonitor.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 [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.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 Internetmonitor extends PolicyStatement {\n  public servicePrefix = 'internetmonitor';\n\n  /**\n   * Grants permission to create a monitor\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_CreateMonitor.html\n   */\n  public toCreateMonitor() {\n    return this.to('CreateMonitor');\n  }\n\n  /**\n   * Grants permission to delete a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_DeleteMonitor.html\n   */\n  public toDeleteMonitor() {\n    return this.to('DeleteMonitor');\n  }\n\n  /**\n   * Grants permission to get information about a health event for a specified monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetHealthEvent.html\n   */\n  public toGetHealthEvent() {\n    return this.to('GetHealthEvent');\n  }\n\n  /**\n   * Grants permission to get information about a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetMonitor.html\n   */\n  public toGetMonitor() {\n    return this.to('GetMonitor');\n  }\n\n  /**\n   * Grants permission to get results for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryResults.html\n   */\n  public toGetQueryResults() {\n    return this.to('GetQueryResults');\n  }\n\n  /**\n   * Grants permission to get status for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryStatus.html\n   */\n  public toGetQueryStatus() {\n    return this.to('GetQueryStatus');\n  }\n\n  /**\n   * Grants permission to share Internet Monitor resources with a monitoring account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-Unified-Cross-Account-Setup.html#CloudWatch-Unified-Cross-Account-Setup-permissions\n   */\n  public toLink() {\n    return this.to('Link');\n  }\n\n  /**\n   * Grants permission to list all health events for a monitor\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListHealthEvents.html\n   */\n  public toListHealthEvents() {\n    return this.to('ListHealthEvents');\n  }\n\n  /**\n   * Grants permission to list all monitors in an account and their statuses\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListMonitors.html\n   */\n  public toListMonitors() {\n    return this.to('ListMonitors');\n  }\n\n  /**\n   * Grants permission to list the tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to start a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StartQuery.html\n   */\n  public toStartQuery() {\n    return this.to('StartQuery');\n  }\n\n  /**\n   * Grants permission to stop a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StopQuery.html\n   */\n  public toStopQuery() {\n    return this.to('StopQuery');\n  }\n\n  /**\n   * Grants permission to add tags to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UpdateMonitor.html\n   */\n  public toUpdateMonitor() {\n    return this.to('UpdateMonitor');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateMonitor',\n      'DeleteMonitor',\n      'Link',\n      'UpdateMonitor'\n    ],\n    Read: [\n      'GetHealthEvent',\n      'GetMonitor',\n      'GetQueryResults',\n      'GetQueryStatus',\n      'ListTagsForResource',\n      'StartQuery',\n      'StopQuery'\n    ],\n    List: [\n      'ListHealthEvents',\n      'ListMonitors'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type HealthEvent to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param eventId - Identifier for the eventId.\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  public onHealthEvent(monitorName: string, eventId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }/health-event/${ eventId }`);\n  }\n\n  /**\n   * Adds a resource of type Monitor to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\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 onMonitor(monitorName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }`);\n  }\n\n  /**\n   * Filters access by 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   * - .toCreateMonitor()\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 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   * - Monitor\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 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   * - .toCreateMonitor()\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 [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudwatchinternetmonitor.js","sourceRoot":"","sources":["cloudwatchinternetmonitor.ts"],"names":[],"mappings":";;;AACA,yCAAyD;AAGzD;;;;GAIG;AACH,MAAa,eAAgB,SAAQ,wBAAe;IAGlD;;;;;;;;;;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;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,YAAY;QACjB,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB;QACtB,OAAO,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,MAAM;QACX,OAAO,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IACzB,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,oBAAoB;QACzB,OAAO,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC;IACvC,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,YAAY;QACjB,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACI,WAAW;QAChB,OAAO,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC;IAC9B,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;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IA8BD;;;;;;;;;;OAUG;IACI,aAAa,CAAC,WAAmB,EAAE,OAAe,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QAC9G,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,YAAa,WAAY,iBAAkB,OAAQ,EAAE,CAAC,CAAC;IACzM,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,SAAS,CAAC,WAAmB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACzF,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,YAAa,WAAY,EAAE,CAAC,CAAC;IAC/K,CAAC;IAED;;;;;;;;OAQG;IACI,eAAe,CAAC,eAAuB,EAAE,OAAgB,EAAE,SAAkB;QAClF,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,qBAAsB,OAAO,IAAI,IAAI,CAAC,cAAe,mBAAoB,eAAgB,EAAE,CAAC,CAAC;IACzJ,CAAC;IAED;;;;;;;;;;;;OAYG;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;;;;;;;;;;;OAWG;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;;;;;;;;;;;;OAYG;IACI,YAAY,CAAC,KAAwB,EAAE,QAA4B;QACxE,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjE,CAAC;IAED;;;OAGG;IACH,YAAY,KAAgC;QAC1C,KAAK,CAAC,KAAK,CAAC,CAAC;QAxUR,kBAAa,GAAG,iBAAiB,CAAC;QAwM/B,oBAAe,GAAoB;YAC3C,KAAK,EAAE;gBACL,eAAe;gBACf,eAAe;gBACf,MAAM;gBACN,eAAe;aAChB;YACD,IAAI,EAAE;gBACJ,gBAAgB;gBAChB,kBAAkB;gBAClB,YAAY;gBACZ,iBAAiB;gBACjB,gBAAgB;gBAChB,qBAAqB;gBACrB,YAAY;gBACZ,WAAW;aACZ;YACD,IAAI,EAAE;gBACJ,kBAAkB;gBAClB,oBAAoB;gBACpB,cAAc;aACf;YACD,OAAO,EAAE;gBACP,aAAa;gBACb,eAAe;aAChB;SACF,CAAC;IAuGF,CAAC;CACF;AA3UD,0CA2UC","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 [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.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 Internetmonitor extends PolicyStatement {\n  public servicePrefix = 'internetmonitor';\n\n  /**\n   * Grants permission to create a monitor\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_CreateMonitor.html\n   */\n  public toCreateMonitor() {\n    return this.to('CreateMonitor');\n  }\n\n  /**\n   * Grants permission to delete a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_DeleteMonitor.html\n   */\n  public toDeleteMonitor() {\n    return this.to('DeleteMonitor');\n  }\n\n  /**\n   * Grants permission to get information about a health event for a specified monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetHealthEvent.html\n   */\n  public toGetHealthEvent() {\n    return this.to('GetHealthEvent');\n  }\n\n  /**\n   * Grants permission to get information about a specified internet event\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetInternetEvent.html\n   */\n  public toGetInternetEvent() {\n    return this.to('GetInternetEvent');\n  }\n\n  /**\n   * Grants permission to get information about a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetMonitor.html\n   */\n  public toGetMonitor() {\n    return this.to('GetMonitor');\n  }\n\n  /**\n   * Grants permission to get results for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryResults.html\n   */\n  public toGetQueryResults() {\n    return this.to('GetQueryResults');\n  }\n\n  /**\n   * Grants permission to get status for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryStatus.html\n   */\n  public toGetQueryStatus() {\n    return this.to('GetQueryStatus');\n  }\n\n  /**\n   * Grants permission to share Internet Monitor resources with a monitoring account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-Unified-Cross-Account-Setup.html#CloudWatch-Unified-Cross-Account-Setup-permissions\n   */\n  public toLink() {\n    return this.to('Link');\n  }\n\n  /**\n   * Grants permission to list all health events for a monitor\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListHealthEvents.html\n   */\n  public toListHealthEvents() {\n    return this.to('ListHealthEvents');\n  }\n\n  /**\n   * Grants permission to list all internet events\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListInternetEvents.html\n   */\n  public toListInternetEvents() {\n    return this.to('ListInternetEvents');\n  }\n\n  /**\n   * Grants permission to list all monitors in an account and their statuses\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListMonitors.html\n   */\n  public toListMonitors() {\n    return this.to('ListMonitors');\n  }\n\n  /**\n   * Grants permission to list the tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to start a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StartQuery.html\n   */\n  public toStartQuery() {\n    return this.to('StartQuery');\n  }\n\n  /**\n   * Grants permission to stop a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StopQuery.html\n   */\n  public toStopQuery() {\n    return this.to('StopQuery');\n  }\n\n  /**\n   * Grants permission to add tags to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UpdateMonitor.html\n   */\n  public toUpdateMonitor() {\n    return this.to('UpdateMonitor');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateMonitor',\n      'DeleteMonitor',\n      'Link',\n      'UpdateMonitor'\n    ],\n    Read: [\n      'GetHealthEvent',\n      'GetInternetEvent',\n      'GetMonitor',\n      'GetQueryResults',\n      'GetQueryStatus',\n      'ListTagsForResource',\n      'StartQuery',\n      'StopQuery'\n    ],\n    List: [\n      'ListHealthEvents',\n      'ListInternetEvents',\n      'ListMonitors'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type HealthEvent to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param eventId - Identifier for the eventId.\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  public onHealthEvent(monitorName: string, eventId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }/health-event/${ eventId }`);\n  }\n\n  /**\n   * Adds a resource of type Monitor to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\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 onMonitor(monitorName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }`);\n  }\n\n  /**\n   * Adds a resource of type InternetEvent to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param internetEventId - Identifier for the internetEventId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\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  public onInternetEvent(internetEventId: string, account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor::${ account ?? this.defaultAccount }:internet-event/${ internetEventId }`);\n  }\n\n  /**\n   * Filters access by 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   * - .toCreateMonitor()\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 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   * - Monitor\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 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   * - .toCreateMonitor()\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 [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
@@ -41,6 +41,18 @@ export declare class EmrContainers extends PolicyStatement {
41
41
  * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateManagedEndpoint.html
42
42
  */
43
43
  toCreateManagedEndpoint(): this;
44
+ /**
45
+ * Grants permission to create a security configuration
46
+ *
47
+ * Access Level: Write
48
+ *
49
+ * Possible conditions:
50
+ * - .ifAwsRequestTag()
51
+ * - .ifAwsTagKeys()
52
+ *
53
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateSecurityConfiguration.html
54
+ */
55
+ toCreateSecurityConfiguration(): this;
44
56
  /**
45
57
  * Grants permission to create a virtual cluster
46
58
  *
@@ -101,6 +113,14 @@ export declare class EmrContainers extends PolicyStatement {
101
113
  * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeManagedEndpoint.html
102
114
  */
103
115
  toDescribeManagedEndpoint(): this;
116
+ /**
117
+ * Grants permission to describe a security configuration
118
+ *
119
+ * Access Level: Read
120
+ *
121
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeSecurityConfiguration.html
122
+ */
123
+ toDescribeSecurityConfiguration(): this;
104
124
  /**
105
125
  * Grants permission to describe a virtual cluster
106
126
  *
@@ -141,6 +161,14 @@ export declare class EmrContainers extends PolicyStatement {
141
161
  * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListManagedEndpoints.html
142
162
  */
143
163
  toListManagedEndpoints(): this;
164
+ /**
165
+ * Grants permission to list security configurations
166
+ *
167
+ * Access Level: List
168
+ *
169
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListSecurityConfigurations.html
170
+ */
171
+ toListSecurityConfigurations(): this;
144
172
  /**
145
173
  * Grants permission to list tags for the specified resource
146
174
  *
@@ -253,6 +281,20 @@ export declare class EmrContainers extends PolicyStatement {
253
281
  * - .ifAwsResourceTag()
254
282
  */
255
283
  onManagedEndpoint(virtualClusterId: string, endpointId: string, account?: string, region?: string, partition?: string): this;
284
+ /**
285
+ * Adds a resource of type securityConfiguration to the statement
286
+ *
287
+ * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/security-configurations.html
288
+ *
289
+ * @param securityConfigurationId - Identifier for the securityConfigurationId.
290
+ * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
291
+ * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
292
+ * @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.
293
+ *
294
+ * Possible conditions:
295
+ * - .ifAwsResourceTag()
296
+ */
297
+ onSecurityConfiguration(securityConfigurationId: string, account?: string, region?: string, partition?: string): this;
256
298
  /**
257
299
  * Filters access by the tag key-value pairs present in the request
258
300
  *
@@ -261,6 +303,7 @@ export declare class EmrContainers extends PolicyStatement {
261
303
  * Applies to actions:
262
304
  * - .toCreateJobTemplate()
263
305
  * - .toCreateManagedEndpoint()
306
+ * - .toCreateSecurityConfiguration()
264
307
  * - .toCreateVirtualCluster()
265
308
  * - .toStartJobRun()
266
309
  * - .toTagResource()
@@ -280,6 +323,7 @@ export declare class EmrContainers extends PolicyStatement {
280
323
  * - jobRun
281
324
  * - jobTemplate
282
325
  * - managedEndpoint
326
+ * - securityConfiguration
283
327
  *
284
328
  * @param tagKey The tag key to check
285
329
  * @param value The value(s) to check
@@ -294,6 +338,7 @@ export declare class EmrContainers extends PolicyStatement {
294
338
  * Applies to actions:
295
339
  * - .toCreateJobTemplate()
296
340
  * - .toCreateManagedEndpoint()
341
+ * - .toCreateSecurityConfiguration()
297
342
  * - .toCreateVirtualCluster()
298
343
  * - .toStartJobRun()
299
344
  * - .toTagResource()
@@ -47,6 +47,20 @@ class EmrContainers extends shared_1.PolicyStatement {
47
47
  toCreateManagedEndpoint() {
48
48
  return this.to('CreateManagedEndpoint');
49
49
  }
50
+ /**
51
+ * Grants permission to create a security configuration
52
+ *
53
+ * Access Level: Write
54
+ *
55
+ * Possible conditions:
56
+ * - .ifAwsRequestTag()
57
+ * - .ifAwsTagKeys()
58
+ *
59
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateSecurityConfiguration.html
60
+ */
61
+ toCreateSecurityConfiguration() {
62
+ return this.to('CreateSecurityConfiguration');
63
+ }
50
64
  /**
51
65
  * Grants permission to create a virtual cluster
52
66
  *
@@ -121,6 +135,16 @@ class EmrContainers extends shared_1.PolicyStatement {
121
135
  toDescribeManagedEndpoint() {
122
136
  return this.to('DescribeManagedEndpoint');
123
137
  }
138
+ /**
139
+ * Grants permission to describe a security configuration
140
+ *
141
+ * Access Level: Read
142
+ *
143
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeSecurityConfiguration.html
144
+ */
145
+ toDescribeSecurityConfiguration() {
146
+ return this.to('DescribeSecurityConfiguration');
147
+ }
124
148
  /**
125
149
  * Grants permission to describe a virtual cluster
126
150
  *
@@ -171,6 +195,16 @@ class EmrContainers extends shared_1.PolicyStatement {
171
195
  toListManagedEndpoints() {
172
196
  return this.to('ListManagedEndpoints');
173
197
  }
198
+ /**
199
+ * Grants permission to list security configurations
200
+ *
201
+ * Access Level: List
202
+ *
203
+ * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListSecurityConfigurations.html
204
+ */
205
+ toListSecurityConfigurations() {
206
+ return this.to('ListSecurityConfigurations');
207
+ }
174
208
  /**
175
209
  * Grants permission to list tags for the specified resource
176
210
  *
@@ -300,6 +334,22 @@ class EmrContainers extends shared_1.PolicyStatement {
300
334
  onManagedEndpoint(virtualClusterId, endpointId, account, region, partition) {
301
335
  return this.on(`arn:${partition ?? this.defaultPartition}:emr-containers:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/virtualclusters/${virtualClusterId}/endpoints/${endpointId}`);
302
336
  }
337
+ /**
338
+ * Adds a resource of type securityConfiguration to the statement
339
+ *
340
+ * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/security-configurations.html
341
+ *
342
+ * @param securityConfigurationId - Identifier for the securityConfigurationId.
343
+ * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
344
+ * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
345
+ * @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.
346
+ *
347
+ * Possible conditions:
348
+ * - .ifAwsResourceTag()
349
+ */
350
+ onSecurityConfiguration(securityConfigurationId, account, region, partition) {
351
+ return this.on(`arn:${partition ?? this.defaultPartition}:emr-containers:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/securityconfigurations/${securityConfigurationId}`);
352
+ }
303
353
  /**
304
354
  * Filters access by the tag key-value pairs present in the request
305
355
  *
@@ -308,6 +358,7 @@ class EmrContainers extends shared_1.PolicyStatement {
308
358
  * Applies to actions:
309
359
  * - .toCreateJobTemplate()
310
360
  * - .toCreateManagedEndpoint()
361
+ * - .toCreateSecurityConfiguration()
311
362
  * - .toCreateVirtualCluster()
312
363
  * - .toStartJobRun()
313
364
  * - .toTagResource()
@@ -329,6 +380,7 @@ class EmrContainers extends shared_1.PolicyStatement {
329
380
  * - jobRun
330
381
  * - jobTemplate
331
382
  * - managedEndpoint
383
+ * - securityConfiguration
332
384
  *
333
385
  * @param tagKey The tag key to check
334
386
  * @param value The value(s) to check
@@ -345,6 +397,7 @@ class EmrContainers extends shared_1.PolicyStatement {
345
397
  * Applies to actions:
346
398
  * - .toCreateJobTemplate()
347
399
  * - .toCreateManagedEndpoint()
400
+ * - .toCreateSecurityConfiguration()
348
401
  * - .toCreateVirtualCluster()
349
402
  * - .toStartJobRun()
350
403
  * - .toTagResource()
@@ -397,6 +450,7 @@ class EmrContainers extends shared_1.PolicyStatement {
397
450
  'CancelJobRun',
398
451
  'CreateJobTemplate',
399
452
  'CreateManagedEndpoint',
453
+ 'CreateSecurityConfiguration',
400
454
  'CreateVirtualCluster',
401
455
  'DeleteJobTemplate',
402
456
  'DeleteManagedEndpoint',
@@ -408,12 +462,14 @@ class EmrContainers extends shared_1.PolicyStatement {
408
462
  'DescribeJobRun',
409
463
  'DescribeJobTemplate',
410
464
  'DescribeManagedEndpoint',
465
+ 'DescribeSecurityConfiguration',
411
466
  'DescribeVirtualCluster'
412
467
  ],
413
468
  List: [
414
469
  'ListJobRuns',
415
470
  'ListJobTemplates',
416
471
  'ListManagedEndpoints',
472
+ 'ListSecurityConfigurations',
417
473
  'ListTagsForResource',
418
474
  'ListVirtualClusters'
419
475
  ],
@@ -425,4 +481,4 @@ class EmrContainers extends shared_1.PolicyStatement {
425
481
  }
426
482
  }
427
483
  exports.EmrContainers = EmrContainers;
428
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emroneksemrcontainers.js","sourceRoot":"","sources":["emroneksemrcontainers.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 [emr-containers](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonemroneksemrcontainers.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 EmrContainers extends PolicyStatement {\n  public servicePrefix = 'emr-containers';\n\n  /**\n   * Grants permission to cancel a job run\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CancelJobRun.html\n   */\n  public toCancelJobRun() {\n    return this.to('CancelJobRun');\n  }\n\n  /**\n   * Grants permission to create a job template\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateJobTemplate.html\n   */\n  public toCreateJobTemplate() {\n    return this.to('CreateJobTemplate');\n  }\n\n  /**\n   * Grants permission to create a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   * - .ifExecutionRoleArn()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateManagedEndpoint.html\n   */\n  public toCreateManagedEndpoint() {\n    return this.to('CreateManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to create a virtual cluster\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateVirtualCluster.html\n   */\n  public toCreateVirtualCluster() {\n    return this.to('CreateVirtualCluster');\n  }\n\n  /**\n   * Grants permission to delete a job template\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteJobTemplate.html\n   */\n  public toDeleteJobTemplate() {\n    return this.to('DeleteJobTemplate');\n  }\n\n  /**\n   * Grants permission to delete a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteManagedEndpoint.html\n   */\n  public toDeleteManagedEndpoint() {\n    return this.to('DeleteManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to delete a virtual cluster\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteVirtualCluster.html\n   */\n  public toDeleteVirtualCluster() {\n    return this.to('DeleteVirtualCluster');\n  }\n\n  /**\n   * Grants permission to describe a job run\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeJobRun.html\n   */\n  public toDescribeJobRun() {\n    return this.to('DescribeJobRun');\n  }\n\n  /**\n   * Grants permission to describe a job template\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeJobTemplate.html\n   */\n  public toDescribeJobTemplate() {\n    return this.to('DescribeJobTemplate');\n  }\n\n  /**\n   * Grants permission to describe a managed endpoint\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeManagedEndpoint.html\n   */\n  public toDescribeManagedEndpoint() {\n    return this.to('DescribeManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to describe a virtual cluster\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeVirtualCluster.html\n   */\n  public toDescribeVirtualCluster() {\n    return this.to('DescribeVirtualCluster');\n  }\n\n  /**\n   * Grants permission to generate a session token used to connect to a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_GetManagedEndpointSessionCredentials.html\n   */\n  public toGetManagedEndpointSessionCredentials() {\n    return this.to('GetManagedEndpointSessionCredentials');\n  }\n\n  /**\n   * Grants permission to list job runs associated with a virtual cluster\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListJobRuns.html\n   */\n  public toListJobRuns() {\n    return this.to('ListJobRuns');\n  }\n\n  /**\n   * Grants permission to list job templates\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListJobTemplates.html\n   */\n  public toListJobTemplates() {\n    return this.to('ListJobTemplates');\n  }\n\n  /**\n   * Grants permission to list managed endpoints associated with a virtual cluster\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListManagedEndpoints.html\n   */\n  public toListManagedEndpoints() {\n    return this.to('ListManagedEndpoints');\n  }\n\n  /**\n   * Grants permission to list tags for the specified resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list virtual clusters\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListVirtualClusters.html\n   */\n  public toListVirtualClusters() {\n    return this.to('ListVirtualClusters');\n  }\n\n  /**\n   * Grants permission to start a job run\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   * - .ifExecutionRoleArn()\n   * - .ifJobTemplateArn()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_StartJobRun.html\n   */\n  public toStartJobRun() {\n    return this.to('StartJobRun');\n  }\n\n  /**\n   * Grants permission to tag the specified resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to untag the specified resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CancelJobRun',\n      'CreateJobTemplate',\n      'CreateManagedEndpoint',\n      'CreateVirtualCluster',\n      'DeleteJobTemplate',\n      'DeleteManagedEndpoint',\n      'DeleteVirtualCluster',\n      'GetManagedEndpointSessionCredentials',\n      'StartJobRun'\n    ],\n    Read: [\n      'DescribeJobRun',\n      'DescribeJobTemplate',\n      'DescribeManagedEndpoint',\n      'DescribeVirtualCluster'\n    ],\n    List: [\n      'ListJobRuns',\n      'ListJobTemplates',\n      'ListManagedEndpoints',\n      'ListTagsForResource',\n      'ListVirtualClusters'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type virtualCluster to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/virtual-cluster.html\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\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 onVirtualCluster(virtualClusterId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }`);\n  }\n\n  /**\n   * Adds a resource of type jobRun to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/job-runs.html\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\n   * @param jobRunId - Identifier for the jobRunId.\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 onJobRun(virtualClusterId: string, jobRunId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }/jobruns/${ jobRunId }`);\n  }\n\n  /**\n   * Adds a resource of type jobTemplate to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/job-templates.html\n   *\n   * @param jobTemplateId - Identifier for the jobTemplateId.\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 onJobTemplate(jobTemplateId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/jobtemplates/${ jobTemplateId }`);\n  }\n\n  /**\n   * Adds a resource of type managedEndpoint to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/ManagementGuide/emr-studio-create-eks-cluster.html#emr-studio-create-managed-endpoint\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\n   * @param endpointId - Identifier for the endpointId.\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 onManagedEndpoint(virtualClusterId: string, endpointId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }/endpoints/${ endpointId }`);\n  }\n\n  /**\n   * Filters access by the tag key-value pairs present 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   * - .toCreateJobTemplate()\n   * - .toCreateManagedEndpoint()\n   * - .toCreateVirtualCluster()\n   * - .toStartJobRun()\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 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   * - virtualCluster\n   * - jobRun\n   * - jobTemplate\n   * - managedEndpoint\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 tag keys present 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   * - .toCreateJobTemplate()\n   * - .toCreateManagedEndpoint()\n   * - .toCreateVirtualCluster()\n   * - .toStartJobRun()\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 the execution role arn present in the request\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/iam-execution-role.html\n   *\n   * Applies to actions:\n   * - .toCreateManagedEndpoint()\n   * - .toStartJobRun()\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 ifExecutionRoleArn(value: string | string[], operator?: Operator | string) {\n    return this.if(`ExecutionRoleArn`, value, operator ?? 'ArnLike');\n  }\n\n  /**\n   * Filters access by the job template arn present in the request\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/iam-job-template.html\n   *\n   * Applies to actions:\n   * - .toStartJobRun()\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 ifJobTemplateArn(value: string | string[], operator?: Operator | string) {\n    return this.if(`JobTemplateArn`, value, operator ?? 'ArnLike');\n  }\n\n  /**\n   * Statement provider for service [emr-containers](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonemroneksemrcontainers.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
484
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emroneksemrcontainers.js","sourceRoot":"","sources":["emroneksemrcontainers.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 [emr-containers](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonemroneksemrcontainers.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 EmrContainers extends PolicyStatement {\n  public servicePrefix = 'emr-containers';\n\n  /**\n   * Grants permission to cancel a job run\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CancelJobRun.html\n   */\n  public toCancelJobRun() {\n    return this.to('CancelJobRun');\n  }\n\n  /**\n   * Grants permission to create a job template\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateJobTemplate.html\n   */\n  public toCreateJobTemplate() {\n    return this.to('CreateJobTemplate');\n  }\n\n  /**\n   * Grants permission to create a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   * - .ifExecutionRoleArn()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateManagedEndpoint.html\n   */\n  public toCreateManagedEndpoint() {\n    return this.to('CreateManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to create a security configuration\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateSecurityConfiguration.html\n   */\n  public toCreateSecurityConfiguration() {\n    return this.to('CreateSecurityConfiguration');\n  }\n\n  /**\n   * Grants permission to create a virtual cluster\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_CreateVirtualCluster.html\n   */\n  public toCreateVirtualCluster() {\n    return this.to('CreateVirtualCluster');\n  }\n\n  /**\n   * Grants permission to delete a job template\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteJobTemplate.html\n   */\n  public toDeleteJobTemplate() {\n    return this.to('DeleteJobTemplate');\n  }\n\n  /**\n   * Grants permission to delete a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteManagedEndpoint.html\n   */\n  public toDeleteManagedEndpoint() {\n    return this.to('DeleteManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to delete a virtual cluster\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DeleteVirtualCluster.html\n   */\n  public toDeleteVirtualCluster() {\n    return this.to('DeleteVirtualCluster');\n  }\n\n  /**\n   * Grants permission to describe a job run\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeJobRun.html\n   */\n  public toDescribeJobRun() {\n    return this.to('DescribeJobRun');\n  }\n\n  /**\n   * Grants permission to describe a job template\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeJobTemplate.html\n   */\n  public toDescribeJobTemplate() {\n    return this.to('DescribeJobTemplate');\n  }\n\n  /**\n   * Grants permission to describe a managed endpoint\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeManagedEndpoint.html\n   */\n  public toDescribeManagedEndpoint() {\n    return this.to('DescribeManagedEndpoint');\n  }\n\n  /**\n   * Grants permission to describe a security configuration\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeSecurityConfiguration.html\n   */\n  public toDescribeSecurityConfiguration() {\n    return this.to('DescribeSecurityConfiguration');\n  }\n\n  /**\n   * Grants permission to describe a virtual cluster\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_DescribeVirtualCluster.html\n   */\n  public toDescribeVirtualCluster() {\n    return this.to('DescribeVirtualCluster');\n  }\n\n  /**\n   * Grants permission to generate a session token used to connect to a managed endpoint\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_GetManagedEndpointSessionCredentials.html\n   */\n  public toGetManagedEndpointSessionCredentials() {\n    return this.to('GetManagedEndpointSessionCredentials');\n  }\n\n  /**\n   * Grants permission to list job runs associated with a virtual cluster\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListJobRuns.html\n   */\n  public toListJobRuns() {\n    return this.to('ListJobRuns');\n  }\n\n  /**\n   * Grants permission to list job templates\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListJobTemplates.html\n   */\n  public toListJobTemplates() {\n    return this.to('ListJobTemplates');\n  }\n\n  /**\n   * Grants permission to list managed endpoints associated with a virtual cluster\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListManagedEndpoints.html\n   */\n  public toListManagedEndpoints() {\n    return this.to('ListManagedEndpoints');\n  }\n\n  /**\n   * Grants permission to list security configurations\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListSecurityConfigurations.html\n   */\n  public toListSecurityConfigurations() {\n    return this.to('ListSecurityConfigurations');\n  }\n\n  /**\n   * Grants permission to list tags for the specified resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list virtual clusters\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_ListVirtualClusters.html\n   */\n  public toListVirtualClusters() {\n    return this.to('ListVirtualClusters');\n  }\n\n  /**\n   * Grants permission to start a job run\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   * - .ifExecutionRoleArn()\n   * - .ifJobTemplateArn()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_StartJobRun.html\n   */\n  public toStartJobRun() {\n    return this.to('StartJobRun');\n  }\n\n  /**\n   * Grants permission to tag the specified resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to untag the specified resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/emr-on-eks/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CancelJobRun',\n      'CreateJobTemplate',\n      'CreateManagedEndpoint',\n      'CreateSecurityConfiguration',\n      'CreateVirtualCluster',\n      'DeleteJobTemplate',\n      'DeleteManagedEndpoint',\n      'DeleteVirtualCluster',\n      'GetManagedEndpointSessionCredentials',\n      'StartJobRun'\n    ],\n    Read: [\n      'DescribeJobRun',\n      'DescribeJobTemplate',\n      'DescribeManagedEndpoint',\n      'DescribeSecurityConfiguration',\n      'DescribeVirtualCluster'\n    ],\n    List: [\n      'ListJobRuns',\n      'ListJobTemplates',\n      'ListManagedEndpoints',\n      'ListSecurityConfigurations',\n      'ListTagsForResource',\n      'ListVirtualClusters'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type virtualCluster to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/virtual-cluster.html\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\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 onVirtualCluster(virtualClusterId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }`);\n  }\n\n  /**\n   * Adds a resource of type jobRun to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/job-runs.html\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\n   * @param jobRunId - Identifier for the jobRunId.\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 onJobRun(virtualClusterId: string, jobRunId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }/jobruns/${ jobRunId }`);\n  }\n\n  /**\n   * Adds a resource of type jobTemplate to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/job-templates.html\n   *\n   * @param jobTemplateId - Identifier for the jobTemplateId.\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 onJobTemplate(jobTemplateId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/jobtemplates/${ jobTemplateId }`);\n  }\n\n  /**\n   * Adds a resource of type managedEndpoint to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/ManagementGuide/emr-studio-create-eks-cluster.html#emr-studio-create-managed-endpoint\n   *\n   * @param virtualClusterId - Identifier for the virtualClusterId.\n   * @param endpointId - Identifier for the endpointId.\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 onManagedEndpoint(virtualClusterId: string, endpointId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/virtualclusters/${ virtualClusterId }/endpoints/${ endpointId }`);\n  }\n\n  /**\n   * Adds a resource of type securityConfiguration to the statement\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/security-configurations.html\n   *\n   * @param securityConfigurationId - Identifier for the securityConfigurationId.\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 onSecurityConfiguration(securityConfigurationId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:emr-containers:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/securityconfigurations/${ securityConfigurationId }`);\n  }\n\n  /**\n   * Filters access by the tag key-value pairs present 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   * - .toCreateJobTemplate()\n   * - .toCreateManagedEndpoint()\n   * - .toCreateSecurityConfiguration()\n   * - .toCreateVirtualCluster()\n   * - .toStartJobRun()\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 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   * - virtualCluster\n   * - jobRun\n   * - jobTemplate\n   * - managedEndpoint\n   * - securityConfiguration\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 tag keys present 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   * - .toCreateJobTemplate()\n   * - .toCreateManagedEndpoint()\n   * - .toCreateSecurityConfiguration()\n   * - .toCreateVirtualCluster()\n   * - .toStartJobRun()\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 the execution role arn present in the request\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/iam-execution-role.html\n   *\n   * Applies to actions:\n   * - .toCreateManagedEndpoint()\n   * - .toStartJobRun()\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 ifExecutionRoleArn(value: string | string[], operator?: Operator | string) {\n    return this.if(`ExecutionRoleArn`, value, operator ?? 'ArnLike');\n  }\n\n  /**\n   * Filters access by the job template arn present in the request\n   *\n   * https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/iam-job-template.html\n   *\n   * Applies to actions:\n   * - .toStartJobRun()\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 ifJobTemplateArn(value: string | string[], operator?: Operator | string) {\n    return this.if(`JobTemplateArn`, value, operator ?? 'ArnLike');\n  }\n\n  /**\n   * Statement provider for service [emr-containers](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonemroneksemrcontainers.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}