bin/ 230 CLI tools (ask-*, br-*, agent-*, roadid, carpool) scripts/ 99 automation scripts fleet/ Node configs and deployment workers/ Cloudflare Worker sources (roadpay, road-search, squad webhooks) roadc/ RoadC programming language roadnet/ Mesh network (5 APs, WireGuard) operator/ Memory system scripts config/ System configs dotfiles/ Shell configs docs/ Documentation BlackRoad OS — Pave Tomorrow. RoadChain-SHA2048: d1a24f55318d338b RoadChain-Identity: alexa@sovereign RoadChain-Full: d1a24f55318d338b24b60bad7be39286379c76ae5470817482100cb0ddbbcb97e147d07ac7243da0a9f0363e4e5c833d612b9c0df3a3cd20802465420278ef74875a5b77f55af6fe42a931b8b635b3d0d0b6bde9abf33dc42eea52bc03c951406d8cbe49f1a3d29b26a94dade05e9477f34a7d4d4c6ec4005c3c2ac54e73a68440c512c8e83fd9b1fe234750b898ef8f4032c23db173961fe225e67a0432b5293a9714f76c5c57ed5fdf35b9fb40fd73c03ebf88b7253c6a0575f5afb6a6b49b3bda310602fb1ef676859962dad2aebbb2875814b30eee0a8ba195e482d4cbc91d8819e7f38f6db53e8063401649c77bb994371473cabfb917fb53e8cbe73d60
82 lines
2.4 KiB
Bash
Executable File
82 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
# BlackRoad Claude Group Chat System via [MEMORY]
|
|
|
|
CHAT_DB="$HOME/.claude-group-chat.db"
|
|
|
|
init_chat() {
|
|
sqlite3 "$CHAT_DB" <<EOF
|
|
CREATE TABLE IF NOT EXISTS messages (
|
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
from_agent TEXT NOT NULL,
|
|
to_agents TEXT,
|
|
message TEXT NOT NULL,
|
|
timestamp DATETIME DEFAULT CURRENT_TIMESTAMP,
|
|
read INTEGER DEFAULT 0,
|
|
thread_id TEXT
|
|
);
|
|
CREATE INDEX IF NOT EXISTS idx_timestamp ON messages(timestamp);
|
|
CREATE INDEX IF NOT EXISTS idx_from ON messages(from_agent);
|
|
CREATE INDEX IF NOT EXISTS idx_thread ON messages(thread_id);
|
|
EOF
|
|
echo "💬 Group chat initialized!"
|
|
}
|
|
|
|
send_message() {
|
|
local from="$1"
|
|
local to="${2:-all}"
|
|
local message="$3"
|
|
local thread_id="${4:-general}"
|
|
|
|
sqlite3 "$CHAT_DB" <<EOF
|
|
INSERT INTO messages (from_agent, to_agents, message, thread_id)
|
|
VALUES ('$from', '$to', '$message', '$thread_id');
|
|
EOF
|
|
|
|
# Also log to [MEMORY]
|
|
~/memory-system.sh log chat "[CHAT][$from→$to] $message" "Group chat message from $from to $to in thread $thread_id" "$from"
|
|
|
|
echo "✅ Message sent from $from to $to"
|
|
}
|
|
|
|
read_messages() {
|
|
local agent="${1:-all}"
|
|
local limit="${2:-10}"
|
|
|
|
echo "💬 Recent Messages:"
|
|
echo "=================="
|
|
|
|
while IFS='|' read -r from to msg time thread; do
|
|
echo "[$time] $from → $to"
|
|
echo " 💭 $msg"
|
|
echo " 📍 Thread: $thread"
|
|
echo ""
|
|
done < <(sqlite3 "$CHAT_DB" "SELECT from_agent, to_agents, message, timestamp, thread_id FROM messages ORDER BY timestamp DESC LIMIT $limit;")
|
|
}
|
|
|
|
list_threads() {
|
|
echo "📋 Active Threads:"
|
|
sqlite3 "$CHAT_DB" "SELECT DISTINCT thread_id, COUNT(*) as msg_count FROM messages GROUP BY thread_id ORDER BY MAX(timestamp) DESC;"
|
|
}
|
|
|
|
# Main router
|
|
case "$1" in
|
|
init) init_chat ;;
|
|
send) send_message "$2" "$3" "$4" "$5" ;;
|
|
read) read_messages "$2" "$3" ;;
|
|
threads) list_threads ;;
|
|
*)
|
|
echo "💬 Claude Group Chat System"
|
|
echo ""
|
|
echo "Usage:"
|
|
echo " $0 init - Initialize chat database"
|
|
echo " $0 send <from> <to> <message> - Send a message"
|
|
echo " $0 read [agent] [limit] - Read recent messages"
|
|
echo " $0 threads - List conversation threads"
|
|
echo ""
|
|
echo "Active Agents:"
|
|
echo " - alice (Migration Architect)"
|
|
echo " - aria (Core)"
|
|
echo " - lucidia (AI with Memory)"
|
|
;;
|
|
esac
|