Components
Tools
The server offers these core tools:
Query Tools
read-agensgraph-cypher
Execute Cypher read queries to read data from the database
Input:
query
(string): The Cypher query to executeparams
(dictionary, optional): Parameters to pass to the Cypher query
Returns: Query results as JSON serialized array of objects
write-agensgraph-cypher
Execute updating Cypher queries
Input:
query
(string): The Cypher update queryparams
(dictionary, optional): Parameters to pass to the Cypher query
Returns: A JSON serialized result summary counter with
{ insertedvertices: number, insertededges: number, ... }
Schema Tools
get-agensgraph-schema
Get a list of all nodes types in the graph database, their attributes with name, type and relationships to other node types
No input required
Returns: JSON serialized list of node labels with two dictionaries: one for attributes and one for relationships
Namespacing
The server supports namespacing to allow multiple Agensgraph MCP servers to be used simultaneously. When a namespace is provided, all tool names are prefixed with the namespace followed by a hyphen (e.g., mydb-read-agensgraph-cypher
).
This is useful when you need to connect to multiple Agensgraph databases or instances from the same session.
Usage with Claude Desktop
Released Package
Can be found on PyPi https://pypi.org/project/mcp-agensgraph-cypher/
Add the server to your claude_desktop_config.json
with the database connection configuration through environment variables. You may also specify the transport method and namespace with cli arguments or environment variables.
Single Graph Example
"mcpServers": {
"agensgraph-cypher": {
"command": "uvx",
"args": [ "mcp-agensgraph-cypher@0.1.0", "--transport", "stdio" ],
"env": {
"AGENSGRAPH_USERNAME": "<your-username>",
"AGENSGRAPH_PASSWORD": "<your-password>",
"AGENSGRAPH_DB": "<dbname>",
"AGENSGRAPH_HOST": "localhost",
"AGENSGRAPH_PORT": "5432",
"AGENSGRAPH_GRAPH_NAME": "graph",
}
}
}
Multiple Graphs Example
Here’s an example of connecting to multiple Graphs within a single agensgraph db using namespaces:
{
"mcpServers": {
"graph1-agensgraph": {
"command": "uvx",
"args": [ "mcp-agensgraph-cypher@0.1.0", "--namespace", "graph1" ],
"env": {
"AGENSGRAPH_USERNAME": "<your-username>",
"AGENSGRAPH_PASSWORD": "<your-password>",
"AGENSGRAPH_DB": "<dbname>",
"AGENSGRAPH_HOST": "localhost",
"AGENSGRAPH_PORT": "5432",
"AGENSGRAPH_GRAPH_NAME": "graph1"
}
},
"graph2-agensgraph": {
"command": "uvx",
"args": [ "mcp-agensgraph-cypher@0.1.0", "--namespace", "graph2" ],
"env": {
"AGENSGRAPH_USERNAME": "<your-username>",
"AGENSGRAPH_PASSWORD": "<your-password>",
"AGENSGRAPH_DB": "<dbname>",
"AGENSGRAPH_HOST": "localhost",
"AGENSGRAPH_PORT": "5432",
"AGENSGRAPH_GRAPH_NAME": "graph2"
}
}
}
}
In this setup:
The graph1 graph tools will be prefixed with
graph1-
(e.g.,graph1-read-agensgraph-cypher
)The graph2 database tools will be prefixed with
graph2-
(e.g.,graph2-get-agensgraph-schema
)
Syntax with --db-url
, --username
, --password
and other command line arguments is still supported but environment variables are preferred.
Legacy Syntax
"mcpServers": {
"agensgraph": {
"command": "uvx",
"args": [
"mcp-agensgraph-cypher@0.1.0",
"--db-name",
"<your-db-name>",
"--username"
"<your-username>",
"--password",
"<your-password>",
"--db-host",
"localhost",
"--db-port",
"5432",
"--namespace",
"mydb",
"--transport",
"sse",
"--server-host",
"0.0.0.0",
"--server-port",
"8000"
]
}
}
Development
Prerequisites
Install
uv
(Universal Virtualenv):
# Using pip
pip install uv
# Using Homebrew on macOS
brew install uv
# Using cargo (Rust package manager)
cargo install uv
Clone the repository and set up development environment:
# Clone the repository
git clone https://github.com/yourusername/agensgraph-ai.git
cd mcp-agensgraph/servers/mcp-agensgraph-cypher
# Create and activate virtual environment using uv
uv venv
source .venv/bin/activate # On Unix/macOS
.venv\Scripts\activate # On Windows
# Install dependencies including dev dependencies
uv pip install -e ".[dev]"
Run Integration Tests
./tests.sh
Development Configuration
Add the server to your claude_desktop_config.json
"mcpServers": {
"agensgraph": {
"command": "uv",
"args": [
"--directory",
"parent_of_servers_repo/servers/mcp-agensgraph-cypher/src",
"run",
"mcp-agensgraph-cypher",
"--transport",
"stdio",
"--namespace",
"dev",
],
"env": {
"AGENSGRAPH_USERNAME": "<your-username>",
"AGENSGRAPH_PASSWORD": "<your-password>",
"AGENSGRAPH_DB": "<dbname>",
"AGENSGRAPH_HOST": "localhost",
"AGENSGRAPH_PORT": "5432",
"AGENSGRAPH_GRAPH_NAME": "graph"
}
}
}