From c91735ea65d566cd60ee7c731d9f79fbeb0433a8 Mon Sep 17 00:00:00 2001 From: Boris Glimcher Date: Mon, 22 Jul 2024 23:57:24 +0300 Subject: [PATCH] refactor: put logic in discoverBootstrapURLs - if user gave us URL, use it - else if user gave us lease file, use it - else try to fecth from network manager via dbus Signed-off-by: Boris Glimcher --- sztp-agent/pkg/secureagent/agent.go | 4 ++- sztp-agent/pkg/secureagent/agent_test.go | 3 +- sztp-agent/pkg/secureagent/daemon.go | 42 +++++++++++++++++------- 3 files changed, 36 insertions(+), 13 deletions(-) diff --git a/sztp-agent/pkg/secureagent/agent.go b/sztp-agent/pkg/secureagent/agent.go index 774a96a0..e248dc42 100644 --- a/sztp-agent/pkg/secureagent/agent.go +++ b/sztp-agent/pkg/secureagent/agent.go @@ -70,6 +70,7 @@ type BootstrapServerErrorOutput struct { // Agent is the basic structure to define an agent instance type Agent struct { + InputBootstrapURL string // Bootstrap complete URL given by USER BootstrapURL string // Bootstrap complete URL SerialNumber string // Device's Serial Number DevicePassword string // Device's Password @@ -87,7 +88,8 @@ type Agent struct { func NewAgent(bootstrapURL, serialNumber, dhcpLeaseFile, devicePassword, devicePrivateKey, deviceEndEntityCert, bootstrapTrustAnchorCert string) *Agent { return &Agent{ - BootstrapURL: bootstrapURL, + InputBootstrapURL: bootstrapURL, + BootstrapURL: "", SerialNumber: GetSerialNumber(serialNumber), DevicePassword: devicePassword, DevicePrivateKey: devicePrivateKey, diff --git a/sztp-agent/pkg/secureagent/agent_test.go b/sztp-agent/pkg/secureagent/agent_test.go index c3de2aa9..ad2ebb09 100644 --- a/sztp-agent/pkg/secureagent/agent_test.go +++ b/sztp-agent/pkg/secureagent/agent_test.go @@ -846,7 +846,8 @@ func TestNewAgent(t *testing.T) { bootstrapTrustAnchorCert: "TestBootstrapTrustCert", }, want: &Agent{ - BootstrapURL: "TestBootstrap", + InputBootstrapURL: "TestBootstrap", + BootstrapURL: "", SerialNumber: "TestSerialNumber", DevicePassword: "TestDevicePassword", DevicePrivateKey: "TestDevicePrivateKey", diff --git a/sztp-agent/pkg/secureagent/daemon.go b/sztp-agent/pkg/secureagent/daemon.go index 2ca807e0..4835af90 100644 --- a/sztp-agent/pkg/secureagent/daemon.go +++ b/sztp-agent/pkg/secureagent/daemon.go @@ -56,11 +56,9 @@ func (a *Agent) RunCommandDaemon() error { func (a *Agent) performBootstrapSequence() error { var err error - if a.GetBootstrapURL() == "" { - err = a.discoverBootstrapURLs() - if err != nil { - return err - } + err = a.discoverBootstrapURLs() + if err != nil { + return err } err = a.doRequestBootstrapServerOnboardingInfo() if err != nil { @@ -91,6 +89,31 @@ func (a *Agent) performBootstrapSequence() error { } func (a *Agent) discoverBootstrapURLs() error { + log.Println("[INFO] Discovering the Bootstrap URL") + if a.InputBootstrapURL != "" { + log.Println("[INFO] User gave us the Bootstrap URL: " + a.InputBootstrapURL) + a.SetBootstrapURL(a.InputBootstrapURL) + log.Println("[INFO] Bootstrap URL retrieved successfully: " + a.GetBootstrapURL()) + return nil + } + if a.DhcpLeaseFile != "" { + log.Println("[INFO] User gave us the DHCP Lease File: " + a.DhcpLeaseFile) + url, err := a.getBootstrapURLsViaLeaseFile() + if err != nil { + return err + } + a.SetBootstrapURL(url) + log.Println("[INFO] Bootstrap URL retrieved successfully: " + a.GetBootstrapURL()) + return nil + } + log.Println("[INFO] User gave us nothing, discover the Bootstrap URL from Network Manager via dbus") + // TODO: fetch the Bootstrap URL from Network Manager via dbus in the future + log.Println("[INFO] Bootstrap URL retrieved successfully: " + a.GetBootstrapURL()) + return nil +} + +// TODO: move this function into DHCP package folder +func (a *Agent) getBootstrapURLsViaLeaseFile() (string, error) { log.Println("[INFO] Get the Bootstrap URL from DHCP client") var line string if _, err := os.Stat(a.DhcpLeaseFile); err == nil { @@ -100,13 +123,10 @@ func (a *Agent) discoverBootstrapURLs() error { break } } - a.SetBootstrapURL(extractfromLine(line, `(?m)[^"]*`, 1)) - } else { - log.Printf("[ERROR] File " + a.DhcpLeaseFile + " does not exist\n") - return errors.New(" File " + a.DhcpLeaseFile + " does not exist\n") + return extractfromLine(line, `(?m)[^"]*`, 1), nil } - log.Println("[INFO] Bootstrap URL retrieved successfully: " + a.GetBootstrapURL()) - return nil + log.Println("[Error] File " + a.DhcpLeaseFile + " does not exist") + return "", errors.New("File " + a.DhcpLeaseFile + " does not exist") } func (a *Agent) doHandleBootstrapRedirect() error {