QGIS MCP
Connects QGIS to an LLM through the Model Context Protocol, allowing agentic interaction with and control of QGIS for prompt-assisted project creation, layer loading, code execution, and more.
README
QGIS MCP (hardened fork)
QGIS MCP connects QGIS to an LLM through the Model Context Protocol (MCP), allowing agentic interaction with and control of QGIS. This enables prompt-assisted project creation, layer loading, code execution and more.
Attribution & lineage
This is a hardened fork, distributed under GPL v3 (see LICENSE). Credit to the chain it builds on:
- BlenderMCP by Siddharth Ahuja — the original concept.
- QGIS MCP by Juan Santos Ochoa (jjsantos01) — the QGIS adaptation this is based on.
- QGIS2OllamaMCP by Anita Graser — the immediate upstream of this fork.
What this fork changes
See CHANGELOG.md for details. In short, two security hardening changes (both untested against a live QGIS — verify locally before relying on them):
- Shared-secret token on the plugin socket (port 9876). The plugin generates a random token in
~/.qgis_mcp/tokenon first run; the MCP server reads the same file and must present the token, so other local processes can't drive QGIS just by reaching the socket. - Loopback-only MCP server. The MCP server (port 9877) now binds explicitly to
127.0.0.1, so it is never exposed to your network regardless of library defaults.
⚠️ Security note: by design this tool lets the LLM run arbitrary Python inside QGIS (the
execute_codetool). Only run the plugin/server while you are actively using it, and only on a machine you trust. After starting, confirm port 9877 is on127.0.0.1withnetstat -ano | findstr 9877.The token check is fail-open: if the plugin cannot read or write
~/.qgis_mcp/token, it logs a warning and runs without authentication rather than refusing to start. Watch the QGIS log to confirm the token loaded.
Components
The system consists of two main components:
- QGIS plugin: A QGIS plugin that creates a socket server within QGIS to receive and execute commands.
- MCP Server: A Python server that implements the Model Context Protocol and connects to the QGIS plugin.
Installation
Prerequisites
- QGIS 3.X (tested with 3.38)
- Ollama and model with support for agents (tested with ministral-3:latest)
- For the MCP server Python environment:
pip install fastmcp ollama(the upstreamrequestsandlupaare not used by this code and are omitted)
QGIS plugin
To install the plugin, you need to copy the folder qgis_mcp_hardened and its content into your QGIS plugins folder. The folder is named qgis_mcp_hardened (not qgis_mcp_plugin) on purpose, so it does not collide with the official qgis_mcp_plugin on plugins.qgis.org.
Usage
Starting the connection in QGIS
- In QGIS, go to
plugins>QGIS2OllamaMCP>QGIS2OllamaMCP
- Click "Start Server"
Will launch on localhost:9876 by default. - Check the logs to see the connection status

Starting the MCP server
python src/qgis_mcp/qgis_mcp_server.py
Will launch on localhost:9877/sse by default (bound to 127.0.0.1).
Tools
ping- Simple ping command to check server connectivityget_qgis_info- Get QGIS information about the current installationload_project- Load a QGIS project from the specified pathcreate_new_project- Create a new project and save itget_project_info- Get current project informationadd_vector_layer- Add a vector layer to the projectadd_raster_layer- Add a raster layer to the projectget_layers- Retrieve all layers in the current projectremove_layer- Remove a layer from the project by its IDzoom_to_layer- Zoom to the extent of a specified layerget_layer_features- Retrieve features from a vector layer with an optional limitexecute_processing- Execute a processing algorithm with the given parameterssave_project- Save the current project to the given pathrender_map- Render the current map view to an image fileexecute_code- Execute arbitrary PyQGIS code provided as a string
Starting the conversation
You can launch an example conversation using:
python src/qgis_mcp/qgis_mcp_client.py
Note: you need to update the project file path to point to a project file on your machine.
Then launch the interactive client to start experimenting:
python src/qgis_mcp/qgis_mcp_client_interactive.py
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.