#include #include #include #include #include #include #include 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); }