From 5b7a263e8f93c4fc064d4233d936cebb455e319c Mon Sep 17 00:00:00 2001 From: Etienne Champetier Date: Thu, 20 Apr 2023 11:14:51 -0400 Subject: [PATCH] tuning: fix cmdCheck when using IFNAME Fixes: c16cff9805427c5db34b43de3155769b362f596e Signed-off-by: Etienne Champetier --- plugins/meta/tuning/tuning.go | 43 +++++++++++++++++++++++------------ 1 file changed, 28 insertions(+), 15 deletions(-) diff --git a/plugins/meta/tuning/tuning.go b/plugins/meta/tuning/tuning.go index 03f4543f7..20946e66c 100644 --- a/plugins/meta/tuning/tuning.go +++ b/plugins/meta/tuning/tuning.go @@ -334,22 +334,13 @@ func cmdAdd(args *skel.CmdArgs) error { err = ns.WithNetNSPath(args.Netns, func(_ ns.NetNS) error { for key, value := range tuningConf.SysCtl { - key = strings.ReplaceAll(key, ".", string(os.PathSeparator)) - - // If the key contains `IFNAME` - substitute it with args.IfName - // to allow setting sysctls on a particular interface, on which - // other operations (like mac/mtu setting) are performed - key = strings.Replace(key, "IFNAME", args.IfName, 1) - - fileName := filepath.Join("/proc/sys", key) - - // Refuse to modify sysctl parameters that don't belong - // to the network subsystem. - if !strings.HasPrefix(fileName, "/proc/sys/net/") { - return fmt.Errorf("invalid net sysctl key: %q", key) + fileName, err := getSysctlFilename(key, args.IfName) + if err != nil { + return err } + content := []byte(value) - err := os.WriteFile(fileName, content, 0o644) + err = os.WriteFile(fileName, content, 0o644) if err != nil { return err } @@ -439,7 +430,10 @@ func cmdCheck(args *skel.CmdArgs) error { err = ns.WithNetNSPath(args.Netns, func(_ ns.NetNS) error { // Check each configured value vs what's currently in the container for key, confValue := range tuningConf.SysCtl { - fileName := filepath.Join("/proc/sys", strings.ReplaceAll(key, ".", "/")) + fileName, err := getSysctlFilename(key, args.IfName) + if err != nil { + return err + } contents, err := os.ReadFile(fileName) if err != nil { @@ -583,3 +577,22 @@ func validateArgs(args *skel.CmdArgs) error { } return nil } + +func getSysctlFilename(key, ifName string) (string, error) { + key = strings.ReplaceAll(key, ".", string(os.PathSeparator)) + + // If the key contains `IFNAME` - substitute it with args.IfName + // to allow setting sysctls on a particular interface, on which + // other operations (like mac/mtu setting) are performed + key = strings.Replace(key, "IFNAME", ifName, 1) + + fileName := filepath.Join("/proc/sys", key) + + // Refuse to modify sysctl parameters that don't belong + // to the network subsystem. + if !strings.HasPrefix(fileName, "/proc/sys/net/") { + return "", fmt.Errorf("invalid net sysctl key: %q", key) + } + + return fileName, nil +}