Skip to content

Commit

Permalink
Update the naming for provider options:
Browse files Browse the repository at this point in the history
Signed-off-by: Jacob Weinstock <[email protected]>
  • Loading branch information
jacobweinstock committed Sep 13, 2023
1 parent 7bd1bbf commit 22782b9
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 48 deletions.
23 changes: 13 additions & 10 deletions api/v1alpha1/machine.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,22 +52,25 @@ type MachineSpec struct {

// ProviderOptions contains provider specific options.
// +optional
ProviderOpts ProviderOpts `json:"providerOpts,omitempty"`
ProviderOptions ProviderOptions `json:"providerOptions,omitempty"`
}

type ProviderOpts struct {
// RPC contains rpc provider options.
type ProviderOptions struct {
// IntelAMT contains the options to customize the IntelAMT provider.
// +optional
RPC OptRPC `json:"rpc"`
// Redfish contains redfish provider options.
IntelAMT *IntelAMTOptions `json:"intelAMT"`

// IPMITOOL contains the options to customize the Ipmitool provider.
// +optional
Redfish OptRedfish `json:"redfish"`
// IPMITOOL contains ipmitool provider options.
IPMITOOL *IPMITOOLOptions `json:"ipmitool"`

// Redfish contains the options to customize the Redfish provider.
// +optional
IPMITOOL OptIPMITOOL `json:"ipmitool"`
// IPMI contains ipmi provider options.
Redfish *RedfishOptions `json:"redfish"`

// RPC contains the options to customize the RPC provider.
// +optional
IntelAMT OptIntelAMT `json:"intelAMT"`
RPC *RPCOptions `json:"rpc"`
}

// Connection contains connection data for a Baseboard Management Controller.
Expand Down
74 changes: 36 additions & 38 deletions api/v1alpha1/provider_opts.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,30 +6,51 @@ import (
corev1 "k8s.io/api/core/v1"
)

// Config defines the configuration for sending rpc notifications.
type OptRPC struct {
// RedfishOptions contains the redfish provider specific options.
type RedfishOptions struct {
// Port that redfish will use for calls.
Port int `json:"port"`
}

// IPMITOOLOptions contains the ipmitool provider specific options.
type IPMITOOLOptions struct {
// Port that ipmitool will use for calls.
Port int `json:"port"`
// CipherSuite that ipmitool will use for calls.
CipherSuite string `json:"cipherSuite"`
}

// IntelAMTOptions contains the intelAMT provider specific options.
type IntelAMTOptions struct {
// Port that intelAMT will use for calls.
Port int `json:"port"`
}

// RPCAlgorithm is a type for HMAC algorithms.
type RPCAlgorithm string

// RPCSecrets holds per Algorithm slice secrets.
// These secrets will be used to create HMAC signatures.
type RPCSecrets map[RPCAlgorithm][]corev1.SecretReference

// RPCOptions defines the configurable options to use when sending rpc notifications.
type RPCOptions struct {
// ConsumerURL is the URL where an rpc consumer/listener is running
// and to which we will send and receive all notifications.
ConsumerURL string `json:"consumerURL"`
// LogNotificationsDisabled determines whether responses from rpc consumer/listeners will be logged or not.
LogNotificationsDisabled bool `json:"logNotificationsDisabled"`
// Opts are the options for the rpc provider.
Opts Opts `json:"opts"`
}

// Opts are the options for the rpc provider.
type Opts struct {
// Request is the options used to create the rpc HTTP request.
Request RequestOpts `json:"request"`
// Signature is the options used for adding an HMAC signature to an HTTP request.
Signature SignatureOpts `json:"signature"`
// HMAC is the options used to create a HMAC signature.
HMAC HMACOpts `json:"hmac"`
// Experimental options.
Experimental Experimental `json:"experimental"`
Experimental ExperimentalOpts `json:"experimental"`
}

// RequestOpts are the options used to create the rpc HTTP request.
// RequestOpts are the options used when creating an HTTP request.
type RequestOpts struct {
// HTTPContentType is the content type to use for the rpc request notification.
HTTPContentType string `json:"httpContentType"`
Expand All @@ -56,41 +77,18 @@ type SignatureOpts struct {
IncludedPayloadHeaders []string `json:"includedPayloadHeaders"`
}

// HMACOpts are the options used to create a HMAC signature.
// HMACOpts are the options used to create an HMAC signature.
type HMACOpts struct {
// PrefixSigDisabled determines whether the algorithm will be prefixed to the signature. Example: sha256=abc123
PrefixSigDisabled bool `json:"prefixSigDisabled"`
// Secrets are a map of algorithms to secrets used for signing.
Secrets Secrets `json:"secrets"`
Secrets RPCSecrets `json:"secrets"`
}

// Experimental options.
type Experimental struct {
// ExperimentalOpts are options we're still learning about and should be used carefully.
type ExperimentalOpts struct {
// CustomRequestPayload must be in json.
CustomRequestPayload string `json:"customRequestPayload"`
// DotPath is the path to where the bmclib RequestPayload{} will be embedded. For example: object.data.body
// DotPath is the path to the json object where the bmclib RequestPayload{} struct will be embedded. For example: object.data.body
DotPath string `json:"dotPath"`
}

// Algorithm is the type for HMAC algorithms.
type Algorithm string

// Secrets hold per algorithm slice secrets.
// These secrets will be used to create HMAC signatures.
type Secrets map[Algorithm][]corev1.SecretReference

// OptRedfish contains redfish provider options.
type OptRedfish struct {
Port int `json:"port"`
}

// OptIPMITOOL contains ipmitool provider options.
type OptIPMITOOL struct {
Port int `json:"port"`
CipherSuite string `json:"cipherSuite"`
}

// OptIntelAMT contains intel amt provider options.
type OptIntelAMT struct {
Port int `json:"port"`
}

0 comments on commit 22782b9

Please sign in to comment.