blob: a3eeebc9f69ae3c733f46244c875761204532c90 [file] [log] [blame]
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <arpa/inet.h>
#include <libnetfilter_conntrack/libnetfilter_conntrack.h>
#include <libnetfilter_conntrack/libnetfilter_conntrack_tcp.h>
static int event_cb(enum nf_conntrack_msg_type type,
struct nf_conntrack *ct,
void *data)
{
static int n = 0;
char buf[1024];
nfct_snprintf(buf, sizeof(buf), ct, type, NFCT_O_PLAIN, NFCT_OF_TIME);
printf("%s\n", buf);
if (++n == 10)
return NFCT_CB_STOP;
return NFCT_CB_CONTINUE;
}
int main(void)
{
int ret;
struct nfct_handle *h;
struct nfct_filter *filter;
h = nfct_open(CONNTRACK, NF_NETLINK_CONNTRACK_NEW |
NF_NETLINK_CONNTRACK_UPDATE);
if (!h) {
perror("nfct_open");
return 0;
}
filter = nfct_filter_create();
if (!filter) {
perror("nfct_create_filter");
return 0;
}
nfct_filter_add_attr_u32(filter, NFCT_FILTER_L4PROTO, IPPROTO_UDP);
nfct_filter_add_attr_u32(filter, NFCT_FILTER_L4PROTO, IPPROTO_TCP);
struct nfct_filter_proto filter_proto = {
.proto = IPPROTO_TCP,
.state = TCP_CONNTRACK_ESTABLISHED
};
nfct_filter_add_attr(filter, NFCT_FILTER_L4PROTO_STATE, &filter_proto);
/* BSF always wants data in host-byte order */
struct nfct_filter_ipv4 filter_ipv4 = {
.addr = ntohl(inet_addr("127.0.0.1")),
.mask = 0xffffffff,
};
/* ignore whatever that comes from 127.0.0.1 */
nfct_filter_set_logic(filter,
NFCT_FILTER_SRC_IPV4,
NFCT_FILTER_LOGIC_NEGATIVE);
nfct_filter_add_attr(filter, NFCT_FILTER_SRC_IPV4, &filter_ipv4);
/* BSF always wants data in host-byte order */
struct nfct_filter_ipv6 filter_ipv6 = {
.addr = { 0x0, 0x0, 0x0, 0x1 },
.mask = { 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff },
};
/* ignore whatever that comes from ::1 (loopback) */
nfct_filter_set_logic(filter,
NFCT_FILTER_SRC_IPV6,
NFCT_FILTER_LOGIC_NEGATIVE);
nfct_filter_add_attr(filter, NFCT_FILTER_SRC_IPV6, &filter_ipv6);
if (nfct_filter_attach(nfct_fd(h), filter) == -1) {
perror("nfct_filter_attach");
return 0;
}
/* release the filter object, this does not detach the filter */
nfct_filter_destroy(filter);
nfct_callback_register(h, NFCT_T_ALL, event_cb, NULL);
printf("TEST: waiting for 10 events...\n");
ret = nfct_catch(h);
printf("TEST: conntrack events ");
if (ret == -1)
printf("(%d)(%s)\n", ret, strerror(errno));
else
printf("(OK)\n");
nfct_close(h);
ret == -1 ? exit(EXIT_FAILURE) : exit(EXIT_SUCCESS);
}