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 +2 -2
- package/lib/generated/policy-statements/cloudwatchinternetmonitor.d.ts +26 -0
- package/lib/generated/policy-statements/cloudwatchinternetmonitor.js +35 -1
- package/lib/generated/policy-statements/emroneksemrcontainers.d.ts +45 -0
- package/lib/generated/policy-statements/emroneksemrcontainers.js +57 -1
- package/lib/generated/policy-statements/kinesisanalyticsv2.d.ts +37 -31
- package/lib/generated/policy-statements/kinesisanalyticsv2.js +38 -32
- package/lib/generated/policy-statements/outposts.d.ts +40 -0
- package/lib/generated/policy-statements/outposts.js +56 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -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":"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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 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"]}
|