Files
blackroad/bin/brctl-sync
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

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