12345678910111213141516171819202122232425262728293031323334353637 |
- package bridge
- import (
- "fmt"
- "io/ioutil"
- "net"
- "github.com/vishvananda/netlink"
- )
- var BridgeIPv6 *net.IPNet
- const BridgeIPv6Str = "fe80::1/64"
- func init() {
- // We allow ourselves to panic in this special case because we indicate a
- // failure to parse a compile-time define constant.
- if ip, netw, err := net.ParseCIDR(BridgeIPv6Str); err == nil {
- BridgeIPv6 = &net.IPNet{IP: ip, Mask: netw.Mask}
- } else {
- panic(fmt.Sprintf("Cannot parse default bridge IPv6 address %q: %v", BridgeIPv6Str, err))
- }
- }
- func SetupBridgeIPv6(i *Interface) error {
- // Enable IPv6 on the bridge
- procFile := "/proc/sys/net/ipv6/conf/" + i.Config.BridgeName + "/disable_ipv6"
- if err := ioutil.WriteFile(procFile, []byte{'0', '\n'}, 0644); err != nil {
- return fmt.Errorf("Unable to enable IPv6 addresses on bridge: %v", err)
- }
- if err := netlink.AddrAdd(i.Link, &netlink.Addr{BridgeIPv6, ""}); err != nil {
- return fmt.Errorf("Failed to add IPv6 address %s to bridge: %v", BridgeIPv6, err)
- }
- return nil
- }
|