1145519Sdarrenr/* $FreeBSD$ */ 2145510Sdarrenr 3145510Sdarrenr/* 4170268Sdarrenr * Copyright (C) 2002-2004 by Darren Reed. 5145510Sdarrenr * 6145510Sdarrenr * See the IPFILTER.LICENCE file for details on licencing. 7145510Sdarrenr * 8145510Sdarrenr * Added redirect stuff and a variety of bug fixes. (mcn@EnGarde.com) 9145510Sdarrenr */ 10145510Sdarrenr 11145510Sdarrenr#include "ipf.h" 12145510Sdarrenr 13145510Sdarrenr 14145510Sdarrenr#if !defined(lint) 15170268Sdarrenrstatic const char rcsid[] = "@(#)$Id: printactivenat.c,v 1.3.2.7 2006/12/12 16:13:00 darrenr Exp $"; 16145510Sdarrenr#endif 17145510Sdarrenr 18145510Sdarrenr 19170268Sdarrenrvoid printactivenat(nat, opts, alive, now) 20145510Sdarrenrnat_t *nat; 21170268Sdarrenrint opts, alive; 22170268Sdarrenru_long now; 23145510Sdarrenr{ 24145510Sdarrenr 25170268Sdarrenr printf("%s", getnattype(nat, alive)); 26145510Sdarrenr 27145510Sdarrenr if (nat->nat_flags & SI_CLONE) 28145510Sdarrenr printf(" CLONE"); 29145510Sdarrenr 30145510Sdarrenr printf(" %-15s", inet_ntoa(nat->nat_inip)); 31145510Sdarrenr 32145510Sdarrenr if ((nat->nat_flags & IPN_TCPUDP) != 0) 33145510Sdarrenr printf(" %-5hu", ntohs(nat->nat_inport)); 34145510Sdarrenr 35145510Sdarrenr printf(" <- -> %-15s",inet_ntoa(nat->nat_outip)); 36145510Sdarrenr 37145510Sdarrenr if ((nat->nat_flags & IPN_TCPUDP) != 0) 38145510Sdarrenr printf(" %-5hu", ntohs(nat->nat_outport)); 39145510Sdarrenr 40145510Sdarrenr printf(" [%s", inet_ntoa(nat->nat_oip)); 41145510Sdarrenr if ((nat->nat_flags & IPN_TCPUDP) != 0) 42145510Sdarrenr printf(" %hu", ntohs(nat->nat_oport)); 43145510Sdarrenr printf("]"); 44145510Sdarrenr 45145510Sdarrenr if (opts & OPT_VERBOSE) { 46170268Sdarrenr printf("\n\tttl %lu use %hu sumd %s/", 47170268Sdarrenr nat->nat_age - now, nat->nat_use, 48170268Sdarrenr getsumd(nat->nat_sumd[0])); 49145510Sdarrenr printf("%s pr %u bkt %d/%d flags %x\n", 50145510Sdarrenr getsumd(nat->nat_sumd[1]), nat->nat_p, 51145510Sdarrenr nat->nat_hv[0], nat->nat_hv[1], nat->nat_flags); 52145510Sdarrenr printf("\tifp %s", getifname(nat->nat_ifps[0])); 53145510Sdarrenr printf(",%s ", getifname(nat->nat_ifps[1])); 54145510Sdarrenr#ifdef USE_QUAD_T 55145510Sdarrenr printf("bytes %qu/%qu pkts %qu/%qu", 56145510Sdarrenr (unsigned long long)nat->nat_bytes[0], 57145510Sdarrenr (unsigned long long)nat->nat_bytes[1], 58145510Sdarrenr (unsigned long long)nat->nat_pkts[0], 59145510Sdarrenr (unsigned long long)nat->nat_pkts[1]); 60145510Sdarrenr#else 61145510Sdarrenr printf("bytes %lu/%lu pkts %lu/%lu", nat->nat_bytes[0], 62145510Sdarrenr nat->nat_bytes[1], nat->nat_pkts[0], nat->nat_pkts[1]); 63145510Sdarrenr#endif 64145510Sdarrenr printf(" ipsumd %x", nat->nat_ipsumd); 65145510Sdarrenr } 66145510Sdarrenr 67145510Sdarrenr if (opts & OPT_DEBUG) { 68145510Sdarrenr printf("\n\tnat_next %p _pnext %p _hm %p\n", 69145510Sdarrenr nat->nat_next, nat->nat_pnext, nat->nat_hm); 70145510Sdarrenr printf("\t_hnext %p/%p _phnext %p/%p\n", 71145510Sdarrenr nat->nat_hnext[0], nat->nat_hnext[1], 72145510Sdarrenr nat->nat_phnext[0], nat->nat_phnext[1]); 73145510Sdarrenr printf("\t_data %p _me %p _state %p _aps %p\n", 74145510Sdarrenr nat->nat_data, nat->nat_me, nat->nat_state, nat->nat_aps); 75145510Sdarrenr printf("\tfr %p ptr %p ifps %p/%p sync %p\n", 76145510Sdarrenr nat->nat_fr, nat->nat_ptr, nat->nat_ifps[0], 77145510Sdarrenr nat->nat_ifps[1], nat->nat_sync); 78145510Sdarrenr printf("\ttqe:pnext %p next %p ifq %p parent %p/%p\n", 79145510Sdarrenr nat->nat_tqe.tqe_pnext, nat->nat_tqe.tqe_next, 80145510Sdarrenr nat->nat_tqe.tqe_ifq, nat->nat_tqe.tqe_parent, nat); 81145510Sdarrenr printf("\ttqe:die %ld touched %ld flags %x state %d/%d\n", 82145510Sdarrenr nat->nat_tqe.tqe_die, nat->nat_tqe.tqe_touched, 83145510Sdarrenr nat->nat_tqe.tqe_flags, nat->nat_tqe.tqe_state[0], 84145510Sdarrenr nat->nat_tqe.tqe_state[1]); 85145510Sdarrenr } 86145510Sdarrenr putchar('\n'); 87145510Sdarrenr} 88