Skip to main content
Announcements
SYSTEM MAINTENANCE: Thurs., Sept. 19, 1 AM ET, Platform will be unavailable for approx. 60 minutes.

Using REST Connector with OAuth2 against Microsoft Dynamics 365 Business Central

100% helpful (2/2)
cancel
Showing results for 
Search instead for 
Did you mean: 
Sonja_Bauernfeind
Digital Support
Digital Support

Using REST Connector with OAuth2 against Microsoft Dynamics 365 Business Central

Last Update:

Sep 5, 2022 8:27:13 AM

Updated By:

Sonja_Bauernfeind

Created date:

May 11, 2022 10:22:58 AM

Background

 

Microsoft is deprecating basic authentication in Microsoft Dynamics 365 Business Central (online), recommending users to instead authenticate with OAuth2. This is in effect from version 20 of Business Central, rolled out in April 2022. Basic auth has been extended for users previously having Business Central v19 who now are upgraded to v20. New customers starting on version 20 must open a support ticket with Microsoft to have basic auth enabled. Basic auth will be turned off for all customers in Business Central v21 (targeted for October 2022).

 

Environment:

Qlik REST Connector 
Qlik Cloud 
Qlik Sense Enterprise on Windows 

 

Assumed Scenario and Prerequisite

 

This article describes how the existing REST Connector in Qlik Sense can be configured to use OAuth2. The suggested OAuth flow uses Service-to-Service authentication against Microsoft Dynamics 365 Business Central. It requires that a single-page application is registered in the Azure portal with granted consent in the Business Central environment and that the related Client ID and Client Secret are known.

 

Obtain the Access Token

 

The configuration requires a separate connection definition for the initial login to get an access token from the Azure portal. The URL to use for this is:

https://login.microsoftonline.com/<BC Tenant ID>/oauth2/v2.0/token

 

Use the POST Method in a REST Connection

Within a REST Connector definition, use the URL noted above together with the POST method.

The request body must include the parameters Client ID (client_id) and the Client Secret (client_secret), together with grant_type=client_credentials and scope set to the API default (scope=https://api.businesscentral.dynamics.com/.default). You must separate the parameters with the ampersand character (&).

Edited connection.png

 

Adjust the Script to Capture a Token Parameter

 

This connection generates a JSON table (named ‘root’), which includes a column with the access token. You can extract the value of the access token into a parameter in the load script with the LET keyword.

REST Business Central Sandbox Auth.png

Use TRACE in the script to output the accessToken value in the data load progress window. The token is necessary to copy as you will paste it in the subsequent step, for the initial load of data.

Data Load Progress.png

 

Get the Data with Separate REST Connection

 

The standard URL for the API endpoint is:

https://api.businesscentral.dynamics.com/v2.0/<environment name>/api/v2.0/<API resource>

See Microsoft documentation for alternatives and further details.

 

Use Query Header Parameters in REST Connection

 

Within a separate REST Connector definition, use the API URL together with the GET method, and other defaults or adjustments as required, to get access to the data from the desired Business Central API resource.

The connection definition must include two query header parameters, one for the authorization token and one to set accept-encoding to gzip, deflate.

Query headers.png

The Authorization parameter must initially have the value Bearer followed by a valid accessToken value, for example, copied from the data load progress window in the previous step.

 

 

Adjust the Script to Dynamically use an Obtained Token

 

This connection generates a table with the data from the API resource defined in the URL. In this example, the company's resource was used (https://api.businesscentral.dynamics.com/v2.0/Sandbox/api/v2.0/companies).

 Adjust the load script by adding a WITH CONNECTION statement including the Authorization header parameter and the accessToken parameter from the preceding script, i.e.
WITH CONNECTION (HTTPHEADER “Authorization” “Bearer $(accessToken)”)

WITH CONNECTION.png

This ensures that the new valid access token generated in the preceding part of the script gets inserted each time the load script is run.

You can configure additional API resources in separate connection definitions or by dynamically define the related URLs and tables in the load script.

Labels (1)
Comments
AlexOmetis
Partner Ambassador
Partner Ambassador

Also worth noting you can use the "Next URL" Pagination option with "root/@odata.nextLink" as the value to make sure you get all the data with the GET connection - mine cut off at 20,000 rows otherwise. 

AlexOmetis_0-1652283627232.png

 

diego_rueda
Partner - Contributor III
Partner - Contributor III

Hi,

What kind of Authentication Schema must be used in both connections?.

 

Sonja_Bauernfeind
Digital Support
Digital Support

Hello @diego_rueda 

The REST Connector is here used in two connection definitions, one to obtain the access token and one to get the data. These are what defines the authentication against MS Dynamics. Then there is also an option for “authentication scheme” within the connection definition UI, for which the default selection ‘Anonymous’ should be just kept as is.

Authentication Anonymous.png

Luisanabria
Creator
Creator

Hi @Sonja_Bauernfeind good day

 

Im trying to connect following your steps, but l have many dudes about it, hope you can guide me.

1. Is neccesary add Qlik as a new aplication in Azure Portal before to this process? 

2. Request body:

              grant_type=
              &client_id=
              &client_secret=
              &scope=https://api.businesscentral.dynamics.com/.default

Where can l get that information? My provider should give me that?

 

Hope you can help me, l really would aprecciate!
thanks

wcilliers
Partner Ambassador
Partner Ambassador

Hi @Sonja_Bauernfeind ,

Thank you for your guidance on this. Are you able to share some more details around the second 'GET' part of the connection. I have followed your steps and was able to get my token. However, for the second connection I am getting the below error using the exact same steps as you;

wcilliers_0-1674532088846.png

 

Any guidance on the entire setup of the second connection would be appreciated.

Thanks,

Wynand

Sonja_Bauernfeind
Digital Support
Digital Support

Hello @wcilliers and @Luisanabria 

Let me look into these queries for you.

All the best,
Sonja 

Sonja_Bauernfeind
Digital Support
Digital Support

Hello @Luisanabria 

It requires that a single-page application is registered in the Azure portal with granted consent in the Business Central environment and that the related Client ID and Client Secret are known. If you do not have access to the above, then your provider will need to give them to you.

All the best,
Sonja

 

Sonja_Bauernfeind
Digital Support
Digital Support

Hello @wcilliers 

Have you included the token as a header with his request as per the step Use Query Header Parameters in REST Connection?

Providing a screenshot of this step may help us narrow down the problem.

All the best,
Sonja 

wcilliers
Partner Ambassador
Partner Ambassador

Hi @Sonja_Bauernfeind ,

Yes I have included the headers.

wcilliers_0-1675034265339.pngwcilliers_1-1675034321487.pngwcilliers_2-1675034352193.png

Thanks,

Wynand

 

Luisanabria
Creator
Creator

@Sonja_Bauernfeind 

Hi all,

l tried many times and problem still unauthorized but my Business Central Provider give me more permissions l didnt have.

 

Thanks, your post helps me so much, the only dude l have, is, if l need for example "sales" and "clients" is neccesary to create 2 REST different connections? and future create a new REST for a new type data l need?

 

Version history
Last update:
‎2022-09-05 08:27 AM
Updated by: