UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

277 lines 25.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CodeguruSecurity = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [codeguru-security](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncodegurusecurity.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class CodeguruSecurity extends shared_1.PolicyStatement { /** * Statement provider for service [codeguru-security](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncodegurusecurity.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 = 'codeguru-security'; this.accessLevelList = { Read: [ 'BatchGetFindings', 'GetAccountConfiguration', 'GetMetricsSummary', 'GetScan', 'ListTagsForResource' ], Write: [ 'CreateScan', 'CreateUploadUrl', 'DeleteScansByCategory', 'UpdateAccountConfiguration' ], List: [ 'GetFindings', 'ListFindings', 'ListFindingsMetrics', 'ListScans' ], Tagging: [ 'TagResource', 'UntagResource' ] }; } /** * Grants permission to batch retrieve specific findings generated by CodeGuru Security * * Access Level: Read * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_BatchGetFindings.html */ toBatchGetFindings() { return this.to('BatchGetFindings'); } /** * Grants permission to create a CodeGuru Security scan * * Access Level: Write * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_CreateScan.html */ toCreateScan() { return this.to('CreateScan'); } /** * Grants permission to generate a presigned url for uploading code archives * * Access Level: Write * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_CreateUploadUrl.html */ toCreateUploadUrl() { return this.to('CreateUploadUrl'); } /** * Grants permission to delete all the scans and related findings from CodeGuru Security by given category * * Access Level: Write */ toDeleteScansByCategory() { return this.to('DeleteScansByCategory'); } /** * Grants permission to retrieve the account level configurations * * Access Level: Read * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetAccountConfiguration.html */ toGetAccountConfiguration() { return this.to('GetAccountConfiguration'); } /** * Grants permission to retrieve findings for a scan generated by CodeGuru Security * * Access Level: List * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetFindings.html */ toGetFindings() { return this.to('GetFindings'); } /** * Grants permission to retrieve AWS accout level metrics summary generated by CodeGuru Security * * Access Level: Read * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetMetricsSummary.html */ toGetMetricsSummary() { return this.to('GetMetricsSummary'); } /** * Grants permission to retrieve CodeGuru Security scan metadata * * Access Level: Read * * Possible conditions: * - .ifAwsResourceTag() * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetScan.html */ toGetScan() { return this.to('GetScan'); } /** * Grants permission to retrieve findings generated by CodeGuru Security * * Access Level: List */ toListFindings() { return this.to('ListFindings'); } /** * Grants permission to retrieve a list of account level findings metrics within a date range * * Access Level: List * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListFindingsMetrics.html */ toListFindingsMetrics() { return this.to('ListFindingsMetrics'); } /** * Grants permission to retrieve list of CodeGuru Security scan metadata * * Access Level: List * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListScans.html */ toListScans() { return this.to('ListScans'); } /** * Grants permission to retrieve a list of tags for a scan name ARN * * Access Level: Read * * Possible conditions: * - .ifAwsResourceTag() * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListTagsForResource.html */ toListTagsForResource() { return this.to('ListTagsForResource'); } /** * Grants permission to add tags to a scan name ARN * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_TagResource.html */ toTagResource() { return this.to('TagResource'); } /** * Grants permission to remove tags from a scan name ARN * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_UntagResource.html */ toUntagResource() { return this.to('UntagResource'); } /** * Grants permission to update the account level configurations * * Access Level: Write * * https://docs.aws.amazon.com/codeguru/latest/security-api/API_UpdateAccountConfiguration.html */ toUpdateAccountConfiguration() { return this.to('UpdateAccountConfiguration'); } /** * Adds a resource of type ScanName to the statement * * https://docs.aws.amazon.com/codeguru/latest/security-ug/working-with-code-scans.html * * @param scanName - Identifier for the scanName. * @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() */ onScanName(scanName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:codeguru-security:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:scans/${scanName}`); } /** * Filters access by the 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: * - .toCreateScan() * - .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 associated with the resource * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag * * Applies to actions: * - .toGetScan() * - .toListTagsForResource() * * Applies to resource types: * - ScanName * * @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: * - .toCreateScan() * - .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.CodeguruSecurity = CodeguruSecurity; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codegurusecurity.js","sourceRoot":"","sources":["codegurusecurity.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 [codeguru-security](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncodegurusecurity.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 CodeguruSecurity extends PolicyStatement {\n  public servicePrefix = 'codeguru-security';\n\n  /**\n   * Statement provider for service [codeguru-security](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncodegurusecurity.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 batch retrieve specific findings generated by CodeGuru Security\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_BatchGetFindings.html\n   */\n  public toBatchGetFindings() {\n    return this.to('BatchGetFindings');\n  }\n\n  /**\n   * Grants permission to create a CodeGuru Security scan\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_CreateScan.html\n   */\n  public toCreateScan() {\n    return this.to('CreateScan');\n  }\n\n  /**\n   * Grants permission to generate a presigned url for uploading code archives\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_CreateUploadUrl.html\n   */\n  public toCreateUploadUrl() {\n    return this.to('CreateUploadUrl');\n  }\n\n  /**\n   * Grants permission to delete all the scans and related findings from CodeGuru Security by given category\n   *\n   * Access Level: Write\n   */\n  public toDeleteScansByCategory() {\n    return this.to('DeleteScansByCategory');\n  }\n\n  /**\n   * Grants permission to retrieve the account level configurations\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetAccountConfiguration.html\n   */\n  public toGetAccountConfiguration() {\n    return this.to('GetAccountConfiguration');\n  }\n\n  /**\n   * Grants permission to retrieve findings for a scan generated by CodeGuru Security\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetFindings.html\n   */\n  public toGetFindings() {\n    return this.to('GetFindings');\n  }\n\n  /**\n   * Grants permission to retrieve AWS accout level metrics summary generated by CodeGuru Security\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetMetricsSummary.html\n   */\n  public toGetMetricsSummary() {\n    return this.to('GetMetricsSummary');\n  }\n\n  /**\n   * Grants permission to retrieve CodeGuru Security scan metadata\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_GetScan.html\n   */\n  public toGetScan() {\n    return this.to('GetScan');\n  }\n\n  /**\n   * Grants permission to retrieve findings generated by CodeGuru Security\n   *\n   * Access Level: List\n   */\n  public toListFindings() {\n    return this.to('ListFindings');\n  }\n\n  /**\n   * Grants permission to retrieve a list of account level findings metrics within a date range\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListFindingsMetrics.html\n   */\n  public toListFindingsMetrics() {\n    return this.to('ListFindingsMetrics');\n  }\n\n  /**\n   * Grants permission to retrieve list of CodeGuru Security scan metadata\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListScans.html\n   */\n  public toListScans() {\n    return this.to('ListScans');\n  }\n\n  /**\n   * Grants permission to retrieve a list of tags for a scan name ARN\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to add tags to a scan name ARN\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a scan name ARN\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update the account level configurations\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-api/API_UpdateAccountConfiguration.html\n   */\n  public toUpdateAccountConfiguration() {\n    return this.to('UpdateAccountConfiguration');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Read: [\n      'BatchGetFindings',\n      'GetAccountConfiguration',\n      'GetMetricsSummary',\n      'GetScan',\n      'ListTagsForResource'\n    ],\n    Write: [\n      'CreateScan',\n      'CreateUploadUrl',\n      'DeleteScansByCategory',\n      'UpdateAccountConfiguration'\n    ],\n    List: [\n      'GetFindings',\n      'ListFindings',\n      'ListFindingsMetrics',\n      'ListScans'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type ScanName to the statement\n   *\n   * https://docs.aws.amazon.com/codeguru/latest/security-ug/working-with-code-scans.html\n   *\n   * @param scanName - Identifier for the scanName.\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 onScanName(scanName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:codeguru-security:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:scans/${ scanName }`);\n  }\n\n  /**\n   * Filters access by the 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   * - .toCreateScan()\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 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 actions:\n   * - .toGetScan()\n   * - .toListTagsForResource()\n   *\n   * Applies to resource types:\n   * - ScanName\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   * - .toCreateScan()\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"]}