ObjectVersion / Action / delete
delete#
- S3.ObjectVersion.delete(**kwargs)#
Removes the null version (if there is one) of an object and inserts a delete marker, which becomes the latest version of the object. If there isn’t a null version, Amazon S3 does not remove any objects but will still respond that the command was successful.
To remove a specific version, you must be the bucket owner and you must use the version Id subresource. Using this subresource permanently deletes the version. If the object deleted is a delete marker, Amazon S3 sets the response header,
x-amz-delete-marker, to true.If the object you want to delete is in a bucket where the bucket versioning configuration is MFA Delete enabled, you must include the
x-amz-mfarequest header in the DELETEversionIdrequest. Requests that includex-amz-mfamust use HTTPS.For more information about MFA Delete, see Using MFA Delete. To see sample requests that use versioning, see Sample Request.
You can delete objects by explicitly calling DELETE Object or configure its lifecycle ( PutBucketLifecycle) to enable Amazon S3 to remove them for you. If you want to block users or accounts from removing or deleting objects from your bucket, you must deny them the
s3:DeleteObject,s3:DeleteObjectVersion, ands3:PutLifeCycleConfigurationactions.The following action is related to
DeleteObject:See also: AWS API Documentation
Request Syntax
response = object_version.delete( MFA='string', RequestPayer='requester', BypassGovernanceRetention=True|False, ExpectedBucketOwner='string', ChecksumAlgorithm='CRC32'|'CRC32C'|'SHA1'|'SHA256'|'CRC64NVME' )
- Parameters:
MFA (string) – The concatenation of the authentication device’s serial number, a space, and the value that is displayed on your authentication device. Required to permanently delete a versioned object if versioning is configured with MFA delete enabled.
RequestPayer (string) – Ignored by COS if present.
BypassGovernanceRetention (boolean) – Ignored by COS if present.
ExpectedBucketOwner (string) – Ignored by COS if present.
ChecksumAlgorithm (string) –
Indicates the algorithm used to create the checksum for the object when you use the SDK. This header will not provide any additional functionality if you don’t use the SDK. When you send this header, there must be a corresponding
x-amz-checksum-algorithmorx-amz-trailerheader sent. Otherwise, Amazon S3 fails the request with the HTTP status code400 Bad Request.For the
x-amz-checksum-algorithmheader, replacealgorithmwith the supported algorithm from the following list:CRC32CRC32CCRC64NVMESHA1SHA256
For more information, see Checking object integrity in the Amazon S3 User Guide.
If the individual checksum value you provide through
x-amz-checksum-algorithmdoesn’t match the checksum algorithm you set throughx-amz-sdk-checksum-algorithm, Amazon S3 fails the request with aBadDigesterror.If you provide an individual checksum, Amazon S3 ignores any provided
ChecksumAlgorithmparameter.
- Return type:
dict
- Returns:
Response Syntax
{ 'DeleteMarker': True|False, 'VersionId': 'string', 'RequestCharged': 'requester' }
Response Structure
(dict) –
DeleteMarker (boolean) –
Specifies whether the versioned object that was permanently deleted was (true) or was not (false) a delete marker.
VersionId (string) –
Returns the version ID of the delete marker created as a result of the DELETE operation.
RequestCharged (string) – Not returned by COS.