Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ErrNeedsPreprovisioningImage = errors.New("No suitable Preprovisioning image available")
ErrNeedsPreprovisioningImage is returned if a preprovisioning image is required
var ErrNeedsRegistration = errors.New("Host not registered")
ErrNeedsRegistration is returned if the host is not registered
Functions ¶
This section is empty.
Types ¶
type AdoptData ¶
type AdoptData struct {
State metal3v1alpha1.ProvisioningState
}
type EventPublisher ¶
type EventPublisher func(reason, message string)
EventPublisher is a function type for publishing events associated with provisioning.
type Factory ¶
type Factory interface {
NewProvisioner(hostData HostData, publish EventPublisher) (Provisioner, error)
}
Factory is the interface for creating new Provisioner objects.
type HTTPHeaders ¶
type HardwareState ¶
type HardwareState struct { // PoweredOn is a pointer to a bool indicating whether the Host is currently // powered on. The value is nil if the power state cannot be determined. PoweredOn *bool }
HardwareState holds the response from an UpdateHardwareState call
type HostConfigData ¶
type HostConfigData interface { // UserData is the interface for a function to retrieve user // data for a host being provisioned. UserData() (string, error) // NetworkData is the interface for a function to retrieve netwok // configuration for a host. NetworkData() (string, error) // MetaData is the interface for a function to retrieve metadata // configuration for a host. MetaData() (string, error) }
HostConfigData retrieves host configuration data
type HostData ¶
type HostData struct { ObjectMeta metav1.ObjectMeta BMCAddress string BMCCredentials bmc.Credentials DisableCertificateVerification bool BootMACAddress string ProvisionerID string }
func BuildHostData ¶
func BuildHostData(host metal3v1alpha1.BareMetalHost, bmcCreds bmc.Credentials) HostData
func BuildHostDataNoBMC ¶
func BuildHostDataNoBMC(host metal3v1alpha1.BareMetalHost) HostData
For controllers that do not need to manage the BMC just set the host and node ID to use with Ironic API
type InspectData ¶
type InspectData struct {
BootMode metal3v1alpha1.BootMode
}
type ManagementAccessData ¶
type ManagementAccessData struct { BootMode metal3v1alpha1.BootMode AutomatedCleaningMode metal3v1alpha1.AutomatedCleaningMode State metal3v1alpha1.ProvisioningState CurrentImage *metal3v1alpha1.Image PreprovisioningImage *PreprovisioningImage HasCustomDeploy bool }
type PrepareData ¶
type PrepareData struct { TargetRAIDConfig *metal3v1alpha1.RAIDConfig ActualRAIDConfig *metal3v1alpha1.RAIDConfig RootDeviceHints *metal3v1alpha1.RootDeviceHints FirmwareConfig *metal3v1alpha1.FirmwareConfig TargetFirmwareSettings metal3v1alpha1.DesiredSettingsMap ActualFirmwareSettings metal3v1alpha1.SettingsMap }
FirmwareConfig and FirmwareSettings are used for implementation of similar functionality FirmwareConfig contains a small subset of common names/values for the BIOS settings and the BMC driver converts them to vendor specific name/values. ActualFirmwareSettings are the complete settings retrieved from the BMC, the names and values are vendor specific. TargetFirmwareSettings contains values that the user has changed.
type PreprovisioningImage ¶
type PreprovisioningImage struct { imageprovider.GeneratedImage Format metal3v1alpha1.ImageFormat }
type ProvisionData ¶
type ProvisionData struct { Image metal3v1alpha1.Image HostConfig HostConfigData BootMode metal3v1alpha1.BootMode HardwareProfile hardware.Profile RootDeviceHints *metal3v1alpha1.RootDeviceHints CustomDeploy *metal3v1alpha1.CustomDeploy }
type Provisioner ¶
type Provisioner interface { // ValidateManagementAccess tests the connection information for // the host to verify that the location and credentials work. The // boolean argument tells the provisioner whether the current set // of credentials it has are different from the credentials it has // previously been using, without implying that either set of // credentials is correct. ValidateManagementAccess(data ManagementAccessData, credentialsChanged, force bool) (result Result, provID string, err error) // PreprovisioningImageFormats returns a list of acceptable formats for a // pre-provisioning image to be built by a PreprovisioningImage object. The // list should be nil if no image build is requested. PreprovisioningImageFormats() ([]metal3v1alpha1.ImageFormat, error) // InspectHardware updates the HardwareDetails field of the host with // details of devices discovered on the hardware. It may be called // multiple times, and should return true for its dirty flag until the // inspection is completed. InspectHardware(data InspectData, force, refresh bool) (result Result, started bool, details *metal3v1alpha1.HardwareDetails, err error) // UpdateHardwareState fetches the latest hardware state of the // server and updates the HardwareDetails field of the host with // details. It is expected to do this in the least expensive way // possible, such as reading from a cache. UpdateHardwareState() (hwState HardwareState, err error) // Adopt brings an externally-provisioned host under management by // the provisioner. Adopt(data AdoptData, force bool) (result Result, err error) // Prepare remove existing configuration and set new configuration Prepare(data PrepareData, unprepared bool, force bool) (result Result, started bool, err error) // Provision writes the image from the host spec to the host. It // may be called multiple times, and should return true for its // dirty flag until the provisioning operation is completed. Provision(data ProvisionData) (result Result, err error) // Deprovision removes the host from the image. It may be called // multiple times, and should return true for its dirty flag until // the deprovisioning operation is completed. Deprovision(force bool) (result Result, err error) // Delete removes the host from the provisioning system. It may be // called multiple times, and should return true for its dirty // flag until the deletion operation is completed. Delete() (result Result, err error) // Detach removes the host from the provisioning system. // Similar to Delete, but ensures non-interruptive behavior // for the target system. It may be called multiple times, // and should return true for its dirty flag until the // deletion operation is completed. Detach() (result Result, err error) // PowerOn ensures the server is powered on independently of any image // provisioning operation. PowerOn(force bool) (result Result, err error) // PowerOff ensures the server is powered off independently of any image // provisioning operation. The boolean argument may be used to specify // if a hard reboot (force power off) is required - true if so. PowerOff(rebootMode metal3v1alpha1.RebootMode, force bool) (result Result, err error) // IsReady checks if the provisioning backend is available to accept // all the incoming requests. IsReady() (result bool, err error) // HasCapacity checks if the backend has a free (de)provisioning slot for the current host HasCapacity() (result bool, err error) // GetFirmwareSettings gets the BIOS settings and optional schema from the host and returns maps GetFirmwareSettings(includeSchema bool) (settings metal3v1alpha1.SettingsMap, schema map[string]metal3v1alpha1.SettingSchema, err error) // AddBMCEventSubscriptionForNode creates the subscription, and updates Status.SubscriptionID AddBMCEventSubscriptionForNode(subscription *metal3v1alpha1.BMCEventSubscription, httpHeaders HTTPHeaders) (result Result, err error) // RemoveBMCEventSubscriptionForNode delete the subscription RemoveBMCEventSubscriptionForNode(subscription metal3v1alpha1.BMCEventSubscription) (result Result, err error) }
Provisioner holds the state information for talking to the provisioning backend.
type Result ¶
type Result struct { // Dirty indicates whether the host object needs to be saved. Dirty bool // RequeueAfter indicates how long to wait before making the same // Provisioner call again. The request should only be requeued if // Dirty is also true. RequeueAfter time.Duration // Any error message produced by the provisioner. ErrorMessage string }
Result holds the response from a call in the Provsioner API.