chat
585 TopicsMicrosoft Teams Bot OAuth login shows blank screen and closes without signing in
I’m building a Microsoft Teams bot using Azure AD OAuth (SSO) with Bot Framework. When I click Sign in, the OAuth popup in Teams shows a blank screen for a moment, then closes automatically without signing me in. What I’ve Done Added redirect URI in Azure App Registration: https://token.botframework.com/.auth/web/redirect Enabled Access tokens and ID tokens in App Registration → Authentication. Configured OAuth connection in Bot Channels Registration (ConnectionName matches my bot code). Verified client ID, client secret, and tenant ID are correct. Code bot.js require("dotenv").config(); const { TeamsActivityHandler } = require("botbuilder"); const { Client } = require("@microsoft/microsoft-graph-client"); const { DialogSet, DialogTurnStatus, OAuthPrompt, WaterfallDialog } = require("botbuilder-dialogs"); require("isomorphic-fetch"); const OAUTH_PROMPT = "OAuthPrompt"; const MAIN_DIALOG = "MainDialog"; class BotActivityHandler extends TeamsActivityHandler { constructor(conversationState, userState) { super(); this.conversationState = conversationState; this.userState = userState; this.dialogState = this.conversationState.createProperty("DialogState"); this.dialogs = new DialogSet(this.dialogState); // OAuthPrompt for Teams SSO this.dialogs.add( new OAuthPrompt(OAUTH_PROMPT, { connectionName: process.env.CONNECTION_NAME, text: "Please sign in to continue", title: "Sign In", timeout: 300000, }) ); this.dialogs.add( new WaterfallDialog(MAIN_DIALOG, [ this.promptStep.bind(this), this.handleFileStep.bind(this), ]) ); this.onMessage(async (context, next) => { const text = (context.activity.text || "").trim().toLowerCase(); const dialogCtx = await this.dialogs.createContext(context); if (text.startsWith("/")) { // ...handle commands... } else { const results = await dialogCtx.continueDialog(); if (results.status === DialogTurnStatus.empty) { if (context.activity.attachments?.length > 0) { await dialogCtx.beginDialog(MAIN_DIALOG, { file: context.activity.attachments[0], }); } else { await context.sendActivity("Upload a file or type /help."); } } } await next(); }); } async promptStep(stepContext) { return await stepContext.beginDialog(OAUTH_PROMPT); } async handleFileStep(stepContext) { const tokenResponse = stepContext.result; if (!tokenResponse?.token) { await stepContext.context.sendActivity("Please sign in to access files."); return await stepContext.endDialog(); } const token = tokenResponse.token; // Use token with Microsoft Graph API // ... return await stepContext.endDialog(); } } module.exports.BotActivityHandler = BotActivityHandler; Problem OAuth popup appears, then closes without completing login. No token is returned to the bot. Questions Why does the OAuth popup in Teams close immediately without signing in? Where can I see detailed error logs for OAuth failures? Azure AD sign-in logs? Application Insights (do I need to configure Instrumentation Key in Bot Service)? Environment Bot Framework v4 (Node.js) Azure Bot Service Microsoft Teams channel Azure AD v2 OAuth71Views0likes2Comments[iOS][Adaptive Card] Issues with Adaptive Card rendering on iOS devices
Hi there, I've encountered some issues with Adaptive Card rendering on iOS devices, although these issues do not appear and work fine on desktop, web, and Android platforms. Issue 1: When specifying the image size within an Adaptive Card, the rendering on iOS devices is inconsistent, resulting in the appearance of an extra blank area. iOS Desktop And the card JSON is: { "type": "AdaptiveCard", "body": [ { "type": "TextBlock", "text": "I am a bot.", "wrap": true }, { "type": "Image", "url": "", "width": "600px", "height": "300px" }, { "type": "ColumnSet", "columns": [ { "type": "Column", "width": "stretch", "items": [] }, { "type": "Column", "items": [ { "type": "TextBlock", "text": "Test Bot", "wrap": true, "isSubtle": true, "size": "Small", "weight": "Lighter" } ], "width": "auto", "verticalContentAlignment": "Center" } ] } ], "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "version": "1.6", "msTeams": { "width": "full" } } Issue 2: The Teams iOS client fails to properly render bold text in markdown when a single TextBlock contains both mention formatting and markdown elements. iOS Desktop Card JSON: { "type": "AdaptiveCard", "msteams": { "entities": [ { "type": "mention", "text": "<at>Zhongfang Zhou</at>", "mentioned": { "id": "29:1hRSk6kciBChF7eND3vFcDpybc1u0u-j4I9sCMr0j9WiD7a7XMGhYtOvCSZZxXQst83aOR_gimo5uEQPDOgP9vQ", "name": "Zhongfang Zhou" } } ] }, "body": [ { "type": "TextBlock", "text": "<at>Zhongfang Zhou</at> Hi, this is the **answer**.", "wrap": true }, { "type": "ColumnSet", "columns": [ { "type": "Column", "width": "stretch", "items": [] }, { "type": "Column", "items": [ { "type": "TextBlock", "text": "Test Bot", "wrap": true, "isSubtle": true, "size": "Small", "weight": "Lighter" } ], "width": "auto", "verticalContentAlignment": "Center" } ] } ], "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "version": "1.6", "msTeams": { "width": "full" } } Issue3: The Teams iOS client incorrectly renders all markdown text as bold when there are two TextBlocks, one containing mention formatting and the other containing markdown text. iOS Desktop Card JSON: { "type": "AdaptiveCard", "msteams": { "entities": [ { "type": "mention", "text": "<at>Zhongfang Zhou</at>", "mentioned": { "id": "29:1hRSk6kciBChF7eND3vFcDpybc1u0u-j4I9sCMr0j9WiD7a7XMGhYtOvCSZZxXQst83aOR_gimo5uEQPDOgP9vQ", "name": "Zhongfang Zhou" } } ] }, "body": [ { "type": "TextBlock", "text": "<at>Zhongfang Zhou</at>", "wrap": true }, { "type": "TextBlock", "text": "Hi, this is the **answer**.", "wrap": true }, { "type": "ColumnSet", "columns": [ { "type": "Column", "width": "stretch", "items": [] }, { "type": "Column", "items": [ { "type": "TextBlock", "text": "Test Bot", "wrap": true, "isSubtle": true, "size": "Small", "weight": "Lighter" } ], "width": "auto", "verticalContentAlignment": "Center" } ] } ], "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "version": "1.6", "msTeams": { "width": "full" } }2.1KViews1like6CommentsUnable to Add Tabs to Chats Consistently in Teams via GraphAPI
Expected Behavior: Tabs should be consistently added to chats when using the Graph API, provided all necessary permissions and conditions are met.Description We are encountering an issue when using the Microsoft Graph API to create chats and https://learn.microsoft.com/en-us/graph/api/chat-post-installedapps?view=graph-rest-1.0&tabs=http and https://learn.microsoft.com/en-us/graph/api/channel-post-tabs?view=graph-rest-1.0&tabs=http in Microsoft Teams. While we have the necessary permissions, the process of adding a tab to a chat works intermittently. Sometimes the tab is successfully added, but most of the time it fails, even though the app is installed correctly, with the following error: Failed to execute MsGraph backend request GetUserLicenseDetailsS2SRequest. Workload MsGraph_DirectoryServices. Request Url: https://graph.microsoft.com/v1.0/users/c0cfdd6b-d64d-42e1-8111-0881725f68ff/licenseDetails?$select=skuId,skuPartNumber,servicePlans, Request Method: GET, Response Status Code: NotFound, Response Headers: Strict-Transport-Security: max-age=31536000\r\nrequest-id: c86b5fbd-4224-486b-8f3e-8ad3f561a377\r\nclient-request-id: c86b5fbd-4224-486b-8f3e-8ad3f561a377\r\nx-ms-ags-diagnostic: {\"ServerInfo\":{\"DataCenter\":\"North Europe\",\"Slice\":\"E\",\"Ring\":\"4\",\"ScaleUnit\":\"011\",\"RoleInstance\":\"DB1PEPF00075073\"}}\r\nx-ms-resource-unit: 1\r\nDate: Tue, 22 Apr 2025 09:47:03 GMT\r\n, Reason Phrase: Not Found, Request ID 1F9FFBD00A5F489E9B7CABDCFB857858. Reproduction steps: Create an AAD App registration with required application permissions (to install apps and manage tabs in chats), ie at least the following: TeamsAppInstallation.ReadWriteAndConsentForChat.All TeamsTab.ReadWriteForChat.All Create a Teams application with a static tab with "groupChat" scope Install app in chat: POST https://graph.microsoft.com/v1.0/chats/:chatId/installedApps with body below Add (pin) tab to chat: POST https://graph.microsoft.com/v1.0/chats/:chatId/tabs with body below {"email address removed for privacy reasons" : "https://graph.microsoft.com/v1.0/appCatalogs/teamsApps/{{AppId}}"} Expected Behavior: Tabs should be consistently added to chats when using the Graph API, provided all necessary permissions and conditions are met. Current Behavior: The process of adding tabs to chats is unreliable. Sometimes the tab is added, but most times, the request fails without clear reasoning. All required permissions appear to be in place since it works occasionally. Note that this issue started to occur at the beginning of the month, around the 8th of April apparently, has anything changed around this date? Also note I also found traces of https://learn.microsoft.com/en-us/answers/questions/2259024/add-tab-to-chat-request-stopped-working-now-it-ret?source=docs in our logs but it is apparently resolved now.389Views2likes11CommentsFailed-Delete Message: Initiator (8:orgid:**) is not allowed to delete message
I am trying to delete a message inside Teams Channel using Graph API, the chat was generated using copilot agent. now i used this action to do the delete:- and this endpoint:- POST /teams/{teamsId}/channels/{channelId}/messages/{chatMessageId}/softDelete but we got this error message:- AclCheckFailed-Delete Message: Initiator (8:orgid:68******3ca) is not allowed to delete message Although the user who run the flow is teams owner + we have this setting enabled to allow owners to delete message:- any advice? Thanks78Views0likes1CommentUse AI to Automatically Translate Messages in Teams Chat
Microsoft Teams is widely used in international organizations, but currently, chat translation requires manual action for each message. I’d love to see an AI-powered feature that automatically translates messages in real time based on user preferences or system-detected language. Suggested Features: Auto-translate messages into the user's default language Option to view original text with one click Support for both 1:1 chats and group/channel conversations Allow users to opt-in/out or customize translation settings Smart detection of language context (e.g., if one person switches to Spanish, the system adapts)155Views0likes1CommentHow to Download Video Clip from Microsoft Teams Programmatically
I’m developing a bot app for Microsoft Teams, and part of its functionality involves handling videos recorded using the Teams widget(see screenshot attached). I am receiving a video clip link in the bot app's backend message. Where is this video file uploaded and how can I download the video clip using that link? I have attempted the SSO auth via Entra ID to fetch the auth token and attached it against the GET request to the video clip link as the bearer token. But still getting 401 errors? Need help and guidance in this matter. Thanks.275Views0likes6CommentsBot send individual chat to User
Hi Teams, I have Teams tab app and bot using TeamsActivityHandler (Typescript), and I have a logic is MS Bot will send private messages to user (It appears as a chat between bot and user) from Channel when I send a message with command Ex: In the Channel (team) have 5 members, when I send command like "MessageAllMembers", MS Bot will send individual message for each member (not Can you help me how to implement this logic or document about it? Thank so much1.5KViews0likes9CommentsAzure Function Not Sending Response Back to Teams Bot – Integration Issue
Azure Function Called by Teams Bot – Triggered Successfully but No Response in Web Chat We are integrating a Microsoft Teams Bot (C#) with an Azure Function (Python). While the Azure Function gets triggered successfully, we are not receiving any response back in Web Chat or Teams. What We Have Done: Teams Bot (C#) is running locally in Visual Studio. We added code to call the Azure Function using HttpClient: What We Have Done: Bot Framework Bot (C#) is running locally via Visual Studio (on ports 7130/5130). We’ve added this code to call the Azure Function: var httpClient = new HttpClient(); var response = await httpClient.PostAsync( "https://<function-url>/api/Foundarybasic", new StringContent(JsonConvert.SerializeObject(turnContext.Activity), Encoding.UTF8, "application/json") ); Azure Function (Python) is deployed and logs show that it receives the request and processes it correctly: ( I tested this from Power Automate getting Proper Response) @app.route(route="Foundarybasic", auth_level=func.AuthLevel.ANONYMOUS) def Foundarybasic(req: func.HttpRequest) -> func.HttpResponse: logging.info("Function triggered") data = req.get_json() user_text = data.get("text", "No message") reply = { "type": "message", "text": f"Echo: '{user_text}' — Azure Bot integration is working!" } return func.HttpResponse(json.dumps(reply), mimetype="application/json", status_code=200) Problem: Azure Function logs show it receives and processes the request correctly. However, nothing shows up in Web Chat or Teams client. No error messages or failed HTTP codes are observed. We want the Teams Bot to call the Azure Function and relay its response back to the user, like an echo bot Is there a required structure for the response that the Bot Framework expects from an external HTTP call? Does the bot need to manually send the Azure Function's response back using turnContext.SendActivityAsync(...)? Are there any known working patterns or best practices for calling Azure Functions from a Teams Bot? Any help, samples, or suggestions would be greatly appreciated! Thanks!90Views0likes1CommentQuestions About Alternatives to Multi-Tenant Bots After July 31, 2025 Deprecation
Hello, As the ability to create multi-tenant bots in Azure will be discontinued after July 31, 2025, I’d like to ask if there are any viable alternatives available now? If I create a single-tenant bot and publish it to the Teams App Store, will users from other tenants still be able to interact with the bot? Additionally, will the bot be able to access their basic user profile information (only user name and aadObjectId) and conversation data? From my understanding, access tokens obtained using the client ID and client secret are tenant-scoped, meaning they are not valid across other tenants. As a result, the bot cannot access user information such as profile photos or email addresses from users in other tenants — is that correct? I'd really appreciate any clarification or recommended best practices on this. Thank you!708Views0likes2CommentsCustom Teams AI Bot does not have attachment button
My team is developing a custom teams AI bot that allows for file uploads. When testing this feature using the edge and chrome debugging, the attachment button does not appear, or it will appear for a moment and then disappear. This seems to be an ongoing issue, and we would like to know if it has a simple remedy or if this problem needs to be escalated to Microsoft Engineers. Please see the following Microsoft developer forum topic discussing the same issue: https://techcommunity.microsoft.com/discussions/teamsdeveloper/file-upload-option-disappearing-in-teams-bot/4397456 My Manifest.json: Sensitive data has been removed "$schema": "https://developer.microsoft.com/en-us/json-schemas/teams/v1.19/MicrosoftTeams.schema.json", "manifestVersion": "1.19", "version": "2.0.0", "id": "${{TEAMS_APP_ID}}", "developer": { "name": "", "websiteUrl": "", "privacyUrl": "", "termsOfUseUrl": "" }, "icons": { "color": "", "outline": "" }, "name": { "short": "", "full": " " }, "description": { "short": "s", "full": "$[file('description.txt')]" }, "accentColor": "#005DAB", "bots": [ { "botId": "${{BOT_ID}}", "scopes": [ "personal", "team", "groupChat" ], "supportsFiles": true, "isNotificationOnly": false, ... }155Views0likes3Comments