# Revolt

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

![Revolt logo](https://logos.composio.dev/api/revolt)

## Description

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

## Summary

Revolt is a free, open-source chat platform for secure, customizable group and 1:1 messaging. Enjoy privacy-first conversations and seamless team collaboration without vendor lock-in.

## Categories

- collaboration & communication

## Toolkit Details

- Tools: 26

## Images

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

## Authentication

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

## Suggested Prompts

- Fetch profile details for user by ID
- List all flags assigned to this user
- Update my status message to 'In a meeting'
- Change display name for a specific user

## Supported Tools

| Tool slug | Name | Description |
|---|---|---|
| `REVOLT_ACKNOWLEDGE_POLICY_CHANGES` | Acknowledge Policy Changes | Tool to acknowledge platform policy changes. Use when accepting or confirming policy updates for your bot account. |
| `REVOLT_ADD_CHANNELS_MESSAGES_REACTIONS` | Add Reaction to Message | Tool to add a reaction to a message in a channel. Use when you want to react with an emoji to a specific message. Returns success on completion. |
| `REVOLT_BLOCK_USER` | Block User | Tool to block another user by their ID. Use when you need to prevent interactions with a specific user. |
| `REVOLT_CREATE_SYNC_SETTINGS_SET` | Create Sync Settings | Tool to upload and save settings data to Revolt's sync storage. Use when you need to persist user settings or preferences. |
| `REVOLT_DELETE_MESSAGE` | Delete Message | Tool to delete a message you've sent or one you have permission to delete. Use when you need to remove a message from a channel. |
| `REVOLT_DELETE_MESSAGES_BULK` | Bulk Delete Messages | Tool to bulk delete multiple messages from a channel. Use when you need to delete multiple messages at once. Requires ManageMessages permission regardless of message ownership. Messages must have been sent within the past 1 week. |
| `REVOLT_FETCH_OWNED_BOTS` | Fetch Owned Bots | Tool to fetch all bots that you have control over. Use when you need to retrieve information about bots owned by the authenticated user account. |
| `REVOLT_FETCH_SYNC_SETTINGS` | Fetch Sync Settings | Tool to fetch settings from server filtered by keys. Returns an object with the requested keys where each value is a tuple of (timestamp, value). Only settings that exist on the server will be included in the response. |
| `REVOLT_FETCH_USER` | Fetch user | Tool to fetch detailed information about a user. Use when you have a valid user ID and need full account details. Call after authenticating with bot token. |
| `REVOLT_FETCH_USER_FLAGS` | Fetch User Flags | Tool to fetch flags associated with a specific user. Use after obtaining the user ID to inspect their special statuses or roles. |
| `REVOLT_GET_API_INFO` | Get API Info | Tool to fetch the server configuration for this Revolt instance. Use when you need to discover API version, feature availability, WebSocket endpoints, or service URLs. |
| `REVOLT_GET_CHANNEL` | Get Channel | Tool to fetch a channel by its ID. Use when you need to retrieve detailed information about a specific channel. |
| `REVOLT_GET_CURRENT_USER` | Get Current User | Tool to retrieve your own user information. Use when you need to fetch details about the authenticated user account. |
| `REVOLT_GET_INVITE` | Get Invite | Tool to fetch detailed information about an invite by its code. Use when you have a valid invite code and need to retrieve invite details including server info, channel info, and member count. |
| `REVOLT_GET_SYNC_UNREADS` | Get Sync Unreads | Tool to fetch information about unread state on channels. Use when you need to check which channels have unread messages or mentions. |
| `REVOLT_GET_USER_PROFILE` | Get User Profile | Tool to retrieve a user's profile data including bio and background. Use when you need profile-specific information beyond basic user data. Will fail if you do not have permission to access the target user's profile. |
| `REVOLT_GET_USERS_DEFAULT_AVATAR` | Get User's Default Avatar | Tool to fetch a user's default avatar image based on their ID. Use when you need to retrieve the default avatar picture for a specific user. |
| `REVOLT_GET_USERS_DM` | Open DM with User | Tool to open a DM with another user. Use when you need to start or access a direct message conversation. If the target is oneself, returns a saved messages channel. |
| `REVOLT_GET_USERS_DMS` | Get User DMs | Tool to fetch all direct message conversations for the authenticated user. Use when you need to list all DM and group DM channels. |
| `REVOLT_PIN_MESSAGE` | Pin Message | Tool to pin a message in a channel by its ID. Use when you need to highlight important messages for channel members. |
| `REVOLT_REMOVE_MESSAGE_REACTION` | Remove Message Reaction | Tool to remove a reaction from a message. Use when you need to remove your own, someone else's, or all reactions of a given emoji from a message. Requires ManageMessages permission if removing others' reactions. |
| `REVOLT_SEND_CHANNELS_MESSAGES` | Send Channel Message | Tool to send a message to a Revolt channel. Use when you need to post a text message, embed, or attachment to a specific channel. Call after authenticating with bot token. |
| `REVOLT_UNBLOCK_USER` | Unblock User | Tool to unblock another user by their ID. Use when you need to remove a block on a specific user. The relationship status will change from 'Blocked' to 'None' after successful execution. |
| `REVOLT_UNPIN_MESSAGE` | Unpin Message | Tool to unpin a message in a channel. Use when you need to remove a pinned message from the channel's pinned messages list. |
| `REVOLT_UPDATE_CHANNELS_MESSAGES` | Update Channel Message | Tool to edit a message that you've previously sent in a channel. Use when you need to update the content or embeds of an existing message. At least one of content or embeds must be provided. |
| `REVOLT_UPDATE_USER` | Update User | Tool to update user information. Use when you need to modify user profile or status fields. Call after authenticating with bot token. |

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

Get tools from Tool Router session and execute Revolt actions with your Agent
```python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'Fetch detailed profile for user ID 8df7a2'
  }]
)
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: 'Fetch detailed profile for user ID 8df7a2'
  }],
});
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 Revolt tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Fetch user details for user ID 12345')
        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: 'Fetch user details for user ID 12345' }],
  stopWhen: stepCountIs( 5 )
});

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

## Why Use Composio?

### 1. AI Native Revolt Integration

- Supports both Revolt MCP and direct API based integrations
- Structured, LLM-friendly schemas for reliable tool execution
- Rich coverage for sending, receiving, and managing Revolt messages and channels

### 2. Managed Auth

- Built-in API key management for Revolt with secure storage
- Central place to manage, scope, and revoke Revolt 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 Revolt
- Scoped, least privilege access to Revolt resources
- Full audit trail of agent actions to support review and compliance

## Use Revolt with any AI Agent Framework

Choose a framework you want to connect Revolt with:

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

Yes, Revolt 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)
