#!/usr/bin/env bash set -euo pipefail log() { printf '[logs] %s\n' "$*" } usage() { cat <<'EOF' Usage: ./logs.sh [--follow] Prints the Firecracker log for a VM. Use --follow to tail -f. EOF } find_vm_json() { local query="$1" local vm_json match_count=0 match="" for vm_json in state/vms/*/vm.json; do [[ -f "$vm_json" ]] || continue local id name id="$(jq -r '.meta.id // empty' "$vm_json")" name="$(jq -r '.meta.name // empty' "$vm_json")" if [[ "$id" == "$query"* || "$name" == "$query"* ]]; then match="$vm_json" match_count=$((match_count + 1)) fi done if (( match_count == 0 )); then log "no VM found for prefix: $query" exit 1 fi if (( match_count > 1 )); then log "multiple VMs found for prefix: $query" exit 1 fi printf '%s' "$match" } QUERY="${1:-}" FOLLOW=0 while [[ $# -gt 0 ]]; do case "$1" in --follow|-f) FOLLOW=1 shift ;; -h|--help) usage exit 0 ;; *) if [[ -z "$QUERY" ]]; then QUERY="$1" shift else log "unknown option: $1" usage exit 1 fi ;; esac done if [[ -z "$QUERY" ]]; then usage exit 1 fi VM_JSON="$(find_vm_json "$QUERY")" LOG_FILE="$(jq -r '.meta.log // empty' "$VM_JSON")" if [[ -z "$LOG_FILE" || ! -f "$LOG_FILE" ]]; then log "log file not found: $LOG_FILE" exit 1 fi if (( FOLLOW == 1 )); then tail -f "$LOG_FILE" else cat "$LOG_FILE" fi