iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
517 lines • 47.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.AccessAnalyzer = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [access-analyzer](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsiamaccessanalyzer.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class AccessAnalyzer extends shared_1.PolicyStatement {
/**
* Statement provider for service [access-analyzer](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsiamaccessanalyzer.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 = 'access-analyzer';
this.accessLevelList = {
Write: [
'ApplyArchiveRule',
'CancelPolicyGeneration',
'CreateAccessPreview',
'CreateAnalyzer',
'CreateArchiveRule',
'DeleteAnalyzer',
'DeleteArchiveRule',
'GenerateFindingRecommendation',
'StartPolicyGeneration',
'StartResourceScan',
'UpdateAnalyzer',
'UpdateArchiveRule',
'UpdateFindings'
],
Read: [
'CheckAccessNotGranted',
'CheckNoNewAccess',
'CheckNoPublicAccess',
'GetAccessPreview',
'GetAnalyzedResource',
'GetAnalyzer',
'GetArchiveRule',
'GetFinding',
'GetFindingRecommendation',
'GetFindingsStatistics',
'GetGeneratedPolicy',
'ListAccessPreviewFindings',
'ListAnalyzedResources',
'ListFindings',
'ListPolicyGenerations',
'ListTagsForResource',
'ValidatePolicy'
],
List: [
'ListAccessPreviews',
'ListAnalyzers',
'ListArchiveRules'
],
Tagging: [
'TagResource',
'UntagResource'
]
};
}
/**
* Grants permission to apply an archive rule
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ApplyArchiveRule.html
*/
toApplyArchiveRule() {
return this.to('ApplyArchiveRule');
}
/**
* Grants permission to cancel a policy generation
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CancelPolicyGeneration.html
*/
toCancelPolicyGeneration() {
return this.to('CancelPolicyGeneration');
}
/**
* Grants permission to check that specified access is not allowed by a policy
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckAccessNotGranted.html
*/
toCheckAccessNotGranted() {
return this.to('CheckAccessNotGranted');
}
/**
* Grants permission to check that no new access is allowed when compared to an existing policy
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckNoNewAccess.html
*/
toCheckNoNewAccess() {
return this.to('CheckNoNewAccess');
}
/**
* Grants permission to check that public access is not allowed by a resource policy
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckNoPublicAccess.html
*/
toCheckNoPublicAccess() {
return this.to('CheckNoPublicAccess');
}
/**
* Grants permission to create an access preview for the specified analyzer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateAccessPreview.html
*/
toCreateAccessPreview() {
return this.to('CreateAccessPreview');
}
/**
* Grants permission to create an analyzer
*
* Access Level: Write
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* Dependent actions:
* - iam:CreateServiceLinkedRole
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateAnalyzer.html
*/
toCreateAnalyzer() {
return this.to('CreateAnalyzer');
}
/**
* Grants permission to create an archive rule for the specified analyzer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateArchiveRule.html
*/
toCreateArchiveRule() {
return this.to('CreateArchiveRule');
}
/**
* Grants permission to delete the specified analyzer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_DeleteAnalyzer.html
*/
toDeleteAnalyzer() {
return this.to('DeleteAnalyzer');
}
/**
* Grants permission to delete archive rules for the specified analyzer
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_DeleteArchiveRule.html
*/
toDeleteArchiveRule() {
return this.to('DeleteArchiveRule');
}
/**
* Grants permission to generate recommendation steps to resolve a finding
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GenerateFindingRecommendation.html
*/
toGenerateFindingRecommendation() {
return this.to('GenerateFindingRecommendation');
}
/**
* Grants permission to retrieve information about an access preview
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAccessPreview.html
*/
toGetAccessPreview() {
return this.to('GetAccessPreview');
}
/**
* Grants permission to retrieve information about an analyzed resource
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAnalyzedResource.html
*/
toGetAnalyzedResource() {
return this.to('GetAnalyzedResource');
}
/**
* Grants permission to retrieve information about analyzers
*
* Access Level: Read
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAnalyzer.html
*/
toGetAnalyzer() {
return this.to('GetAnalyzer');
}
/**
* Grants permission to retrieve information about archive rules for the specified analyzer
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetArchiveRule.html
*/
toGetArchiveRule() {
return this.to('GetArchiveRule');
}
/**
* Grants permission to retrieve findings
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetFindingV2.html
*/
toGetFinding() {
return this.to('GetFinding');
}
/**
* Grants permission to retrieve recommendation steps to resolve a finding
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetFindingRecommendation.html
*/
toGetFindingRecommendation() {
return this.to('GetFindingRecommendation');
}
/**
* Grants permission to retrieve statistics for findings
*
* Access Level: Read
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#access-analyzer-permissions
*/
toGetFindingsStatistics() {
return this.to('GetFindingsStatistics');
}
/**
* Grants permission to retrieve a policy that was generated using StartPolicyGeneration
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetGeneratedPolicy.html
*/
toGetGeneratedPolicy() {
return this.to('GetGeneratedPolicy');
}
/**
* Grants permission to retrieve a list of findings from an access preview
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAccessPreviewFindings.html
*/
toListAccessPreviewFindings() {
return this.to('ListAccessPreviewFindings');
}
/**
* Grants permission to retrieve a list of access previews
*
* Access Level: List
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAccessPreviews.html
*/
toListAccessPreviews() {
return this.to('ListAccessPreviews');
}
/**
* Grants permission to retrieve a list of resources that have been analyzed
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAnalyzedResources.html
*/
toListAnalyzedResources() {
return this.to('ListAnalyzedResources');
}
/**
* Grants permission to retrieves a list of analyzers
*
* Access Level: List
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAnalyzers.html
*/
toListAnalyzers() {
return this.to('ListAnalyzers');
}
/**
* Grants permission to retrieve a list of archive rules from an analyzer
*
* Access Level: List
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListArchiveRules.html
*/
toListArchiveRules() {
return this.to('ListArchiveRules');
}
/**
* Grants permission to retrieve a list of findings from an analyzer
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListFindingsV2.html
*/
toListFindings() {
return this.to('ListFindings');
}
/**
* Grants permission to list all the recently started policy generations
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListPolicyGenerations.html
*/
toListPolicyGenerations() {
return this.to('ListPolicyGenerations');
}
/**
* Grants permission to retrieve a list of tags applied to a resource
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListTagsForResource.html
*/
toListTagsForResource() {
return this.to('ListTagsForResource');
}
/**
* Grants permission to start a policy generation
*
* Access Level: Write
*
* Dependent actions:
* - iam:PassRole
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_StartPolicyGeneration.html
*/
toStartPolicyGeneration() {
return this.to('StartPolicyGeneration');
}
/**
* Grants permission to start a scan of the policies applied to a resource
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_StartResourceScan.html
*/
toStartResourceScan() {
return this.to('StartResourceScan');
}
/**
* Grants permission to add a tag to a resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsRequestTag()
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_TagResource.html
*/
toTagResource() {
return this.to('TagResource');
}
/**
* Grants permission to remove a tag from a resource
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAwsTagKeys()
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UntagResource.html
*/
toUntagResource() {
return this.to('UntagResource');
}
/**
* Grants permission to modify an analyzer's configuration
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateAnalyzer.html
*/
toUpdateAnalyzer() {
return this.to('UpdateAnalyzer');
}
/**
* Grants permission to modify an archive rule
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateArchiveRule.html
*/
toUpdateArchiveRule() {
return this.to('UpdateArchiveRule');
}
/**
* Grants permission to modify findings
*
* Access Level: Write
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateFindings.html
*/
toUpdateFindings() {
return this.to('UpdateFindings');
}
/**
* Grants permission to validate a policy
*
* Access Level: Read
*
* https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ValidatePolicy.html
*/
toValidatePolicy() {
return this.to('ValidatePolicy');
}
/**
* Adds a resource of type Analyzer to the statement
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources
*
* @param analyzerName - Identifier for the analyzerName.
* @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()
*/
onAnalyzer(analyzerName, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:access-analyzer:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:analyzer/${analyzerName}`);
}
/**
* Adds a resource of type ArchiveRule to the statement
*
* https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources
*
* @param analyzerName - Identifier for the analyzerName.
* @param ruleName - Identifier for the ruleName.
* @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.
*/
onArchiveRule(analyzerName, ruleName, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:access-analyzer:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:analyzer/${analyzerName}/archive-rule/${ruleName}`);
}
/**
* Filters actions based on 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:
* - .toCreateAnalyzer()
* - .toGetAnalyzer()
* - .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 actions based on 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:
* - Analyzer
*
* @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 actions based on 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:
* - .toCreateAnalyzer()
* - .toGetAnalyzer()
* - .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.AccessAnalyzer = AccessAnalyzer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iamaccessanalyzer.js","sourceRoot":"","sources":["iamaccessanalyzer.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 [access-analyzer](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsiamaccessanalyzer.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 AccessAnalyzer extends PolicyStatement {\n  public servicePrefix = 'access-analyzer';\n\n  /**\n   * Statement provider for service [access-analyzer](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsiamaccessanalyzer.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 apply an archive rule\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ApplyArchiveRule.html\n   */\n  public toApplyArchiveRule() {\n    return this.to('ApplyArchiveRule');\n  }\n\n  /**\n   * Grants permission to cancel a policy generation\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CancelPolicyGeneration.html\n   */\n  public toCancelPolicyGeneration() {\n    return this.to('CancelPolicyGeneration');\n  }\n\n  /**\n   * Grants permission to check that specified access is not allowed by a policy\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckAccessNotGranted.html\n   */\n  public toCheckAccessNotGranted() {\n    return this.to('CheckAccessNotGranted');\n  }\n\n  /**\n   * Grants permission to check that no new access is allowed when compared to an existing policy\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckNoNewAccess.html\n   */\n  public toCheckNoNewAccess() {\n    return this.to('CheckNoNewAccess');\n  }\n\n  /**\n   * Grants permission to check that public access is not allowed by a resource policy\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CheckNoPublicAccess.html\n   */\n  public toCheckNoPublicAccess() {\n    return this.to('CheckNoPublicAccess');\n  }\n\n  /**\n   * Grants permission to create an access preview for the specified analyzer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateAccessPreview.html\n   */\n  public toCreateAccessPreview() {\n    return this.to('CreateAccessPreview');\n  }\n\n  /**\n   * Grants permission to create an analyzer\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * Dependent actions:\n   * - iam:CreateServiceLinkedRole\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateAnalyzer.html\n   */\n  public toCreateAnalyzer() {\n    return this.to('CreateAnalyzer');\n  }\n\n  /**\n   * Grants permission to create an archive rule for the specified analyzer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_CreateArchiveRule.html\n   */\n  public toCreateArchiveRule() {\n    return this.to('CreateArchiveRule');\n  }\n\n  /**\n   * Grants permission to delete the specified analyzer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_DeleteAnalyzer.html\n   */\n  public toDeleteAnalyzer() {\n    return this.to('DeleteAnalyzer');\n  }\n\n  /**\n   * Grants permission to delete archive rules for the specified analyzer\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_DeleteArchiveRule.html\n   */\n  public toDeleteArchiveRule() {\n    return this.to('DeleteArchiveRule');\n  }\n\n  /**\n   * Grants permission to generate recommendation steps to resolve a finding\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GenerateFindingRecommendation.html\n   */\n  public toGenerateFindingRecommendation() {\n    return this.to('GenerateFindingRecommendation');\n  }\n\n  /**\n   * Grants permission to retrieve information about an access preview\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAccessPreview.html\n   */\n  public toGetAccessPreview() {\n    return this.to('GetAccessPreview');\n  }\n\n  /**\n   * Grants permission to retrieve information about an analyzed resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAnalyzedResource.html\n   */\n  public toGetAnalyzedResource() {\n    return this.to('GetAnalyzedResource');\n  }\n\n  /**\n   * Grants permission to retrieve information about analyzers\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetAnalyzer.html\n   */\n  public toGetAnalyzer() {\n    return this.to('GetAnalyzer');\n  }\n\n  /**\n   * Grants permission to retrieve information about archive rules for the specified analyzer\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetArchiveRule.html\n   */\n  public toGetArchiveRule() {\n    return this.to('GetArchiveRule');\n  }\n\n  /**\n   * Grants permission to retrieve findings\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetFindingV2.html\n   */\n  public toGetFinding() {\n    return this.to('GetFinding');\n  }\n\n  /**\n   * Grants permission to retrieve recommendation steps to resolve a finding\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetFindingRecommendation.html\n   */\n  public toGetFindingRecommendation() {\n    return this.to('GetFindingRecommendation');\n  }\n\n  /**\n   * Grants permission to retrieve statistics for findings\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#access-analyzer-permissions\n   */\n  public toGetFindingsStatistics() {\n    return this.to('GetFindingsStatistics');\n  }\n\n  /**\n   * Grants permission to retrieve a policy that was generated using StartPolicyGeneration\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_GetGeneratedPolicy.html\n   */\n  public toGetGeneratedPolicy() {\n    return this.to('GetGeneratedPolicy');\n  }\n\n  /**\n   * Grants permission to retrieve a list of findings from an access preview\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAccessPreviewFindings.html\n   */\n  public toListAccessPreviewFindings() {\n    return this.to('ListAccessPreviewFindings');\n  }\n\n  /**\n   * Grants permission to retrieve a list of access previews\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAccessPreviews.html\n   */\n  public toListAccessPreviews() {\n    return this.to('ListAccessPreviews');\n  }\n\n  /**\n   * Grants permission to retrieve a list of resources that have been analyzed\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAnalyzedResources.html\n   */\n  public toListAnalyzedResources() {\n    return this.to('ListAnalyzedResources');\n  }\n\n  /**\n   * Grants permission to retrieves a list of analyzers\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListAnalyzers.html\n   */\n  public toListAnalyzers() {\n    return this.to('ListAnalyzers');\n  }\n\n  /**\n   * Grants permission to retrieve a list of archive rules from an analyzer\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListArchiveRules.html\n   */\n  public toListArchiveRules() {\n    return this.to('ListArchiveRules');\n  }\n\n  /**\n   * Grants permission to retrieve a list of findings from an analyzer\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListFindingsV2.html\n   */\n  public toListFindings() {\n    return this.to('ListFindings');\n  }\n\n  /**\n   * Grants permission to list all the recently started policy generations\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListPolicyGenerations.html\n   */\n  public toListPolicyGenerations() {\n    return this.to('ListPolicyGenerations');\n  }\n\n  /**\n   * Grants permission to retrieve a list of tags applied to a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to start a policy generation\n   *\n   * Access Level: Write\n   *\n   * Dependent actions:\n   * - iam:PassRole\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_StartPolicyGeneration.html\n   */\n  public toStartPolicyGeneration() {\n    return this.to('StartPolicyGeneration');\n  }\n\n  /**\n   * Grants permission to start a scan of the policies applied to a resource\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_StartResourceScan.html\n   */\n  public toStartResourceScan() {\n    return this.to('StartResourceScan');\n  }\n\n  /**\n   * Grants permission to add a tag to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove a tag from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to modify an analyzer's configuration\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateAnalyzer.html\n   */\n  public toUpdateAnalyzer() {\n    return this.to('UpdateAnalyzer');\n  }\n\n  /**\n   * Grants permission to modify an archive rule\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateArchiveRule.html\n   */\n  public toUpdateArchiveRule() {\n    return this.to('UpdateArchiveRule');\n  }\n\n  /**\n   * Grants permission to modify findings\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_UpdateFindings.html\n   */\n  public toUpdateFindings() {\n    return this.to('UpdateFindings');\n  }\n\n  /**\n   * Grants permission to validate a policy\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/access-analyzer/latest/APIReference/API_ValidatePolicy.html\n   */\n  public toValidatePolicy() {\n    return this.to('ValidatePolicy');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'ApplyArchiveRule',\n      'CancelPolicyGeneration',\n      'CreateAccessPreview',\n      'CreateAnalyzer',\n      'CreateArchiveRule',\n      'DeleteAnalyzer',\n      'DeleteArchiveRule',\n      'GenerateFindingRecommendation',\n      'StartPolicyGeneration',\n      'StartResourceScan',\n      'UpdateAnalyzer',\n      'UpdateArchiveRule',\n      'UpdateFindings'\n    ],\n    Read: [\n      'CheckAccessNotGranted',\n      'CheckNoNewAccess',\n      'CheckNoPublicAccess',\n      'GetAccessPreview',\n      'GetAnalyzedResource',\n      'GetAnalyzer',\n      'GetArchiveRule',\n      'GetFinding',\n      'GetFindingRecommendation',\n      'GetFindingsStatistics',\n      'GetGeneratedPolicy',\n      'ListAccessPreviewFindings',\n      'ListAnalyzedResources',\n      'ListFindings',\n      'ListPolicyGenerations',\n      'ListTagsForResource',\n      'ValidatePolicy'\n    ],\n    List: [\n      'ListAccessPreviews',\n      'ListAnalyzers',\n      'ListArchiveRules'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type Analyzer to the statement\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources\n   *\n   * @param analyzerName - Identifier for the analyzerName.\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 onAnalyzer(analyzerName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:access-analyzer:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:analyzer/${ analyzerName }`);\n  }\n\n  /**\n   * Adds a resource of type ArchiveRule to the statement\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/access-analyzer-getting-started.html#permission-resources\n   *\n   * @param analyzerName - Identifier for the analyzerName.\n   * @param ruleName - Identifier for the ruleName.\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  public onArchiveRule(analyzerName: string, ruleName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:access-analyzer:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:analyzer/${ analyzerName }/archive-rule/${ ruleName }`);\n  }\n\n  /**\n   * Filters actions based on 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   * - .toCreateAnalyzer()\n   * - .toGetAnalyzer()\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 actions based on 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   * - Analyzer\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 actions based on 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   * - .toCreateAnalyzer()\n   * - .toGetAnalyzer()\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"]}