Drop-in LangChain integration for Neruva. NeruvaChatMessageHistory (BaseChatMessageHistory) auto-pipes turns into the substrate. NeruvaContextRetriever (BaseRetriever) federates Records + KG. Substrate v0.5.7: typed-shape context, tenant PII rules, depth-unlimited nested-belief, counterfactuals, EFE planner, continual learning. Deterministic, bit-identical replay. Sub-100ms p95. Works with RunnableWithMessageHistory + RetrievalQA.
Project description
neruva-langchain
Drop-in LangChain integration for Neruva agent memory. Three wrappers cover the common LangChain plug points: chat history, conversation memory, and document retriever.
pip install neruva-langchain
What's new in the substrate (v0.5.7, May 2026)
The substrate this adapter wraps has gained a lot since the last release.
All of it is available via the same agent_* API the wrappers already
call, so existing code keeps working — new capabilities just become
available.
- Deterministic replay — every query is bit-identical across reruns from the same seed. Replay any past state for audit or debugging.
- Typed-shape context — pull structured JSON from records with
per-field citations.
{question, shape: {field: type}}→ typed result without an LLM at query time. Natural fit for tool-calling chains that need a specific output schema. - Tenant-specific PII rules — register your custom ID formats (employee codes, patient codes, order IDs) from 3-5 examples. The substrate redacts them automatically. Sub-microsecond per span.
- Depth-unlimited nested-belief tracking — store and retrieve
chains like
Alice → Bob → Carol thinks Xat any depth, with inner-position-swap rejection. - Counterfactual rollouts — "what if action k had been a' instead?" Replay an action sequence with one step substituted.
- Active inference planning — score candidate action sequences by KL distance to a goal-marginal. Caller-owned dynamics.
- Continual K-gram learning — provable no-forgetting via
integer-add commutativity; repeated
train()calls accumulate.
NeruvaChatMessageHistory
Auto-records every turn into the Neruva Records substrate. Drop into any
LangChain primitive that accepts a BaseChatMessageHistory:
from neruva_langchain import NeruvaChatMessageHistory
history = NeruvaChatMessageHistory(
api_key="nv_...", # or env NERUVA_API_KEY
namespace="user_alice", # one per user / session
)
history.add_user_message("My name is Alice and I live in Toronto.")
history.add_ai_message("Nice to meet you, Alice!")
# Later — even after process restart, substrate-backed:
print(history.messages)
Use with RunnableWithMessageHistory (modern pattern)
from langchain_anthropic import ChatAnthropic
from langchain_core.prompts import ChatPromptTemplate, MessagesPlaceholder
from langchain_core.runnables.history import RunnableWithMessageHistory
from neruva_langchain import NeruvaChatMessageHistory
prompt = ChatPromptTemplate.from_messages([
("system", "You are a helpful assistant."),
MessagesPlaceholder(variable_name="history"),
("human", "{input}"),
])
chain = prompt | ChatAnthropic(model="claude-opus-4-7")
chain_with_history = RunnableWithMessageHistory(
chain,
lambda session_id: NeruvaChatMessageHistory(namespace=session_id),
input_messages_key="input",
history_messages_key="history",
)
chain_with_history.invoke(
{"input": "What did I tell you about my project last week?"},
config={"configurable": {"session_id": "user_alice"}},
)
NeruvaContextRetriever
BaseRetriever for RetrievalQA chains. Returns Document objects
sourced from federated agent_recall:
from neruva_langchain import NeruvaContextRetriever
from langchain.chains import RetrievalQA
from langchain_anthropic import ChatAnthropic
retriever = NeruvaContextRetriever(
api_key="nv_...",
namespaces=["session_a", "session_b"], # multi-session fan-out
)
qa = RetrievalQA.from_chain_type(
llm=ChatAnthropic(model="claude-opus-4-7"),
retriever=retriever,
)
qa.invoke("Where does Alice work?")
Why use Neruva instead of LangChain's built-in memory?
| Feature | LangChain default | Neruva |
|---|---|---|
| Persists across process restart | Manual setup | Built-in (GCS-backed) |
| Cross-session recall | No | Yes via namespaces=[...] |
| Fact extraction (KG) | No | Auto (hd_kg_extraction_prompt + caller LLM) |
| GDPR forget by user | Manual | user_id= auto-folds, one-call forget |
| Determinism / replayability | No | Bit-identical from seed |
| Portability | Pickle | .neruva zip container |
Get an API key · Docs · Status
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file neruva_langchain-0.1.2.tar.gz.
File metadata
- Download URL: neruva_langchain-0.1.2.tar.gz
- Upload date:
- Size: 9.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ed4388819a0fc924f0e10e005b991f99ff3ba1c6afaca3bfec8cf9b0fb22d36
|
|
| MD5 |
9d50c301a58ef8944fd42ad69ff4b250
|
|
| BLAKE2b-256 |
63dc75161e94d785f4c693f43f92958d1789f8d647bfa2159c80fac573660151
|
File details
Details for the file neruva_langchain-0.1.2-py3-none-any.whl.
File metadata
- Download URL: neruva_langchain-0.1.2-py3-none-any.whl
- Upload date:
- Size: 9.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ba911eac5280d92fa5d8878039ecd6ccf79d2408cc447d1cf015e2f25d1ff6f2
|
|
| MD5 |
7bc6b5f08d3ea60a511432174a63540c
|
|
| BLAKE2b-256 |
b9dab8a20d8baf32db6dc6aa25df11cfddac672ce8c95b55f5935fa6428a0631
|