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
(Objective-C) Glacier Upload ArchiveDemonstrates how to add an archive to a vault. For a successful upload, your data is durably persisted. In response, Amazon S3 Glacier (Glacier) returns the archive ID in the x-amz-archive-id header of the response. You should save the archive ID returned so that you can access the archive later. Note: This example requires Chilkat v9.5.0.78 or greater.
#import <CkoRest.h> #import <CkoAuthAws.h> #import <NSString.h> #import <CkoCrypt2.h> #import <CkoStream.h> // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoRest *rest = [[CkoRest alloc] init]; // Connect to the Amazon AWS REST server in the desired region. BOOL bTls = YES; int port = 443; BOOL bAutoReconnect = YES; BOOL success = [rest Connect: @"glacier.us-west-2.amazonaws.com" port: [NSNumber numberWithInt: port] tls: bTls autoReconnect: bAutoReconnect]; // Provide AWS credentials. CkoAuthAws *authAws = [[CkoAuthAws alloc] init]; 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 Upload Archive Reference Documentation // [rest AddHeader: @"x-amz-glacier-version" value: @"2012-06-01"]; // We'll need to pre-compute the SHA256 tree hash and the SHA256 linear hash. // The hashes are added in the following request headers: // x-amz-sha256-tree-hash: SHA256 tree hash // x-amz-content-sha256: SHA256 linear hash // The file we'll be uploading NSString *filePath = @"qa_data/zips/somethingBig.zip"; CkoCrypt2 *crypt = [[CkoCrypt2 alloc] init]; crypt.HashAlgorithm = @"sha256-tree-hash"; crypt.EncodingMode = @"hexlower"; NSString *treeHashHex = [crypt HashFileENC: filePath]; [rest AddHeader: @"x-amz-sha256-tree-hash" value: treeHashHex]; crypt.HashAlgorithm = @"sha256"; NSString *linearHashHex = [crypt HashFileENC: filePath]; authAws.PrecomputedSha256 = linearHashHex; // We can optionally add a description // In this case, we'll set the description equal to the local filepath of the file we're uploading. [rest AddHeader: @"x-amz-archive-description" value: filePath]; // Upload the file to the vault named "chilkat" CkoStream *fileStream = [[CkoStream alloc] init]; fileStream.SourceFile = filePath; // May need to increase the timeout if this is a really large file.. rest.IdleTimeoutMs = [NSNumber numberWithInt:120000]; // Add an Expect: 100-continue request header [rest AddHeader: @"Expect" value: @"100-continue"]; NSString *responseStr = [rest FullRequestStream: @"POST" uriPath: @"/AWS_ACCOUNT_ID/vaults/chilkat/archives" stream: fileStream]; if (rest.LastMethodSuccess != YES) { NSLog(@"%@",rest.LastErrorText); return; } int respStatusCode = [rest.ResponseStatusCode intValue]; if (respStatusCode >= 400) { NSLog(@"%@%d",@"Response Status Code = ",respStatusCode); NSLog(@"%@",@"Response Header:"); NSLog(@"%@",rest.ResponseHeader); NSLog(@"%@",@"Response Body:"); NSLog(@"%@",responseStr); return; } // Success is indicated by a 201 response status with an empty response body. NSLog(@"%@%d",@"response status code = ",respStatusCode); // If successful, the response header looks like this. // The Location and x-amz-archive-id are two items of information we may wish to save.. // HTTP/1.1 201 Created // x-amzn-RequestId: AAABZpJrTyioDC_HsOmHae8EZp_uBSJr6cnGOLKp_XJCl-Q // Date: Wed, 10 Feb 2017 12:00:00 GMT // x-amz-sha256-tree-hash: beb0fe31a1c7ca8c6c04d574ea906e3f97b31fdca7571defb5b44dca89b5af60 // Location: /111122223333/vaults/examplevault/archives/NkbByEejwEggmBz2fTH ... GlqrEXAMPLEArchiveId // x-amz-archive-id: NkbByEejwEggmBz2fTHgJrg0XBoDfjP4q6iu87-TjhqG6eGoOY9Z8i1_AUyUsu ... BfGlqrEXAMPLEArchiveId // NSString *archiveId = [rest ResponseHdrByName: @"x-amz-archive-id"]; NSLog(@"%@%@",@"x-amz-archive-id = ",archiveId); NSString *location = [rest ResponseHdrByName: @"Location"]; NSLog(@"%@%@",@"Location = ",location); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.