UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

290 lines 25.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ElementalSupportCases = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [elemental-support-cases](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awselementalsupportcases.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class ElementalSupportCases extends shared_1.PolicyStatement { /** * Statement provider for service [elemental-support-cases](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awselementalsupportcases.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 = 'elemental-support-cases'; this.accessLevelList = { Write: [ 'AddCaseComment', 'CheckCasePermission', 'CompleteMultipartUpload', 'CreateCase', 'CreateS3CLIUploadCommand', 'CreateS3DownloadUrl', 'StartMultipartUpload', 'UpdateCase', 'UpdateCaseStatus', 'UpdateMultipartUpload' ], Read: [ 'GetCase', 'GetCasePermission', 'GetCases', 'GetUICache', 'ListTagsForCase' ], Tagging: [ 'TagCase', 'UntagCase' ] }; } /** * Grants permission to add a comment to a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toAddCaseComment() { return this.to('AddCaseComment'); } /** * Grants permission to verify whether the caller has the permissions to perform support case operations * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toCheckCasePermission() { return this.to('CheckCasePermission'); } /** * Grants permission to complete a multipart file upload to a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toCompleteMultipartUpload() { return this.to('CompleteMultipartUpload'); } /** * Grants permission to create a support case * * Access Level: Write * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/elemental-appliances-software */ toCreateCase() { return this.to('CreateCase'); } /** * Grants permission to create a cli command to allow a file upload to a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toCreateS3CLIUploadCommand() { return this.to('CreateS3CLIUploadCommand'); } /** * Grants permission to download a file from a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toCreateS3DownloadUrl() { return this.to('CreateS3DownloadUrl'); } /** * Grants permission to describe a support case in your account * * Access Level: Read * * https://docs.aws.amazon.com/elemental-appliances-software */ toGetCase() { return this.to('GetCase'); } /** * Grants permission to verify whether the caller has the permissions to perform support case operations * * Access Level: Read * * https://docs.aws.amazon.com/elemental-appliances-software */ toGetCasePermission() { return this.to('GetCasePermission'); } /** * Grants permission to list the support cases in your account * * Access Level: Read * * https://docs.aws.amazon.com/elemental-appliances-software */ toGetCases() { return this.to('GetCases'); } /** * Grants permission to retrieve cached case user data for use in the Console * * Access Level: Read * * https://docs.aws.amazon.com/elemental-appliances-software */ toGetUICache() { return this.to('GetUICache'); } /** * Grants permission to list tags on a support case * * Access Level: Read * * https://docs.aws.amazon.com/elemental-appliances-software */ toListTagsForCase() { return this.to('ListTagsForCase'); } /** * Grants permission to start a multipart file upload to a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toStartMultipartUpload() { return this.to('StartMultipartUpload'); } /** * Grants permission to add a tag on a support case * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/elemental-appliances-software */ toTagCase() { return this.to('TagCase'); } /** * Grants permission to remove a tag on a support case * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/elemental-appliances-software */ toUntagCase() { return this.to('UntagCase'); } /** * Grants permission to update a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toUpdateCase() { return this.to('UpdateCase'); } /** * Grants permission to update a support case status * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toUpdateCaseStatus() { return this.to('UpdateCaseStatus'); } /** * Grants permission to update a multipart file upload to a support case * * Access Level: Write * * https://docs.aws.amazon.com/elemental-appliances-software */ toUpdateMultipartUpload() { return this.to('UpdateMultipartUpload'); } /** * Adds a resource of type case to the statement * * https://docs.aws.amazon.com/elemental-appliances-software/ * * @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 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() */ onCase(resourceId, account, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:elemental-support-cases::${account ?? this.defaultAccount}:case/${resourceId}`); } /** * Filters access by tags that are passed in the request * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag * * Applies to actions: * - .toCreateCase() * - .toTagCase() * * @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 tags associated with the resource * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag * * Applies to resource types: * - case * * @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 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: * - .toCreateCase() * - .toTagCase() * - .toUntagCase() * * @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.ElementalSupportCases = ElementalSupportCases; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elementalsupportcases.js","sourceRoot":"","sources":["elementalsupportcases.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 [elemental-support-cases](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awselementalsupportcases.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 ElementalSupportCases extends PolicyStatement {\n  public servicePrefix = 'elemental-support-cases';\n\n  /**\n   * Statement provider for service [elemental-support-cases](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awselementalsupportcases.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 comment to a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toAddCaseComment() {\n    return this.to('AddCaseComment');\n  }\n\n  /**\n   * Grants permission to verify whether the caller has the permissions to perform support case operations\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toCheckCasePermission() {\n    return this.to('CheckCasePermission');\n  }\n\n  /**\n   * Grants permission to complete a multipart file upload to a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toCompleteMultipartUpload() {\n    return this.to('CompleteMultipartUpload');\n  }\n\n  /**\n   * Grants permission to create a support case\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toCreateCase() {\n    return this.to('CreateCase');\n  }\n\n  /**\n   * Grants permission to create a cli command to allow a file upload to a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toCreateS3CLIUploadCommand() {\n    return this.to('CreateS3CLIUploadCommand');\n  }\n\n  /**\n   * Grants permission to download a file from a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toCreateS3DownloadUrl() {\n    return this.to('CreateS3DownloadUrl');\n  }\n\n  /**\n   * Grants permission to describe a support case in your account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toGetCase() {\n    return this.to('GetCase');\n  }\n\n  /**\n   * Grants permission to verify whether the caller has the permissions to perform support case operations\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toGetCasePermission() {\n    return this.to('GetCasePermission');\n  }\n\n  /**\n   * Grants permission to list the support cases in your account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toGetCases() {\n    return this.to('GetCases');\n  }\n\n  /**\n   * Grants permission to retrieve cached case user data for use in the Console\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toGetUICache() {\n    return this.to('GetUICache');\n  }\n\n  /**\n   * Grants permission to list tags on a support case\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toListTagsForCase() {\n    return this.to('ListTagsForCase');\n  }\n\n  /**\n   * Grants permission to start a multipart file upload to a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toStartMultipartUpload() {\n    return this.to('StartMultipartUpload');\n  }\n\n  /**\n   * Grants permission to add a tag on a support case\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toTagCase() {\n    return this.to('TagCase');\n  }\n\n  /**\n   * Grants permission to remove a tag on a support case\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toUntagCase() {\n    return this.to('UntagCase');\n  }\n\n  /**\n   * Grants permission to update a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toUpdateCase() {\n    return this.to('UpdateCase');\n  }\n\n  /**\n   * Grants permission to update a support case status\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toUpdateCaseStatus() {\n    return this.to('UpdateCaseStatus');\n  }\n\n  /**\n   * Grants permission to update a multipart file upload to a support case\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software\n   */\n  public toUpdateMultipartUpload() {\n    return this.to('UpdateMultipartUpload');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AddCaseComment',\n      'CheckCasePermission',\n      'CompleteMultipartUpload',\n      'CreateCase',\n      'CreateS3CLIUploadCommand',\n      'CreateS3DownloadUrl',\n      'StartMultipartUpload',\n      'UpdateCase',\n      'UpdateCaseStatus',\n      'UpdateMultipartUpload'\n    ],\n    Read: [\n      'GetCase',\n      'GetCasePermission',\n      'GetCases',\n      'GetUICache',\n      'ListTagsForCase'\n    ],\n    Tagging: [\n      'TagCase',\n      'UntagCase'\n    ]\n  };\n\n  /**\n   * Adds a resource of type case to the statement\n   *\n   * https://docs.aws.amazon.com/elemental-appliances-software/\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 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 onCase(resourceId: string, account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:elemental-support-cases::${ account ?? this.defaultAccount }:case/${ resourceId }`);\n  }\n\n  /**\n   * Filters access by tags that are passed 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   * - .toCreateCase()\n   * - .toTagCase()\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 tags 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   * - case\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 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   * - .toCreateCase()\n   * - .toTagCase()\n   * - .toUntagCase()\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"]}