Go
Go
Azure Storage: Get Blob Service Stats
See more Azure Cloud Storage Examples
Azure Storage Blob Service REST API: Sample code to get Blob Service StatsChilkat Go Downloads
success := false
// Azure Blob Service Example: Get Blob Service Stats
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
rest := chilkat.NewRest()
// Connect to the Azure Storage Blob Service
bTls := true
port := 443
bAutoReconnect := true
// In this example, the storage account name is "chilkat".
// ---- IMPORTANT ----
// The "-secondary" suffix is required.
// This requires an Azure storage account with replication set to "Read-access geo-redundant storage (RA-GRS)"
// If you made the change just prior to testing this example, you'll need to give it time for the
// DNS to become available..
// ---- IMPORTANT ----
success = rest.Connect("chilkat-secondary.blob.core.windows.net",port,bTls,bAutoReconnect)
if success == false {
fmt.Println(rest.LastErrorText())
rest.DisposeRest()
return
}
// Provide Azure Cloud credentials for the REST call.
azAuth := chilkat.NewAuthAzureStorage()
azAuth.SetAccessKey("AZURE_ACCESS_KEY")
// The account name used here should match the 1st part of the domain passed in the call to Connect (above).
azAuth.SetAccount("chilkat")
azAuth.SetScheme("SharedKey")
azAuth.SetService("Blob")
// This causes the "x-ms-version: 2021-08-06" header to be automatically added.
azAuth.SetXMsVersion("2021-08-06")
success = rest.SetAuthAzureStorage(azAuth)
// Note: The application does not need to explicitly set the following
// headers: x-ms-date, Authorization. These headers
// are automatically set by Chilkat.
responseStr := rest.FullRequestNoBody("GET","/?restype=service&comp=stats")
if rest.LastMethodSuccess() == false {
fmt.Println(rest.LastErrorText())
rest.DisposeRest()
azAuth.DisposeAuthAzureStorage()
return
}
// When successful, the Azure Storage service will respond with a 200 response code,
// with an XML body.
if rest.ResponseStatusCode() != 200 {
// Examine the request/response to see what happened.
fmt.Println("response status code = ", rest.ResponseStatusCode())
fmt.Println("response status text = ", rest.ResponseStatusText())
fmt.Println("response header: ", rest.ResponseHeader())
fmt.Println("response body (if any): ", *responseStr)
fmt.Println("---")
fmt.Println("LastRequestStartLine: ", rest.LastRequestStartLine())
fmt.Println("LastRequestHeader: ", rest.LastRequestHeader())
rest.DisposeRest()
azAuth.DisposeAuthAzureStorage()
return
}
// Load the XML response for parsing.
// An example of the response XML is shown below.
xml := chilkat.NewXml()
success = xml.LoadXml(*responseStr)
fmt.Println(*xml.GetXml())
// Use the ChilkatPath method to get various pieces of information out
// of the XML. For example:
fmt.Println("Status = ", *xml.ChilkatPath("GeoReplication|Status|*"))
lastSyncTimeStr := xml.ChilkatPath("GeoReplication|LastSyncTime|*")
fmt.Println("LastSyncTime = ", *lastSyncTimeStr)
// The date/time string can be loaded into a CkDateTime object for
// access to individual parts, or conversion to other formats.
dateTime := chilkat.NewCkDateTime()
success = dateTime.SetFromRfc822(*lastSyncTimeStr)
// For example:
bLocalTime := true
dt := chilkat.NewDtObj()
dateTime.ToDtObj(bLocalTime,dt)
fmt.Println(dt.Year(), "/", dt.Month(), "/", dt.Day())
// <StorageServiceStats>
// <GeoReplication>
// <Status>live</Status>
// <LastSyncTime>Tue, 03 May 2016 23:57:54 GMT</LastSyncTime>
// </GeoReplication>
// </StorageServiceStats>
rest.DisposeRest()
azAuth.DisposeAuthAzureStorage()
xml.DisposeXml()
dateTime.DisposeCkDateTime()
dt.DisposeDtObj()