hypabase

mcp
Security Audit
Pass
Health Pass
  • License — License: Apache-2.0
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Community trust — 11 GitHub stars
Code Pass
  • Code scan — Scanned 12 files during light audit, no dangerous patterns found
Permissions Pass
  • Permissions — No dangerous permissions requested
Purpose
This is a Python library and MCP server that provides hypergraph data structures with built-in provenance tracking and SQLite persistence. It enables users and AI agents to store, query, and manage complex, multi-entity relationships locally.

Security Assessment
Overall Risk: Low. The tool operates entirely locally, using SQLite for data persistence without making external network requests or executing arbitrary shell commands. A light code scan of 12 files found no dangerous patterns, hardcoded secrets, or requests for elevated system permissions. Because it is designed as an AI agent memory server, it processes and stores the data fed to it locally; therefore, standard caution should be applied regarding what information you allow the AI to remember.

Quality Assessment
The project is actively maintained, with its most recent push occurring today. It utilizes the permissive Apache-2.0 license, making it suitable for both personal and commercial use. While it is a smaller tool with 11 GitHub stars, its availability on PyPI, inclusion of continuous integration (CI), and provision of both a CLI and clear documentation indicate a solid, usable project structure.

Verdict
Safe to use.
SUMMARY

A Python hypergraph library with provenance and SQLite persistence.

README.md

Hypabase

CI
PyPI
Python
License
Downloads

A Python hypergraph library with provenance and SQLite persistence.

Install

uv add hypabase

Quick example

from hypabase import Hypabase

hb = Hypabase("my.db")

# One edge connecting five entities
hb.edge(
    ["dr_smith", "patient_123", "aspirin", "headache", "mercy_hospital"],
    type="treatment",
    source="clinical_records",
    confidence=0.95,
)

# Query edges involving a node
hb.edges(containing=["patient_123"])

# Find paths between entities
hb.paths("dr_smith", "mercy_hospital")

Features

  • Hyperedges — an edge connects 2+ nodes in a single relationship
  • Provenance — every edge carries source and confidence
  • SQLite persistence — data persists to a local file automatically
  • O(1) vertex-set lookup — find edges by their exact node set
  • Namespace isolation.database("name") for scoped views in a single file
  • Provenance queries — filter by source and min_confidence, summarize with sources()
  • Memory MCP server — 7 tools for AI agent persistent memory (remember, recall, forget, consolidate, connections, who_knows_what, resolve_contradiction)
  • CLIhypabase init, hypabase node, hypabase edge, hypabase query

Provenance

Every edge carries source and confidence:

hb.edge(
    ["patient_123", "aspirin", "ibuprofen"],
    type="drug_interaction",
    source="clinical_decision_support_v3",
    confidence=0.92,
)

# Bulk provenance via context manager
with hb.context(source="schema_analysis", confidence=0.9):
    hb.edge(["a", "b"], type="fk")
    hb.edge(["b", "c"], type="fk")

# Query by provenance
hb.edges(source="clinical_decision_support_v3")
hb.edges(min_confidence=0.9)

# Overview of all sources
hb.sources()

Namespace isolation

Isolate data into separate namespaces within a single file:

hb = Hypabase("knowledge.db")

drugs = hb.database("drugs")
sessions = hb.database("sessions")

drugs.node("aspirin", type="drug")
sessions.node("s1", type="session")

drugs.nodes()     # -> [aspirin]
sessions.nodes()  # -> [s1]

What is a hypergraph?

In a regular graph, an edge connects exactly two nodes. In a hypergraph, a single edge — called a hyperedge — can connect any number of nodes at once.

Consider a medical event: Dr. Smith prescribes aspirin to Patient 123 for a headache at Mercy Hospital. In a traditional graph, you'd split this into binary edges — doctor-patient, doctor-drug, patient-hospital — and the fact that they belong to one event becomes an inference, not a structure. A hypergraph stores this natively: one edge connecting all five entities.

This matters because real-world relationships often involve more than two things. A paper has three or four authors, not one. A transaction involves a buyer, a seller, a product, and a payment method. A chemical reaction has reagents and products on both sides. Forcing these into pairs means the grouping becomes implicit.

Why provenance?

When relationships come from different sources — manual entry, LLM extraction, sensor data, clinical records — you need to know where each one came from and how much you trust it. Hypabase tracks this with two fields on every edge: source (a string identifying the origin) and confidence (a float from 0 to 1). You can filter queries by these fields and get a summary of all sources in your graph with hb.sources().

Where hypergraphs show up

  • Knowledge graphs — representing complex real-world relationships without decomposition
  • Agent memory — structured, queryable memory for AI agents that persists across sessions
  • Biomedical data — drug interactions, clinical events, molecular pathways
  • RAG pipelines — storing extracted relationships for retrieval-augmented generation
  • Supply chains, collaboration networks, and anywhere relationships involve more than two things

The broader idea has roots in AI research going back to OpenCog's AtomSpace, which uses hypergraph-like structures to represent knowledge for AGI. More recent work applies hypergraphs specifically to retrieval and reasoning:

MCP server

Hypabase includes a Memory MCP server with 7 tools so AI agents can use it as structured, persistent memory. Works with Claude Code, Claude Desktop, Cursor, Windsurf, and any MCP-compatible client.

uv add hypabase
hypabase-memory

CLI

uv add hypabase
hypabase init
hypabase node dr_smith --type doctor
hypabase edge dr_smith patient_123 aspirin --type treatment --source clinical_records
hypabase query --containing dr_smith
hypabase stats

Documentation

docs.hypabase.app

License

Apache 2.0

Reviews (0)

No results found