1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/*
* Copyright (C) 2012 by Darren Reed.
*
* See the IPFILTER.LICENCE file for details on licencing.
*
* $Id: load_dstlistnode.c,v 1.1.2.5 2012/07/22 08:04:24 darren_r Exp $
*/
#include <fcntl.h>
#include <sys/ioctl.h>
#include "ipf.h"
#include "netinet/ip_lookup.h"
#include "netinet/ip_pool.h"
int
load_dstlistnode(int role, char *name, ipf_dstnode_t *node,
ioctlfunc_t iocfunc)
{
iplookupop_t op;
frdest_t *dst;
char *what;
int err;
if (pool_open() == -1)
return (-1);
dst = calloc(1, sizeof(*dst) + node->ipfd_dest.fd_name);
if (dst == NULL)
return (-1);
op.iplo_unit = role;
op.iplo_type = IPLT_DSTLIST;
op.iplo_arg = 0;
op.iplo_struct = dst;
op.iplo_size = sizeof(*dst);
if (node->ipfd_dest.fd_name >= 0)
op.iplo_size += node->ipfd_dest.fd_name;
(void) strncpy(op.iplo_name, name, sizeof(op.iplo_name));
dst->fd_addr = node->ipfd_dest.fd_addr;
dst->fd_type = node->ipfd_dest.fd_type;
dst->fd_name = node->ipfd_dest.fd_name;
if (node->ipfd_dest.fd_name >= 0)
bcopy(node->ipfd_names, (char *)dst + sizeof(*dst),
node->ipfd_dest.fd_name);
if ((opts & OPT_REMOVE) == 0) {
what = "add";
err = pool_ioctl(iocfunc, SIOCLOOKUPADDNODE, &op);
} else {
what = "delete";
err = pool_ioctl(iocfunc, SIOCLOOKUPDELNODE, &op);
}
free(dst);
if (err != 0) {
if ((opts & OPT_DONOTHING) == 0) {
char msg[80];
(void) snprintf(msg, sizeof(msg), "%s lookup node", what);
return (ipf_perror_fd(pool_fd(), iocfunc, msg));
}
}
return (0);
}
|