Documentation ¶
Overview ¶
Package v1alpha2 contains API Schema definitions for the dhcp v1alpha2 API group. It is the primary internal API group for the intended Hedgehog DHCP server configuration and storing leases as well as making them available to the end user through API. Not intended to be modified by the user. +kubebuilder:object:generate=true +groupName=dhcp.githedgehog.com
Index ¶
Constants ¶
const (
ManagementSubnet = "management"
)
Variables ¶
var ( // GroupVersion is group version used to register these objects GroupVersion = schema.GroupVersion{Group: "dhcp.githedgehog.com", Version: "v1alpha2"} // SchemeBuilder is used to add go types to the GroupVersionKind scheme SchemeBuilder = &scheme.Builder{GroupVersion: GroupVersion} // AddToScheme adds the types in this group-version to the given scheme. AddToScheme = SchemeBuilder.AddToScheme )
Functions ¶
This section is empty.
Types ¶
type DHCPAllocated ¶
type DHCPAllocated struct { // Allocated IP address IP string `json:"ip"` // Expiry time of the lease Expiry metav1.Time `json:"expiry"` // Hostname from DHCP request Hostname string `json:"hostname"` }
DHCPAllocated is a single allocated IP with expiry time and hostname from DHCP requests, it's effectively a DHCP lease
func (*DHCPAllocated) DeepCopy ¶
func (in *DHCPAllocated) DeepCopy() *DHCPAllocated
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DHCPAllocated.
func (*DHCPAllocated) DeepCopyInto ¶
func (in *DHCPAllocated) DeepCopyInto(out *DHCPAllocated)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type DHCPSubnet ¶
type DHCPSubnet struct { metav1.TypeMeta `json:",inline"` metav1.ObjectMeta `json:"metadata,omitempty"` // Spec is the desired state of the DHCPSubnet Spec DHCPSubnetSpec `json:"spec,omitempty"` // Status is the observed state of the DHCPSubnet Status DHCPSubnetStatus `json:"status,omitempty"` }
+kubebuilder:object:root=true +kubebuilder:subresource:status +kubebuilder:resource:categories=hedgehog;fabric,shortName=dhcp +kubebuilder:printcolumn:name="Subnet",type=string,JSONPath=`.spec.subnet`,priority=0 +kubebuilder:printcolumn:name="CIDRBlock",type=string,JSONPath=`.spec.cidrBlock`,priority=0 +kubebuilder:printcolumn:name="Gateway",type=string,JSONPath=`.spec.gateway`,priority=0 +kubebuilder:printcolumn:name="StartIP",type=string,JSONPath=`.spec.startIP`,priority=0 +kubebuilder:printcolumn:name="EndIP",type=string,JSONPath=`.spec.endIP`,priority=0 +kubebuilder:printcolumn:name="VRF",type=string,JSONPath=`.spec.vrf`,priority=1 +kubebuilder:printcolumn:name="CircuitID",type=string,JSONPath=`.spec.circuitID`,priority=1 +kubebuilder:printcolumn:name="DNSServers",type=string,JSONPath=`.spec.dnsServers`,priority=1 +kubebuilder:printcolumn:name="TimeServers",type=string,JSONPath=`.spec.timeServers`,priority=1 +kubebuilder:printcolumn:name="InterfaceMTU",type=integer,JSONPath=`.spec.interfaceMTU`,priority=1 +kubebuilder:printcolumn:name="Age",type=date,JSONPath=`.metadata.creationTimestamp`,priority=0 DHCPSubnet is the configuration (spec) for the Hedgehog DHCP server and storage for the leases (status). It's primary internal API group, but it makes allocated IPs / leases information available to the end user through API. Not intended to be modified by the user.
func (*DHCPSubnet) DeepCopy ¶
func (in *DHCPSubnet) DeepCopy() *DHCPSubnet
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DHCPSubnet.
func (*DHCPSubnet) DeepCopyInto ¶
func (in *DHCPSubnet) DeepCopyInto(out *DHCPSubnet)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*DHCPSubnet) DeepCopyObject ¶
func (in *DHCPSubnet) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
type DHCPSubnetList ¶
type DHCPSubnetList struct { metav1.TypeMeta `json:",inline"` metav1.ListMeta `json:"metadata,omitempty"` Items []DHCPSubnet `json:"items"` }
DHCPSubnetList contains a list of DHCPSubnet
func (*DHCPSubnetList) DeepCopy ¶
func (in *DHCPSubnetList) DeepCopy() *DHCPSubnetList
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DHCPSubnetList.
func (*DHCPSubnetList) DeepCopyInto ¶
func (in *DHCPSubnetList) DeepCopyInto(out *DHCPSubnetList)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*DHCPSubnetList) DeepCopyObject ¶
func (in *DHCPSubnetList) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
type DHCPSubnetSpec ¶
type DHCPSubnetSpec struct { // Full VPC subnet name (including VPC name), such as "vpc-0/default" Subnet string `json:"subnet"` // CIDR block to use for VPC subnet, such as "10.10.10.0/24" CIDRBlock string `json:"cidrBlock"` // Gateway, such as 10.10.10.1 Gateway string `json:"gateway"` // Start IP from the CIDRBlock to allocate IPs, such as 10.10.10.10 StartIP string `json:"startIP"` // End IP from the CIDRBlock to allocate IPs, such as 10.10.10.99 EndIP string `json:"endIP"` // VRF name to identify specific VPC (will be added to DHCP packets by DHCP relay in suboption 151), such as "VrfVvpc-1" as it's named on switch VRF string `json:"vrf"` // VLAN ID to identify specific subnet within the VPC, such as "Vlan1000" as it's named on switch CircuitID string `json:"circuitID"` // PXEURL (optional) to identify the pxe server to use to boot hosts connected to this segment such as http://10.10.10.99/bootfilename or tftp://10.10.10.99/bootfilename, http query strings are not supported PXEURL string `json:"pxeURL"` // DNSservers (optional) to configure Domain Name Servers for this particular segment such as: 10.10.10.1, 10.10.10.2 DNSServers []string `json:"dnsServers"` // TimeServers (optional) NTP server addresses to configure for time servers for this particular segment such as: 10.10.10.1, 10.10.10.2 TimeServers []string `json:"timeServers"` // InterfaceMTU (optional) is the MTU setting that the dhcp server will send to the clients. It is dependent on the client to honor this option. // +kubebuilder:validation:Minimum: 96 // +kubebuilder:validation:Maximum: 9036 InterfaceMTU uint16 `json:"interfaceMTU"` // DefaultURL (optional) is the option 114 "default-url" to be sent to the clients DefaultURL string `json:"defaultURL"` }
DHCPSubnetSpec defines the desired state of DHCPSubnet
func (*DHCPSubnetSpec) DeepCopy ¶
func (in *DHCPSubnetSpec) DeepCopy() *DHCPSubnetSpec
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DHCPSubnetSpec.
func (*DHCPSubnetSpec) DeepCopyInto ¶
func (in *DHCPSubnetSpec) DeepCopyInto(out *DHCPSubnetSpec)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type DHCPSubnetStatus ¶
type DHCPSubnetStatus struct { // Allocated is a map of allocated IPs with expiry time and hostname from DHCP requests Allocated map[string]DHCPAllocated `json:"allocated,omitempty"` }
DHCPSubnetStatus defines the observed state of DHCPSubnet
func (*DHCPSubnetStatus) DeepCopy ¶
func (in *DHCPSubnetStatus) DeepCopy() *DHCPSubnetStatus
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DHCPSubnetStatus.
func (*DHCPSubnetStatus) DeepCopyInto ¶
func (in *DHCPSubnetStatus) DeepCopyInto(out *DHCPSubnetStatus)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.