Skip to content

apify/actors-mcp-server

Repository files navigation

Apify Model Context Protocol (MCP) Server

Actors MCP Server

Implementation of an MCP server for all Apify Actors. This server enables interaction with one or more Apify Actors that can be defined in the MCP Server configuration.

The server can be used in two ways:

  • πŸ‡¦ Apify MCP Server Actor: runs an HTTP server with MCP protocol via Server-Sent Events.
  • βΎ• Apify MCP Server Stdio: provides support for the MCP protocol via standard input/output stdio.

🎯 What does Apify MCP server do?

The MCP Server Actor allows an AI assistant to use any Apify Actor as a tool to perform a specific task. For example it can:

To interact with the Apify MCP server, you can use MCP clients such as Claude Desktop, LibreChat, or other MCP clients. Additionally, you can use simple example clients found in the examples directory.

When you have Actors integrated with the MCP server, you can ask:

  • "Search web and summarize recent trends about AI Agents"
  • "Find top 10 best Italian restaurants in San Francisco"
  • "Find and analyze Instagram profile of The Rock"
  • "Provide a step-by-step guide on using the Model Context Protocol with source URLs."
  • "What Apify Actors I can use?"

The following image shows how the Apify MCP server interacts with the Apify platform and AI clients:

Actors-MCP-server

In the future, we plan to load Actors dynamically and provide Apify's dataset and key-value store as resources. See the Roadmap for more details.

πŸ”„ What is the Model Context Protocol?

The Model Context Protocol (MCP) allows AI applications (and AI agents), such as Claude Desktop, to connect to external tools and data sources. MCP is an open protocol that enables secure, controlled interactions between AI applications, AI Agents, and local or remote resources.

For more information, see the Model Context Protocol website.

πŸ€– How is Actors MCP Server related to AI Agents?

The Apify MCP Server exposes Apify's Actors through the MCP protocol, allowing AI Agents or frameworks that implement the MCP protocol to access all Apify Actors as tools for data extraction, web searching, and other tasks.

To learn more, check out the blog post: What are AI Agents?

🧱 Components

Tools

Any Apify Actor can be used as a tool. By default, the server is pre-configured with the Actors specified below, but it can be overridden by providing Actor input.

'apify/instagram-scraper'
'apify/rag-web-browser'
'lukaskrivka/google-maps-with-contact-details'

The MCP server loads the Actor input schema and creates MCP tools corresponding to the Actors. See this example of input schema for the RAG Web Browser.

The tool name must always be the full Actor name, such as apify/rag-web-browser. The arguments for an MCP tool represent the input parameters of the Actor. For example, for the apify/rag-web-browser Actor, the arguments are:

{
  "query": "restaurants in San Francisco",
  "maxResults": 3
}

You don't need to specify the input parameters or which Actor to call, everything is managed by an LLM. When a tool is called, the arguments are automatically passed to the Actor by the LLM. You can refer to the specific Actor's documentation for a list of available arguments.

Prompt & Resources

The server does not provide any resources and prompts. We plan to add Apify's dataset and key-value store as resources in the future.

βš™οΈ Usage

The Apify MCP Server can be used in two ways: as an Apify Actor running at Apify platform or as a local server running on your machine.

πŸ‡¦ MCP Server Actor

Standby web server

The Actor runs in Standby mode with an HTTP web server that receives and processes requests.

Start server with default Actors. To use the Apify MCP Server with set of default Actors, send an HTTP GET request with your Apify API token to the following URL.

https://actors-mcp-server.apify.actor?token=<APIFY_TOKEN>

It is also possible to start the MCP server with a different set of Actors. To do this, create a task and specify the list of Actors you want to use.

Then, run task in Standby mode with the selected Actors using your Apify API token.

https://actors-mcp-server-task.apify.actor?token=<APIFY_TOKEN>

You can find a list of all available Actors in the Apify Store.

πŸ’¬ Interact with the MCP Server

Once the server is running, you can interact with Server-Sent Events (SSE) to send messages to the server and receive responses. You can use MCP clients such as Superinference.ai or LibreChat. (Claude Desktop does not support SSE transport yet, see Claude Desktop Configuration section for more details).

In the client settings you need to provide server configuration:

{
    "mcpServers": {
        "apify": {
            "type": "sse",
            "url": "https://actors-mcp-server.apify.actor/sse",
            "env": {
                "APIFY_TOKEN": "your-apify-token"
            }
        }
    }
}

Alternatively, you can use simple python client_see.py or test the server using curl </> commands.

  1. Initiate Server-Sent-Events (SSE) by sending a GET request to the following URL:

    curl https://actors-mcp-server.apify.actor/sse?token=<APIFY_TOKEN>
    

    The server will respond with a sessionId, which you can use to send messages to the server:

    event: endpoint
    data: /message?sessionId=a1b
  2. Send a message to the server by making a POST request with the sessionId:

    curl -X POST "https://actors-mcp-server.apify.actor/message?token=<APIFY_TOKEN>&session_id=a1b" -H "Content-Type: application/json" -d '{
      "jsonrpc": "2.0",
      "id": 1,
      "method": "tools/call",
      "params": {
        "arguments": { "searchStringsArray": ["restaurants in San Francisco"], "maxCrawledPlacesPerSearch": 3 },
        "name": "lukaskrivka/google-maps-with-contact-details"
      }
    }'

    The MCP server will start the Actor lukaskrivka/google-maps-with-contact-details with the provided arguments as input parameters. For this POST request, the server will respond with:

    Accepted
    
  3. Receive the response. The server will invoke the specified Actor as a tool using the provided query parameters and stream the response back to the client via SSE. The response will be returned as JSON text.

    event: message
    data: {"result":{"content":[{"type":"text","text":"{\"searchString\":\"restaurants in San Francisco\",\"rank\":1,\"title\":\"Gary Danko\",\"description\":\"Renowned chef Gary Danko's fixed-price menus of American cuisine ... \",\"price\":\"$100+\"...}}]}}
    

βΎ• MCP Server at a local host

Prerequisites

  • MacOS or Windows
  • The latest version of Claude Desktop must be installed (or another MCP client)
  • Node.js (v18 or higher)
  • Apify API Token (APIFY_TOKEN)

Install

Follow the steps below to set up and run the server on your local machine: First, clone the repository using the following command:

git clone [email protected]:apify/actor-mcp-server.git

Navigate to the project directory and install the required dependencies:

cd actor-mcp-server
npm install

Before running the server, you need to build the project:

npm run build

Claude Desktop

Configure Claude Desktop to recognize the MCP server.

  1. Open your Claude Desktop configuration and edit the following file:

    • On macOS: ~/Library/Application\ Support/Claude/claude_desktop_config.json
    • On Windows: %APPDATA%/Claude/claude_desktop_config.json
    "mcpServers": {
      "actors-mcp-server": {
        "command": "npx",
        "args": ["-y", "@apify/actors-mcp-server"]
        "env": {
           "APIFY_TOKEN": "your-apify-token"
        }
      }
    }
    

    Alternatively, you can use the following command to select one or more Apify Actors:

    "mcpServers": {
      "actors-mcp-server": {
        "command": "npx",
        "args": [
          "-y", "@apify/actors-mcp-serves",
          "--actors", "lukaskrivka/google-maps-with-contact-details,apify/instagram-scraper"
        ]
        "env": {
           "APIFY_TOKEN": "your-apify-token"
        }
      }
    }
    
  2. Restart Claude Desktop

    • Fully quit Claude Desktop (ensure it’s not just minimized or closed).
    • Restart Claude Desktop.
    • Look for the πŸ”Œ icon to confirm that the Exa server is connected.
  3. Examples

    You can ask Claude to perform web searches, such as:

    Find and analyze recent research papers about LLMs.
    Find top 10 best Italian restaurants in San Francisco.
    Find and analyze instagram profile of the Rock.
    

Stdio clients

Create environment file .env with the following content:

APIFY_TOKEN=your-apify-token
# ANTHROPIC_API_KEY is only required when you want to run examples/clientStdioChat.js
ANTHROPIC_API_KEY=your-anthropic-api-token

In the examples directory, you can find two clients that interact with the server via standard input/output (stdio):

  1. clientStdio.ts This client script starts the MCP server with two specified Actors. It then calls the apify/rag-web-browser tool with a query and prints the result. It demonstrates how to connect to the MCP server, list available tools, and call a specific tool using stdio transport.

    node dist/examples/clientStdio.js
  2. clientStdioChat.ts This client script also starts the MCP server but provides an interactive command-line chat interface. It prompts the user to interact with the server, allowing for dynamic tool calls and responses. This example is useful for testing and debugging interactions with the MCP server in conversational manner.

    node dist/examples/clientStdioChat.js

πŸ‘·πŸΌ Development

Prerequisites

  • Node.js (v18 or higher)
  • Python 3.6 or higher

Create environment file .env with the following content:

APIFY_TOKEN=your-apify-token
# ANTHROPIC_API_KEY is only required when you want to run examples/clientStdioChat.js
ANTHROPIC_API_KEY=your-anthropic-api-token

Local client (SSE)

To test the server with the SSE transport, you can use python script examples/client_sse.py: Currently, the node.js client does not support to establish a connection to remote server witch custom headers. You need to change URL to your local server URL in the script.

python src/examples/client_sse.py

Debugging

Since MCP servers operate over standard input/output (stdio), debugging can be challenging. For the best debugging experience, use the MCP Inspector.

Build the actor-mcp-server package:

npm run build

You can launch the MCP Inspector via npm with this command:

npx @modelcontextprotocol/inspector node @apify/actors-mcp-server --env APIFY_TOKEN=your-apify-token

Upon launching, the Inspector will display a URL that you can access in your browser to begin debugging.

β“˜ Limitations and feedback

To limit the context size the properties in the input schema are pruned and description is truncated to 200 characters. Enum fields and titles are truncated to max 50 options.

Memory for each Actor is limited to 4GB. Free users have an 8GB limit, 128MB needs to be allocated for running Actors-MCP-Server.

If you need other features or have any feedback, please submit an issue in Apify Console to let us know.

πŸš€ Roadmap (January 2025)

  • Document examples for LibreChat.
  • Provide tools to search for Actors and load them as needed.
  • Add Apify's dataset and key-value store as resources.
  • Add tools such as Actor logs and Actor runs for debugging.