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) Set Container ACLAzure Storage Blob Service REST API: Sample code to set the permissions of a container.
; Azure Blob Service Example: Set Container ACL ; See also: https://msdn.microsoft.com/en-us/library/azure/dd179391.aspx ; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oRest = ObjCreate("Chilkat.Rest") ; Connect to the Azure Storage Blob Service Local $bTls = True Local $iPort = 443 Local $bAutoReconnect = True ; In this example, the storage account name is "chilkat". Local $bSuccess = $oRest.Connect("chilkat.blob.core.windows.net",$iPort,$bTls,$bAutoReconnect) If ($bSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; Provide Azure Cloud credentials for the REST call. $oAzAuth = ObjCreate("Chilkat.AuthAzureStorage") $oAzAuth.AccessKey = "AZURE_ACCESS_KEY" ; The account name used here should match the 1st part of the domain passed in the call to Connect (above). $oAzAuth.Account = "chilkat" $oAzAuth.Scheme = "SharedKey" $oAzAuth.Service = "Blob" ; This causes the "x-ms-version: 2021-08-06" header to be automatically added. $oAzAuth.XMsVersion = "2021-08-06" $bSuccess = $oRest.SetAuthAzureStorage($oAzAuth) ; Note: The application does not need to explicitly set the following ; headers: x-ms-date, Authorization. These headers ; are automatically set by Chilkat. ; The XML body of the request will look like this: ; <?xml version="1.0" encoding="utf-8"?> ; <SignedIdentifiers> ; <SignedIdentifier> ; <Id>unique-character-value-of-up-to-64-chars</Id> ; <AccessPolicy> ; <Start>start-time</Start> ; <Expiry>expiry-time</Expiry> ; <Permission>abbreviated-permission-list</Permission> ; </AccessPolicy> ; </SignedIdentifier> ; </SignedIdentifiers> ; Generate a random 32-character string. $oPrng = ObjCreate("Chilkat.Prng") Local $sRandomId = $oPrng.RandomString(32,True,True,True) ; Get the current system date/time in ISO 8061 format $oDt = ObjCreate("Chilkat.CkDateTime") $oDt.SetFromCurrentSystemTime() Local $bLocal = False ; Get the current date/time in ISO 8061 UTC format. Local $sCurDtStr = $oDt.GetAsTimestamp($bLocal) ; The expire time will be 365 days in the future. $bSuccess = $oDt.AddDays(365) Local $sExpireDtStr = $oDt.GetAsTimestamp($bLocal) ; Build the request: $oXml = ObjCreate("Chilkat.Xml") $oXml.Tag = "SignedIdentifiers" Local $oXSignedId = $oXml.NewChild("SignedIdentifier","") $oXSignedId.NewChild2 "Id",$sRandomId Local $oXAccessPolicy = $oXSignedId.NewChild("AccessPolicy","") $oXAccessPolicy.NewChild2 "Start",$sCurDtStr $oXAccessPolicy.NewChild2 "Expiry",$sExpireDtStr $oXAccessPolicy.NewChild2 "Permission","rwd" ; Show the XML.. ConsoleWrite($oXml.GetXml() & @CRLF) ; The expected response is a 200 response status code with no response body. Local $sResponseStr = $oRest.FullRequestString("PUT","/mycontainer?restype=container&comp=acl",$oXml.GetXml()) If ($oRest.LastMethodSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; When successful, the Azure Storage service will respond with a 200 response status code, ; with no response body. If ($oRest.ResponseStatusCode <> 200) Then ; 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 (if any): " & $sResponseStr & @CRLF) ConsoleWrite("---" & @CRLF) ConsoleWrite("LastRequestStartLine: " & $oRest.LastRequestStartLine & @CRLF) ConsoleWrite("LastRequestHeader: " & $oRest.LastRequestHeader & @CRLF) Exit EndIf ConsoleWrite("Success." & @CRLF) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.