const struct fw3_option fw3_redirect_opts[] = {
+ FW3_OPT("enabled", bool, redirect, enabled),
+
FW3_OPT("name", string, redirect, name),
FW3_OPT("family", family, redirect, family),
INIT_LIST_HEAD(&redir->proto);
INIT_LIST_HEAD(&redir->mac_src);
+ redir->enabled = true;
redir->reflection = true;
fw3_parse_options(redir, fw3_redirect_opts, s);
+ if (!redir->enabled)
+ {
+ fw3_free_redirect(redir);
+ continue;
+ }
+
if (redir->src.invert)
{
warn_elem(e, "must not have an inverted source");
warn_elem(e, "has no source specified");
else
{
- setbit(redir->_src->dst_flags, redir->target);
+ set(redir->_src->flags, FW3_FAMILY_V4, redir->target);
redir->_src->conntrack = true;
valid = true;
}
if (redir->reflection && redir->_dest && redir->_src->masq)
{
- setbit(redir->_dest->dst_flags, FW3_TARGET_ACCEPT);
- setbit(redir->_dest->dst_flags, FW3_TARGET_DNAT);
- setbit(redir->_dest->dst_flags, FW3_TARGET_SNAT);
+ set(redir->_dest->flags, FW3_FAMILY_V4, FW3_TARGET_ACCEPT);
+ set(redir->_dest->flags, FW3_FAMILY_V4, FW3_TARGET_DNAT);
+ set(redir->_dest->flags, FW3_FAMILY_V4, FW3_TARGET_SNAT);
}
}
else
warn_elem(e, "has no src_dip option specified");
else
{
- setbit(redir->_dest->dst_flags, redir->target);
+ set(redir->_dest->flags, FW3_FAMILY_V4, redir->target);
redir->_dest->conntrack = true;
valid = true;
}
return;
}
- setbit(redir->_ipset->flags, family);
+ set(redir->_ipset->flags, family, family);
}
fw3_foreach(proto, &redir->proto)