feat: machine binding and version enforcement

migration 017 adds machine_id to agents table
middleware validates X-Machine-ID header on authed routes
agent client sends machine ID with requests
MIN_AGENT_VERSION config defaults 0.1.22
version utils added for comparison

blocks config copying attacks via hardware fingerprint
old agents get 426 upgrade required
breaking: <0.1.22 agents rejected
This commit is contained in:
Fimeg
2025-11-02 09:30:04 -05:00
parent 99480f3fe3
commit ec3ba88459
48 changed files with 3811 additions and 122 deletions

23
scripts/build-secure-agent.sh Executable file
View File

@@ -0,0 +1,23 @@
#!/bin/bash
# RedFlag Agent Build Script
# Builds agent binary (public key fetched from server at runtime)
set -e
echo "🔨 RedFlag Agent Build"
echo "====================="
# Build agent
echo "Building agent..."
cd aggregator-agent
go build \
-o redflag-agent \
./cmd/agent
cd ..
echo "✅ Agent build complete!"
echo " Binary: aggregator-agent/redflag-agent"
echo ""
echo " Note: Agent will fetch the server's public key automatically at startup"