Skip to main content

Maintenance of a set of tools to enhance LLM through MCP protocols.

Project description

mcp-toolbox

Release Build status codecov Commit activity License

A comprehensive toolkit for enhancing LLM capabilities through the Model Context Protocol (MCP). This package provides a collection of tools that allow LLMs to interact with external services and APIs, extending their functionality beyond text generation.

Features

*nix is our main target, but Windows should work too.

  • Command Line Execution: Execute any command line instruction through LLM
  • Figma Integration: Access Figma files, components, styles, and more
  • Extensible Architecture: Easily add new API integrations
  • MCP Protocol Support: Compatible with Claude Desktop and other MCP-enabled LLMs
  • Comprehensive Testing: Well-tested codebase with high test coverage

Installation

Using uv (Recommended)

We recommend using uv to manage your environment.

# Install uv
curl -LsSf https://astral.sh/uv/install.sh | sh  # For macOS/Linux
# or
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"  # For Windows

Then you can use uvx mcp-toolbox@latest stdio as commands for running the MCP server for latest version.

Installing via Smithery

To install Toolbox for LLM Enhancement for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install @ai-zerolab/mcp-toolbox --client claude

Using pip

pip install mcp-toolbox

And you can use mcp-toolbox stdio as commands for running the MCP server.

Configuration

Environment Variables

The following environment variables can be configured:

  • FIGMA_API_KEY: API key for Figma integration

Claude Desktop Configuration

To use mcp-toolbox with Claude Desktop, add the following to your Claude Desktop configuration file:

{
  "mcpServers": {
    "zerolab-toolbox": {
      "command": "uvx",
      "args": ["mcp-toolbox@latest", "stdio"],
      "env": {
        "FIGMA_API_KEY": "your-figma-api-key"
      }
    }
  }
}

You can generate a debug configuration template using:

uv run generate_config_template.py

Available Tools

Command Line Tools

Tool Description
execute_command Execute a command line instruction

File Operations Tools

Tool Description
read_file_content Read content from a file
write_file_content Write content to a file
replace_in_file Replace content in a file using regular expressions
list_directory List directory contents with detailed information

Figma Tools

Tool Description
figma_get_file Get a Figma file by key
figma_get_file_nodes Get specific nodes from a Figma file
figma_get_image Get images for nodes in a Figma file
figma_get_image_fills Get URLs for images used in a Figma file
figma_get_comments Get comments on a Figma file
figma_post_comment Post a comment on a Figma file
figma_delete_comment Delete a comment from a Figma file
figma_get_team_projects Get projects for a team
figma_get_project_files Get files for a project
figma_get_team_components Get components for a team
figma_get_file_components Get components from a file
figma_get_component Get a component by key
figma_get_team_component_sets Get component sets for a team
figma_get_team_styles Get styles for a team
figma_get_file_styles Get styles from a file
figma_get_style Get a style by key

XiaoyuZhouFM Tools

Tool Description
xiaoyuzhoufm_download Download a podcast episode from XiaoyuZhouFM with optional automatic m4a to mp3 conversion

Audio Tools

Tool Description
get_audio_length Get the length of an audio file in seconds
get_audio_text Get transcribed text from a specific time range in an audio file

Usage Examples

Running the MCP Server

# Run with stdio transport (default)
mcp-toolbox stdio

# Run with SSE transport
mcp-toolbox sse --host localhost --port 9871

Using with Claude Desktop

  1. Configure Claude Desktop as shown in the Configuration section
  2. Start Claude Desktop
  3. Ask Claude to interact with Figma files:
    • "Can you get information about this Figma file: 12345abcde?"
    • "Show me the components in this Figma file: 12345abcde"
    • "Get the comments from this Figma file: 12345abcde"
  4. Ask Claude to execute command line instructions:
    • "What files are in the current directory?"
    • "What's the current system time?"
    • "Show me the contents of a specific file."
  5. Ask Claude to download podcasts from XiaoyuZhouFM:
  6. Ask Claude to work with audio files:
    • "What's the length of this audio file: audio.m4a?"
    • "Transcribe the audio from 60 to 90 seconds in audio.m4a"
    • "Get the text from 2:30 to 3:00 in the audio file"

Development

Local Setup

Fork the repository and clone it to your local machine.

# Install in development mode
make install
# Activate a virtual environment
source .venv/bin/activate  # For macOS/Linux
# or
.venv\Scripts\activate  # For Windows

Running Tests

make test

Running Checks

make check

Building Documentation

make docs

Adding New Tools

To add a new API integration:

  1. Update config.py with any required API keys
  2. Create a new module in mcp_toolbox/
  3. Implement your API client and tools
  4. Add tests for your new functionality
  5. Update the README.md with new environment variables and tools

See the development guide for more detailed instructions.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the terms of the license included in the repository.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_toolbox-0.0.7.tar.gz (99.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_toolbox-0.0.7-py3-none-any.whl (22.1 kB view details)

Uploaded Python 3

File details

Details for the file mcp_toolbox-0.0.7.tar.gz.

File metadata

  • Download URL: mcp_toolbox-0.0.7.tar.gz
  • Upload date:
  • Size: 99.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.2

File hashes

Hashes for mcp_toolbox-0.0.7.tar.gz
Algorithm Hash digest
SHA256 75b8b6144f6ab947fa997e4519b06ac12bae9bdd1b04ef570c6fc8de003b6bda
MD5 dfe075bf5fe9abf018400ee92c429229
BLAKE2b-256 302de9b51684fd3681baad6c1e060f505f29a226e1c9ab07f14f00c6fc1f5e43

See more details on using hashes here.

File details

Details for the file mcp_toolbox-0.0.7-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_toolbox-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ba8014630094f804fcce298cf60d15b2df4f7185da4fff860f5100345834e647
MD5 607386d03628d2f913c5d012f82c0363
BLAKE2b-256 771b9e2a14a3c89f3ee9c51dc06978d30dfbc569bd2a2f954efc2e586683ec9e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page