description:BGPConfiguration contains the configuration for any BGP routing.
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:BGPConfigurationSpec contains the values of the BGP configuration.
properties:
asNumber:
description:'ASNumber is the default AS number used by a node. [Default:
64512]'
format:int32
type:integer
communities:
description:Communities is a list of BGP community values and their
arbitrary names for tagging routes.
items:
description:Community contains standard or large community value
and its name.
properties:
name:
description:Name given to community value.
type:string
value:
description:Value must be of format `aa:nn` or `aa:nn:mm`.
For standard community use `aa:nn` format, where `aa` and
`nn` are 16 bit number. For large community use `aa:nn:mm`
format, where `aa`, `nn` and `mm` are 32 bit number. Where,
`aa` is an AS Number, `nn` and `mm` are per-AS identifier.
pattern:^(\d+):(\d+)$|^(\d+):(\d+):(\d+)$
type:string
type:object
type:array
listenPort:
description:ListenPort is the port where BGP protocol should listen.
Defaults to 179
maximum:65535
minimum:1
type:integer
logSeverityScreen:
description:'LogSeverityScreen is the log severity above which logs
are sent to the stdout. [Default:INFO]'
type:string
nodeToNodeMeshEnabled:
description:'NodeToNodeMeshEnabled sets whether full node to node
description:CIDR for which properties should be advertised.
type:string
communities:
description:Communities can be list of either community names
already defined in `Specs.Communities` or community value
of format `aa:nn` or `aa:nn:mm`. For standard community use
`aa:nn` format, where `aa` and `nn` are 16 bit number. For
large community use `aa:nn:mm` format, where `aa`, `nn` and
`mm` are 32 bit number. Where,`aa` is an AS Number, `nn` and
`mm` are per-AS identifier.
items:
type:string
type:array
type:object
type:array
serviceClusterIPs:
description:ServiceClusterIPs are the CIDR blocks from which service
cluster IPs are allocated. If specified, Calico will advertise these
blocks, as well as any cluster IPs within them.
items:
description:ServiceClusterIPBlock represents a single allowed ClusterIP
CIDR block.
properties:
cidr:
type:string
type:object
type:array
serviceExternalIPs:
description:ServiceExternalIPs are the CIDR blocks for Kubernetes
Service External IPs. Kubernetes Service ExternalIPs will only be
advertised if they are within one of these blocks.
items:
description:ServiceExternalIPBlock represents a single allowed
External IP CIDR block.
properties:
cidr:
type:string
type:object
type:array
serviceLoadBalancerIPs:
description:ServiceLoadBalancerIPs are the CIDR blocks for Kubernetes
Service LoadBalancer IPs. Kubernetes Service status.LoadBalancer.Ingress
IPs will only be advertised if they are within one of these blocks.
items:
description:ServiceLoadBalancerIPBlock represents a single allowed
LoadBalancer IP CIDR block.
properties:
cidr:
type:string
type:object
type:array
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:bgppeers.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:BGPPeer
listKind:BGPPeerList
plural:bgppeers
singular:bgppeer
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:BGPPeerSpec contains the specification for a BGPPeer resource.
properties:
asNumber:
description:The AS Number of the peer.
format:int32
type:integer
keepOriginalNextHop:
description:Option to keep the original nexthop field when routes
are sent to a BGP Peer. Setting "true" configures the selected BGP
Peers node to use the "next hop keep;" instead of "next hop self;"(default)
description:The node name identifying the Calico node instance that
is targeted by this peer. If this is not set, and no nodeSelector
is specified, then this BGP peer selects all nodes in the cluster.
type:string
nodeSelector:
description:Selector for the nodes that should have this peering. When
this is set, the Node field must be empty.
type:string
password:
description:Optional BGP password for the peerings generated by this
BGPPeer resource.
properties:
secretKeyRef:
description:Selects a key of a secret in the node pod's namespace.
properties:
key:
description:The key of the secret to select from. Must be
a valid secret key.
type:string
name:
description: 'Name of the referent. More info:https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
TODO:Add other useful fields. apiVersion, kind, uid?'
type:string
optional:
description:Specify whether the Secret or its key must be
defined
type:boolean
required:
- key
type:object
type:object
peerIP:
description:The IP address of the peer followed by an optional port
number to peer with. If port number is given, format should be `[<IPv6>]:port`
or `<IPv4>:<port>` for IPv4. If optional port number is not set,
and this peer IP and ASNumber belongs to a calico/node with ListenPort
set in BGPConfiguration, then we use that port to peer.
type:string
peerSelector:
description:Selector for the remote nodes to peer with. When this
is set, the PeerIP and ASNumber fields must be empty. For each
peering between the local node and selected remote nodes, we configure
an IPv4 peering if both ends have NodeBGPSpec.IPv4Address specified,
and an IPv6 peering if both ends have NodeBGPSpec.IPv6Address specified. The
remote AS number comes from the remote node's NodeBGPSpec.ASNumber,
or the global default if that is not set.
type:string
sourceAddress:
description:Specifies whether and how to configure a source address
for the peerings generated by this BGPPeer resource. Default value
"UseNodeIP"means to configure the node IP as the source address. "None"
means not to configure a source address.
type:string
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:blockaffinities.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:BlockAffinity
listKind:BlockAffinityList
plural:blockaffinities
singular:blockaffinity
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:BlockAffinitySpec contains the specification for a BlockAffinity
resource.
properties:
cidr:
type:string
deleted:
description:Deleted indicates that this block affinity is being deleted.
This field is a string for compatibility with older releases that
mistakenly treat this field as a string.
type:string
node:
type:string
state:
type:string
required:
- cidr
- deleted
- node
- state
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:clusterinformations.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:ClusterInformation
listKind:ClusterInformationList
plural:clusterinformations
singular:clusterinformation
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
description:ClusterInformation contains the cluster specific information.
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:ClusterInformationSpec contains the values of describing
the cluster.
properties:
calicoVersion:
description:CalicoVersion is the version of Calico that the cluster
is running
type:string
clusterGUID:
description:ClusterGUID is the GUID of the cluster
type:string
clusterType:
description:ClusterType describes the type of the cluster
type:string
datastoreReady:
description:DatastoreReady is used during significant datastore migrations
to signal to components such as Felix that it should wait before
accessing the datastore.
type:boolean
variant:
description:Variant declares which variant of Calico should be active.
type:string
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:felixconfigurations.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:FelixConfiguration
listKind:FelixConfigurationList
plural:felixconfigurations
singular:felixconfiguration
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
description:Felix Configuration contains the configuration for Felix.
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:FelixConfigurationSpec contains the values of the Felix configuration.
properties:
allowIPIPPacketsFromWorkloads:
description:'AllowIPIPPacketsFromWorkloads controls whether Felix
will add a rule to drop IPIP encapsulated traffic from workloads
[Default:false]'
type:boolean
allowVXLANPacketsFromWorkloads:
description:'AllowVXLANPacketsFromWorkloads controls whether Felix
will add a rule to drop VXLAN encapsulated traffic from workloads
[Default:false]'
type:boolean
awsSrcDstCheck:
description:'Set source-destination-check on AWS EC2 instances. Accepted
value must be one of "DoNothing", "Enabled" or "Disabled". [Default:
DoNothing]'
enum:
- DoNothing
- Enable
- Disable
type:string
bpfConnectTimeLoadBalancingEnabled:
description:'BPFConnectTimeLoadBalancingEnabled when in BPF mode,
controls whether Felix installs the connection-time load balancer. The
connect-time load balancer is required for the host to be able to
reach Kubernetes services and it improves the performance of pod-to-service
connections. The only reason to disable it is for debugging purposes. [Default:
true]'
type:boolean
bpfDataIfacePattern:
description:BPFDataIfacePattern is a regular expression that controls
which interfaces Felix should attach BPF programs to in order to
catch traffic to/from the network. This needs to match the interfaces
that Calico workload traffic flows over as well as any interfaces
that handle incoming traffic to nodeports and services from outside
the cluster. It should not match the workload interfaces (usually
named cali...).
type:string
bpfDisableUnprivileged:
description:'BPFDisableUnprivileged, if enabled, Felix sets the kernel.unprivileged_bpf_disabled
sysctl to disable unprivileged use of BPF. This ensures that unprivileged
users cannot access Calico''s BPF maps and cannot insert their own
BPF programs to interfere with Calico''s. [Default:true]'
type:boolean
bpfEnabled:
description:'BPFEnabled, if enabled Felix will use the BPF dataplane.
[Default:false]'
type:boolean
bpfExternalServiceMode:
description:'BPFExternalServiceMode in BPF mode, controls how connections
from outside the cluster to services (node ports and cluster IPs)
are forwarded to remote workloads. If set to "Tunnel" then both
request and response traffic is tunneled to the remote node. If
set to "DSR", the request traffic is tunneled but the response traffic
is sent directly from the remote node. In "DSR" mode, the remote
node appears to use the IP of the ingress node; this requires a
description:'UsageReportingEnabled reports anonymous Calico version
number and cluster size to projectcalico.org. Logs warnings returned
by the usage server. For example, if a significant security vulnerability
has been discovered in the version of Calico being used. [Default:
true]'
type:boolean
usageReportingInitialDelay:
description:'UsageReportingInitialDelay controls the minimum delay
before Felix makes a report. [Default:300s]'
type:string
usageReportingInterval:
description:'UsageReportingInterval controls the interval at which
Felix makes reports. [Default:86400s]'
type:string
useInternalDataplaneDriver:
type:boolean
vxlanEnabled:
type:boolean
vxlanMTU:
description:'VXLANMTU is the MTU to set on the tunnel device. See
Configuring MTU [Default:1440]'
type:integer
vxlanPort:
type:integer
vxlanVNI:
type:integer
wireguardEnabled:
description:'WireguardEnabled controls whether Wireguard is enabled.
[Default:false]'
type:boolean
wireguardInterfaceName:
description:'WireguardInterfaceName specifies the name to use for
the Wireguard interface. [Default:wg.calico]'
type:string
wireguardListeningPort:
description:'WireguardListeningPort controls the listening port used
by Wireguard. [Default:51820]'
type:integer
wireguardMTU:
description:'WireguardMTU controls the MTU on the Wireguard interface.
See Configuring MTU [Default:1420]'
type:integer
wireguardRoutingRulePriority:
description:'WireguardRoutingRulePriority controls the priority value
to use for the Wireguard routing rule. [Default:99]'
type:integer
xdpEnabled:
description:'XDPEnabled enables XDP acceleration for suitable untracked
incoming deny rules. [Default:true]'
type:boolean
xdpRefreshInterval:
description:'XDPRefreshInterval is the period at which Felix re-checks
all XDP state to ensure that no other process has accidentally broken
Calico''s BPF maps or attached programs. Set to 0 to disable XDP
refresh. [Default:90s]'
type:string
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:globalnetworkpolicies.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:GlobalNetworkPolicy
listKind:GlobalNetworkPolicyList
plural:globalnetworkpolicies
singular:globalnetworkpolicy
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
properties:
applyOnForward:
description:ApplyOnForward indicates to apply the rules in this policy
onforward traffic.
type:boolean
doNotTrack:
description:DoNotTrack indicates whether packets matched by the rules
in this policy should go through the data plane's connection tracking,
such as Linux conntrack. If True, the rules in this policy are
applied before any data plane connection tracking, and packets allowed
by this policy are marked as not to be tracked.
type:boolean
egress:
description:The ordered set of egress rules. Each rule contains
a set of packet match criteria and a corresponding action to apply.
items:
description:"A Rule encapsulates a set of match criteria and an
action. Both selector-based security Policy and security Profiles
reference rules - separated out as a list of rules for both ingress
and egress packet matching. \n Each positive match criteria has
a negated version, prefixed with \"Not\". All the match criteria
within a rule must be satisfied for a packet to match. A single
rule can contain the positive and negative version of a match
and both must be satisfied for the rule to match."
properties:
action:
type:string
destination:
description:Destination contains the match criteria that apply
to destination entity.
properties:
namespaceSelector:
description:"NamespaceSelector is an optional field that
contains a selector expression. Only traffic that originates
from (or terminates at) endpoints within the selected
namespaces will be matched. When both NamespaceSelector
== \"prod\" \ttype in {\"frontend\", \"backend\"} \tdeployment !=
\"dev\" \t! has(label_name)"
type:string
serviceAccountSelector:
description:ServiceAccountSelector is an optional field for an expression
used to select a pod based on service accounts.
type:string
types:
description:"Types indicates whether this policy applies to ingress,
or to egress, or to both. When not explicitly specified (and so
the value on creation is empty or nil), Calico defaults Types according
to what Ingress and Egress rules are present in the policy. The
default is:\n - [ PolicyTypeIngress ], if there are no Egress rules
(including the case where there are also no Ingress rules) \n
- [PolicyTypeEgress ], if there are Egress rules but no Ingress
rules \n - [ PolicyTypeIngress, PolicyTypeEgress ], if there are
both Ingress and Egress rules. \n When the policy is read back again,
Types will always be one of these values, never empty or nil."
items:
description:PolicyType enumerates the possible values of the PolicySpec
Types field.
type:string
type:array
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:globalnetworksets.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:GlobalNetworkSet
listKind:GlobalNetworkSetList
plural:globalnetworksets
singular:globalnetworkset
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
description:GlobalNetworkSet contains a set of arbitrary IP sub-networks/CIDRs
that share labels to allow rules to refer to them via selectors. The labels
of GlobalNetworkSet are not namespaced.
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:GlobalNetworkSetSpec contains the specification for a NetworkSet
resource.
properties:
nets:
description:The list of IP networks that belong to this set.
items:
type:string
type:array
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:hostendpoints.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:HostEndpoint
listKind:HostEndpointList
plural:hostendpoints
singular:hostendpoint
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:HostEndpointSpec contains the specification for a HostEndpoint
resource.
properties:
expectedIPs:
description:"The expected IP addresses (IPv4 and IPv6) of the endpoint.
If \"InterfaceName\" is not present, Calico will look for an interface
matching any of the IPs in the list and apply policy to that. Note:
\tWhen using the selector match criteria in an ingress or egress
security Policy \tor Profile, Calico converts the selector into
a set of IP addresses. For host \tendpoints, the ExpectedIPs field
is used for that purpose. (If only the interface \tname is specified,
Calico does not learn the IPs of the interface for use in match
\tcriteria.)"
items:
type:string
type:array
interfaceName:
description:"Either \"*\",or the name of a specific Linux interface
to apply policy to; or empty. \"*\" indicates that this HostEndpoint
governs all traffic to, from or through the default network namespace
of the host named by the \"Node\" field; entering and leaving that
namespace via any interface, including those from/to non-host-networked
local workloads. \n If InterfaceName is not \"*\", this HostEndpoint
only governs traffic that enters or leaves the host through the
specific interface named by InterfaceName, or - when InterfaceName
is empty - through the specific interface that has one of the IPs
in ExpectedIPs. Therefore, when InterfaceName is empty, at least
one expected IP must be specified. Only external interfaces (such
as \"eth0\") are supported here; it isn't possible for a HostEndpoint
to protect traffic through a specific local workload interface.
\n Note:Only some kinds of policy are implemented for \"*\" HostEndpoints;
initially just pre-DNAT policy. Please check Calico documentation
for the latest position."
type:string
node:
description:The node name identifying the Calico node instance.
type:string
ports:
description:Ports contains the endpoint's named ports, which may
be referenced in security policy rules.
items:
properties:
name:
type:string
port:
type:integer
protocol:
anyOf:
- type:integer
- type:string
pattern:^.*
x-kubernetes-int-or-string:true
required:
- name
- port
- protocol
type:object
type:array
profiles:
description:A list of identifiers of security Profile objects that
apply to this endpoint. Each profile is applied in the order that
they appear in this list. Profile rules are applied after the selector-based
security policy.
items:
type:string
type:array
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:ipamblocks.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:IPAMBlock
listKind:IPAMBlockList
plural:ipamblocks
singular:ipamblock
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:IPAMBlockSpec contains the specification for an IPAMBlock
resource.
properties:
affinity:
type:string
allocations:
items:
type:integer
# TODO: This nullable is manually added in. We should update controller-gen
# to handle []*int properly itself.
nullable:true
type:array
attributes:
items:
properties:
handle_id:
type:string
secondary:
additionalProperties:
type:string
type:object
type:object
type:array
cidr:
type:string
deleted:
type:boolean
strictAffinity:
type:boolean
unallocated:
items:
type:integer
type:array
required:
- allocations
- attributes
- cidr
- strictAffinity
- unallocated
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:ipamconfigs.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:IPAMConfig
listKind:IPAMConfigList
plural:ipamconfigs
singular:ipamconfig
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:IPAMConfigSpec contains the specification for an IPAMConfig
resource.
properties:
autoAllocateBlocks:
type:boolean
maxBlocksPerHost:
description:MaxBlocksPerHost, if non-zero, is the max number of blocks
that can be affine to each host.
type:integer
strictAffinity:
type:boolean
required:
- autoAllocateBlocks
- strictAffinity
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:ipamhandles.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:IPAMHandle
listKind:IPAMHandleList
plural:ipamhandles
singular:ipamhandle
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:IPAMHandleSpec contains the specification for an IPAMHandle
resource.
properties:
block:
additionalProperties:
type:integer
type:object
deleted:
type:boolean
handleID:
type:string
required:
- block
- handleID
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:ippools.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:IPPool
listKind:IPPoolList
plural:ippools
singular:ippool
scope:Cluster
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:IPPoolSpec contains the specification for an IPPool resource.
properties:
blockSize:
description:The block size to use for IP address assignments from
this pool. Defaults to 26 for IPv4 and 112 for IPv6.
type:integer
cidr:
description:The pool CIDR.
type:string
disabled:
description:When disabled is true, Calico IPAM will not assign addresses
from this pool.
type:boolean
ipip:
description: 'Deprecated:this field is only used for APIv1 backwards
compatibility. Setting this field is not allowed, this field is
for internal use only.'
properties:
enabled:
description:When enabled is true, ipip tunneling will be used
to deliver packets to destinations within this pool.
type:boolean
mode:
description:The IPIP mode. This can be one of "always" or "cross-subnet". A
mode of "always" will also use IPIP tunneling for routing to
destination IP addresses within this pool. A mode of "cross-subnet"
will only use IPIP tunneling when the destination node is on
a different subnet to the originating node. The default value
(if not specified) is "always".
type:string
type:object
ipipMode:
description:Contains configuration for IPIP tunneling for this pool.
If not specified, then this is defaulted to "Never" (i.e. IPIP tunneling
is disabled).
type:string
nat-outgoing:
description: 'Deprecated:this field is only used for APIv1 backwards
compatibility. Setting this field is not allowed, this field is
for internal use only.'
type:boolean
natOutgoing:
description:When nat-outgoing is true, packets sent from Calico networked
containers in this pool to destinations outside of this pool will
be masqueraded.
type:boolean
nodeSelector:
description:Allows IPPool to allocate for a specific node by label
selector.
type:string
vxlanMode:
description:Contains configuration for VXLAN tunneling for this pool.
If not specified, then this is defaulted to "Never" (i.e. VXLAN
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:KubeControllersConfigurationSpec contains the values of the
Kubernetes controllers configuration.
properties:
controllers:
description:Controllers enables and configures individual Kubernetes
controllers
properties:
namespace:
description:Namespace enables and configures the namespace controller.
Enabled by default, set to nil to disable.
properties:
reconcilerPeriod:
description:'ReconcilerPeriod is the period to perform reconciliation
with the Calico datastore. [Default:5m]'
type:string
type:object
node:
description:Node enables and configures the node controller.
Enabled by default, set to nil to disable.
properties:
hostEndpoint:
description:HostEndpoint controls syncing nodes to host endpoints.
Disabled by default, set to nil to disable.
properties:
autoCreate:
description:'AutoCreate enables automatic creation of
host endpoints for every node. [Default:Disabled]'
description:'ReconcilerPeriod is the period to perform
reconciliation with the Calico datastore. [Default:
5m]'
type:string
syncLabels:
description:'SyncLabels controls whether to copy Kubernetes
node labels to Calico nodes. [Default:Enabled]'
type:string
type:object
policy:
description:Policy enables and configures the policy controller.
Enabled by default, set to nil to disable.
properties:
reconcilerPeriod:
description:'ReconcilerPeriod is the period to perform
reconciliation with the Calico datastore. [Default:
5m]'
type:string
type:object
serviceAccount:
description:ServiceAccount enables and configures the service
account controller. Enabled by default, set to nil to disable.
properties:
reconcilerPeriod:
description:'ReconcilerPeriod is the period to perform
reconciliation with the Calico datastore. [Default:
5m]'
type:string
type:object
workloadEndpoint:
description:WorkloadEndpoint enables and configures the workload
endpoint controller. Enabled by default, set to nil to disable.
properties:
reconcilerPeriod:
description:'ReconcilerPeriod is the period to perform
reconciliation with the Calico datastore. [Default:
5m]'
type:string
type:object
type:object
etcdV3CompactionPeriod:
description:'EtcdV3CompactionPeriod is the period between etcdv3
compaction requests. Set to 0 to disable. [Default:10m]'
type:string
healthChecks:
description:'HealthChecks enables or disables support for health
checks [Default:Enabled]'
type:string
logSeverityScreen:
description:'LogSeverityScreen is the log severity above which
logs are sent to the stdout. [Default:Info]'
type:string
prometheusMetricsPort:
description:'PrometheusMetricsPort is the TCP port that the Prometheus
metrics server should bind to. Set to 0 to disable. [Default:
9094]'
type:integer
required:
- controllers
type:object
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:networkpolicies.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:NetworkPolicy
listKind:NetworkPolicyList
plural:networkpolicies
singular:networkpolicy
scope:Namespaced
versions:
- name:v1
schema:
openAPIV3Schema:
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
properties:
egress:
description:The ordered set of egress rules. Each rule contains
a set of packet match criteria and a corresponding action to apply.
items:
description:"A Rule encapsulates a set of match criteria and an
action. Both selector-based security Policy and security Profiles
reference rules - separated out as a list of rules for both ingress
and egress packet matching. \n Each positive match criteria has
a negated version, prefixed with \"Not\". All the match criteria
within a rule must be satisfied for a packet to match. A single
rule can contain the positive and negative version of a match
and both must be satisfied for the rule to match."
properties:
action:
type:string
destination:
description:Destination contains the match criteria that apply
to destination entity.
properties:
namespaceSelector:
description:"NamespaceSelector is an optional field that
contains a selector expression. Only traffic that originates
from (or terminates at) endpoints within the selected
namespaces will be matched. When both NamespaceSelector
== \"prod\" \ttype in {\"frontend\", \"backend\"} \tdeployment !=
\"dev\" \t! has(label_name)"
type:string
serviceAccountSelector:
description:ServiceAccountSelector is an optional field for an expression
used to select a pod based on service accounts.
type:string
types:
description:"Types indicates whether this policy applies to ingress,
or to egress, or to both. When not explicitly specified (and so
the value on creation is empty or nil), Calico defaults Types according
to what Ingress and Egress are present in the policy. The default
is:\n - [ PolicyTypeIngress ], if there are no Egress rules (including
the case where there are also no Ingress rules) \n - [ PolicyTypeEgress
],if there are Egress rules but no Ingress rules \n - [ PolicyTypeIngress,
PolicyTypeEgress ], if there are both Ingress and Egress rules.
\n When the policy is read back again, Types will always be one
of these values, never empty or nil."
items:
description:PolicyType enumerates the possible values of the PolicySpec
Types field.
type:string
type:array
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
name:networksets.crd.projectcalico.org
spec:
group:crd.projectcalico.org
names:
kind:NetworkSet
listKind:NetworkSetList
plural:networksets
singular:networkset
scope:Namespaced
versions:
- name:v1
schema:
openAPIV3Schema:
description:NetworkSet is the Namespaced-equivalent of the GlobalNetworkSet.
properties:
apiVersion:
description:'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type:string
kind:
description:'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info:https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type:string
metadata:
type:object
spec:
description:NetworkSetSpec contains the specification for a NetworkSet
resource.
properties:
nets:
description:The list of IP networks that belong to this set.