Classic ASP
Classic ASP
Glacier Get Inventory Retrieval Job Output
See more Amazon Glacier Examples
Demonstrates how to get and parse the inventory retrieval job output.Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
set rest = Server.CreateObject("Chilkat.Rest")
' Connect to the Amazon AWS REST server in the desired region.
bTls = 1
port = 443
bAutoReconnect = 1
success = rest.Connect("glacier.us-west-2.amazonaws.com",port,bTls,bAutoReconnect)
' Provide AWS credentials.
set authAws = Server.CreateObject("Chilkat.AuthAws")
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.SecretKey = "AWS_SECRET_KEY"
authAws.ServiceName = "glacier"
authAws.Region = "us-west-2"
success = rest.SetAuthAws(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
'
success = rest.AddHeader("x-amz-glacier-version","2012-06-01")
set sbResponseBody = Server.CreateObject("Chilkat.StringBuilder")
success = rest.FullRequestNoBodySb("GET","/AWS_ACCOUNT_ID/vaults/chilkat/jobs/JOB_ID/output",sbResponseBody)
If (success <> 1) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
respStatusCode = rest.ResponseStatusCode
If (respStatusCode >= 400) Then
Response.Write "<pre>" & Server.HTMLEncode( "Response Status Code = " & respStatusCode) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response Header:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( rest.ResponseHeader) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response Body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( sbResponseBody.GetAsString()) & "</pre>"
Response.End
End If
' Success is indicated by a 200 response status.
Response.Write "<pre>" & Server.HTMLEncode( "response status code = " & respStatusCode) & "</pre>"
' The inventory retrieval job output is in CSV format.
Response.Write "<pre>" & Server.HTMLEncode( "job output:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( sbResponseBody.GetAsString()) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "--") & "</pre>"
' The CSV has these fields: ArchiveId,ArchiveDescription,CreationDate,Size,SHA256TreeHash
' Parse the CSV like this...
set csv = Server.CreateObject("Chilkat.Csv")
csv.HasColumnNames = 1
success = csv.LoadFromString(sbResponseBody.GetAsString())
i = 0
numRows = csv.NumRows
Do While i < numRows
Response.Write "<pre>" & Server.HTMLEncode( "ArchiveId: " & csv.GetCellByName(i,"ArchiveId")) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Description: " & csv.GetCellByName(i,"ArchiveDescription")) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Size: " & csv.GetCellByName(i,"Size")) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "-") & "</pre>"
i = i + 1
Loop
%>
</body>
</html>