|
| 1 | +#!/usr/bin/bash |
| 2 | + |
| 3 | +set -euo pipefail |
| 4 | + |
| 5 | +# Resolve script location |
| 6 | +SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" |
| 7 | +ZONES_DIR="$SCRIPT_DIR/zones" |
| 8 | +NAMED_CONF_TEMPLATE="$SCRIPT_DIR/named.conf.in" |
| 9 | +NAMED_CONF="$SCRIPT_DIR/named.conf" |
| 10 | +PID_FILE="$ZONES_DIR/named.pid" |
| 11 | +LOG_FILE="$SCRIPT_DIR/named.log" |
| 12 | + |
| 13 | +# Default mode: background |
| 14 | +FOREGROUND=false |
| 15 | +if [[ "${1:-}" == "-f" ]]; then |
| 16 | + FOREGROUND=true |
| 17 | +fi |
| 18 | + |
| 19 | +# Ensure zones directory exists |
| 20 | +if [ ! -d "$ZONES_DIR" ]; then |
| 21 | + echo "Zone directory $ZONES_DIR not found." |
| 22 | + exit 1 |
| 23 | +fi |
| 24 | + |
| 25 | +# Ensure template exists |
| 26 | +if [ ! -f "$NAMED_CONF_TEMPLATE" ]; then |
| 27 | + echo "Template file $NAMED_CONF_TEMPLATE not found." |
| 28 | + exit 1 |
| 29 | +fi |
| 30 | + |
| 31 | +# Generate named.conf from template |
| 32 | +echo "Generating $NAMED_CONF from $NAMED_CONF_TEMPLATE" |
| 33 | +sed -e "s|@ZONES_DIR@|$ZONES_DIR|g" \ |
| 34 | + -e "s|@PID_FILE@|$PID_FILE|g" \ |
| 35 | + -e "s|@SCRIPT_DIR@|$SCRIPT_DIR|g" \ |
| 36 | + "$NAMED_CONF_TEMPLATE" > "$NAMED_CONF" |
| 37 | + |
| 38 | +# Clean up any leftover journal or PID files |
| 39 | +rm -f "$ZONES_DIR"/*.jnl "$PID_FILE" |
| 40 | + |
| 41 | +# Print what we're doing |
| 42 | +echo "Starting BIND from $SCRIPT_DIR" |
| 43 | + |
| 44 | +if $FOREGROUND; then |
| 45 | + echo "(running in foreground)" |
| 46 | + exec named -c "$NAMED_CONF" -p 53 -u "$(whoami)" -g -d 1 |
| 47 | +else |
| 48 | + echo "(running in background)" |
| 49 | + named -c "$NAMED_CONF" -p 53 -u "$(whoami)" |
| 50 | + |
| 51 | + # Wait for BIND to start with periodic checks |
| 52 | + MAX_WAIT=20 # Maximum wait time in attempts (20 * 0.5s = 10s) |
| 53 | + CHECK_INTERVAL=0.5 # Check every 500ms |
| 54 | + ATTEMPTS=0 |
| 55 | + |
| 56 | + echo -n "Waiting for BIND to start" |
| 57 | + |
| 58 | + while [[ $ATTEMPTS -lt $MAX_WAIT ]]; do |
| 59 | + if [[ -f "$PID_FILE" ]] && kill -0 "$(cat "$PID_FILE")" 2>/dev/null; then |
| 60 | + echo "" # New line after the dots |
| 61 | + ELAPSED=$(echo "scale=1; $ATTEMPTS * $CHECK_INTERVAL" | bc 2>/dev/null || echo "${ATTEMPTS}") |
| 62 | + echo "BIND started in background with PID $(cat "$PID_FILE") (took ~${ELAPSED}s)" |
| 63 | + exit 0 |
| 64 | + fi |
| 65 | + |
| 66 | + echo -n "." |
| 67 | + sleep "$CHECK_INTERVAL" |
| 68 | + ((ATTEMPTS++)) |
| 69 | + done |
| 70 | + |
| 71 | + echo "" # New line after the dots |
| 72 | + TOTAL_WAIT=$(echo "scale=1; $MAX_WAIT * $CHECK_INTERVAL" | bc 2>/dev/null || echo "${MAX_WAIT}") |
| 73 | + echo "Failed to start BIND within ~${TOTAL_WAIT}s. See $LOG_FILE for details." |
| 74 | + |
| 75 | + # Show last few lines of log for debugging |
| 76 | + if [[ -f "$LOG_FILE" ]]; then |
| 77 | + echo "Last few lines from log:" |
| 78 | + tail -5 "$LOG_FILE" |
| 79 | + fi |
| 80 | + |
| 81 | + exit 1 |
| 82 | +fi |
0 commit comments