X-Git-Url: http://git.archive.openwrt.org/?p=project%2Ffirewall3.git;a=blobdiff_plain;f=zones.h;h=cf5ce3c7ee1da2fd81ee4bc4aec1e07c27c3bd5e;hp=8f94ccff7f5d67b0b456bea83937c06bb622a830;hb=35d57952d708007f5a08a72421fe55e775e3fd0f;hpb=62863ea95d3c2c7dd0b56ac0f1dee5a4590ca70c diff --git a/zones.h b/zones.h index 8f94ccf..cf5ce3c 100644 --- a/zones.h +++ b/zones.h @@ -20,6 +20,10 @@ #define __FW3_ZONES_H #include "options.h" +#include "iptables.h" + +/* 32 - sizeof("postrouting_") - sizeof("_rule") - sizeof("\0") */ +#define FW3_ZONE_MAXNAMELEN 14 extern const struct fw3_option fw3_zone_opts[]; @@ -27,22 +31,25 @@ struct fw3_zone * fw3_alloc_zone(void); void fw3_load_zones(struct fw3_state *state, struct uci_package *p); -void fw3_print_zone_chains(enum fw3_table table, enum fw3_family family, - bool reload, struct fw3_state *state); +void fw3_print_zone_chains(struct fw3_ipt_handle *handle, + struct fw3_state *state, bool reload); -void fw3_print_zone_rules(enum fw3_table table, enum fw3_family family, - bool reload, struct fw3_state *state); +void fw3_print_zone_rules(struct fw3_ipt_handle *handle, + struct fw3_state *state, bool reload); -void fw3_flush_zones(enum fw3_table table, enum fw3_family family, - bool pass2, bool reload, struct fw3_state *state); +void fw3_flush_zones(struct fw3_ipt_handle *handle, struct fw3_state *state, + bool reload); -struct fw3_zone * fw3_lookup_zone(struct fw3_state *state, const char *name, - bool running); +void fw3_hotplug_zones(struct fw3_state *state, bool add); -#define fw3_to_src_target(t) \ - (FW3_FLAG_SRC_ACCEPT - FW3_FLAG_ACCEPT + t) +struct fw3_zone * fw3_lookup_zone(struct fw3_state *state, const char *name); + +struct list_head * fw3_resolve_zone_addresses(struct fw3_zone *zone); #define fw3_free_zone(zone) \ fw3_free_object(zone, fw3_zone_opts) +#define fw3_to_src_target(t) \ + (FW3_FLAG_SRC_ACCEPT - FW3_FLAG_ACCEPT + t) + #endif