function cmd::group::logs() { local name="" limit=50 while [[ $# -gt 0 ]]; do case "$1" in --name) util::require_flag "--name" "${2:-}" || return 1; name="$2"; shift 2 ;; --limit) util::require_flag "--limit" "${2:-}" || return 1; limit="$2"; shift 2 ;; --help) cmd::group::help; return ;; *) log::error "Unknown flag: $1"; return 1 ;; esac done [[ -z "$name" ]] && log::error "Missing required flag: --name" && return 1 group::require_exists "$name" || return 1 local peers_list=() mapfile -t peers_list < <(group::peers "$name") [[ -z "${peers_list[0]}" ]] && log::wg_warning "Group '${name}' has no peers" && return 0 log::section "Logs: Group '${name}'" for peer_name in "${peers_list[@]}"; do [[ -z "$peer_name" ]] && continue # Skip if peer no longer exists if ! peers::require_exists "$peer_name" > /dev/null 2>&1; then log::wg_warning "Peer '${peer_name}' no longer exists — skipping" continue fi printf "\n \033[1;37m── %s ──\033[0m\n" "$peer_name" load_command logs cmd::logs::show --name "$peer_name" --limit "$limit" done }