Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Azure webhook infrastructure for high availability of the webhook functionality that means if Insights is down for sometime, payloads from devops tools should not be missed.

Official Link – portal.azure.com

Tip

Step - by - step guide on how to Install Azure Webhook Infrastructure

Expand
titleStep 1: Azure Storage

...

Image Added
  • Fill the required details in all the given tabs (Basic, Networking…etc.) and click on Review + create.

    1. Basics

      1. Choose Subscription and Resource Group.

      2. Storage account name: insightswebhookstorage.

      3. Account kind: StorageV2

      4. Leave Replication as it is.

      5. Access Tier: Hot

...

Image Added

Image Added

  • After clicking create button, a new page will be opened where you can see your storage account deployment. Deployment will take approx. 1 minutes to complete.

  • After completing deployment, click on Go to Resource button to go inside storage account.

  • Click on containers tab in the overview section or select from left menu.

...

Image Added
  • Create 3 new containers by click on + container button with names:

    1. insightswebhookevents

...

    1. insightsfailedwebhookevents

...

functionapp

...

Click on Change access level button and select Container option and click OK.

...

    1. insightsfunctionapp

Select Public access level as Container for all the containers.

Image Added

Image Added

  • Click on 3 dots given on the right side and then click on Access policy

...

  • to create policy.

...

Image Added

  • Click on + Add Policy button under stored access policy and fill the details to create policy

...

  • as follows:

    • Fill Identifier as Insights(You may change)

    • Select all permissions.

    • Select start time and end time.

    • Click OK button.

    • After clicking OK, Click on Save button to save policy.

    • Repeat

...

    • these steps for all containers.

Image Added
  • Download the zip file from the nexus repository(PlatformInsightsAzureWebhook.zip) to your local system.

  • Follow the steps to upload zip file into the container:

    • Click on functionapp container to go inside container.

    • Click on upload button.

    • Select the zip file from the local system.

    • Select checkbox Overwrite if files already exist.

    • Click on advanced and change the Blob type to Block Blob and Block size to 100 MB.

    • Click on Upload button.

Image Added

Image Added

  • Click on the zip filename and copy the URL from the overview section and paste it in notepad.

Image Added
  • Click on containers from the left menu and copy the names of the two container i.e. insightswebhookevents and failedwebhookevents and paste it on notepad.

  • Go to insightswebhookstorage storage account.

    • Click on Properties under settings in the left menu and copy the value of Primary Blob Service Endpoint and paste it on notepad.

      Image Added

    • Click on Access Keys under settings in the left menu and copy the value of storage account name and Key of Key1 and paste it on notepad.

Image Added
  • Make sure you have 6 values present somewhere as shown in the below image

Image Added
Expand
titleStep 2: Azure Functions
Image Added
  • Fill the required details:

    • Basics

      • Choose Subscription and Resource Group.

      • Function App name: InsightsWebhookHandler

      • Publish: Code

      • Runtime stack: Java

      • Choose Region where your storage account is created.

    • Monitoring

      • Select insightswebhookstorage option in Storage account.

      • Operating System: Windows

      • Choose Plan type as per needs.

    • Monitoring

      • Enable Application Insights: Yes

      • Application Insights: Create New

    • Click on Review+ Create button and then review the filled details and click on create.

    • After clicking create button, a new page will be opened where you can see your function app deployment. Deployment will take approx. 2-3 minutes to complete.

    • After completing deployment, click on Go to Resource button to go inside function app.

    • Please reference to the images given below:

Image AddedImage AddedImage Added

  • Click on configuration under configured features

Image Added
  • Click on + New application setting button

Image Added

  • Fill the name and values and click OK. Repeat this step for all the values of the table given below and click on Save button.

  • Copy the values from the notepad we stored before while setting up azure storage.

Note: Please do not change the Application Setting Name while adding application settings.

Name

Value

1

WEBSITE_RUN_FROM_PACKAGE

<Zip_URL>

2

StorageEndpoint

< Blob Service Endpoint>

3

StorageAccountName

< Storage account name>

4

StorageAccountKey

< Key>

5

WebhookEventContainer

< WebhookEventContainer>

6

FailedEventContainer

< FailedEventContainer>

7

TimerInterval(Every One Hour)

0 0 * * * *

Image AddedImage Added

Expand
titleStep 3: API Management
Image Added

  • Fill the required details and click create button.

Image Added
  • Click on APIs link from left menu.

  • Click on +Add API link and click on Function App from the given templates.

Image Added
  • Follow the steps to create API:–

    • Select function app.

      • Click on browse.

      • Click on Function App

      • Select function and click select on right bottom.

      • Click select on left bottom to return to API configuration page.

        Image Added

    • Change the API URL suffix to “function”

    • Click create button.

Image Added
  • Click on InsightsWebhookHandler API and then click on POST operation (automatically added) under all operations. After that, Post operation will be shown in the Frontend section.

  • Click on the highlighted part given in the image.

Image Added
  • Click on Query tab and then click on + Add parameter link.

    • name = endpoint

    • Type = string

    • Tick Required checkbox

    • Click on Save button

Image Added
  • Go to Settings tab in the API and unselect Subscription required and click Save button.

Image Added
Expand
titleStep 4: Configure Webhook
Image Added
  • Copy the webhook url provided by Insights Application by clicking on the highlighted part and keep it somewhere in notepad.

Image AddedImage Added