Multitenant App associated to Single-tenant Azure Bot working even after deprecation

Anuj Arora 20 Reputation points
2025-10-14T18:00:35.09+00:00

I created a Single tenant Azure Bot. I want to use it for sending Proactive messages/notifications from our on-premises deployed Bot service using agents-sdk to different customer tenants in MS Teams. Since we want to send the notifications/messages to different target tenants, we changed the registered app (in AAD) associated with SingleTenant created Azure Bot to Multitenant App. Is it a correct configuration? Because I don't understand how can we achieve this if we make this Bot App registered as SingleTenant. Also, making it single-tenant doesn't work shows some Authorization issues (500 internal server error). I am confused right now, whether this configuration of SingleTenant Bot and MultiTenant App is correct for production or not. Somebody Please clarify this.

This below notice on Bot service to make Bot singletenant looks misleading, because multitenant app associated to SingleTenant Bot is still working.

deprecationimage

appimage

botimage

Azure AI Bot Service
Azure AI Bot Service
An Azure service that provides an integrated environment for bot development.
0 comments No comments
{count} votes

Answer accepted by question author
  1. Sina Salam 25,761 Reputation points Volunteer Moderator
    2025-10-15T12:17:40.7233333+00:00

    Hello Anuj Arora,

    Welcome to the Microsoft Q&A and thank you for posting your questions here.

    I understand you are having issues configuring your Azure Bot for cross-tenant proactive messaging in Microsoft Teams.

    Try to understand:

    • Multi-Tenant App Registration is required for cross-tenant access.
    • Single-Tenant App Registration restricts access to only one tenant, which is causing the authorization issues.
    • So, do not rely on Single-Tenant App Registration for cross-tenant messaging.

    However, the most reliable approach is to register your bot's Azure AD app as Multi-Tenant, which allows it to authenticate and interact with users across different customer tenants. You can do this by navigating to Azure Portal > App Registrations > Authentication, and selecting “Accounts in any organizational directory (Any Azure AD directory - Multitenant)”.

    While your Azure Bot resource itself can remain Single-Tenant, what truly governs tenant access is the App Registration. The bot service uses this app to authenticate and authorize requests, so its multi-tenant configuration is what enables communication with external tenants.

    But for production deployment, it's recommended to publish your bot to the Teams App Store (AppSource). This ensures discoverability and simplifies consent management for external organizations. Microsoft handles provisioning and tenant onboarding through AppSource, as clarified in @Aryan Parashar have stated.

    To allow external tenants to grant permissions to your bot, you should provide an admin consent URL like: https://login.microsoftonline.com/common/adminconsent?client_id=<your-app-id>

    This link enables tenant administrators to approve your bot’s access to their directory.

    In your Teams App Manifest, ensure you include the webApplicationInfo section with your app ID and resource URI:

    "webApplicationInfo": {
      "id": "<your-app-id>",
      "resource": "https://yourdomain.com"
    }
    

    This configuration is required for Teams to correctly route authentication and authorization requests to your bot. Refer to the Teams manifest schema documentation for full details.

    Finally, your bot code must be capable of validating tokens from multiple tenants. Use the Microsoft Bot Framework SDK to handle token validation securely and ensure that your bot can process proactive messages without authorization failures.

    I hope this is helpful! Do not hesitate to let me know if you have any other questions or clarifications.


    Please don't forget to close up the thread here by upvoting and accept it as an answer if it is helpful.


0 additional answers

Sort by: Most helpful

Your answer

Answers can be marked as 'Accepted' by the question author and 'Recommended' by moderators, which helps users know the answer solved the author's problem.