Versions Compared

Key

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

...

  1. Go to Storage accounts page in the portal or visit link: https://portal.azure.com/#blade/HubsExtension/BrowseResource/resourceType/Microsoft.Storage%2FStorageAccounts

  2. Click on + Add Button to add new storage account.

  3. Fill the required details in all the given tabs (Basic, Networking…etc.) and click on create.
    Basics:
    i. Choose Subscription and Resource Group.
    ii. Storage account name: insightswebhookstorage.
    iii. Account kind: StorageV2
    iv. Leave Replication as it is.
    v. Access Tier: Hot

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

  5. Create 3 new containers by click on + container button with names:
    a. insightswebhookevents
    b. failedwebhookevents
    c. functionapp

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

  7. Click on 3 dots given on the right side and then click on Access policy for both the containers to create policy.

  8. Click on + Add Policy button under stored access policy and fill the details to create policy and click OK button. After clicking OK, Click on Save button to save policy. Repeat this step for all containers.

  9. Download the zip file from the docroot server to the local system.

  10. Follow steps to upload file:
    a. Click on functionapp container to go inside container and Click on upload button.

b. Follow Steps:
i. Select the zip file from the local system.
ii. Select checkbox Overwrite if files already exist.
iii. Click on advanced and change the Blob type to Block Blob and Block size to 100 MB.
iv. Click on Upload button.

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

  2. Go to insightswebhookstorage storage account.
    a. Click on Properties under settings in the left menu and copy the value of Primary Blob Service Endpoint and paste it on notepad.

b. 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.

  1. Click on containers from the left menu and copy the names of the two container i.e. insightswebhookevents and failedwebhookevents

  2. Make sure you have 6 values present somewhere as shown in the below image

Azure Functions

  1. Go to Function App page from left menu or visit link https://portal.azure.com/#blade/HubsExtension/BrowseResource/resourceType/Microsoft.Web%2Fsites/kind/functionapp

  2. Click on + Add button

  3. Fill the required details:
    a. Basics:
    i. Choose Subscription and Resource Group.
    ii. Function App name: InsightsWebhookHandler
    iii. Publish: Code
    iv. Runtime stack: Java
    v. Choose Region where your storage account is created.
    b. Hosting
    i. Select insightswebhookstorage option in Storage account.
    ii. Operating System: Windows
    iii. Choose Plan type as per needs.
    c. Monitoring:
    i. Enable Application Insights: Yes
    ii. 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.

  1. Click on configuration under configured features

  2. Click on + New application setting button

  3. 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 Name while adding application settings.

S.No. 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 0 0 * * * *

API Management

  1. Go to API Management Services from the home page or visit link https://portal.azure.com/#blade/HubsExtension/BrowseResourceBlade/resourceType/Microsoft.ApiManagement%2Fservice

  2. Create API management Service. Click on + Add Button.

  3. Fill the required details and click create button.

  4. Click on APIs link from left menu.

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

  6. Follow the steps to create API:–
    • Select function app.
    o Click on browse.
    o Click on Function App
    o Select function and click select on right bottom.
    o Click select on left bottom to return to API configuration page.

• Change the API URL suffix to function
• Click create button.

  1. 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.

  1. Click on Query tab and then click on + Add parameter link.
    a. name = endpoint
    b. Type = string
    c. Tick Required checkbox
    d. Click on Save button

  2. Go to Settings tab in the API and untick Subscription required and click Save button.

Configure Webhook

  1. Go to API Management Services from the home page or visit link https://portal.azure.com/#blade/HubsExtension/BrowseResourceBlade/resourceType/Microsoft.ApiManagement%2Fservice

  2. Open the API management service by clicking on the name. After that, Click on the APIs under API Management from left menu and then click on your Function API(eg - InsightsWebhookHandler)

  3. Click on Setting tab and copy the Base URL. Follow the given steps to complete the API url:
    a. Append the function name to the Base URL. Example:
    https://insightstest.azure-api.net/function/InsightsWebhookHandler
    b. Add query parameter “endpoint” to build the final API URL
    https://insightstest.azure-api.net/function/InsightsWebhookHandler? endpoint=<WEBHOOK_NAME>
    c. Replace <WEBHOOK_NAME> with the name of the tool webhook name from the Insights application.

  4. Copy the webhook url provided by Insights Application by clicking on the highlighted part and keep it somewhere in notepad.

  5. Go to Function App page from left menu or visit link https://portal.azure.com/#blade/HubsExtension/BrowseResource/resourceType/Microsoft.Web%2Fsites/kind/functionapp

  6. Open the function app by clicking on the name and then click on configuration. After that, Add new application setting by clicking on the + New application setting link
    a. Name: Webhook Name
    b. Value: Webhook URL

  7. Final step, paste the final API URL in the webhook section of the devops tool.