UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

365 lines 35.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Codestar = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [codestar](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscodestar.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class Codestar extends shared_1.PolicyStatement { /** * Statement provider for service [codestar](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscodestar.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 = 'codestar'; this.accessLevelList = { 'Permissions management': [ 'AssociateTeamMember', 'CreateProject', 'DeleteProject', 'DisassociateTeamMember', 'UpdateTeamMember' ], Write: [ 'CreateUserProfile', 'DeleteExtendedAccess', 'DeleteUserProfile', 'PutExtendedAccess', 'UpdateProject', 'UpdateUserProfile' ], Read: [ 'DescribeProject', 'DescribeUserProfile', 'GetExtendedAccess' ], List: [ 'ListProjects', 'ListResources', 'ListTagsForProject', 'ListTeamMembers', 'ListUserProfiles', 'VerifyServiceRole' ], Tagging: [ 'TagProject', 'UntagProject' ] }; } /** * Grants permission to add a user to the team for an AWS CodeStar project * * Access Level: Permissions management * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_AssociateTeamMember.html */ toAssociateTeamMember() { return this.to('AssociateTeamMember'); } /** * Grants permission to create a project with minimal structure, customer policies, and no resources * * Access Level: Permissions management * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_CreateProject.html */ toCreateProject() { return this.to('CreateProject'); } /** * Grants permission to create a profile for a user that includes user preferences, display name, and email * * Access Level: Write * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_CreateUserProfile.html */ toCreateUserProfile() { return this.to('CreateUserProfile'); } /** * Grants permission to extended delete APIs * * Access Level: Write */ toDeleteExtendedAccess() { return this.to('DeleteExtendedAccess'); } /** * Grants permission to delete a project, including project resources. Does not delete users associated with the project, but does delete the IAM roles that allowed access to the project * * Access Level: Permissions management * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DeleteProject.html */ toDeleteProject() { return this.to('DeleteProject'); } /** * Grants permission to delete a user profile in AWS CodeStar, including all personal preference data associated with that profile, such as display name and email address. It does not delete the history of that user, for example the history of commits made by that user * * Access Level: Write * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DeleteUserProfile.html */ toDeleteUserProfile() { return this.to('DeleteUserProfile'); } /** * Grants permission to describe a project and its resources * * Access Level: Read * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DescribeProject.html */ toDescribeProject() { return this.to('DescribeProject'); } /** * Grants permission to describe a user in AWS CodeStar and the user attributes across all projects * * Access Level: Read * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DescribeUserProfile.html */ toDescribeUserProfile() { return this.to('DescribeUserProfile'); } /** * Grants permission to remove a user from a project. Removing a user from a project also removes the IAM policies from that user that allowed access to the project and its resources * * Access Level: Permissions management * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DisassociateTeamMember.html */ toDisassociateTeamMember() { return this.to('DisassociateTeamMember'); } /** * Grants permission to extended read APIs * * Access Level: Read */ toGetExtendedAccess() { return this.to('GetExtendedAccess'); } /** * Grants permission to list all projects in CodeStar associated with your AWS account * * Access Level: List * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListProjects.html */ toListProjects() { return this.to('ListProjects'); } /** * Grants permission to list all resources associated with a project in CodeStar * * Access Level: List * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListResources.html */ toListResources() { return this.to('ListResources'); } /** * Grants permission to list the tags associated with a project in CodeStar * * Access Level: List * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListTagsForProject.html */ toListTagsForProject() { return this.to('ListTagsForProject'); } /** * Grants permission to list all team members associated with a project * * Access Level: List * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListTeamMembers.html */ toListTeamMembers() { return this.to('ListTeamMembers'); } /** * Grants permission to list user profiles in AWS CodeStar * * Access Level: List * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListUserProfiles.html */ toListUserProfiles() { return this.to('ListUserProfiles'); } /** * Grants permission to extended write APIs * * Access Level: Write */ toPutExtendedAccess() { return this.to('PutExtendedAccess'); } /** * Grants permission to add tags to a project in CodeStar * * Access Level: Tagging * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_TagProject.html */ toTagProject() { return this.to('TagProject'); } /** * Grants permission to remove tags from a project in CodeStar * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UntagProject.html */ toUntagProject() { return this.to('UntagProject'); } /** * Grants permission to update a project in CodeStar * * Access Level: Write * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateProject.html */ toUpdateProject() { return this.to('UpdateProject'); } /** * Grants permission to update team member attributes within a CodeStar project * * Access Level: Permissions management * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateTeamMember.html */ toUpdateTeamMember() { return this.to('UpdateTeamMember'); } /** * Grants permission to update a profile for a user that includes user preferences, display name, and email * * Access Level: Write * * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateUserProfile.html */ toUpdateUserProfile() { return this.to('UpdateUserProfile'); } /** * Grants permission to verify whether the AWS CodeStar service role exists in the customer's account * * Access Level: List */ toVerifyServiceRole() { return this.to('VerifyServiceRole'); } /** * Adds a resource of type project to the statement * * https://docs.aws.amazon.com/codestar/latest/userguide/working-with-projects.html * * @param projectId - Identifier for the projectId. * @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(projectId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:codestar:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:project/${projectId}`); } /** * Adds a resource of type user to the statement * * https://docs.aws.amazon.com/codestar/latest/userguide/working-with-user-info.html * * @param userNameWithPath - Identifier for the userNameWithPath. * @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: * - .ifIamResourceTag() */ onUser(userNameWithPath, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:iam:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:user/${userNameWithPath}`); } /** * Filters access by requests based on the allowed set of values for each of the tags * * Applies to actions: * - .toCreateProject() * - .toTagProject() * * @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 actions based on tag-value associated with the resource * * 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 requests based on the presence of mandatory tags in the request * * Applies to actions: * - .toCreateProject() * - .toTagProject() * - .toUntagProject() * * @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 actions based on tag-value associated with the resource * * Applies to resource types: * - user * * @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` */ ifIamResourceTag(tagKey, value, operator) { return this.if(`iam:ResourceTag/${tagKey}`, value, operator ?? 'StringLike'); } } exports.Codestar = Codestar; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codestar.js","sourceRoot":"","sources":["codestar.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 [codestar](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscodestar.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 Codestar extends PolicyStatement {\n  public servicePrefix = 'codestar';\n\n  /**\n   * Statement provider for service [codestar](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awscodestar.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 add a user to the team for an AWS CodeStar project\n   *\n   * Access Level: Permissions management\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_AssociateTeamMember.html\n   */\n  public toAssociateTeamMember() {\n    return this.to('AssociateTeamMember');\n  }\n\n  /**\n   * Grants permission to create a project with minimal structure, customer policies, and no resources\n   *\n   * Access Level: Permissions management\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_CreateProject.html\n   */\n  public toCreateProject() {\n    return this.to('CreateProject');\n  }\n\n  /**\n   * Grants permission to create a profile for a user that includes user preferences, display name, and email\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_CreateUserProfile.html\n   */\n  public toCreateUserProfile() {\n    return this.to('CreateUserProfile');\n  }\n\n  /**\n   * Grants permission to extended delete APIs\n   *\n   * Access Level: Write\n   */\n  public toDeleteExtendedAccess() {\n    return this.to('DeleteExtendedAccess');\n  }\n\n  /**\n   * Grants permission to delete a project, including project resources. Does not delete users associated with the project, but does delete the IAM roles that allowed access to the project\n   *\n   * Access Level: Permissions management\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DeleteProject.html\n   */\n  public toDeleteProject() {\n    return this.to('DeleteProject');\n  }\n\n  /**\n   * Grants permission to delete a user profile in AWS CodeStar, including all personal preference data associated with that profile, such as display name and email address. It does not delete the history of that user, for example the history of commits made by that user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DeleteUserProfile.html\n   */\n  public toDeleteUserProfile() {\n    return this.to('DeleteUserProfile');\n  }\n\n  /**\n   * Grants permission to describe a project and its resources\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DescribeProject.html\n   */\n  public toDescribeProject() {\n    return this.to('DescribeProject');\n  }\n\n  /**\n   * Grants permission to describe a user in AWS CodeStar and the user attributes across all projects\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DescribeUserProfile.html\n   */\n  public toDescribeUserProfile() {\n    return this.to('DescribeUserProfile');\n  }\n\n  /**\n   * Grants permission to remove a user from a project. Removing a user from a project also removes the IAM policies from that user that allowed access to the project and its resources\n   *\n   * Access Level: Permissions management\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_DisassociateTeamMember.html\n   */\n  public toDisassociateTeamMember() {\n    return this.to('DisassociateTeamMember');\n  }\n\n  /**\n   * Grants permission to extended read APIs\n   *\n   * Access Level: Read\n   */\n  public toGetExtendedAccess() {\n    return this.to('GetExtendedAccess');\n  }\n\n  /**\n   * Grants permission to list all projects in CodeStar associated with your AWS account\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListProjects.html\n   */\n  public toListProjects() {\n    return this.to('ListProjects');\n  }\n\n  /**\n   * Grants permission to list all resources associated with a project in CodeStar\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListResources.html\n   */\n  public toListResources() {\n    return this.to('ListResources');\n  }\n\n  /**\n   * Grants permission to list the tags associated with a project in CodeStar\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListTagsForProject.html\n   */\n  public toListTagsForProject() {\n    return this.to('ListTagsForProject');\n  }\n\n  /**\n   * Grants permission to list all team members associated with a project\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListTeamMembers.html\n   */\n  public toListTeamMembers() {\n    return this.to('ListTeamMembers');\n  }\n\n  /**\n   * Grants permission to list user profiles in AWS CodeStar\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_ListUserProfiles.html\n   */\n  public toListUserProfiles() {\n    return this.to('ListUserProfiles');\n  }\n\n  /**\n   * Grants permission to extended write APIs\n   *\n   * Access Level: Write\n   */\n  public toPutExtendedAccess() {\n    return this.to('PutExtendedAccess');\n  }\n\n  /**\n   * Grants permission to add tags to a project in CodeStar\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_TagProject.html\n   */\n  public toTagProject() {\n    return this.to('TagProject');\n  }\n\n  /**\n   * Grants permission to remove tags from a project in CodeStar\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UntagProject.html\n   */\n  public toUntagProject() {\n    return this.to('UntagProject');\n  }\n\n  /**\n   * Grants permission to update a project in CodeStar\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateProject.html\n   */\n  public toUpdateProject() {\n    return this.to('UpdateProject');\n  }\n\n  /**\n   * Grants permission to update team member attributes within a CodeStar project\n   *\n   * Access Level: Permissions management\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateTeamMember.html\n   */\n  public toUpdateTeamMember() {\n    return this.to('UpdateTeamMember');\n  }\n\n  /**\n   * Grants permission to update a profile for a user that includes user preferences, display name, and email\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codestar/latest/APIReference/API_UpdateUserProfile.html\n   */\n  public toUpdateUserProfile() {\n    return this.to('UpdateUserProfile');\n  }\n\n  /**\n   * Grants permission to verify whether the AWS CodeStar service role exists in the customer's account\n   *\n   * Access Level: List\n   */\n  public toVerifyServiceRole() {\n    return this.to('VerifyServiceRole');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    'Permissions management': [\n      'AssociateTeamMember',\n      'CreateProject',\n      'DeleteProject',\n      'DisassociateTeamMember',\n      'UpdateTeamMember'\n    ],\n    Write: [\n      'CreateUserProfile',\n      'DeleteExtendedAccess',\n      'DeleteUserProfile',\n      'PutExtendedAccess',\n      'UpdateProject',\n      'UpdateUserProfile'\n    ],\n    Read: [\n      'DescribeProject',\n      'DescribeUserProfile',\n      'GetExtendedAccess'\n    ],\n    List: [\n      'ListProjects',\n      'ListResources',\n      'ListTagsForProject',\n      'ListTeamMembers',\n      'ListUserProfiles',\n      'VerifyServiceRole'\n    ],\n    Tagging: [\n      'TagProject',\n      'UntagProject'\n    ]\n  };\n\n  /**\n   * Adds a resource of type project to the statement\n   *\n   * https://docs.aws.amazon.com/codestar/latest/userguide/working-with-projects.html\n   *\n   * @param projectId - Identifier for the projectId.\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(projectId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:codestar:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:project/${ projectId }`);\n  }\n\n  /**\n   * Adds a resource of type user to the statement\n   *\n   * https://docs.aws.amazon.com/codestar/latest/userguide/working-with-user-info.html\n   *\n   * @param userNameWithPath - Identifier for the userNameWithPath.\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   * - .ifIamResourceTag()\n   */\n  public onUser(userNameWithPath: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:iam:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:user/${ userNameWithPath }`);\n  }\n\n  /**\n   * Filters access by requests based on the allowed set of values for each of the tags\n   *\n   * Applies to actions:\n   * - .toCreateProject()\n   * - .toTagProject()\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 actions based on tag-value associated with the resource\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 requests based on the presence of mandatory tags in the request\n   *\n   * Applies to actions:\n   * - .toCreateProject()\n   * - .toTagProject()\n   * - .toUntagProject()\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  /**\n   * Filters access by actions based on tag-value associated with the resource\n   *\n   * Applies to resource types:\n   * - user\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 ifIamResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`iam:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n}\n"]}