TakanariShimbo/rosbridge-mcp-server
If you are the rightful owner of rosbridge-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The Rosbridge MCP Server is a Python implementation that integrates ROS with Model Context Protocol (MCP) servers, allowing for message publication to ROS topics via rosbridge.
| | README
Rosbridge MCP Server
A Model Context Protocol (MCP) server that provides comprehensive tools for interacting with ROS (Robot Operating System) via rosbridge WebSocket connection. This Python implementation enables AI assistants to monitor and control ROS systems through a standardized interface.
Features
- Topic Operations: List topics, get topic info, and publish messages
- Service Operations: List services and call ROS services
- Action Operations: List action servers, send goals, and cancel actions
Usage
Choose one of these examples based on your needs:
Basic usage (localhost):
{
"mcpServers": {
"rosbridge": {
"command": "uvx",
"args": ["takanarishimbo-rosbridge-mcp-server"]
}
}
}
Custom rosbridge host:
{
"mcpServers": {
"rosbridge": {
"command": "uvx",
"args": ["takanarishimbo-rosbridge-mcp-server"],
"env": {
"ROSBRIDGE_HOST": "192.168.1.100",
"ROSBRIDGE_PORT": "9090"
}
}
}
}
Remote ROS system:
{
"mcpServers": {
"rosbridge": {
"command": "uvx",
"args": ["rosbridge-mcp-server"],
"env": {
"ROSBRIDGE_HOST": "ros-robot.local",
"ROSBRIDGE_PORT": "9091"
}
}
}
}
Configuration
The server can be configured using environment variables:
ROSBRIDGE_HOST
The rosbridge server host (default: "localhost")
Examples:
localhost
: Local rosbridge192.168.1.100
: Remote IP addressros-robot.local
: Hostname
ROSBRIDGE_PORT
The rosbridge server port (default: "9090")
Standard rosbridge WebSocket port is 9090.
Available Tools
Topic Operations
list_topics
List all available ROS topics with their types.
No parameters required.
get_topic_info
Get detailed information about a specific topic including publishers and subscribers.
Parameters:
topic
(required): The ROS topic name (e.g., "/cmd_vel")
publish_topic
Publish a message to a ROS topic.
Parameters:
topic
(required): The ROS topic name (e.g., "/cmd_vel")message_type
(required): The ROS message type (e.g., "geometry_msgs/Twist")message
(required): The message data as a JSON object
Example:
{
"name": "publish_topic",
"arguments": {
"topic": "/cmd_vel",
"message_type": "geometry_msgs/Twist",
"message": {
"linear": { "x": 0.5, "y": 0.0, "z": 0.0 },
"angular": { "x": 0.0, "y": 0.0, "z": 0.1 }
}
}
}
Service Operations
list_services
List all available ROS services.
No parameters required.
publish_service
Call a ROS service.
Parameters:
service
(required): The ROS service name (e.g., "/add_two_ints")service_type
(required): The ROS service type (e.g., "rospy_tutorials/AddTwoInts")request
(required): The service request data as a JSON objecttimeout
(optional): Timeout in seconds (default: 10)
Example:
{
"name": "publish_service",
"arguments": {
"service": "/add_two_ints",
"service_type": "rospy_tutorials/AddTwoInts",
"request": {
"a": 10,
"b": 20
}
}
}
Action Operations
list_actions
List all available ROS action servers.
No parameters required.
publish_action
Send a goal to a ROS action server.
Parameters:
action_name
(required): The ROS action server name (e.g., "/move_base")action_type
(required): The ROS action type (e.g., "move_base_msgs/MoveBaseAction")goal
(required): The goal data as a JSON objecttimeout
(optional): Timeout in seconds to wait for result (default: 30)
Example:
{
"name": "publish_action",
"arguments": {
"action_name": "/move_base",
"action_type": "move_base_msgs/MoveBaseAction",
"goal": {
"target_pose": {
"header": {
"frame_id": "map"
},
"pose": {
"position": { "x": 1.0, "y": 2.0, "z": 0.0 },
"orientation": { "x": 0.0, "y": 0.0, "z": 0.0, "w": 1.0 }
}
}
}
}
}
cancel_action
Cancel a running ROS action goal.
Parameters:
action_name
(required): The ROS action server name (e.g., "/move_base")goal_id
(optional): The specific goal ID to cancel (cancels all if not provided)
Development
-
Clone this repository
git clone https://github.com/TakanariShimbo/rosbridge-mcp-server.git cd rosbridge-mcp-server
-
Install dependencies using uv
uv sync
-
Start rosbridge on your ROS system
roslaunch rosbridge_server rosbridge_websocket.launch
-
Run the server
uv run takanarishimbo-rosbridge-mcp-server
-
Test with MCP Inspector (optional)
npx @modelcontextprotocol/inspector uv run takanarishimbo-rosbridge-mcp-server
Publishing to PyPI
This project uses PyPI's Trusted Publishers feature for secure, token-less publishing via GitHub Actions.
1. Configure PyPI Trusted Publisher
-
Log in to PyPI (create account if needed)
- Go to https://pypi.org/
-
Navigate to Publishing Settings
- Go to your account settings
- Click on "Publishing" or go to https://pypi.org/manage/account/publishing/
-
Add GitHub Publisher
- Click "Add a new publisher"
- Select "GitHub" as the publisher
- Fill in:
- Owner:
TakanariShimbo
(your GitHub username/org) - Repository:
rosbridge-mcp-server
- Workflow name:
pypi-publish.yml
- Environment:
pypi
(optional but recommended)
- Owner:
- Click "Add"
2. Configure GitHub Environment (Recommended)
-
Navigate to Repository Settings
- Go to your GitHub repository
- Click "Settings" ā "Environments"
-
Create PyPI Environment
- Click "New environment"
- Name:
pypi
- Configure protection rules (optional):
- Add required reviewers
- Restrict to specific branches/tags
3. Setup GitHub Personal Access Token (for release script)
The release script needs to push to GitHub, so you'll need a GitHub token:
-
Create GitHub Personal Access Token
- Go to https://github.com/settings/tokens
- Click "Generate new token" ā "Generate new token (classic)"
- Set expiration (recommended: 90 days or custom)
- Select scopes:
- ā
repo
(Full control of private repositories)
- ā
- Click "Generate token"
- Copy the generated token (starts with
ghp_
)
-
Configure Git with Token
# Option 1: Use GitHub CLI (recommended) gh auth login # Option 2: Configure git to use token git config --global credential.helper store # Then when prompted for password, use your token instead
4. Release New Version
Use the release script to automatically version, tag, and trigger publishing:
# First time setup
chmod +x scripts/release.sh
# Increment patch version (0.1.0 ā 0.1.1)
./scripts/release.sh patch
# Increment minor version (0.1.0 ā 0.2.0)
./scripts/release.sh minor
# Increment major version (0.1.0 ā 1.0.0)
./scripts/release.sh major
# Set specific version
./scripts/release.sh 1.2.3
5. Verify Publication
-
Check GitHub Actions
- Go to "Actions" tab in your repository
- Verify the "Publish to PyPI" workflow completed successfully
-
Verify PyPI Package
- Visit: https://pypi.org/project/rosbridge-mcp-server/
- Or run:
pip show rosbridge-mcp-server
Release Process Flow
release.sh
script updates version in all files- Creates git commit and tag
- Pushes to GitHub
- GitHub Actions workflow triggers on new tag
- Workflow uses OIDC to authenticate with PyPI (no tokens needed!)
- Workflow builds project and publishes to PyPI
- Package becomes available globally via
pip install
oruvx
Code Quality
This project uses ruff
for linting and formatting:
# Run linter
uv run ruff check
# Fix linting issues
uv run ruff check --fix
# Format code
uv run ruff format
Project Structure
rosbridge-mcp-server/
āāā src/
ā āāā __init__.py # Package initialization
ā āāā __main__.py # Main entry point
ā āāā server.py # Server implementation
ā āāā tools/ # Tool implementations
ā āāā __init__.py # Tools module initialization
ā āāā list_topics.py # List topics tool
ā āāā list_actions.py # List actions tool
ā āāā list_services.py # List services tool
ā āāā get_topic_info.py # Get topic info tool
ā āāā publish_topic.py # Publish topic tool
ā āāā publish_action.py # Publish action tool
ā āāā publish_service.py # Publish service tool
ā āāā cancel_action.py # Cancel action tool
āāā pyproject.toml # Project configuration
āāā uv.lock # Dependency lock file
āāā .github/
ā āāā workflows/
ā āāā pypi-publish.yml # PyPI publish workflow with Trusted Publishers
āāā scripts/
ā āāā release.sh # Release automation script
āāā docs/
ā āāā README.md # English documentation
ā āāā README_ja.md # Japanese documentation
āāā .gitignore # Git ignore file
License
MIT