fix: update references to openclaw-true-recall-blocks, add upgrade docs, add backfill script
This commit is contained in:
107
README.md
107
README.md
@@ -61,7 +61,7 @@ true-recall-base (REQUIRED)
|
|||||||
│ ├── Curator extracts gems → gems_tr
|
│ ├── Curator extracts gems → gems_tr
|
||||||
│ └── Plugin injects gems into prompts
|
│ └── Plugin injects gems into prompts
|
||||||
│
|
│
|
||||||
└──▶ true-recall-blocks (ADDON)
|
└──▶ openclaw-true-recall-blocks (ADDON)
|
||||||
├── Topic clustering → topic_blocks_tr
|
├── Topic clustering → topic_blocks_tr
|
||||||
└── Contextual block retrieval
|
└── Contextual block retrieval
|
||||||
|
|
||||||
@@ -654,3 +654,108 @@ curl -s "http://10.0.0.40:6333/collections/memories_tr/points/scroll" \
|
|||||||
---
|
---
|
||||||
|
|
||||||
**Prerequisite for:** TrueRecall Gems, TrueRecall Blocks
|
**Prerequisite for:** TrueRecall Gems, TrueRecall Blocks
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Upgrading from Older Versions
|
||||||
|
|
||||||
|
This section covers full upgrades from older TrueRecall Base installations to the current version.
|
||||||
|
|
||||||
|
### Version History
|
||||||
|
|
||||||
|
| Version | Key Changes |
|
||||||
|
|---------|-------------|
|
||||||
|
| **v1.0** | Initial release - basic watcher |
|
||||||
|
| **v1.1** | Session detection improvements |
|
||||||
|
| **v1.2** | Priority-based session detection, lock file validation, backfill script |
|
||||||
|
| **v1.3** | Offset persistence (resumes from last position), fixes duplicate processing |
|
||||||
|
| **v1.4** | Current version - Memory backfill fix (Qdrant ids field), improved error handling |
|
||||||
|
|
||||||
|
### Upgrade Paths
|
||||||
|
|
||||||
|
#### From v1.0/v1.1/v1.2 → v1.4 (Current)
|
||||||
|
|
||||||
|
If you have an older installation, follow these steps:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Step 1: Backup existing configuration
|
||||||
|
cp /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py.bak.$(date +%Y%m%d)
|
||||||
|
|
||||||
|
cp /root/.openclaw/workspace/skills/qdrant-memory/scripts/config.json /root/.openclaw/workspace/skills/qdrant-memory/scripts/config.json.bak.$(date +%Y%m%d)
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Step 2: Stop the watcher
|
||||||
|
pkill -f realtime_qdrant_watcher
|
||||||
|
# Verify stopped
|
||||||
|
ps aux | grep realtime_qdrant_watcher
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Step 3: Download latest files (choose one source)
|
||||||
|
|
||||||
|
# Option A: From GitLab (recommended)
|
||||||
|
curl -o /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py https://gitlab.com/mdkrush/openclaw-true-recall-base/-/raw/master/watcher/realtime_qdrant_watcher.py
|
||||||
|
|
||||||
|
# Option B: From Gitea
|
||||||
|
curl -o /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py http://10.0.0.61:3000/SpeedyFoxAi/openclaw-true-recall-base/raw/branch/master/watcher/realtime_qdrant_watcher.py
|
||||||
|
|
||||||
|
# Option C: From local clone (if you cloned the repo)
|
||||||
|
cp /path/to/openclaw-true-recall-base/watcher/realtime_qdrant_watcher.py /root/.openclaw/workspace/skills/qdrant-memory/scripts/
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Step 4: Start the watcher
|
||||||
|
python3 /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py --daemon
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Step 5: Verify installation
|
||||||
|
ps aux | grep realtime_qdrant_watcher
|
||||||
|
curl -s "http://10.0.0.40:6333/collections/memories_tr/points/scroll" -H "Content-Type: application/json" -d '{"limit": 3}' | jq '.result.points[0].payload.timestamp'
|
||||||
|
```
|
||||||
|
|
||||||
|
### Upgrading with Git (If You Cloned the Repository)
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Navigate to your clone
|
||||||
|
cd /path/to/openclaw-true-recall-base
|
||||||
|
git pull origin master
|
||||||
|
|
||||||
|
# Stop current watcher
|
||||||
|
pkill -f realtime_qdrant_watcher
|
||||||
|
|
||||||
|
# Copy updated files to OpenClaw
|
||||||
|
cp watcher/realtime_qdrant_watcher.py /root/.openclaw/workspace/skills/qdrant-memory/scripts/
|
||||||
|
cp scripts/backfill_memory.py /root/.openclaw/workspace/skills/qdrant-memory/scripts/
|
||||||
|
|
||||||
|
# Restart the watcher
|
||||||
|
python3 /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py --daemon
|
||||||
|
|
||||||
|
# Verify
|
||||||
|
ps aux | grep realtime_qdrant_watcher
|
||||||
|
```
|
||||||
|
|
||||||
|
### Backfilling Historical Memories (Optional)
|
||||||
|
|
||||||
|
```bash
|
||||||
|
python3 /root/.openclaw/workspace/skills/qdrant-memory/scripts/backfill_memory.py
|
||||||
|
```
|
||||||
|
|
||||||
|
### Verifying Your Upgrade
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# 1. Check watcher is running
|
||||||
|
ps aux | grep realtime_qdrant_watcher
|
||||||
|
|
||||||
|
# 2. Verify source is "true-recall-base"
|
||||||
|
curl -s "http://10.0.0.40:6333/collections/memories_tr/points/scroll" -H "Content-Type: application/json" -d '{"limit": 1}' | jq '.result.points[0].payload.source'
|
||||||
|
|
||||||
|
# 3. Check date coverage
|
||||||
|
curl -s "http://10.0.0.40:6333/collections/memories_tr/points/scroll" -H "Content-Type: application/json" -d '{"limit": 10000}' | jq '[.result.points[].payload.date] | unique | sort'
|
||||||
|
```
|
||||||
|
|
||||||
|
Expected output:
|
||||||
|
- Source: `"true-recall-base"`
|
||||||
|
- Dates: Array from oldest to newest memory
|
||||||
|
|||||||
29
install.sh
29
install.sh
@@ -96,3 +96,32 @@ echo " curl -s http://$QDRANT_IP/collections/memories_tr | jq '.result.points_c
|
|||||||
echo ""
|
echo ""
|
||||||
echo "View logs:"
|
echo "View logs:"
|
||||||
echo " sudo journalctl -u mem-qdrant-watcher -f"
|
echo " sudo journalctl -u mem-qdrant-watcher -f"
|
||||||
|
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=========================================="
|
||||||
|
echo "UPGRADING FROM OLDER VERSION"
|
||||||
|
echo "=========================================="
|
||||||
|
echo ""
|
||||||
|
echo "If you already have TrueRecall Base installed:"
|
||||||
|
echo ""
|
||||||
|
echo "1. Stop the watcher:"
|
||||||
|
echo " pkill -f realtime_qdrant_watcher"
|
||||||
|
echo ""
|
||||||
|
echo "2. Backup current files:"
|
||||||
|
echo " cp /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py \"
|
||||||
|
echo " /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py.bak"
|
||||||
|
echo ""
|
||||||
|
echo "3. Copy updated files:"
|
||||||
|
echo " cp watcher/realtime_qdrant_watcher.py \"
|
||||||
|
echo " /root/.openclaw/workspace/skills/qdrant-memory/scripts/"
|
||||||
|
echo " cp scripts/backfill_memory.py \"
|
||||||
|
echo " /root/.openclaw/workspace/skills/qdrant-memory/scripts/"
|
||||||
|
echo ""
|
||||||
|
echo "4. Restart watcher:"
|
||||||
|
echo " python3 /root/.openclaw/workspace/skills/qdrant-memory/scripts/realtime_qdrant_watcher.py --daemon"
|
||||||
|
echo ""
|
||||||
|
echo "5. Verify:"
|
||||||
|
echo " ps aux | grep realtime_qdrant_watcher"
|
||||||
|
echo ""
|
||||||
|
echo "For full upgrade instructions, see README.md"
|
||||||
|
|||||||
67
scripts/backfill_memory.py
Normal file
67
scripts/backfill_memory.py
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
"""Backfill memory files to Qdrant memories_tr collection."""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import json
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
QDRANT_URL = "http://10.0.0.40:6333"
|
||||||
|
MEMORY_DIR = "/root/.openclaw/workspace/memory"
|
||||||
|
|
||||||
|
def get_memory_files():
|
||||||
|
"""Get all memory files sorted by date."""
|
||||||
|
files = []
|
||||||
|
for f in os.listdir(MEMORY_DIR):
|
||||||
|
if f.startswith("2026-") and f.endswith(".md"):
|
||||||
|
date = f.replace(".md", "")
|
||||||
|
files.append((date, f))
|
||||||
|
return sorted(files, key=lambda x: x[0])
|
||||||
|
|
||||||
|
def backfill_file(date, filename):
|
||||||
|
"""Backfill a single memory file to Qdrant."""
|
||||||
|
filepath = os.path.join(MEMORY_DIR, filename)
|
||||||
|
with open(filepath, 'r') as f:
|
||||||
|
content = f.read()
|
||||||
|
|
||||||
|
# Truncate if too long for payload
|
||||||
|
payload = {
|
||||||
|
"content": content[:50000], # Limit size
|
||||||
|
"date": date,
|
||||||
|
"source": "memory_file",
|
||||||
|
"curated": False,
|
||||||
|
"role": "system",
|
||||||
|
"user_id": "rob"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Add to Qdrant
|
||||||
|
import requests
|
||||||
|
point_id = hash(f"memory_{date}") % 10000000000
|
||||||
|
resp = requests.post(
|
||||||
|
f"{QDRANT_URL}/collections/memories_tr/points",
|
||||||
|
json={
|
||||||
|
"points": [{
|
||||||
|
"id": point_id,
|
||||||
|
"payload": payload
|
||||||
|
}],
|
||||||
|
"ids": [point_id]
|
||||||
|
}
|
||||||
|
)
|
||||||
|
return resp.status_code == 200
|
||||||
|
|
||||||
|
def main():
|
||||||
|
files = get_memory_files()
|
||||||
|
print(f"Found {len(files)} memory files to backfill")
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
for date, filename in files:
|
||||||
|
print(f"Backfilling {filename}...", end=" ")
|
||||||
|
if backfill_file(date, filename):
|
||||||
|
print("✓")
|
||||||
|
count += 1
|
||||||
|
else:
|
||||||
|
print("✗")
|
||||||
|
|
||||||
|
print(f"\nBackfilled {count}/{len(files)} files")
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
@@ -19,7 +19,7 @@ true-recall-base (REQUIRED FOUNDATION)
|
|||||||
│ ├── Curator extracts atomic gems
|
│ ├── Curator extracts atomic gems
|
||||||
│ └── Plugin injects gems as context
|
│ └── Plugin injects gems as context
|
||||||
│
|
│
|
||||||
└──▶ true-recall-blocks (OPTIONAL ADDON)
|
└──▶ openclaw-true-recall-blocks (OPTIONAL ADDON)
|
||||||
├── Topic clustering
|
├── Topic clustering
|
||||||
└── Block-based retrieval
|
└── Block-based retrieval
|
||||||
```
|
```
|
||||||
@@ -82,4 +82,4 @@ curl -s http://10.0.0.40:6333/collections/memories_tr | jq '.result.points_count
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
*Next: Install true-recall-gems OR true-recall-blocks (not both)*
|
*Next: Install true-recall-gems OR openclaw-true-recall-blocks (not both)*
|
||||||
|
|||||||
Reference in New Issue
Block a user