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
150 lines
4.0 KiB
Bash
150 lines
4.0 KiB
Bash
#!/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.
|
|
# ============================================================================
|
|
# brctl-sync - Sync files across cluster nodes
|
|
# Usage: brctl-sync <command> [args]
|
|
|
|
NODES="cecilia lucidia octavia aria blackroad os cadence"
|
|
SYNC_DIR="/opt/blackroad/shared"
|
|
|
|
usage() {
|
|
cat << 'EOF'
|
|
brctl-sync - Cluster File Synchronization
|
|
|
|
USAGE:
|
|
brctl-sync <command> [args]
|
|
|
|
COMMANDS:
|
|
push <file> [nodes] Push file to all/specified nodes
|
|
pull <node> <file> Pull file from a node
|
|
broadcast <file> Push file to ALL online nodes
|
|
collect <remote> <local> Collect file from all nodes
|
|
init Initialize sync directories on all nodes
|
|
|
|
EXAMPLES:
|
|
brctl-sync push config.yaml # Push to all nodes
|
|
brctl-sync push script.sh cecilia # Push to cecilia only
|
|
brctl-sync broadcast /opt/blackroad/bin/brnode
|
|
brctl-sync collect /var/log/syslog ./logs/
|
|
EOF
|
|
}
|
|
|
|
# Push file to nodes
|
|
push_file() {
|
|
local file="$1"
|
|
shift
|
|
local targets="${@:-$NODES}"
|
|
|
|
if [ ! -f "$file" ]; then
|
|
echo "File not found: $file"
|
|
return 1
|
|
fi
|
|
|
|
local filename=$(basename "$file")
|
|
|
|
for node in $targets; do
|
|
echo -n "$node: "
|
|
if ssh -o ConnectTimeout=2 -o BatchMode=yes "$node" "true" 2>/dev/null; then
|
|
cat "$file" | ssh "$node" "cat > $SYNC_DIR/$filename" 2>/dev/null && echo "OK" || echo "FAILED"
|
|
else
|
|
echo "OFFLINE"
|
|
fi
|
|
done
|
|
}
|
|
|
|
# Pull file from node
|
|
pull_file() {
|
|
local node="$1"
|
|
local remote_file="$2"
|
|
local local_file="${3:-$(basename $remote_file)}"
|
|
|
|
echo "Pulling $remote_file from $node..."
|
|
ssh "$node" "cat $remote_file" > "$local_file" 2>/dev/null && echo "OK: $local_file" || echo "FAILED"
|
|
}
|
|
|
|
# Broadcast file to all online nodes
|
|
broadcast_file() {
|
|
local file="$1"
|
|
local remote_path="${2:-$file}"
|
|
|
|
if [ ! -f "$file" ]; then
|
|
echo "File not found: $file"
|
|
return 1
|
|
fi
|
|
|
|
for node in $NODES; do
|
|
echo -n "$node: "
|
|
if ssh -o ConnectTimeout=2 -o BatchMode=yes "$node" "true" 2>/dev/null; then
|
|
local dir=$(dirname "$remote_path")
|
|
ssh "$node" "mkdir -p $dir" 2>/dev/null
|
|
cat "$file" | ssh "$node" "cat > $remote_path && chmod +x $remote_path 2>/dev/null" && echo "OK" || echo "FAILED"
|
|
else
|
|
echo "OFFLINE"
|
|
fi
|
|
done
|
|
}
|
|
|
|
# Collect file from all nodes
|
|
collect_files() {
|
|
local remote_file="$1"
|
|
local local_dir="$2"
|
|
|
|
mkdir -p "$local_dir"
|
|
|
|
for node in $NODES; do
|
|
echo -n "$node: "
|
|
if ssh -o ConnectTimeout=2 -o BatchMode=yes "$node" "true" 2>/dev/null; then
|
|
local filename=$(basename "$remote_file")
|
|
ssh "$node" "cat $remote_file" > "$local_dir/${node}-${filename}" 2>/dev/null && echo "OK" || echo "FAILED"
|
|
else
|
|
echo "OFFLINE"
|
|
fi
|
|
done
|
|
}
|
|
|
|
# Initialize sync directories
|
|
init_sync() {
|
|
for node in $NODES; do
|
|
echo -n "$node: "
|
|
if ssh -o ConnectTimeout=2 -o BatchMode=yes "$node" "true" 2>/dev/null; then
|
|
ssh "$node" "sudo mkdir -p $SYNC_DIR && sudo chown \$(whoami) $SYNC_DIR" 2>/dev/null && echo "OK" || echo "FAILED"
|
|
else
|
|
echo "OFFLINE"
|
|
fi
|
|
done
|
|
}
|
|
|
|
case "${1:-}" in
|
|
push)
|
|
shift
|
|
push_file "$@"
|
|
;;
|
|
pull)
|
|
pull_file "$2" "$3" "$4"
|
|
;;
|
|
broadcast)
|
|
broadcast_file "$2" "$3"
|
|
;;
|
|
collect)
|
|
collect_files "$2" "$3"
|
|
;;
|
|
init)
|
|
init_sync
|
|
;;
|
|
-h|--help|help|"")
|
|
usage
|
|
;;
|
|
*)
|
|
echo "Unknown command: $1"
|
|
usage
|
|
exit 1
|
|
;;
|
|
esac
|