blob: ac2a6b3b9b355668a6705b5c7fd3c7e197b1b3a0 [file] [log] [blame]
Marc Bouchere6869a82000-03-20 06:03:29 +00001#ifndef _IPTABLES_USER_H
2#define _IPTABLES_USER_H
3
Rusty Russell79dee072000-05-02 16:45:16 +00004#include "iptables_common.h"
Marc Bouchere6869a82000-03-20 06:03:29 +00005#include "libiptc/libiptc.h"
6
7/* Include file for additions: new matches and targets. */
8struct iptables_match
9{
10 struct iptables_match *next;
11
12 ipt_chainlabel name;
13
14 const char *version;
15
16 /* Size of match data. */
17 size_t size;
18
Rusty Russelledf14cf2000-04-19 11:26:44 +000019 /* Size of match data relevent for userspace comparison purposes */
20 size_t userspacesize;
21
Marc Bouchere6869a82000-03-20 06:03:29 +000022 /* Function which prints out usage message. */
23 void (*help)(void);
24
25 /* Initialize the match. */
26 void (*init)(struct ipt_entry_match *m, unsigned int *nfcache);
27
28 /* Function which parses command options; returns true if it
29 ate an option */
30 int (*parse)(int c, char **argv, int invert, unsigned int *flags,
31 const struct ipt_entry *entry,
32 unsigned int *nfcache,
33 struct ipt_entry_match **match);
34
35 /* Final check; exit if not ok. */
36 void (*final_check)(unsigned int flags);
37
38 /* Prints out the match iff non-NULL: put space at end */
39 void (*print)(const struct ipt_ip *ip,
40 const struct ipt_entry_match *match, int numeric);
41
Rusty Russell79dee072000-05-02 16:45:16 +000042 /* Saves the match info in parsable form to stdout. */
Marc Bouchere6869a82000-03-20 06:03:29 +000043 void (*save)(const struct ipt_ip *ip,
44 const struct ipt_entry_match *match);
45
46 /* Pointer to list of extra command-line options */
Jan Echternachb6db3312000-08-27 07:39:08 +000047 const struct option *extra_opts;
Marc Bouchere6869a82000-03-20 06:03:29 +000048
49 /* Ignore these men behind the curtain: */
50 unsigned int option_offset;
51 struct ipt_entry_match *m;
52 unsigned int mflags;
Harald Weltea114e9e2000-12-01 14:28:19 +000053 unsigned int used;
Harald Welte3efb6ea2001-08-06 18:50:21 +000054#ifdef NO_SHARED_LIBS
55 unsigned int loaded; /* simulate loading so options are merged properly */
56#endif
Marc Bouchere6869a82000-03-20 06:03:29 +000057};
58
59struct iptables_target
60{
61 struct iptables_target *next;
62
63 ipt_chainlabel name;
64
65 const char *version;
66
67 /* Size of target data. */
68 size_t size;
69
Rusty Russelledf14cf2000-04-19 11:26:44 +000070 /* Size of target data relevent for userspace comparison purposes */
71 size_t userspacesize;
72
Marc Bouchere6869a82000-03-20 06:03:29 +000073 /* Function which prints out usage message. */
74 void (*help)(void);
75
76 /* Initialize the target. */
77 void (*init)(struct ipt_entry_target *t, unsigned int *nfcache);
78
79 /* Function which parses command options; returns true if it
80 ate an option */
81 int (*parse)(int c, char **argv, int invert, unsigned int *flags,
82 const struct ipt_entry *entry,
83 struct ipt_entry_target **target);
84
85 /* Final check; exit if not ok. */
86 void (*final_check)(unsigned int flags);
87
88 /* Prints out the target iff non-NULL: put space at end */
89 void (*print)(const struct ipt_ip *ip,
90 const struct ipt_entry_target *target, int numeric);
91
92 /* Saves the targinfo in parsable form to stdout. */
93 void (*save)(const struct ipt_ip *ip,
94 const struct ipt_entry_target *target);
95
96 /* Pointer to list of extra command-line options */
97 struct option *extra_opts;
98
99 /* Ignore these men behind the curtain: */
100 unsigned int option_offset;
101 struct ipt_entry_target *t;
102 unsigned int tflags;
Harald Weltea114e9e2000-12-01 14:28:19 +0000103 unsigned int used;
Harald Welte3efb6ea2001-08-06 18:50:21 +0000104#ifdef NO_SHARED_LIBS
105 unsigned int loaded; /* simulate loading so options are merged properly */
106#endif
Marc Bouchere6869a82000-03-20 06:03:29 +0000107};
108
109/* Your shared library should call one of these. */
110extern void register_match(struct iptables_match *me);
111extern void register_target(struct iptables_target *me);
112
Rusty Russell79dee072000-05-02 16:45:16 +0000113extern struct in_addr *dotted_to_addr(const char *dotted);
Marc Bouchere6869a82000-03-20 06:03:29 +0000114extern char *addr_to_dotted(const struct in_addr *addrp);
Marc Bouchere6869a82000-03-20 06:03:29 +0000115
116extern int do_command(int argc, char *argv[], char **table,
117 iptc_handle_t *handle);
118/* Keeping track of external matches and targets: linked lists. */
119extern struct iptables_match *iptables_matches;
120extern struct iptables_target *iptables_targets;
121
Rusty Russell79dee072000-05-02 16:45:16 +0000122enum ipt_tryload {
123 DONT_LOAD,
124 TRY_LOAD,
125 LOAD_MUST_SUCCEED
126};
127
128extern struct iptables_target *find_target(const char *name, enum ipt_tryload);
129extern struct iptables_match *find_match(const char *name, enum ipt_tryload);
Harald Weltea114e9e2000-12-01 14:28:19 +0000130
131extern int delete_chain(const ipt_chainlabel chain, int verbose,
132 iptc_handle_t *handle);
133extern int flush_entries(const ipt_chainlabel chain, int verbose,
134 iptc_handle_t *handle);
135extern int for_each_chain(int (*fn)(const ipt_chainlabel, int, iptc_handle_t *),
136 int verbose, int builtinstoo, iptc_handle_t *handle);
Marc Bouchere6869a82000-03-20 06:03:29 +0000137#endif /*_IPTABLES_USER_H*/