How to integrate Microsoft teams MCP with LlamaIndex

This guide walks you through connecting Microsoft teams to LlamaIndex using the Composio tool router. By the end, you'll have a working Microsoft teams agent that can add new member to project team, schedule an online meeting for sales, list all chats i’m part of through natural language commands. This guide will help you understand how to give your LlamaIndex agent real control over a Microsoft teams account through Composio's Microsoft teams MCP server. Before we dive in, let's take a quick look at the key ideas and tools involved.

Microsoft teams logoMicrosoft teams
Oauth2S2s Oauth2

Microsoft Teams is a collaboration platform that combines chat, meetings, and file sharing within Microsoft 365. It keeps distributed teams connected and productive through seamless virtual communication.

150 Tools

Introduction

This guide walks you through connecting Microsoft teams to LlamaIndex using the Composio tool router. By the end, you'll have a working Microsoft teams agent that can add new member to project team, schedule an online meeting for sales, list all chats i’m part of through natural language commands.

This guide will help you understand how to give your LlamaIndex agent real control over a Microsoft teams account through Composio's Microsoft teams MCP server.

Before we dive in, let's take a quick look at the key ideas and tools involved.

Also integrate Microsoft teams with

TL;DR

Here's what you'll learn:
  • Set your OpenAI and Composio API keys
  • Install LlamaIndex and Composio packages
  • Create a Composio Tool Router session for Microsoft teams
  • Connect LlamaIndex to the Microsoft teams MCP server
  • Build a Microsoft teams-powered agent using LlamaIndex
  • Interact with Microsoft teams through natural language

What is LlamaIndex?

LlamaIndex is a data framework for building LLM applications. It provides tools for connecting LLMs to external data sources and services through agents and tools.

Key features include:

  • ReAct Agent: Reasoning and acting pattern for tool-using agents
  • MCP Tools: Native support for Model Context Protocol
  • Context Management: Maintain conversation context across interactions
  • Async Support: Built for async/await patterns

What is the Microsoft teams MCP server, and what's possible with it?

The Microsoft Teams MCP server is an implementation of the Model Context Protocol that connects your AI agent and assistants like Claude, Cursor, etc directly to your Microsoft Teams account. It provides structured and secure access to your Teams workspace, so your agent can perform actions like managing chats, sending messages, creating meetings, and organizing teams on your behalf.

  • Automated chat and message management: Let your agent retrieve, read, and summarize messages from any Teams chat, or fetch all chats you’re part of for quick updates.
  • Team and channel organization: Easily create new teams, add members, get channel details, or archive and delete teams to keep your workspace organized.
  • Scheduling online meetings: Have your agent schedule standalone Teams meetings instantly, making it simple to coordinate with colleagues or clients without manual setup.
  • Granular access to team and chat details: Fetch full information about specific teams, channels, or even individual messages with precision, enabling rich contextual workflows.
  • Seamless membership and collaboration management: Add or update members in teams with a prompt, ensuring the right people always have access to the conversations and resources they need.

What is the Composio tool router, and how does it fit here?

What is Composio SDK?

Composio's Composio SDK helps agents find the right tools for a task at runtime. You can plug in multiple toolkits (like Gmail, HubSpot, and GitHub), and the agent will identify the relevant app and action to complete multi-step workflows. This can reduce token usage and improve the reliability of tool calls. Read more here: Getting started with Composio SDK

The tool router generates a secure MCP URL that your agents can access to perform actions.

How the Composio SDK works

The Composio SDK follows a three-phase workflow:

  1. Discovery: Searches for tools matching your task and returns relevant toolkits with their details.
  2. Authentication: Checks for active connections. If missing, creates an auth config and returns a connection URL via Auth Link.
  3. Execution: Executes the action using the authenticated connection.

Step-by-step Guide

Step by step10 STEPS
1

Prerequisites

Before you begin, make sure you have:
  • Python 3.8/Node 16 or higher installed
  • A Composio account with the API key
  • An OpenAI API key
  • A Microsoft teams account and project
  • Basic familiarity with async Python/Typescript
2

Getting API Keys for OpenAI, Composio, and Microsoft teams

OpenAI API key (OPENAI_API_KEY)
  • Go to the OpenAI dashboard
  • Create an API key if you don't have one
  • Assign it to OPENAI_API_KEY in .env
Composio API key and user ID
  • Log into the Composio dashboard
  • Copy your API key from Settings
    • Use this as COMPOSIO_API_KEY
  • Pick a stable user identifier (email or ID)
    • Use this as COMPOSIO_USER_ID
3

Installing dependencies

npm install @composio/llamaindex @llamaindex/openai @llamaindex/tools @llamaindex/workflow dotenv

Create a new Typescript project and install the necessary dependencies:

  • @composio/llamaindex: Composio's LlamaIndex integration
  • @llamaindex/openai: OpenAI LLM integration
  • @llamaindex/tools: MCP client for LlamaIndex
  • @llamaindex/workflow: Workflow framework for LlamaIndex
  • dotenv: Environment variable management
4

Set environment variables

bash
OPENAI_API_KEY=your-openai-api-key
COMPOSIO_API_KEY=your-composio-api-key
COMPOSIO_USER_ID=your-user-id

Create a .env file in your project root:

These credentials will be used to:

  • Authenticate with OpenAI's GPT-5 model
  • Connect to Composio's Tool Router
  • Identify your Composio user session for Microsoft teams access
5

Import modules

import "dotenv/config";
import readline from "node:readline/promises";
import { stdin as input, stdout as output } from "node:process";

import { Composio } from "@composio/core";

import { mcp } from "@llamaindex/tools";
import { agent as createAgent } from "@llamaindex/workflow";
import { openai } from "@llamaindex/openai";

dotenv.config();

Create a new file called microsoft teams_llamaindex_agent.ts and import the required modules:

Key imports:

  • dotenv.config loads .env at runtime
  • readline gives us a simple CLI chat loop
  • Composio is the main Composio SDK client
  • mcp connects to an MCP endpoint
  • createAgent builds a LlamaIndex agent
  • openai configures the LLM backend
6

Load environment variables and initialize Composio

const OPENAI_API_KEY = process.env.OPENAI_API_KEY;
const COMPOSIO_API_KEY = process.env.COMPOSIO_API_KEY;
const COMPOSIO_USER_ID = process.env.COMPOSIO_USER_ID;

if (!OPENAI_API_KEY) throw new Error("OPENAI_API_KEY is not set");
if (!COMPOSIO_API_KEY) throw new Error("COMPOSIO_API_KEY is not set");
if (!COMPOSIO_USER_ID) throw new Error("COMPOSIO_USER_ID is not set");

What's happening:

This ensures missing credentials cause early, clear errors before the agent attempts to initialise.

7

Create a Tool Router session and build the agent function

async function buildAgent() {

  console.log(`Initializing Composio client...${COMPOSIO_USER_ID!}...`);
  console.log(`COMPOSIO_USER_ID: ${COMPOSIO_USER_ID!}...`);

  const composio = new Composio({
    apiKey: COMPOSIO_API_KEY,
    provider: new LlamaindexProvider(),
  });

  const session = await composio.create(
    COMPOSIO_USER_ID!,
    {
      toolkits: ["microsoft_teams"],
    },
  );

  const mcpUrl = session.mcp.url;
  console.log(`Composio Tool Router MCP URL: ${mcpUrl}`);

  const server = mcp({
    url: mcpUrl,
    clientName: "composio_tool_router_with_llamaindex",
    requestInit: {
      headers: {
        "x-api-key": COMPOSIO_API_KEY!,
      },
    },
    // verbose: true,
  });

  const tools = await server.tools();

  const llm = openai({ apiKey: OPENAI_API_KEY, model: "gpt-5" });

  const agent = createAgent({
    name: "composio_tool_router_with_llamaindex",
        description : "An agent that uses Composio Tool Router MCP tools to perform actions.",
    systemPrompt:
      "You are a helpful assistant connected to Composio Tool Router."+
"Use the available tools to answer user queries and perform Microsoft teams actions." ,
    llm,
    tools,
  });

  return agent;
}

What's happening here:

  • We create a Composio client using your API key and configure it with the LlamaIndex provider
  • We then create a tool router MCP session for your user, specifying the toolkits we want to use (in this case, microsoft teams)
  • The session returns an MCP HTTP endpoint URL that acts as a gateway to all your configured tools
  • LlamaIndex will connect to this endpoint to dynamically discover and use the available Microsoft teams tools.
  • The MCP tools are mapped to LlamaIndex-compatible tools and plug them into the Agent.
8

Create an interactive chat loop

async function chatLoop(agent: ReturnType<typeof createAgent>) {
  const rl = readline.createInterface({ input, output });

  console.log("Type 'quit' or 'exit' to stop.");

  while (true) {
    let userInput: string;

    try {
      userInput = (await rl.question("\nYou: ")).trim();
    } catch {
      console.log("\nAgent: Bye!");
      break;
    }

    if (!userInput) {
      continue;
    }

    const lower = userInput.toLowerCase();
    if (lower === "quit" || lower === "exit") {
      console.log("Agent: Bye!");
      break;
    }

    try {
      process.stdout.write("Agent: ");

      const stream = agent.runStream(userInput);
      let finalResult: any = null;

      for await (const event of stream) {
        // The event.data contains the streamed content
        const data: any = event.data;

        // Check for streaming delta content
        if (data?.delta) {
          process.stdout.write(data.delta);
        }

        // Store final result for fallback
        if (data?.result || data?.message) {
          finalResult = data;
        }
      }

      // If no streaming happened, show the final result
      if (finalResult) {
        const answer =
          finalResult.result ??
          finalResult.message?.content ??
          finalResult.message ??
          "";
        if (answer && typeof answer === "string" && !answer.includes("[object")) {
          process.stdout.write(answer);
        }
      }

      console.log(); // New line after streaming completes
    } catch (err: any) {
      console.error("\nAgent error:", err?.message ?? err);
    }
  }

  rl.close();
}

What's happening:

  • We're creating a direct terminal interface to chat with Microsoft teams
  • The LLM's responses are streamed to the CLI for faster interaction.
  • The agent uses context to maintain conversation history
  • The agent processes the request, selects appropriate Microsoft teams tools, and returns a result
  • We extract the answer from the result data structure and display it to the user
  • You can type 'quit' or 'exit' to stop the chat loop gracefully
  • Agent responses and any errors are streamed in a clear, readable format
9

Define the main entry point

async function main() {
  try {
    const agent = await buildAgent();
    await chatLoop(agent);
  } catch (err) {
    console.error("Failed to start agent:", err);
    process.exit(1);
  }
}

main();

What's happening here:

  • We're orchestrating the entire application flow
  • The agent gets built with proper error handling
  • Then we kick off the interactive chat loop so you can start talking to Microsoft teams
10

Run the agent

npx ts-node llamaindex-agent.ts

When prompted, authenticate and authorise your agent with Microsoft teams, then start asking questions.

Complete Code

Here's the complete code to get you started with Microsoft teams and LlamaIndex:

import "dotenv/config";
import readline from "node:readline/promises";
import { stdin as input, stdout as output } from "node:process";

import { Composio } from "@composio/core";
import { LlamaindexProvider } from "@composio/llamaindex";

import { mcp } from "@llamaindex/tools";
import { agent as createAgent } from "@llamaindex/workflow";
import { openai } from "@llamaindex/openai";

dotenv.config();

const OPENAI_API_KEY = process.env.OPENAI_API_KEY;
const COMPOSIO_API_KEY = process.env.COMPOSIO_API_KEY;
const COMPOSIO_USER_ID = process.env.COMPOSIO_USER_ID;

if (!OPENAI_API_KEY) {
    throw new Error("OPENAI_API_KEY is not set in the environment");
  }
if (!COMPOSIO_API_KEY) {
    throw new Error("COMPOSIO_API_KEY is not set in the environment");
  }
if (!COMPOSIO_USER_ID) {
    throw new Error("COMPOSIO_USER_ID is not set in the environment");
  }

async function buildAgent() {

  console.log(`Initializing Composio client...${COMPOSIO_USER_ID!}...`);
  console.log(`COMPOSIO_USER_ID: ${COMPOSIO_USER_ID!}...`);

  const composio = new Composio({
    apiKey: COMPOSIO_API_KEY,
    provider: new LlamaindexProvider(),
  });

  const session = await composio.create(
    COMPOSIO_USER_ID!,
    {
      toolkits: ["microsoft_teams"],
    },
  );

  const mcpUrl = session.mcp.url;
  console.log(`Composio Tool Router MCP URL: ${mcpUrl}`);

  const server = mcp({
    url: mcpUrl,
    clientName: "composio_tool_router_with_llamaindex",
    requestInit: {
      headers: {
        "x-api-key": COMPOSIO_API_KEY!,
      },
    },
    // verbose: true,
  });

  const tools = await server.tools();

  const llm = openai({ apiKey: OPENAI_API_KEY, model: "gpt-5" });

  const agent = createAgent({
    name: "composio_tool_router_with_llamaindex",
    description:
      "An agent that uses Composio Tool Router MCP tools to perform actions.",
    systemPrompt:
      "You are a helpful assistant connected to Composio Tool Router."+
"Use the available tools to answer user queries and perform Microsoft teams actions." ,
    llm,
    tools,
  });

  return agent;
}

async function chatLoop(agent: ReturnType<typeof createAgent>) {
  const rl = readline.createInterface({ input, output });

  console.log("Type 'quit' or 'exit' to stop.");

  while (true) {
    let userInput: string;

    try {
      userInput = (await rl.question("\nYou: ")).trim();
    } catch {
      console.log("\nAgent: Bye!");
      break;
    }

    if (!userInput) {
      continue;
    }

    const lower = userInput.toLowerCase();
    if (lower === "quit" || lower === "exit") {
      console.log("Agent: Bye!");
      break;
    }

    try {
      process.stdout.write("Agent: ");

      const stream = agent.runStream(userInput);
      let finalResult: any = null;

      for await (const event of stream) {
        // The event.data contains the streamed content
        const data: any = event.data;

        // Check for streaming delta content
        if (data?.delta) {
          process.stdout.write(data.delta);
        }

        // Store final result for fallback
        if (data?.result || data?.message) {
          finalResult = data;
        }
      }

      // If no streaming happened, show the final result
      if (finalResult) {
        const answer =
          finalResult.result ??
          finalResult.message?.content ??
          finalResult.message ??
          "";
        if (answer && typeof answer === "string" && !answer.includes("[object")) {
          process.stdout.write(answer);
        }
      }

      console.log(); // New line after streaming completes
    } catch (err: any) {
      console.error("\nAgent error:", err?.message ?? err);
    }
  }

  rl.close();
}

async function main() {
  try {
    const agent = await buildAgent();
    await chatLoop(agent);
  } catch (err: any) {
    console.error("Failed to start agent:", err?.message ?? err);
    process.exit(1);
  }
}

main();

Conclusion

You've successfully connected Microsoft teams to LlamaIndex through Composio's Tool Router MCP layer. Key takeaways:
  • Tool Router dynamically exposes Microsoft teams tools through an MCP endpoint
  • LlamaIndex's ReActAgent handles reasoning and orchestration; Composio handles integrations
  • The agent becomes more capable without increasing prompt size
  • Async Python provides clean, efficient execution of agent workflows
You can easily extend this to other toolkits like Gmail, Notion, Stripe, GitHub, and more by adding them to the toolkits parameter.
TOOLS

Supported Tools

Every Microsoft teams action and event your agent gets out of the box.

Add chat member

Tool to add a conversationMember to a Microsoft Teams chat.

Add tab to channel

Tool to add a new tab to a Microsoft Teams channel.

Add member to team

Tool to add a user to a Microsoft Teams team.

Add team members (bulk)

Tool to add multiple members to a Microsoft Teams team in a single operation.

Archive channel

Tool to archive a channel in a Microsoft Teams team.

Archive team channel

Tool to archive a channel in a Microsoft Teams team using the group ID.

Archive Teams team

Tool to archive a Microsoft Teams team.

Get all chats

Retrieves all Microsoft Teams chats a specified user is part of, supporting filtering, property selection, and pagination.

Clear Automatic Location

Tool to clear the automatic location from a user's presence in Microsoft Teams.

Clear User Preferred Presence

Tool to clear a user's preferred presence setting in Microsoft Teams.

Clear Presence

Tool to clear the presence information for a user's application presence session in Microsoft Teams.

Clear Presence Location

Tool to clear the authenticated user's presence location.

Clone Team

Tool to clone a Microsoft Teams team using the team ID.

Create Call Operation

Tool to create a new operation for a communications call.

Create a channel

Tool to create a new standard, private, or shared channel within a Microsoft Teams team.

Create Content Sharing Session

Tool to create a content sharing session in a Microsoft Teams call.

Create channel in group team

Tool to create a new channel in a group's associated team.

Create online meeting

Use to schedule a new standalone Microsoft Teams online meeting, i.

Create user offer shift request

Tool to create a new offer shift request in a user's joined team schedule.

Create open shifts

Tool to create a new open shift in a Microsoft Teams team schedule.

Create open shift change request

Tool to create a new open shift change request in a team schedule.

Create or get online meeting

Tool to create a new Microsoft Teams online meeting or retrieve an existing one based on externalId.

Create or update schedule

Tool to create or replace a schedule object for a Microsoft Teams team.

Create schedule day note

Tool to create a new day note in a team's schedule.

Create scheduling group

Tool to create a new scheduling group in a team's schedule.

Create team schedule shift

Tool to create a new shift in a Microsoft Teams team schedule.

Create Team

Tool to create a new Microsoft Teams team.

Create Team From Group

Tool to create a new team under an existing Microsoft 365 group.

Create time off

Tool to create a new timeOff instance in a team's schedule.

Create time off reason

Tool to create a new time off reason in a team's schedule.

Create time off request

Tool to create a new time off request in a team's schedule.

Create user online meeting

Tool to create a new Microsoft Teams online meeting for a specific user.

Delete Call Operation

Tool to delete a navigation property operation for a communications call.

Delete team channel

Tool to delete a channel from a Microsoft Teams team.

Delete team schedule day note

Tool to delete a day note from a Microsoft Teams schedule.

Delete open shift

Tool to delete an open shift from a Microsoft Teams schedule.

Delete team scheduling group

Tool to delete a scheduling group from a Microsoft Teams team schedule.

Delete team schedule shift

Tool to delete a shift from a Microsoft Teams team schedule.

Soft-delete Teams channel message

Tool to soft-delete a message in a Teams channel.

Delete channel tab

Tool to delete a tab from a Microsoft Teams channel.

Delete Teams team

Tool to delete a Microsoft Teams team.

Delete time off

Tool to delete a timeOff from a team's schedule.

Delete time off reason

Tool to delete a time off reason from a team's schedule.

Delete time off request

Tool to delete a time off request from a Microsoft Teams team schedule.

Delete User Online Meeting

Tool to delete an online meeting for a user.

Get call operation

Tool to get a specific commsOperation for a call.

Get team channel

Tool to get a specific channel in a team.

Get Teams channel message

Retrieves a specific message from a Microsoft Teams channel using its Team, Channel, and Message IDs.

Get channel message reply

Tool to retrieve a single reply to a message in a channel.

Get chat

Tool to retrieve a single chat by ID.

Get chat member

Tool to get a specific conversation member from a Microsoft Teams chat.

Get chat message

Tool to get a specific chat message.

Get day note

Tool to retrieve a specific day note from a team's schedule.

Get channel files folder

Tool to get the files folder (DriveItem) metadata for a specific channel in a Microsoft Teams team.

Get User Profile

Tool to retrieve a user's profile (id/UPN/mail/displayName).

Get offer shift request

Tool to get a specific offer shift request from a Microsoft Teams schedule.

Get online meeting

Tool to retrieve details of a specific Microsoft Teams online meeting by its ID.

Get open shift

Tool to get a specific open shift from a Microsoft Teams schedule.

Get open shift change request

Tool to retrieve a specific open shift change request from a Microsoft Teams team's schedule.

Get User Presence

Tool to get a specific user's presence information.

Get primary channel

Tool to get the default (General) channel of a team.

Get schedule

Tool to retrieve the properties and relationships of a schedule object.

Get scheduling group

Tool to retrieve a specific scheduling group from a Microsoft Teams team's schedule.

Get shift

Tool to retrieve a shift by ID from a Microsoft Teams team schedule.

Get swap shifts change request

Tool to get a specific swap shift change request from a Microsoft Teams schedule.

Get channel tab

Tool to get a specific tab in a Microsoft Teams channel.

Get Team

Tool to get a specific team.

Get team member

Tool to get a specific conversation member from a team.

Get Team Operation Status

Tool to retrieve the status of a Teams async operation using teamId and operationId.

Get installed app in team

Tool to get an installed app in a Microsoft Teams team.

Get time off by ID

Tool to retrieve a specific time off entry from a Microsoft Teams team's schedule by ID.

Get time off reason

Tool to get a specific time off reason from a team's schedule.

Get time off request

Tool to retrieve a specific time off request from a team's schedule.

Get user chat

Tool to retrieve a specific chat for a user.

Get User Teamwork

Tool to get userTeamwork settings for a specified user, including Microsoft Teams region and locale.

Hide chat for user

Tool to hide a Microsoft Teams chat for a specific user.

List user's associated teams

Tool to list teams that a user is associated with in Microsoft Teams.

List channel tabs

Tool to list tabs from a Microsoft Teams channel.

List Communications Call Operations

Tool to list operations on a Microsoft Teams call.

List deleted teams

Tool to list deleted Microsoft Teams and their properties.

List Group Team Operations

Tool to list operations on a group's team.

List team incoming channels

Tool to list incoming channels shared with a Microsoft Teams team.

List installed apps in team

Tool to list apps installed in a Microsoft Teams team.

List channel message replies

Tool to list all replies to a specific message in a Microsoft Teams channel.

List offer shift requests

Tool to list offer shift requests in a Microsoft Teams schedule.

List user online meetings

Look up a Microsoft Teams online meeting for a user by identifier.

List open shift change requests

Tool to list open shift change requests in a Microsoft Teams schedule.

List open shifts

Tool to list open shifts in a Microsoft Teams schedule.

List People

Retrieves a list of people relevant to a specified user from Microsoft Graph, noting the `search` parameter is only effective if `user_id` is 'me'.

List pinned messages

Tool to retrieve the list of pinned messages in a Microsoft Teams chat.

List team schedule day notes

Tool to list all dayNotes from a team's schedule.

List scheduling groups

Tool to list scheduling groups in a team's schedule.

List shifts

Tool to list shifts in a Microsoft Teams schedule.

List swap shifts change requests

Tool to list swap shift change requests in a Microsoft Teams schedule.

List team members

Tool to list members of a Microsoft Teams team.

List Team Operations

Tool to list operations from a team.

List teams permission grants

Tool to list all resource-specific permission grants for a team with support for filtering, pagination, and sorting.

List team time off entries

Tool to list time off entries from a Microsoft Teams team's schedule.

List team schedule time off reasons

Tool to get time off reasons from a team's schedule.

List time off requests

Tool to retrieve a list of time off requests from a Microsoft Teams team's schedule.

List user's chat members

Tool to list members of a specific chat for a user in Microsoft Teams.

List user chat messages

Tool to retrieve messages from a specific chat for a given user.

List user joined teams

Tool to list the Teams that a specified user is a direct member of (joined teams).

List users

Tool to list all users in the organization.

Mark chat as read for user

Tool to mark a chat as read for a specific user in Microsoft Teams.

Mark chat as unread for user

Marks a specific chat as unread for a user by setting the last read message timestamp.

Pin message in chat

Tool to pin a message in a Microsoft Teams chat.

Reply to Teams channel message

Sends a reply to an existing message, identified by `message_id`, within a specific `channel_id` of a given `team_id` in Microsoft Teams.

Provision channel email address

Tool to provision an email address for a Microsoft Teams channel.

Remove channel email address

Tool to remove the email address of a channel in Microsoft Teams.

Remove chat member

Tool to remove a member from a Microsoft Teams chat.

Remove team member

Tool to remove a member from a Microsoft Teams team.

Remove team members

Tool to remove multiple members from a Microsoft Teams team in bulk.

Search Teams files

Search files in Microsoft Teams using KQL syntax.

Search Teams messages

Search Microsoft Teams messages using powerful KQL syntax.

Send Activity Notification to Recipients

Tool to send activity notifications to specified recipients in Microsoft Teams.

Set Presence

Tool to set the presence information for a user's application presence session.

Set Presence Automatic Location

Tool to set the automatic presence location (office/remote/timeOff) for a specified user.

Set User Preferred Presence

Tool to set the preferred availability and activity status for a user.

Set User Presence Manual Location

Tool to set the manual presence location (office/remote/timeOff) for a specific user.

Share Team Schedule

Tool to share a Microsoft Teams schedule for a specified time range.

Create Chat

Creates a new chat; if a 'oneOnOne' chat with the specified members already exists, its details are returned, while 'group' chats are always newly created.

List Teams

Retrieves Microsoft Teams accessible by the authenticated user, allowing filtering, property selection, and pagination.

List channel messages

Tool to list messages in a Teams channel when team_id and channel_id are known (no chat_id required).

List team channels

Retrieves channels for a specified Microsoft Teams team ID (must be valid and for an existing team), with options to include shared channels, filter results, and select properties.

Send Channel Message

Posts a new top-level message to a channel in Microsoft Teams (does NOT reply to an existing message).

Send message to Teams chat

Sends a non-empty message (text or HTML) to a specified, existing Microsoft Teams chat; content must be valid HTML if `content_type` is 'html'.

Unarchive channel

Tool to unarchive a channel in a Microsoft Teams team.

Unarchive group team channel

Tool to unarchive a channel in a Microsoft Teams group's team.

Unarchive Teams team

Tool to unarchive a Microsoft Teams team.

Unhide Chat For User

Tool to unhide a chat for a specific user.

Unpin chat message

Tool to unpin a message from a Microsoft Teams chat.

Update Call

Tool to update the navigation property calls in Microsoft Teams communications.

Update Call Operation

Tool to update the navigation property operations in communications.

Update Call Participant

Tool to update a participant in a Microsoft Teams call.

Update Teams channel

Tool to update channel properties in a Microsoft Teams group.

Update Teams channel message

Tool to update a message in a channel.

Update Chat

Tool to update the properties of a chat.

Update Teams chat message

Tool to update a specific message in a chat.

Update Content Sharing Session

Tool to update a content sharing session in a Microsoft Teams call.

Update schedule day note

Tool to update an existing day note in a team's schedule.

Update online meeting

Tool to update the properties of an existing Microsoft Teams online meeting.

Update open shift

Tool to update an existing open shift in a Microsoft Teams team schedule.

Update scheduling group

Tool to replace/update a scheduling group in a team's schedule.

Update Teams channel tab

Tool to update the properties of a tab in a Microsoft Teams channel.

Update Team

Tool to update the properties of a team.

Update team member

Tool to update a team member's roles or properties in Microsoft Teams.

Update team schedule shift

Tool to update an existing shift in a Microsoft Teams team schedule.

Update time off

Tool to replace an existing timeOff entry in a team's schedule.

Update time off reason

Tool to update a time off reason in a team's schedule.

FAQ

Frequently asked questions

With a standalone Microsoft teams MCP server, the agents and LLMs can only access a fixed set of Microsoft teams tools tied to that server. However, with the Composio Tool Router, agents can dynamically load tools from Microsoft teams and many other apps based on the task at hand, all through a single MCP endpoint.

Yes, you can. LlamaIndex fully supports MCP integration. You get structured tool calling, message history handling, and model orchestration while Tool Router takes care of discovering and serving the right Microsoft teams tools.

Yes, absolutely. You can configure which Microsoft teams scopes and actions are allowed when connecting your account to Composio. You can also bring your own OAuth credentials or API configuration so you keep full control over what the agent can do.

All sensitive data such as tokens, keys, and configuration is fully encrypted at rest and in transit. Composio is SOC 2 Type 2 compliant and follows strict security practices so your Microsoft teams data and credentials are handled as safely as possible.

Start with Microsoft teams.It takes 30 seconds.

Managed auth, hosted MCP servers, and every Microsoft teams tool your agent needs.Free to start.

Start building