Table of Contents

Delegated permissions

The permissions below are known as delegated permissions:

Image shows delegated permissions

Delegated permissions are the subset of both the current user permissions and the application permissions.

Image shows delegated permission venn diagram

Granting delegated permissions:

  • Does not grant the application any permission by itself, a user must always be present.
  • Does not grant the user permission to do anything they couldn't already do without the app.
  • Is a filter that controls what the application can do on the user's behalf.
  • Doesn't change the security posture of the Microsoft 365 tenant other than to trust Altus software to work on behalf of the users to perform actions they could already do manually.

More information about delegated permissions.

Authentication Pop-ups

When an application needs to perform actions on behalf of a user, it requires an Application identity in addition to the current user identity. This dual identity setup allows Microsoft Entra ID to determine whether the requested action should be permitted.

The Application identity is established through an "Application Registration." In this scenario, the application is registered as a multi-tenant application, meaning it can be utilised by multiple Microsoft 365 tenancies. This single application registration must include a fixed Return URL, which is essential for the authentication process to receive the access token. Given that each customer has a unique URL for their Altus instance under the *.dynamics.com domain, and the Return URL must be consistent across all customers, the URL must be hosted centrally. A browser pop-up to a page on the altus.pro domain can be expected on end-user machines to enable this authentication to occur.

Customers can be assured that all authentication processes occur client-side in the browser. Altus publishes this static page via a Content Delivery Network (CDN) to ensure efficient and secure access. The MSAL library passes the access token to the page via anchor method (using a # in the URL) which ensures the access token cannot be passed to an Altus server.

These requirements are dictated by the architecture of Microsoft Entra ID.