Documentation ¶
Index ¶
- type BootConfig
- type BootDataDatabase
- func (bddb BootDataDatabase) Add(bp bssTypes.BootParams) (result map[string]string, err error)
- func (bddb BootDataDatabase) CheckNodeExistence(macs, xnames []string, nids []int32) (existingNodes []Node, nonExistingMacs, nonExistingXnames []string, ...)
- func (bddb BootDataDatabase) Close() error
- func (bddb BootDataDatabase) Delete(bp bssTypes.BootParams) (nodesDeleted, bcsDeleted []string, err error)
- func (bddb BootDataDatabase) GetBootConfigsAll() ([]BootGroup, []BootConfig, int, error)
- func (bddb BootDataDatabase) GetBootConfigsByItems(kernelUri, initrdUri, cmdline string) ([]BootGroup, []BootConfig, int, error)
- func (bddb BootDataDatabase) GetBootParamsAll() ([]bssTypes.BootParams, error)
- func (bddb BootDataDatabase) GetBootParamsByMac(macs []string) ([]bssTypes.BootParams, error)
- func (bddb BootDataDatabase) GetBootParamsByName(names []string) ([]bssTypes.BootParams, error)
- func (bddb BootDataDatabase) GetBootParamsByNid(nids []int32) ([]bssTypes.BootParams, error)
- func (bddb BootDataDatabase) GetNodes() ([]Node, error)
- func (bddb BootDataDatabase) GetNodesByBootGroupId(bgId string) ([]Node, error)
- func (bddb BootDataDatabase) GetNodesByItems(macs, xnames []string, nids []int32) ([]Node, error)
- func (bddb BootDataDatabase) LogEndpointAccess(name string, endpointType bssTypes.EndpointType) (err error)
- func (bddb BootDataDatabase) SearchEndpointAccesses(name string, endpointType bssTypes.EndpointType) (accesses []bssTypes.EndpointAccess, err error)
- func (bddb BootDataDatabase) Set(bp bssTypes.BootParams) (err error)
- func (bddb BootDataDatabase) Update(bp bssTypes.BootParams) (nodesUpdated []string, err error)
- type BootGroup
- type BootGroupAssignment
- type EndpointAccess
- type ErrPostgresAdd
- type ErrPostgresDelete
- type ErrPostgresDuplicate
- type ErrPostgresGet
- type ErrPostgresNotExists
- type ErrPostgresSet
- type ErrPostgresUpdate
- type Node
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BootConfig ¶
type BootConfig struct { Id string `json:"id"` // UUID of this boot configuration KernelUri string `json:"kernel_uri"` // URI to kernel image InitrdUri string `json:"initrd_uri,omitempty"` // URI to initrd image Cmdline string `json:"cmdline,omitempty"` // boot parameters associated with this image }
func NewBootConfig ¶
func NewBootConfig(kernelUri, initrdUri, cmdline string) (bc BootConfig, err error)
NewBootConfig creates a new BootConfig and populates it with kernel and initrd images, as well as additional boot parameters, generates a unique ID, and returns the new BootConfig. If kernelUri is blank, an error is returned.
type BootDataDatabase ¶
func Connect ¶
func Connect(host string, port uint, dbName, user, password string, ssl bool, extraDbOpts string) (BootDataDatabase, error)
Connect opens a new connections to a Postgres database and ensures it is reachable. If not, an error is thrown.
func (BootDataDatabase) Add ¶
func (bddb BootDataDatabase) Add(bp bssTypes.BootParams) (result map[string]string, err error)
Add takes a bssTypes.BootParams and adds nodes and their boot configuration to the database. If a node or its configuration already exists, it is ignored. If one or more nodes are specified and a configuration exists that does not belong to an existing node group, that config is used for that/those node(s). One or more nodes can be specified by _either_ their XNames, boot MAC addresses, or NIDs. One or more node group names can be specified instead of XNames, but this is currently not supported by Add.
func (BootDataDatabase) CheckNodeExistence ¶ added in v1.27.1
func (bddb BootDataDatabase) CheckNodeExistence(macs, xnames []string, nids []int32) (existingNodes []Node, nonExistingMacs, nonExistingXnames []string, nonExistingNids []int32, err error)
CheckNodeExistence takes takes a slice of MAC addresses, a slice of XNames, and a slice of NIDs and checks to see if the nodes corresponding to them exist in the nodes table. Those that do exist are added to an existing Node slice. MAC addresses, XNames, and NIDs that do not correspond to any existing nodes are added to a corresponding slice of non-existing MACs/XNames/NIDs. The slices of existing nodes, nonexisting MAC addresses, nonexisting XNames, and nonexisting NIDs are returned. If an error occurs when querying the database, it is returned.
func (BootDataDatabase) Close ¶
func (bddb BootDataDatabase) Close() error
Close calls the Close() method on the database object within the BootDataDatabase. If it errs, an error is returned.
func (BootDataDatabase) Delete ¶
func (bddb BootDataDatabase) Delete(bp bssTypes.BootParams) (nodesDeleted, bcsDeleted []string, err error)
Delete removes one or more nodes (and the corresponding BootGroupAssignment(s)) from the database, as well as the corresponding BootGroup/BootConfig if no other node uses the same boot config. If kernel URI, initrd URI, and params are specified, Delete will also remove any boot config (and matching boot group) matching them. A list of node IDs and a map of boot group IDs to boot config IDs that were deleted are returned. If an error occurs with the deletion, it is returned.
func (BootDataDatabase) GetBootConfigsAll ¶
func (bddb BootDataDatabase) GetBootConfigsAll() ([]BootGroup, []BootConfig, int, error)
GetBootConfigsAll returns a slice of all BootGroups and a slice of all BootConfigs in the database, as well as the number of items in these slices (each BootGroup corresponds to a BootConfig, so these slices have the same number of items). If an error occurs with the query or scanning of the query results, an error is returned.
func (BootDataDatabase) GetBootConfigsByItems ¶
func (bddb BootDataDatabase) GetBootConfigsByItems(kernelUri, initrdUri, cmdline string) ([]BootGroup, []BootConfig, int, error)
GetBootConfigsByItems returns a slice of BootGroups and a slice of BootConfigs that match the passed kernel URI, initrd URI, and parameters, as well as the number of results that were returned (each BootGroup corresponds to a BootConfig, so these slices have the same number of items). If an error occurs with the query or scanning of the query results, an error is returned.
func (BootDataDatabase) GetBootParamsAll ¶
func (bddb BootDataDatabase) GetBootParamsAll() ([]bssTypes.BootParams, error)
GetBootParamsAll returns a slice of bssTypes.BootParams that contains all of the boot configurations for all nodes in the database. Each item contains node information (boot MAC address (if present), XName (if present), NID (if present)) as well as its associated boot configuration (kernel URI, initrd URI (if present), and parameters). If an error occurred while fetching the information, an error is returned.
func (BootDataDatabase) GetBootParamsByMac ¶
func (bddb BootDataDatabase) GetBootParamsByMac(macs []string) ([]bssTypes.BootParams, error)
GetBootParamsByMac returns a slice of bssTypes.BootParams that contains the boot configurations for nodes whose boot MAC addresses are found in the passed slice of MAC addresses. Each item contains node information (boot MAC address (if present), XName (if present), NID (if present)) as well as its associated boot configuration (kernel URI, initrd URI (if present), and parameters). If an error occurred while fetching the information, an error is returned.
func (BootDataDatabase) GetBootParamsByName ¶
func (bddb BootDataDatabase) GetBootParamsByName(names []string) ([]bssTypes.BootParams, error)
GetBootParamsByName returns a slice of bssTypes.BootParams that contains the boot configurations for nodes whose XNames are found in the passed slice of names. Each item contains node information (boot MAC address (if present), XName (if present), NID (if present)) as well as its associated boot configuration (kernel URI, initrd URI (if present), and parameters). If an error occurred while fetching the information, an error is returned.
func (BootDataDatabase) GetBootParamsByNid ¶
func (bddb BootDataDatabase) GetBootParamsByNid(nids []int32) ([]bssTypes.BootParams, error)
GetBootParamsByNid returns a slice of bssTypes.BootParams that contains the boot configurations for nodes whose NIDs are found in the passed slice of NIDs. Each item contains node information (boot MAC address (if present), XName (if present), NID (if present)) as well as its associated boot configuration (kernel URI, initrd URI (if present), and parameters). If an error occurred while fetching the information, an error is returned.
func (BootDataDatabase) GetNodes ¶
func (bddb BootDataDatabase) GetNodes() ([]Node, error)
GetNodes returns a list of all nodes in the nodes table within bddb.
func (BootDataDatabase) GetNodesByBootGroupId ¶
func (bddb BootDataDatabase) GetNodesByBootGroupId(bgId string) ([]Node, error)
GetNodesByBootGroupId returns a slice of Nodes that are a member of the BootGroup with an ID of bgId. If an error occurs during the query or scanning, an error is returned.
func (BootDataDatabase) GetNodesByItems ¶
func (bddb BootDataDatabase) GetNodesByItems(macs, xnames []string, nids []int32) ([]Node, error)
GetNodesByItems queries the nodes table for any Nodes that has an XName, MAC address, or NID that matches any in macs, xnames, or nids. Any matches found are returned. Otherwise, an empty Node list is returned. If no macs, xnames, or nids are specified, all nodes are returned.
func (BootDataDatabase) LogEndpointAccess ¶ added in v1.31.2
func (bddb BootDataDatabase) LogEndpointAccess(name string, endpointType bssTypes.EndpointType) (err error)
LogEndpointAccess takes a name and an endpoint type and adds a table entry to the endpoint_accesses table with the current timestamp.
func (BootDataDatabase) SearchEndpointAccesses ¶ added in v1.31.2
func (bddb BootDataDatabase) SearchEndpointAccesses(name string, endpointType bssTypes.EndpointType) (accesses []bssTypes.EndpointAccess, err error)
SearchEndpointAccesses takes the name of a node (xname) and a BSS endpoint as arguments and returns a slice of EndpointAccess structs representing timestamps of when the passed endpoint was accessed for the passed name. If endpointType is empty, then all endpoint accesses for the given name are returned. If name is empty, then all accesses for the given endpoint are returned. If both arguments are empty, then all endpoint accesses for all names are returned.
func (BootDataDatabase) Set ¶ added in v1.32.0
func (bddb BootDataDatabase) Set(bp bssTypes.BootParams) (err error)
Set modifies existing boot parameters, kernel, or initramfs URIs and adds any new ones. Unlike Update, any nodes that do not already exist are added. Under the hood, Set determines which nodes do not exist and calls Add to add them with the new boot configuration, then determines which nodes do exist and calls Update to update them with the new boot configuration.
func (BootDataDatabase) Update ¶
func (bddb BootDataDatabase) Update(bp bssTypes.BootParams) (nodesUpdated []string, err error)
Update modifies the boot parameters (and, optionally, the kernel and/or initramfs URI) of one or more existing nodes, specified by node ID, XName, or MAC address. If any of the passed nodes does not exist in the database, the operation aborts and an error is returned. A slice of strings is returned containing the node IDs of nodes whose values were updated.
type BootGroup ¶
type BootGroup struct { Id string `json:"id"` BootConfigId string `json:"boot_config_id"` Name string `json:"name"` Description string `json:"description"` }
func NewBootGroup ¶
NewBootGroup creates a new BootGroup and populates it with the specified boot config ID, name, and description, as well as populates its ID with a unique identifier. The new BootGroup is returned.
type BootGroupAssignment ¶
type BootGroupAssignment struct { BootGroupId string `json:"boot_group_id"` NodeId string `json:"node_id"` }
func NewBootGroupAssignment ¶
func NewBootGroupAssignment(bgId, nodeId string) (bga BootGroupAssignment, err error)
NewBootGroupAssignment creates a new BootGroupAssignment and populates it with the boot group id and node ID specified, returning the BootGroupAssignment that got created. If either bgId or nodeId is blank, an error is returned.
type EndpointAccess ¶ added in v1.31.2
type ErrPostgresAdd ¶ added in v1.32.0
type ErrPostgresAdd struct {
Err error
}
ErrPostgresAdd represents an error emitted by the Add() function. The data structure contains the error it wraps.
func (ErrPostgresAdd) Error ¶ added in v1.32.0
func (epa ErrPostgresAdd) Error() string
func (ErrPostgresAdd) Is ¶ added in v1.32.0
func (epa ErrPostgresAdd) Is(e error) bool
type ErrPostgresDelete ¶ added in v1.32.0
type ErrPostgresDelete struct {
Err error
}
ErrPostgresDelete represents an error emitted by the Delete() function. The data structure contains the error it wraps.
func (ErrPostgresDelete) Error ¶ added in v1.32.0
func (epd ErrPostgresDelete) Error() string
func (ErrPostgresDelete) Is ¶ added in v1.32.0
func (epd ErrPostgresDelete) Is(e error) bool
type ErrPostgresDuplicate ¶ added in v1.32.0
type ErrPostgresDuplicate struct {
Data interface{}
}
ErrPostgresDuplicate represents an error that occurs when data being manipulated already exists in the database. The data being manipulated is contained in the data structure.
func (ErrPostgresDuplicate) Error ¶ added in v1.32.0
func (epd ErrPostgresDuplicate) Error() string
func (ErrPostgresDuplicate) Is ¶ added in v1.32.0
func (epd ErrPostgresDuplicate) Is(e error) bool
type ErrPostgresGet ¶ added in v1.32.0
type ErrPostgresGet struct {
Err error
}
ErrPostgresGet represents an error emitted by any of the Get() functions. The data structure contains the error it wraps.
func (ErrPostgresGet) Error ¶ added in v1.32.0
func (epg ErrPostgresGet) Error() string
func (ErrPostgresGet) Is ¶ added in v1.32.0
func (epg ErrPostgresGet) Is(e error) bool
type ErrPostgresNotExists ¶ added in v1.32.0
type ErrPostgresNotExists struct {
Data interface{}
}
ErrPostgresNotExists represents an error that occurs when data being queried does not exist in the database. The data being queried is contained in the data structure.
func (ErrPostgresNotExists) Error ¶ added in v1.32.0
func (epne ErrPostgresNotExists) Error() string
func (ErrPostgresNotExists) Is ¶ added in v1.32.0
func (epne ErrPostgresNotExists) Is(e error) bool
type ErrPostgresSet ¶ added in v1.32.0
type ErrPostgresSet struct {
Err error
}
ErrPostgresSet represents an error emitted by the Set() function. The data structure contains the error it wraps.
func (ErrPostgresSet) Error ¶ added in v1.32.0
func (eps ErrPostgresSet) Error() string
func (ErrPostgresSet) Is ¶ added in v1.32.0
func (eps ErrPostgresSet) Is(e error) bool
type ErrPostgresUpdate ¶ added in v1.32.0
type ErrPostgresUpdate struct {
Err error
}
ErrPostgresUpdate represents an error emitted by the Update() function. The data structure contains the error it wraps.
func (ErrPostgresUpdate) Error ¶ added in v1.32.0
func (epu ErrPostgresUpdate) Error() string
func (ErrPostgresUpdate) Is ¶ added in v1.32.0
func (epu ErrPostgresUpdate) Is(e error) bool