Skip to content

Latest commit

 

History

History
77 lines (51 loc) · 8.96 KB

File metadata and controls

77 lines (51 loc) · 8.96 KB

Serverless Request Bin with Azure Durable Functions

Quick Deploy to Azure

Deploy to Azure

Context

If you have developed or consumed HTTP APIs or webhooks, chances are that you have had the need of troubleshooting and inspecting HTTP requests. In the past, there was a very popular and handy free site called Request Bin (requestb.in) that allowed you to capture your HTTP requests and inspect their content, including the body, headers, query params, etc. Unfortunately, due to ongoing abuse, the publicly hosted version of Request Bin was discontinued.

This application allows you to Deploy your own Serverless Request Bin to inspect HTTP Requests in a secure and cost-effective manner.

Consider this a sample solution for personal use. When I was building it, I wanted to test the new capabilities of Durable Entities in the Azure Durable Functions extension. I also used a DotLiquid template to transform objects to HTML.

The Function App is composed of four functions. Functions are just wrappers that call services. The functions are described as follows:

  • PersistIntoBin. Persists HTTP requests into a particular bin specified as a path parameter.
  • GetBin. Gets the HTTP request history for a particular bin specified as a path parameter.
  • EmptyBin. Deletes the HTTP request history for a particular bin.
  • RequestBin. Which represents the Durable Entity function.

Benefits of the Serverless Request Bin

If you deploy your own instance of the Stateful Serverless Request Bin, you would get some benefits, including:

  • Owning the Request Bin, thus having no risk of someone else capturing your sensitive HTTP Requests.
  • Having a very **cost-effective **solution, considering the free executions you get and the low cost associated with the corresponding storage.
  • No need of creating a Bin in advance, the platform will create one if the Bin identifier is not currently in used.
  • Flexible bin identifiers. You can assign any value you like to the bin identifier, as long as it is not longer than 36 characters, and has no special characters other than hyphen, underscore or dot.
  • Dark Mode ;)
  • Full control over the bin lifecycle. Now, with Durable Entities we have full control over the lifecycle of your request bins.

How to Deploy your own

To deploy the Serverless Request Bin you need

  • Access to an Azure Subscription
  • Contributor access to a Resource Group or the Azure Subscription

Deploying your own instance is very easy. You just need to click on the button at the top, and this will take you to the deployment page. If you are planning to deploy the Serverless Request Bin in a new resource group, it is highly recommended to create the resource group in advance, so you can choose the region for the resource group. New resources will be deployed in the same region as the resource group that you have created, with the exception of Application Insights, which is not available in all regions. At the time of writing, the deploy.azure.com service used here does not allow you to choose the region for a new resource group. Please read the following section to understand the purpose of each of the settings.

Configuration Options

The configuration options and settings of the Serverless Request Bin are described in the table below. Some of these options are available only at deployment time, while others are also available after deployment as Application Settings of the Function App created.

Setting Description Can be updated after deployment?
Directory Azure Active Directory Tenant that you want to use to deploy the solution No
Subscription Azure subscription in which you want to deploy the solution No
App Name Used to name the different components of the Serverless Request Bin. including the Function App, the consumption plan, Application Insights, and the Azure Storage account. No
App Insights Region Given that Application Insights is not available in all regions, choose the closest region to the resource group. No
Request Bin Renderer App Setting to configure the Request Bin Renderer to return the Request Bin history to the user. Currently, only “Liquid” is supported. The “Liquid” renderer allows you to convert the Request Bin history object to HTML. Yes
Request Bin Renderer Template File name of the Liquid template to use while rendering the request bin history. Currently, only the “DarkHtmlRender.liquid “ template is provided. You can add your own liquid templates as well. Yes
Request Bin Max Size Maximum number of request to store in the Request Bin. Yes
Request Body Max Length Maximum number of characters to read and store of a request body. If a request body is larger than this limit, the body would be truncated. Yes
Headers to Ignore Azure Functions add some headers to HTTP requests. If you prefer a cleaner request bin, you can ignore the specified HTTP headers. Specify the headers to ignore as a pipe-delimited list. Yes

How to use it

Using the Serverless Request Bin is very easy. Once you have successfully deployed the Serverless Request Bin, you can use it as follows:

  1. Creating a new Request Bin. Request Bins are created on the fly when the first request to the Request Bin identifier is received. Bin identifiers can be up to 36 characters long and only support digits, letters and the hyphen, underscore and dot symbols.
  2. Sending HTTP Requests for inspection. Send a HTTP request using any of the methods to https://<yourfunctionappname>.azurewebsites.net/<binId> e.g. POST https://<yourfunctionappname>.azurewebsites.net/1234567890?a=1&b=2
  3. Inspecting the Request Bin history. GET https://<yourfunctionappname>.azurewebsites.net/history/<binId> e.g. GET https://<yourfunctionappname>.azurewebsites.net/history/1234567890
  4. Deleting the Request Bin history. DELETE https://<yourfunctionappname>.azurewebsites.net/history/<binId> e.g. DELETE https://<yourfunctionappname>.azurewebsites.net/history/1234567890

What you can learn from this solution

You can just use the solution and hopefully, it provides the value you want from it. However, you can also learn some things from the source code, including:

  • Durable Entities in the Azure Durable Functions extension:
  • Options Pattern in Azure Functions. The options pattern is described in detail here and can be used in Azure Functions injecting configuration settings using the IOptions<T> interface via Dependency Injection.
  • Returning HTML content from an HTTP triggered Azure Function. Most of the HTTP triggered Azure Functions samples we can find on the web return an ObjectResult. However, you can also return a ContentResult, in this case, we are returning content of type text/html.
  • Rendering an object into HTML using DotLiquid. You can see how you can transform an object into HTML using Liquid Templates and DotLiquid.

This solution should be considered a sample application and only targeted to personal use.