Sample code for 30+ languages & platforms
Visual FoxPro

Get Container Metadata

See more Azure Cloud Storage Examples

Azure Storage Blob Service REST API: Sample code to get the user-defined metadata of a container.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loRest
LOCAL lnBTls
LOCAL lnPort
LOCAL lnBAutoReconnect
LOCAL loAzAuth
LOCAL lcResponseStr

lnSuccess = 0

* Azure Blob Service Example: Get Container User-Defined Metadata
* See also: https://msdn.microsoft.com/en-us/library/azure/ee691976.aspx

* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loRest = CreateObject('Chilkat.Rest')

* Connect to the Azure Storage Blob Service
lnBTls = 1
lnPort = 443
lnBAutoReconnect = 1
* In this example, the storage account name is "chilkat".
lnSuccess = loRest.Connect("chilkat.blob.core.windows.net",lnPort,lnBTls,lnBAutoReconnect)
IF (lnSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    CANCEL
ENDIF

* Provide Azure Cloud credentials for the REST call.
loAzAuth = CreateObject('Chilkat.AuthAzureStorage')
loAzAuth.AccessKey = "AZURE_ACCESS_KEY"
* The account name used here should match the 1st part of the domain passed in the call to Connect (above).
loAzAuth.Account = "chilkat"
loAzAuth.Scheme = "SharedKey"
loAzAuth.Service = "Blob"
* This causes the "x-ms-version: 2021-08-06" header to be automatically added.
loAzAuth.XMsVersion = "2021-08-06"
lnSuccess = loRest.SetAuthAzureStorage(loAzAuth)

* Note: The application does not need to explicitly set the following
* headers: x-ms-date, Authorization.  These headers
* are automatically set by Chilkat.

* The expected success response is a 200 response status code with no response body.
* In this example, we are getting the metadata of the container named "mycontainer".
lcResponseStr = loRest.FullRequestNoBody("GET","/mycontainer?restype=container&comp=metadata")
IF (loRest.LastMethodSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    RELEASE loAzAuth
    CANCEL
ENDIF

* When successful, the Azure Storage service will respond with a 200 response status code,
* with no response body.

IF (loRest.ResponseStatusCode <> 200) THEN
    * Examine the request/response to see what happened.
    ? "response status code = " + STR(loRest.ResponseStatusCode)
    ? "response status text = " + loRest.ResponseStatusText
    ? "response header: " + loRest.ResponseHeader
    ? "response body (if any): " + lcResponseStr
    ? "---"
    ? "LastRequestStartLine: " + loRest.LastRequestStartLine
    ? "LastRequestHeader: " + loRest.LastRequestHeader
    RELEASE loRest
    RELEASE loAzAuth
    CANCEL
ENDIF

* The user-defined metadata is located in the response header.
* The full response header can be obtained like this:
? "response header: " + loRest.ResponseHeader
? "--"

* Metadata headers begin with "x-ms-meta-"
* Individual response header fields can be retrieved like this:
? "x-ms-meta-Category: " + loRest.ResponseHdrByName("x-ms-meta-Category")
? "x-ms-meta-Resolution: " + loRest.ResponseHdrByName("x-ms-meta-Resolution")

? "Success."

RELEASE loRest
RELEASE loAzAuth