function cmd::logs::show_wg_events() { local filter_ip="${1:-}" filter_name="${2:-}" filter_type="${3:-}" \ limit="${4:-50}" collapse="${5:-1}" \ since="${6:-}" filter_event="${7:-}" sort_order="${8:-desc}" [[ ! -f "$WG_EVENTS_LOG" ]] && return 0 local data data=$(json::wg_events \ "$WG_EVENTS_LOG" "$filter_name" "$filter_type" \ "$limit" "$collapse" "$since" "$filter_event" \ "$(ctx::endpoint_cache)" "$sort_order" \ 2>/dev/null) [[ -z "$data" ]] && return 0 # Resolve endpoints and measure column widths local w_client=16 w_endpoint=16 local resolved_data="" while IFS='|' read -r ts client endpoint event count gap_seconds; do [[ -z "$ts" ]] && continue local endpoint_display endpoint_display=$(resolve::ip "$endpoint") [[ -z "$endpoint_display" ]] && endpoint_display="$endpoint" resolved_data+="${ts}|${client}|${endpoint_display}|${event}|${count}|${gap_seconds}"$'\n' (( ${#client} > w_client )) && w_client=${#client} (( ${#endpoint_display} > w_endpoint )) && w_endpoint=${#endpoint_display} done <<< "$data" (( w_client += 2 )) (( w_endpoint += 2 )) ui::logs::wg_section_header while IFS='|' read -r ts client endpoint event count gap_seconds; do [[ -z "$ts" ]] && continue ui::logs::wg_row "$ts" "$client" "$endpoint" "$event" \ "$count" "$w_client" "$w_endpoint" "$gap_seconds" done <<< "$resolved_data" printf "\n" }