Blame bootstrap_ver/iptables/xshared.h

Packit Service fa126c
#ifndef IPTABLES_XSHARED_H
Packit Service fa126c
#define IPTABLES_XSHARED_H 1
Packit Service fa126c
Packit Service fa126c
#include <limits.h>
Packit Service fa126c
#include <stdbool.h>
Packit Service fa126c
#include <stdint.h>
Packit Service fa126c
#include <netinet/in.h>
Packit Service fa126c
#include <net/if.h>
Packit Service fa126c
#include <linux/netfilter_arp/arp_tables.h>
Packit Service fa126c
#include <linux/netfilter_ipv4/ip_tables.h>
Packit Service fa126c
#include <linux/netfilter_ipv6/ip6_tables.h>
Packit Service fa126c
Packit Service fa126c
#ifdef DEBUG
Packit Service fa126c
#define DEBUGP(x, args...) fprintf(stdout, x, ## args)
Packit Service fa126c
#else
Packit Service fa126c
#define DEBUGP(x, args...)
Packit Service fa126c
#endif
Packit Service fa126c
Packit Service fa126c
enum {
Packit Service fa126c
	OPT_NONE        = 0,
Packit Service fa126c
	OPT_NUMERIC     = 1 << 0,
Packit Service fa126c
	OPT_SOURCE      = 1 << 1,
Packit Service fa126c
	OPT_DESTINATION = 1 << 2,
Packit Service fa126c
	OPT_PROTOCOL    = 1 << 3,
Packit Service fa126c
	OPT_JUMP        = 1 << 4,
Packit Service fa126c
	OPT_VERBOSE     = 1 << 5,
Packit Service fa126c
	OPT_EXPANDED    = 1 << 6,
Packit Service fa126c
	OPT_VIANAMEIN   = 1 << 7,
Packit Service fa126c
	OPT_VIANAMEOUT  = 1 << 8,
Packit Service fa126c
	OPT_LINENUMBERS = 1 << 9,
Packit Service fa126c
	OPT_COUNTERS    = 1 << 10,
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
struct xtables_globals;
Packit Service fa126c
struct xtables_rule_match;
Packit Service fa126c
struct xtables_target;
Packit Service fa126c
Packit Service fa126c
/**
Packit Service fa126c
 * xtables_afinfo - protocol family dependent information
Packit Service fa126c
 * @kmod:		kernel module basename (e.g. "ip_tables")
Packit Service fa126c
 * @proc_exists:	file which exists in procfs when module already loaded
Packit Service fa126c
 * @libprefix:		prefix of .so library name (e.g. "libipt_")
Packit Service fa126c
 * @family:		nfproto family
Packit Service fa126c
 * @ipproto:		used by setsockopt (e.g. IPPROTO_IP)
Packit Service fa126c
 * @so_rev_match:	optname to check revision support of match
Packit Service fa126c
 * @so_rev_target:	optname to check revision support of target
Packit Service fa126c
 */
Packit Service fa126c
struct xtables_afinfo {
Packit Service fa126c
	const char *kmod;
Packit Service fa126c
	const char *proc_exists;
Packit Service fa126c
	const char *libprefix;
Packit Service fa126c
	uint8_t family;
Packit Service fa126c
	uint8_t ipproto;
Packit Service fa126c
	int so_rev_match;
Packit Service fa126c
	int so_rev_target;
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
/* trick for ebtables-compat, since watchers are targets */
Packit Service fa126c
struct ebt_match {
Packit Service fa126c
	struct ebt_match			*next;
Packit Service fa126c
	union {
Packit Service fa126c
		struct xtables_match		*match;
Packit Service fa126c
		struct xtables_target		*watcher;
Packit Service fa126c
	} u;
Packit Service fa126c
	bool					ismatch;
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
/* Fake ebt_entry */
Packit Service fa126c
struct ebt_entry {
Packit Service fa126c
	/* this needs to be the first field */
Packit Service fa126c
	unsigned int bitmask;
Packit Service fa126c
	unsigned int invflags;
Packit Service fa126c
	uint16_t ethproto;
Packit Service fa126c
	/* the physical in-dev */
Packit Service fa126c
	char in[IFNAMSIZ];
Packit Service fa126c
	/* the logical in-dev */
Packit Service fa126c
	char logical_in[IFNAMSIZ];
Packit Service fa126c
	/* the physical out-dev */
Packit Service fa126c
	char out[IFNAMSIZ];
Packit Service fa126c
	/* the logical out-dev */
Packit Service fa126c
	char logical_out[IFNAMSIZ];
Packit Service fa126c
	unsigned char sourcemac[6];
Packit Service fa126c
	unsigned char sourcemsk[6];
Packit Service fa126c
	unsigned char destmac[6];
Packit Service fa126c
	unsigned char destmsk[6];
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
struct iptables_command_state {
Packit Service fa126c
	union {
Packit Service fa126c
		struct ebt_entry eb;
Packit Service fa126c
		struct ipt_entry fw;
Packit Service fa126c
		struct ip6t_entry fw6;
Packit Service fa126c
		struct arpt_entry arp;
Packit Service fa126c
	};
Packit Service fa126c
	int invert;
Packit Service fa126c
	int c;
Packit Service fa126c
	unsigned int options;
Packit Service fa126c
	struct xtables_rule_match *matches;
Packit Service fa126c
	struct ebt_match *match_list;
Packit Service fa126c
	struct xtables_target *target;
Packit Service fa126c
	struct xt_counters counters;
Packit Service fa126c
	char *protocol;
Packit Service fa126c
	int proto_used;
Packit Service fa126c
	const char *jumpto;
Packit Service fa126c
	char **argv;
Packit Service fa126c
	bool restore;
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
typedef int (*mainfunc_t)(int, char **);
Packit Service fa126c
Packit Service fa126c
struct subcommand {
Packit Service fa126c
	const char *name;
Packit Service fa126c
	mainfunc_t main;
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
enum {
Packit Service fa126c
	XT_OPTION_OFFSET_SCALE = 256,
Packit Service fa126c
};
Packit Service fa126c
Packit Service fa126c
extern void print_extension_helps(const struct xtables_target *,
Packit Service fa126c
	const struct xtables_rule_match *);
Packit Service fa126c
extern const char *proto_to_name(uint8_t, int);
Packit Service fa126c
extern int command_default(struct iptables_command_state *,
Packit Service fa126c
	struct xtables_globals *);
Packit Service fa126c
extern struct xtables_match *load_proto(struct iptables_command_state *);
Packit Service fa126c
extern int subcmd_main(int, char **, const struct subcommand *);
Packit Service fa126c
extern void xs_init_target(struct xtables_target *);
Packit Service fa126c
extern void xs_init_match(struct xtables_match *);
Packit Service fa126c
Packit Service fa126c
/**
Packit Service fa126c
 * Values for the iptables lock.
Packit Service fa126c
 *
Packit Service fa126c
 * A value >= 0 indicates the lock filedescriptor. Other values are:
Packit Service fa126c
 *
Packit Service fa126c
 * XT_LOCK_FAILED : The lock could not be acquired.
Packit Service fa126c
 *
Packit Service fa126c
 * XT_LOCK_BUSY : The lock was held by another process. xtables_lock only
Packit Service fa126c
 * returns this value when |wait| == false. If |wait| == true, xtables_lock
Packit Service fa126c
 * will not return unless the lock has been acquired.
Packit Service fa126c
 *
Packit Service fa126c
 * XT_LOCK_NOT_ACQUIRED : We have not yet attempted to acquire the lock.
Packit Service fa126c
 */
Packit Service fa126c
enum {
Packit Service fa126c
	XT_LOCK_BUSY = -1,
Packit Service fa126c
	XT_LOCK_FAILED = -2,
Packit Service fa126c
	XT_LOCK_NOT_ACQUIRED  = -3,
Packit Service fa126c
};
Packit Service fa126c
extern void xtables_unlock(int lock);
Packit Service fa126c
extern int xtables_lock_or_exit(int wait, struct timeval *tv);
Packit Service fa126c
Packit Service fa126c
int parse_wait_time(int argc, char *argv[]);
Packit Service fa126c
void parse_wait_interval(int argc, char *argv[], struct timeval *wait_interval);
Packit Service fa126c
int parse_counters(const char *string, struct xt_counters *ctr);
Packit Service fa126c
bool xs_has_arg(int argc, char *argv[]);
Packit Service fa126c
Packit Service fa126c
extern const struct xtables_afinfo *afinfo;
Packit Service fa126c
Packit Service fa126c
extern char *newargv[];
Packit Service fa126c
extern int newargc;
Packit Service fa126c
Packit Service fa126c
extern char *oldargv[];
Packit Service fa126c
extern int oldargc;
Packit Service fa126c
Packit Service fa126c
extern int newargvattr[];
Packit Service fa126c
Packit Service fa126c
int add_argv(const char *what, int quoted);
Packit Service fa126c
void free_argv(void);
Packit Service fa126c
void save_argv(void);
Packit Service fa126c
void add_param_to_argv(char *parsestart, int line);
Packit Service fa126c
Packit Service fa126c
void print_ipv4_addresses(const struct ipt_entry *fw, unsigned int format);
Packit Service fa126c
void print_ipv6_addresses(const struct ip6t_entry *fw6, unsigned int format);
Packit Service fa126c
Packit Service fa126c
void print_ifaces(const char *iniface, const char *outiface, uint8_t invflags,
Packit Service fa126c
		  unsigned int format);
Packit Service fa126c
Packit Service fa126c
void command_match(struct iptables_command_state *cs);
Packit Service fa126c
const char *xt_parse_target(const char *targetname);
Packit Service fa126c
void command_jump(struct iptables_command_state *cs);
Packit Service fa126c
Packit Service fa126c
#endif /* IPTABLES_XSHARED_H */