Unicode C++
Unicode C++
How to Generate an Azure Service Bus Shared Access Signature (SAS)
See more Azure Service Bus Examples
Demonstrates generating and using an Azure Service Bus Shared Access Signature (SAS).Note: This example requires Chilkat v9.5.0.65 or greater.
Chilkat Unicode C++ Downloads
#include <CkAuthAzureSASW.h>
#include <CkDateTimeW.h>
#include <CkStringBuilderW.h>
#include <CkFileAccessW.h>
void ChilkatSample(void)
{
// Note: Requires Chilkat v9.5.0.65 or greater.
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// -------------------------------------------------------------------
// Create a Shared Access Signature (SAS) token for Azure Service Bus.
// -------------------------------------------------------------------
CkAuthAzureSASW authSas;
authSas.put_AccessKey(L"AzureServiceBus_PrimaryKey");
// The SAS token for Service Bus will look like this:
// (The order of params will be different. The order does not matter.)
// sig=<signature-string>&se=<expiry>&skn=<keyName>&sr=<URL-encoded-resourceURI>
// Specify the format of the string to sign.
authSas.put_StringToSign(L"resourceURI,expiry");
// Create an expiry to 30 days in the future.
CkDateTimeW dtExpiry;
dtExpiry.SetFromCurrentSystemTime();
dtExpiry.AddDays(30);
authSas.SetTokenParam(L"expiry",L"se",dtExpiry.getAsUnixTimeStr(true));
// Set the skn (keyname)
// This example uses the key "RootManageSharedAccessKey". This give full access.
// In a typical scenario, you would create a new Azure key (for the service bus)
// in the Azure portal, such that the key has limited permissions. This would
// allow you to give the SAS token to others for specific access for some period of time.
authSas.SetTokenParam(L"keyName",L"skn",L"RootManageSharedAccessKey");
// Set the URL-encoded-resourceURI
CkStringBuilderW sbResourceUri;
sbResourceUri.Append(L"https://<yournamespace>.servicebus.windows.net/");
sbResourceUri.Encode(L"url",L"utf-8");
authSas.SetTokenParam(L"resourceURI",L"sr",sbResourceUri.getAsString());
// Generate the SAS token.
const wchar_t *sasToken = authSas.generateToken();
if (authSas.get_LastMethodSuccess() != true) {
wprintf(L"%s\n",authSas.lastErrorText());
return;
}
wprintf(L"SAS token: %s\n",sasToken);
// Save the SAS token to a file.
// We can then use this pre-generated token for future Service Bus operations.
CkFileAccessW fac;
fac.WriteEntireTextFile(L"qa_data/tokens/serviceBusSas.txt",sasToken,L"utf-8",false);
}