Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Glacier Delete All Archives in a VaultIterates over a vault inventory retrieval and deletes each archive.
load ./chilkat.dll # 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 Retrieve Job Output Reference Documentation # CkRest_AddHeader $rest "x-amz-glacier-version" "2012-06-01" set sbResponseBody [new_CkStringBuilder] set success [CkRest_FullRequestNoBodySb $rest "GET" "/AWS_ACCOUNT_ID/vaults/chilkat/jobs/JOB_ID/output" $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 200 response status. puts "response status code = $respStatusCode" # The inventory retrieval job output is in CSV format. puts "job output:" puts [CkStringBuilder_getAsString $sbResponseBody] puts "--" # The CSV has these fields: ArchiveId,ArchiveDescription,CreationDate,Size,SHA256TreeHash set csv [new_CkCsv] CkCsv_put_HasColumnNames $csv 1 CkCsv_LoadFromString $csv [CkStringBuilder_getAsString $sbResponseBody] # Iterate over the results and delete each archive from the vault. set i 0 set numRows [CkCsv_get_NumRows $csv] while {$i < $numRows} { set archiveId [CkCsv_getCellByName $csv $i "ArchiveId"] puts "Deleting ArchiveId: $archiveId" CkRest_AddPathParam $rest "ArchiveID" $archiveId 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 delete_CkCsv $csv exit } set respStatusCode [CkRest_get_ResponseStatusCode $rest] # Success is indicated by a 204 response status with an empty response body. # A 404 resonse indicates the archive was likely already deleted. puts "response status code = $respStatusCode" set i [expr $i + 1] } delete_CkRest $rest delete_CkAuthAws $authAws delete_CkStringBuilder $sbResponseBody delete_CkCsv $csv |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.