UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

427 lines 40.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Mq = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [mq](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmq.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class Mq extends shared_1.PolicyStatement { /** * Statement provider for service [mq](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmq.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 = 'mq'; this.accessLevelList = { Write: [ 'CreateBroker', 'CreateConfiguration', 'CreateReplicaBroker', 'CreateUser', 'DeleteBroker', 'DeleteConfiguration', 'DeleteUser', 'Promote', 'RebootBroker', 'UpdateBroker', 'UpdateConfiguration', 'UpdateUser' ], Tagging: [ 'CreateTags', 'DeleteTags' ], Read: [ 'DescribeBroker', 'DescribeBrokerEngineTypes', 'DescribeBrokerInstanceOptions', 'DescribeConfiguration', 'DescribeConfigurationRevision', 'DescribeUser' ], List: [ 'ListBrokers', 'ListConfigurationRevisions', 'ListConfigurations', 'ListTags', 'ListUsers' ] }; } /** * Grants permission to create a broker * * Access Level: Write * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * Dependent actions: * - ec2:CreateNetworkInterface * - ec2:CreateNetworkInterfacePermission * - ec2:CreateSecurityGroup * - ec2:CreateVpcEndpoint * - ec2:DescribeInternetGateways * - ec2:DescribeNetworkInterfacePermissions * - ec2:DescribeNetworkInterfaces * - ec2:DescribeSecurityGroups * - ec2:DescribeSubnets * - ec2:DescribeVpcEndpoints * - ec2:DescribeVpcs * - ec2:ModifyNetworkInterfaceAttribute * - iam:CreateServiceLinkedRole * - route53:AssociateVPCWithHostedZone * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-post */ toCreateBroker() { return this.to('CreateBroker'); } /** * Grants permission to create a new configuration for the specified configuration name. Amazon MQ uses the default configuration (the engine type and engine version) * * Access Level: Write * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-post */ toCreateConfiguration() { return this.to('CreateConfiguration'); } /** * Grants permission to create a replica broker * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-post */ toCreateReplicaBroker() { return this.to('CreateReplicaBroker'); } /** * Grants permission to create tags * * Access Level: Tagging * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-post */ toCreateTags() { return this.to('CreateTags'); } /** * Grants permission to create an ActiveMQ user * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-post */ toCreateUser() { return this.to('CreateUser'); } /** * Grants permission to delete a broker * * Access Level: Write * * Dependent actions: * - ec2:DeleteNetworkInterface * - ec2:DeleteNetworkInterfacePermission * - ec2:DeleteVpcEndpoints * - ec2:DetachNetworkInterface * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-delete */ toDeleteBroker() { return this.to('DeleteBroker'); } /** * Grants permission to delete a configuration * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-delete */ toDeleteConfiguration() { return this.to('DeleteConfiguration'); } /** * Grants permission to delete tags * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-delete */ toDeleteTags() { return this.to('DeleteTags'); } /** * Grants permission to delete an ActiveMQ user * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-delete */ toDeleteUser() { return this.to('DeleteUser'); } /** * Grants permission to return information about the specified broker * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-get */ toDescribeBroker() { return this.to('DescribeBroker'); } /** * Grants permission to return information about broker engines * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/broker-engine-types.html#broker-engine-types-http-methods */ toDescribeBrokerEngineTypes() { return this.to('DescribeBrokerEngineTypes'); } /** * Grants permission to return information about the broker instance options * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/broker-instance-options.html#broker-engine-types-http-methods */ toDescribeBrokerInstanceOptions() { return this.to('DescribeBrokerInstanceOptions'); } /** * Grants permission to return information about the specified configuration * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration.html#rest-api-configuration-methods-get */ toDescribeConfiguration() { return this.to('DescribeConfiguration'); } /** * Grants permission to return the specified configuration revision for the specified configuration * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration-revision.html#rest-api-configuration-revision-methods-get */ toDescribeConfigurationRevision() { return this.to('DescribeConfigurationRevision'); } /** * Grants permission to return information about an ActiveMQ user * * Access Level: Read * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-get */ toDescribeUser() { return this.to('DescribeUser'); } /** * Grants permission to return a list of all brokers * * Access Level: List * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-get */ toListBrokers() { return this.to('ListBrokers'); } /** * Grants permission to return a list of all existing revisions for the specified configuration * * Access Level: List * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-revisions.html#rest-api-revisions-methods-get */ toListConfigurationRevisions() { return this.to('ListConfigurationRevisions'); } /** * Grants permission to return a list of all configurations * * Access Level: List * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-get */ toListConfigurations() { return this.to('ListConfigurations'); } /** * Grants permission to return a list of tags * * Access Level: List * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-get */ toListTags() { return this.to('ListTags'); } /** * Grants permission to return a list of all ActiveMQ users * * Access Level: List * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-users.html#rest-api-users-methods-get */ toListUsers() { return this.to('ListUsers'); } /** * Grants permission to promote a broker * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-promote.html#rest-api-promote-methods-post */ toPromote() { return this.to('Promote'); } /** * Grants permission to reboot a broker * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-restart.html#rest-api-reboot-methods-post */ toRebootBroker() { return this.to('RebootBroker'); } /** * Grants permission to add a pending configuration change to a broker * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-get */ toUpdateBroker() { return this.to('UpdateBroker'); } /** * Grants permission to update the specified configuration * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration.html#rest-api-configuration-methods-put */ toUpdateConfiguration() { return this.to('UpdateConfiguration'); } /** * Grants permission to update the information for an ActiveMQ user * * Access Level: Write * * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-put */ toUpdateUser() { return this.to('UpdateUser'); } /** * Adds a resource of type brokers to the statement * * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/amazon-mq-how-it-works.html * * @param brokerName - Identifier for the brokerName. * @param brokerId - Identifier for the brokerId. * @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() */ onBrokers(brokerName, brokerId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:mq:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:broker:${brokerName}:${brokerId}`); } /** * Adds a resource of type configurations to the statement * * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/amazon-mq-how-it-works.html * * @param configurationId - Identifier for the configurationId. * @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() */ onConfigurations(configurationId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:mq:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:configuration:${configurationId}`); } /** * Filters access by the tags that are passed in the request * * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags * * Applies to actions: * - .toCreateBroker() * - .toCreateConfiguration() * - .toCreateTags() * * @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 the tags associated with the resource * * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags * * Applies to resource types: * - brokers * - configurations * * @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 tag keys that are passed in the request * * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags * * Applies to actions: * - .toCreateBroker() * - .toCreateConfiguration() * - .toCreateTags() * - .toDeleteTags() * * @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.Mq = Mq; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mq.js","sourceRoot":"","sources":["mq.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 [mq](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmq.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 Mq extends PolicyStatement {\n  public servicePrefix = 'mq';\n\n  /**\n   * Statement provider for service [mq](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmq.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 a broker\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * Dependent actions:\n   * - ec2:CreateNetworkInterface\n   * - ec2:CreateNetworkInterfacePermission\n   * - ec2:CreateSecurityGroup\n   * - ec2:CreateVpcEndpoint\n   * - ec2:DescribeInternetGateways\n   * - ec2:DescribeNetworkInterfacePermissions\n   * - ec2:DescribeNetworkInterfaces\n   * - ec2:DescribeSecurityGroups\n   * - ec2:DescribeSubnets\n   * - ec2:DescribeVpcEndpoints\n   * - ec2:DescribeVpcs\n   * - ec2:ModifyNetworkInterfaceAttribute\n   * - iam:CreateServiceLinkedRole\n   * - route53:AssociateVPCWithHostedZone\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-post\n   */\n  public toCreateBroker() {\n    return this.to('CreateBroker');\n  }\n\n  /**\n   * Grants permission to create a new configuration for the specified configuration name. Amazon MQ uses the default configuration (the engine type and engine version)\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-post\n   */\n  public toCreateConfiguration() {\n    return this.to('CreateConfiguration');\n  }\n\n  /**\n   * Grants permission to create a replica broker\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-post\n   */\n  public toCreateReplicaBroker() {\n    return this.to('CreateReplicaBroker');\n  }\n\n  /**\n   * Grants permission to create tags\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-post\n   */\n  public toCreateTags() {\n    return this.to('CreateTags');\n  }\n\n  /**\n   * Grants permission to create an ActiveMQ user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-post\n   */\n  public toCreateUser() {\n    return this.to('CreateUser');\n  }\n\n  /**\n   * Grants permission to delete a broker\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - ec2:DeleteNetworkInterface\n   * - ec2:DeleteNetworkInterfacePermission\n   * - ec2:DeleteVpcEndpoints\n   * - ec2:DetachNetworkInterface\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-delete\n   */\n  public toDeleteBroker() {\n    return this.to('DeleteBroker');\n  }\n\n  /**\n   * Grants permission to delete a configuration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-delete\n   */\n  public toDeleteConfiguration() {\n    return this.to('DeleteConfiguration');\n  }\n\n  /**\n   * Grants permission to delete tags\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-delete\n   */\n  public toDeleteTags() {\n    return this.to('DeleteTags');\n  }\n\n  /**\n   * Grants permission to delete an ActiveMQ user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-delete\n   */\n  public toDeleteUser() {\n    return this.to('DeleteUser');\n  }\n\n  /**\n   * Grants permission to return information about the specified broker\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-get\n   */\n  public toDescribeBroker() {\n    return this.to('DescribeBroker');\n  }\n\n  /**\n   * Grants permission to return information about broker engines\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/broker-engine-types.html#broker-engine-types-http-methods\n   */\n  public toDescribeBrokerEngineTypes() {\n    return this.to('DescribeBrokerEngineTypes');\n  }\n\n  /**\n   * Grants permission to return information about the broker instance options\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/broker-instance-options.html#broker-engine-types-http-methods\n   */\n  public toDescribeBrokerInstanceOptions() {\n    return this.to('DescribeBrokerInstanceOptions');\n  }\n\n  /**\n   * Grants permission to return information about the specified configuration\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration.html#rest-api-configuration-methods-get\n   */\n  public toDescribeConfiguration() {\n    return this.to('DescribeConfiguration');\n  }\n\n  /**\n   * Grants permission to return the specified configuration revision for the specified configuration\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration-revision.html#rest-api-configuration-revision-methods-get\n   */\n  public toDescribeConfigurationRevision() {\n    return this.to('DescribeConfigurationRevision');\n  }\n\n  /**\n   * Grants permission to return information about an ActiveMQ user\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-get\n   */\n  public toDescribeUser() {\n    return this.to('DescribeUser');\n  }\n\n  /**\n   * Grants permission to return a list of all brokers\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-brokers.html#rest-api-brokers-methods-get\n   */\n  public toListBrokers() {\n    return this.to('ListBrokers');\n  }\n\n  /**\n   * Grants permission to return a list of all existing revisions for the specified configuration\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-revisions.html#rest-api-revisions-methods-get\n   */\n  public toListConfigurationRevisions() {\n    return this.to('ListConfigurationRevisions');\n  }\n\n  /**\n   * Grants permission to return a list of all configurations\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configurations.html#rest-api-configurations-methods-get\n   */\n  public toListConfigurations() {\n    return this.to('ListConfigurations');\n  }\n\n  /**\n   * Grants permission to return a list of tags\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-tags.html#rest-api-tags-methods-get\n   */\n  public toListTags() {\n    return this.to('ListTags');\n  }\n\n  /**\n   * Grants permission to return a list of all ActiveMQ users\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-users.html#rest-api-users-methods-get\n   */\n  public toListUsers() {\n    return this.to('ListUsers');\n  }\n\n  /**\n   * Grants permission to promote a broker\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-promote.html#rest-api-promote-methods-post\n   */\n  public toPromote() {\n    return this.to('Promote');\n  }\n\n  /**\n   * Grants permission to reboot a broker\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-restart.html#rest-api-reboot-methods-post\n   */\n  public toRebootBroker() {\n    return this.to('RebootBroker');\n  }\n\n  /**\n   * Grants permission to add a pending configuration change to a broker\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-broker.html#rest-api-broker-methods-get\n   */\n  public toUpdateBroker() {\n    return this.to('UpdateBroker');\n  }\n\n  /**\n   * Grants permission to update the specified configuration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-configuration.html#rest-api-configuration-methods-put\n   */\n  public toUpdateConfiguration() {\n    return this.to('UpdateConfiguration');\n  }\n\n  /**\n   * Grants permission to update the information for an ActiveMQ user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/api-reference/rest-api-username.html#rest-api-username-methods-put\n   */\n  public toUpdateUser() {\n    return this.to('UpdateUser');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateBroker',\n      'CreateConfiguration',\n      'CreateReplicaBroker',\n      'CreateUser',\n      'DeleteBroker',\n      'DeleteConfiguration',\n      'DeleteUser',\n      'Promote',\n      'RebootBroker',\n      'UpdateBroker',\n      'UpdateConfiguration',\n      'UpdateUser'\n    ],\n    Tagging: [\n      'CreateTags',\n      'DeleteTags'\n    ],\n    Read: [\n      'DescribeBroker',\n      'DescribeBrokerEngineTypes',\n      'DescribeBrokerInstanceOptions',\n      'DescribeConfiguration',\n      'DescribeConfigurationRevision',\n      'DescribeUser'\n    ],\n    List: [\n      'ListBrokers',\n      'ListConfigurationRevisions',\n      'ListConfigurations',\n      'ListTags',\n      'ListUsers'\n    ]\n  };\n\n  /**\n   * Adds a resource of type brokers to the statement\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/amazon-mq-how-it-works.html\n   *\n   * @param brokerName - Identifier for the brokerName.\n   * @param brokerId - Identifier for the brokerId.\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 onBrokers(brokerName: string, brokerId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:mq:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:broker:${ brokerName }:${ brokerId }`);\n  }\n\n  /**\n   * Adds a resource of type configurations to the statement\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/amazon-mq-how-it-works.html\n   *\n   * @param configurationId - Identifier for the configurationId.\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 onConfigurations(configurationId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:mq:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:configuration:${ configurationId }`);\n  }\n\n  /**\n   * Filters access by the tags that are passed in the request\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags\n   *\n   * Applies to actions:\n   * - .toCreateBroker()\n   * - .toCreateConfiguration()\n   * - .toCreateTags()\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 tags associated with the resource\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags\n   *\n   * Applies to resource types:\n   * - brokers\n   * - configurations\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 that are passed in the request\n   *\n   * https://docs.aws.amazon.com/amazon-mq/latest/developer-guide/security_iam_service-with-iam.html#security_iam_service-with-iam-tags\n   *\n   * Applies to actions:\n   * - .toCreateBroker()\n   * - .toCreateConfiguration()\n   * - .toCreateTags()\n   * - .toDeleteTags()\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"]}