ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz/*
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx * Copyright (C) 2002-2004 by Darren Reed.
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz *
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz * See the IPFILTER.LICENCE file for details on licencing.
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz */
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
f4b3ec61df05330d25f55a36b975b4d7519fdeb1dh#pragma ident "%Z%%M% %I% %E% SMI"
f4b3ec61df05330d25f55a36b975b4d7519fdeb1dh
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#include "ipf.h"
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#if !defined(lint)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yzstatic const char rcsid[] = "@(#)$Id: printactivenat.c,v 1.3.2.4 2004/05/11 16:07:32 darrenr Exp $";
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#endif
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
f4b3ec61df05330d25f55a36b975b4d7519fdeb1dhvoid printactivenat(nat, opts, alive)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yznat_t *nat;
f4b3ec61df05330d25f55a36b975b4d7519fdeb1dhint opts, alive;
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz{
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
f4b3ec61df05330d25f55a36b975b4d7519fdeb1dh printf("%s", getnattype(nat, alive));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if (nat->nat_flags & SI_CLONE)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(" CLONE");
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx printactiveaddress(nat->nat_v, " %-15s", &nat->nat_inip6,
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx nat->nat_ifnames[0]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if ((nat->nat_flags & IPN_TCPUDP) != 0)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(" %-5hu", ntohs(nat->nat_inport));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx printf(" <- -> ");
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx printactiveaddress(nat->nat_v, "%-15s", &nat->nat_outip6,
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx nat->nat_ifnames[0]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if ((nat->nat_flags & IPN_TCPUDP) != 0)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(" %-5hu", ntohs(nat->nat_outport));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx printf(" [");
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx printactiveaddress(nat->nat_v, "%s", &nat->nat_oip6,
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx nat->nat_ifnames[0]);
d6c23f6fbecbcca8ddd2b74c6e10f37095f9fd46yx
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if ((nat->nat_flags & IPN_TCPUDP) != 0)
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(" %hu", ntohs(nat->nat_oport));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("]");
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if (opts & OPT_VERBOSE) {
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\n\tage %lu use %hu sumd %s/",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_age, nat->nat_use, getsumd(nat->nat_sumd[0]));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("%s pr %u bkt %d/%d flags %x\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz getsumd(nat->nat_sumd[1]), nat->nat_p,
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_hv[0], nat->nat_hv[1], nat->nat_flags);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\tifp %s", getifname(nat->nat_ifps[0]));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(",%s ", getifname(nat->nat_ifps[1]));
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#ifdef USE_QUAD_T
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("bytes %qu/%qu pkts %qu/%qu",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz (unsigned long long)nat->nat_bytes[0],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz (unsigned long long)nat->nat_bytes[1],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz (unsigned long long)nat->nat_pkts[0],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz (unsigned long long)nat->nat_pkts[1]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#else
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("bytes %lu/%lu pkts %lu/%lu", nat->nat_bytes[0],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_bytes[1], nat->nat_pkts[0], nat->nat_pkts[1]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz#endif
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf(" ipsumd %x", nat->nat_ipsumd);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz }
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz if (opts & OPT_DEBUG) {
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\n\tnat_next %p _pnext %p _hm %p\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_next, nat->nat_pnext, nat->nat_hm);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\t_hnext %p/%p _phnext %p/%p\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_hnext[0], nat->nat_hnext[1],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_phnext[0], nat->nat_phnext[1]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\t_data %p _me %p _state %p _aps %p\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_data, nat->nat_me, nat->nat_state, nat->nat_aps);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\tfr %p ptr %p ifps %p/%p sync %p\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_fr, nat->nat_ptr, nat->nat_ifps[0],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_ifps[1], nat->nat_sync);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\ttqe:pnext %p next %p ifq %p parent %p/%p\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_tqe.tqe_pnext, nat->nat_tqe.tqe_next,
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_tqe.tqe_ifq, nat->nat_tqe.tqe_parent, nat);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz printf("\ttqe:die %ld touched %ld flags %x state %d/%d\n",
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_tqe.tqe_die, nat->nat_tqe.tqe_touched,
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_tqe.tqe_flags, nat->nat_tqe.tqe_state[0],
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz nat->nat_tqe.tqe_state[1]);
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz }
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz putchar('\n');
ab25eeb551a4be927a4b6ae2cf8aff7ed17decb4yz}