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
This commit is contained in:
182
scripts/blackroad-sovereign-mesh.sh
Executable file
182
scripts/blackroad-sovereign-mesh.sh
Executable file
@@ -0,0 +1,182 @@
|
||||
#!/usr/bin/env bash
|
||||
# BLACKROAD SOVEREIGN MESH - LOCAL + CLOUD
|
||||
# TRULY UNSTOPPABLE - Distributed across home AND cloud!
|
||||
|
||||
set -euo pipefail
|
||||
|
||||
# Source centralized config
|
||||
NODES_CONFIG="$HOME/.blackroad/config/nodes.sh"
|
||||
if [[ -f "$NODES_CONFIG" ]]; then
|
||||
source "$NODES_CONFIG"
|
||||
else
|
||||
echo "ERROR: Missing $NODES_CONFIG — run setup first" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Mesh-specific node lists (subset for sync)
|
||||
MESH_LOCAL="cecilia lucidia"
|
||||
MESH_CLOUD="anastasia gematria"
|
||||
MESH_ALL="$MESH_LOCAL $MESH_CLOUD"
|
||||
|
||||
# Node configurations — uses centralized registry
|
||||
get_host() {
|
||||
local node="$1"
|
||||
if [[ -n "${NODE_USER[$node]:-}" && -n "${NODE_IP[$node]:-}" ]]; then
|
||||
echo "${NODE_USER[$node]}@${NODE_IP[$node]}"
|
||||
else
|
||||
echo "unknown@0.0.0.0"
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
get_path() {
|
||||
case "$1" in
|
||||
cecilia) echo "/home/blackroad/claude" ;;
|
||||
lucidia) echo "/home/octavia/claude" ;;
|
||||
anastasia) echo "/home/blackroad/claude" ;;
|
||||
gematria) echo "/home/blackroad/claude" ;;
|
||||
*) echo "/opt/blackroad/claude" ;;
|
||||
esac
|
||||
}
|
||||
|
||||
get_type() {
|
||||
case "$1" in
|
||||
cecilia|lucidia) echo "LOCAL" ;;
|
||||
anastasia|gematria) echo "CLOUD" ;;
|
||||
*) echo "UNKNOWN" ;;
|
||||
esac
|
||||
}
|
||||
|
||||
banner() {
|
||||
echo -e "${PINK}"
|
||||
cat << 'ART'
|
||||
╔═══════════════════════════════════════════════════════════════════╗
|
||||
║ ███████╗ ██████╗ ██╗ ██╗███████╗██████╗ ███████╗██╗ ██████╗ ║
|
||||
║ ██╔════╝██╔═══██╗██║ ██║██╔════╝██╔══██╗██╔════╝██║██╔════╝ ║
|
||||
║ ███████╗██║ ██║██║ ██║█████╗ ██████╔╝█████╗ ██║██║ ███╗ ║
|
||||
║ ╚════██║██║ ██║╚██╗ ██╔╝██╔══╝ ██╔══██╗██╔══╝ ██║██║ ██║ ║
|
||||
║ ███████║╚██████╔╝ ╚████╔╝ ███████╗██║ ██║███████╗██║╚██████╔╝ ║
|
||||
║ ╚══════╝ ╚═════╝ ╚═══╝ ╚══════╝╚═╝ ╚═╝╚══════╝╚═╝ ╚═════╝ ║
|
||||
║ M E S H ║
|
||||
║ LOCAL (1.25TB) + CLOUD (69GB) = UNSTOPPABLE ║
|
||||
╚═══════════════════════════════════════════════════════════════════╝
|
||||
ART
|
||||
echo -e "${RESET}"
|
||||
}
|
||||
|
||||
check_all() {
|
||||
banner
|
||||
echo -e "${AMBER}Checking ALL nodes (Local + Cloud)...${RESET}\n"
|
||||
|
||||
echo -e "${BLUE}LOCAL NODES:${RESET}"
|
||||
for node in $MESH_LOCAL; do
|
||||
host=$(get_host "$node")
|
||||
if ssh -o ConnectTimeout=3 -o BatchMode=yes "$host" "echo ok" &>/dev/null; then
|
||||
echo -e " ${GREEN}●${RESET} $node - ONLINE"
|
||||
else
|
||||
echo -e " ${PINK}○${RESET} $node - offline"
|
||||
fi
|
||||
done
|
||||
|
||||
echo -e "\n${VIOLET}CLOUD NODES:${RESET}"
|
||||
for node in $MESH_CLOUD; do
|
||||
host=$(get_host "$node")
|
||||
if ssh -o ConnectTimeout=5 -o BatchMode=yes "$host" "echo ok" &>/dev/null; then
|
||||
echo -e " ${GREEN}●${RESET} $node - ONLINE"
|
||||
else
|
||||
echo -e " ${PINK}○${RESET} $node - offline"
|
||||
fi
|
||||
done
|
||||
echo
|
||||
}
|
||||
|
||||
sync_all() {
|
||||
banner
|
||||
echo -e "${AMBER}Syncing to ALL nodes...${RESET}\n"
|
||||
|
||||
for node in $MESH_ALL; do
|
||||
host=$(get_host "$node")
|
||||
path=$(get_path "$node")
|
||||
type=$(get_type "$node")
|
||||
|
||||
echo -e "${BLUE}→ [$type] $node...${RESET}"
|
||||
if ssh -o ConnectTimeout=5 -o BatchMode=yes "$host" "echo ok" &>/dev/null; then
|
||||
# Sync config (smaller, goes everywhere)
|
||||
rsync -avz --delete ~/.claude/ "$host:$path/config/" 2>/dev/null
|
||||
|
||||
# Sync memory (full sync to local, journals only to cloud)
|
||||
if [ "$type" = "LOCAL" ]; then
|
||||
rsync -avz ~/.blackroad/memory/ "$host:$path/time/memory/" 2>/dev/null
|
||||
else
|
||||
# Cloud gets just journals (smaller footprint)
|
||||
rsync -avz ~/.blackroad/memory/journals/ "$host:$path/time/journals/" 2>/dev/null
|
||||
fi
|
||||
echo -e " ${GREEN}✓${RESET} $node synced"
|
||||
else
|
||||
echo -e " ${PINK}✗${RESET} $node unreachable"
|
||||
fi
|
||||
done
|
||||
|
||||
echo -e "\n${GREEN}═══ SOVEREIGN MESH SYNC COMPLETE ═══${RESET}"
|
||||
}
|
||||
|
||||
status_all() {
|
||||
banner
|
||||
echo -e "${AMBER}Storage Status - All Nodes:${RESET}\n"
|
||||
|
||||
total_available=0
|
||||
|
||||
for node in $MESH_ALL; do
|
||||
host=$(get_host "$node")
|
||||
path=$(get_path "$node")
|
||||
type=$(get_type "$node")
|
||||
|
||||
echo -e "${BLUE}[$type] $node:${RESET}"
|
||||
if ssh -o ConnectTimeout=5 -o BatchMode=yes "$host" "du -sh $path 2>/dev/null; df -h \$(dirname $path) | tail -1" 2>/dev/null; then
|
||||
echo
|
||||
else
|
||||
echo " (offline)"
|
||||
echo
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
broadcast_all() {
|
||||
banner
|
||||
local action="$1"
|
||||
local entity="$2"
|
||||
local details="$3"
|
||||
local ts=$(date -u +%Y-%m-%dT%H:%M:%SZ)
|
||||
local entry="{\"ts\":\"$ts\",\"agent\":\"${MY_CLAUDE:-sovereign-mesh}\",\"action\":\"$action\",\"entity\":\"$entity\",\"details\":\"$details\",\"mesh\":\"all-nodes-local-cloud\"}"
|
||||
|
||||
echo -e "${AMBER}Broadcasting to ALL nodes (Local + Cloud)...${RESET}"
|
||||
for node in $MESH_ALL; do
|
||||
host=$(get_host "$node")
|
||||
path=$(get_path "$node")
|
||||
|
||||
if ssh -o ConnectTimeout=5 -o BatchMode=yes "$host" "echo '$entry' >> $path/time/journals/master-time.jsonl" 2>/dev/null; then
|
||||
echo -e " ${GREEN}✓${RESET} $node"
|
||||
else
|
||||
echo -e " ${PINK}✗${RESET} $node"
|
||||
fi
|
||||
done
|
||||
echo -e "${GREEN}Broadcast complete - replicated across local AND cloud!${RESET}"
|
||||
}
|
||||
|
||||
case "${1:-check}" in
|
||||
check) check_all ;;
|
||||
sync) sync_all ;;
|
||||
status) status_all ;;
|
||||
broadcast) shift; broadcast_all "$@" ;;
|
||||
*)
|
||||
banner
|
||||
echo "Usage: blackroad-sovereign-mesh.sh [check|sync|status|broadcast]"
|
||||
echo ""
|
||||
echo " check - Check ALL nodes (local + cloud)"
|
||||
echo " sync - Sync to ALL nodes"
|
||||
echo " status - Show storage on ALL nodes"
|
||||
echo " broadcast - Log to ALL time journals"
|
||||
echo ""
|
||||
echo "Nodes: cecilia, lucidia (LOCAL) + anastasia, gematria (CLOUD)"
|
||||
;;
|
||||
esac
|
||||
Reference in New Issue
Block a user