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:
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.
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
required:
- asNumber
- peerIP
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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.
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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
and Selector are defined on the same rule, then only workload
endpoints that are matched by both selectors will be selected
by the rule. \n For NetworkPolicy, an empty NamespaceSelector
implies that the Selector is limited to selecting only
workload endpoints in the same namespace as the NetworkPolicy.
\n For NetworkPolicy, `global()` NamespaceSelector implies
that the Selector is limited to selecting only GlobalNetworkSet
or HostEndpoint. \n For GlobalNetworkPolicy, an empty
NamespaceSelector implies the Selector applies to workload
endpoints across all namespaces."
type:string
nets:
description:Nets is an optional field that restricts the
rule to only apply to traffic that originates from (or
terminates at) IP addresses in any of the given subnets.
items:
type:string
type:array
notNets:
description:NotNets is the negated version of the Nets
field.
items:
type:string
type:array
notPorts:
description:NotPorts is the negated version of the Ports
field. Since only some protocols have ports, if any ports
are specified it requires the Protocol match in the Rule
to be set to "TCP" or "UDP".
items:
anyOf:
- type:integer
- type:string
pattern:^.*
x-kubernetes-int-or-string:true
type:array
notSelector:
description:NotSelector is the negated version of the Selector
field. See Selector field for subtleties with negated
selectors.
type:string
ports:
description:"Ports is an optional field that restricts
the rule to only apply to traffic that has a source (destination)
port that matches one of these ranges/values. This value
is a list of integers or strings that represent ranges
of ports. \n Since only some protocols have ports, if
any ports are specified it requires the Protocol match
in the Rule to be set to \"TCP\" or \"UDP\"."
items:
anyOf:
- type:integer
- type:string
pattern:^.*
x-kubernetes-int-or-string:true
type:array
selector:
description:"Selector is an optional field that contains
a selector expression (see Policy for sample syntax).
\ Only traffic that originates from (terminates at) endpoints
matching the selector will be matched. \n Note that:in
addition to the negated version of the Selector (see NotSelector
below), the selector expression syntax itself supports
negation. The two types of negation are subtly different.
One negates the set of matched endpoints, the other negates
the whole match:\n \tSelector = \"!has(my_label)\" matches
packets that are from other Calico-controlled \tendpoints
that do not have the label “my_label”. \n \tNotSelector
= \"has(my_label)\" matches packets that are not from
Calico-controlled \tendpoints that do have the label “my_label”.
\n The effect is that the latter will accept packets from
non-Calico sources whereas the former is limited to packets
from Calico-controlled endpoints."
type:string
serviceAccounts:
description:ServiceAccounts is an optional field that restricts
the rule to only apply to traffic that originates from
(or terminates at) a pod running as a matching service
account.
properties:
names:
description:Names is an optional field that restricts
the rule to only apply to traffic that originates
from (or terminates at) a pod running as a service
account whose name is in the list.
items:
type:string
type:array
selector:
description:Selector is an optional field that restricts
the rule to only apply to traffic that originates
from (or terminates at) a pod running as a service
account that matches the given label selector. If
both Names and Selector are specified then they are
AND'ed.
type:string
type:object
type:object
http:
description:HTTP contains match criteria that apply to HTTP
requests.
properties:
methods:
description:Methods is an optional field that restricts
the rule to apply only to HTTP requests that use one of
the listed HTTP Methods (e.g. GET, PUT, etc.) Multiple
methods are OR'd together.
items:
type:string
type:array
paths:
description:'Paths is an optional field that restricts
the rule to apply to HTTP requests that use one of the
listed HTTP Paths. Multiple paths are OR''d together.
e.g: - exact: /foo - prefix: /bar NOTE:Each entry may
ONLY specify either a `exact` or a `prefix` match. The
validator will check for it.'
items:
description:'HTTPPath specifies an HTTP path to match.
It may be either of the form: exact: <path>:which matches
the path exactly or prefix: <path-prefix>:which matches
the path prefix'
properties:
exact:
type:string
prefix:
type:string
type:object
type:array
type:object
icmp:
description:ICMP is an optional field that restricts the rule
to apply to a specific type and code of ICMP traffic. This
should only be specified if the Protocol field is set to "ICMP"
or "ICMPv6".
properties:
code:
description:Match on a specific ICMP code. If specified,
the Type value must also be specified. This is a technical
limitation imposed by the kernel’s iptables firewall,
which Calico uses to enforce the rule.
type:integer
type:
description:Match on a specific ICMP type. For example
a value of 8 refers to ICMP Echo Request (i.e. pings).
type:integer
type:object
ipVersion:
description:IPVersion is an optional field that restricts the
rule to only match a specific IP version.
type:integer
metadata:
description:Metadata contains additional information for this
rule
properties:
annotations:
additionalProperties:
type:string
description:Annotations is a set of key value pairs that
give extra information about the rule
type:object
type:object
notICMP:
description:NotICMP is the negated version of the ICMP field.
properties:
code:
description:Match on a specific ICMP code. If specified,
the Type value must also be specified. This is a technical
limitation imposed by the kernel’s iptables firewall,
which Calico uses to enforce the rule.
type:integer
type:
description:Match on a specific ICMP type. For example
a value of 8 refers to ICMP Echo Request (i.e. pings).
type:integer
type:object
notProtocol:
anyOf:
- type:integer
- type:string
description:NotProtocol is the negated version of the Protocol
field.
pattern:^.*
x-kubernetes-int-or-string:true
protocol:
anyOf:
- type:integer
- type:string
description:"Protocol is an optional field that restricts the
rule to only apply to traffic of a specific IP protocol. Required
if any of the EntityRules contain Ports (because ports only
apply to certain protocols). \n Must be one of these string
== \"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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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
- deleted
- strictAffinity
- unallocated
type:object
type:object
served:true
storage:true
status:
acceptedNames:
kind:""
plural:""
conditions:[]
storedVersions:[]
---
---
apiVersion:apiextensions.k8s.io/v1
kind:CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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.
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]'
type:string
type:object
reconcilerPeriod:
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
required:
- controllers
type:object
status:
description:KubeControllersConfigurationStatus represents the status
of the configuration. It's useful for admins to be able to see the actual
config that was applied, which can be modified by environment variables
onthe kube-controllers process.
properties:
environmentVars:
additionalProperties:
type:string
description:EnvironmentVars contains the environment variables on
the kube-controllers that influenced the RunningConfig.
type:object
runningConfig:
description:RunningConfig contains the effective config that is running
in the kube-controllers pod, after merging the API resource with
any environment variables.
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.
of host endpoints for every node. [Default:Disabled]'
type:string
type:object
reconcilerPeriod:
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
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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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
and Selector are defined on the same rule, then only workload
endpoints that are matched by both selectors will be selected
by the rule. \n For NetworkPolicy, an empty NamespaceSelector
implies that the Selector is limited to selecting only
workload endpoints in the same namespace as the NetworkPolicy.
\n For NetworkPolicy, `global()` NamespaceSelector implies
that the Selector is limited to selecting only GlobalNetworkSet
or HostEndpoint. \n For GlobalNetworkPolicy, an empty
NamespaceSelector implies the Selector applies to workload
endpoints across all namespaces."
type:string
nets:
description:Nets is an optional field that restricts the
rule to only apply to traffic that originates from (or
terminates at) IP addresses in any of the given subnets.
items:
type:string
type:array
notNets:
description:NotNets is the negated version of the Nets
field.
items:
type:string
type:array
notPorts:
description:NotPorts is the negated version of the Ports
field. Since only some protocols have ports, if any ports
are specified it requires the Protocol match in the Rule
to be set to "TCP" or "UDP".
items:
anyOf:
- type:integer
- type:string
pattern:^.*
x-kubernetes-int-or-string:true
type:array
notSelector:
description:NotSelector is the negated version of the Selector
field. See Selector field for subtleties with negated
selectors.
type:string
ports:
description:"Ports is an optional field that restricts
the rule to only apply to traffic that has a source (destination)
port that matches one of these ranges/values. This value
is a list of integers or strings that represent ranges
of ports. \n Since only some protocols have ports, if
any ports are specified it requires the Protocol match
in the Rule to be set to \"TCP\" or \"UDP\"."
items:
anyOf:
- type:integer
- type:string
pattern:^.*
x-kubernetes-int-or-string:true
type:array
selector:
description:"Selector is an optional field that contains
a selector expression (see Policy for sample syntax).
\ Only traffic that originates from (terminates at) endpoints
matching the selector will be matched. \n Note that:in
addition to the negated version of the Selector (see NotSelector
below), the selector expression syntax itself supports
negation. The two types of negation are subtly different.
One negates the set of matched endpoints, the other negates
the whole match:\n \tSelector = \"!has(my_label)\" matches
packets that are from other Calico-controlled \tendpoints
that do not have the label “my_label”. \n \tNotSelector
= \"has(my_label)\" matches packets that are not from
Calico-controlled \tendpoints that do have the label “my_label”.
\n The effect is that the latter will accept packets from
non-Calico sources whereas the former is limited to packets
from Calico-controlled endpoints."
type:string
serviceAccounts:
description:ServiceAccounts is an optional field that restricts
the rule to only apply to traffic that originates from
(or terminates at) a pod running as a matching service
account.
properties:
names:
description:Names is an optional field that restricts
the rule to only apply to traffic that originates
from (or terminates at) a pod running as a service
account whose name is in the list.
items:
type:string
type:array
selector:
description:Selector is an optional field that restricts
the rule to only apply to traffic that originates
from (or terminates at) a pod running as a service
account that matches the given label selector. If
both Names and Selector are specified then they are
AND'ed.
type:string
type:object
type:object
http:
description:HTTP contains match criteria that apply to HTTP
requests.
properties:
methods:
description:Methods is an optional field that restricts
the rule to apply only to HTTP requests that use one of
the listed HTTP Methods (e.g. GET, PUT, etc.) Multiple
methods are OR'd together.
items:
type:string
type:array
paths:
description:'Paths is an optional field that restricts
the rule to apply to HTTP requests that use one of the
listed HTTP Paths. Multiple paths are OR''d together.
e.g: - exact: /foo - prefix: /bar NOTE:Each entry may
ONLY specify either a `exact` or a `prefix` match. The
validator will check for it.'
items:
description:'HTTPPath specifies an HTTP path to match.
It may be either of the form: exact: <path>:which matches
the path exactly or prefix: <path-prefix>:which matches
the path prefix'
properties:
exact:
type:string
prefix:
type:string
type:object
type:array
type:object
icmp:
description:ICMP is an optional field that restricts the rule
to apply to a specific type and code of ICMP traffic. This
should only be specified if the Protocol field is set to "ICMP"
or "ICMPv6".
properties:
code:
description:Match on a specific ICMP code. If specified,
the Type value must also be specified. This is a technical
limitation imposed by the kernel’s iptables firewall,
which Calico uses to enforce the rule.
type:integer
type:
description:Match on a specific ICMP type. For example
a value of 8 refers to ICMP Echo Request (i.e. pings).
type:integer
type:object
ipVersion:
description:IPVersion is an optional field that restricts the
rule to only match a specific IP version.
type:integer
metadata:
description:Metadata contains additional information for this
rule
properties:
annotations:
additionalProperties:
type:string
description:Annotations is a set of key value pairs that
give extra information about the rule
type:object
type:object
notICMP:
description:NotICMP is the negated version of the ICMP field.
properties:
code:
description:Match on a specific ICMP code. If specified,
the Type value must also be specified. This is a technical
limitation imposed by the kernel’s iptables firewall,
which Calico uses to enforce the rule.
type:integer
type:
description:Match on a specific ICMP type. For example
a value of 8 refers to ICMP Echo Request (i.e. pings).
type:integer
type:object
notProtocol:
anyOf:
- type:integer
- type:string
description:NotProtocol is the negated version of the Protocol
field.
pattern:^.*
x-kubernetes-int-or-string:true
protocol:
anyOf:
- type:integer
- type:string
description:"Protocol is an optional field that restricts the
rule to only apply to traffic of a specific IP protocol. Required
if any of the EntityRules contain Ports (because ports only
apply to certain protocols). \n Must be one of these string
== \"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:
annotations:
controller-gen.kubebuilder.io/version:(devel)
creationTimestamp:null
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.