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
(Unicode C++) Azure Storage: Get Blob Service StatsAzure Storage Blob Service REST API: Sample code to get Blob Service Stats
#include <CkRestW.h> #include <CkAuthAzureStorageW.h> #include <CkXmlW.h> #include <CkDateTimeW.h> #include <CkDtObjW.h> void ChilkatSample(void) { // 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. CkRestW rest; // Connect to the Azure Storage Blob Service bool bTls = true; int port = 443; bool 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 ---- bool success = rest.Connect(L"chilkat-secondary.blob.core.windows.net",port,bTls,bAutoReconnect); if (success != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } // Provide Azure Cloud credentials for the REST call. CkAuthAzureStorageW azAuth; azAuth.put_AccessKey(L"AZURE_ACCESS_KEY"); // The account name used here should match the 1st part of the domain passed in the call to Connect (above). azAuth.put_Account(L"chilkat"); azAuth.put_Scheme(L"SharedKey"); azAuth.put_Service(L"Blob"); // This causes the "x-ms-version: 2020-08-04" header to be automatically added. azAuth.put_XMsVersion(L"2020-08-04"); 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. const wchar_t *responseStr = rest.fullRequestNoBody(L"GET",L"/?restype=service&comp=stats"); if (rest.get_LastMethodSuccess() != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } // When successful, the Azure Storage service will respond with a 200 response code, // with an XML body. if (rest.get_ResponseStatusCode() != 200) { // Examine the request/response to see what happened. wprintf(L"response status code = %d\n",rest.get_ResponseStatusCode()); wprintf(L"response status text = %s\n",rest.responseStatusText()); wprintf(L"response header: %s\n",rest.responseHeader()); wprintf(L"response body (if any): %s\n",responseStr); wprintf(L"---\n"); wprintf(L"LastRequestStartLine: %s\n",rest.lastRequestStartLine()); wprintf(L"LastRequestHeader: %s\n",rest.lastRequestHeader()); return; } // Load the XML response for parsing. // An example of the response XML is shown below. CkXmlW xml; success = xml.LoadXml(responseStr); wprintf(L"%s\n",xml.getXml()); // Use the ChilkatPath method to get various pieces of information out // of the XML. For example: wprintf(L"Status = %s\n",xml.chilkatPath(L"GeoReplication|Status|*")); const wchar_t *lastSyncTimeStr = xml.chilkatPath(L"GeoReplication|LastSyncTime|*"); wprintf(L"LastSyncTime = %s\n",lastSyncTimeStr); // The date/time string can be loaded into a CkDateTime object for // access to individual parts, or conversion to other formats. CkDateTimeW dateTime; success = dateTime.SetFromRfc822(lastSyncTimeStr); // For example: bool bLocalTime = true; CkDtObjW *dt = dateTime.GetDtObj(bLocalTime); wprintf(L"%d/%d/%d\n",dt->get_Year(),dt->get_Month(),dt->get_Day()); delete dt; // <StorageServiceStats> // <GeoReplication> // <Status>live</Status> // <LastSyncTime>Tue, 03 May 2016 23:57:54 GMT</LastSyncTime> // </GeoReplication> // </StorageServiceStats> } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.