Adding a New Graph Database to cognee
This guide describes how to integrate a new graph database engine into cognee.Repository Options
Cognee used both the core and the community repositories to host graph-database adapters. 🚨 From now on every graph-database adapter – except Kuzu – will live in the cognee-community repository.NetworkX has already been migrated and the remaining adapters will follow shortly.
Therefore all new adapter contributions must target the community repository.The core repository will keep only the built-in Kuzu integration.
For Community Repository
To add a new adapter to cognee-community:- Fork and clone the cognee-community repository
- Create your adapter in
packages/<engine_name>/cognee_community_graph_adapter_<engine_name>/ - Inside that directory add
__init__.py,<engine_name>_adapter.py, andregister.py(see the Redis example). - At the package root
packages/<engine_name>/add__init__.py,pyproject.toml, andREADME.md. - Submit a pull request to the community repository
Why cognee-community?
cognee-community is the extension hub for Cognee.Anything that is not part of the core lives here—adapters for third-party databases, pipelines, community contributed additional tasks, etc.
Placing your adapter in this repository means:
- Your code is released under the community license and can evolve independently of the core.
- It can be installed with
pip install cognee-community-graph-adapter-(engine_mane)without pulling in heavyweight drivers for users who don’t need them. For example, for NetworkX it ispip install cognee-community-graph-adapter-networkx - These packages can be called with cognee core package using the registration step described below.
packages/* in the community repo—each sub-folder represents a separate provider implemented in exactly the way you are about to do.
1. Implement the Adapter
File: packages/graph/<engine_name>/cognee_community_graph_adapter_<engine_name>/<engine_name>_adapter.py
Your adapter must subclass GraphDBInterface, implementing all required CRUD and utility methods (e.g., add_node, add_edge, extract_node, etc.). Here is a sample skeleton with placeholders:
GraphDBInterface. Reference the KuzuAdapter or the Neo4jAdapter for a more comprehensive example.
2. Test with a Dedicated Script
Your contribution should have an example showcasing how this integration should be configured and used.File: packages/graph/engine_name/examples/example.pyCreate a script that loads cognee and the integration package, registers it to use your new
<engine_name> provider, and runs basic usage checks (e.g., adding data, searching, pruning). For example:
3. Create a Test Workflow
File: .github/workflows/engine_name/test_engine_name.ymlCreate a GitHub Actions workflow to run your integration tests. This ensures any pull requests that modify your new engine (or the shared graph code) will be tested automatically. See an example here.
- Rename
<engine_name>appropriately. - Ensure your
pyproject.tomlhas an extras entry for any new dependencies.
5. Poetry Extras
If your new graph engine requires a special Python client or system libraries, update:pyproject.toml:
6. Final Checklist
-
Implement your
<EngineName>Adapterinpackages/<engine_name>/cognee_community_graph_adapter_<engine_name>/<engine_name>_adapter.py. -
Add a register helper (
register.py) and call it before configuring Cognee: -
Create a test or example script
example.py. -
Create a test workflow:
.github/workflows/engine_name/test_<engine_name>.yml. -
Add required dependencies to
pyproject.tomlextras. - Open a PR to verify that your new integration passes CI.