DataFlex
DataFlex
Glacier Get Inventory Retrieval Job Output
See more Amazon Glacier Examples
Demonstrates how to get and parse the inventory retrieval job output.Chilkat DataFlex Downloads
Use ChilkatAx-win32.pkg
Procedure Test
Boolean iSuccess
Handle hoRest
Boolean iBTls
Integer iPort
Boolean iBAutoReconnect
Variant vAuthAws
Handle hoAuthAws
Variant vSbResponseBody
Handle hoSbResponseBody
Integer iRespStatusCode
Handle hoCsv
Integer i
Integer iNumRows
String sTemp1
Move False To iSuccess
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
Get Create (RefClass(cComChilkatRest)) To hoRest
If (Not(IsComObjectCreated(hoRest))) Begin
Send CreateComObject of hoRest
End
// Connect to the Amazon AWS REST server in the desired region.
Move True To iBTls
Move 443 To iPort
Move True To iBAutoReconnect
Get ComConnect Of hoRest "glacier.us-west-2.amazonaws.com" iPort iBTls iBAutoReconnect To iSuccess
// Provide AWS credentials.
Get Create (RefClass(cComChilkatAuthAws)) To hoAuthAws
If (Not(IsComObjectCreated(hoAuthAws))) Begin
Send CreateComObject of hoAuthAws
End
Set ComAccessKey Of hoAuthAws To "AWS_ACCESS_KEY"
Set ComSecretKey Of hoAuthAws To "AWS_SECRET_KEY"
Set ComServiceName Of hoAuthAws To "glacier"
Set ComRegion Of hoAuthAws To "us-west-2"
Get pvComObject of hoAuthAws to vAuthAws
Get ComSetAuthAws Of hoRest vAuthAws To iSuccess
// --------------------------------------------------------------------------
// 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
//
Get ComAddHeader Of hoRest "x-amz-glacier-version" "2012-06-01" To iSuccess
Get Create (RefClass(cComChilkatStringBuilder)) To hoSbResponseBody
If (Not(IsComObjectCreated(hoSbResponseBody))) Begin
Send CreateComObject of hoSbResponseBody
End
Get pvComObject of hoSbResponseBody to vSbResponseBody
Get ComFullRequestNoBodySb Of hoRest "GET" "/AWS_ACCOUNT_ID/vaults/chilkat/jobs/JOB_ID/output" vSbResponseBody To iSuccess
If (iSuccess <> True) Begin
Get ComLastErrorText Of hoRest To sTemp1
Showln sTemp1
Procedure_Return
End
Get ComResponseStatusCode Of hoRest To iRespStatusCode
If (iRespStatusCode >= 400) Begin
Showln "Response Status Code = " iRespStatusCode
Showln "Response Header:"
Get ComResponseHeader Of hoRest To sTemp1
Showln sTemp1
Showln "Response Body:"
Get ComGetAsString Of hoSbResponseBody To sTemp1
Showln sTemp1
Procedure_Return
End
// Success is indicated by a 200 response status.
Showln "response status code = " iRespStatusCode
// The inventory retrieval job output is in CSV format.
Showln "job output:"
Get ComGetAsString Of hoSbResponseBody To sTemp1
Showln sTemp1
Showln "--"
// The CSV has these fields: ArchiveId,ArchiveDescription,CreationDate,Size,SHA256TreeHash
// Parse the CSV like this...
Get Create (RefClass(cComChilkatCsv)) To hoCsv
If (Not(IsComObjectCreated(hoCsv))) Begin
Send CreateComObject of hoCsv
End
Set ComHasColumnNames Of hoCsv To True
Get ComGetAsString Of hoSbResponseBody To sTemp1
Get ComLoadFromString Of hoCsv sTemp1 To iSuccess
Move 0 To i
Get ComNumRows Of hoCsv To iNumRows
While (i < iNumRows)
Get ComGetCellByName Of hoCsv i "ArchiveId" To sTemp1
Showln "ArchiveId: " sTemp1
Get ComGetCellByName Of hoCsv i "ArchiveDescription" To sTemp1
Showln "Description: " sTemp1
Get ComGetCellByName Of hoCsv i "Size" To sTemp1
Showln "Size: " sTemp1
Showln "-"
Move (i + 1) To i
Loop
End_Procedure