File: libipfwc.h

package info (click to toggle)
ipchains-perl 1%3A0.5-12
  • links: PTS
  • area: main
  • in suites: woody
  • size: 260 kB
  • ctags: 467
  • sloc: ansic: 3,836; perl: 246; makefile: 47
file content (88 lines) | stat: -rw-r--r-- 3,794 bytes parent folder | download | duplicates (2)
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
88
#ifndef _LIBIPFWC_H
#define _LIBIPFWC_H
/* Library which manipulates firewall rules.  Version 0.1. */

/* This might not be the most efficient way of manipulating the rules,
 * but I'll maintain this as long as possible... */

/* (C)1998 Paul ``Rusty'' Russell - Placed under the GNU GPL (See
   COPYING for details). */

#include "ipfwc.h"

/* Gets the names of all the chains.  Returns internal pointer to
   array of ipfwc_fwchain.  Fills in num_chains.  You don't need to be
   root.  Returns NULL on error.*/
struct ipfwc_fwchain *ipfwc_get_chainnames(unsigned int *num_chains);

/* Take a snapshot of the rules; if zero is set, clears counters.
   Uses ipfwc_get_chainnames.  Returns internal pointer to array of
   ipfwc_fwrules.  Fills in num_rules.  You don't need to be
   root, unless zero is set.  Returns NULL on error. */
struct ipfwc_fwrule *ipfwc_get_rules(unsigned int *num_rules, int zero);

/* These functions return TRUE for OK or 0 and set errno.  If errno ==
   0, it means there was a version error (ie. upgrade libipfwc). */
/* Rule numbers start at 1 for the first rule. */

/* Insert the entry `fw' in chain `chain' into position `rulenum'. */
int ipfwc_insert_entry(const ip_chainlabel chain, 
                       const struct ip_fwuser *fw, 
                       unsigned int rulenum);

/* Atomically replace rule `rulenum' in `chain' with `fw'. */
int ipfwc_replace_entry(const ip_chainlabel chain, 
                        const struct ip_fwuser *fw, 
                        unsigned int rulenum);

/* Append entry `fw' to chain `chain'.  Equivalent to insert with
   rulenum = length of chain. */
int ipfwc_append_entry(const ip_chainlabel chain, const struct ip_fwuser *fw);

/* Delete the first rule in `chain' which matches `fw'. */
int ipfwc_delete_entry(const ip_chainlabel chain, const struct ip_fwuser *fw);

/* Delete the rule in position `rulenum' in `chain'. */
int ipfwc_delete_num_entry(const ip_chainlabel chain, unsigned int rulenum);

/* Check the packet `fw' on chain `chain'.  Returns the verdict, or
   NULL and sets errno. */
const char *ipfwc_check_packet(const ip_chainlabel chain, struct ip_fw *fw);

/* Flushes the entries in the given chain (ie. empties chain). */
int ipfwc_flush_entries(const ip_chainlabel chain);

/* Zeroes the counters in a chain. */
int ipfwc_zero_entries(const ip_chainlabel chain);

/* Creates a new chain. */
int ipfwc_create_chain(const ip_chainlabel chain);

/* Deletes a chain. */
int ipfwc_delete_chain(const ip_chainlabel chain);

/* Sets the policy on a built-in chain. */
int ipfwc_set_policy(const ip_chainlabel chain, const ip_chainlabel policy);

/* Translates errno numbers into more human-readable form than strerror. */
const char *ipfwc_strerror(int err);

/* These are the functions you should use from perl. */
/* ipfw_init is the main function and should be called via the others */

int ipfw_init(int args, char **arglist, unsigned int command, const char *chain, unsigned int rulenum);

int ipfw_append(int args, char **arglist, const char *chain);
int ipfw_delete(int args, char **arglist, const char *chain, unsigned int rulenum);
int ipfw_check(int args, char **arglist, const char *chain);
int ipfw_replace(int args, char **arglist, const char *chain, unsigned int rulenum);
int ipfw_insert(int args, char **arglist, const char *chain, unsigned int rulenum);
int ipfw_list(int args, char **arglist, const char *chain);
int ipfw_flush(int args, char **arglist, const char *chain);
int ipfw_zero(int args, char **arglist);
int ipfw_masq(int args, char **arglist);
int ipfw_new_chain(int args, char **arglist, const char *chain);
int ipfw_del_chain(int args, char **arglist, const char *chain);
int ipfw_set_policy(int args, char **arglist, const char *chain);

#endif /* _LIBIPFWC_H */