iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
374 lines • 32.9 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Monitron = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [monitron](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmonitron.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class Monitron extends shared_1.PolicyStatement {
/**
* Statement provider for service [monitron](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmonitron.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 = 'monitron';
this.accessLevelList = {
'Permissions management': [
'AssociateProjectAdminUser',
'CreateProjectUserAssociation',
'CreateUserAccessRoleAssociation',
'DeleteProjectUserAssociation',
'DeleteUserAccessRoleAssociation',
'DisassociateProjectAdminUser',
'ListProjectAdminUsers'
],
Write: [
'CreateProject',
'DeleteProject',
'UpdateProject'
],
Read: [
'GetProject',
'GetProjectAdminUser',
'ListTagsForResource'
],
List: [
'ListProjectUserAssociations',
'ListProjects',
'ListUserAccessRoleAssociations'
],
Tagging: [
'TagResource',
'UntagResource'
]
};
}
/**
* Grants permission to associate a user with the project as an administrator
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:AssociateProfile
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfileAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html
*/
toAssociateProjectAdminUser() {
return this.to('AssociateProjectAdminUser');
}
/**
* Grants permission to create a project
*
* Access Level: Write
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* Dependent actions:
* - iam:CreateServiceLinkedRole
* - kms:CreateGrant
* - sso:CreateManagedApplicationInstance
* - sso:DeleteManagedApplicationInstance
* - sso:DescribeRegisteredRegions
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-creating-project.html
*/
toCreateProject() {
return this.to('CreateProject');
}
/**
* Grants permission to associate a user with the project
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:AssociateProfile
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfileAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/adding-user.html
*/
toCreateProjectUserAssociation() {
return this.to('CreateProjectUserAssociation');
}
/**
* Grants permission to associate an access role with the user
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfileAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/adding-user.html
*/
toCreateUserAccessRoleAssociation() {
return this.to('CreateUserAccessRoleAssociation');
}
/**
* Grants permission to delete a project
*
* Access Level: Write
*
* Dependent actions:
* - sso:DeleteManagedApplicationInstance
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-delete-project.html
*/
toDeleteProject() {
return this.to('DeleteProject');
}
/**
* Grants permission to disassociate a user from the project
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:DisassociateProfile
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/deleting-user.html
*/
toDeleteProjectUserAssociation() {
return this.to('DeleteProjectUserAssociation');
}
/**
* Grants permission to disassociate an access role from the user
*
* Access Level: Permissions management
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/deleting-user.html
*/
toDeleteUserAccessRoleAssociation() {
return this.to('DeleteUserAccessRoleAssociation');
}
/**
* Grants permission to disassociate an administrator from the project
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:DisassociateProfile
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mu-remove-project-admin.html
*/
toDisassociateProjectAdminUser() {
return this.to('DisassociateProjectAdminUser');
}
/**
* Grants permission to get information about a project
*
* Access Level: Read
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html
*/
toGetProject() {
return this.to('GetProject');
}
/**
* Grants permission to describe an administrator who is associated with the project
*
* Access Level: Read
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:GetManagedApplicationInstance
* - sso:ListProfileAssociations
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html
*/
toGetProjectAdminUser() {
return this.to('GetProjectAdminUser');
}
/**
* Grants permission to list all administrators associated with the project
*
* Access Level: Permissions management
*
* Dependent actions:
* - sso-directory:DescribeUsers
* - sso:GetManagedApplicationInstance
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html
*/
toListProjectAdminUsers() {
return this.to('ListProjectAdminUsers');
}
/**
* Grants permission to list all users associated with the project
*
* Access Level: List
*
* Dependent actions:
* - sso:GetManagedApplicationInstance
* - sso:GetProfile
* - sso:ListDirectoryAssociations
* - sso:ListProfileAssociations
* - sso:ListProfiles
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html
*/
toListProjectUserAssociations() {
return this.to('ListProjectUserAssociations');
}
/**
* Grants permission to list all projects
*
* Access Level: List
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html
*/
toListProjects() {
return this.to('ListProjects');
}
/**
* Grants permission to list all tags for a resource
*
* Access Level: Read
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html
*/
toListTagsForResource() {
return this.to('ListTagsForResource');
}
/**
* Grants permission to list all access roles associated with the user
*
* Access Level: List
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html
*/
toListUserAccessRoleAssociations() {
return this.to('ListUserAccessRoleAssociations');
}
/**
* Grants permission to tag a resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
* - .ifAwsRequestTag()
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html
*/
toTagResource() {
return this.to('TagResource');
}
/**
* Grants permission to untag a resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html#modify-tag-1
*/
toUntagResource() {
return this.to('UntagResource');
}
/**
* Grants permission to update a project
*
* Access Level: Write
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-updating-project.html
*/
toUpdateProject() {
return this.to('UpdateProject');
}
/**
* Adds a resource of type project to the statement
*
* https://docs.aws.amazon.com/Monitron/latest/user-guide/projects-chapter.html
*
* @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()
*/
onProject(resourceId, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:monitron:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:project/${resourceId}`);
}
/**
* Filters access by the 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:
* - .toCreateProject()
* - .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 the tags attached to the resource
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag
*
* Applies to resource types:
* - project
*
* @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/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys
*
* Applies to actions:
* - .toCreateProject()
* - .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.Monitron = Monitron;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monitron.js","sourceRoot":"","sources":["monitron.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 [monitron](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmonitron.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 Monitron extends PolicyStatement {\n  public servicePrefix = 'monitron';\n\n  /**\n   * Statement provider for service [monitron](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonmonitron.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 associate a user with the project as an administrator\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:AssociateProfile\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfileAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html\n   */\n  public toAssociateProjectAdminUser() {\n    return this.to('AssociateProjectAdminUser');\n  }\n\n  /**\n   * Grants permission to create a project\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * Dependent actions:\n   * - iam:CreateServiceLinkedRole\n   * - kms:CreateGrant\n   * - sso:CreateManagedApplicationInstance\n   * - sso:DeleteManagedApplicationInstance\n   * - sso:DescribeRegisteredRegions\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-creating-project.html\n   */\n  public toCreateProject() {\n    return this.to('CreateProject');\n  }\n\n  /**\n   * Grants permission to associate a user with the project\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:AssociateProfile\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfileAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/adding-user.html\n   */\n  public toCreateProjectUserAssociation() {\n    return this.to('CreateProjectUserAssociation');\n  }\n\n  /**\n   * Grants permission to associate an access role with the user\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfileAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/adding-user.html\n   */\n  public toCreateUserAccessRoleAssociation() {\n    return this.to('CreateUserAccessRoleAssociation');\n  }\n\n  /**\n   * Grants permission to delete a project\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - sso:DeleteManagedApplicationInstance\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-delete-project.html\n   */\n  public toDeleteProject() {\n    return this.to('DeleteProject');\n  }\n\n  /**\n   * Grants permission to disassociate a user from the project\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:DisassociateProfile\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/deleting-user.html\n   */\n  public toDeleteProjectUserAssociation() {\n    return this.to('DeleteProjectUserAssociation');\n  }\n\n  /**\n   * Grants permission to disassociate an access role from the user\n   *\n   * Access Level: Permissions management\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/deleting-user.html\n   */\n  public toDeleteUserAccessRoleAssociation() {\n    return this.to('DeleteUserAccessRoleAssociation');\n  }\n\n  /**\n   * Grants permission to disassociate an administrator from the project\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:DisassociateProfile\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mu-remove-project-admin.html\n   */\n  public toDisassociateProjectAdminUser() {\n    return this.to('DisassociateProjectAdminUser');\n  }\n\n  /**\n   * Grants permission to get information about a project\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html\n   */\n  public toGetProject() {\n    return this.to('GetProject');\n  }\n\n  /**\n   * Grants permission to describe an administrator who is associated with the project\n   *\n   * Access Level: Read\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:GetManagedApplicationInstance\n   * - sso:ListProfileAssociations\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html\n   */\n  public toGetProjectAdminUser() {\n    return this.to('GetProjectAdminUser');\n  }\n\n  /**\n   * Grants permission to list all administrators associated with the project\n   *\n   * Access Level: Permissions management\n   *\n   * Dependent actions:\n   * - sso-directory:DescribeUsers\n   * - sso:GetManagedApplicationInstance\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html\n   */\n  public toListProjectAdminUsers() {\n    return this.to('ListProjectAdminUsers');\n  }\n\n  /**\n   * Grants permission to list all users associated with the project\n   *\n   * Access Level: List\n   *\n   * Dependent actions:\n   * - sso:GetManagedApplicationInstance\n   * - sso:GetProfile\n   * - sso:ListDirectoryAssociations\n   * - sso:ListProfileAssociations\n   * - sso:ListProfiles\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html\n   */\n  public toListProjectUserAssociations() {\n    return this.to('ListProjectUserAssociations');\n  }\n\n  /**\n   * Grants permission to list all projects\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-project-tasks.html\n   */\n  public toListProjects() {\n    return this.to('ListProjects');\n  }\n\n  /**\n   * Grants permission to list all tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list all access roles associated with the user\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/user-management-chapter.html\n   */\n  public toListUserAccessRoleAssociations() {\n    return this.to('ListUserAccessRoleAssociations');\n  }\n\n  /**\n   * Grants permission to tag a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to untag a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/tagging.html#modify-tag-1\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a project\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/mp-updating-project.html\n   */\n  public toUpdateProject() {\n    return this.to('UpdateProject');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    'Permissions management': [\n      'AssociateProjectAdminUser',\n      'CreateProjectUserAssociation',\n      'CreateUserAccessRoleAssociation',\n      'DeleteProjectUserAssociation',\n      'DeleteUserAccessRoleAssociation',\n      'DisassociateProjectAdminUser',\n      'ListProjectAdminUsers'\n    ],\n    Write: [\n      'CreateProject',\n      'DeleteProject',\n      'UpdateProject'\n    ],\n    Read: [\n      'GetProject',\n      'GetProjectAdminUser',\n      'ListTagsForResource'\n    ],\n    List: [\n      'ListProjectUserAssociations',\n      'ListProjects',\n      'ListUserAccessRoleAssociations'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type project to the statement\n   *\n   * https://docs.aws.amazon.com/Monitron/latest/user-guide/projects-chapter.html\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 onProject(resourceId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:monitron:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:project/${ resourceId }`);\n  }\n\n  /**\n   * Filters access by the 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   * - .toCreateProject()\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 the tags 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   * - project\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/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .toCreateProject()\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"]}