iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
382 lines • 38.9 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Kafkaconnect = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [kafkaconnect](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmanagedstreamingforkafkaconnect.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class Kafkaconnect extends shared_1.PolicyStatement {
/**
* Statement provider for service [kafkaconnect](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmanagedstreamingforkafkaconnect.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
constructor(sid) {
super(sid);
this.servicePrefix = 'kafkaconnect';
this.accessLevelList = {
Write: [
'CreateConnector',
'CreateCustomPlugin',
'CreateWorkerConfiguration',
'DeleteConnector',
'DeleteCustomPlugin',
'DeleteWorkerConfiguration',
'UpdateConnector'
],
Read: [
'DescribeConnector',
'DescribeConnectorOperation',
'DescribeCustomPlugin',
'DescribeWorkerConfiguration',
'ListConnectorOperations',
'ListConnectors',
'ListCustomPlugins',
'ListTagsForResource',
'ListWorkerConfigurations'
],
Tagging: [
'TagResource',
'UntagResource'
]
};
}
/**
* Grants permission to create an MSK Connect connector
*
* Access Level: Write
*
* Dependent actions:
* - ec2:CreateNetworkInterface
* - ec2:DescribeSecurityGroups
* - ec2:DescribeSubnets
* - ec2:DescribeVpcs
* - firehose:TagDeliveryStream
* - iam:AttachRolePolicy
* - iam:CreateServiceLinkedRole
* - iam:PassRole
* - iam:PutRolePolicy
* - logs:CreateLogDelivery
* - logs:DescribeLogGroups
* - logs:DescribeResourcePolicies
* - logs:GetLogDelivery
* - logs:ListLogDeliveries
* - logs:PutResourcePolicy
* - s3:GetBucketPolicy
* - s3:PutBucketPolicy
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateConnector.html
*/
toCreateConnector() {
return this.to('CreateConnector');
}
/**
* Grants permission to create an MSK Connect custom plugin
*
* Access Level: Write
*
* Dependent actions:
* - s3:GetObject
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateCustomPlugin.html
*/
toCreateCustomPlugin() {
return this.to('CreateCustomPlugin');
}
/**
* Grants permission to create an MSK Connect worker configuration
*
* Access Level: Write
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateWorkerConfiguration.html
*/
toCreateWorkerConfiguration() {
return this.to('CreateWorkerConfiguration');
}
/**
* Grants permission to delete an MSK Connect connector
*
* Access Level: Write
*
* Dependent actions:
* - logs:DeleteLogDelivery
* - logs:ListLogDeliveries
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteConnector.html
*/
toDeleteConnector() {
return this.to('DeleteConnector');
}
/**
* Grants permission to delete an MSK Connect custom plugin
*
* Access Level: Write
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteCustomPlugin.html
*/
toDeleteCustomPlugin() {
return this.to('DeleteCustomPlugin');
}
/**
* Grants permission to delete an MSK Connect worker configuration
*
* Access Level: Write
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteWorkerConfiguration.html
*/
toDeleteWorkerConfiguration() {
return this.to('DeleteWorkerConfiguration');
}
/**
* Grants permission to describe an MSK Connect connector
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeConnector.html
*/
toDescribeConnector() {
return this.to('DescribeConnector');
}
/**
* Grants permission to describe a MSK Connect connector operation
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeConnectorOperation.html
*/
toDescribeConnectorOperation() {
return this.to('DescribeConnectorOperation');
}
/**
* Grants permission to describe an MSK Connect custom plugin
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeCustomPlugin.html
*/
toDescribeCustomPlugin() {
return this.to('DescribeCustomPlugin');
}
/**
* Grants permission to describe an MSK Connect worker configuration
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeWorkerConfiguration.html
*/
toDescribeWorkerConfiguration() {
return this.to('DescribeWorkerConfiguration');
}
/**
* Grants permission to list all operations of a given MSK Connect connector
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListConnectorOperations.html
*/
toListConnectorOperations() {
return this.to('ListConnectorOperations');
}
/**
* Grants permission to list all MSK Connect connectors in this account
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListConnectors.html
*/
toListConnectors() {
return this.to('ListConnectors');
}
/**
* Grants permission to list all MSK Connect custom plugins in this account
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListCustomPlugins.html
*/
toListCustomPlugins() {
return this.to('ListCustomPlugins');
}
/**
* Grants permission to list tags of an MSK Connect resource
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListTagsForResource.html
*/
toListTagsForResource() {
return this.to('ListTagsForResource');
}
/**
* Grants permission to list all MSK Connect worker configurations in this account
*
* Access Level: Read
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListWorkerConfigurations.html
*/
toListWorkerConfigurations() {
return this.to('ListWorkerConfigurations');
}
/**
* Grants permission to tag an MSK Connect resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_TagResource.html
*/
toTagResource() {
return this.to('TagResource');
}
/**
* Grants permission to remove tags from an MSK Connect resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_UntagResource.html
*/
toUntagResource() {
return this.to('UntagResource');
}
/**
* Grants permission to update an MSK Connect connector
*
* Access Level: Write
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_UpdateConnector.html
*/
toUpdateConnector() {
return this.to('UpdateConnector');
}
/**
* Adds a resource of type connector to the statement
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ConnectorSummary.html
*
* @param connectorName - Identifier for the connectorName.
* @param uUID - Identifier for the uUID.
* @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
* @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
* @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.
*
* Possible conditions:
* - .ifAwsResourceTag()
*/
onConnector(connectorName, uUID, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:kafkaconnect:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:connector/${connectorName}/${uUID}`);
}
/**
* Adds a resource of type custom plugin to the statement
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_CustomPlugin.html
*
* @param customPluginName - Identifier for the customPluginName.
* @param uUID - Identifier for the uUID.
* @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
* @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
* @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.
*
* Possible conditions:
* - .ifAwsResourceTag()
*/
onCustomPlugin(customPluginName, uUID, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:kafkaconnect:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:custom-plugin/${customPluginName}/${uUID}`);
}
/**
* Adds a resource of type worker configuration to the statement
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_WorkerConfiguration.html
*
* @param workerConfigurationName - Identifier for the workerConfigurationName.
* @param uUID - Identifier for the uUID.
* @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
* @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
* @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.
*
* Possible conditions:
* - .ifAwsResourceTag()
*/
onWorkerConfiguration(workerConfigurationName, uUID, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:kafkaconnect:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:worker-configuration/${workerConfigurationName}/${uUID}`);
}
/**
* Adds a resource of type connector operation to the statement
*
* https://docs.aws.amazon.com/MSKC/latest/mskc/API_ConnectorOperation.html
*
* @param connectorName - Identifier for the connectorName.
* @param connectorUUID - Identifier for the connectorUUID.
* @param uUID - Identifier for the uUID.
* @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
* @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
* @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.
*
* Possible conditions:
* - .ifAwsResourceTag()
*/
onConnectorOperation(connectorName, connectorUUID, uUID, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:kafkaconnect:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:connector-operation/${connectorName}/${connectorUUID}/${uUID}`);
}
/**
* Filters access by the presence of tag key-value pairs in the request
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag
*
* Applies to actions:
* - .toTagResource()
*
* @param tagKey The tag key to check
* @param value The value(s) to check
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
*/
ifAwsRequestTag(tagKey, value, operator) {
return this.if(`aws:RequestTag/${tagKey}`, value, operator ?? 'StringLike');
}
/**
* Filters access by tag key-value pairs attached to the resource
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag
*
* Applies to actions:
* - .toListTagsForResource()
* - .toTagResource()
*
* Applies to resource types:
* - connector
* - custom plugin
* - worker configuration
* - connector operation
*
* @param tagKey The tag key to check
* @param value The value(s) to check
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
*/
ifAwsResourceTag(tagKey, value, operator) {
return this.if(`aws:ResourceTag/${tagKey}`, value, operator ?? 'StringLike');
}
/**
* Filters access by the presence of tag keys in the request
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys
*
* Applies to actions:
* - .toTagResource()
* - .toUntagResource()
*
* @param value The value(s) to check
* @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`
*/
ifAwsTagKeys(value, operator) {
return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');
}
}
exports.Kafkaconnect = Kafkaconnect;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managedstreamingforkafkaconnect.js","sourceRoot":"","sources":["managedstreamingforkafkaconnect.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\n\n/**\n * Statement provider for service [kafkaconnect](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmanagedstreamingforkafkaconnect.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 Kafkaconnect extends PolicyStatement {\n  public servicePrefix = 'kafkaconnect';\n\n  /**\n   * Statement provider for service [kafkaconnect](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmanagedstreamingforkafkaconnect.html).\n   *\n   * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n   */\n  constructor(sid?: string) {\n    super(sid);\n  }\n\n  /**\n   * Grants permission to create an MSK Connect connector\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - ec2:CreateNetworkInterface\n   * - ec2:DescribeSecurityGroups\n   * - ec2:DescribeSubnets\n   * - ec2:DescribeVpcs\n   * - firehose:TagDeliveryStream\n   * - iam:AttachRolePolicy\n   * - iam:CreateServiceLinkedRole\n   * - iam:PassRole\n   * - iam:PutRolePolicy\n   * - logs:CreateLogDelivery\n   * - logs:DescribeLogGroups\n   * - logs:DescribeResourcePolicies\n   * - logs:GetLogDelivery\n   * - logs:ListLogDeliveries\n   * - logs:PutResourcePolicy\n   * - s3:GetBucketPolicy\n   * - s3:PutBucketPolicy\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateConnector.html\n   */\n  public toCreateConnector() {\n    return this.to('CreateConnector');\n  }\n\n  /**\n   * Grants permission to create an MSK Connect custom plugin\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - s3:GetObject\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateCustomPlugin.html\n   */\n  public toCreateCustomPlugin() {\n    return this.to('CreateCustomPlugin');\n  }\n\n  /**\n   * Grants permission to create an MSK Connect worker configuration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_CreateWorkerConfiguration.html\n   */\n  public toCreateWorkerConfiguration() {\n    return this.to('CreateWorkerConfiguration');\n  }\n\n  /**\n   * Grants permission to delete an MSK Connect connector\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - logs:DeleteLogDelivery\n   * - logs:ListLogDeliveries\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteConnector.html\n   */\n  public toDeleteConnector() {\n    return this.to('DeleteConnector');\n  }\n\n  /**\n   * Grants permission to delete an MSK Connect custom plugin\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteCustomPlugin.html\n   */\n  public toDeleteCustomPlugin() {\n    return this.to('DeleteCustomPlugin');\n  }\n\n  /**\n   * Grants permission to delete an MSK Connect worker configuration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DeleteWorkerConfiguration.html\n   */\n  public toDeleteWorkerConfiguration() {\n    return this.to('DeleteWorkerConfiguration');\n  }\n\n  /**\n   * Grants permission to describe an MSK Connect connector\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeConnector.html\n   */\n  public toDescribeConnector() {\n    return this.to('DescribeConnector');\n  }\n\n  /**\n   * Grants permission to describe a MSK Connect connector operation\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeConnectorOperation.html\n   */\n  public toDescribeConnectorOperation() {\n    return this.to('DescribeConnectorOperation');\n  }\n\n  /**\n   * Grants permission to describe an MSK Connect custom plugin\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeCustomPlugin.html\n   */\n  public toDescribeCustomPlugin() {\n    return this.to('DescribeCustomPlugin');\n  }\n\n  /**\n   * Grants permission to describe an MSK Connect worker configuration\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_DescribeWorkerConfiguration.html\n   */\n  public toDescribeWorkerConfiguration() {\n    return this.to('DescribeWorkerConfiguration');\n  }\n\n  /**\n   * Grants permission to list all operations of a given MSK Connect connector\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListConnectorOperations.html\n   */\n  public toListConnectorOperations() {\n    return this.to('ListConnectorOperations');\n  }\n\n  /**\n   * Grants permission to list all MSK Connect connectors in this account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListConnectors.html\n   */\n  public toListConnectors() {\n    return this.to('ListConnectors');\n  }\n\n  /**\n   * Grants permission to list all MSK Connect custom plugins in this account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListCustomPlugins.html\n   */\n  public toListCustomPlugins() {\n    return this.to('ListCustomPlugins');\n  }\n\n  /**\n   * Grants permission to list tags of an MSK Connect resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list all MSK Connect worker configurations in this account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ListWorkerConfigurations.html\n   */\n  public toListWorkerConfigurations() {\n    return this.to('ListWorkerConfigurations');\n  }\n\n  /**\n   * Grants permission to tag an MSK Connect resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from an MSK Connect resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update an MSK Connect connector\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_UpdateConnector.html\n   */\n  public toUpdateConnector() {\n    return this.to('UpdateConnector');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateConnector',\n      'CreateCustomPlugin',\n      'CreateWorkerConfiguration',\n      'DeleteConnector',\n      'DeleteCustomPlugin',\n      'DeleteWorkerConfiguration',\n      'UpdateConnector'\n    ],\n    Read: [\n      'DescribeConnector',\n      'DescribeConnectorOperation',\n      'DescribeCustomPlugin',\n      'DescribeWorkerConfiguration',\n      'ListConnectorOperations',\n      'ListConnectors',\n      'ListCustomPlugins',\n      'ListTagsForResource',\n      'ListWorkerConfigurations'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type connector to the statement\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ConnectorSummary.html\n   *\n   * @param connectorName - Identifier for the connectorName.\n   * @param uUID - Identifier for the uUID.\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 onConnector(connectorName: string, uUID: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:kafkaconnect:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:connector/${ connectorName }/${ uUID }`);\n  }\n\n  /**\n   * Adds a resource of type custom plugin to the statement\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_CustomPlugin.html\n   *\n   * @param customPluginName - Identifier for the customPluginName.\n   * @param uUID - Identifier for the uUID.\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 onCustomPlugin(customPluginName: string, uUID: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:kafkaconnect:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:custom-plugin/${ customPluginName }/${ uUID }`);\n  }\n\n  /**\n   * Adds a resource of type worker configuration to the statement\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_WorkerConfiguration.html\n   *\n   * @param workerConfigurationName - Identifier for the workerConfigurationName.\n   * @param uUID - Identifier for the uUID.\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 onWorkerConfiguration(workerConfigurationName: string, uUID: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:kafkaconnect:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:worker-configuration/${ workerConfigurationName }/${ uUID }`);\n  }\n\n  /**\n   * Adds a resource of type connector operation to the statement\n   *\n   * https://docs.aws.amazon.com/MSKC/latest/mskc/API_ConnectorOperation.html\n   *\n   * @param connectorName - Identifier for the connectorName.\n   * @param connectorUUID - Identifier for the connectorUUID.\n   * @param uUID - Identifier for the uUID.\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 onConnectorOperation(connectorName: string, connectorUUID: string, uUID: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:kafkaconnect:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:connector-operation/${ connectorName }/${ connectorUUID }/${ uUID }`);\n  }\n\n  /**\n   * Filters access by the presence of tag key-value pairs in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .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 actions:\n   * - .toListTagsForResource()\n   * - .toTagResource()\n   *\n   * Applies to resource types:\n   * - connector\n   * - custom plugin\n   * - worker configuration\n   * - connector operation\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the presence of tag keys in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .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"]}