# Sendbird

```json
{
  "name": "Sendbird",
  "slug": "sendbird",
  "url": "https://composio.dev/toolkits/sendbird",
  "markdown_url": "https://composio.dev/toolkits/sendbird.md",
  "logo_url": "https://logos.composio.dev/api/sendbird",
  "categories": [
    "collaboration & communication"
  ],
  "is_composio_managed": false,
  "updated_at": "2026-05-12T10:25:12.638Z"
}
```

![Sendbird logo](https://logos.composio.dev/api/sendbird)

## Description

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Sendbird MCP or direct API to send messages, manage channels, fetch conversations, and moderate chats through natural language.

## Summary

Sendbird is a developer platform for adding chat, voice, and video to apps. It helps businesses deliver real-time, in-app communication experiences.

## Categories

- collaboration & communication

## Toolkit Details

- Tools: 37

## Images

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

## Authentication

- **Api Key**
  - Type: `api_key`
  - Description: Api Key authentication for Sendbird.
  - Setup:
    - Configure Api Key credentials for Sendbird.
    - Use the credentials when creating an auth config in Composio.

## Suggested Prompts

- Add users to a group chat channel
- Ban a disruptive user from group chat
- Get unread message count for a user
- Create a new group channel with members

## Supported Tools

| Tool slug | Name | Description |
|---|---|---|
| `SENDBIRD_ADD_MEMBERS_GROUP_CHANNEL` | Add Members To Group Channel | Tool to add members to a group channel. Use when you need to invite one or more users into an existing group channel. |
| `SENDBIRD_BAN_USER_FROM_GROUP_CHANNEL` | Ban User from Group Channel | Tool to ban a user from a group channel. Use when moderating group channels to restrict member access. Execute after confirming channel_url and user_id. |
| `SENDBIRD_CREATE_CHANNEL` | Create Group Channel | Tool to create a new group channel. Use when you need to start a conversation with specific users. Execute after specifying users and optional settings. |
| `SENDBIRD_CREATE_USER` | Create Sendbird User | Creates a new user in Sendbird. Use this to register user accounts before they can join channels or send messages. The user_id must be unique across the application. |
| `SENDBIRD_DELETE_CHANNEL` | Delete Group Channel | Permanently deletes a Sendbird group channel. Use this tool when you need to remove a group channel and all its associated data (messages, members, etc.). WARNING: This action is irreversible. Requires the channel_url identifier of the channel to delete. |
| `SENDBIRD_DELETE_MESSAGE` | Delete Message | Permanently deletes a specific message from a Sendbird group channel. This action cannot be undone. Use this when you need to remove a message that was sent by mistake or contains inappropriate content. Requires both channel_url and message_id, which can be obtained from channel/message listing endpoints. |
| `SENDBIRD_DELETE_USER` | Delete Sendbird User | Tool to delete a Sendbird user. Use when you need to remove a user from your Sendbird application, optionally permanently. |
| `SENDBIRD_GET_COUNT_PREFERENCE_OF_CHANNEL` | Get Count Preference Of Channel | Tool to retrieve a user's count preference for a specific group channel. Use after confirming the user and channel exist to determine whether to display all, unread-only, or mention-only counts. |
| `SENDBIRD_GET_NUMBER_OF_CHANNELS_BY_JOIN_STATUS` | Get User Group Channel Count by Join Status | Retrieves the number of group channels for a user, categorized by join status (joined, invited, etc.). Use this tool to get channel count statistics for a specific user, optionally filtered by channel properties like visibility (public/private), distinctness, or super mode. Returns counts of joined channels, invited channels (with friend/non-friend breakdown), and total count. |
| `SENDBIRD_GET_NUMBER_OF_UNREAD_ITEMS` | Sendbird Get Unread Item Count | Tool to retrieve a user's unread item counts including unread messages, mentions, and pending invitations across group channels. Use this to display unread counts in the UI for a specific user. |
| `SENDBIRD_ISSUE_SESSION_TOKEN` | Issue Session Token | Issues a session token for authenticating a Sendbird user. Use this tool when you need to: - Generate a new session token for SDK authentication - Refresh an expiring or expired session token - Provide secure access for a user to connect to Sendbird chat The session token has a default expiration of 7 days if expires_at is not specified. |
| `SENDBIRD_LEAVE_GROUP_CHANNELS` | Leave Group Channels | Tool to leave group channels for a user. Use when you need to make a user exit one or more joined group channels. |
| `SENDBIRD_LIST_BANNED_MEMBERS` | List Banned Members | Tool to list banned members in a group channel. Use when you need to see which users are banned from a specific group channel. |
| `SENDBIRD_LIST_GROUP_CHANNEL_MESSAGES` | Sendbird List Group Channel Messages | Tool to list (paginate) messages in a group channel when you only know the channel_url. Requires either message_ts (Unix ms timestamp) or message_id as an anchor. Use with SENDBIRD_VIEW_GROUP_CHANNEL (show_read_receipt=true) to fetch unread messages: get last-read timestamp, then call this with message_ts=, prev_limit=0, next_limit=, include=false. |
| `SENDBIRD_LIST_GROUP_CHANNELS` | List Group Channels | Tool to list group channels. Use when you need to fetch paginated group channels with optional filters. |
| `SENDBIRD_LIST_MEMBERS_GROUP_CHANNEL` | List Group Channel Members | Tool to list members of a group channel. Use when you need to paginate through members of a specified group channel. |
| `SENDBIRD_LIST_OPERATORS_CUSTOM_CHANNEL_TYPE` | List Operators by Custom Channel Type | Tool to list operators of a channel by custom channel type. Use when you need to fetch operators for a specific custom channel type with pagination. |
| `SENDBIRD_LIST_OPERATORS_GROUP_CHANNEL` | List Group Channel Operators | Tool to list operators of a group channel. Use after specifying the channel_url when needing to paginate through operators. |
| `SENDBIRD_LIST_OPERATORS_OPEN_CHANNEL` | List Open Channel Operators | Tool to list operators of an open channel. Use when you have the open channel URL and need to fetch its operators. Supports pagination via token and limit. |
| `SENDBIRD_LIST_USERS` | List Sendbird Users | Retrieves a paginated list of users from your Sendbird application. Use this tool to: - Browse all users in your application - Search for users by nickname or user IDs - Filter users by metadata, custom type, or activity status - Paginate through large user lists using the 'next' token Returns user details including profile info, connection status, and metadata. Results are paginated; use the 'next' token from the response to fetch additional pages. |
| `SENDBIRD_MARK_ALL_USER_MESSAGES_AS_READ` | Mark All User Messages As Read | Tool to mark all of a user's messages as read in group channels. Use when resetting unread message counts after a user has viewed all messages. |
| `SENDBIRD_MUTE_USER` | Mute User | Tool to mute a user in a group channel. Use when you need to prevent a user from sending messages for a specified duration. |
| `SENDBIRD_REGISTER_OPERATORS_CUSTOM_CHANNEL_TYPE` | Register Operators by Custom Channel Type | Registers one or more users as operators for all channels with a specified custom channel type. Use this tool when you need to grant operator privileges to users across all channels that share the same custom_type. Operators have elevated permissions including: - Muting and banning users from channels - Deleting messages in channels - Freezing/unfreezing channels - Managing channel settings Prerequisites: - The user IDs must belong to existing Sendbird users - The custom_type should match channels you want to manage Note: This affects all channels with the specified custom_type, not just a single channel. |
| `SENDBIRD_REGISTER_OPERATORS_GROUP_CHANNEL` | Register Group Channel Operators | Tool to register one or more users as operators in a Sendbird group channel. Use when elevating permissions of existing channel members. |
| `SENDBIRD_REGISTER_OPERATORS_OPEN_CHANNEL` | Register Operators to Open Channel | Tool to register operators to an open channel. Use after creating or updating an open channel when you need to assign operator roles. |
| `SENDBIRD_REVOKE_ALL_SESSION_TOKENS` | Revoke All Session Tokens | Tool to revoke all session tokens for a user. Use when you need to invalidate all active sessions for security. |
| `SENDBIRD_SEND_MESSAGE` | Send Message | Tool to send a message to a group channel. Use when you need to post a text, file, or admin message to an existing group channel. |
| `SENDBIRD_UNBAN_USER` | Unban User from Group Channel | Tool to unban a user from a group channel. Use when reinstating a previously banned user. Execute after confirming the user is currently banned. |
| `SENDBIRD_UNMUTE_USER` | Unmute User | Tool to unmute a user in a group channel. Use when you want to restore a muted user's ability to send messages after confirming they are muted. |
| `SENDBIRD_UNREGISTER_OPERATORS_CUSTOM_CHANNEL_TYPE` | Unregister Operators Custom Channel Type | Tool to unregister operators from channels by custom channel type. Use when you need to remove operator roles from users across channels of a specific custom type. |
| `SENDBIRD_UPDATE_COUNT_PREFERENCE_OF_CHANNEL` | Update Count Preference Of Channel | Tool to update a user's unread count preference for a specific group channel. Use when you want to include or suppress a channel in the user's unread counts. |
| `SENDBIRD_UPDATE_GROUP_CHANNEL` | Update Group Channel | Tool to update group channel information. Use when you need to modify channel attributes such as name, cover image, privacy settings, or operator list after channel creation. |
| `SENDBIRD_UPDATE_MESSAGE` | Sendbird Update Message | Tool to update an existing group channel message in Sendbird. Use after you need to modify content or metadata of a sent message. |
| `SENDBIRD_UPDATE_USER` | Update Sendbird User | Tool to update a user's information. Use when modifying nickname, profile image URL, activation status, or metadata. |
| `SENDBIRD_VIEW_GROUP_CHANNEL` | Sendbird View Group Channel | Tool to view information about a specific group channel. Use when you need channel details after confirming the channel_url. |
| `SENDBIRD_VIEW_MESSAGE` | Sendbird View Message | Tool to view a specific message in a group channel. Use after confirming channel_url and message_id. |
| `SENDBIRD_VIEW_USER` | View User | Tool to retrieve information about a specific Sendbird user. Use when you need to fetch detailed user data by their user ID. |

## 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 Sendbird Tools via Tool Router with Your Agent

Get tools from Tool Router session and execute Sendbird actions with your Agent
```python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'Add new users to the "Project Team" group channel in Sendbird.'
  }]
)
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: 'Add new users to the "Project Team" group channel in Sendbird.'
  }],
});
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 Sendbird tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Add members to group channel "dev-team"')
        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: 'Add members to group channel "dev-team"' }],
  stopWhen: stepCountIs( 5 )
});

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

## Why Use Composio?

### 1. AI Native Sendbird Integration

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

### 2. Managed Auth

- Built-in API key handling with automatic credential rotation
- Central place to manage, scope, and revoke Sendbird 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 Sendbird
- Scoped, least privilege access to Sendbird resources
- Full audit trail of agent actions to support review and compliance

## Use Sendbird with any AI Agent Framework

Choose a framework you want to connect Sendbird with:

- [OpenAI Agents SDK](https://composio.dev/toolkits/sendbird/framework/open-ai-agents-sdk)
- [Claude Agent SDK](https://composio.dev/toolkits/sendbird/framework/claude-agents-sdk)
- [Claude Code](https://composio.dev/toolkits/sendbird/framework/claude-code)
- [Claude Cowork](https://composio.dev/toolkits/sendbird/framework/claude-cowork)
- [Codex](https://composio.dev/toolkits/sendbird/framework/codex)
- [OpenClaw](https://composio.dev/toolkits/sendbird/framework/openclaw)
- [Hermes](https://composio.dev/toolkits/sendbird/framework/hermes-agent)
- [Google ADK](https://composio.dev/toolkits/sendbird/framework/google-adk)
- [LangChain](https://composio.dev/toolkits/sendbird/framework/langchain)
- [Vercel AI SDK](https://composio.dev/toolkits/sendbird/framework/ai-sdk)
- [Mastra AI](https://composio.dev/toolkits/sendbird/framework/mastra-ai)
- [LlamaIndex](https://composio.dev/toolkits/sendbird/framework/llama-index)
- [CrewAI](https://composio.dev/toolkits/sendbird/framework/crew-ai)
- [Pydantic AI](https://composio.dev/toolkits/sendbird/framework/pydantic-ai)
- [AutoGen](https://composio.dev/toolkits/sendbird/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.
- [Microsoft teams](https://composio.dev/toolkits/microsoft_teams) - 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.
- [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.

## Frequently Asked Questions

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

Yes, Sendbird requires you to configure your own API key credentials. Once set up, Composio handles secure credential storage and API request handling for you.

### 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)
