UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

382 lines 38.9 kB
"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"]}