#!/bin/bash set -e # RedFlag Agent Installation Script # This script installs the RedFlag agent as a systemd service with proper permissions SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" AGENT_USER="redflag-agent" AGENT_HOME="/var/lib/redflag-agent" AGENT_BINARY="/usr/local/bin/redflag-agent" SUDOERS_FILE="/etc/sudoers.d/redflag-agent" SERVICE_FILE="/etc/systemd/system/redflag-agent.service" echo "=== RedFlag Agent Installation ===" echo "" # Check if running as root if [ "$EUID" -ne 0 ]; then echo "ERROR: This script must be run as root (use sudo)" exit 1 fi # Function to create user if doesn't exist create_user() { if id "$AGENT_USER" &>/dev/null; then echo "✓ User $AGENT_USER already exists" else echo "Creating system user $AGENT_USER..." useradd -r -s /bin/false -d "$AGENT_HOME" -m "$AGENT_USER" echo "✓ User $AGENT_USER created" fi # Add user to docker group for Docker update scanning if getent group docker &>/dev/null; then echo "Adding $AGENT_USER to docker group..." usermod -aG docker "$AGENT_USER" echo "✓ User $AGENT_USER added to docker group" else echo "⚠ Docker group not found - Docker updates will not be available" echo " (Install Docker first, then reinstall the agent to enable Docker support)" fi } # Function to build agent binary build_agent() { echo "Building agent binary..." cd "$SCRIPT_DIR" go build -o redflag-agent ./cmd/agent echo "✓ Agent binary built" } # Function to install agent binary install_binary() { echo "Installing agent binary to $AGENT_BINARY..." cp "$SCRIPT_DIR/redflag-agent" "$AGENT_BINARY" chmod 755 "$AGENT_BINARY" chown root:root "$AGENT_BINARY" echo "✓ Agent binary installed" } # Function to install sudoers configuration install_sudoers() { echo "Installing sudoers configuration..." cat > "$SUDOERS_FILE" <<'EOF' # RedFlag Agent minimal sudo permissions # This file is generated automatically during RedFlag agent installation # APT package management commands redflag-agent ALL=(root) NOPASSWD: /usr/bin/apt-get update redflag-agent ALL=(root) NOPASSWD: /usr/bin/apt-get install -y * redflag-agent ALL=(root) NOPASSWD: /usr/bin/apt-get upgrade -y * redflag-agent ALL=(root) NOPASSWD: /usr/bin/apt-get install --dry-run --yes * # DNF package management commands redflag-agent ALL=(root) NOPASSWD: /usr/bin/dnf makecache redflag-agent ALL=(root) NOPASSWD: /usr/bin/dnf install -y * redflag-agent ALL=(root) NOPASSWD: /usr/bin/dnf upgrade -y * redflag-agent ALL=(root) NOPASSWD: /usr/bin/dnf install --assumeno --downloadonly * # Docker operations redflag-agent ALL=(root) NOPASSWD: /usr/bin/docker pull * redflag-agent ALL=(root) NOPASSWD: /usr/bin/docker image inspect * redflag-agent ALL=(root) NOPASSWD: /usr/bin/docker manifest inspect * EOF chmod 440 "$SUDOERS_FILE" # Validate sudoers file if visudo -c -f "$SUDOERS_FILE"; then echo "✓ Sudoers configuration installed and validated" else echo "ERROR: Sudoers configuration is invalid" rm -f "$SUDOERS_FILE" exit 1 fi } # Function to install systemd service install_service() { echo "Installing systemd service..." cat > "$SERVICE_FILE" <