Skip to content

Commit

Permalink
add firmware validation client function
Browse files Browse the repository at this point in the history
  • Loading branch information
DoctorVin committed Oct 17, 2024
1 parent efc6f71 commit d4d44f3
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 17 deletions.
6 changes: 6 additions & 0 deletions pkg/api/v1/conditions/client/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,12 @@ func (c *Client) ServerBiosControl(ctx context.Context,
return c.post(ctx, path, params)
}

func (c *Client) ValidateFirmwareSet(ctx context.Context,
params *v1types.FirmwareValidationParameters) (*v1types.ServerResponse, error) {

Check failure on line 96 in pkg/api/v1/conditions/client/client.go

View workflow job for this annotation

GitHub Actions / lint-test

undefined: v1types.FirmwareValidationParameters (typecheck)

Check failure on line 96 in pkg/api/v1/conditions/client/client.go

View workflow job for this annotation

GitHub Actions / lint-test

undefined: v1types.FirmwareValidationParameters (typecheck)

return c.post(ctx, "validateFirmware", params)
}

func (c *Client) ServerConditionCreate(ctx context.Context, serverID uuid.UUID, conditionKind rctypes.Kind, conditionCreate v1types.ConditionCreate) (*v1types.ServerResponse, error) {
path := fmt.Sprintf("servers/%s/condition/%s", serverID.String(), conditionKind)

Expand Down
15 changes: 2 additions & 13 deletions pkg/api/v1/conditions/routes/firmware_validation_handlers.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
package routes

import (
"encoding/json"
"net/http"
"time"

"github.com/gin-gonic/gin"
"github.com/google/uuid"
rctypes "github.com/metal-toolbox/rivets/condition"
"github.com/pkg/errors"
"github.com/prometheus/client_golang/prometheus"
Expand All @@ -18,17 +16,8 @@ import (
v1types "github.com/metal-toolbox/conditionorc/pkg/api/v1/conditions/types"
)

type FirmwareValidationRequest struct {
ServerID uuid.UUID `json:"server_id" binding:"required,uuid4_rfc4122"`
FirmwareSetID uuid.UUID `json:"firmware_set_id" binding:"required,uuid4_rfc4122"`
}

func (fvr FirmwareValidationRequest) AsJSON() (json.RawMessage, error) {
return json.Marshal(fvr)
}

// this is where we compose all conditions to be executed during the firmware validation task
func firmwareValidationConditions(fvr FirmwareValidationRequest) *rctypes.ServerConditions {
func firmwareValidationConditions(fvr *v1types.FirmwareValidationRequest) *rctypes.ServerConditions {
createTime := time.Now()

fwParams := &rctypes.FirmwareInstallTaskParameters{
Expand Down Expand Up @@ -88,7 +77,7 @@ func (r *Routes) validateFirmware(c *gin.Context) (int, *v1types.ServerResponse)
otelCtx, span := otel.Tracer(pkgName).Start(c.Request.Context(), "Routes.validateFirmware")
defer span.End()

var fvr FirmwareValidationRequest
fvr := &v1types.FirmwareValidationRequest{}
if err := c.ShouldBindJSON(&fvr); err != nil {
r.logger.WithError(err).Warn("unmarshal firmware validation payload")

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import (
"github.com/google/uuid"
"github.com/metal-toolbox/conditionorc/internal/model"
"github.com/metal-toolbox/conditionorc/internal/store"
v1types "github.com/metal-toolbox/conditionorc/pkg/api/v1/conditions/types"
"github.com/pkg/errors"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
Expand Down Expand Up @@ -40,7 +41,7 @@ func TestValidateFirmware(t *testing.T) {
_, fleetdb, _, server, err := setupTestServer(t)
require.NoError(t, err, "prerequisite setup")

fvr, err := FirmwareValidationRequest{
fvr, err := v1types.FirmwareValidationRequest{
ServerID: uuid.New(),
FirmwareSetID: uuid.New(),
}.AsJSON()
Expand All @@ -65,7 +66,7 @@ func TestValidateFirmware(t *testing.T) {
FacilityCode: "fc13",
}

fvr, err := FirmwareValidationRequest{
fvr, err := v1types.FirmwareValidationRequest{
ServerID: srv.ID,
FirmwareSetID: uuid.New(),
}.AsJSON()
Expand Down Expand Up @@ -101,7 +102,7 @@ func TestValidateFirmware(t *testing.T) {
FacilityCode: "fc13",
}

fvr, err := FirmwareValidationRequest{
fvr, err := v1types.FirmwareValidationRequest{
ServerID: srv.ID,
FirmwareSetID: uuid.New(),
}.AsJSON()
Expand Down Expand Up @@ -133,7 +134,7 @@ func TestValidateFirmware(t *testing.T) {
FacilityCode: "fc13",
}

fvr, err := FirmwareValidationRequest{
fvr, err := v1types.FirmwareValidationRequest{
ServerID: srv.ID,
FirmwareSetID: uuid.New(),
}.AsJSON()
Expand Down
9 changes: 9 additions & 0 deletions pkg/api/v1/conditions/types/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,3 +184,12 @@ type ServerProvisionRequest struct {
NetworkConfiguration string `json:"NetworkConfiguration,omitempty"`
Tags []string `json:"Tags,omitempty"`
}

type FirmwareValidationRequest struct {
ServerID uuid.UUID `json:"server_id" binding:"required,uuid4_rfc4122"`
FirmwareSetID uuid.UUID `json:"firmware_set_id" binding:"required,uuid4_rfc4122"`
}

func (fvr FirmwareValidationRequest) AsJSON() (json.RawMessage, error) {
return json.Marshal(fvr)
}

0 comments on commit d4d44f3

Please sign in to comment.