1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <string.h>
4 #include <errno.h>
5 #include <arpa/inet.h>
6 
7 #include <libnetfilter_conntrack/libnetfilter_conntrack.h>
8 
cb(enum nf_conntrack_msg_type type,struct nf_expect * exp,void * data)9 static int cb(enum nf_conntrack_msg_type type,
10 	      struct nf_expect *exp,
11 	      void *data)
12 {
13 	char buf[1024];
14 
15 	nfexp_snprintf(buf, 1024, exp, NFCT_T_UNKNOWN, NFCT_O_DEFAULT, 0);
16 	printf("%s\n", buf);
17 
18 	return NFCT_CB_CONTINUE;
19 }
20 
main(void)21 int main(void)
22 {
23 	int ret;
24 	struct nfct_handle *h;
25 	struct nf_conntrack *master;
26 	struct nf_expect *exp;
27 
28 	master = nfct_new();
29 	if (!master) {
30 		perror("nfct_new");
31 		exit(EXIT_FAILURE);
32 	}
33 
34 	nfct_set_attr_u8(master, ATTR_L3PROTO, AF_INET);
35 	nfct_set_attr_u32(master, ATTR_IPV4_SRC, inet_addr("1.1.1.1"));
36 	nfct_set_attr_u32(master, ATTR_IPV4_DST, inet_addr("2.2.2.2"));
37 
38 	nfct_set_attr_u8(master, ATTR_L4PROTO, IPPROTO_TCP);
39 	nfct_set_attr_u16(master, ATTR_PORT_SRC, htons(10240));
40 	nfct_set_attr_u16(master, ATTR_PORT_DST, htons(10241));
41 
42 	exp = nfexp_new();
43 	if (!exp) {
44 		perror("nfexp_new");
45 		nfct_destroy(master);
46 		exit(EXIT_FAILURE);
47 	}
48 
49 	nfexp_set_attr(exp, ATTR_EXP_MASTER, master);
50 
51 	h = nfct_open(EXPECT, 0);
52 	if (!h) {
53 		perror("nfct_open");
54 		nfct_destroy(master);
55 		return -1;
56 	}
57 
58 	nfexp_callback_register(h, NFCT_T_ALL, cb, NULL);
59 	ret = nfexp_query(h, NFCT_Q_GET, exp);
60 
61 	printf("TEST: get expectation ");
62 	if (ret == -1)
63 		printf("(%d)(%s)\n", ret, strerror(errno));
64 	else
65 		printf("(OK)\n");
66 
67 	nfct_close(h);
68 
69 	nfct_destroy(master);
70 
71 	ret == -1 ? exit(EXIT_FAILURE) : exit(EXIT_SUCCESS);
72 }
73