Sample code for 30+ languages & platforms
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

AutoIt
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)