About Microsoft Teams
The Microsoft Teams integration connects Serval to your organization’s Teams tenant so the Serval bot can power a help desk directly inside Teams - receiving channel messages, @mentions, thread replies, group chat messages, and DMs - and so workflows can send direct messages, channel threads, and group chat messages. Setup is two one-time admin actions: a Microsoft administrator grants tenant-wide admin consent to Serval’s managed application, and a Teams administrator uploads a Serval-generated bot app package to your organization’s Teams app catalog. There is nothing for you to register or configure on the Microsoft side - Serval manages its own application. This integration is separate from the Microsoft Graph integration; if your team also needs mail, calendar, SharePoint, or Entra user lookups, connect both. Authentication: One-time Microsoft admin consent against Serval’s managed application, plus a Teams bot app package uploaded by a Teams administrator. No credentials form - there is no client ID, secret, or app registration for you to create. Data sync: No background data sync. Inbound Teams messages are pushed to Serval in real time as they happen; outbound messages and API actions run on demand with short-lived tokens minted per request. API requests from Serval workflows can only reach Microsoft’sgraph.microsoft.com and smba.trafficmanager.net services.
What the Microsoft Teams integration enables
| Capability | Description |
|---|---|
| Help desk in Teams channels | The Serval bot receives channel messages, @mentions, thread replies, group chat messages, and DMs - powering ticket creation and in-thread AI responses. You activate a channel by @mentioning the bot in it; the channel then appears in Serval, where you assign it one of five modes: Disabled, Help desk (Always respond), Help desk (When relevant), Silent, or On demand. |
| Send direct messages | Workflows can send a 1:1 direct message to any user in your tenant. Serval automatically installs its bot for that user first if needed. |
| Send channel messages | Workflows can start a new thread in a channel. They accept a copied Teams link - a “Copy link to channel” link, a team link, or a channel message link - and auto-install the bot into the team if needed. Proactive bot messages work in standard and shared channels, not private channels. |
| Send group chat messages | Workflows can post into an existing group chat using a copied chat link or a raw group chat ID (it starts with 19: and typically ends in @unq.gbl.spaces). |
| In-Teams bot commands | Users can run /healthcheck in any team, group chat, or DM to check that Serval’s connection to Microsoft Teams is working, and /create-ticket in a personal chat to create a Serval support ticket from a short form. |
| Microsoft Graph requests (Teams-scoped) | Advanced workflows can make arbitrary Microsoft Graph calls - catalog, install, membership, and channel queries - using the integration’s tenant credentials. |
| Bot Framework requests | Advanced workflows can call the Bot Framework Connector API directly for activities, adaptive cards, reactions, and conversation operations. |
Get your credentials
There are no credentials to create. You will not register an Entra application, and you will never see or enter a client ID or secret - Serval uses its own managed application. Instead, two people in your organization each perform a one-time approval. Microsoft’s official documentation on the admin consent flow is here.Line up a Microsoft administrator
Line up a Teams administrator
Plan for auto-install (optional)
Connect in Serval
Start the connection
Accept Microsoft's admin consent prompt
Download the Teams bot app package
Serval-Teams-Bot.zip, generated specifically for your installation.Upload the package in the Teams Admin Center
Activate channels
Verifying the connection
The Microsoft Teams integration runs three health checks. Microsoft Teams Connectivity - lists a small sample of your teams through Microsoft Graph to verify Serval’s application permissions work. Finding zero teams still counts as success.- Success: “Connected to Microsoft Teams. Found [number] team(s) including: [team names]” - or, with zero teams: “Connected to Microsoft Teams, but no teams found in the organization. Create a team in Microsoft Teams and try again.”
- Insufficient privileges: “Serval does not have the required permissions to access Microsoft Teams. Please ensure the Team.ReadBasic.All application permission is granted in your Azure AD app registration. After adding the permission, an administrator must click ‘Grant admin consent’.”
- Access denied: “Access denied when connecting to Microsoft Teams. The Team.ReadBasic.All application permission may not be granted. Go to Azure AD → App registrations → API permissions and verify that Team.ReadBasic.All is listed and has admin consent granted.”
- Authentication failure: “Authentication failed when connecting to Microsoft Teams. Admin consent may have been revoked, or the app credentials are invalid. Try reconnecting the Microsoft Teams integration.”
- Not found: “The Microsoft Teams API endpoint was not found. This may indicate that Microsoft Teams is not enabled for your tenant.”
- Microsoft server error: “Microsoft Teams returned a server error. This is likely a temporary issue with Microsoft’s API - please try again later.”
- Consent never granted: “Admin consent has not been granted for the Microsoft Teams integration. Please reconnect the integration - a Microsoft administrator must approve the consent prompt.”
- Anything else: “Unable to connect to Microsoft Teams. Please verify the integration is connected and the admin has approved the required permissions.”
- Success: “Serval bot app is present in the organization’s Teams app catalog (ID: [app ID]).”
- Not found: “The Serval bot app was not found in your organization’s Teams app catalog. An administrator needs to upload the app package (downloadable from this page) in the Teams Admin Center under ‘Manage apps’. Without this, the bot cannot be installed to teams or users.”
- Insufficient privileges: “Serval does not have permission to query the Teams app catalog. Ensure the AppCatalog.Read.All application permission is granted in your Azure AD app registration and that an administrator has clicked ‘Grant admin consent’.”
- Access denied: “Access denied when querying the Teams app catalog. The AppCatalog.Read.All permission may not be granted. Check Azure AD → App registrations → API permissions.”
- Authentication failure: “Authentication failed when querying the Teams app catalog. Admin consent may have been revoked, or the app credentials are invalid. Try reconnecting the Microsoft Teams integration.”
- Anything else: “Unable to query the Teams app catalog. Please verify the integration is connected and the admin has approved the required permissions.”
- Success: “Channel resolution is working. Team “[name]” has internalId and [number] channel(s).” - or, with zero teams: “Connected to Microsoft Teams, but no teams found in the organization. Channel @mention support requires at least one team.”
- Missing internal ID: “Serval can list teams but cannot read team internal IDs. This prevents Serval from resolving which channel the bot was @mentioned in. Please ensure the Team.ReadBasic.All application permission is granted with admin consent in Azure AD → Enterprise Applications → Serval → Permissions.”
- Insufficient privileges: “Serval does not have the required permissions to resolve Teams channels. Please ensure Team.ReadBasic.All and Channel.ReadBasic.All application permissions are granted in your Azure AD app registration with admin consent.”
- Access denied: “Access denied when resolving Teams channels. The required application permissions (Team.ReadBasic.All, Channel.ReadBasic.All) may not be granted. Check Azure AD → App registrations → API permissions.”
- Authentication failure: “Authentication failed when resolving Teams channels. Admin consent may have been revoked, or the app credentials are invalid. Try reconnecting the Microsoft Teams integration.”
- Anything else: “Unable to resolve Teams channels. This is required for channel @mention support. Please verify the integration is connected and the admin has approved the required permissions.”
Gotchas and troubleshooting
Admin consent alone is not enough - the bot app package upload is a separate, mandatory step
Admin consent alone is not enough - the bot app package upload is a separate, mandatory step
Serval-Teams-Bot.zip to the org app catalog (Teams Admin Center → Manage apps), the bot cannot install itself anywhere: the Bot App Catalog Presence health check fails, and every send-message action fails. Direct messages report:We couldn’t find the Serval application in your Microsoft Teams app catalog. Please ask an administrator to upload it in Teams Admin Center before direct messages can be sent.Channel and group chat messages report that the Serval bot app was not found in the Teams app catalog and that an administrator must upload the app package in Teams Admin Center, followed by diagnostic details of each app identity Serval tried. The bot’s chat and channel read/send rights come from resource-specific consent declared in the uploaded package - not from admin consent.
Channel mapping breaks silently without Team.ReadBasic.All / Channel.ReadBasic.All
Channel mapping breaks silently without Team.ReadBasic.All / Channel.ReadBasic.All
Catalog queries need AppCatalog.Read.All
Catalog queries need AppCatalog.Read.All
Revoked or missing admin consent surfaces as specific AADSTS errors
Revoked or missing admin consent surfaces as specific AADSTS errors
- AADSTS700016: “The Serval application was not found in the directory ‘[organization name]’. This usually means admin consent has not been granted or has been revoked. Please reconnect the Microsoft Teams integration to grant admin consent again.”
- AADSTS65001: “Admin consent has not been granted for the Microsoft Teams integration. Please reconnect the integration - an administrator must approve the consent prompt.”
- unauthorized_client: “The Serval application is not authorized for tenant ‘[organization name]’. This typically means admin consent needs to be granted. Please reconnect the Microsoft Teams integration.”
- AADSTS7000215: “The client secret for the Serval application is invalid. Please contact Serval support.” - that one is a Serval-side issue, not something you can fix.
The app package is environment- and install-specific - don't reuse a ZIP across orgs
The app package is environment- and install-specific - don't reuse a ZIP across orgs
Serval-Teams-Bot.zip is stamped with your specific installation’s identity. If the catalog app doesn’t match the connected integration, direct messages report:We found the Serval application in your Microsoft Teams app catalog, but couldn’t install it with the current Microsoft Teams integration configuration. Please ask an administrator to verify the Microsoft Teams integration is configured for the correct Serval application.Channel messages similarly report that Serval found the app but couldn’t install it in the target team - which can also happen when the team hasn’t granted the required resource-specific permissions or tenant policy blocks app-only installation. Re-download the package from the current integration settings page and re-upload it.
Setup Policies require an Admin Center upload
Setup Policies require an Admin Center upload
Channel messages need a copied Teams link, and private channels are not supported
Channel messages need a copied Teams link, and private channels are not supported
19: works there.)Cross-tenant / external group chats can't be auto-installed
Cross-tenant / external group chats can't be auto-installed
Separate from the Microsoft Graph integration
Separate from the Microsoft Graph integration
No connect form, and Reconnect is a full re-consent
No connect form, and Reconnect is a full re-consent
Message size limits are not pre-validated
Message size limits are not pre-validated
Need help? Contact support@serval.com for assistance with your Microsoft Teams integration.

