From 0aa5d6ad2fb7843b3da1009ea5a54c4990d9bccc Mon Sep 17 00:00:00 2001 From: Jake Schuurmans Date: Mon, 30 Sep 2024 13:24:52 -0400 Subject: [PATCH] FS-1729; Set/Upload BiosCfg skeleton - move actions to their own file for cleanliness - Update Rivets, add new biosControl action - add new biosControl action to handler - add new functions to store/bmc to support SetBiosConfig - TODO; Add correct bmcClient call in store/bmc --- go.mod | 8 +++--- go.sum | 16 +++++++---- internal/bioscfg/action.go | 50 +++++++++++++++++++++++++++++++++ internal/bioscfg/handler.go | 43 +++------------------------- internal/store/bmc/bmc.go | 11 +++++++- internal/store/bmc/dryRun.go | 6 +++- internal/store/bmc/interface.go | 3 +- 7 files changed, 85 insertions(+), 52 deletions(-) create mode 100644 internal/bioscfg/action.go diff --git a/go.mod b/go.mod index 156b9f0..11f1584 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module github.com/metal-toolbox/bioscfg go 1.22.1 require ( - github.com/bmc-toolbox/bmclib/v2 v2.2.4 + github.com/bmc-toolbox/bmclib/v2 v2.3.0 github.com/bombsimon/logrusr/v2 v2.0.1 github.com/coreos/go-oidc v2.2.1+incompatible github.com/equinix-labs/otel-init-go v0.0.9 @@ -12,7 +12,7 @@ require ( github.com/jeremywohl/flatten v1.0.1 github.com/metal-toolbox/ctrl v0.2.9 github.com/metal-toolbox/fleetdb v1.19.5 - github.com/metal-toolbox/rivets v1.3.8 + github.com/metal-toolbox/rivets v1.3.9-0.20240930172024-b54836e2f7ec github.com/mitchellh/copystructure v1.2.0 github.com/mitchellh/mapstructure v1.5.0 github.com/pkg/errors v0.9.1 @@ -36,7 +36,7 @@ require ( github.com/VictorLowther/soap v0.0.0-20150314151524-8e36fca84b22 // indirect github.com/banzaicloud/logrus-runtime-formatter v0.0.0-20190729070250-5ae5475bae5e // indirect github.com/beorn7/perks v1.0.1 // indirect - github.com/bmc-toolbox/common v0.0.0-20240723142833-87832458b53b // indirect + github.com/bmc-toolbox/common v0.0.0-20240806132831-ba8adc6a35e3 // indirect github.com/bytedance/sonic v1.12.1 // indirect github.com/bytedance/sonic/loader v0.2.0 // indirect github.com/cenkalti/backoff/v4 v4.3.0 // indirect @@ -112,7 +112,7 @@ require ( github.com/spf13/afero v1.11.0 // indirect github.com/spf13/cast v1.6.0 // indirect github.com/spf13/pflag v1.0.5 // indirect - github.com/stmcginnis/gofish v0.15.1-0.20231121142100-22a60a77be91 // indirect + github.com/stmcginnis/gofish v0.19.0 // indirect github.com/stretchr/objx v0.5.2 // indirect github.com/subosito/gotenv v1.6.0 // indirect github.com/twitchyliquid64/golang-asm v0.15.1 // indirect diff --git a/go.sum b/go.sum index 43373b7..c850c84 100644 --- a/go.sum +++ b/go.sum @@ -111,10 +111,10 @@ github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+Ce github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= -github.com/bmc-toolbox/bmclib/v2 v2.2.4 h1:agAQuDLI/NNpKkxU+c+NfPZAu8ENBDE+kcTfz7WTCrw= -github.com/bmc-toolbox/bmclib/v2 v2.2.4/go.mod h1:V2XVg0Scpm16+0gE7WnI+5bU/M0c/o/nPZKHKzyVjAo= -github.com/bmc-toolbox/common v0.0.0-20240723142833-87832458b53b h1:0LHjikaGWlqEMczrCEZ6w1N/ZqcYlx6WRHkhabRUQEk= -github.com/bmc-toolbox/common v0.0.0-20240723142833-87832458b53b/go.mod h1:Cdnkm+edb6C0pVkyCrwh3JTXAe0iUF9diDG/DztPI9I= +github.com/bmc-toolbox/bmclib/v2 v2.3.0 h1:BP8GkND46LSvK6hQcvJEyJpwDpB0rh5CNaZdfCOMNN8= +github.com/bmc-toolbox/bmclib/v2 v2.3.0/go.mod h1:t8If/0fHQTRIK/yKDk2H3SgthDNNj+7z2aeftDFRFrU= +github.com/bmc-toolbox/common v0.0.0-20240806132831-ba8adc6a35e3 h1:/BjZSX/sphptIdxpYo4wxAQkgMLyMMgfdl48J9DKNeE= +github.com/bmc-toolbox/common v0.0.0-20240806132831-ba8adc6a35e3/go.mod h1:Cdnkm+edb6C0pVkyCrwh3JTXAe0iUF9diDG/DztPI9I= github.com/bombsimon/logrusr/v2 v2.0.1 h1:1VgxVNQMCvjirZIYaT9JYn6sAVGVEcNtRE0y4mvaOAM= github.com/bombsimon/logrusr/v2 v2.0.1/go.mod h1:ByVAX+vHdLGAfdroiMg6q0zgq2FODY2lc5YJvzmOJio= github.com/bytedance/sonic v1.12.1 h1:jWl5Qz1fy7X1ioY74WqO0KjAMtAGQs4sYnjiEBiyX24= @@ -558,6 +558,10 @@ github.com/metal-toolbox/fleetdb v1.19.5 h1:ERgdFAUtWnT/AeVhCGclsENmwPhU88JUcgOZ github.com/metal-toolbox/fleetdb v1.19.5/go.mod h1:k9MZXQsJX4NfBoANst6g1468papSs0tzsSyzN3gGWuQ= github.com/metal-toolbox/rivets v1.3.8 h1:BxzBPBYPMGBwJurIe+8Xji2YL7vHZUHbOmMpszWfPYw= github.com/metal-toolbox/rivets v1.3.8/go.mod h1:8irU6eXgOa3QkjdcGi/aY4vqoMqCkbwVz7iVTYYPCX8= +github.com/metal-toolbox/rivets v1.3.9-0.20240930171923-6b6ce41dd113 h1:N4OnmHlO0kAiEBPqYrjmYXl8BRSORHHd08wIEF0355Y= +github.com/metal-toolbox/rivets v1.3.9-0.20240930171923-6b6ce41dd113/go.mod h1:yxvMwsGL8LsEWL5eBq17ViEvULVOojl+vIcGcz+YTzE= +github.com/metal-toolbox/rivets v1.3.9-0.20240930172024-b54836e2f7ec h1:k/MCL5iD7ZBqi/zLla/PQ8kk85Pejox3XUoia8py75s= +github.com/metal-toolbox/rivets v1.3.9-0.20240930172024-b54836e2f7ec/go.mod h1:yxvMwsGL8LsEWL5eBq17ViEvULVOojl+vIcGcz+YTzE= github.com/microsoft/go-mssqldb v0.17.0/go.mod h1:OkoNGhGEs8EZqchVTtochlXruEhEOaO4S0d2sB5aeGQ= github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso= github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI= @@ -701,8 +705,8 @@ github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An github.com/spf13/viper v1.12.0/go.mod h1:b6COn30jlNxbm/V2IqWiNWkJ+vZNiMNksliPCiuKtSI= github.com/spf13/viper v1.19.0 h1:RWq5SEjt8o25SROyN3z2OrDB9l7RPd3lwTWU8EcEdcI= github.com/spf13/viper v1.19.0/go.mod h1:GQUN9bilAbhU/jgc1bKs99f/suXKeUMct8Adx5+Ntkg= -github.com/stmcginnis/gofish v0.15.1-0.20231121142100-22a60a77be91 h1:WmABtU8y6kTgzoVUn3FWCQGAfyodve3uz3xno28BrRs= -github.com/stmcginnis/gofish v0.15.1-0.20231121142100-22a60a77be91/go.mod h1:BLDSFTp8pDlf/xDbLZa+F7f7eW0E/CHCboggsu8CznI= +github.com/stmcginnis/gofish v0.19.0 h1:fmxdRZ5WHfs+4ExArMYoeRfoh+SAxLELKtmoVplBkU4= +github.com/stmcginnis/gofish v0.19.0/go.mod h1:lq2jHj2t8Krg0Gx02ABk8MbK7Dz9jvWpO/TGnVksn00= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE= diff --git a/internal/bioscfg/action.go b/internal/bioscfg/action.go new file mode 100644 index 0000000..c54b2ff --- /dev/null +++ b/internal/bioscfg/action.go @@ -0,0 +1,50 @@ +package bioscfg + +import ( + "context" + + "github.com/metal-toolbox/bioscfg/internal/model" +) + +// ResetBios reset the bios of the server +func (th *TaskHandler) ResetBiosConfig(ctx context.Context) error { + // Get Power State + state, err := th.bmcClient.GetPowerState(ctx) + if err != nil { + return th.failedWithError(ctx, "error getting power state", err) + } + + err = th.publishActivef(ctx, "current power state: %s", state) + if err != nil { + return err + } + + // Reset Bios + err = th.bmcClient.ResetBiosConfig(ctx) + if err != nil { + return th.failedWithError(ctx, "error reseting bios", err) + } + + err = th.publishActive(ctx, "BIOS settings reset") + if err != nil { + return err + } + + // Reboot (if ON) + if state == model.PowerStateOn { + err = th.bmcClient.SetPowerState(ctx, model.PowerStateReset) + if err != nil { + return th.failedWithError(ctx, "failed to reboot server", err) + } + + return th.successful(ctx, "rebooting server") + } + + return th.successful(ctx, "skipping server reboot, not on") +} + +// UploadConfig set BIOS Config +func (th *TaskHandler) SetBiosConfig(ctx context.Context) error { + // TODO + return th.bmcClient.SetBiosConfig(ctx) +} diff --git a/internal/bioscfg/handler.go b/internal/bioscfg/handler.go index 25d911f..46c6ccb 100644 --- a/internal/bioscfg/handler.go +++ b/internal/bioscfg/handler.go @@ -109,46 +109,11 @@ func (th *TaskHandler) Run(ctx context.Context) error { } switch th.task.Parameters.Action { - case rctypes.ResetSettings: - return th.ResetBios(ctx) + case rctypes.ResetBiosConfig: + return th.ResetBiosConfig(ctx) + case rctypes.SetBiosConfig: + return th.SetBiosConfig(ctx) default: return th.failedWithError(ctx, string(th.task.Parameters.Action), errUnsupportedAction) } } - -// ResetBios reset the bios of the server -func (th *TaskHandler) ResetBios(ctx context.Context) error { - // Get Power State - state, err := th.bmcClient.GetPowerState(ctx) - if err != nil { - return th.failedWithError(ctx, "error getting power state", err) - } - - err = th.publishActivef(ctx, "current power state: %s", state) - if err != nil { - return err - } - - // Reset Bios - err = th.bmcClient.ResetBios(ctx) - if err != nil { - return th.failedWithError(ctx, "error reseting bios", err) - } - - err = th.publishActive(ctx, "BIOS settings reset") - if err != nil { - return err - } - - // Reboot (if ON) - if state == model.PowerStateOn { - err = th.bmcClient.SetPowerState(ctx, model.PowerStateReset) - if err != nil { - return th.failedWithError(ctx, "failed to reboot server", err) - } - - return th.successful(ctx, "rebooting server") - } - - return th.successful(ctx, "skipping server reboot, not on") -} diff --git a/internal/store/bmc/bmc.go b/internal/store/bmc/bmc.go index c441513..e47185d 100644 --- a/internal/store/bmc/bmc.go +++ b/internal/store/bmc/bmc.go @@ -82,6 +82,7 @@ func (b *Client) Close(traceCtx context.Context) error { // GetPowerState returns the device power status func (b *Client) GetPowerState(ctx context.Context) (string, error) { defer b.tracelog() + return b.client.GetPowerState(ctx) } @@ -148,11 +149,16 @@ func (b *Client) HostBooted(ctx context.Context) (bool, error) { return status == constants.POSTStateOS, nil } -func (b *Client) ResetBios(ctx context.Context) error { +func (b *Client) ResetBiosConfig(ctx context.Context) error { defer b.tracelog() return b.client.ResetBiosConfiguration(ctx) } +func (b *Client) SetBiosConfig(ctx context.Context) error { + defer b.tracelog() + return errors.New("TODO; NOT IMPLEMENTED UPLOADBIOSCONFIG. ASK JAMES") +} + func (b *Client) tracelog() { pc, _, _, _ := runtime.Caller(1) funcName := path.Base(runtime.FuncForPC(pc).Name()) @@ -240,6 +246,9 @@ func newBmclibClient(asset *model.Asset, l *logrus.Entry) *bmclib.Client { providers.FeatureBootDeviceSet, providers.FeaturePowerSet, providers.FeaturePowerState, + providers.FeatureResetBiosConfiguration, + providers.FeatureSetBiosConfiguration, + providers.FeatureSetBiosConfigurationFromFile, ) // NOTE: remove the .Using("redfish") before this ends up in prod diff --git a/internal/store/bmc/dryRun.go b/internal/store/bmc/dryRun.go index ff2edb1..2cd0de7 100644 --- a/internal/store/bmc/dryRun.go +++ b/internal/store/bmc/dryRun.go @@ -119,7 +119,7 @@ func (b *DryRunBMCClient) HostBooted(_ context.Context) (bool, error) { return true, nil } -func (b *DryRunBMCClient) ResetBios(ctx context.Context) error { +func (b *DryRunBMCClient) ResetBiosConfig(ctx context.Context) error { _, ok := serverStates[b.id] if !ok { return errBmcCantFindServer @@ -130,6 +130,10 @@ func (b *DryRunBMCClient) ResetBios(ctx context.Context) error { return b.SetPowerState(ctx, "cycle") } +func (b *DryRunBMCClient) SetBiosConfig(ctx context.Context) error { + return nil +} + // getServer gets a simulateed server state, and update power status and boot device if required func (b *DryRunBMCClient) getServer() (*server, error) { state, ok := serverStates[b.id] diff --git a/internal/store/bmc/interface.go b/internal/store/bmc/interface.go index 20f3953..08d6443 100644 --- a/internal/store/bmc/interface.go +++ b/internal/store/bmc/interface.go @@ -14,5 +14,6 @@ type BMC interface { GetBootDevice(ctx context.Context) (device string, persistent, efiBoot bool, err error) PowerCycleBMC(ctx context.Context) error HostBooted(ctx context.Context) (bool, error) - ResetBios(ctx context.Context) error + ResetBiosConfig(ctx context.Context) error + SetBiosConfig(ctx context.Context) error }