iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
447 lines • 41.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.BackupGateway = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [backup-gateway](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsbackupgateway.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class BackupGateway extends shared_1.PolicyStatement {
/**
* Statement provider for service [backup-gateway](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsbackupgateway.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 = 'backup-gateway';
this.accessLevelList = {
Write: [
'AssociateGatewayToServer',
'Backup',
'CreateGateway',
'DeleteGateway',
'DeleteHypervisor',
'DisassociateGatewayFromServer',
'ImportHypervisorConfiguration',
'PutBandwidthRateLimitSchedule',
'PutHypervisorPropertyMappings',
'PutMaintenanceStartTime',
'Restore',
'StartVirtualMachinesMetadataSync',
'TestHypervisorConfiguration',
'UpdateGatewayInformation',
'UpdateGatewaySoftwareNow',
'UpdateHypervisor'
],
Read: [
'GetBandwidthRateLimitSchedule',
'GetGateway',
'GetHypervisor',
'GetHypervisorPropertyMappings',
'GetVirtualMachine',
'ListGateways',
'ListHypervisors',
'ListTagsForResource',
'ListVirtualMachines'
],
Tagging: [
'TagResource',
'UntagResource'
]
};
}
/**
* Grants permission to AssociateGatewayToServer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_AssociateGatewayToServer.html
*/
toAssociateGatewayToServer() {
return this.to('AssociateGatewayToServer');
}
/**
* Grants permission to Backup
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_StartBackupJob.html
*/
toBackup() {
return this.to('Backup');
}
/**
* Grants permission to to CreateGateway
*
* Access Level: Write
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_CreateGateway.html
*/
toCreateGateway() {
return this.to('CreateGateway');
}
/**
* Grants permission to DeleteGateway
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DeleteGateway.html
*/
toDeleteGateway() {
return this.to('DeleteGateway');
}
/**
* Grants permission to DeleteHypervisor
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DeleteHypervisor.html
*/
toDeleteHypervisor() {
return this.to('DeleteHypervisor');
}
/**
* Grants permission to DisassociateGatewayFromServer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DisassociateGatewayFromServer.html
*/
toDisassociateGatewayFromServer() {
return this.to('DisassociateGatewayFromServer');
}
/**
* Grants permission to GetBandwidthRateLimitSchedule
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetBandwidthRateLimitSchedule.html
*/
toGetBandwidthRateLimitSchedule() {
return this.to('GetBandwidthRateLimitSchedule');
}
/**
* Grants permission to GetGateway
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetGateway.html
*/
toGetGateway() {
return this.to('GetGateway');
}
/**
* Grants permission to GetHypervisor
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetHypervisor.html
*/
toGetHypervisor() {
return this.to('GetHypervisor');
}
/**
* Grants permission to GetHypervisorPropertyMappings
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetHypervisorPropertyMappings.html
*/
toGetHypervisorPropertyMappings() {
return this.to('GetHypervisorPropertyMappings');
}
/**
* Grants permission to GetVirtualMachine
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetVirtualMachine.html
*/
toGetVirtualMachine() {
return this.to('GetVirtualMachine');
}
/**
* Grants permission to ImportHypervisorConfiguration
*
* Access Level: Write
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ImportHypervisorConfiguration.html
*/
toImportHypervisorConfiguration() {
return this.to('ImportHypervisorConfiguration');
}
/**
* Grants permission to ListGateways
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListGateways.html
*/
toListGateways() {
return this.to('ListGateways');
}
/**
* Grants permission to ListHypervisors
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListHypervisors.html
*/
toListHypervisors() {
return this.to('ListHypervisors');
}
/**
* Grants permission to ListTagsForResource
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListTagsForResource.html
*/
toListTagsForResource() {
return this.to('ListTagsForResource');
}
/**
* Grants permission to ListVirtualMachines
*
* Access Level: Read
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListVirtualMachines.html
*/
toListVirtualMachines() {
return this.to('ListVirtualMachines');
}
/**
* Grants permission to PutBandwidthRateLimitSchedule
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutBandwidthRateLimitSchedule.html
*/
toPutBandwidthRateLimitSchedule() {
return this.to('PutBandwidthRateLimitSchedule');
}
/**
* Grants permission to PutHypervisorPropertyMappings
*
* Access Level: Write
*
* Dependent actions:
* - iam:PassRole
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutHypervisorPropertyMappings.html
*/
toPutHypervisorPropertyMappings() {
return this.to('PutHypervisorPropertyMappings');
}
/**
* Grants permission to PutMaintenanceStartTime
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutMaintenanceStartTime.html
*/
toPutMaintenanceStartTime() {
return this.to('PutMaintenanceStartTime');
}
/**
* Grants permission to Restore
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_StartRestoreJob.html
*/
toRestore() {
return this.to('Restore');
}
/**
* Grants permission to StartVirtualMachinesMetadataSync
*
* Access Level: Write
*
* Dependent actions:
* - iam:PassRole
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_StartVirtualMachinesMetadataSync.html
*/
toStartVirtualMachinesMetadataSync() {
return this.to('StartVirtualMachinesMetadataSync');
}
/**
* Grants permission to TagResource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_TagResource.html
*/
toTagResource() {
return this.to('TagResource');
}
/**
* Grants permission to TestHypervisorConfiguration
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_TestHypervisorConfiguration.html
*/
toTestHypervisorConfiguration() {
return this.to('TestHypervisorConfiguration');
}
/**
* Grants permission to UntagResource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UntagResource.html
*/
toUntagResource() {
return this.to('UntagResource');
}
/**
* Grants permission to UpdateGatewayInformation
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateGatewayInformation.html
*/
toUpdateGatewayInformation() {
return this.to('UpdateGatewayInformation');
}
/**
* Grants permission to UpdateGatewaySoftwareNow
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateGatewaySoftwareNow.html
*/
toUpdateGatewaySoftwareNow() {
return this.to('UpdateGatewaySoftwareNow');
}
/**
* Grants permission to UpdateHypervisor
*
* Access Level: Write
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateHypervisor.html
*/
toUpdateHypervisor() {
return this.to('UpdateHypervisor');
}
/**
* Adds a resource of type gateway to the statement
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_Gateway.html
*
* @param gatewayId - Identifier for the gatewayId.
* @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()
*/
onGateway(gatewayId, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:backup-gateway:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:gateway/${gatewayId}`);
}
/**
* Adds a resource of type hypervisor to the statement
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_Hypervisor.html
*
* @param hypervisorId - Identifier for the hypervisorId.
* @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()
*/
onHypervisor(hypervisorId, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:backup-gateway:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:hypervisor/${hypervisorId}`);
}
/**
* Adds a resource of type virtualmachine to the statement
*
* https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_VirtualMachine.html
*
* @param virtualmachineId - Identifier for the virtualmachineId.
* @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()
*/
onVirtualmachine(virtualmachineId, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:backup-gateway:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:vm/${virtualmachineId}`);
}
/**
* Filters access by the allowed set of values for each of the tags
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag
*
* Applies to actions:
* - .toCreateGateway()
* - .toImportHypervisorConfiguration()
* - .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-value associated with the resource
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag
*
* Applies to resource types:
* - gateway
* - hypervisor
* - virtualmachine
*
* @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 mandatory tags in the request
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys
*
* Applies to actions:
* - .toCreateGateway()
* - .toImportHypervisorConfiguration()
* - .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.BackupGateway = BackupGateway;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"backupgateway.js","sourceRoot":"","sources":["backupgateway.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 [backup-gateway](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsbackupgateway.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 BackupGateway extends PolicyStatement {\n  public servicePrefix = 'backup-gateway';\n\n  /**\n   * Statement provider for service [backup-gateway](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsbackupgateway.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 AssociateGatewayToServer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_AssociateGatewayToServer.html\n   */\n  public toAssociateGatewayToServer() {\n    return this.to('AssociateGatewayToServer');\n  }\n\n  /**\n   * Grants permission to Backup\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_StartBackupJob.html\n   */\n  public toBackup() {\n    return this.to('Backup');\n  }\n\n  /**\n   * Grants permission to to CreateGateway\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_CreateGateway.html\n   */\n  public toCreateGateway() {\n    return this.to('CreateGateway');\n  }\n\n  /**\n   * Grants permission to DeleteGateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DeleteGateway.html\n   */\n  public toDeleteGateway() {\n    return this.to('DeleteGateway');\n  }\n\n  /**\n   * Grants permission to DeleteHypervisor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DeleteHypervisor.html\n   */\n  public toDeleteHypervisor() {\n    return this.to('DeleteHypervisor');\n  }\n\n  /**\n   * Grants permission to DisassociateGatewayFromServer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_DisassociateGatewayFromServer.html\n   */\n  public toDisassociateGatewayFromServer() {\n    return this.to('DisassociateGatewayFromServer');\n  }\n\n  /**\n   * Grants permission to GetBandwidthRateLimitSchedule\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetBandwidthRateLimitSchedule.html\n   */\n  public toGetBandwidthRateLimitSchedule() {\n    return this.to('GetBandwidthRateLimitSchedule');\n  }\n\n  /**\n   * Grants permission to GetGateway\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetGateway.html\n   */\n  public toGetGateway() {\n    return this.to('GetGateway');\n  }\n\n  /**\n   * Grants permission to GetHypervisor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetHypervisor.html\n   */\n  public toGetHypervisor() {\n    return this.to('GetHypervisor');\n  }\n\n  /**\n   * Grants permission to GetHypervisorPropertyMappings\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetHypervisorPropertyMappings.html\n   */\n  public toGetHypervisorPropertyMappings() {\n    return this.to('GetHypervisorPropertyMappings');\n  }\n\n  /**\n   * Grants permission to GetVirtualMachine\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_GetVirtualMachine.html\n   */\n  public toGetVirtualMachine() {\n    return this.to('GetVirtualMachine');\n  }\n\n  /**\n   * Grants permission to ImportHypervisorConfiguration\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ImportHypervisorConfiguration.html\n   */\n  public toImportHypervisorConfiguration() {\n    return this.to('ImportHypervisorConfiguration');\n  }\n\n  /**\n   * Grants permission to ListGateways\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListGateways.html\n   */\n  public toListGateways() {\n    return this.to('ListGateways');\n  }\n\n  /**\n   * Grants permission to ListHypervisors\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListHypervisors.html\n   */\n  public toListHypervisors() {\n    return this.to('ListHypervisors');\n  }\n\n  /**\n   * Grants permission to ListTagsForResource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to ListVirtualMachines\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_ListVirtualMachines.html\n   */\n  public toListVirtualMachines() {\n    return this.to('ListVirtualMachines');\n  }\n\n  /**\n   * Grants permission to PutBandwidthRateLimitSchedule\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutBandwidthRateLimitSchedule.html\n   */\n  public toPutBandwidthRateLimitSchedule() {\n    return this.to('PutBandwidthRateLimitSchedule');\n  }\n\n  /**\n   * Grants permission to PutHypervisorPropertyMappings\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - iam:PassRole\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutHypervisorPropertyMappings.html\n   */\n  public toPutHypervisorPropertyMappings() {\n    return this.to('PutHypervisorPropertyMappings');\n  }\n\n  /**\n   * Grants permission to PutMaintenanceStartTime\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_PutMaintenanceStartTime.html\n   */\n  public toPutMaintenanceStartTime() {\n    return this.to('PutMaintenanceStartTime');\n  }\n\n  /**\n   * Grants permission to Restore\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_StartRestoreJob.html\n   */\n  public toRestore() {\n    return this.to('Restore');\n  }\n\n  /**\n   * Grants permission to StartVirtualMachinesMetadataSync\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - iam:PassRole\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_StartVirtualMachinesMetadataSync.html\n   */\n  public toStartVirtualMachinesMetadataSync() {\n    return this.to('StartVirtualMachinesMetadataSync');\n  }\n\n  /**\n   * Grants permission to TagResource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to TestHypervisorConfiguration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_TestHypervisorConfiguration.html\n   */\n  public toTestHypervisorConfiguration() {\n    return this.to('TestHypervisorConfiguration');\n  }\n\n  /**\n   * Grants permission to UntagResource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to UpdateGatewayInformation\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateGatewayInformation.html\n   */\n  public toUpdateGatewayInformation() {\n    return this.to('UpdateGatewayInformation');\n  }\n\n  /**\n   * Grants permission to UpdateGatewaySoftwareNow\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateGatewaySoftwareNow.html\n   */\n  public toUpdateGatewaySoftwareNow() {\n    return this.to('UpdateGatewaySoftwareNow');\n  }\n\n  /**\n   * Grants permission to UpdateHypervisor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_UpdateHypervisor.html\n   */\n  public toUpdateHypervisor() {\n    return this.to('UpdateHypervisor');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AssociateGatewayToServer',\n      'Backup',\n      'CreateGateway',\n      'DeleteGateway',\n      'DeleteHypervisor',\n      'DisassociateGatewayFromServer',\n      'ImportHypervisorConfiguration',\n      'PutBandwidthRateLimitSchedule',\n      'PutHypervisorPropertyMappings',\n      'PutMaintenanceStartTime',\n      'Restore',\n      'StartVirtualMachinesMetadataSync',\n      'TestHypervisorConfiguration',\n      'UpdateGatewayInformation',\n      'UpdateGatewaySoftwareNow',\n      'UpdateHypervisor'\n    ],\n    Read: [\n      'GetBandwidthRateLimitSchedule',\n      'GetGateway',\n      'GetHypervisor',\n      'GetHypervisorPropertyMappings',\n      'GetVirtualMachine',\n      'ListGateways',\n      'ListHypervisors',\n      'ListTagsForResource',\n      'ListVirtualMachines'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type gateway to the statement\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_Gateway.html\n   *\n   * @param gatewayId - Identifier for the gatewayId.\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 onGateway(gatewayId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:backup-gateway:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:gateway/${ gatewayId }`);\n  }\n\n  /**\n   * Adds a resource of type hypervisor to the statement\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_Hypervisor.html\n   *\n   * @param hypervisorId - Identifier for the hypervisorId.\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 onHypervisor(hypervisorId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:backup-gateway:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:hypervisor/${ hypervisorId }`);\n  }\n\n  /**\n   * Adds a resource of type virtualmachine to the statement\n   *\n   * https://docs.aws.amazon.com/aws-backup/latest/devguide/API_BGW_VirtualMachine.html\n   *\n   * @param virtualmachineId - Identifier for the virtualmachineId.\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 onVirtualmachine(virtualmachineId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:backup-gateway:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:vm/${ virtualmachineId }`);\n  }\n\n  /**\n   * Filters access by the allowed set of values for each of the tags\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .toCreateGateway()\n   * - .toImportHypervisorConfiguration()\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-value associated with the resource\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag\n   *\n   * Applies to resource types:\n   * - gateway\n   * - hypervisor\n   * - virtualmachine\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 mandatory tags 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   * - .toCreateGateway()\n   * - .toImportHypervisorConfiguration()\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"]}