Files
blackroad/scripts/claude-group-chat.sh
Alexa Amundson 78fbe80f2a Initial monorepo — everything BlackRoad in one place
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
2026-03-14 17:08:41 -05:00

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