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:
166
bin/blackroad-fleet
Executable file
166
bin/blackroad-fleet
Executable 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
|
||||
Reference in New Issue
Block a user