Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(C# UWP/WinRT) Glacier Get Inventory Retrieval Job OutputDemonstrates how to get and parse the inventory retrieval job output.
// This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. Chilkat.Rest rest = new Chilkat.Rest(); // Connect to the Amazon AWS REST server in the desired region. bool bTls = true; int port = 443; bool bAutoReconnect = true; bool success = await rest.ConnectAsync("glacier.us-west-2.amazonaws.com",port,bTls,bAutoReconnect); // Provide AWS credentials. Chilkat.AuthAws authAws = new 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 // rest.AddHeader("x-amz-glacier-version","2012-06-01"); Chilkat.StringBuilder sbResponseBody = new Chilkat.StringBuilder(); success = await rest.FullRequestNoBodySbAsync("GET","/AWS_ACCOUNT_ID/vaults/chilkat/jobs/JOB_ID/output",sbResponseBody); if (success != true) { Debug.WriteLine(rest.LastErrorText); return; } int respStatusCode = rest.ResponseStatusCode; if (respStatusCode >= 400) { Debug.WriteLine("Response Status Code = " + Convert.ToString(respStatusCode)); Debug.WriteLine("Response Header:"); Debug.WriteLine(rest.ResponseHeader); Debug.WriteLine("Response Body:"); Debug.WriteLine(sbResponseBody.GetAsString()); return; } // Success is indicated by a 200 response status. Debug.WriteLine("response status code = " + Convert.ToString(respStatusCode)); // The inventory retrieval job output is in CSV format. Debug.WriteLine("job output:"); Debug.WriteLine(sbResponseBody.GetAsString()); Debug.WriteLine("--"); // The CSV has these fields: ArchiveId,ArchiveDescription,CreationDate,Size,SHA256TreeHash // Parse the CSV like this... Chilkat.Csv csv = new Chilkat.Csv(); csv.HasColumnNames = true; csv.LoadFromString(sbResponseBody.GetAsString()); int i = 0; int numRows = csv.NumRows; while (i < numRows) { Debug.WriteLine("ArchiveId: " + csv.GetCellByName(i,"ArchiveId")); Debug.WriteLine("Description: " + csv.GetCellByName(i,"ArchiveDescription")); Debug.WriteLine("Size: " + csv.GetCellByName(i,"Size")); Debug.WriteLine("-"); i = i + 1; } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.