iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
436 lines • 41.3 kB
JavaScript
"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',
'UpdateBrokerAccessConfiguration',
'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 RabbitMQ broker authentication and authorization configuration
*
* Access Level: Write
*/
toUpdateBrokerAccessConfiguration() {
return this.to('UpdateBrokerAccessConfiguration');
}
/**
* 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 RabbitMQ broker authentication and authorization configuration\n   *\n   * Access Level: Write\n   */\n  public toUpdateBrokerAccessConfiguration() {\n    return this.to('UpdateBrokerAccessConfiguration');\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      'UpdateBrokerAccessConfiguration',\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"]}