1 /*
2  * Copyright (C) 2002 by Darren Reed.
3  *
4  * See the IPFILTER.LICENCE file for details on licencing.
5  *
6  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
7  * Use is subject to license terms.
8  */
9 
10 #include <sys/ioctl.h>
11 #include "ipf.h"
12 #include "netinet/ipl.h"
13 
14 #define	PRINTF	(void)printf
15 #define	FPRINTF	(void)fprintf
16 
17 
printpool_live(pool,fd,name,opts)18 ip_pool_t *printpool_live(pool, fd, name, opts)
19 ip_pool_t *pool;
20 int fd;
21 char *name;
22 int opts;
23 {
24 	ip_pool_node_t entry, *top, *node;
25 	ipflookupiter_t iter;
26 	int i, printed = 0, last;
27 	ipfobj_t obj;
28 
29 	if ((name != NULL) && strncmp(name, pool->ipo_name, FR_GROUPLEN))
30 		return pool->ipo_next;
31 
32 	printpooldata(pool, opts);
33 
34 	if ((opts & OPT_DEBUG) == 0)
35 		PRINTF("\t{");
36 
37 	obj.ipfo_rev = IPFILTER_VERSION;
38 	obj.ipfo_type = IPFOBJ_LOOKUPITER;
39 	obj.ipfo_ptr = &iter;
40 	obj.ipfo_size = sizeof(iter);
41 
42 	iter.ili_data = &entry;
43 	iter.ili_type = IPLT_POOL;
44 	iter.ili_otype = IPFLOOKUPITER_NODE;
45 	iter.ili_ival = IPFGENITER_LOOKUP;
46 	iter.ili_unit = pool->ipo_unit;
47 	strncpy(iter.ili_name, pool->ipo_name, FR_GROUPLEN);
48 
49 	last = 0;
50 	top = NULL;
51 
52 	while (!last && (ioctl(fd, SIOCLOOKUPITER, &obj) == 0)) {
53 		if (entry.ipn_next == NULL)
54 			last = 1;
55 		entry.ipn_next = top;
56 		top = malloc(sizeof(*top));
57 		if (top == NULL)
58 			break;
59 		bcopy(&entry, top, sizeof(entry));
60 	}
61 
62 	while (top != NULL) {
63 		node = top;
64 		(void) printpoolnode(node, opts);
65 		top = node->ipn_next;
66 		free(node);
67 		printed++;
68 
69 		if ((opts & OPT_DEBUG) == 0)
70 			putchar(';');
71 	}
72 
73 	if (printed == 0)
74 		putchar(';');
75 
76 	if ((opts & OPT_DEBUG) == 0)
77 		PRINTF(" };\n");
78 	return pool->ipo_next;
79 }
80