planet-mcp is a local MCP server powered by the Planet SDK. It allows an AI agent/chat to interact with the Planet API.
To get started with your preferred AI agent, find it in the Usage section below.
This is experimental software. This MCP service will invoke the Planet SDK/CLI on your behalf. It can create and modify orders, subscriptions, and more. Do not disable tool approvals and always carefully review tool prompts before approving them. Use at your own risk.
Tools may be added, removed or altered based on testing/feedback.
Reminder: MCP servers and tools will increase the number of tokens used during interactions with your LLM provider.
We would love to hear back from you after using this, if you have a feature request or find something isn't working please file a Github issue for us! Thanks
- Python 3.11 or higher
To install the Planet MCP server, use pip or your preferred package manager:
pip install planet-mcpThis will also install the planet SDK.
You must authenticate your Planet account before using the local MCP server. You can do this by running:
planet auth loginNOTE
if you have PL_API_KEY set globaly, you should run unset PL_API_KEY and then planet auth reset and planet auth login again.
The following AI agents have been tested with the Planet local MCP. For other agents, refer to their documentation for adding a custom MCP server (the Planet local MCP uses stdio transport).
To connect with Claude Code, run the following command:
claude mcp add planet planet-mcpTo connect using Claude Desktop, add the following to your claude_desktop_config.json file (see MCP documentation for more details):
{
"mcpServers": {
"planet": {
"type": "stdio",
"command": "planet-mcp"
}
}
}To connect using Gemini CLI, add the following to your ~/.gemini/settings.json file:
"mcpServers": {
"planet": {
"command": "planet-mcp",
"description": "Planet MCP Server",
"timeout": 30000,
"trust": false
}
}To connect using GitHub Copilot, configure the mcp.json file (see VSCode docs) with the following configuration:
{
"servers": {
"planet": {
"type": "stdio",
"command": "planet-mcp"
}
}
}If you'd like, you can enable or disable specific tools in the MCP server. For example, if you're only working with the orders tooling: You can start the server with just the that enabled:
--include-tags=orders
If you want to keep the defaults, but disable a certain tool, you can: --exclude-tags=destinations
In order to disable more than one tool you can provide a comma separated list like:
--exclude-tags=destinations,mosaics
By default, we have disabled download tools and the subscriptions tools, as we have found those tools don't work very well with LLMs at the moment.
- Does Planet have any recent imagery over Puget Sound?
- List my feature collections
- Order me the latest high-res imagery over the Netherlands
- Create a PlanetScope order with the first item in my Netherlands Feature Collection.
This is likely due to the planet-mcp package being installed to a different Python environment than the one your AI agent is using. The easiest way to resolve this is to run which planet-mcp after installing the package, and then copy the full path to your AI agent's MCP configuration. For example, if which planet-mcp returns /home/user/.local/share/virtualenvs/test/bin/planet-mcp, your config file would look like:
{
"servers": {
"planet": {
"command": "/home/user/.local/share/virtualenvs/test/bin/planet-mcp"
}
}
}- python (>= 3.11) + uv
- npx + friends (node >= 20) (to run inspector, if desired)
make dev-up- Optional,
make inspector
-
Create and activate virtual environment using uv:
uv venv
source .venv/bin/activate -
Install dependencies using uv:
uv pip install -e '.' -
Run mcp server
planet-mcp
Optional run the inspector with
uv run fastmcp dev src/planet_mcp/main.py