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
(AutoIt) Wasabi File Streaming UploadSee more Wasabi ExamplesDemonstrates how to do a streaming upload from a file to the Wasabi storage service. The AWS authorization presents some difficulties when the REST request body is to be streamed from a file (or from some other source). The issue is that the SHA-256 hash of the file data must be calculated. There are only two possible ways to do this: (1) stream the file into memory in its entirety and calculate the SHA-256 hash prior to uploading, or (2) pre-calculate the SHA-256 in a streaming fashion, and then provide it to the AWS authentication object. If the application does NOT pre-compute the SHA-256, then Chilkat (internally) is forced to stream into memory, calculate the SHA-256, and then upload from the in-memory copy of the file.
; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. ; This first part is optional. AWS authentication requires ; the SHA-256 hash of the request body (i.e. the contents of the file ; to be uploaded). We can choose to pre-calculate the SHA-256 in a streaming fashion ; and then provide it to the authenticator object. This way, if the file is ; extremely large, it never needs to completely reside in memory. $oCrypt = ObjCreate("Chilkat.Crypt2") ; ---------------------------------------------------- ; Important: Wasabi requires a lowercase hex format. ; ---------------------------------------------------- $oCrypt.EncodingMode = "hex-lower" $oCrypt.HashAlgorithm = "sha-256" Local $sFileToUploadPath = "qa_data/xml/hamlet.xml" Local $sHashStr = $oCrypt.HashFileENC($sFileToUploadPath) $oRest = ObjCreate("Chilkat.Rest") ; Connect to the Amazon AWS REST server. Local $bTls = True Local $iPort = 443 Local $bAutoReconnect = True ; This example will demonstrate uploading to a bucket in the eu-west-2 region Local $bSuccess = $oRest.Connect("s3.eu-west-2.wasabisys.com",$iPort,$bTls,$bAutoReconnect) ; Provide AWS credentials for the REST call. $oAuthAws = ObjCreate("Chilkat.AuthAws") $oAuthAws.AccessKey = "access-key" $oAuthAws.SecretKey = "secret-key" $oAuthAws.ServiceName = "s3" ; Provide the pre-computed SHA-256 here: $oAuthAws.PrecomputedSha256 = $sHashStr $bSuccess = $oRest.SetAuthAws($oAuthAws) $oRest.AddHeader("Expect","100-continue") $oRest.AddHeader("Content-Type","application/xml") ; Set the bucket name via the HOST header. ; In this case, the bucket name is "chilkat100". $oRest.Host = "chilkat100.s3.eu-west-2.wasabisys.com" $oFileStream = ObjCreate("Chilkat.Stream") $oFileStream.SourceFile = $sFileToUploadPath ; Upload to the Wasabi Storage service. ; If the application provided the SHA-256 hash of the file contents (as shown above) ; then file is streamed and never has to completely reside in memory. ; If the application did NOT provide the SHA-256, then Chilkat will (internally) ; load the entire file into memory, calculate the SHA-256, and then upload. Local $sResponseStr = $oRest.FullRequestStream("PUT","/hamlet.xml",$oFileStream) If ($oRest.LastMethodSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; When successful, the Wasabi Storage service will respond with a 200 response code, ; with an XML body. If ($oRest.ResponseStatusCode = 200) Then ConsoleWrite($sResponseStr & @CRLF) ConsoleWrite("File uploaded." & @CRLF) Else ; Examine the request/response to see what happened. ConsoleWrite("response status code = " & $oRest.ResponseStatusCode & @CRLF) ConsoleWrite("response status text = " & $oRest.ResponseStatusText & @CRLF) ConsoleWrite("response header: " & $oRest.ResponseHeader & @CRLF) ConsoleWrite("response body: " & $sResponseStr & @CRLF) ConsoleWrite("---" & @CRLF) ConsoleWrite("LastRequestStartLine: " & $oRest.LastRequestStartLine & @CRLF) ConsoleWrite("LastRequestHeader: " & $oRest.LastRequestHeader & @CRLF) EndIf |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.