printactivenat.c revision 145519
1/*	$FreeBSD: head/contrib/ipfilter/lib/printactivenat.c 145519 2005-04-25 18:20:15Z darrenr $	*/
2
3/*
4 * Copyright (C) 1993-2001 by Darren Reed.
5 *
6 * See the IPFILTER.LICENCE file for details on licencing.
7 *
8 * Added redirect stuff and a variety of bug fixes. (mcn@EnGarde.com)
9 */
10
11#include "ipf.h"
12
13
14#if !defined(lint)
15static const char rcsid[] = "@(#)Id: printactivenat.c,v 1.3.2.4 2004/05/11 16:07:32 darrenr Exp";
16#endif
17
18
19void printactivenat(nat, opts)
20nat_t *nat;
21int opts;
22{
23
24	printf("%s", getnattype(nat->nat_ptr));
25
26	if (nat->nat_flags & SI_CLONE)
27		printf(" CLONE");
28
29	printf(" %-15s", inet_ntoa(nat->nat_inip));
30
31	if ((nat->nat_flags & IPN_TCPUDP) != 0)
32		printf(" %-5hu", ntohs(nat->nat_inport));
33
34	printf(" <- -> %-15s",inet_ntoa(nat->nat_outip));
35
36	if ((nat->nat_flags & IPN_TCPUDP) != 0)
37		printf(" %-5hu", ntohs(nat->nat_outport));
38
39	printf(" [%s", inet_ntoa(nat->nat_oip));
40	if ((nat->nat_flags & IPN_TCPUDP) != 0)
41		printf(" %hu", ntohs(nat->nat_oport));
42	printf("]");
43
44	if (opts & OPT_VERBOSE) {
45		printf("\n\tage %lu use %hu sumd %s/",
46			nat->nat_age, nat->nat_use, getsumd(nat->nat_sumd[0]));
47		printf("%s pr %u bkt %d/%d flags %x\n",
48			getsumd(nat->nat_sumd[1]), nat->nat_p,
49			nat->nat_hv[0], nat->nat_hv[1], nat->nat_flags);
50		printf("\tifp %s", getifname(nat->nat_ifps[0]));
51		printf(",%s ", getifname(nat->nat_ifps[1]));
52#ifdef	USE_QUAD_T
53		printf("bytes %qu/%qu pkts %qu/%qu",
54			(unsigned long long)nat->nat_bytes[0],
55			(unsigned long long)nat->nat_bytes[1],
56			(unsigned long long)nat->nat_pkts[0],
57			(unsigned long long)nat->nat_pkts[1]);
58#else
59		printf("bytes %lu/%lu pkts %lu/%lu", nat->nat_bytes[0],
60			nat->nat_bytes[1], nat->nat_pkts[0], nat->nat_pkts[1]);
61#endif
62		printf(" ipsumd %x", nat->nat_ipsumd);
63	}
64
65	if (opts & OPT_DEBUG) {
66		printf("\n\tnat_next %p _pnext %p _hm %p\n",
67			nat->nat_next, nat->nat_pnext, nat->nat_hm);
68		printf("\t_hnext %p/%p _phnext %p/%p\n",
69			nat->nat_hnext[0], nat->nat_hnext[1],
70			nat->nat_phnext[0], nat->nat_phnext[1]);
71		printf("\t_data %p _me %p _state %p _aps %p\n",
72			nat->nat_data, nat->nat_me, nat->nat_state, nat->nat_aps);
73		printf("\tfr %p ptr %p ifps %p/%p sync %p\n",
74			nat->nat_fr, nat->nat_ptr, nat->nat_ifps[0],
75			nat->nat_ifps[1], nat->nat_sync);
76		printf("\ttqe:pnext %p next %p ifq %p parent %p/%p\n",
77			nat->nat_tqe.tqe_pnext, nat->nat_tqe.tqe_next,
78			nat->nat_tqe.tqe_ifq, nat->nat_tqe.tqe_parent, nat);
79		printf("\ttqe:die %ld touched %ld flags %x state %d/%d\n",
80			nat->nat_tqe.tqe_die, nat->nat_tqe.tqe_touched,
81			nat->nat_tqe.tqe_flags, nat->nat_tqe.tqe_state[0],
82			nat->nat_tqe.tqe_state[1]);
83	}
84	putchar('\n');
85}
86