network: add publicly mapped ports to FORWARD table
Allow publicly mapped ports to be made public beyond the host. This is needed for distros like Fedora and RHEL which have a reject all rule at the end of their FORWARD table. Docker-DCO-1.1-Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com> (github: jpoimboe)
This commit is contained in:
parent
8a7c81a41c
commit
c6b78b9d31
1 changed files with 17 additions and 0 deletions
|
@ -73,6 +73,23 @@ func (c *Chain) Forward(action Action, ip net.IP, port int, proto, dest_addr str
|
||||||
} else if len(output) != 0 {
|
} else if len(output) != 0 {
|
||||||
return fmt.Errorf("Error iptables forward: %s", output)
|
return fmt.Errorf("Error iptables forward: %s", output)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fAction := action
|
||||||
|
if fAction == Add {
|
||||||
|
fAction = "-I"
|
||||||
|
}
|
||||||
|
if output, err := Raw(string(fAction), "FORWARD",
|
||||||
|
"!", "-i", c.Bridge,
|
||||||
|
"-o", c.Bridge,
|
||||||
|
"-p", proto,
|
||||||
|
"-d", daddr,
|
||||||
|
"--dport", strconv.Itoa(port),
|
||||||
|
"-j", "ACCEPT"); err != nil {
|
||||||
|
return err
|
||||||
|
} else if len(output) != 0 {
|
||||||
|
return fmt.Errorf("Error iptables forward: %s", output)
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue