reconcilecontext

package
v1.2.6 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 18, 2024 License: Apache-2.0 Imports: 6 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Infra

type Infra interface {
	//GetUsedIPsByCIDR returns a map of reserved IPs by CIDR, this IPs cannot be used for assigning to namespaces
	GetUsedIPsByCIDR(rc *ReconcileContext) (map[string][]net.IP, error)
	//ReconcileInstanceSecondaryIPs will make sure that Assigned Egress IPs to instances are correclty reconciled
	//this includes adding and possibly removing secondary IPs to selected instances.
	ReconcileInstanceSecondaryIPs(rc *ReconcileContext) error

	// RemoveAllAssignedIPs uncoditionally remoevs all the assigned IPs to VMs, used in clean-up login
	RemoveAllAssignedIPs(rc *ReconcileContext) error

	// GetCapacity return the ip capacity of the node (this includes the primary IP)
	GetIPCapacity(node *corev1.Node) (uint32, error)
}

Infra abstracts away infrastructure related concerns

type NodeCapacity added in v1.2.4

type NodeCapacity interface {
}

type ReconcileContext

type ReconcileContext struct {
	//immutable fields within a reconciliation cycle
	Context                     context.Context                  `json:"context,omitempty"`
	Infrastructure              *ocpconfigv1.Infrastructure      `json:"infrastructure,omitempty"`
	CloudCredentialsSecret      *corev1.Secret                   `json:"cloudCredentialsSecret,omitempty"`
	EgressIPAM                  *redhatcopv1alpha1.EgressIPAM    `json:"egressIPAM,omitempty"`
	CIDRs                       []string                         `json:"cIDRs,omitempty"`
	NetCIDRByCIDR               map[string]*net.IPNet            `json:"netCIDRByCIDR,omitempty"`
	CIDRsByLabel                map[string]string                `json:"cIDRsByLabel,omitempty"`
	ReservedIPsByCIDR           map[string][]net.IP              `json:"reservedIPsByCIDR,omitempty"`
	AllNodes                    map[string]corev1.Node           `json:"allNodes,omitempty"`
	AllHostSubnets              map[string]ocpnetv1.HostSubnet   `json:"allHostSubnets,omitempty"`
	SelectedNodes               map[string]corev1.Node           `json:"selectedNodes,omitempty"`
	SelectedNodesByCIDR         map[string][]string              `json:"selectedNodesByCIDR,omitempty"`
	SelectedHostSubnets         map[string]ocpnetv1.HostSubnet   `json:"selectedHostSubnets,omitempty"`
	SelectedHostSubnetsByCIDR   map[string][]string              `json:"selectedHostSubnetsByCIDR,omitempty"`
	ReferringNamespaces         map[string]corev1.Namespace      `json:"referringNamespaces,omitempty"`
	InitiallyAssignedNamespaces []corev1.Namespace               `json:"initiallyAssignedNamespaces,omitempty"`
	UnAssignedNamespaces        []corev1.Namespace               `json:"unAssignedNamespaces,omitempty"`
	NetNamespaces               map[string]ocpnetv1.NetNamespace `json:"netNamespaces,omitempty"`
	InitiallyAssignedIPsByNode  map[string][]string              `json:"initiallyAssignedIPsByNode,omitempty"`

	Infra Infra `json:"infra,omitempty"`

	UsedIPsByCIDR map[string][]net.IP `json:"usedIPsByCIDR,omitempty"`

	//variable fields
	FinallyAssignedNamespaces []corev1.Namespace  `json:"finallyAssignedNamespaces,omitempty"`
	FinallyAssignedIPsByNode  map[string][]string `json:"finallyAssignedIPsByNode,omitempty"`
}

ReconcileContext is a data structure represts all the known information about the current reconcile cycle.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL