# Microsoft teams

```json
{
  "name": "Microsoft teams",
  "slug": "microsoft_teams",
  "url": "https://composio.dev/toolkits/microsoft_teams",
  "markdown_url": "https://composio.dev/toolkits/microsoft_teams.md",
  "logo_url": "https://logos.composio.dev/api/microsoft_teams",
  "categories": [
    "collaboration & communication"
  ],
  "is_composio_managed": true,
  "updated_at": "2026-05-06T08:20:13.617Z"
}
```

![Microsoft teams logo](https://logos.composio.dev/api/microsoft_teams)

## Description

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Microsoft teams MCP or direct API to send messages, manage channels, schedule meetings, and fetch chat history through natural language.

## Summary

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.

## Categories

- collaboration & communication

## Toolkit Details

- Tools: 28
- Managed auth: Managed by Composio

## Images

- Logo: https://logos.composio.dev/api/microsoft_teams

## Authentication

- **Oauth2**
  - Type: `oauth2`
  - Description: Oauth2 authentication for Microsoft Teams.
  - Setup:
    - Configure Oauth2 credentials for Microsoft Teams.
    - Use the credentials when creating an auth config in Composio.
- **S2s Oauth2**
  - Type: `custom`
  - Description: S2s Oauth2 authentication for Microsoft Teams.
  - Setup:
    - Configure S2s Oauth2 credentials for Microsoft Teams.
    - Use the credentials when creating an auth config in Composio.

## Suggested Prompts

- Add new member to project team
- Schedule an online meeting for sales
- List all chats I’m part of
- Get details for marketing team channel

## Supported Tools

| Tool slug | Name | Description |
|---|---|---|
| `MICROSOFT_TEAMS_ADD_MEMBER_TO_TEAM` | Add member to team | Tool to add a user to a microsoft teams team. use when granting or updating membership for a user. |
| `MICROSOFT_TEAMS_ARCHIVE_TEAM` | Archive Teams team | Tool to archive a microsoft teams team. use after confirming the team id; returns 202 if accepted. |
| `MICROSOFT_TEAMS_CHATS_GET_ALL_CHATS` | Get all chats | Retrieves all microsoft teams chats a specified user is part of, supporting filtering, property selection, and pagination. |
| `MICROSOFT_TEAMS_CHATS_GET_ALL_MESSAGES` | Get all chat messages | Retrieves all messages from a specified microsoft teams chat using the microsoft graph api, automatically handling pagination; ensure `chat id` is valid and odata expressions in `filter` or `select` are correct. |
| `MICROSOFT_TEAMS_CREATE_MEETING` | Create online meeting | Use to schedule a new standalone microsoft teams online meeting, i.e., one not linked to any calendar event. |
| `MICROSOFT_TEAMS_CREATE_TEAM` | Create Team | Tool to create a new microsoft teams team. use when you need to provision a team with optional template, channels, and members. |
| `MICROSOFT_TEAMS_DELETE_TEAM` | Delete Teams team | Tool to delete a microsoft teams team. use after confirming the target team id. |
| `MICROSOFT_TEAMS_GET_CHANNEL` | Get team channel | Tool to get a specific channel in a team. use after obtaining valid team and channel ids to fetch channel details. |
| `MICROSOFT_TEAMS_GET_CHAT_MESSAGE` | Get chat message | Tool to get a specific chat message. use after confirming chat id and message id. |
| `MICROSOFT_TEAMS_GET_TEAM` | Get Team | Tool to get a specific team. use when full details of one team by id are needed. |
| `MICROSOFT_TEAMS_LIST_MESSAGE_REPLIES` | List message replies | Tool to list replies to a channel message. use after obtaining team, channel, and message ids. |
| `MICROSOFT_TEAMS_LIST_TEAM_MEMBERS` | List team members | Tool to list members of a microsoft teams team. use when you need to retrieve the members of a specific team, for auditing or notifications. |
| `MICROSOFT_TEAMS_LIST_TEAMS_TEMPLATES` | List Teams templates | Tool to list available microsoft teams templates. use when retrieving templates for team creation or customization workflows. |
| `MICROSOFT_TEAMS_LIST_USERS` | List users | Tool to list all users in the organization. use when you need to retrieve directory users with filtering, pagination, and field selection. |
| `MICROSOFT_TEAMS_TEAMS_CREATE_CHANNEL` | Create a channel | Creates a new 'standard', 'private', or 'shared' channel within a specified microsoft teams team. |
| `MICROSOFT_TEAMS_TEAMS_CREATE_CHAT` | 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. |
| `MICROSOFT_TEAMS_TEAMS_GET_MESSAGE` | Get Teams message | Retrieves a specific message from a microsoft teams channel using its team, channel, and message ids. |
| `MICROSOFT_TEAMS_TEAMS_LIST` | List Teams | Retrieves microsoft teams accessible by the authenticated user, allowing filtering, property selection, and pagination. |
| `MICROSOFT_TEAMS_TEAMS_LIST_CHANNELS` | 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. |
| `MICROSOFT_TEAMS_TEAMS_LIST_CHAT_MESSAGES` | List chat messages | Retrieves messages (newest first) from an existing and accessible microsoft teams one-on-one chat, group chat, or channel thread, specified by `chat id`. |
| `MICROSOFT_TEAMS_TEAMS_LIST_PEOPLE` | 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'. |
| `MICROSOFT_TEAMS_TEAMS_POST_CHANNEL_MESSAGE` | Post message to Teams channel | Posts a new text or html message to a specified channel in a microsoft teams team. |
| `MICROSOFT_TEAMS_TEAMS_POST_CHAT_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'. |
| `MICROSOFT_TEAMS_TEAMS_POST_MESSAGE_REPLY` | 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. |
| `MICROSOFT_TEAMS_UNARCHIVE_TEAM` | Unarchive Teams team | Tool to unarchive a microsoft teams team. use when you need to restore an archived team to active state. |
| `MICROSOFT_TEAMS_UPDATE_CHANNEL_MESSAGE` | Update Teams channel message | Tool to update a message in a channel. use when you need to modify an existing channel message after confirming channel and message ids. |
| `MICROSOFT_TEAMS_UPDATE_CHAT_MESSAGE` | Update Teams chat message | Tool to update a specific message in a chat. use when you need to correct or modify a sent chat message. |
| `MICROSOFT_TEAMS_UPDATE_TEAM` | Update Team | Tool to update the properties of a team. use when you need to modify team settings such as member, messaging, or fun settings. |

## Supported Triggers

None listed.

## Installation and MCP Setup

### Path 1: SDK Installation

#### Path 1, Step 1: Install Composio

Install the Composio SDK
```python
pip install composio_openai
```

```typescript
npm install @composio/openai
```

#### Path 1, Step 2: Initialize Composio and Create Tool Router Session

Import and initialize Composio client, then create a Tool Router session
```python
from openai import OpenAI
from composio import Composio
from composio_openai import OpenAIResponsesProvider

composio = Composio(provider=OpenAIResponsesProvider())
openai = OpenAI()
session = composio.create(user_id='your-user-id')
```

```typescript
import OpenAI from 'openai';
import { Composio } from '@composio/core';
import { OpenAIResponsesProvider } from '@composio/openai';

const composio = new Composio({
  provider: new OpenAIResponsesProvider(),
});
const openai = new OpenAI({});
const session = await composio.create('your-user-id');
```

#### Path 1, Step 3: Execute Microsoft teams Tools via Tool Router with Your Agent

Get tools from Tool Router session and execute Microsoft teams actions with your Agent
```python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'List all chat messages from the engineering team channel this morning'
  }]
)
result = composio.provider.handle_tool_calls(
  response=response,
  user_id='your-user-id'
)
print(result)
```

```typescript
const tools = session.tools;
const response = await openai.responses.create({
  model: 'gpt-4.1',
  tools: tools,
  input: [{
    role: 'user',
    content: 'List all chat messages from the engineering team channel this morning'
  }],
});
const result = await composio.provider.handleToolCalls(
  'your-user-id',
  response.output
);
console.log(result);
```

### Path 2: MCP Server Setup

#### Path 2, Step 1: Install Composio

Install the Composio SDK and Claude Agent SDK
```python
pip install composio claude-agent-sdk
```

```typescript
npm install @composio/core ai @ai-sdk/openai @ai-sdk/mcp
```

#### Path 2, Step 2: Create Tool Router Session

Initialize the Composio client and create a Tool Router session
```python
from composio import Composio
from claude_agent_sdk import ClaudeSDKClient, ClaudeAgentOptions

composio = Composio(api_key='your-composio-api-key')
session = composio.create(user_id='your-user-id')
url = session.mcp.url
```

```typescript
import { Composio } from '@composio/core';

const composio = new Composio({ apiKey: 'your-api-key' });

console.log("Creating Tool Router session...");
const { mcp } = await composio.create('your-user-id');
console.log(`Tool Router session created: ${mcp.url}`);
```

#### Path 2, Step 3: Connect to AI Agent

Use the MCP server with your AI agent
```python
import asyncio

options = ClaudeAgentOptions(
    permission_mode='bypassPermissions',
    mcp_servers={
        'tool_router': {
            'type': 'http',
            'url': url,
            'headers': {
                'x-api-key': 'your-composio-api-key'
            }
        }
    },
    system_prompt='You are a helpful assistant with access to Microsoft teams tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Create online meeting with project team tomorrow at 2pm')
        async for message in client.receive_response():
            if hasattr(message, 'content'):
                for block in message.content:
                    if hasattr(block, 'text'):
                        print(block.text)

asyncio.run(main())
```

```typescript
import { openai } from '@ai-sdk/openai';
import { experimental_createMCPClient as createMCPClient } from '@ai-sdk/mcp';
import { generateText, stepCountIs } from 'ai';

const client = await createMCPClient({
  transport: {
    type: 'http',
    url: mcp.url,
    headers: { 'x-api-key': 'your-composio-api-key' }
  }
});

const tools = await client.tools();

const { text } = await generateText({
  model: openai('gpt-4o'),
  tools,
  messages: [{ role: 'user', content: 'Create online meeting with project team tomorrow at 2pm' }],
  stopWhen: stepCountIs( 5 )
});

console.log(`Agent: ${text}`);
```

## Why Use Composio?

### 1. AI Native Microsoft teams Integration

- Supports both Microsoft teams MCP and direct API based integrations
- Structured, LLM-friendly schemas for reliable tool execution
- Rich coverage for reading, writing, and querying your Microsoft teams data

### 2. Managed Auth

- Built-in OAuth handling with automatic token refresh and rotation
- Central place to manage, scope, and revoke Microsoft teams access
- Per user and per environment credentials instead of hard-coded keys

### 3. Agent Optimized Design

- Tools are tuned using real error and success rates to improve reliability over time
- Comprehensive execution logs so you always know what ran, when, and on whose behalf

### 4. Enterprise Grade Security

- Fine-grained RBAC so you control which agents and users can access Microsoft teams
- Scoped, least privilege access to Microsoft teams resources
- Full audit trail of agent actions to support review and compliance

## Use Microsoft teams with any AI Agent Framework

Choose a framework you want to connect Microsoft teams with:

- [ChatGPT](https://composio.dev/toolkits/microsoft_teams/framework/chatgpt)
- [OpenAI Agents SDK](https://composio.dev/toolkits/microsoft_teams/framework/open-ai-agents-sdk)
- [Claude Agent SDK](https://composio.dev/toolkits/microsoft_teams/framework/claude-agents-sdk)
- [Claude Code](https://composio.dev/toolkits/microsoft_teams/framework/claude-code)
- [Claude Cowork](https://composio.dev/toolkits/microsoft_teams/framework/claude-cowork)
- [Codex](https://composio.dev/toolkits/microsoft_teams/framework/codex)
- [Cursor](https://composio.dev/toolkits/microsoft_teams/framework/cursor)
- [VS Code](https://composio.dev/toolkits/microsoft_teams/framework/vscode)
- [OpenCode](https://composio.dev/toolkits/microsoft_teams/framework/opencode)
- [OpenClaw](https://composio.dev/toolkits/microsoft_teams/framework/openclaw)
- [Hermes](https://composio.dev/toolkits/microsoft_teams/framework/hermes-agent)
- [CLI](https://composio.dev/toolkits/microsoft_teams/framework/cli)
- [Google ADK](https://composio.dev/toolkits/microsoft_teams/framework/google-adk)
- [LangChain](https://composio.dev/toolkits/microsoft_teams/framework/langchain)
- [Vercel AI SDK](https://composio.dev/toolkits/microsoft_teams/framework/ai-sdk)
- [Mastra AI](https://composio.dev/toolkits/microsoft_teams/framework/mastra-ai)
- [LlamaIndex](https://composio.dev/toolkits/microsoft_teams/framework/llama-index)
- [CrewAI](https://composio.dev/toolkits/microsoft_teams/framework/crew-ai)
- [Pydantic AI](https://composio.dev/toolkits/microsoft_teams/framework/pydantic-ai)
- [AutoGen](https://composio.dev/toolkits/microsoft_teams/framework/autogen)

## Related Toolkits

- [Gmail](https://composio.dev/toolkits/gmail) - Gmail is Google's email service with powerful spam protection, search, and G Suite integration. It keeps your inbox organized and makes communication fast and reliable.
- [Outlook](https://composio.dev/toolkits/outlook) - Outlook is Microsoft's email and calendaring platform for unified communications and scheduling. It helps users stay organized with powerful email, contacts, and calendar management.
- [Slack](https://composio.dev/toolkits/slack) - Slack is a channel-based messaging platform for teams and organizations. It helps people collaborate in real time, share files, and connect all their tools in one place.
- [Gong](https://composio.dev/toolkits/gong) - Gong is a platform for video meetings, call recording, and team collaboration. It helps teams capture conversations, analyze calls, and turn insights into action.
- [Slackbot](https://composio.dev/toolkits/slackbot) - Slackbot is a conversational automation tool for Slack that handles reminders, notifications, and automated responses. It boosts team productivity by streamlining onboarding, answering FAQs, and managing timely alerts—all right inside Slack.
- [2chat](https://composio.dev/toolkits/_2chat) - 2chat is an API platform for WhatsApp and multichannel text messaging. It streamlines chat automation, group management, and real-time messaging for developers.
- [Agent mail](https://composio.dev/toolkits/agent_mail) - Agent mail provides AI agents with dedicated email inboxes for sending, receiving, and managing emails. It empowers agents to communicate autonomously with people, services, and other agents—no human intervention needed.
- [Basecamp](https://composio.dev/toolkits/basecamp) - Basecamp is a project management and team collaboration tool by 37signals. It helps teams organize tasks, share files, and communicate efficiently in one place.
- [Chatwork](https://composio.dev/toolkits/chatwork) - Chatwork is a team communication platform with group chats, file sharing, and task management. It helps businesses boost collaboration and streamline productivity.
- [Clickmeeting](https://composio.dev/toolkits/clickmeeting) - ClickMeeting is a cloud-based platform for running online meetings and webinars. It helps businesses and individuals host, manage, and engage virtual audiences with ease.
- [Confluence](https://composio.dev/toolkits/confluence) - Confluence is Atlassian's team collaboration and knowledge management platform. It helps your team organize, share, and update documents and project content in one secure workspace.
- [Dailybot](https://composio.dev/toolkits/dailybot) - DailyBot streamlines team collaboration with chat-based standups, reminders, and polls. It keeps work flowing smoothly in your favorite messaging platforms.
- [Dialmycalls](https://composio.dev/toolkits/dialmycalls) - Dialmycalls is a mass notification service for sending voice and text messages to contacts. It helps teams and organizations quickly broadcast urgent alerts and updates.
- [Dialpad](https://composio.dev/toolkits/dialpad) - Dialpad is a cloud-based business phone and contact center system for teams. It unifies voice, video, messaging, and meetings across your devices.
- [Discord](https://composio.dev/toolkits/discord) - Discord is a real-time messaging and VoIP platform for communities and teams. It lets users chat, share media, and collaborate across public and private channels.
- [Discordbot](https://composio.dev/toolkits/discordbot) - Discordbot is an automation tool for Discord servers that handles moderation, messaging, and user engagement. It helps communities run smoothly by automating routine and complex tasks.
- [Echtpost](https://composio.dev/toolkits/echtpost) - Echtpost is a secure digital communication platform for encrypted document and message exchange. It ensures confidential data stays private and protected during transmission.
- [Egnyte](https://composio.dev/toolkits/egnyte) - Egnyte is a cloud-based platform for secure file sharing, storage, and governance. It helps teams collaborate efficiently while maintaining data compliance and security.
- [Google Meet](https://composio.dev/toolkits/googlemeet) - Google Meet is a secure video conferencing platform for virtual meetings, chat, and screen sharing. It helps teams connect, collaborate, and communicate seamlessly from anywhere.
- [Heartbeat](https://composio.dev/toolkits/heartbeat) - Heartbeat is a plug-and-play platform for building and managing online communities. It helps you organize users, channels, events, and discussions in one place.

## Frequently Asked Questions

### Do I need my own developer credentials to use Microsoft teams with Composio?

No, you can get started immediately using Composio's built-in Microsoft teams app. For production, we recommend configuring your own OAuth credentials.

### Can I use multiple toolkits together?

Yes! Composio's Tool Router enables agents to use multiple toolkits. [Learn more](https://docs.composio.dev/tool-router/overview).

### Is Composio secure?

Composio is SOC 2 and ISO 27001 compliant with all data encrypted in transit and at rest. [Learn more](https://trust.composio.dev).

### What if the API changes?

Composio maintains and updates all toolkit integrations automatically, so your agents always work with the latest API versions.

---
[See all toolkits](https://composio.dev/toolkits) · [Composio docs](https://docs.composio.dev/llms.txt)
