In a previous article we got an introduction to Azure Event Grid, if you’re new to Event Grid you should check it out first to familiarise yourself with some basic concepts.
In this article we’ll create an Azure Event Grid topic and subscription and see it in action.
First off, if you want to create a free Azure Account you can do so, then log into the Azure portal.
Next go and create a new resource group, Azure Event Grid is currently in preview and only available in selected locations such as West US 2.
data:image/s3,"s3://crabby-images/b2542/b25422d647e3c77ea15462a236f3e83a9e8cfd88" alt="Creating a new resource group Creating a new resource group"
Once the resource group is created, head down to the More services option and search for Event Grid.
data:image/s3,"s3://crabby-images/59db6/59db68ef6faecef800ee055e1e191b91bb4d1892" alt="Navigating to Event Grid Topics Navigating to Event Grid Topics"
There are topics provided by Azure services (such as blob storage ) and there is also the ability to create your own custom topics for custom applications/third parties/etc.
Click Event Grid Topics and this will take you to a list of all your topics. Click the +Add button to begin creation of a custom topic. Give the topic a name sales-leads and choose the resource group created earlier, once again choose West US 2.
data:image/s3,"s3://crabby-images/9bc2e/9bc2e27b495e88b75dd824a995e9611aecbab879" alt="Creating a new Azure Event Grid Topic Creating a new Azure Event Grid Topic"
Click create, wait for the deployment to complete and hit refresh in the topics list to see your new topic:
data:image/s3,"s3://crabby-images/d35f5/d35f50c12602a571eaa610455ef97dbd7d651e75" alt="Azure Event Grid topic added Azure Event Grid topic added"
Click on the newly added sales-leads topic, notice the overview showing publish metrics:
data:image/s3,"s3://crabby-images/15453/1545305040aceb48ff50861c58022da215dd1840" alt="Event Grid Topic details Event Grid Topic details"
At the top right hover over the Topic Endpoint and click the button to copy this to the clipboard (we’ll use this later):
data:image/s3,"s3://crabby-images/7fded/7fdedca5d73d0681c3347b800796e7e90a4e797e" alt="Getting Event Grid Topic endpoint Getting Event Grid Topic endpoint"
In this example the copied endpoint is: https://sales-leads.westus2-1.eventgrid.azure.net/api/events
We’ll also need an access key to be able to HTTP POST to this custom topic later, to do this click the Access keys option and copy Key 1 for later use:
data:image/s3,"s3://crabby-images/072b7/072b78aaadaffe6ca663d0fa21f5e0eae6baaae1" alt="Getting access key for Azure Event Grid topic Getting access key for Azure Event Grid topic"
Click back on Overview and click the +Event Subscription button:
data:image/s3,"s3://crabby-images/f8d01/f8d01861fb770136e14e57f601b6f6be3a21af29" alt="Creating a new Azure Event Grid Subscription Creating a new Azure Event Grid Subscription"
In this example we’ll create a subscription that will call an external (to Azure) service that will mail a conference brochure to all new sales leads. In this example we are simulating a temporary extension to the sales system for a limited period during the run-up to a sales conference. This is one use case for Azure Event Grid that allows extension of a core system without needing to modify it (assuming that events are being emitted).
To simulate this external service we’ll use RequestBin which you can learn more about in this article. Once you’ve created your request bin, take a note of the Bin URL.
data:image/s3,"s3://crabby-images/1fccd/1fccdf0174e3a57c07b3715c6e927f336339366e" alt="Creating a RequestBin URL Creating a RequestBin URL"
Fill out the new event subscription details:
- Name: send-upcoming-conference-brochure
- Subscribe to all event types: Untick
- Event Types: new-sales-lead-created
- Subscriber endpoint: https://requestb.in/1bbopge1 (this is the RequestBin URL created above)
data:image/s3,"s3://crabby-images/bf296/bf2967637aa6a083996e0d15a7bcccb9fec30093" alt="Event subscription details Event subscription details"
Click Create.
To recap, there is now a custom topic called sales-leads that we can publish events to at its URL: https://sales-leads.westus2-1.eventgrid.azure.net/api/events. There is also an event subscription set up for this topic but that is limited to only those events published of type new-sales-lead-created. This event subscription uses the Azure Event Grid WebHooks event handler to HTTP push events to the RequestBin URL.
To see this in action, open Postman and select POST and paste the topic URL (https://sales-leads.westus2-1.eventgrid.azure.net/api/events). Add a header called aeg-sas-key and paste in the key that was copied earlier:
data:image/s3,"s3://crabby-images/7f634/7f63482e679558d595ebeffd0b66e4bec3e0794c" alt="Basic Postman setup Basic Postman setup"
The final thing to do is define the event data that we want to publish:
[
{
"id": "42",
"eventType": "new-sales-lead-created",
"subject": "myapp/sales/leads",
"eventTime": "2017-12-07T01:01:36+00:00",
"data":{
"firstName": "Jason",
"postalAddress": "xyz"
}
}
]
data:image/s3,"s3://crabby-images/311c7/311c7811d26feaa8059d96915bf2c20ba36272f9" alt="Event JSON data Event JSON data"
And then click Send in Postman. You should get a 200 OK response.
Heading back to the RequestBin window and refreshing the page shows the subscription working and the event being pushed to RequestBin:
data:image/s3,"s3://crabby-images/16e90/16e90c17629cac128b4768e25f519efcb0fb66df" alt="RequestBin receiving Azure Event Grid event RequestBin receiving Azure Event Grid event"
Because the event subscription is filtered on an event type of new-sales-lead-created, if we send a different event type from Postman (e.g.: "eventType": "new-sales-lead-rejected",), the subscription won’t activate nor push the event to RequestBin.
If you want to fill in the gaps in your C# knowledge be sure to check out my C# Tips and Traps training course from Pluralsight – get started with a free trial.
data:image/s3,"s3://crabby-images/a8ef8/a8ef8e379fb21ab5a80fb4d497f745024389342a" alt=""
data:image/s3,"s3://crabby-images/9ae5c/9ae5c168b63ac7a2087017154ac4b713eaffabdd" alt=""
SHARE: