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