AutoIt
AutoIt
Azure File Service: List Shares
See more Azure Cloud Storage Examples
Sample code to list the file shares in an Azure storage account.Chilkat AutoIt Downloads
Local $bSuccess = False
; Azure File Service Example: List all the file shares in a storage account.
; See also: https://docs.microsoft.com/en-us/rest/api/storageservices/list-shares
; 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".
$bSuccess = $oRest.Connect("chilkat.file.core.windows.net",$iPort,$bTls,$bAutoReconnect)
If ($bSuccess = False) 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 = "File"
; 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.
; Send the GET request to list the shares.
Local $sResponseStr = $oRest.FullRequestNoBody("GET","/?comp=list")
If ($oRest.LastMethodSuccess = False) Then
ConsoleWrite($oRest.LastErrorText & @CRLF)
Exit
EndIf
; When successful, the Azure Storage service will respond with a 200 response status code,
; with an XML 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
; Load the XML response for parsing.
; An example of the response XML is shown below.
$oXml = ObjCreate("Chilkat.Xml")
$bSuccess = $oXml.LoadXml($sResponseStr)
ConsoleWrite($oXml.GetXml() & @CRLF)
; Here's a sample response:
; <?xml version="1.0" encoding="utf-8" ?>
; <EnumerationResults ServiceEndpoint="https://chilkat.file.core.windows.net/">
; <Shares>
; <Share>
; <Name>beardie</Name>
; <Properties>
; <Last-Modified>Mon, 26 Jun 2017 21:24:57 GMT</Last-Modified>
; <Etag>"0x8D4BCD9CBD872E5"</Etag>
; <Quota>5120</Quota>
; </Properties>
; </Share>
; <Share>
; <Name>pip</Name>
; <Properties>
; <Last-Modified>Mon, 26 Jun 2017 21:24:44 GMT</Last-Modified>
; <Etag>"0x8D4BCD9C3D823D1"</Etag>
; <Quota>5120</Quota>
; </Properties>
; </Share>
; </Shares>
; <NextMarker />
; </EnumerationResults>
; Let's iterate over the file shares
$oLastMod = ObjCreate("Chilkat.CkDateTime")
Local $iNumShares = $oXml.NumChildrenAt("Shares")
Local $i = 0
$oDt = ObjCreate("Chilkat.DtObj")
While $i < $iNumShares
ConsoleWrite("---- Share " & $i & " ----" & @CRLF)
$oXml.I = $i
ConsoleWrite("Name: " & $oXml.GetChildContent("Shares|Share[i]|Name") & @CRLF)
$oLastMod.SetFromRfc822($oXml.GetChildContent("Shares|Share[i]|Properties|Last-Modified"))
$oLastMod.ToDtObj True,$oDt
ConsoleWrite("Last-Modified YMD: " & $oDt.Year & "," & $oDt.Month & "," & $oDt.Day & @CRLF)
$i = $i + 1
Wend
; Output for the above loop:
; ---- Share 0 ----
; Name: beardie
; Last-Modified YMD: 2017,6,26
; ---- Share 1 ----
; Name: pip
; Last-Modified YMD: 2017,6,26
;
ConsoleWrite("Success." & @CRLF)