blob: c53d026736f548b07c8e4452716fa27bf2e6ba54 [file] [log] [blame]
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <libnetfilter_conntrack/libnetfilter_conntrack.h>
static int n = 0;
static int
ct_event_cb(enum nf_conntrack_msg_type type,struct nf_conntrack *ct, void *data)
{
char buf[1024];
nfct_snprintf(buf, sizeof(buf), ct, type, NFCT_O_PLAIN, NFCT_OF_TIME);
printf("[CT] %s\n", buf);
if (++n == 20)
return NFCT_CB_STOP;
return NFCT_CB_CONTINUE;
}
static int
exp_event_cb(enum nf_conntrack_msg_type type,struct nf_expect *exp, void *data)
{
char buf[1024];
nfexp_snprintf(buf, 1024, exp, type, NFCT_O_DEFAULT, 0);
printf("[EXP] %s\n", buf);
if (++n == 20)
return NFCT_CB_STOP;
return NFCT_CB_CONTINUE;
}
int main(void)
{
int ret = 0;
struct nfct_handle *h;
h = nfct_open(NFNL_SUBSYS_NONE, NF_NETLINK_CONNTRACK_EXP_NEW |
NF_NETLINK_CONNTRACK_EXP_UPDATE |
NF_NETLINK_CONNTRACK_EXP_DESTROY |
NF_NETLINK_CONNTRACK_NEW |
NF_NETLINK_CONNTRACK_UPDATE |
NF_NETLINK_CONNTRACK_DESTROY);
if (h == NULL) {
perror("nfct_open");
return -1;
}
nfexp_callback_register(h, NFCT_T_ALL, exp_event_cb, NULL);
nfct_callback_register(h, NFCT_T_ALL, ct_event_cb, NULL);
printf("TEST: waiting for 20 expectation events...\n");
/* we may use nfexp_catch() instead, it would also work. */
ret = nfct_catch(h);
printf("TEST: expectation 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);
}