Tcl
Tcl
Amazon Glacier Delete Archive
See more Amazon Glacier Examples
Demonstrates how to delete an archive from a vault. You can delete one archive at a time from a vault. To delete the archive you must provide its archive ID in the delete request. You can get the archive ID by downloading the vault inventory for the vault that contains the archive.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set rest [new_CkRest]
# Connect to the Amazon AWS REST server in the desired region.
set bTls 1
set port 443
set bAutoReconnect 1
set success [CkRest_Connect $rest "glacier.us-west-2.amazonaws.com" $port $bTls $bAutoReconnect]
# Provide AWS credentials.
set authAws [new_CkAuthAws]
CkAuthAws_put_AccessKey $authAws "AWS_ACCESS_KEY"
CkAuthAws_put_SecretKey $authAws "AWS_SECRET_KEY"
CkAuthAws_put_ServiceName $authAws "glacier"
CkAuthAws_put_Region $authAws "us-west-2"
set success [CkRest_SetAuthAws $rest $authAws]
# --------------------------------------------------------------------------
# Note: The above REST connection and setup of the AWS credentials
# can be done once. After connecting, any number of REST calls can be made.
# The "auto reconnect" property passed to rest.Connect indicates that if
# the connection is lost, a REST method call will automatically reconnect
# if needed.
# --------------------------------------------------------------------------
#
# For more information, see Glacier Delete Archive Reference Documentation
#
CkRest_AddHeader $rest "x-amz-glacier-version" "2012-06-01"
# Delete the access policy for the "chilkat" vault.
set sbResponseBody [new_CkStringBuilder]
# Specify the x-amz-archive-id returned by Glacier when the archive was originally uploaded.
# (The x-amz-archive-id can also be obtained by fetching the archive inventory.)
CkRest_AddPathParam $rest "ArchiveID" "u2DRi9wXfC-40ofjphG-oU9CQTo2PgbiHSqp8j0ISTSea7dZxABB-jkt-B_kgGU8uCCWVFUNqB4ZnE1Aw-MTZ-MZDC4w-fWmM-1UE-bSpqOUy2_BzyopZg1Dq_wOgti_6oUEz7rRmQ"
set success [CkRest_FullRequestNoBodySb $rest "DELETE" "/AWS_ACCOUNT_ID/vaults/chilkat/archives/ArchiveID" $sbResponseBody]
if {$success != 1} then {
puts [CkRest_lastErrorText $rest]
delete_CkRest $rest
delete_CkAuthAws $authAws
delete_CkStringBuilder $sbResponseBody
exit
}
set respStatusCode [CkRest_get_ResponseStatusCode $rest]
if {$respStatusCode >= 400} then {
puts "Response Status Code = $respStatusCode"
puts "Response Header:"
puts [CkRest_responseHeader $rest]
puts "Response Body:"
puts [CkStringBuilder_getAsString $sbResponseBody]
delete_CkRest $rest
delete_CkAuthAws $authAws
delete_CkStringBuilder $sbResponseBody
exit
}
# Success is indicated by a 204 response status with an empty response body.
puts "response status code = $respStatusCode"
delete_CkRest $rest
delete_CkAuthAws $authAws
delete_CkStringBuilder $sbResponseBody