iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
607 lines • 49.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.S3ObjectLambda = void 0;
const shared_1 = require("../../shared");
/**
* Statement provider for service [s3-object-lambda](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3objectlambda.html).
*
* @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement
*/
class S3ObjectLambda extends shared_1.PolicyStatement {
/**
* Statement provider for service [s3-object-lambda](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3objectlambda.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 = 's3-object-lambda';
this.accessLevelList = {
Write: [
'AbortMultipartUpload',
'DeleteObject',
'DeleteObjectVersion',
'PutObject',
'PutObjectLegalHold',
'PutObjectRetention',
'RestoreObject',
'WriteGetObjectResponse'
],
Tagging: [
'DeleteObjectTagging',
'DeleteObjectVersionTagging',
'PutObjectTagging',
'PutObjectVersionTagging'
],
Read: [
'GetObject',
'GetObjectAcl',
'GetObjectLegalHold',
'GetObjectRetention',
'GetObjectTagging',
'GetObjectVersion',
'GetObjectVersionAcl',
'GetObjectVersionTagging'
],
List: [
'ListBucket',
'ListBucketMultipartUploads',
'ListBucketVersions',
'ListMultipartUploadParts'
],
'Permissions management': [
'PutObjectAcl',
'PutObjectVersionAcl'
]
};
}
/**
* Grants permission to abort a multipart upload
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_AbortMultipartUpload.html
*/
toAbortMultipartUpload() {
return this.to('AbortMultipartUpload');
}
/**
* Grants permission to remove the null version of an object and insert a delete marker, which becomes the current version of the object
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObject.html
*/
toDeleteObject() {
return this.to('DeleteObject');
}
/**
* Grants permission to use the tagging subresource to remove the entire tag set from the specified object
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObjectTagging.html
*/
toDeleteObjectTagging() {
return this.to('DeleteObjectTagging');
}
/**
* Grants permission to remove a specific version of an object
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObject.html
*/
toDeleteObjectVersion() {
return this.to('DeleteObjectVersion');
}
/**
* Grants permission to remove the entire tag set for a specific version of the object
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObjectTagging.html
*/
toDeleteObjectVersionTagging() {
return this.to('DeleteObjectVersionTagging');
}
/**
* Grants permission to retrieve objects from Amazon S3
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html
*/
toGetObject() {
return this.to('GetObject');
}
/**
* Grants permission to return the access control list (ACL) of an object
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectAcl.html
*/
toGetObjectAcl() {
return this.to('GetObjectAcl');
}
/**
* Grants permission to get an object's current Legal Hold status
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectLegalHold.html
*/
toGetObjectLegalHold() {
return this.to('GetObjectLegalHold');
}
/**
* Grants permission to retrieve the retention settings for an object
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectRetention.html
*/
toGetObjectRetention() {
return this.to('GetObjectRetention');
}
/**
* Grants permission to return the tag set of an object
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectTagging.html
*/
toGetObjectTagging() {
return this.to('GetObjectTagging');
}
/**
* Grants permission to retrieve a specific version of an object
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html
*/
toGetObjectVersion() {
return this.to('GetObjectVersion');
}
/**
* Grants permission to return the access control list (ACL) of a specific object version
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectAcl.html
*/
toGetObjectVersionAcl() {
return this.to('GetObjectVersionAcl');
}
/**
* Grants permission to return the tag set for a specific version of the object
*
* Access Level: Read
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/dev/setting-repl-config-perm-overview.html
*/
toGetObjectVersionTagging() {
return this.to('GetObjectVersionTagging');
}
/**
* Grants permission to list some or all of the objects in an Amazon S3 bucket (up to 1000)
*
* Access Level: List
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListObjectsV2.html
*/
toListBucket() {
return this.to('ListBucket');
}
/**
* Grants permission to list in-progress multipart uploads
*
* Access Level: List
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListMultipartUploads.html
*/
toListBucketMultipartUploads() {
return this.to('ListBucketMultipartUploads');
}
/**
* Grants permission to list metadata about all the versions of objects in an Amazon S3 bucket
*
* Access Level: List
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListObjectVersions.html
*/
toListBucketVersions() {
return this.to('ListBucketVersions');
}
/**
* Grants permission to list the parts that have been uploaded for a specific multipart upload
*
* Access Level: List
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListParts.html
*/
toListMultipartUploadParts() {
return this.to('ListMultipartUploadParts');
}
/**
* Grants permission to add an object to a bucket
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObject.html
*/
toPutObject() {
return this.to('PutObject');
}
/**
* Grants permission to set the access control list (ACL) permissions for new or existing objects in an S3 bucket
*
* Access Level: Permissions management
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectAcl.html
*/
toPutObjectAcl() {
return this.to('PutObjectAcl');
}
/**
* Grants permission to apply a Legal Hold configuration to the specified object
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectLegalHold.html
*/
toPutObjectLegalHold() {
return this.to('PutObjectLegalHold');
}
/**
* Grants permission to place an Object Retention configuration on an object
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectRetention.html
*/
toPutObjectRetention() {
return this.to('PutObjectRetention');
}
/**
* Grants permission to set the supplied tag-set to an object that already exists in a bucket
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectTagging.html
*/
toPutObjectTagging() {
return this.to('PutObjectTagging');
}
/**
* Grants permission to use the acl subresource to set the access control list (ACL) permissions for an object that already exists in a bucket
*
* Access Level: Permissions management
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectAcl.html
*/
toPutObjectVersionAcl() {
return this.to('PutObjectVersionAcl');
}
/**
* Grants permission to set the supplied tag-set for a specific version of an object
*
* Access Level: Tagging
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
* - .ifVersionid()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectTagging.html
*/
toPutObjectVersionTagging() {
return this.to('PutObjectVersionTagging');
}
/**
* Grants permission to restore an archived copy of an object back into Amazon S3
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_RestoreObject.html
*/
toRestoreObject() {
return this.to('RestoreObject');
}
/**
* Grants permission to provide data for GetObject requests send to S3 Object Lambda
*
* Access Level: Write
*
* Possible conditions:
* - .ifAuthType()
* - .ifSignatureAge()
* - .ifTlsVersion()
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/API_WriteGetObjectResponse.html
*/
toWriteGetObjectResponse() {
return this.to('WriteGetObjectResponse');
}
/**
* Adds a resource of type objectlambdaaccesspoint to the statement
*
* https://docs.aws.amazon.com/AmazonS3/latest/dev/transforming-objects.html
*
* @param accessPointName - Identifier for the accessPointName.
* @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.
*/
onObjectlambdaaccesspoint(accessPointName, account, region, partition) {
return this.on(`arn:${partition ?? this.defaultPartition}:s3-object-lambda:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:accesspoint/${accessPointName}`);
}
/**
* Filters access by the TLS version used by the client
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html
*
* Applies to actions:
* - .toAbortMultipartUpload()
* - .toDeleteObject()
* - .toDeleteObjectTagging()
* - .toDeleteObjectVersion()
* - .toDeleteObjectVersionTagging()
* - .toGetObject()
* - .toGetObjectAcl()
* - .toGetObjectLegalHold()
* - .toGetObjectRetention()
* - .toGetObjectTagging()
* - .toGetObjectVersion()
* - .toGetObjectVersionAcl()
* - .toGetObjectVersionTagging()
* - .toListBucket()
* - .toListBucketMultipartUploads()
* - .toListBucketVersions()
* - .toListMultipartUploadParts()
* - .toPutObject()
* - .toPutObjectAcl()
* - .toPutObjectLegalHold()
* - .toPutObjectRetention()
* - .toPutObjectTagging()
* - .toPutObjectVersionAcl()
* - .toPutObjectVersionTagging()
* - .toRestoreObject()
* - .toWriteGetObjectResponse()
*
* @param value The value(s) to check
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
*/
ifTlsVersion(value, operator) {
return this.if(`TlsVersion`, value, operator ?? 'NumericEquals');
}
/**
* Filters access by authentication method
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html
*
* Applies to actions:
* - .toAbortMultipartUpload()
* - .toDeleteObject()
* - .toDeleteObjectTagging()
* - .toDeleteObjectVersion()
* - .toDeleteObjectVersionTagging()
* - .toGetObject()
* - .toGetObjectAcl()
* - .toGetObjectLegalHold()
* - .toGetObjectRetention()
* - .toGetObjectTagging()
* - .toGetObjectVersion()
* - .toGetObjectVersionAcl()
* - .toGetObjectVersionTagging()
* - .toListBucket()
* - .toListBucketMultipartUploads()
* - .toListBucketVersions()
* - .toListMultipartUploadParts()
* - .toPutObject()
* - .toPutObjectAcl()
* - .toPutObjectLegalHold()
* - .toPutObjectRetention()
* - .toPutObjectTagging()
* - .toPutObjectVersionAcl()
* - .toPutObjectVersionTagging()
* - .toRestoreObject()
* - .toWriteGetObjectResponse()
*
* @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`
*/
ifAuthType(value, operator) {
return this.if(`authType`, value, operator ?? 'StringLike');
}
/**
* Filters access by the age in milliseconds of the request signature
*
* https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html
*
* Applies to actions:
* - .toAbortMultipartUpload()
* - .toDeleteObject()
* - .toDeleteObjectTagging()
* - .toDeleteObjectVersion()
* - .toDeleteObjectVersionTagging()
* - .toGetObject()
* - .toGetObjectAcl()
* - .toGetObjectLegalHold()
* - .toGetObjectRetention()
* - .toGetObjectTagging()
* - .toGetObjectVersion()
* - .toGetObjectVersionAcl()
* - .toGetObjectVersionTagging()
* - .toListBucket()
* - .toListBucketMultipartUploads()
* - .toListBucketVersions()
* - .toListMultipartUploadParts()
* - .toPutObject()
* - .toPutObjectAcl()
* - .toPutObjectLegalHold()
* - .toPutObjectRetention()
* - .toPutObjectTagging()
* - .toPutObjectVersionAcl()
* - .toPutObjectVersionTagging()
* - .toRestoreObject()
* - .toWriteGetObjectResponse()
*
* @param value The value(s) to check
* @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`
*/
ifSignatureAge(value, operator) {
return this.if(`signatureAge`, value, operator ?? 'NumericEquals');
}
/**
* Filters access by a specific object version
*
* https://docs.aws.amazon.com/AmazonS3/latest/dev/amazon-s3-policy-keys.html/#getobjectversion-limit-access-to-specific-version-3
*
* Applies to actions:
* - .toDeleteObjectVersion()
* - .toDeleteObjectVersionTagging()
* - .toGetObjectVersion()
* - .toGetObjectVersionAcl()
* - .toGetObjectVersionTagging()
* - .toPutObjectVersionAcl()
* - .toPutObjectVersionTagging()
*
* @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`
*/
ifVersionid(value, operator) {
return this.if(`versionid`, value, operator ?? 'StringLike');
}
}
exports.S3ObjectLambda = S3ObjectLambda;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"s3objectlambda.js","sourceRoot":"","sources":["s3objectlambda.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 [s3-object-lambda](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3objectlambda.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 S3ObjectLambda extends PolicyStatement {\n  public servicePrefix = 's3-object-lambda';\n\n  /**\n   * Statement provider for service [s3-object-lambda](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3objectlambda.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 abort a multipart upload\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_AbortMultipartUpload.html\n   */\n  public toAbortMultipartUpload() {\n    return this.to('AbortMultipartUpload');\n  }\n\n  /**\n   * Grants permission to remove the null version of an object and insert a delete marker, which becomes the current version of the object\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObject.html\n   */\n  public toDeleteObject() {\n    return this.to('DeleteObject');\n  }\n\n  /**\n   * Grants permission to use the tagging subresource to remove the entire tag set from the specified object\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObjectTagging.html\n   */\n  public toDeleteObjectTagging() {\n    return this.to('DeleteObjectTagging');\n  }\n\n  /**\n   * Grants permission to remove a specific version of an object\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObject.html\n   */\n  public toDeleteObjectVersion() {\n    return this.to('DeleteObjectVersion');\n  }\n\n  /**\n   * Grants permission to remove the entire tag set for a specific version of the object\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_DeleteObjectTagging.html\n   */\n  public toDeleteObjectVersionTagging() {\n    return this.to('DeleteObjectVersionTagging');\n  }\n\n  /**\n   * Grants permission to retrieve objects from Amazon S3\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html\n   */\n  public toGetObject() {\n    return this.to('GetObject');\n  }\n\n  /**\n   * Grants permission to return the access control list (ACL) of an object\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectAcl.html\n   */\n  public toGetObjectAcl() {\n    return this.to('GetObjectAcl');\n  }\n\n  /**\n   * Grants permission to get an object's current Legal Hold status\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectLegalHold.html\n   */\n  public toGetObjectLegalHold() {\n    return this.to('GetObjectLegalHold');\n  }\n\n  /**\n   * Grants permission to retrieve the retention settings for an object\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectRetention.html\n   */\n  public toGetObjectRetention() {\n    return this.to('GetObjectRetention');\n  }\n\n  /**\n   * Grants permission to return the tag set of an object\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectTagging.html\n   */\n  public toGetObjectTagging() {\n    return this.to('GetObjectTagging');\n  }\n\n  /**\n   * Grants permission to retrieve a specific version of an object\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html\n   */\n  public toGetObjectVersion() {\n    return this.to('GetObjectVersion');\n  }\n\n  /**\n   * Grants permission to return the access control list (ACL) of a specific object version\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObjectAcl.html\n   */\n  public toGetObjectVersionAcl() {\n    return this.to('GetObjectVersionAcl');\n  }\n\n  /**\n   * Grants permission to return the tag set for a specific version of the object\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/dev/setting-repl-config-perm-overview.html\n   */\n  public toGetObjectVersionTagging() {\n    return this.to('GetObjectVersionTagging');\n  }\n\n  /**\n   * Grants permission to list some or all of the objects in an Amazon S3 bucket (up to 1000)\n   *\n   * Access Level: List\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListObjectsV2.html\n   */\n  public toListBucket() {\n    return this.to('ListBucket');\n  }\n\n  /**\n   * Grants permission to list in-progress multipart uploads\n   *\n   * Access Level: List\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListMultipartUploads.html\n   */\n  public toListBucketMultipartUploads() {\n    return this.to('ListBucketMultipartUploads');\n  }\n\n  /**\n   * Grants permission to list metadata about all the versions of objects in an Amazon S3 bucket\n   *\n   * Access Level: List\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListObjectVersions.html\n   */\n  public toListBucketVersions() {\n    return this.to('ListBucketVersions');\n  }\n\n  /**\n   * Grants permission to list the parts that have been uploaded for a specific multipart upload\n   *\n   * Access Level: List\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_ListParts.html\n   */\n  public toListMultipartUploadParts() {\n    return this.to('ListMultipartUploadParts');\n  }\n\n  /**\n   * Grants permission to add an object to a bucket\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObject.html\n   */\n  public toPutObject() {\n    return this.to('PutObject');\n  }\n\n  /**\n   * Grants permission to set the access control list (ACL) permissions for new or existing objects in an S3 bucket\n   *\n   * Access Level: Permissions management\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectAcl.html\n   */\n  public toPutObjectAcl() {\n    return this.to('PutObjectAcl');\n  }\n\n  /**\n   * Grants permission to apply a Legal Hold configuration to the specified object\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectLegalHold.html\n   */\n  public toPutObjectLegalHold() {\n    return this.to('PutObjectLegalHold');\n  }\n\n  /**\n   * Grants permission to place an Object Retention configuration on an object\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectRetention.html\n   */\n  public toPutObjectRetention() {\n    return this.to('PutObjectRetention');\n  }\n\n  /**\n   * Grants permission to set the supplied tag-set to an object that already exists in a bucket\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectTagging.html\n   */\n  public toPutObjectTagging() {\n    return this.to('PutObjectTagging');\n  }\n\n  /**\n   * Grants permission to use the acl subresource to set the access control list (ACL) permissions for an object that already exists in a bucket\n   *\n   * Access Level: Permissions management\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectAcl.html\n   */\n  public toPutObjectVersionAcl() {\n    return this.to('PutObjectVersionAcl');\n  }\n\n  /**\n   * Grants permission to set the supplied tag-set for a specific version of an object\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   * - .ifVersionid()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObjectTagging.html\n   */\n  public toPutObjectVersionTagging() {\n    return this.to('PutObjectVersionTagging');\n  }\n\n  /**\n   * Grants permission to restore an archived copy of an object back into Amazon S3\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_RestoreObject.html\n   */\n  public toRestoreObject() {\n    return this.to('RestoreObject');\n  }\n\n  /**\n   * Grants permission to provide data for GetObject requests send to S3 Object Lambda\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAuthType()\n   * - .ifSignatureAge()\n   * - .ifTlsVersion()\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/API_WriteGetObjectResponse.html\n   */\n  public toWriteGetObjectResponse() {\n    return this.to('WriteGetObjectResponse');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AbortMultipartUpload',\n      'DeleteObject',\n      'DeleteObjectVersion',\n      'PutObject',\n      'PutObjectLegalHold',\n      'PutObjectRetention',\n      'RestoreObject',\n      'WriteGetObjectResponse'\n    ],\n    Tagging: [\n      'DeleteObjectTagging',\n      'DeleteObjectVersionTagging',\n      'PutObjectTagging',\n      'PutObjectVersionTagging'\n    ],\n    Read: [\n      'GetObject',\n      'GetObjectAcl',\n      'GetObjectLegalHold',\n      'GetObjectRetention',\n      'GetObjectTagging',\n      'GetObjectVersion',\n      'GetObjectVersionAcl',\n      'GetObjectVersionTagging'\n    ],\n    List: [\n      'ListBucket',\n      'ListBucketMultipartUploads',\n      'ListBucketVersions',\n      'ListMultipartUploadParts'\n    ],\n    'Permissions management': [\n      'PutObjectAcl',\n      'PutObjectVersionAcl'\n    ]\n  };\n\n  /**\n   * Adds a resource of type objectlambdaaccesspoint to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/dev/transforming-objects.html\n   *\n   * @param accessPointName - Identifier for the accessPointName.\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 onObjectlambdaaccesspoint(accessPointName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:s3-object-lambda:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:accesspoint/${ accessPointName }`);\n  }\n\n  /**\n   * Filters access by the TLS version used by the client\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html\n   *\n   * Applies to actions:\n   * - .toAbortMultipartUpload()\n   * - .toDeleteObject()\n   * - .toDeleteObjectTagging()\n   * - .toDeleteObjectVersion()\n   * - .toDeleteObjectVersionTagging()\n   * - .toGetObject()\n   * - .toGetObjectAcl()\n   * - .toGetObjectLegalHold()\n   * - .toGetObjectRetention()\n   * - .toGetObjectTagging()\n   * - .toGetObjectVersion()\n   * - .toGetObjectVersionAcl()\n   * - .toGetObjectVersionTagging()\n   * - .toListBucket()\n   * - .toListBucketMultipartUploads()\n   * - .toListBucketVersions()\n   * - .toListMultipartUploadParts()\n   * - .toPutObject()\n   * - .toPutObjectAcl()\n   * - .toPutObjectLegalHold()\n   * - .toPutObjectRetention()\n   * - .toPutObjectTagging()\n   * - .toPutObjectVersionAcl()\n   * - .toPutObjectVersionTagging()\n   * - .toRestoreObject()\n   * - .toWriteGetObjectResponse()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`\n   */\n  public ifTlsVersion(value: number | number[], operator?: Operator | string) {\n    return this.if(`TlsVersion`, value, operator ?? 'NumericEquals');\n  }\n\n  /**\n   * Filters access by authentication method\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html\n   *\n   * Applies to actions:\n   * - .toAbortMultipartUpload()\n   * - .toDeleteObject()\n   * - .toDeleteObjectTagging()\n   * - .toDeleteObjectVersion()\n   * - .toDeleteObjectVersionTagging()\n   * - .toGetObject()\n   * - .toGetObjectAcl()\n   * - .toGetObjectLegalHold()\n   * - .toGetObjectRetention()\n   * - .toGetObjectTagging()\n   * - .toGetObjectVersion()\n   * - .toGetObjectVersionAcl()\n   * - .toGetObjectVersionTagging()\n   * - .toListBucket()\n   * - .toListBucketMultipartUploads()\n   * - .toListBucketVersions()\n   * - .toListMultipartUploadParts()\n   * - .toPutObject()\n   * - .toPutObjectAcl()\n   * - .toPutObjectLegalHold()\n   * - .toPutObjectRetention()\n   * - .toPutObjectTagging()\n   * - .toPutObjectVersionAcl()\n   * - .toPutObjectVersionTagging()\n   * - .toRestoreObject()\n   * - .toWriteGetObjectResponse()\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 ifAuthType(value: string | string[], operator?: Operator | string) {\n    return this.if(`authType`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the age in milliseconds of the request signature\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/API/bucket-policy-s3-sigv4-conditions.html\n   *\n   * Applies to actions:\n   * - .toAbortMultipartUpload()\n   * - .toDeleteObject()\n   * - .toDeleteObjectTagging()\n   * - .toDeleteObjectVersion()\n   * - .toDeleteObjectVersionTagging()\n   * - .toGetObject()\n   * - .toGetObjectAcl()\n   * - .toGetObjectLegalHold()\n   * - .toGetObjectRetention()\n   * - .toGetObjectTagging()\n   * - .toGetObjectVersion()\n   * - .toGetObjectVersionAcl()\n   * - .toGetObjectVersionTagging()\n   * - .toListBucket()\n   * - .toListBucketMultipartUploads()\n   * - .toListBucketVersions()\n   * - .toListMultipartUploadParts()\n   * - .toPutObject()\n   * - .toPutObjectAcl()\n   * - .toPutObjectLegalHold()\n   * - .toPutObjectRetention()\n   * - .toPutObjectTagging()\n   * - .toPutObjectVersionAcl()\n   * - .toPutObjectVersionTagging()\n   * - .toRestoreObject()\n   * - .toWriteGetObjectResponse()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [numeric operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_Numeric). **Default:** `NumericEquals`\n   */\n  public ifSignatureAge(value: number | number[], operator?: Operator | string) {\n    return this.if(`signatureAge`, value, operator ?? 'NumericEquals');\n  }\n\n  /**\n   * Filters access by a specific object version\n   *\n   * https://docs.aws.amazon.com/AmazonS3/latest/dev/amazon-s3-policy-keys.html/#getobjectversion-limit-access-to-specific-version-3\n   *\n   * Applies to actions:\n   * - .toDeleteObjectVersion()\n   * - .toDeleteObjectVersionTagging()\n   * - .toGetObjectVersion()\n   * - .toGetObjectVersionAcl()\n   * - .toGetObjectVersionTagging()\n   * - .toPutObjectVersionAcl()\n   * - .toPutObjectVersionTagging()\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 ifVersionid(value: string | string[], operator?: Operator | string) {\n    return this.if(`versionid`, value, operator ?? 'StringLike');\n  }\n}\n"]}