Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
Text to Cypher
A high-performance Rust library and API service that translates natural language text to Cypher queries for graph databases, featuring integration with genai and FalkorDB. Use as a library in your Rust applications or deploy the all-in-one Docker solution with integrated FalkorDB database, web browser interface, text-to-cypher API, and Model Context Protocol (MCP) server support!
✨ What's New
Dynamic Cypher Skills: Load FalkorDB-specific Cypher best practices at runtime from external skill files. The LLM can request detailed skill content on-demand via tool calling, keeping prompts compact while enabling deep expertise when needed. See Dynamic Cypher Skills for details.
Library Support: Now available as a Rust library! Use text-to-cypher directly in your Rust applications without the REST API overhead.
All-in-One Docker Solution: Our Docker image includes everything you need in a single container:
- 🗄️ FalkorDB Database (port 6379) - Full graph database with Redis protocol
- 🌐 FalkorDB Web Interface (port 3000) - Interactive graph browser and query builder
- 🚀 Text-to-Cypher API (port 8080) - Natural language to Cypher conversion
- 🤖 MCP Server (port 3001) - AI assistant integration support
Features
Core Capabilities
- Text to Cypher Translation: Convert natural language queries to Cypher database queries using AI
- Enhanced Schema Discovery: Automatically discover and analyze graph database schemas with example values
- Query Validation: Built-in validation system to catch syntax errors before execution
- Self-Healing Queries: Automatic retry with error feedback when queries fail
- Library & API Modes: Use as a Rust library or REST API
- RESTful API: Clean HTTP API with comprehensive OpenAPI/Swagger documentation
- MCP Server: Model Context Protocol server for AI assistant integrations
- Streaming Responses: Real-time Server-Sent Events (SSE) streaming of query processing results
Infrastructure
- Rust Library: Integrate directly into your Rust applications
- Integrated FalkorDB: Built-in FalkorDB graph database with web browser interface
- All-in-One Docker Solution: Complete stack in a single container - database, web UI, API, and MCP server
- Multi-Platform Support: Docker images available for both AMD64 and ARM64 architectures
AI & Quality
- AI Model Integration: Powered by genai for natural language processing with support for multiple providers
- Dynamic Cypher Skills: Load FalkorDB-specific best practices from external skill files with on-demand tool calling
- Schema-Aware Generation: Uses schema with example values for better query accuracy
- Production Ready: Comprehensive error handling, logging, and robust architecture
- Environment Configuration: Flexible configuration via
.envfile with fallback to request parameters
Quick Start
Using as a Rust Library
Add text-to-cypher to your Cargo.toml:
[]
# For library usage only (without REST server)
= { = "0.1", = false }
# For full server capabilities
= "0.1"
Basic Example:
use ;
async
More Examples:
See the library usage example for comprehensive examples including:
- Using the high-level
TextToCypherClient - Using core functions directly for more control
- Generating Cypher queries without execution
Run the example:
# Ensure FalkorDB is running
# Set your API key
# Run the example (library mode - no server dependencies)
Using from TypeScript/JavaScript
See TypeScript Usage Guide for detailed instructions on using text-to-cypher from TypeScript/JavaScript applications via REST API, Node.js native bindings, or WebAssembly.
Using from Python
See Python Usage Guide for detailed instructions on using text-to-cypher from Python applications via REST API or PyO3 bindings.
Using Docker (Recommended for Server)
The easiest way to get started is using our all-in-one Docker image that includes FalkorDB database, web browser interface, text-to-cypher API, and MCP server:
# Run the complete stack with all services
# Or using environment file
# Or mounting .env file for full MCP server functionality
# Custom ports using environment variables
Available Services
Once running, access the services at:
- FalkorDB Database:
localhost:6379(Redis protocol) - FalkorDB Web Interface:
http://localhost:3000(Interactive graph database browser) - Text-to-Cypher API:
http://localhost:8080(REST API) - Swagger UI:
http://localhost:8080/swagger-ui/(API documentation) - MCP Server:
localhost:3001(Model Context Protocol server) - OpenAPI Spec:
http://localhost:8080/api-doc/openapi.json
Local Development
If you prefer to run locally without Docker:
# Prerequisites: You'll need FalkorDB running separately
# Install Rust (if not already installed)
|
# Clone and run the text-to-cypher service
The local development setup requires:
- FalkorDB instance: Running on port 6379 (can be Docker or native)
- Rust environment: For building and running the text-to-cypher service
API Documentation
The API includes comprehensive Swagger UI documentation available at /swagger-ui/ when running the server.
Configuration
The application supports flexible configuration via environment variables or .env file:
Core Settings
DEFAULT_MODEL: Default AI model to use (e.g., "openai:gpt-4")DEFAULT_KEY: Default API key for the AI service
Port Configuration
REST_PORT: REST API server port (default: 8080)MCP_PORT: MCP server port for AI assistant integrations (default: 3001)- The MCP server provides an SSE endpoint at
/sseon this port
- The MCP server provides an SSE endpoint at
Optional Settings
FALKORDB_CONNECTION: FalkorDB connection string (default: "falkor://127.0.0.1:6379")SKILLS_DIR: Path to a directory containing FalkorDB Cypher skill files (optional, see Dynamic Cypher Skills)
Create a .env file from the provided example:
# Edit .env with your preferred default model and API key
MCP Server Configuration
Important: The MCP server will only start if:
- Both
DEFAULT_MODELandDEFAULT_KEYare configured - The
.envfile physically exists (not just environment variables)
For Docker deployments:
- Use
--env-file .envor-eflags for HTTP server only (MCP server also starts if both MODEL and KEY are provided) - Use
-v $(pwd)/.env:/app/.env:roto ensure MCP server starts with mounted.envfile
Architecture
The integrated Docker solution runs four concurrent services:
FalkorDB Database (Port 6379)
- Graph database server with Redis protocol compatibility
- Stores and manages graph data structures
- Accessible via Redis clients and graph query languages
FalkorDB Web Interface (Port 3000)
- Interactive web-based graph database browser
- Visual query builder and result visualization
- Database administration and monitoring tools
- Graph data exploration interface
Text-to-Cypher HTTP API (Port 8080)
- Main REST API for text-to-cypher conversion
- Swagger UI documentation at
http://localhost:8080/swagger-ui/ - OpenAPI specification at
http://localhost:8080/api-doc/openapi.json - Supports both streaming (SSE) and non-streaming responses
MCP Server (Port 3001) - Conditional
- Model Context Protocol server for AI assistant integrations
- Provides
text_to_cyphertool for natural language to Cypher conversion - Note: MCP server only starts if both
DEFAULT_MODELandDEFAULT_KEYare configured
Deployment Options
Docker Deployment (Production)
The project provides an all-in-one Docker image that includes FalkorDB database, web browser interface, text-to-cypher API, and MCP server:
# Pull the latest image
# Option 1: Complete stack with all services (recommended)
# Option 2: Using environment file
# Option 3: Mount .env file for full MCP functionality
# View logs from all services
Docker Configuration Options
| Method | All Services | Use Case |
|---|---|---|
-e DEFAULT_MODEL=... -e DEFAULT_KEY=... |
✅ | Environment-based config |
--env-file .env |
✅ | File-based configuration |
-v $(pwd)/.env:/app/.env:ro |
✅ | Mounted configuration file |
Note: All four services (FalkorDB database, web interface, text-to-cypher API, and MCP server) will start when both DEFAULT_MODEL and DEFAULT_KEY are configured, regardless of how the environment variables are provided.
Service Ports
| Service | Port | Description |
|---|---|---|
| FalkorDB Database | 6379 | Redis protocol access to graph database |
| FalkorDB Web Interface | 3000 | Interactive web browser for graph exploration |
| Text-to-Cypher HTTP API | 8080 | REST API with Swagger documentation |
| MCP Server | 3001 | Model Context Protocol server for AI integrations |
Docker Features
- All-in-One Solution: Complete graph database stack in a single container
- Built-in Cypher Skills: FalkorDB-specific Cypher best practices baked in from FalkorDB/skills
- Multi-Platform: Support for both AMD64 and ARM64 architectures
- Minimal Size: Optimized Alpine Linux base for efficient deployment
- Production Ready: Includes supervisord for process management and logging
- Security: Services run with appropriate user permissions
Environment Variables
Configure the application using environment variables or .env file:
DEFAULT_MODEL: Default AI model (e.g., "gpt-4o-mini", "anthropic:claude-3")DEFAULT_KEY: Default API key for the AI serviceFALKORDB_CONNECTION: FalkorDB connection URL (default: "falkor://127.0.0.1:6379")SKILLS_DIR: Path to Cypher skills directory (default:/app/skillsin Docker, see Dynamic Cypher Skills)
MCP Server Usage
The MCP server provides a standardized interface for AI assistants to convert natural language questions into Cypher queries. This enables seamless integration with AI tools that support the Model Context Protocol.
Using MCP Inspector
To test and interact with the MCP server, you can use the MCP Inspector:
- Start the text-to-cypher stack:
- Install MCP Inspector (if not already installed):
-
Connect MCP Inspector to the server:
- Open MCP Inspector in your browser (typically
http://localhost:6274) - Add a new server connection with these settings:
- Transport:
stdio - Command:
nc - Arguments:
["localhost", "3001"]
- Transport:
Or if using a direct connection:
- Transport:
sse - URL:
http://localhost:3001/sse
- Open MCP Inspector in your browser (typically
-
Available Tools: The MCP server exposes the following tool:
text_to_cypherConverts natural language questions into Cypher queries for graph databases.
Parameters:
graph_name(required): Name of the graph database to queryquestion(required): Natural language question to convert to Cypher
Example Usage in MCP Inspector:
-
Example Workflow:
- Select the
text_to_cyphertool in MCP Inspector - Fill in the parameters:
- Graph name:
"social_network" - Question:
"Who are the friends of John with more than 5 mutual connections?"
- Graph name:
- Execute the tool
- View the generated Cypher query and execution results
- Select the
Pro Tip: You can also interact with the FalkorDB directly through the web interface at http://localhost:3000 to create and explore graphs visually!
Integration with AI Assistants
The MCP server enables AI assistants to:
- Convert natural language to Cypher queries
- Execute queries against FalkorDB graphs
- Provide structured responses with query results
- Handle complex graph database interactions seamlessly
MCP Server Benefits
- Standardized Interface: Uses the Model Context Protocol for consistent AI tool integration
- Streaming Support: Real-time processing and response streaming
- Error Handling: Comprehensive error messages and validation
- Documentation: Auto-generated tool documentation with parameter descriptions and examples
Getting Started
Prerequisites
- For Docker (Recommended): Docker installed on your system
- For Local Development:
- Rust (latest stable version)
- FalkorDB instance (can be run via Docker:
docker run -d -p 6379:6379 falkordb/falkordb:latest)
Running the Complete Stack
Using Docker (Recommended)
# Run the complete integrated stack
Local Development
# Start FalkorDB separately
# Run text-to-cypher service
Access the Services
Once running, access the services at:
- FalkorDB Web Interface:
http://localhost:3000(Interactive graph browser) - Text-to-Cypher API:
http://localhost:8080 - Swagger UI:
http://localhost:8080/swagger-ui/ - OpenAPI spec:
http://localhost:8080/api-doc/openapi.json - FalkorDB Database:
localhost:6379(Redis protocol) - MCP Server:
localhost:3001(Model Context Protocol)
Building for Production
Docker Build (Local)
# Build locally using the build script
# Or build manually (defaults to SKILLS_REF=main for local/dev builds)
# For reproducible production builds, pass a pinned FalkorDB/skills ref
Using Pre-built Images
# Pull from Docker Hub
# Available tags: latest, v1.0.0, v0.1.0-beta.x, etc.
Native Build
Testing
The library includes comprehensive unit tests with 33+ test cases covering:
- Library API tests (src/lib.rs):
TextToCypherClientconstruction, request/response serialization, chat types - Processor tests (src/processor.rs): Request/response handling, status checks, serialization
- Validator tests (src/validator.rs): Cypher query validation and security checks
- Formatter tests (src/formatter.rs): Result formatting for various data types
- Schema tests (src/schema/discovery.rs): Schema discovery and validation
Run all tests:
# Run library tests only
# Run all tests including integration tests
# Run with output
Development
Prerequisites
Quick Start with just
# List all available recipes
# Download FalkorDB Cypher skills + run lint + tests
# Start development server (auto-downloads skills if missing)
# Download skills manually
# Download skills pinned to a specific version
# List loaded skills
Available Recipes
| Recipe | Description |
|---|---|
just download-skills |
Download latest FalkorDB Cypher skills |
just download-skills-pinned <ref> |
Download skills at a specific branch/tag/commit |
just build |
Build in debug mode |
just build-release |
Build in release mode |
just build-lib |
Build library only (no server deps) |
just fmt |
Check formatting |
just clippy |
Run clippy with CI-level strictness |
just lint |
Run all lints (fmt + clippy) |
just test |
Run all tests |
just check |
Full CI check (lint + test) |
just dev |
Start development server with skills |
just run |
Start release server with skills |
just docker-build [version] [skills_ref] |
Build Docker image locally (defaults to latest skills from main) |
just docker-push <version> <registry> <skills_ref> |
Build and push Docker image with a pinned skills ref |
just list-skills |
Show all loaded skills |
just clean |
Clean build artifacts and skills |
Code Quality
The project maintains high code quality standards:
# Using just (recommended)
# Or with cargo directly
Project Structure
text-to-cypher/
├── src/
│ ├── main.rs # Main application and HTTP server
│ ├── chat.rs # Chat message types and handling
│ ├── error.rs # Error types and handling
│ ├── formatter.rs # Query result formatting
│ ├── mcp/ # Model Context Protocol server
│ ├── schema/ # Graph schema discovery
│ ├── skills/ # Dynamic Cypher skill loading
│ │ ├── mod.rs # Skill catalog, tool calling, provider gating
│ │ ├── parser.rs # YAML frontmatter + markdown parser
│ │ └── loader.rs # Directory-based skill loader
│ └── template.rs # Template engine for prompts
├── templates/ # AI prompt templates
│ ├── system_prompt.txt # System prompt for AI
│ ├── user_prompt.txt # User query template
│ └── last_request_prompt.txt # Final response template
├── skills/ # Downloaded Cypher skills (gitignored)
├── justfile # Development task recipes
├── Dockerfile # All-in-one Docker image with FalkorDB + skills
├── supervisord.conf # Process management configuration
├── entrypoint.sh # Docker container startup script
├── .dockerignore # Docker build context filtering
└── docker-build.sh # Convenient Docker build script
API Usage Examples
Basic Text-to-Cypher Request
Using the FalkorDB Web Interface
- Access the web interface: Open
http://localhost:3000in your browser - Connect to database: The interface automatically connects to the local FalkorDB instance
- Create sample data: Use the visual interface to create nodes and relationships
- Run queries: Test Cypher queries directly in the web interface
- Export/Import: Save your graph data or load sample datasets
Using Server-Sent Events (SSE)
The API supports streaming responses for real-time progress updates:
const eventSource = ;
eventSource ;
Complete Workflow Example
# 1. Start the complete stack
# 2. Create a graph using FalkorDB web interface (http://localhost:3000)
# Add some sample data: people, relationships, etc.
# 3. Query using natural language via the API
# 4. Use MCP server for AI assistant integrations (port 3001)
# Connect your AI assistant to http://localhost:3001
Publishing to crates.io
This library is designed to be published to crates.io, making it easy to use in any Rust project.
For Maintainers
To publish a new version to crates.io:
-
Ensure you have a crates.io account and are logged in:
# First time only: Create account at https://crates.io/ and get API token -
Update the version in
Cargo.tomlfollowing Semantic Versioning:[] = "0.1.1" # Increment as needed -
Update CHANGELOG (if exists) with version changes and release notes.
-
Ensure all tests pass (including doc tests):
-
Run code quality checks:
# Format code # Run clippy with pedantic lints -
Build and test both library and server modes:
# Test library-only mode (minimal dependencies) # Test with server features (default) # Test the example -
Do a dry-run publish to verify package contents:
Review the output to ensure:
- All necessary files are included
- No sensitive files are accidentally included
- Package size is reasonable
-
Create a git tag for the version:
-
Publish to crates.io:
Note: Publishing is permanent - you cannot delete or replace a published version.
-
Verify the published crate:
# Check on crates.io # Test installing from crates.io
For Users
Once published, users can easily add text-to-cypher to their projects:
[]
# Library-only usage (no REST server)
= { = "0.1", = false }
# With REST server capabilities
= "0.1"
The library is published with:
- default features: Includes REST API server, Swagger UI, MCP server
- no-default-features: Core library only (schema discovery, query generation, execution)
Troubleshooting
Common Issues
Services not starting:
- Ensure all required ports (6379, 3000, 8080, 3001) are available
- Check that
DEFAULT_MODELandDEFAULT_KEYare properly configured - View logs:
docker logs -f <container-name>
MCP Server not starting:
- Verify both
DEFAULT_MODELandDEFAULT_KEYenvironment variables are set - For local builds, ensure
.envfile exists in the working directory
FalkorDB connection issues:
- The integrated FalkorDB automatically starts with the container
- No external FalkorDB instance needed when using the Docker image
- Database is accessible at
localhost:6379(Redis protocol)
Web interface not accessible:
- Ensure port 3000 is properly mapped:
-p 3000:3000 - Try accessing
http://localhost:3000directly - Check firewall settings if running on a remote server
Getting Help
- API Documentation:
http://localhost:8080/swagger-ui/ - Web Interface:
http://localhost:3000for graph exploration - Logs: Use
docker logs -f <container-name>to view all service logs - Issues: Report problems at GitHub Issues
Dynamic Cypher Skills
Text-to-cypher supports loading FalkorDB-specific Cypher expertise from external skill files at runtime. This allows the LLM to generate better, more efficient Cypher queries by leveraging domain-specific knowledge about FalkorDB's query engine.
How It Works
The system uses a two-tier architecture for skill loading:
┌─────────────────────────────────────────────────────────────┐
│ System Prompt │
│ ┌───────────────────────────────────────────────────────┐ │
│ │ Tier 1: Skill Catalog (compact) │ │
│ │ - apply-cypher-limitations: Avoid FalkorDB pitfalls │ │
│ │ - use-parameters: Use parameterized queries │ │
│ │ - fulltext-search: Full-text search syntax │ │
│ └───────────────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────────────┘
│
LLM decides it needs
more detail on a skill
│
▼
┌─────────────────────────────────────────────────────────────┐
│ Tier 2: Tool Call → read_skill("apply-cypher-limitations") │
│ ┌───────────────────────────────────────────────────────┐ │
│ │ Full skill content returned: │ │
│ │ # Apply Cypher Limitations │ │
│ │ - <> and != are NOT index-accelerated │ │
│ │ - Use positive predicates when possible │ │
│ │ - Self-referencing relationships are directed... │ │
│ └───────────────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────────────┘
Tier 1 (Catalog): A compact list of skill names and descriptions is injected into the system prompt. This gives the LLM awareness of available expertise without bloating the context window.
Tier 2 (Tool Calling): When the LLM determines it needs detailed guidance for a particular query, it calls the read_skill tool to load the full skill content on-demand. This keeps prompts lean for simple queries while enabling deep expertise for complex ones.
Provider Support
Tool calling (Tier 2) is supported by these providers:
| Provider | Tool Calling | Behavior |
|---|---|---|
| OpenAI | ✅ | On-demand skill loading via read_skill tool |
| Anthropic | ✅ | On-demand skill loading via read_skill tool |
| Gemini | ✅ | On-demand skill loading via read_skill tool |
| xAI | ✅ | On-demand skill loading via read_skill tool |
| DeepSeek | ✅ | On-demand skill loading via read_skill tool |
| Groq | ❌ | All skill content injected directly into prompt |
| Ollama | ❌ | All skill content injected directly into prompt |
| Cohere | ❌ | All skill content injected directly into prompt |
For providers without tool support, the system automatically falls back to injecting all skill content directly into the system prompt. Every provider benefits from skills — only the delivery mechanism differs.
Advantages & Limitations
Advantages:
- 🎯 Smaller prompts — Only skill names/descriptions in the base prompt; full content loaded on-demand
- 🔧 Maintainable — Skills live in plain markdown files, easy to add/edit/remove without code changes
- 🔌 Pluggable — Load different skill sets for different deployments or use cases
- 🚀 Better queries — LLM generates FalkorDB-optimized Cypher by leveraging domain-specific knowledge
- ⬇️ Backward compatible — Without
SKILLS_DIR, behavior is identical to the base system - 🔄 Universal fallback — Providers without tool support still get all skill content (just via prompt injection)
Limitations:
- 📡 Extra LLM round-trips — Tool calling adds 1-3 additional API calls when skills are requested
- 💰 Increased token usage — Skill content adds tokens to the context (either via tools or prompt injection)
- 📁 Requires skill files — You need to provide/maintain the skill directory (see FalkorDB/skills for ready-made skills)
- 🤖 Provider-dependent — Tool calling quality varies by provider; some models may over-request or under-request skills
Setting Up Skills
Docker (zero setup required)
The Docker image comes with FalkorDB Cypher skills pre-installed at /app/skills. Skills are enabled by default — no configuration needed:
# Skills are already baked in — just run!
To override with custom skills, mount your own directory:
Release Docker builds require a full FalkorDB/skills commit SHA. Use ./docker-build.sh --skills-ref <commit-sha> or rebuild manually with --build-arg SKILLS_REF=<commit-sha>; reserve SKILLS_REF=main for local/dev builds only.
Development (using just)
The easiest way to set up skills locally:
# Install just: https://github.com/casey/just#installation
# Download latest FalkorDB Cypher skills
# Or pin to a specific version
# Start dev server (auto-downloads skills if missing)
# List available skills
Manual setup
# Download skills via curl
|
# Point the server at them
Skill file format
Each skill lives in its own directory with a skill.md file containing YAML frontmatter and markdown body:
skills/
apply-cypher-limitations/
skill.md
use-parameters/
skill.md
fulltext-search/
skill.md
A skill.md file looks like:
name: Apply Cypher Limitations
description: Avoid FalkorDB-specific Cypher pitfalls and write optimized queries
- --
Instead of: `MATCH (n:Person) WHERE n.age <> 30 RETURN n`
Prefer: `MATCH (n:Person) WHERE n.age > 30 OR n.age < 30 RETURN n`
Library Usage with Skills
Basic — load skills from a directory:
use ;
use Path;
async
Advanced — use the lower-level API with skills:
use ;
use Path;
async
Without skills — everything works exactly as before:
// No skills, no changes needed
let client = new;
let response = client.text_to_cypher.await?;
Recent Improvements
This project implements best practices from current research and industry leaders:
Query Quality & Reliability
- Query Validation: Automatic syntax and safety validation before execution
- Self-Healing: Failed queries are automatically regenerated with error feedback
- Enhanced Schema: Schema discovery now includes example values for better context
Based on Research From
- Neo4j Labs Text2Cypher - Industry best practices
- arXiv 2412.10064 - Text2Cypher academic research
- GraphRAG - Microsoft's approach
- MDPI Research - Reinforcement learning techniques
Documentation
- Improvements Guide - Detailed technical improvements
- Best Practices - Usage guidelines and optimization tips
License
This project is licensed under the MIT License.