Files
blackroad/scripts/blackroad-log-aggregator.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

85 lines
3.8 KiB
Bash
Executable File

#!/usr/bin/env bash
# BR-Logs - Fleet log aggregator
set -eo pipefail
# Source centralized config
NODES_CONFIG="$HOME/.blackroad/config/nodes.sh"
if [[ -f "$NODES_CONFIG" ]]; then
source "$NODES_CONFIG"
NODES=()
for n in "${PI_NODES[@]}"; do
NODES+=("${n}:${NODE_IP[$n]}:${NODE_USER[$n]}")
done
else
PINK='\033[38;5;205m'; BLUE='\033[38;5;69m'; GREEN='\033[38;5;82m'
AMBER='\033[38;5;214m'; RED='\033[38;5;196m'; RESET='\033[0m'
NODES=("alice:192.168.4.49:pi" "cecilia:192.168.4.96:blackroad" "octavia:192.168.4.100:pi" "lucidia:192.168.4.38:octavia")
fi
while true; do
clear
printf "${PINK}╔════════════════════════════════════════╗${RESET}\n"
printf "${PINK}║ 📋 BR-Logs Aggregator ║${RESET}\n"
printf "${PINK}╚════════════════════════════════════════╝${RESET}\n\n"
cat <<MENU
${BLUE}1${RESET}) Tail all nodes (live)
${BLUE}2${RESET}) System errors (last hour)
${BLUE}3${RESET}) Docker logs
${BLUE}4${RESET}) Ollama logs
${BLUE}5${RESET}) Cloudflared logs
${BLUE}6${RESET}) Power/throttle alerts
${BLUE}7${RESET}) Search logs
${BLUE}0${RESET}) Quit
MENU
printf " ${PINK}> ${RESET}"
read -r c
case $c in
1) printf "\n ${GREEN}Live tail (Ctrl+C to stop):${RESET}\n\n"
for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
ssh -o ConnectTimeout=3 "${user}@${ip}" "journalctl -f -n 5 --no-pager 2>/dev/null" 2>/dev/null | sed "s/^/ [${name}] /" &
done
wait
read -rp " ↩ ";;
2) for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "journalctl -p err --since '1 hour ago' --no-pager -n 10 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
3) for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s Docker ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "docker ps --format 'table {{.Names}}\t{{.Status}}' 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
4) for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s Ollama ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "journalctl -u ollama --no-pager -n 5 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
5) for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s Cloudflared ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "journalctl -u cloudflared --no-pager -n 5 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
6) for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s Power ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "vcgencmd get_throttled 2>/dev/null; vcgencmd measure_volts 2>/dev/null; vcgencmd measure_temp 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
7) printf " Search: "; read -r query
for entry in "${NODES[@]}"; do
IFS=: read -r name ip user <<< "$entry"
printf "\n ${AMBER}── %s ──${RESET}\n" "$name"
ssh -o ConnectTimeout=3 "${user}@${ip}" "journalctl --no-pager -n 20 --grep='$query' 2>/dev/null" || printf " ${RED}Offline${RESET}\n"
done
read -rp " ↩ ";;
0|q) exit;;
esac
done