Create an Entra App for BC Integration
How to create an Entra App Registration in Azure
trigger OnDelete()
var
PaymentTermsTranslation: Record "Payment Term Translation";
begin
PaymentTermsTranslation.SetRange("Payment Term", Code);
PaymentTermsTranslation.DeleteAll();
end;
Creating an App Registration in Azure for Business Central
This post shows how to create an App Registration in Azure, allowing third-party systems to connect to Business Central (BC) APIs securely. It acts as an identity in BC and enables the use of OAuth 2.0 authentication protocols required by BC online.
A Few Key Concepts
Application Id (aka Client ID)
This is a unique identifier assigned to the app. It is registered in BC as the ‘identity’, and permissions are assigned to it, similar to a user’s permissions.
Tenant ID
The Azure tenant ID where the app is registered.
Redirect URI
This is where the authentication responses are sent:
BC Online
https://businesscentral.dynamics.com/OAuthLanding.htm
BC On Premise (some examples)
https://localhost/BC250/OAuthLanding.htm
https://MyServer/BC250/OAuthLanding.htm
https://{your server}/{your environment}/OAuthLanding.htm
Client Secret
The secret is generated and shared with the third-party system. It is used to prove identity when requesting an authentication token. These secrets are time-limited, and a new one must be generated and shared when the current one expires.
INFO
Client secrets are displayed only once, upon creation. If lost, a new one must be generated.
API Permissions
These define the API access an Entra app will have. They are configured in Azure and are unrelated to BC permissions. Examples include access to the Admin API in Business Central or Microsoft Graph API to read a user’s email address.
Delegated Permissions vs Application Permissions
When adding API permissions for Business Central, you must choose between Delegated and Application permissions. Generally, an app will need one or the other, depending on its specific purpose.
Delegated Permissions
Delegated permissions are used when the app acts on behalf of a signed-in user. These permissions require user authentication, meaning the user must log in. The app can only access Business Central based on that user’s permissions.
Application Permissions
Application permissions allow access to Business Central without a signed-in user. They are typically used for background services, automation, or system-to-system (S2S) integrations. The app receives full access based on assigned permissions.
Comparison Table
Feature | Delegated Permissions | Application Permissions |
---|---|---|
User Sign-in Required? | ✅ Yes | ❌ No |
Follows User Permissions? | ✅ Yes | ❌ No (App has its own BC permissions) |
Best for? | Interactive user-based applications | Background processes, system-to-system integration |
Example Use Case | Power Automate flow running as a user | Automated data sync between BC and another system |
Authentication Type | OAuth 2.0 (User login required) | OAuth 2.0 Client Credentials (No user login) |
Requires Admin Consent? | Sometimes | Always |
How to Register a New App for Business Central
Go to Azure Portal.
Navigate to Azure Active Directory → App registrations.
data:image/s3,"s3://crabby-images/4932d/4932d4f0a197b978469bb02b216ab395df430295" alt="VAT Posting Setup in BC"
- Click + New registration. Give the app a name and choose the account type.
data:image/s3,"s3://crabby-images/ba5fa/ba5fa0be3b675359142095731fadf117d51f056f" alt="VAT Posting Setup in BC"
- Select Web (this can also be done later in Authentication settings).
data:image/s3,"s3://crabby-images/291bf/291bfd5fb4eb91ed131a1e6d1acd7e9322041594" alt="VAT Posting Setup in BC"
Enter the redirect URI:
https://businesscentral.dynamics.com/OAuthLanding.htm
Click Register to continue.Now we need to select the API permissions required for the app. Go to API Permissions and Add A Permission
data:image/s3,"s3://crabby-images/fc1de/fc1ded2d171c6c4edff8cb4522292a01d0f4710d" alt="VAT Posting Setup in BC"
- From the options, select Dynamics 365 Business Central
data:image/s3,"s3://crabby-images/5cf10/5cf108e979163723261eb7d009c3dbd9c462f541" alt="VAT Posting Setup in BC"
- For Delegated Permissions, add the required permissions.
data:image/s3,"s3://crabby-images/5b788/5b788af840ab8f963402837dd0a610265c7a4db9" alt="VAT Posting Setup in BC"
- For Application Permissions, select and choose the necessary permissions.
data:image/s3,"s3://crabby-images/da737/da737eb4d6de14620c43b0cfd3f03a18ba96523c" alt="VAT Posting Setup in BC"
- If required, grant admin consent (admin access required).
data:image/s3,"s3://crabby-images/cc608/cc6084657fa3b15f13e23ce2f3a7d3c5df2730da" alt="VAT Posting Setup in BC"
- Select Yes, then confirm the status is granted.
data:image/s3,"s3://crabby-images/8ccf7/8ccf7e41516f44fd3409740e42fe7b3739af6738" alt="VAT Posting Setup in BC"
- Add a client secret for S2S access, o to Certificates & Secrets then click New Secret.
data:image/s3,"s3://crabby-images/430c4/430c4ec3a40cafd8ca12cfc5beff5d5b0c138f1d" alt="VAT Posting Setup in BC"
- Give the secret a name and set an expiration duration. Click Add.
data:image/s3,"s3://crabby-images/0035a/0035a88c5883b77fbe7c5a8ebf3c82d2c2d1deb8" alt="VAT Posting Setup in BC"
- This will generate a secret (the Value column). This is the only time you will be able to view this so make a note of it, securely.
data:image/s3,"s3://crabby-images/e3ff5/e3ff58d88e921331b49aefd30fd5bc53b0ad6ee6" alt="VAT Posting Setup in BC"
- The three pieces of information you generally need are
- Application (client) ID – Found on the app registration overview page.
- Client Secret – Obtained in the previous step.
- Directory (tenant) ID – Found on the app registration overview page.
CAUTION
Important: If a client secret is compromised, remove it immediately and generate a new one.
Configuring the Entra App in Business Central
- Navigate to Microsoft Entra Applications.
data:image/s3,"s3://crabby-images/c963e/c963e32884a77f8d12ba8fc067496db8ba515aa4" alt="VAT Posting Setup in BC"
- Create a new Entra Application.
data:image/s3,"s3://crabby-images/1750f/1750f5b3fbbf87d42f7eff3191d23117ea6bee8d" alt="VAT Posting Setup in BC"
- Add the client ID from the Entra App and Grant Consent.
data:image/s3,"s3://crabby-images/94f1e/94f1e71587604973a0b7f1fb59c87b6e92ea97f4" alt="VAT Posting Setup in BC"
- Sign in as an admin and accept the requested permissions.
data:image/s3,"s3://crabby-images/549a8/549a80113743e5f40e19ccfe5efb698925465edb" alt="VAT Posting Setup in BC"
- Change the state to Enabled. A prompt will ask if you want to create a user with the app’s name. Select Yes to continue.
data:image/s3,"s3://crabby-images/fa458/fa458cb8250ae89aa69a856994c6d61b55b34515" alt="VAT Posting Setup in BC"
- Assign permission sets to the S2S user as required.
- Note: It is not possible to assign SUPER permissions to an S2S user in Business Central.
data:image/s3,"s3://crabby-images/33fdb/33fdb00b7993e4846b3cee5eb362b6d5561fd147" alt="VAT Posting Setup in BC"
That’s it! Now configure the third-party application with the client secret or, if testing APIs, configure Postman.