From a8f6b9f8f0d90330cfb259b088925808ca01bef1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edu=20G=C3=B3mez=20Escandell?= Date: Fri, 27 Oct 2023 17:21:10 +0200 Subject: [PATCH] Config: dump no longer writes to the regisry --- .../internal/config/config_marshal.go | 52 ------------------- 1 file changed, 52 deletions(-) diff --git a/windows-agent/internal/config/config_marshal.go b/windows-agent/internal/config/config_marshal.go index 52cb944b5..637d16b67 100644 --- a/windows-agent/internal/config/config_marshal.go +++ b/windows-agent/internal/config/config_marshal.go @@ -97,13 +97,6 @@ func readFromRegistry(r Registry, key uintptr, field string) (string, error) { func (c Config) dump() (err error) { defer decorate.OnError(&err, "could not store Config data") - // Backup the file in case the registry write fails. - // This avoids partial writes - restore, err := makeBackup(c.cachePath) - if err != nil { - return err - } - h := marshalHelper{ Landscape: c.landscape, Subscription: c.subscription, @@ -113,51 +106,6 @@ func (c Config) dump() (err error) { return err } - if err := h.dumpRegistry(c.registry); err != nil { - return errors.Join(err, restore()) - } - - return nil -} - -// makeBackup makes a backup of the selected file. It returns -// a restoring function. -func makeBackup(originalPath string) (func() error, error) { - backupPath := originalPath + ".backup" - - err := os.Rename(originalPath, backupPath) - if errors.Is(err, fs.ErrNotExist) { - // File does not exist. Restoring means deleting it. - return func() error { - return os.RemoveAll(originalPath) - }, nil - } - if err != nil { - return nil, fmt.Errorf("could not create backup: %v", err) - } - - // File does exist. Restoring means moving it back. - return func() error { - return os.Rename(backupPath, originalPath) - }, nil -} - -func (h marshalHelper) dumpRegistry(reg Registry) error { - // CreateKey is equivalent to OpenKey if the key already existed - k, err := reg.HKCUCreateKey(registryPath, registry.WRITE) - if err != nil { - return fmt.Errorf("could not open or create registry key: %w", err) - } - defer reg.CloseKey(k) - - if err := reg.WriteValue(k, "UbuntuProToken", h.Subscription.Organization); err != nil { - return fmt.Errorf("could not write UbuntuProToken into registry key: %v", err) - } - - if err := reg.WriteMultilineValue(k, "LandscapeConfig", h.Landscape.OrgConfig); err != nil { - return fmt.Errorf("could not write LandscapeConfig into registry key: %v", err) - } - return nil }