This post shows how to consume Azure service bus topic subscriptions in an Azure function.
Code: https://github.com/damienbod/AspNetCoreServiceBus
Posts in this series:
- Using Azure Service Bus Queues with ASP.NET Core Services
- Using Azure Service Bus Topics in ASP.NET Core
- Using Azure Service Bus Topics Subscription Filters in ASP.NET Core
- Using Entity Framework Core to process Azure Service Messages in ASP.NET Core
- Using an Azure Service Bus Topic Subscription in an Azure Function
Processing the Azure Service Bus Messages in an Azure Function
Setting this up could not be easier. In Visual Studio, create a new Azure function project, and then create a new Azure function using the Visual Studio helpers.
Select a Service Bus Topic trigger and add the definitions as required. These can be changed later, if you don’t know the required values.
The new Azure function has an attribute which is used to defined the client for the topic subscription. The service bus connection string is defined as ServiceBusConnectionString. This will be specified later. The message is then deserialized to an object. Now you can handle the payload as required.
using Microsoft.Azure.WebJobs; using Microsoft.Extensions.Logging; using Newtonsoft.Json; namespace FunctionService3 { public static class SubscriptionClientFunction { [FunctionName("SubscriptionClientFunction")] public static void Run([ServiceBusTrigger( "mytopic", "functionsubscription", Connection = "ServiceBusConnectionString")]string message, ILogger log) { log.LogInformation($"C# ServiceBus topic trigger function processed message: {message}"); var payload = JsonConvert.DeserializeObject<MyPayload>(message); } } }
The connection for the Azure service bus is defined in the local.settings.json file. This is a bit of a problem because we should not be committing this secret value to our source code repository. We could use a dev service bus here, and commit this then. The test and production service bus connection strings could then be set as part of the build.
Azure Key Vault could also be used to get the service bus connection string. This is only a little bit better as the key vault secret would be pushed to the server, so we still have a secret in our code.
It would be nice if we could use something like the Microsoft extensions key vault configuration where no secret is required to use the key vault.
{ "IsEncrypted": false, "Values": { "AzureWebJobsStorage": "UseDevelopmentStorage=true", "FUNCTIONS_WORKER_RUNTIME": "dotnet", "ServiceBusConnectionString": "Not possible to read from a secret src without a another" }, "Host": { "LocalHttpPort": "7071", "CORS": "*" } }
The Azure service bus subscription needs to be configured in Azure:
It is really easy to use Azure service bus with Azure functions. The handling of secrets could be improved. There are some open source projects which help solve this problem.
Links:
https://docs.microsoft.com/en-us/azure/service-bus-messaging/
https://www.nuget.org/packages/Microsoft.Azure.ServiceBus
Always subscribe to Dead-lettered messages when using an Azure Service Bus
https://ml-software.ch/posts/stripe-api-with-asp-net-core-part-3