iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
574 lines • 57 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Cloud9 = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [cloud9](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscloud9.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class Cloud9 extends shared_1.PolicyStatement {
/**
* Statement provider for service [cloud9](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscloud9.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 = 'cloud9';
this.accessLevelList = {
Write: [
'ActivateEC2Remote',
'CreateEnvironmentEC2',
'CreateEnvironmentMembership',
'CreateEnvironmentSSH',
'DeleteEnvironment',
'DeleteEnvironmentMembership',
'ModifyTemporaryCredentialsOnEnvironmentEC2',
'UpdateEnvironment',
'UpdateEnvironmentMembership',
'UpdateEnvironmentSettings',
'UpdateMembershipSettings',
'UpdateSSHRemote',
'UpdateUserSettings'
],
Read: [
'CreateEnvironmentToken',
'DescribeEC2Remote',
'DescribeEnvironmentMemberships',
'DescribeEnvironmentStatus',
'DescribeEnvironments',
'DescribeSSHRemote',
'GetEnvironmentConfig',
'GetEnvironmentSettings',
'GetMembershipSettings',
'GetMigrationExperiences',
'GetUserPublicKey',
'GetUserSettings',
'ListEnvironments',
'ListTagsForResource'
],
Tagging: [
'TagResource',
'UntagResource'
]
};
}
/**
* Grants permission to start the Amazon EC2 instance that your AWS Cloud9 IDE connects to
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toActivateEC2Remote() {
return this.to('ActivateEC2Remote');
}
/**
* Grants permission to create an AWS Cloud9 development environment, launches an Amazon Elastic Compute Cloud (Amazon EC2) instance, and then hosts the environment on the instance
*
* Access Level: Write
*
* Possible conditions:
* - .ifEnvironmentName()
* - .ifInstanceType()
* - .ifSubnetId()
* - .ifUserArn()
* - .ifOwnerArn()
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* Dependent actions:
* - ec2:DescribeSubnets
* - ec2:DescribeVpcs
* - iam:CreateServiceLinkedRole
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_CreateEnvironmentEC2.html
*/
toCreateEnvironmentEC2() {
return this.to('CreateEnvironmentEC2');
}
/**
* Grants permission to add an environment member to an AWS Cloud9 development environment
*
* Access Level: Write
*
* Possible conditions:
* - .ifUserArn()
* - .ifEnvironmentId()
* - .ifPermissions()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_CreateEnvironmentMembership.html
*/
toCreateEnvironmentMembership() {
return this.to('CreateEnvironmentMembership');
}
/**
* Grants permission to create an AWS Cloud9 SSH development environment
*
* Access Level: Write
*
* Possible conditions:
* - .ifEnvironmentName()
* - .ifOwnerArn()
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toCreateEnvironmentSSH() {
return this.to('CreateEnvironmentSSH');
}
/**
* Grants permission to create an authentication token that allows a connection between the AWS Cloud9 IDE and the user's environment
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toCreateEnvironmentToken() {
return this.to('CreateEnvironmentToken');
}
/**
* Grants permission to delete an AWS Cloud9 development environment. If the environment is hosted on an Amazon Elastic Compute Cloud (Amazon EC2) instance, also terminates the instance
*
* Access Level: Write
*
* Dependent actions:
* - iam:CreateServiceLinkedRole
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DeleteEnvironment.html
*/
toDeleteEnvironment() {
return this.to('DeleteEnvironment');
}
/**
* Grants permission to delete an environment member from an AWS Cloud9 development environment
*
* Access Level: Write
*
* Possible conditions:
* - .ifUserArn()
* - .ifEnvironmentId()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DeleteEnvironmentMembership.html
*/
toDeleteEnvironmentMembership() {
return this.to('DeleteEnvironmentMembership');
}
/**
* Grants permission to get details about the connection to the EC2 development environment, including host, user, and port
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toDescribeEC2Remote() {
return this.to('DescribeEC2Remote');
}
/**
* Grants permission to get information about environment members for an AWS Cloud9 development environment
*
* Access Level: Read
*
* Possible conditions:
* - .ifUserArn()
* - .ifEnvironmentId()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironmentMemberships.html
*/
toDescribeEnvironmentMemberships() {
return this.to('DescribeEnvironmentMemberships');
}
/**
* Grants permission to get status information for an AWS Cloud9 development environment
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironmentStatus.html
*/
toDescribeEnvironmentStatus() {
return this.to('DescribeEnvironmentStatus');
}
/**
* Grants permission to get information about AWS Cloud9 development environments
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironments.html
*/
toDescribeEnvironments() {
return this.to('DescribeEnvironments');
}
/**
* Grants permission to get details about the connection to the SSH development environment, including host, user, and port
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toDescribeSSHRemote() {
return this.to('DescribeSSHRemote');
}
/**
* Grants permission to get configuration information that's used to initialize the AWS Cloud9 IDE
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetEnvironmentConfig() {
return this.to('GetEnvironmentConfig');
}
/**
* Grants permission to get the AWS Cloud9 IDE settings for a specified development environment
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetEnvironmentSettings() {
return this.to('GetEnvironmentSettings');
}
/**
* Grants permission to get the AWS Cloud9 IDE settings for a specified environment member
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetMembershipSettings() {
return this.to('GetMembershipSettings');
}
/**
* Grants permission to get the migration experience for a cloud9 user
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetMigrationExperiences() {
return this.to('GetMigrationExperiences');
}
/**
* Grants permission to get the user's public SSH key, which is used by AWS Cloud9 to connect to SSH development environments
*
* Access Level: Read
*
* Possible conditions:
* - .ifUserArn()
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetUserPublicKey() {
return this.to('GetUserPublicKey');
}
/**
* Grants permission to get the AWS Cloud9 IDE settings for a specified user
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toGetUserSettings() {
return this.to('GetUserSettings');
}
/**
* Grants permission to get a list of AWS Cloud9 development environment identifiers
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_ListEnvironments.html
*/
toListEnvironments() {
return this.to('ListEnvironments');
}
/**
* Grants permission to list tags for a cloud9 environment
*
* Access Level: Read
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_ListTagsForResource.html
*/
toListTagsForResource() {
return this.to('ListTagsForResource');
}
/**
* Grants permission to set AWS managed temporary credentials on the Amazon EC2 instance that's used by the AWS Cloud9 integrated development environment (IDE)
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toModifyTemporaryCredentialsOnEnvironmentEC2() {
return this.to('ModifyTemporaryCredentialsOnEnvironmentEC2');
}
/**
* Grants permission to add tags to a cloud9 environment
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_TagResource.html
*/
toTagResource() {
return this.to('TagResource');
}
/**
* Grants permission to remove tags from a cloud9 environment
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UntagResource.html
*/
toUntagResource() {
return this.to('UntagResource');
}
/**
* Grants permission to change the settings of an existing AWS Cloud9 development environment
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UpdateEnvironment.html
*/
toUpdateEnvironment() {
return this.to('UpdateEnvironment');
}
/**
* Grants permission to change the settings of an existing environment member for an AWS Cloud9 development environment
*
* Access Level: Write
*
* Possible conditions:
* - .ifUserArn()
* - .ifEnvironmentId()
* - .ifPermissions()
*
* https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UpdateEnvironmentMembership.html
*/
toUpdateEnvironmentMembership() {
return this.to('UpdateEnvironmentMembership');
}
/**
* Grants permission to update the AWS Cloud9 IDE settings for a specified development environment
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toUpdateEnvironmentSettings() {
return this.to('UpdateEnvironmentSettings');
}
/**
* Grants permission to update the AWS Cloud9 IDE settings for a specified environment member
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toUpdateMembershipSettings() {
return this.to('UpdateMembershipSettings');
}
/**
* Grants permission to update details about the connection to the SSH development environment, including host, user, and port
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toUpdateSSHRemote() {
return this.to('UpdateSSHRemote');
}
/**
* Grants permission to update IDE-specific settings of an AWS Cloud9 user
*
* Access Level: Write
*
* https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix
*/
toUpdateUserSettings() {
return this.to('UpdateUserSettings');
}
/**
* Adds a resource of type environment to the statement
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-environment
*
* @param resourceId - Identifier for the resourceId.
* @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()
*/
onEnvironment(resourceId, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:cloud9:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:environment:${resourceId}`);
}
/**
* 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:
* - .toCreateEnvironmentEC2()
* - .toCreateEnvironmentSSH()
* - .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 resource types:
* - environment
*
* @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:
* - .toCreateEnvironmentEC2()
* - .toCreateEnvironmentSSH()
* - .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');
}
/**
* Filters access by the AWS Cloud9 environment ID
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_EnvironmentId
*
* Applies to actions:
* - .toCreateEnvironmentMembership()
* - .toDeleteEnvironmentMembership()
* - .toDescribeEnvironmentMemberships()
* - .toUpdateEnvironmentMembership()
*
* @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`
*/
ifEnvironmentId(value, operator) {
return this.if(`EnvironmentId`, value, operator ?? 'StringLike');
}
/**
* Filters access by the AWS Cloud9 environment name
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_EnvironmentName
*
* Applies to actions:
* - .toCreateEnvironmentEC2()
* - .toCreateEnvironmentSSH()
*
* @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`
*/
ifEnvironmentName(value, operator) {
return this.if(`EnvironmentName`, value, operator ?? 'StringLike');
}
/**
* Filters access by the instance type of the AWS Cloud9 environment's Amazon EC2 instance
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_InstanceType
*
* Applies to actions:
* - .toCreateEnvironmentEC2()
*
* @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`
*/
ifInstanceType(value, operator) {
return this.if(`InstanceType`, value, operator ?? 'StringLike');
}
/**
* Filters access by the owner ARN specified
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_OwnerArn
*
* Applies to actions:
* - .toCreateEnvironmentEC2()
* - .toCreateEnvironmentSSH()
*
* @param value The value(s) to check
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
*/
ifOwnerArn(value, operator) {
return this.if(`OwnerArn`, value, operator ?? 'ArnLike');
}
/**
* Filters access by the type of AWS Cloud9 permissions
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_Permissions
*
* Applies to actions:
* - .toCreateEnvironmentMembership()
* - .toUpdateEnvironmentMembership()
*
* @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`
*/
ifPermissions(value, operator) {
return this.if(`Permissions`, value, operator ?? 'StringLike');
}
/**
* Filters access by the subnet ID that the AWS Cloud9 environment will be created in
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_SubnetId
*
* Applies to actions:
* - .toCreateEnvironmentEC2()
*
* @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`
*/
ifSubnetId(value, operator) {
return this.if(`SubnetId`, value, operator ?? 'StringLike');
}
/**
* Filters access by the user ARN specified
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-cloud9_UserArn
*
* Applies to actions:
* - .toCreateEnvironmentEC2()
* - .toCreateEnvironmentMembership()
* - .toDeleteEnvironmentMembership()
* - .toDescribeEnvironmentMemberships()
* - .toGetUserPublicKey()
* - .toUpdateEnvironmentMembership()
*
* @param value The value(s) to check
* @param operator Works with [arn operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_ARN). **Default:** `ArnLike`
*/
ifUserArn(value, operator) {
return this.if(`UserArn`, value, operator ?? 'ArnLike');
}
}
exports.Cloud9 = Cloud9;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud9.js","sourceRoot":"","sources":["cloud9.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 [cloud9](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscloud9.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 Cloud9 extends PolicyStatement {\n  public servicePrefix = 'cloud9';\n\n  /**\n   * Statement provider for service [cloud9](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscloud9.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 start the Amazon EC2 instance that your AWS Cloud9 IDE connects to\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toActivateEC2Remote() {\n    return this.to('ActivateEC2Remote');\n  }\n\n  /**\n   * Grants permission to create an AWS Cloud9 development environment, launches an Amazon Elastic Compute Cloud (Amazon EC2) instance, and then hosts the environment on the instance\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEnvironmentName()\n   * - .ifInstanceType()\n   * - .ifSubnetId()\n   * - .ifUserArn()\n   * - .ifOwnerArn()\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * Dependent actions:\n   * - ec2:DescribeSubnets\n   * - ec2:DescribeVpcs\n   * - iam:CreateServiceLinkedRole\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_CreateEnvironmentEC2.html\n   */\n  public toCreateEnvironmentEC2() {\n    return this.to('CreateEnvironmentEC2');\n  }\n\n  /**\n   * Grants permission to add an environment member to an AWS Cloud9 development environment\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifUserArn()\n   * - .ifEnvironmentId()\n   * - .ifPermissions()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_CreateEnvironmentMembership.html\n   */\n  public toCreateEnvironmentMembership() {\n    return this.to('CreateEnvironmentMembership');\n  }\n\n  /**\n   * Grants permission to create an AWS Cloud9 SSH development environment\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEnvironmentName()\n   * - .ifOwnerArn()\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toCreateEnvironmentSSH() {\n    return this.to('CreateEnvironmentSSH');\n  }\n\n  /**\n   * Grants permission to create an authentication token that allows a connection between the AWS Cloud9 IDE and the user's environment\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toCreateEnvironmentToken() {\n    return this.to('CreateEnvironmentToken');\n  }\n\n  /**\n   * Grants permission to delete an AWS Cloud9 development environment. If the environment is hosted on an Amazon Elastic Compute Cloud (Amazon EC2) instance, also terminates the instance\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - iam:CreateServiceLinkedRole\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DeleteEnvironment.html\n   */\n  public toDeleteEnvironment() {\n    return this.to('DeleteEnvironment');\n  }\n\n  /**\n   * Grants permission to delete an environment member from an AWS Cloud9 development environment\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifUserArn()\n   * - .ifEnvironmentId()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DeleteEnvironmentMembership.html\n   */\n  public toDeleteEnvironmentMembership() {\n    return this.to('DeleteEnvironmentMembership');\n  }\n\n  /**\n   * Grants permission to get details about the connection to the EC2 development environment, including host, user, and port\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toDescribeEC2Remote() {\n    return this.to('DescribeEC2Remote');\n  }\n\n  /**\n   * Grants permission to get information about environment members for an AWS Cloud9 development environment\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifUserArn()\n   * - .ifEnvironmentId()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironmentMemberships.html\n   */\n  public toDescribeEnvironmentMemberships() {\n    return this.to('DescribeEnvironmentMemberships');\n  }\n\n  /**\n   * Grants permission to get status information for an AWS Cloud9 development environment\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironmentStatus.html\n   */\n  public toDescribeEnvironmentStatus() {\n    return this.to('DescribeEnvironmentStatus');\n  }\n\n  /**\n   * Grants permission to get information about AWS Cloud9 development environments\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_DescribeEnvironments.html\n   */\n  public toDescribeEnvironments() {\n    return this.to('DescribeEnvironments');\n  }\n\n  /**\n   * Grants permission to get details about the connection to the SSH development environment, including host, user, and port\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toDescribeSSHRemote() {\n    return this.to('DescribeSSHRemote');\n  }\n\n  /**\n   * Grants permission to get configuration information that's used to initialize the AWS Cloud9 IDE\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetEnvironmentConfig() {\n    return this.to('GetEnvironmentConfig');\n  }\n\n  /**\n   * Grants permission to get the AWS Cloud9 IDE settings for a specified development environment\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetEnvironmentSettings() {\n    return this.to('GetEnvironmentSettings');\n  }\n\n  /**\n   * Grants permission to get the AWS Cloud9 IDE settings for a specified environment member\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetMembershipSettings() {\n    return this.to('GetMembershipSettings');\n  }\n\n  /**\n   * Grants permission to get the migration experience for a cloud9 user\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetMigrationExperiences() {\n    return this.to('GetMigrationExperiences');\n  }\n\n  /**\n   * Grants permission to get the user's public SSH key, which is used by AWS Cloud9 to connect to SSH development environments\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifUserArn()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetUserPublicKey() {\n    return this.to('GetUserPublicKey');\n  }\n\n  /**\n   * Grants permission to get the AWS Cloud9 IDE settings for a specified user\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toGetUserSettings() {\n    return this.to('GetUserSettings');\n  }\n\n  /**\n   * Grants permission to get a list of AWS Cloud9 development environment identifiers\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_ListEnvironments.html\n   */\n  public toListEnvironments() {\n    return this.to('ListEnvironments');\n  }\n\n  /**\n   * Grants permission to list tags for a cloud9 environment\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to set AWS managed temporary credentials on the Amazon EC2 instance that's used by the AWS Cloud9 integrated development environment (IDE)\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toModifyTemporaryCredentialsOnEnvironmentEC2() {\n    return this.to('ModifyTemporaryCredentialsOnEnvironmentEC2');\n  }\n\n  /**\n   * Grants permission to add tags to a cloud9 environment\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a cloud9 environment\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to change the settings of an existing AWS Cloud9 development environment\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UpdateEnvironment.html\n   */\n  public toUpdateEnvironment() {\n    return this.to('UpdateEnvironment');\n  }\n\n  /**\n   * Grants permission to change the settings of an existing environment member for an AWS Cloud9 development environment\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifUserArn()\n   * - .ifEnvironmentId()\n   * - .ifPermissions()\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/APIReference/API_UpdateEnvironmentMembership.html\n   */\n  public toUpdateEnvironmentMembership() {\n    return this.to('UpdateEnvironmentMembership');\n  }\n\n  /**\n   * Grants permission to update the AWS Cloud9 IDE settings for a specified development environment\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toUpdateEnvironmentSettings() {\n    return this.to('UpdateEnvironmentSettings');\n  }\n\n  /**\n   * Grants permission to update the AWS Cloud9 IDE settings for a specified environment member\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toUpdateMembershipSettings() {\n    return this.to('UpdateMembershipSettings');\n  }\n\n  /**\n   * Grants permission to update details about the connection to the SSH development environment, including host, user, and port\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toUpdateSSHRemote() {\n    return this.to('UpdateSSHRemote');\n  }\n\n  /**\n   * Grants permission to update IDE-specific settings of an AWS Cloud9 user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cloud9/latest/user-guide/security-iam.html#auth-and-access-control-ref-matrix\n   */\n  public toUpdateUserSettings() {\n    return this.to('UpdateUserSettings');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'ActivateEC2Remote',\n      'CreateEnvironmentEC2',\n      'CreateEnvironmentMembership',\n      'CreateEnvironmentSSH',\n      'DeleteEnvironment',\n      'DeleteEnvironmentMembership',\n      'ModifyTemporaryCredentialsOnEnvironmentEC2',\n      'UpdateEnvironment',\n      'UpdateEnvironmentMembership',\n      'UpdateEnvironmentSettings',\n      'UpdateMembershipSettings',\n      'UpdateSSHRemote',\n      'UpdateUserSettings'\n    ],\n    Read: [\n      'CreateEnvironmentToken',\n      'DescribeEC2Remote',\n      'DescribeEnvironmentMemberships',\n      'DescribeEnvironmentStatus',\n      'DescribeEnvironments',\n      'DescribeSSHRemote',\n      'GetEnvironmentConfig',\n      'GetEnvironmentSettings',\n      'GetMembershipSettings',\n      'GetMigrationExperiences',\n      'GetUserPublicKey',\n      'GetUserSettings',\n      'ListEnvironments',\n      'ListTagsForResource'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type environment to the statement\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/list_awscloud9.html##awscloud9-environment\n   *\n   * @param resourceId - Identifier for the resourceId.\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 onEnvironment(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:cloud9:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:environment:${ resourceId }`);\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   * - .toCreateEnvironmentEC2()\n   * - .toCreateEnvironmentSSH()\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 resource types:\n   * - environment\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   * - .toCreateEnvironmentEC2()\n   * - .toCreateEnvironmentSSH()\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_conditi