--- /dev/null
+package utils
+
+import (
+ "crypto/sha512"
+ "fmt"
+)
+
+// 29 - len('CNI') - 2*len('-')
+const maxNameLen = 16
+
+// Generates a chain name to be used with iptables.
+// Ensures that the generated name is less than
+// 29 chars in length
+func FormatChainName(name string, id string) string {
+ h := sha512.Sum512([]byte(id))
+ if len(name) > maxNameLen {
+ return fmt.Sprintf("CNI-%s-%x", name[:len(name)-maxNameLen], h[:8])
+ }
+ return fmt.Sprintf("CNI-%s-%x", name, h[:8])
+}
--- /dev/null
+package utils_test
+
+import (
+ . "github.com/onsi/ginkgo"
+ . "github.com/onsi/gomega"
+
+ "testing"
+)
+
+func TestUtils(t *testing.T) {
+ RegisterFailHandler(Fail)
+ RunSpecs(t, "Utils Suite")
+}
--- /dev/null
+package utils
+
+import (
+ . "github.com/onsi/ginkgo"
+ . "github.com/onsi/gomega"
+)
+
+var _ = Describe("Utils", func() {
+ It("should format a short name", func() {
+ chain := FormatChainName("test", "1234")
+ Expect(chain).To(Equal("CNI-test-d404559f602eab6f"))
+ })
+
+ It("should truncate a long name", func() {
+ chain := FormatChainName("testalongnamethatdoesnotmakesense", "1234")
+ Expect(chain).To(Equal("CNI-testalongnamethat-d404559f602eab6f"))
+ })
+})
"github.com/appc/cni/pkg/ns"
"github.com/appc/cni/pkg/skel"
"github.com/appc/cni/pkg/types"
+ "github.com/appc/cni/pkg/utils"
"github.com/vishvananda/netlink"
)
}
if n.IPMasq {
- chain := "CNI-" + n.Name
+ chain := utils.FormatChainName(n.Name, args.ContainerID)
if err = ip.SetupIPMasq(ip.Network(&result.IP4.IP), chain); err != nil {
return err
}
package main
import (
- "crypto/sha512"
"encoding/json"
"errors"
"fmt"
"github.com/appc/cni/pkg/ns"
"github.com/appc/cni/pkg/skel"
"github.com/appc/cni/pkg/types"
+ "github.com/appc/cni/pkg/utils"
)
func init() {
}
if conf.IPMasq {
- h := sha512.Sum512([]byte(args.ContainerID))
- chain := fmt.Sprintf("CNI-%s-%x", conf.Name, h[:8])
+ chain := utils.FormatChainName(conf.Name, args.ContainerID)
if err = ip.SetupIPMasq(&result.IP4.IP, chain); err != nil {
return err
}
}
if conf.IPMasq {
- h := sha512.Sum512([]byte(args.ContainerID))
- chain := fmt.Sprintf("CNI-%s-%x", conf.Name, h[:8])
+ chain := utils.FormatChainName(conf.Name, args.ContainerID)
if err = ip.TeardownIPMasq(ipn, chain); err != nil {
return err
}
source ./build
-TESTABLE="plugins/ipam/dhcp plugins/main/loopback pkg/invoke pkg/ns pkg/skel pkg/types"
+TESTABLE="plugins/ipam/dhcp plugins/main/loopback pkg/invoke pkg/ns pkg/skel pkg/types pkg/utils"
FORMATTABLE="$TESTABLE libcni pkg/ip pkg/ns pkg/types pkg/ipam plugins/ipam/host-local plugins/main/bridge plugins/meta/flannel plugins/meta/tuning"
# user has not provided PKG override