summaryrefslogtreecommitdiffstats
path: root/include/libnfnetlink_queue/libnfnetlink_queue.h
blob: 9c2b40d5a5aa728974f5614bc3c1aa1f8bb57c91 (plain)
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/* libnfqnetlink.h: Header file for the Netfilter Queue library.
 *
 * (C) 2005 by Harald Welte <laforge@gnumonks.org>
 *
 *
 * Changelog : 
 * 	(2005/08/11)  added  parsing function (Eric Leblond <regit@inl.fr>)
 * 
 * This software may be used and distributed according to the terms
 * of the GNU General Public License, incorporated herein by reference.
 */

#ifndef __LIBCTNETLINK_H
#define __LIBCTNETLINK_H

#include <libnfnetlink/libnfnetlink.h>

#include <linux/netfilter/nfnetlink.h>
#include <linux/netfilter/nfnetlink_queue.h>

struct nfqnl_handle;
struct nfqnl_q_handle;

extern int nfqnl_errno;

extern struct nfnl_handle *nfqnl_nfnlh(struct nfqnl_handle *h);
extern int nfqnl_fd(struct nfqnl_handle *h);

typedef int  nfqnl_callback(struct nfqnl_q_handle *gh, struct nfgenmsg *nfmsg,
		       struct nfattr *nfa[], void *data);


extern struct nfqnl_handle *nfqnl_open(void);
extern int nfqnl_close(struct nfqnl_handle *h);

extern int nfqnl_bind_pf(struct nfqnl_handle *h, u_int16_t pf);
extern int nfqnl_unbind_pf(struct nfqnl_handle *h, u_int16_t pf);

extern struct nfqnl_q_handle *nfqnl_create_queue(struct nfqnl_handle *h,
			      			 u_int16_t num,
						 nfqnl_callback *cb,
						 void *data);
extern int nfqnl_destroy_queue(struct nfqnl_q_handle *qh);

extern int nfqnl_handle_packet(struct nfqnl_handle *h, char *buf, int len);

extern int nfqnl_set_mode(struct nfqnl_q_handle *qh,
			  u_int8_t mode, unsigned int len);

extern int nfqnl_set_verdict(struct nfqnl_q_handle *qh,
			     u_int32_t id,
			     u_int32_t verdict,
			     u_int32_t data_len,
			     unsigned char *buf);

extern int nfqnl_set_verdict_mark(struct nfqnl_q_handle *qh, 
				  u_int32_t id,
			   	  u_int32_t verdict, 
				  u_int32_t mark,
			   	  u_int32_t datalen,
				  unsigned char *buf);

/* message parsing function */

extern struct nfqnl_msg_packet_hdr *
				nfqnl_get_msg_packet_hdr(struct nfattr *nfa[]);

extern u_int32_t nfqnl_get_nfmark(struct nfattr *nfa[]);

extern struct nfqnl_msg_packet_timestamp *
				nfqnl_get_timestamp(struct nfattr *nfa[]);

/* return 0 if not set */
extern u_int32_t nfqnl_get_indev(struct nfattr *nfa[]);
extern u_int32_t nfqnl_get_physindev(struct nfattr *nfa[]);
extern u_int32_t nfqnl_get_outdev(struct nfattr *nfa[]);
extern u_int32_t nfqnl_get_physoutdev(struct nfattr *nfa[]);

extern struct nfqnl_msg_packet_hw *nfqnl_get_packet_hw(struct nfattr *nfa[]);

/* return 0 if problem */
extern int nfqnl_get_payload(struct nfattr *nfa[],
			     char ** data, unsigned int* datalen);



#endif	/* __LIBNFQNETLINK_H */