From 0cf0c441d1d7640fe406dc4874168be6be6051a8 Mon Sep 17 00:00:00 2001 From: Tom Wieczorek Date: Thu, 11 Apr 2024 23:00:34 +0200 Subject: [PATCH] Use file.WriteAtomically to write keepalived config file This aligns with other file generation routines in k0s. Also, use template.Must(...) to parse the template string, as it's a hard coded constant. Signed-off-by: Tom Wieczorek --- pkg/component/controller/cplb_unix.go | 38 ++++++++++++--------------- 1 file changed, 17 insertions(+), 21 deletions(-) diff --git a/pkg/component/controller/cplb_unix.go b/pkg/component/controller/cplb_unix.go index ef8820f1e287..de26f0ea6316 100644 --- a/pkg/component/controller/cplb_unix.go +++ b/pkg/component/controller/cplb_unix.go @@ -19,16 +19,18 @@ limitations under the License. package controller import ( + "bufio" "context" "errors" "fmt" - "io/fs" + "io" "net" "os" "path/filepath" "slices" "text/template" + "github.com/k0sproject/k0s/internal/pkg/file" "github.com/k0sproject/k0s/internal/pkg/users" k0sAPI "github.com/k0sproject/k0s/pkg/apis/k0s/v1beta1" "github.com/k0sproject/k0s/pkg/assets" @@ -257,31 +259,25 @@ func (*Keepalived) getLinkAddresses(link netlink.Link) ([]netlink.Addr, []string } func (k *Keepalived) generateKeepalivedTemplate() error { - f, err := os.OpenFile(k.configFilePath, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, fs.FileMode(0500)) - if err != nil { - return fmt.Errorf("failed to open keepalived config file: %v", err) - } - defer f.Close() - - template, err := template.New("keepalived").Parse(keepalivedConfigTemplate) - if err != nil { - return fmt.Errorf("failed to parse keepalived template: %v", err) - } - + template := template.Must(template.New("keepalived").Parse(keepalivedConfigTemplate)) kc := keepalivedConfig{ VRRPInstances: k.Config.VRRPInstances, } - if err = template.Execute(f, kc); err != nil { - return fmt.Errorf("failed to execute keepalived template: %v", err) - } - // TODO: Do we really need to this every single time? - if err = os.Chown(k.configFilePath, k.uid, -1); err != nil { - return fmt.Errorf("failed to chown keepalived config file: %v", err) - } - if err = os.Chmod(k.configFilePath, fs.FileMode(0400)); err != nil { - return fmt.Errorf("failed to chmod keepalived config file: %v", err) + if err := file.WriteAtomically(k.configFilePath, 0500, func(file io.Writer) error { + if err := file.(*os.File).Chown(k.uid, -1); err != nil { + return err + } + + w := bufio.NewWriter(file) + if err := template.Execute(w, kc); err != nil { + return err + } + return w.Flush() + }); err != nil { + return fmt.Errorf("failed to write keepalived config file: %w", err) } + return nil }