It's an automatically generated reference for the Fabric API. You can find latest version in the Fabric repository.
API Reference
Packages
- agent.githedgehog.com/v1beta1
- dhcp.githedgehog.com/v1beta1
- vpc.githedgehog.com/v1beta1
- wiring.githedgehog.com/v1beta1
agent.githedgehog.com/v1beta1
Package v1beta1 contains API Schema definitions for the agent v1beta1 API group. This is the internal API group for the switch and control node agents. Not intended to be modified by the user.
Resource Types
AdminStatus
Underlying type: string
Appears in: - SwitchStateInterface
| Field | Description | 
|---|---|
| `` | |
| up | |
| down | |
| testing | 
Agent
Agent is an internal API object used by the controller to pass all relevant information to the agent running on a specific switch in order to fully configure it and manage its lifecycle. It is not intended to be used directly by users. Spec of the object isn't user-editable, it is managed by the controller. Status of the object is updated by the agent and is used by the controller to track the state of the agent and the switch it is running on. Name of the Agent object is the same as the name of the switch it is running on and it's created in the same namespace as the Switch object.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | agent.githedgehog.com/v1beta1 | ||
| kindstring | Agent | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| statusAgentStatus | Status is the observed state of the Agent | 
AgentStatus
AgentStatus defines the observed state of the agent running on a specific switch and includes information about the switch itself as well as the state of the agent and applied configuration.
Appears in: - Agent
| Field | Description | Default | Validation | 
|---|---|---|---|
| versionstring | Current running agent version | ||
| installIDstring | ID of the agent installation, used to track NOS re-installs | ||
| runIDstring | ID of the agent run, used to track agent restarts | ||
| bootIDstring | ID for the NOS boot, used to track NOS reboots | ||
| lastHeartbeatTime | Time of the last heartbeat from the agent | ||
| lastAttemptTimeTime | Time of the last attempt to apply configuration | ||
| lastAttemptGeninteger | Generation of the last attempt to apply configuration | ||
| lastAppliedTimeTime | Time of the last successful configuration application | ||
| lastAppliedGeninteger | Generation of the last successful configuration application | ||
| stateSwitchState | Detailed switch state updated with each heartbeat | ||
| conditionsCondition array | Conditions of the agent, includes readiness marker for use with kubectl wait | 
BGPMessages
Appears in: - SwitchStateBGPNeighbor
| Field | Description | Default | Validation | 
|---|---|---|---|
| recBGPMessagesCounters | |||
| sentBGPMessagesCounters | 
BGPMessagesCounters
Appears in: - BGPMessages
| Field | Description | Default | Validation | 
|---|---|---|---|
| capinteger | |||
| keepalinteger | |||
| notifinteger | |||
| openinteger | |||
| rrefreshinteger | |||
| updateinteger | 
BGPNeighborSessionState
Underlying type: string
Appears in: - SwitchStateBGPNeighbor
| Field | Description | 
|---|---|
| `` | |
| idle | |
| connect | |
| active | |
| openSent | |
| openConfirm | |
| established | 
BGPPeerType
Underlying type: string
Appears in: - SwitchStateBGPNeighbor
| Field | Description | 
|---|---|
| `` | |
| internal | |
| external | 
OperStatus
Underlying type: string
Appears in: - SwitchStateInterface
| Field | Description | 
|---|---|
| `` | |
| up | |
| down | |
| testing | |
| unknown | |
| dormant | |
| notPresent | |
| lowerLayerDown | 
SwitchState
Appears in: - AgentStatus
| Field | Description | Default | Validation | 
|---|---|---|---|
| nosSwitchStateNOS | Information about the switch and NOS | ||
| interfacesobject (keys:string, values:SwitchStateInterface) | Switch interfaces state (incl. physical, management and port channels) | ||
| breakoutsobject (keys:string, values:SwitchStateBreakout) | Breakout ports state (port -> breakout state) | ||
| transceiversobject (keys:string, values:SwitchStateTransceiver) | Transceivers state (port -> transceiver state) | ||
| bgpNeighborsobject (keys:string, values:map[string]SwitchStateBGPNeighbor) | State of all BGP neighbors (VRF -> neighbor address -> state) | ||
| platformSwitchStatePlatform | State of the switch platform (fans, PSUs, sensors) | ||
| criticalResourcesSwitchStateCRM | State of the critical resources (ACLs, routes, etc.) | ||
| roceboolean | State of the roce configuration | ||
| firmwareobject (keys:string, values:string) | Firmware versions of the switch | 
SwitchStateBGPNeighbor
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| connDroppedinteger | |||
| enabledboolean | |||
| estabTransinteger | |||
| lastEstabTime | |||
| lastReadTime | |||
| lastResetReasonstring | |||
| lastResetTime | |||
| lastWriteTime | |||
| localASinteger | |||
| msgsBGPMessages | |||
| peerASinteger | |||
| peerGroupstring | |||
| peerPortinteger | |||
| peerTypeBGPPeerType | |||
| remoteRouterIDstring | |||
| stateBGPNeighborSessionState | |||
| shutdownMsgstring | |||
| prefixesobject (keys:string, values:SwitchStateBGPNeighborPrefixes) | 
SwitchStateBGPNeighborPrefixes
Appears in: - SwitchStateBGPNeighbor
| Field | Description | Default | Validation | 
|---|---|---|---|
| recinteger | |||
| recPreinteger | |||
| sentinteger | 
SwitchStateBreakout
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| modestring | |||
| statusstring | 
SwitchStateCRM
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| aclStatsSwitchStateCRMACLStats | |||
| statsSwitchStateCRMStats | 
SwitchStateCRMACLDetails
Appears in: - SwitchStateCRMACLInfo
| Field | Description | Default | Validation | 
|---|---|---|---|
| groupsAvailableinteger | |||
| groupsUsedinteger | |||
| tablesAvailableinteger | |||
| tablesUsedinteger | 
SwitchStateCRMACLInfo
Appears in: - SwitchStateCRMACLStats
| Field | Description | Default | Validation | 
|---|---|---|---|
| lagSwitchStateCRMACLDetails | |||
| portSwitchStateCRMACLDetails | |||
| rifSwitchStateCRMACLDetails | |||
| switchSwitchStateCRMACLDetails | |||
| vlanSwitchStateCRMACLDetails | 
SwitchStateCRMACLStats
Appears in: - SwitchStateCRM
| Field | Description | Default | Validation | 
|---|---|---|---|
| egressSwitchStateCRMACLInfo | |||
| ingressSwitchStateCRMACLInfo | 
SwitchStateCRMStats
Appears in: - SwitchStateCRM
| Field | Description | Default | Validation | 
|---|---|---|---|
| dnatEntriesAvailableinteger | |||
| dnatEntriesUsedinteger | |||
| fdbEntriesAvailableinteger | |||
| fdbEntriesUsedinteger | |||
| ipmcEntriesAvailableinteger | |||
| ipmcEntriesUsedinteger | |||
| ipv4NeighborsAvailableinteger | |||
| ipv4NeighborsUsedinteger | |||
| ipv4NexthopsAvailableinteger | |||
| ipv4NexthopsUsedinteger | |||
| ipv4RoutesAvailableinteger | |||
| ipv4RoutesUsedinteger | |||
| ipv6NeighborsAvailableinteger | |||
| ipv6NeighborsUsedinteger | |||
| ipv6NexthopsAvailableinteger | |||
| ipv6NexthopsUsedinteger | |||
| ipv6RoutesAvailableinteger | |||
| ipv6RoutesUsedinteger | |||
| nexthopGroupMembersAvailableinteger | |||
| nexthopGroupMembersUsedinteger | |||
| nexthopGroupsAvailableinteger | |||
| nexthopGroupsUsedinteger | |||
| snatEntriesAvailableinteger | |||
| snatEntriesUsedinteger | 
SwitchStateInterface
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| enabledboolean | |||
| adminAdminStatus | |||
| operOperStatus | |||
| macstring | |||
| changeTime | |||
| speedstring | |||
| autoboolean | |||
| fecstring | |||
| countersSwitchStateInterfaceCounters | |||
| lldpNeighborsSwitchStateLLDPNeighbor array | 
SwitchStateInterfaceCounters
Appears in: - SwitchStateInterface
| Field | Description | Default | Validation | 
|---|---|---|---|
| inbinteger | |||
| inbpsfloat | |||
| indinteger | |||
| ineinteger | |||
| inpbsfloat | |||
| inuinteger | |||
| clearTime | |||
| outbinteger | |||
| outbpsfloat | |||
| outdinteger | |||
| outeinteger | |||
| outppsfloat | |||
| outuinteger | |||
| queuesobject (keys:string, values:SwitchStateInterfaceCountersQueue) | 
SwitchStateInterfaceCountersQueue
Appears in: - SwitchStateInterfaceCounters
| Field | Description | Default | Validation | 
|---|---|---|---|
| dbinteger | |||
| dpinteger | |||
| ecnbinteger | |||
| ecnpinteger | |||
| binteger | |||
| bpsinteger | |||
| pinteger | |||
| ppsinteger | |||
| wreddpinteger | 
SwitchStateLLDPNeighbor
Appears in: - SwitchStateInterface
| Field | Description | Default | Validation | 
|---|---|---|---|
| namestring | |||
| chassisstring | |||
| sysNamestring | |||
| sysDescrstring | |||
| portIDstring | |||
| portDescrstring | |||
| manufstring | |||
| modelstring | |||
| serialstring | 
SwitchStateNOS
SwitchStateNOS contains information about the switch and NOS received from the switch itself by the agent
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| asicVersionstring | ASIC name, such as "broadcom" or "vs" | ||
| buildCommitstring | NOS build commit | ||
| buildDatestring | NOS build date | ||
| builtBystring | NOS build user | ||
| configDBVersionstring | NOS config DB version, such as "version_4_2_1" | ||
| distributionVersionstring | Distribution version, such as "Debian 10.13" | ||
| hardwareVersionstring | Hardware version, such as "X01" | ||
| hwskuVersionstring | Hwsku version, such as "DellEMC-S5248f-P-25G-DPB" | ||
| kernelVersionstring | Kernel version, such as "5.10.0-21-amd64" | ||
| mfgNamestring | Manufacturer name, such as "Dell EMC" | ||
| platformNamestring | Platform name, such as "x86_64-dellemc_s5248f_c3538-r0" | ||
| productDescriptionstring | NOS product description, such as "Enterprise SONiC Distribution by Broadcom - Enterprise Base package" | ||
| productVersionstring | NOS product version, empty for Broadcom SONiC | ||
| serialNumberstring | Switch serial number | ||
| softwareVersionstring | NOS software version, such as "4.2.0-Enterprise_Base" | ||
| uptimestring | Switch uptime, such as "21:21:27 up 1 day, 23:26, 0 users, load average: 1.92, 1.99, 2.00 " | 
SwitchStatePlatform
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| fansobject (keys:string, values:SwitchStatePlatformFan) | |||
| psusobject (keys:string, values:SwitchStatePlatformPSU) | |||
| tempsobject (keys:string, values:SwitchStatePlatformTemperature) | 
SwitchStatePlatformFan
Appears in: - SwitchStatePlatform
| Field | Description | Default | Validation | 
|---|---|---|---|
| dirstring | |||
| speedfloat | |||
| presenceboolean | |||
| statusboolean | 
SwitchStatePlatformPSU
Appears in: - SwitchStatePlatform
| Field | Description | Default | Validation | 
|---|---|---|---|
| inCurrentfloat | |||
| inPowerfloat | |||
| inVoltagefloat | |||
| outCurrentfloat | |||
| outPowerfloat | |||
| outVoltagefloat | |||
| presenceboolean | |||
| statusboolean | 
SwitchStatePlatformTemperature
Appears in: - SwitchStatePlatform
| Field | Description | Default | Validation | 
|---|---|---|---|
| tempfloat | |||
| alarmsstring | |||
| highThresholdfloat | |||
| critHighThresholdfloat | |||
| lowThresholdfloat | |||
| critLowThresholdfloat | 
SwitchStateTransceiver
Appears in: - SwitchState
| Field | Description | Default | Validation | 
|---|---|---|---|
| descrstring | |||
| cablestring | |||
| formFactorstring | |||
| connTypestring | |||
| presentstring | |||
| lengthfloat | |||
| operstring | |||
| tempfloat | |||
| voltagefloat | |||
| serialstring | |||
| vendorstring | |||
| vendorPartstring | |||
| vendorOUIstring | |||
| vendorRevstring | |||
| firmwarestring | |||
| cmisstring | |||
| cmisRevstring | |||
| cmisAppinteger | |||
| channelsobject (keys:string, values:SwitchStateTransceiverChannel) | 
SwitchStateTransceiverChannel
Appears in: - SwitchStateTransceiver
| Field | Description | Default | Validation | 
|---|---|---|---|
| infloat | |||
| outfloat | |||
| biasfloat | 
dhcp.githedgehog.com/v1beta1
Package v1beta1 contains API Schema definitions for the dhcp v1beta1 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.
Resource Types
DHCPAllocated
DHCPAllocated is a single allocated IP with expiry time and hostname from DHCP requests, it's effectively a DHCP lease
Appears in: - DHCPSubnetStatus
| Field | Description | Default | Validation | 
|---|---|---|---|
| ipstring | Allocated IP address | ||
| expiryTime | Expiry time of the lease | ||
| hostnamestring | Hostname from DHCP request | 
DHCPRoute
Appears in: - DHCPSubnetSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| destinationstring | Destination is the destination prefix for the route | ||
| gatewaystring | Gateway is the gateway IP address for the route | 
DHCPSubnet
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.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | dhcp.githedgehog.com/v1beta1 | ||
| kindstring | DHCPSubnet | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specDHCPSubnetSpec | Spec is the desired state of the DHCPSubnet | ||
| statusDHCPSubnetStatus | Status is the observed state of the DHCPSubnet | 
DHCPSubnetSpec
DHCPSubnetSpec defines the desired state of DHCPSubnet
Appears in: - DHCPSubnet
| Field | Description | Default | Validation | 
|---|---|---|---|
| subnetstring | Full VPC subnet name (including VPC name), such as "vpc-0/default" | ||
| cidrBlockstring | CIDR block to use for VPC subnet, such as "10.10.10.0/24" | ||
| gatewaystring | Gateway, such as 10.10.10.1 | ||
| startIPstring | Start IP from the CIDRBlock to allocate IPs, such as 10.10.10.10 | ||
| endIPstring | End IP from the CIDRBlock to allocate IPs, such as 10.10.10.99 | ||
| leaseTimeSecondsinteger | Lease time in seconds, such as 3600 | ||
| vrfstring | 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 | ||
| circuitIDstring | VLAN ID to identify specific subnet within the VPC, such as "Vlan1000" as it's named on switch | ||
| pxeURLstring | 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 | ||
| dnsServersstring array | DNSservers (optional) to configure Domain Name Servers for this particular segment such as: 10.10.10.1, 10.10.10.2 | ||
| timeServersstring array | TimeServers (optional) NTP server addresses to configure for time servers for this particular segment such as: 10.10.10.1, 10.10.10.2 | ||
| interfaceMTUinteger | 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. | ||
| defaultURLstring | DefaultURL (optional) is the option 114 "default-url" to be sent to the clients | ||
| l3Modeboolean | L3 mode is used to indicate that this subnet is for a VPC in L3 mode meaning that /32 should be advertised to the clients | ||
| disableDefaultRouteboolean | Disable default route advertisement in DHCP | ||
| advertisedRoutesDHCPRoute array | AdvertisedRoutes (optional) is a list of custom routes to advertise in DHCP | 
DHCPSubnetStatus
DHCPSubnetStatus defines the observed state of DHCPSubnet
Appears in: - DHCPSubnet
| Field | Description | Default | Validation | 
|---|---|---|---|
| allocatedobject (keys:string, values:DHCPAllocated) | Allocated is a map of allocated IPs with expiry time and hostname from DHCP requests | 
vpc.githedgehog.com/v1beta1
Package v1beta1 contains API Schema definitions for the vpc v1beta1 API group. It is public API group for the VPCs and Externals APIs. Intended to be used by the user.
Resource Types
External
External object represents an external system connected to the Fabric and available to the specific IPv4Namespace. Users can do external peering with the external system by specifying the name of the External Object without need to worry about the details of how external system is attached to the Fabric.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | External | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specExternalSpec | Spec is the desired state of the External | ||
| statusExternalStatus | Status is the observed state of the External | 
ExternalAttachment
ExternalAttachment is a definition of how specific switch is connected with external system (External object). Effectively it represents BGP peering between the switch and external system including all needed configuration.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | ExternalAttachment | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specExternalAttachmentSpec | Spec is the desired state of the ExternalAttachment | ||
| statusExternalAttachmentStatus | Status is the observed state of the ExternalAttachment | 
ExternalAttachmentNeighbor
ExternalAttachmentNeighbor defines the BGP neighbor configuration for the external attachment
Appears in: - ExternalAttachmentSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| asninteger | ASN is the ASN of the BGP neighbor | ||
| ipstring | IP is the IP address of the BGP neighbor to peer with (without prefix length) | 
ExternalAttachmentSpec
ExternalAttachmentSpec defines the desired state of ExternalAttachment
Appears in: - ExternalAttachment
| Field | Description | Default | Validation | 
|---|---|---|---|
| externalstring | External is the name of the External object this attachment belongs to | ||
| connectionstring | Connection is the name of the Connection object this attachment belongs to (essentially the name of the switch/port) | ||
| switchExternalAttachmentSwitch | Switch is the switch port configuration for the external attachment | ||
| neighborExternalAttachmentNeighbor | Neighbor is the BGP neighbor configuration for the external attachment | 
ExternalAttachmentStatus
ExternalAttachmentStatus defines the observed state of ExternalAttachment
Appears in: - ExternalAttachment
ExternalAttachmentSwitch
ExternalAttachmentSwitch defines the switch port configuration for the external attachment
Appears in: - ExternalAttachmentSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| vlaninteger | VLAN (optional) is the VLAN ID used for the subinterface on a switch port specified in the connection, set to 0 if no VLAN is used | ||
| ipstring | IP is the IP address of the subinterface on a switch port specified in the connection, it should include the prefix length | 
ExternalPeering
ExternalPeering is the Schema for the externalpeerings API
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | ExternalPeering | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specExternalPeeringSpec | Spec is the desired state of the ExternalPeering | ||
| statusExternalPeeringStatus | Status is the observed state of the ExternalPeering | 
ExternalPeeringSpec
ExternalPeeringSpec defines the desired state of ExternalPeering
Appears in: - ExternalPeering
| Field | Description | Default | Validation | 
|---|---|---|---|
| permitExternalPeeringSpecPermit | Permit defines the peering policy - which VPC and External to peer with and which subnets/prefixes to permit | 
ExternalPeeringSpecExternal
ExternalPeeringSpecExternal defines the External-side of the configuration to peer with
Appears in: - ExternalPeeringSpecPermit
| Field | Description | Default | Validation | 
|---|---|---|---|
| namestring | Name is the name of the External to peer with | ||
| prefixesExternalPeeringSpecPrefix array | Prefixes is the list of prefixes to permit from the External to the VPC | 
ExternalPeeringSpecPermit
ExternalPeeringSpecPermit defines the peering policy - which VPC and External to peer with and which subnets/prefixes to permit
Appears in: - ExternalPeeringSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| vpcExternalPeeringSpecVPC | VPC is the VPC-side of the configuration to peer with | ||
| externalExternalPeeringSpecExternal | External is the External-side of the configuration to peer with | 
ExternalPeeringSpecPrefix
ExternalPeeringSpecPrefix defines the prefix to permit from the External to the VPC
Appears in: - ExternalPeeringSpecExternal
| Field | Description | Default | Validation | 
|---|---|---|---|
| prefixstring | Prefix is the subnet to permit from the External to the VPC, e.g. 0.0.0.0/0 for any route including default route. It matches any prefix length less than or equal to 32 effectively permitting all prefixes within the specified one. | 
ExternalPeeringSpecVPC
ExternalPeeringSpecVPC defines the VPC-side of the configuration to peer with
Appears in: - ExternalPeeringSpecPermit
| Field | Description | Default | Validation | 
|---|---|---|---|
| namestring | Name is the name of the VPC to peer with | ||
| subnetsstring array | Subnets is the list of subnets to advertise from VPC to the External | 
ExternalPeeringStatus
ExternalPeeringStatus defines the observed state of ExternalPeering
Appears in: - ExternalPeering
ExternalSpec
ExternalSpec describes IPv4 namespace External belongs to and inbound/outbound communities which are used to filter routes from/to the external system.
Appears in: - External
| Field | Description | Default | Validation | 
|---|---|---|---|
| ipv4Namespacestring | IPv4Namespace is the name of the IPv4Namespace this External belongs to | ||
| inboundCommunitystring | InboundCommunity is the inbound community to filter routes from the external system (e.g. 65102:5000) | ||
| outboundCommunitystring | OutboundCommunity is theoutbound community that all outbound routes will be stamped with (e.g. 50000:50001) | 
ExternalStatus
ExternalStatus defines the observed state of External
Appears in: - External
IPv4Namespace
IPv4Namespace represents a namespace for VPC subnets allocation. All VPC subnets within a single IPv4Namespace are non-overlapping. Users can create multiple IPv4Namespaces to allocate same VPC subnets.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | IPv4Namespace | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specIPv4NamespaceSpec | Spec is the desired state of the IPv4Namespace | ||
| statusIPv4NamespaceStatus | Status is the observed state of the IPv4Namespace | 
IPv4NamespaceSpec
IPv4NamespaceSpec defines the desired state of IPv4Namespace
Appears in: - IPv4Namespace
| Field | Description | Default | Validation | 
|---|---|---|---|
| subnetsstring array | Subnets is the list of subnets to allocate VPC subnets from, couldn't overlap between each other and with Fabric reserved subnets | MaxItems: 20 MinItems: 1 | 
IPv4NamespaceStatus
IPv4NamespaceStatus defines the observed state of IPv4Namespace
Appears in: - IPv4Namespace
VPC
VPC is Virtual Private Cloud, similar to the public cloud VPC it provides an isolated private network for the resources with support for multiple subnets each with user-provided VLANs and on-demand DHCP.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | VPC | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specVPCSpec | Spec is the desired state of the VPC | ||
| statusVPCStatus | Status is the observed state of the VPC | 
VPCAttachment
VPCAttachment is the Schema for the vpcattachments API
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | VPCAttachment | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specVPCAttachmentSpec | Spec is the desired state of the VPCAttachment | ||
| statusVPCAttachmentStatus | Status is the observed state of the VPCAttachment | 
VPCAttachmentSpec
VPCAttachmentSpec defines the desired state of VPCAttachment
Appears in: - VPCAttachment
| Field | Description | Default | Validation | 
|---|---|---|---|
| subnetstring | Subnet is the full name of the VPC subnet to attach to, such as "vpc-1/default" | ||
| connectionstring | Connection is the name of the connection to attach to the VPC | ||
| nativeVLANboolean | NativeVLAN is the flag to indicate if the native VLAN should be used for attaching the VPC subnet | 
VPCAttachmentStatus
VPCAttachmentStatus defines the observed state of VPCAttachment
Appears in: - VPCAttachment
VPCDHCP
VPCDHCP defines the on-demand DHCP configuration for the subnet
Appears in: - VPCSubnet
| Field | Description | Default | Validation | 
|---|---|---|---|
| relaystring | Relay is the DHCP relay IP address, if specified, DHCP server will be disabled | ||
| enableboolean | Enable enables DHCP server for the subnet | ||
| rangeVPCDHCPRange | Range (optional) is the DHCP range for the subnet if DHCP server is enabled | ||
| optionsVPCDHCPOptions | Options (optional) is the DHCP options for the subnet if DHCP server is enabled | 
VPCDHCPOptions
VPCDHCPOptions defines the DHCP options for the subnet if DHCP server is enabled
Appears in: - VPCDHCP
| Field | Description | Default | Validation | 
|---|---|---|---|
| pxeURLstring | 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 | ||
| dnsServersstring array | DNSservers (optional) to configure Domain Name Servers for this particular segment such as: 10.10.10.1, 10.10.10.2 | Optional: {} | |
| timeServersstring array | TimeServers (optional) NTP server addresses to configure for time servers for this particular segment such as: 10.10.10.1, 10.10.10.2 | Optional: {} | |
| interfaceMTUinteger | 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. | ||
| leaseTimeSecondsinteger | Lease time in seconds, such as 3600 | ||
| disableDefaultRouteboolean | Disable default route advertisement. For L3VNI VPCs, a classless static route to the VPC subnet will be advertised if this option is enabled. | ||
| advertisedRoutesVPCDHCPRoute array | Advertise custom routes to the clients via the classless static route option. If non-empty, and unless the disable default route flag is enabled, a default route via the VPC gateway will be added automatically. | Optional: {} | 
VPCDHCPRange
VPCDHCPRange defines the DHCP range for the subnet if DHCP server is enabled
Appears in: - VPCDHCP
| Field | Description | Default | Validation | 
|---|---|---|---|
| startstring | Start is the start IP address of the DHCP range | ||
| endstring | End is the end IP address of the DHCP range | 
VPCDHCPRoute
Appears in: - VPCDHCPOptions
| Field | Description | Default | Validation | 
|---|---|---|---|
| destinationstring | Destination is the destination prefix for the route | ||
| gatewaystring | Gateway is the gateway IP address for the route | 
VPCMode
Underlying type: string
VPCMode defines how VPCs are implemented on the switches
Appears in: - VPCSpec
| Field | Description | 
|---|---|
| `` | L2VNI: L2VPN EVPN with VRF per VPC and L2VNI per VPC subnet | 
| l3vni | L3VNI: L2VPN EVPN with VRF per VPC and only L3VNI per VPC, hosts should have /32 IP addresses in the VPC subnets | 
| l3flat | (EXPERIMENTAL) L3Flat: All VPCs are configured within default VRF and ACLs are used for isolation and VPC peerings, hosts should have /32 IP addresses in the VPC subnets | 
VPCPeer
Appears in: - VPCPeeringSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| subnetsstring array | Subnets is the list of subnets to advertise from current VPC to the peer VPC | MaxItems: 10 MinItems: 1 | 
VPCPeering
VPCPeering represents a peering between two VPCs with corresponding filtering rules. Minimal example of the VPC peering showing vpc-1 to vpc-2 peering with all subnets allowed:
spec:
  permit:
  - vpc-1: {}
    vpc-2: {}
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | vpc.githedgehog.com/v1beta1 | ||
| kindstring | VPCPeering | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specVPCPeeringSpec | Spec is the desired state of the VPCPeering | ||
| statusVPCPeeringStatus | Status is the observed state of the VPCPeering | 
VPCPeeringSpec
VPCPeeringSpec defines the desired state of VPCPeering
Appears in: - VPCPeering
| Field | Description | Default | Validation | 
|---|---|---|---|
| remotestring | |||
| permitmap[string]VPCPeer array | Permit defines a list of the peering policies - which VPC subnets will have access to the peer VPC subnets. | MaxItems: 10 MinItems: 1 | 
VPCPeeringStatus
VPCPeeringStatus defines the observed state of VPCPeering
Appears in: - VPCPeering
VPCSpec
VPCSpec defines the desired state of VPC. At least one subnet is required.
Appears in: - VPC
| Field | Description | Default | Validation | 
|---|---|---|---|
| modeVPCMode | Mode is the VPC mode that defines how the VPCs are configured on the switches | ||
| subnetsobject (keys:string, values:VPCSubnet) | Subnets is the list of VPC subnets to configure | ||
| ipv4Namespacestring | IPv4Namespace is the name of the IPv4Namespace this VPC belongs to (if not specified, "default" is used) | ||
| vlanNamespacestring | VLANNamespace is the name of the VLANNamespace this VPC belongs to (if not specified, "default" is used) | ||
| defaultIsolatedboolean | DefaultIsolated sets default behavior for isolated mode for the subnets (disabled by default) | ||
| defaultRestrictedboolean | DefaultRestricted sets default behavior for restricted mode for the subnets (disabled by default) | ||
| permitstring array array | Permit defines a list of the access policies between the subnets within the VPC - each policy is a list of subnets that have access to each other. It's applied on top of the subnet isolation flag and if subnet isn't isolated it's not required to have it in a permit list while if vpc is marked as isolated it's required to have it in a permit list to have access to other subnets. | ||
| staticRoutesVPCStaticRoute array | StaticRoutes is the list of additional static routes for the VPC | 
VPCStaticRoute
VPCStaticRoute defines the static route for the VPC
Appears in: - VPCSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| prefixstring | Prefix for the static route (mandatory), e.g. 10.42.0.0/24 | ||
| nextHopsstring array | NextHops for the static route (at least one is required), e.g. 10.99.0.0 | 
VPCStatus
VPCStatus defines the observed state of VPC
Appears in: - VPC
VPCSubnet
VPCSubnet defines the VPC subnet configuration
Appears in: - VPCSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| subnetstring | Subnet is the subnet CIDR block, such as "10.0.0.0/24", should belong to the IPv4Namespace and be unique within the namespace | ||
| gatewaystring | Gateway (optional) for the subnet, if not specified, the first IP (e.g. 10.0.0.1) in the subnet is used as the gateway | ||
| dhcpVPCDHCP | DHCP is the on-demand DHCP configuration for the subnet | ||
| vlaninteger | VLAN is the VLAN ID for the subnet, should belong to the VLANNamespace and be unique within the namespace | ||
| isolatedboolean | Isolated is the flag to enable isolated mode for the subnet which means no access to and from the other subnets within the VPC | ||
| restrictedboolean | Restricted is the flag to enable restricted mode for the subnet which means no access between hosts within the subnet itself | 
wiring.githedgehog.com/v1beta1
Package v1beta1 contains API Schema definitions for the wiring v1beta1 API group. It is public API group mainly for the underlay definition including Switches, Server, wiring between them and etc. Intended to be used by the user.
Resource Types
BasePortName
BasePortName defines the full name of the switch port
Appears in: - ConnExternalLink - ConnFabricLinkSwitch - ConnGatewayLinkGateway - ConnStaticExternalLinkSwitch - ServerToSwitchLink - SwitchToSwitchLink
| Field | Description | Default | Validation | 
|---|---|---|---|
| portstring | Port defines the full name of the switch port in the format of "device/port", such as "spine-1/E1/1". SONiC port name is used as a port name and switch name should be same as the name of the Switch object. | 
ConnBundled
ConnBundled defines the bundled connection (port channel, single server to a single switch with multiple links)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksServerToSwitchLink array | Links is the list of server-to-switch links | ||
| mtuinteger | MTU is the MTU to be configured on the switch port or port channel | 
ConnESLAG
ConnESLAG defines the ESLAG connection (port channel, single server to 2-4 switches with multiple links)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksServerToSwitchLink array | Links is the list of server-to-switch links | MinItems: 2 | |
| mtuinteger | MTU is the MTU to be configured on the switch port or port channel | ||
| fallbackboolean | Fallback is the optional flag that used to indicate one of the links in LACP port channel to be used as a fallback link | 
ConnExternal
ConnExternal defines the external connection (single switch to a single external device with a single link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linkConnExternalLink | Link is the external connection link | 
ConnExternalLink
ConnExternalLink defines the external connection link
Appears in: - ConnExternal
| Field | Description | Default | Validation | 
|---|---|---|---|
| switchBasePortName | 
ConnFabric
ConnFabric defines the fabric connection (single spine to a single leaf with at least one link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksFabricLink array | Links is the list of spine-to-leaf links | MinItems: 1 | 
ConnFabricLinkSwitch
ConnFabricLinkSwitch defines the switch side of the fabric (or gateway) link
Appears in: - FabricLink - GatewayLink - MeshLink
| Field | Description | Default | Validation | 
|---|---|---|---|
| portstring | Port defines the full name of the switch port in the format of "device/port", such as "spine-1/E1/1". SONiC port name is used as a port name and switch name should be same as the name of the Switch object. | ||
| ipstring | IP is the IP address of the switch side of the fabric link (switch port configuration) | Pattern: ^((25[0-5]\|(2[0-4]\|1\d\|[1-9]\|)\d)\.?\b)\{4\}/([1-2]?[0-9]\|3[0-2])$ | 
ConnGateway
ConnGateway defines the gateway connection (single spine to a single gateway with at least one link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksGatewayLink array | Links is the list of spine to gateway links | MinItems: 1 | 
ConnGatewayLinkGateway
ConnGatewayLinkGateway defines the gateway side of the gateway link
Appears in: - GatewayLink
| Field | Description | Default | Validation | 
|---|---|---|---|
| portstring | Port defines the full name of the switch port in the format of "device/port", such as "spine-1/E1/1". SONiC port name is used as a port name and switch name should be same as the name of the Switch object. | ||
| ipstring | IP is the IP address of the switch side of the fabric link (switch port configuration) | Pattern: ^((25[0-5]\|(2[0-4]\|1\d\|[1-9]\|)\d)\.?\b)\{4\}/([1-2]?[0-9]\|3[0-2])$ | 
ConnMCLAG
ConnMCLAG defines the MCLAG connection (port channel, single server to pair of switches with multiple links)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksServerToSwitchLink array | Links is the list of server-to-switch links | MinItems: 2 | |
| mtuinteger | MTU is the MTU to be configured on the switch port or port channel | ||
| fallbackboolean | Fallback is the optional flag that used to indicate one of the links in LACP port channel to be used as a fallback link | 
ConnMCLAGDomain
ConnMCLAGDomain defines the MCLAG domain connection which makes two switches into a single logical switch or redundancy group and allows to use MCLAG connections to connect servers in a multi-homed way.
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| peerLinksSwitchToSwitchLink array | PeerLinks is the list of peer links between the switches, used to pass server traffic between switch | MinItems: 1 | |
| sessionLinksSwitchToSwitchLink array | SessionLinks is the list of session links between the switches, used only to pass MCLAG control plane and BGP traffic between switches | MinItems: 1 | 
ConnMesh
ConnMesh defines the mesh connection (direct leaf to leaf connection with at least one link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksMeshLink array | Links is the list of leaf to leaf links | MinItems: 1 | 
ConnStaticExternal
ConnStaticExternal defines the static external connection (single switch to a single external device with a single link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linkConnStaticExternalLink | Link is the static external connection link | ||
| withinVPCstring | WithinVPC is the optional VPC name to provision the static external connection within the VPC VRF instead of default one to make resource available to the specific VPC | 
ConnStaticExternalLink
ConnStaticExternalLink defines the static external connection link
Appears in: - ConnStaticExternal
| Field | Description | Default | Validation | 
|---|---|---|---|
| switchConnStaticExternalLinkSwitch | Switch is the switch side of the static external connection link | 
ConnStaticExternalLinkSwitch
ConnStaticExternalLinkSwitch defines the switch side of the static external connection link
Appears in: - ConnStaticExternalLink
| Field | Description | Default | Validation | 
|---|---|---|---|
| portstring | Port defines the full name of the switch port in the format of "device/port", such as "spine-1/E1/1". SONiC port name is used as a port name and switch name should be same as the name of the Switch object. | ||
| ipstring | IP is the IP address of the switch side of the static external connection link (switch port configuration) | Pattern: ^((25[0-5]\|(2[0-4]\|1\d\|[1-9]\|)\d)\.?\b)\{4\}/([1-2]?[0-9]\|3[0-2])$ | |
| nextHopstring | NextHop is the next hop IP address for static routes that will be created for the subnets | Pattern: ^((25[0-5]\|(2[0-4]\|1\d\|[1-9]\|)\d)\.?\b)\{4\}$ | |
| subnetsstring array | Subnets is the list of subnets that will get static routes using the specified next hop | ||
| vlaninteger | VLAN is the optional VLAN ID to be configured on the switch port | 
ConnUnbundled
ConnUnbundled defines the unbundled connection (no port channel, single server to a single switch with a single link)
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linkServerToSwitchLink | Link is the server-to-switch link | ||
| mtuinteger | MTU is the MTU to be configured on the switch port or port channel | 
ConnVPCLoopback
ConnVPCLoopback defines the VPC loopback connection (multiple port pairs on a single switch) that enables automated workaround named "VPC Loopback" that allow to avoid switch hardware limitations and traffic going through CPU in some cases
Appears in: - ConnectionSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| linksSwitchToSwitchLink array | Links is the list of VPC loopback links | MinItems: 1 | 
Connection
Connection object represents a logical and physical connections between any devices in the Fabric (Switch, Server and External objects). It's needed to define all physical and logical connections between the devices in the Wiring Diagram. Connection type is defined by the top-level field in the ConnectionSpec. Exactly one of them could be used in a single Connection object.
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | Connection | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specConnectionSpec | Spec is the desired state of the Connection | ||
| statusConnectionStatus | Status is the observed state of the Connection | 
ConnectionSpec
ConnectionSpec defines the desired state of Connection
Appears in: - Connection
| Field | Description | Default | Validation | 
|---|---|---|---|
| unbundledConnUnbundled | Unbundled defines the unbundled connection (no port channel, single server to a single switch with a single link) | ||
| bundledConnBundled | Bundled defines the bundled connection (port channel, single server to a single switch with multiple links) | ||
| mclagConnMCLAG | MCLAG defines the MCLAG connection (port channel, single server to pair of switches with multiple links) | ||
| eslagConnESLAG | ESLAG defines the ESLAG connection (port channel, single server to 2-4 switches with multiple links) | ||
| mclagDomainConnMCLAGDomain | MCLAGDomain defines the MCLAG domain connection which makes two switches into a single logical switch for server multi-homing | ||
| fabricConnFabric | Fabric defines the fabric connection (single spine to a single leaf with at least one link) | ||
| meshConnMesh | Mesh defines the mesh connection (direct leaf to leaf connection with at least one link) | ||
| gatewayConnGateway | Gateway defines the gateway connection (single spine to a single gateway with at least one link) | ||
| vpcLoopbackConnVPCLoopback | VPCLoopback defines the VPC loopback connection (multiple port pairs on a single switch) for automated workaround | ||
| externalConnExternal | External defines the external connection (single switch to a single external device with a single link) | ||
| staticExternalConnStaticExternal | StaticExternal defines the static external connection (single switch to a single external device with a single link) | 
ConnectionStatus
ConnectionStatus defines the observed state of Connection
Appears in: - Connection
FabricLink
FabricLink defines the fabric connection link
Appears in: - ConnFabric
| Field | Description | Default | Validation | 
|---|---|---|---|
| spineConnFabricLinkSwitch | Spine is the spine side of the fabric link | ||
| leafConnFabricLinkSwitch | Leaf is the leaf side of the fabric link | 
GatewayLink
GatewayLink defines the gateway connection link
Appears in: - ConnGateway
| Field | Description | Default | Validation | 
|---|---|---|---|
| switchConnFabricLinkSwitch | Switch is the switch (spine or leaf) side of the gateway link | ||
| gatewayConnGatewayLinkGateway | Gateway is the gateway side of the gateway link | 
MeshLink
MeshLink defines the mesh connection link, i.e. a direct leaf to leaf connection
Appears in: - ConnMesh
| Field | Description | Default | Validation | 
|---|---|---|---|
| leaf1ConnFabricLinkSwitch | |||
| leaf2ConnFabricLinkSwitch | 
Server
Server is the Schema for the servers API
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | Server | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specServerSpec | Spec is desired state of the server | ||
| statusServerStatus | Status is the observed state of the server | 
ServerFacingConnectionConfig
ServerFacingConnectionConfig defines any server-facing connection (unbundled, bundled, mclag, etc.) configuration
Appears in: - ConnBundled - ConnESLAG - ConnMCLAG - ConnUnbundled
| Field | Description | Default | Validation | 
|---|---|---|---|
| mtuinteger | MTU is the MTU to be configured on the switch port or port channel | 
ServerSpec
ServerSpec defines the desired state of Server
Appears in: - Server
| Field | Description | Default | Validation | 
|---|---|---|---|
| descriptionstring | Description is a description of the server | ||
| profilestring | Profile is the profile of the server, name of the ServerProfile object to be used for this server, currently not used by the Fabric | 
ServerStatus
ServerStatus defines the observed state of Server
Appears in: - Server
ServerToSwitchLink
ServerToSwitchLink defines the server-to-switch link
Appears in: - ConnBundled - ConnESLAG - ConnMCLAG - ConnUnbundled
| Field | Description | Default | Validation | 
|---|---|---|---|
| serverBasePortName | Server is the server side of the connection | ||
| switchBasePortName | Switch is the switch side of the connection | 
Switch
Switch is the Schema for the switches API
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | Switch | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specSwitchSpec | Spec is desired state of the switch | ||
| statusSwitchStatus | Status is the observed state of the switch | 
SwitchBoot
Appears in: - SwitchSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| serialstring | Identify switch by serial number | ||
| macstring | Identify switch by MAC address of the management port | 
SwitchECMP
SwitchECMP is a struct that defines the ECMP configuration for the switch
Appears in: - SwitchSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| roceQPNboolean | RoCEQPN is a flag to enable RoCE QPN hashing | 
SwitchGroup
SwitchGroup is the marker API object to group switches together, switch can belong to multiple groups
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | SwitchGroup | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specSwitchGroupSpec | Spec is the desired state of the SwitchGroup | ||
| statusSwitchGroupStatus | Status is the observed state of the SwitchGroup | 
SwitchGroupSpec
SwitchGroupSpec defines the desired state of SwitchGroup
Appears in: - SwitchGroup
SwitchGroupStatus
SwitchGroupStatus defines the observed state of SwitchGroup
Appears in: - SwitchGroup
SwitchProfile
SwitchProfile represents switch capabilities and configuration
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | SwitchProfile | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specSwitchProfileSpec | |||
| statusSwitchProfileStatus | 
SwitchProfileConfig
Defines switch-specific configuration options
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| maxPathsEBGPinteger | MaxPathsIBGP defines the maximum number of IBGP paths to be configured | 
SwitchProfileFeatures
Defines features supported by a specific switch which is later used for roles and Fabric API features usage validation
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| subinterfacesboolean | Subinterfaces defines if switch supports subinterfaces | ||
| aclsboolean | ACLs defines if switch supports ACLs | ||
| l2vniboolean | L2VNI defines if switch supports L2 VNIs | ||
| l3vniboolean | L3VNI defines if switch supports L3 VNIs | ||
| roceboolean | RoCE defines if switch supports RoCEv2 over VXLAN and related features used by the fabric | ||
| mclagboolean | MCLAG defines if switch supports MCLAG (with VXLAN) | ||
| eslagboolean | ESLAG defines if switch supports ESLAG (ESI multi-homing) | ||
| ecmpRoCEQPNboolean | ECMPRoCEQPN defines if switch supports ECMP QPN hashing | 
SwitchProfilePipeline
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| maxPortsinteger | MaxPorts defines the maximum number of ports (breakouts) allowed for the pipeline | 
SwitchProfilePort
Defines a switch port configuration Only one of Profile or Group can be set
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| nosstring | NOSName defines how port is named in the NOS | ||
| baseNOSNamestring | BaseNOSName defines the base NOS name that could be used together with the profile to generate the actual NOS name (e.g. breakouts) | ||
| labelstring | Label defines the physical port label you can see on the actual switch | ||
| groupstring | If port isn't directly manageable, group defines the group it belongs to, exclusive with profile | ||
| profilestring | If port is directly configurable, profile defines the profile it belongs to, exclusive with group | ||
| managementboolean | Management defines if port is a management port, it's a special case and it can't have a group or profile | ||
| oniePortNamestring | OniePortName defines the ONIE port name for management ports only | ||
| pipelinestring | Pipeline defines the pipeline used by the port, on some platforms multiple ports share the same pipeline | 
SwitchProfilePortGroup
Defines a switch port group configuration
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| nosstring | NOSName defines how group is named in the NOS | ||
| profilestring | Profile defines the possible configuration profile for the group, could only have speed profile | 
SwitchProfilePortProfile
Defines a switch port profile configuration
Appears in: - SwitchProfileSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| speedSwitchProfilePortProfileSpeed | Speed defines the speed configuration for the profile, exclusive with breakout | ||
| breakoutSwitchProfilePortProfileBreakout | Breakout defines the breakout configuration for the profile, exclusive with speed | ||
| autoNegAllowedboolean | AutoNegAllowed defines if configuring auto-negotiation is allowed for the port | ||
| autoNegDefaultboolean | AutoNegDefault defines the default auto-negotiation state for the port | 
SwitchProfilePortProfileBreakout
Defines a switch port profile breakout configuration
Appears in: - SwitchProfilePortProfile
| Field | Description | Default | Validation | 
|---|---|---|---|
| defaultstring | Default defines the default breakout mode for the profile | ||
| supportedobject (keys:string, values:SwitchProfilePortProfileBreakoutMode) | Supported defines the supported breakout modes for the profile with the NOS name offsets | 
SwitchProfilePortProfileBreakoutMode
Defines a switch port profile breakout mode configuration
Appears in: - SwitchProfilePortProfileBreakout
| Field | Description | Default | Validation | 
|---|---|---|---|
| offsetsstring array | Offsets defines the breakout NOS port name offset from the port NOS Name for each breakout mode | 
SwitchProfilePortProfileSpeed
Defines a switch port profile speed configuration
Appears in: - SwitchProfilePortProfile
| Field | Description | Default | Validation | 
|---|---|---|---|
| defaultstring | Default defines the default speed for the profile | ||
| supportedstring array | Supported defines the supported speeds for the profile | 
SwitchProfileSpec
SwitchProfileSpec defines the desired state of SwitchProfile
Appears in: - SwitchProfile
| Field | Description | Default | Validation | 
|---|---|---|---|
| displayNamestring | DisplayName defines the human-readable name of the switch | ||
| otherNamesstring array | OtherNames defines alternative names for the switch | ||
| switchSiliconstring | SwitchSilicon defines the switch silicon name | ||
| featuresSwitchProfileFeatures | Features defines the features supported by the switch | ||
| notesstring | Notes is a free-form field for any additional information about the switch | ||
| configSwitchProfileConfig | Config defines the switch-specific configuration options | ||
| portsobject (keys:string, values:SwitchProfilePort) | Ports defines the switch port configuration | ||
| portGroupsobject (keys:string, values:SwitchProfilePortGroup) | PortGroups defines the switch port group configuration | ||
| portProfilesobject (keys:string, values:SwitchProfilePortProfile) | PortProfiles defines the switch port profile configuration | ||
| nosTypeNOSType | NOSType defines the NOS type to be used for the switch | ||
| platformstring | Platform is what expected to be request by ONIE and displayed in the NOS | ||
| pipelinesobject (keys:string, values:SwitchProfilePipeline) | Pipelines defines the switch pipeline configuration | ||
| maxPortsinteger | MaxPorts defines the maximum number of ports (breakouts) allowed for the switch | 
SwitchProfileStatus
SwitchProfileStatus defines the observed state of SwitchProfile
Appears in: - SwitchProfile
SwitchRedundancy
SwitchRedundancy is the switch redundancy configuration which includes name of the redundancy group switch belongs to and its type, used both for MCLAG and ESLAG connections. It defines how redundancy will be configured and handled on the switch as well as which connection types will be available. If not specified, switch will not be part of any redundancy group. If name isn't empty, type must be specified as well and name should be the same as one of the SwitchGroup objects.
Appears in: - SwitchSpec
| Field | Description | Default | Validation | 
|---|---|---|---|
| groupstring | Group is the name of the redundancy group switch belongs to | ||
| typeRedundancyType | Type is the type of the redundancy group, could be mclag or eslag | 
SwitchRole
Underlying type: string
SwitchRole is the role of the switch, could be spine, server-leaf or border-leaf or mixed-leaf
Validation: - Enum: [spine server-leaf border-leaf mixed-leaf virtual-edge]
Appears in: - SwitchSpec
| Field | Description | 
|---|---|
| spine | |
| server-leaf | |
| border-leaf | |
| mixed-leaf | 
SwitchSpec
SwitchSpec defines the desired state of Switch
Appears in: - Switch
| Field | Description | Default | Validation | 
|---|---|---|---|
| roleSwitchRole | Role is the role of the switch, could be spine, server-leaf or border-leaf or mixed-leaf | Enum: [spine server-leaf border-leaf mixed-leaf virtual-edge] Required: {} | |
| descriptionstring | Description is a description of the switch | ||
| profilestring | Profile is the profile of the switch, name of the SwitchProfile object to be used for this switch, currently not used by the Fabric | ||
| groupsstring array | Groups is a list of switch groups the switch belongs to | ||
| redundancySwitchRedundancy | Redundancy is the switch redundancy configuration including name of the redundancy group switch belongs to and its type, used both for MCLAG and ESLAG connections | ||
| vlanNamespacesstring array | VLANNamespaces is a list of VLAN namespaces the switch is part of, their VLAN ranges could not overlap | ||
| asninteger | ASN is the ASN of the switch | ||
| ipstring | IP is the IP of the switch that could be used to access it from other switches and control nodes in the Fabric | ||
| vtepIPstring | VTEPIP is the VTEP IP of the switch | ||
| protocolIPstring | ProtocolIP is used as BGP Router ID for switch configuration | ||
| portGroupSpeedsobject (keys:string, values:string) | PortGroupSpeeds is a map of port group speeds, key is the port group name, value is the speed, such as '"2": 10G' | ||
| portSpeedsobject (keys:string, values:string) | PortSpeeds is a map of port speeds, key is the port name, value is the speed | ||
| portBreakoutsobject (keys:string, values:string) | PortBreakouts is a map of port breakouts, key is the port name, value is the breakout configuration, such as "1/55: 4x25G" | ||
| portAutoNegsobject (keys:string, values:boolean) | PortAutoNegs is a map of port auto negotiation, key is the port name, value is true or false | ||
| bootSwitchBoot | Boot is the boot/provisioning information of the switch | ||
| enableAllPortsboolean | EnableAllPorts is a flag to enable all ports on the switch regardless of them being used or not | ||
| roceboolean | RoCE is a flag to enable RoCEv2 support on the switch which includes lossless queues and QoS configuration | ||
| ecmpSwitchECMP | ECMP is the ECMP configuration for the switch | 
SwitchStatus
SwitchStatus defines the observed state of Switch
Appears in: - Switch
SwitchToSwitchLink
SwitchToSwitchLink defines the switch-to-switch link
Appears in: - ConnMCLAGDomain - ConnVPCLoopback
| Field | Description | Default | Validation | 
|---|---|---|---|
| switch1BasePortName | Switch1 is the first switch side of the connection | ||
| switch2BasePortName | Switch2 is the second switch side of the connection | 
VLANNamespace
VLANNamespace is the Schema for the vlannamespaces API
| Field | Description | Default | Validation | 
|---|---|---|---|
| apiVersionstring | wiring.githedgehog.com/v1beta1 | ||
| kindstring | VLANNamespace | ||
| metadataObjectMeta | Refer to Kubernetes API documentation for fields of metadata. | ||
| specVLANNamespaceSpec | Spec is the desired state of the VLANNamespace | ||
| statusVLANNamespaceStatus | Status is the observed state of the VLANNamespace | 
VLANNamespaceSpec
VLANNamespaceSpec defines the desired state of VLANNamespace
Appears in: - VLANNamespace
| Field | Description | Default | Validation | 
|---|---|---|---|
| rangesVLANRange array | Ranges is a list of VLAN ranges to be used in this namespace, couldn't overlap between each other and with Fabric reserved VLAN ranges | MaxItems: 20 MinItems: 1 | 
VLANNamespaceStatus
VLANNamespaceStatus defines the observed state of VLANNamespace
Appears in: - VLANNamespace