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:
2026-03-14 17:07:35 -05:00
commit 78fbe80f2a
511 changed files with 102646 additions and 0 deletions

166
bin/blackroad-fleet Executable file
View File

@@ -0,0 +1,166 @@
#!/usr/bin/env bash
# ============================================================================
# BLACKROAD OS, INC. - PROPRIETARY AND CONFIDENTIAL
# Copyright (c) 2025-2026 BlackRoad OS, Inc. All Rights Reserved.
#
# This code is the intellectual property of BlackRoad OS, Inc.
# AI-assisted development does not transfer ownership to AI providers.
# Unauthorized use, copying, or distribution is prohibited.
# NOT licensed for AI training or data extraction.
# ============================================================================
# br-fleet - BlackRoad Fleet Orchestrator (local version)
# Execute fleet commands from Mac
PINK='\033[38;5;205m'
AMBER='\033[38;5;214m'
GREEN='\033[38;5;82m'
RED='\033[38;5;196m'
BLUE='\033[38;5;69m'
VIOLET='\033[38;5;135m'
WHITE='\033[1;37m'
DIM='\033[2m'
NC='\033[0m'
NODES=(cecilia lucidia octavia aria anastasia)
case "$1" in
status|"")
echo -e "${PINK}━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━${NC}"
echo -e "${WHITE} BLACKROAD FLEET STATUS${NC}"
echo -e "${PINK}━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━${NC}"
echo ""
for node in "${NODES[@]}"; do
echo -n -e "${AMBER}$node${NC}: "
if ssh -o ConnectTimeout=3 "$node" "echo ok" &>/dev/null; then
echo -n -e "${GREEN}ONLINE${NC} "
# Check services in parallel
for port in 8000 8765 8766 11434; do
if ssh -o ConnectTimeout=2 "$node" "ss -tlnp 2>/dev/null | grep -q :$port" 2>/dev/null; then
case $port in
8000) echo -n -e "${BLUE}API${NC} " ;;
8765) echo -n -e "${VIOLET}MESH${NC} " ;;
8766) echo -n -e "${PINK}EVENT${NC} " ;;
11434) echo -n -e "${AMBER}OLLAMA${NC} " ;;
esac
fi
done
echo ""
else
echo -e "${RED}OFFLINE${NC}"
fi
done
echo ""
echo -e "${DIM}Ports: API=8000 Mesh=8765 EventBus=8766 Ollama=11434${NC}"
;;
start)
service="$2"
echo -e "${PINK}Starting $service on fleet...${NC}"
for node in "${NODES[@]}"; do
echo -n "$node: "
case "$service" in
api)
ssh "$node" 'cd ~/blackroad-api 2>/dev/null && nohup ~/.local/bin/uvicorn main:app --host 0.0.0.0 --port 8000 > api.log 2>&1 &' && \
echo -e "${GREEN}started${NC}" || echo "skip"
;;
mesh)
ssh "$node" 'nohup python3 ~/.blackroad/mesh/mesh_hub.py > ~/.blackroad/mesh/hub.log 2>&1 &' && \
echo -e "${GREEN}started${NC}" || echo "skip"
;;
eventbus)
ssh "$node" 'nohup python3 ~/.blackroad/eventbus/event_bus.py > ~/.blackroad/eventbus/logs/bus.log 2>&1 &' && \
echo -e "${GREEN}started${NC}" || echo "skip"
;;
health)
ssh "$node" 'nohup python3 ~/.blackroad/monitor/health_daemon.py > ~/.blackroad/monitor/health.log 2>&1 &' && \
echo -e "${GREEN}started${NC}" || echo "skip"
;;
all)
ssh "$node" 'cd ~/blackroad-api 2>/dev/null && nohup ~/.local/bin/uvicorn main:app --host 0.0.0.0 --port 8000 > api.log 2>&1 &; \
nohup python3 ~/.blackroad/mesh/mesh_hub.py > ~/.blackroad/mesh/hub.log 2>&1 &; \
nohup python3 ~/.blackroad/eventbus/event_bus.py > ~/.blackroad/eventbus/logs/bus.log 2>&1 &; \
nohup python3 ~/.blackroad/monitor/health_daemon.py > ~/.blackroad/monitor/health.log 2>&1 &' &
echo -e "${GREEN}starting all${NC}"
;;
esac
done
wait
;;
stop)
service="$2"
port=""
case "$service" in
api) port=8000 ;;
mesh) port=8765 ;;
eventbus) port=8766 ;;
esac
if [ -n "$port" ]; then
echo -e "${AMBER}Stopping $service (port $port) on fleet...${NC}"
for node in "${NODES[@]}"; do
echo -n "$node: "
ssh "$node" "lsof -ti:$port 2>/dev/null | xargs kill -9 2>/dev/null" && \
echo -e "${GREEN}stopped${NC}" || echo "not running"
done
fi
;;
exec)
shift
cmd="$*"
echo -e "${PINK}Executing on fleet: $cmd${NC}"
echo ""
for node in "${NODES[@]}"; do
echo -e "${AMBER}=== $node ===${NC}"
ssh -o ConnectTimeout=5 "$node" "$cmd" 2>/dev/null || echo "(offline)"
echo ""
done
;;
resources)
echo -e "${PINK}━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━${NC}"
echo -e "${WHITE} FLEET RESOURCE USAGE${NC}"
echo -e "${PINK}━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━${NC}"
echo ""
printf "%-12s %8s %8s %8s\n" "NODE" "CPU" "MEM" "DISK"
echo "─────────────────────────────────────────"
for node in "${NODES[@]}"; do
cpu=$(ssh -o ConnectTimeout=3 "$node" "top -bn1 | grep 'Cpu' | awk '{print \$2}'" 2>/dev/null || echo "?")
mem=$(ssh -o ConnectTimeout=3 "$node" "free | awk '/Mem:/{printf \"%.1f\", \$3/\$2*100}'" 2>/dev/null || echo "?")
disk=$(ssh -o ConnectTimeout=3 "$node" "df / | awk 'NR==2{print \$5}'" 2>/dev/null || echo "?")
printf "%-12s %7s%% %7s%% %8s\n" "$node" "$cpu" "$mem" "$disk"
done
;;
ssh)
node="$2"
shift 2
cmd="$*"
if [ -n "$cmd" ]; then
ssh "$node" "$cmd"
else
ssh "$node"
fi
;;
*)
echo -e "${PINK}br-fleet${NC} - BlackRoad Fleet Orchestrator"
echo ""
echo "Commands:"
echo " status - Show fleet status"
echo " start <svc> - Start service on fleet (api/mesh/eventbus/health/all)"
echo " stop <svc> - Stop service on fleet"
echo " exec <cmd> - Execute command on all nodes"
echo " resources - Show resource usage"
echo " ssh <node> - SSH to node"
;;
esac