Apify MCP for AI Agents

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Apify MCP or direct API to launch Actors, monitor task status, manage datasets, and automate web data collection through natural language.
Trusted by
AWS
Glean
Zoom
Airtable

30 min · no commitment · see it on your stack

Apify Logo
Gradient Top
Gradient Middle
Gradient Bottom
divider

Try Apify now

Enter a prompt below to test the integration in our Tool Router playground. You'll be redirected to sign in and try it live.

Supported Tools

Tools
Build ActorTool to build an Actor with specified configuration.
Abort Actor BuildTool to abort an Actor build that is starting or running.
Delete Actor BuildTool to delete an Actor build permanently.
Get Actor BuildTool to get detailed information about a specific Actor build.
Get Actor Build LogTool to retrieve the log file for a specific Actor build.
Get user builds listTool to get a paginated list of all builds for a user.
Abort Actor RunTool to abort a running or starting Actor run.
Delete Actor RunTool to delete a finished Actor run.
Get Actor RunTool to get details about a specific Actor run.
Update Actor Run Status MessageTool to update the status message of an Actor run.
Delete Actor TaskTool to delete an Actor task permanently.
Get Actor TaskTool to get complete details about an Actor task.
Update Actor TaskTool to update Actor task settings using JSON payload.
Get last actor task runTool to get the most recent run of a specific Actor task.
Run Task Sync (GET)Tool to run a specific task synchronously and return its output.
Run Task Sync & Get Dataset ItemsTool to run an actor task synchronously and retrieve its dataset items.
Run Task Sync with Input Override & Get Dataset ItemsTool to run an actor task synchronously with input overrides and retrieve its dataset items.
Run Task Sync (POST)Tool to run an Actor task synchronously with input override and return its output.
Update ActorTool to update Actor settings using JSON payload.
Get last actor runTool to get the most recent run of a specific Actor.
Run Actor Sync without Input (GET)Tool to run a specific Actor synchronously without input and return its output.
Run Actor Sync & Get Dataset ItemsTool to run Actor synchronously and get dataset items.
Get list of ActorsTool to get the list of all Actors that the user created or used.
Delete Actor VersionTool to delete a specific version of an Actor's source code.
Delete Actor Version Environment VariableTool to delete an environment variable from a specific Actor version.
Get Actor Version Environment VariableTool to get environment variable details for a specific Actor version.
Update Actor Version Environment VariableTool to update environment variable for a specific Actor version using JSON payload.
Get list of Actor version environment variablesTool to get the list of environment variables for a specific Actor version.
Create Actor Version Environment VariableTool to create an environment variable for a specific Actor version.
Get Actor versionTool to get details about a specific version of an Actor.
Update Actor VersionTool to update an Actor version's configuration and source code.
Get list of Actor versionsTool to get the list of versions of a specific Actor.
Create Actor VersionTool to create a new version of an Actor.
Get list of Actor webhooksTool to get a list of webhooks for a specific Actor.
Create ActorTool to create a new Actor with specified configuration.
Create DatasetTool to create a new dataset.
Create Actor TaskTool to create a new Actor task with specified settings.
Create Task WebhookTool to create a webhook for an Actor task.
Delete DatasetTool to delete a dataset permanently.
Get DatasetTool to retrieve dataset metadata by dataset ID.
Update DatasetTool to update a dataset's name via JSON payload.
Get list of datasetsTool to get list of datasets for a user.
Get Dataset StatisticsTool to get dataset field statistics by dataset ID.
Delete ActorTool to delete an Actor permanently.
Delete WebhookTool to delete a webhook by its ID.
Get Actor DetailsTool to get details of a specific Actor.
Get Actor Last Run Dataset ItemsTool to get dataset items from the last run of an Actor.
Get all webhooksTool to get a list of all webhooks created by the user.
Get dataset itemsTool to retrieve items from a dataset.
Get Default BuildTool to get the default build for an Actor.
Get Key-Value RecordTool to retrieve a record from a key-value store.
Get list of buildsTool to get a list of builds for a specific Actor.
Get list of runsTool to get a list of runs for a specific Actor.
Get list of task runsTool to get a list of runs for a specific Actor task.
Get list of tasksTool to fetch a paginated list of tasks belonging to the authenticated user.
Get list of task webhooksTool to get a list of webhooks for a specific Actor task.
Get logTool to retrieve logs for a specific Actor run or build.
Get OpenAPI DefinitionTool to get the OpenAPI definition for a specific Actor build.
Get Run Dataset ItemsTool to get dataset items from a specific Actor run.
Get Task InputTool to retrieve the input configuration of a specific task.
Get Task Last Run Dataset ItemsTool to get dataset items from the last run of an Actor task.
Delete Key-Value StoreTool to delete a key-value store permanently.
Get Key-Value StoreTool to retrieve key-value store metadata by store ID.
Get Key-Value Store KeysTool to retrieve a list of keys from a key-value store.
Delete Key-Value Store RecordTool to delete a record from a key-value store.
Check Key-Value Store Record ExistsTool to check if a record exists in a key-value store.
Get list of key-value storesTool to get the list of key-value stores owned by the user.
Create Key-Value StoreTool to create a new key-value store or retrieve an existing one by name.
List User Actor RunsTool to get a paginated list of all Actor runs for the authenticated user.
Delete Request QueueTool to delete a request queue permanently.
Get Request QueueTool to retrieve request queue metadata by queue ID.
Get Request Queue HeadTool to retrieve first requests from the queue for inspection.
Get Head and Lock Queue RequestsTool to get and lock head requests from the queue.
Update Request QueueTool to update request queue name using JSON payload.
Delete Request from QueueTool to delete a specific request from a request queue.
Get Request from QueueTool to retrieve a specific request from a request queue by its ID.
Delete Request LockTool to delete a request lock from a request queue.
Prolong Request LockTool to prolong request lock in a request queue.
Update Request in QueueTool to update a request in a request queue.
Batch Delete Requests from QueueTool to batch-delete up to 25 requests from a queue.
Batch Add Requests to QueueTool to batch-add up to 25 requests to a request queue.
List Request Queue RequestsTool to list requests in a request queue with pagination support.
Add Request to QueueTool to add a request to the queue.
Unlock Queue RequestsTool to unlock requests in a request queue that are currently locked by the client.
Get list of request queuesTool to get list of request queues for a user.
Create Request QueueTool to create a new request queue or retrieve an existing one by name.
Run Actor AsynchronouslyTool to run a specific Actor asynchronously.
Run Actor SyncTool to run a specific Actor synchronously with input and return its output record.
Run Actor Sync & Get Dataset ItemsTool to run an Actor synchronously and retrieve its dataset items.
Run Task AsynchronouslyTool to run a specific Actor task asynchronously.
Delete ScheduleTool to delete a schedule by its ID.
Get ScheduleTool to get schedule details by ID.
Get Schedule LogTool to get schedule log by ID.
Update ScheduleTool to update an existing schedule with new settings.
Get list of schedulesTool to get list of schedules created by the user.
Create ScheduleTool to create a new schedule with specified settings.
Store Data in DatasetTool to store data items in a dataset.
Store Data in Key-Value StoreTool to create or update a record in a key-value store.
Get list of Actors in StoreTool to get list of public Actors from Apify Store.
Update Key-Value StoreTool to update a key-value store's properties.
Update Task InputTool to update the input configuration of a specific Actor task.
Get Public User DataTool to get public user data.
Get Current User Account DataTool to get private user account information.
Get Account LimitsTool to get a complete summary of account limits and usage.
Update Account LimitsTool to update account limits manageable on the Limits page.
Get Monthly UsageTool to get monthly usage summary with daily breakdown.
Get list of webhook dispatchesTool to get list of webhook dispatches for the user.
Get Webhook DispatchTool to get webhook dispatch object with all details.
Get webhookTool to get webhook object with all details.
Update WebhookTool to update webhook using JSON payload.
Test WebhookTool to test a webhook by creating a test dispatch with a dummy payload.
Get webhook dispatchesTool to get list of webhook dispatches for a specific webhook.
Python
TypeScript

Install Composio

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

Create 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
Initialize the Composio client and create a Tool Router session

Connect to 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 Apify tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Get dataset items from my latest Apify dataset')
        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())
Use the MCP server with your AI agent

Why Use Composio?

AI Native Apify Integration

  • Supports both Apify MCP and direct API based integrations
  • Structured, LLM-friendly schemas for reliable tool execution
  • Rich coverage for launching Actors, fetching run results, and managing datasets

Managed Auth

  • Built-in API key management for secure and easy integration
  • Central place to manage, scope, and revoke Apify access
  • Per user and per environment credentials instead of hard-coded keys

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

Enterprise Grade Security

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

Frequently Asked Questions

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

Yes, Apify 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.

Is Composio secure?

Composio is SOC 2 and ISO 27001 compliant with all data encrypted in transit and at rest. Learn more.

What if the API changes?

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

Used by agents from

Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai

Never worry about agent reliability

We handle tool reliability, observability, and security so you never have to second-guess an agent action.