Documentation ¶
Overview ¶
Package v1alpha1 contains API Schema definitions for the v1alpha1 API group +kubebuilder:object:generate=true +groupName=kuadrant.io
Index ¶
- Constants
- Variables
- type ConditionReason
- type ConditionType
- type DNSRecord
- func (in *DNSRecord) DeepCopy() *DNSRecord
- func (in *DNSRecord) DeepCopyInto(out *DNSRecord)
- func (in *DNSRecord) DeepCopyObject() runtime.Object
- func (s *DNSRecord) GetProviderRef() ProviderRef
- func (s *DNSRecord) GetUIDHash() string
- func (s *DNSRecord) HasDNSZoneAssigned() bool
- func (s *DNSRecord) HasOwnerIDAssigned() bool
- func (s *DNSRecord) Validate() error
- type DNSRecordList
- type DNSRecordSpec
- type DNSRecordStatus
- type DNSRecordType
- type HealthCheckSpec
- type HealthCheckStatus
- type HealthCheckStatusProbe
- type HealthProtocol
- type ProviderAccessor
- type ProviderRef
Constants ¶
const ( // CNAMERecordType is an RFC 1035 CNAME record. CNAMERecordType DNSRecordType = "CNAME" // ARecordType is an RFC 1035 A record. ARecordType DNSRecordType = "A" // NSRecordType is a name server record. NSRecordType DNSRecordType = "NS" DefaultGeo string = "default" )
const ( ProviderSpecificWeight = "weight" ProviderSpecificGeoCode = "geo-code" )
const ( // SecretTypeKuadrantAWS contains data needed for aws(route53) authentication and configuration. // // Required fields: // - Secret.Data["AWS_ACCESS_KEY_ID"] - aws access key id // - Secret.Data["AWS_SECRET_ACCESS_KEY"] - aws secret access key SecretTypeKuadrantAWS corev1.SecretType = "kuadrant.io/aws" // AWSAccessKeyIDKey is the key of the required AWS access key id for SecretTypeKuadrantAWS provider secrets AWSAccessKeyIDKey = "AWS_ACCESS_KEY_ID" // AWSSecretAccessKeyKey is the key of the required AWS secret access key for SecretTypeKuadrantAWS provider secrets AWSSecretAccessKeyKey = "AWS_SECRET_ACCESS_KEY" // AWSRegionKey is the key of the optional region for SecretTypeKuadrantAWS provider secrets AWSRegionKey = "AWS_REGION" // SecretTypeKuadrantGCP contains data needed for gcp(google cloud dns) authentication and configuration. // // Required fields: // - Secret.Data["GOOGLE"] - json formatted google credentials string // - Secret.Data["PROJECT_ID"] - google project id SecretTypeKuadrantGCP corev1.SecretType = "kuadrant.io/gcp" // GoogleJsonKey is the key of the required json formatted credentials string for SecretTypeKuadrantGCP provider secrets GoogleJsonKey = "GOOGLE" // GoogleProjectIDKey is the key of the required project id for SecretTypeKuadrantGCP provider secrets GoogleProjectIDKey = "PROJECT_ID" // SecretTypeKuadrantAzure contains data needed for azure authentication and configuration. // // Required fields: // - Secret.Data["azure.json"] - json formatted azure credentials string SecretTypeKuadrantAzure corev1.SecretType = "kuadrant.io/azure" // AzureJsonKey is the key of the required data for SecretTypeDockerConfigJson provider secrets AzureJsonKey = "azure.json" // SecretTypeKuadrantInmemory contains data needed for inmemory configuration. SecretTypeKuadrantInmemory corev1.SecretType = "kuadrant.io/inmemory" // InmemInitZonesKey is the key of the optional comma separated list of zone names to initialise in the SecretTypeKuadrantInmemory provider secrets InmemInitZonesKey = "INMEM_INIT_ZONES" )
const WildcardPrefix = "*."
Variables ¶
var ( // GroupVersion is group version used to register these objects GroupVersion = schema.GroupVersion{Group: "kuadrant.io", Version: "v1alpha1"} // SchemeBuilder is used to add go types to the GroupVersionKind scheme SchemeBuilder = &scheme.Builder{GroupVersion: GroupVersion} // AddToScheme adds the types in this group-version to the given scheme. AddToScheme = SchemeBuilder.AddToScheme )
Functions ¶
This section is empty.
Types ¶
type ConditionReason ¶ added in v0.2.0
type ConditionReason string
type ConditionType ¶ added in v0.2.0
type ConditionType string
const ConditionTypeReady ConditionType = "Ready"
type DNSRecord ¶
type DNSRecord struct { metav1.TypeMeta `json:",inline"` metav1.ObjectMeta `json:"metadata,omitempty"` Spec DNSRecordSpec `json:"spec,omitempty"` Status DNSRecordStatus `json:"status,omitempty"` }
DNSRecord is the Schema for the dnsrecords API
func (*DNSRecord) DeepCopy ¶
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DNSRecord.
func (*DNSRecord) DeepCopyInto ¶
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*DNSRecord) DeepCopyObject ¶
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
func (*DNSRecord) GetProviderRef ¶ added in v0.5.0
func (s *DNSRecord) GetProviderRef() ProviderRef
func (*DNSRecord) GetUIDHash ¶ added in v0.4.1
GetUIDHash returns a hash of the current records UID with a fixed length of 8.
func (*DNSRecord) HasDNSZoneAssigned ¶ added in v0.5.0
func (*DNSRecord) HasOwnerIDAssigned ¶ added in v0.5.0
type DNSRecordList ¶
type DNSRecordList struct { metav1.TypeMeta `json:",inline"` metav1.ListMeta `json:"metadata,omitempty"` Items []DNSRecord `json:"items"` }
DNSRecordList contains a list of DNSRecord
func (*DNSRecordList) DeepCopy ¶
func (in *DNSRecordList) DeepCopy() *DNSRecordList
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DNSRecordList.
func (*DNSRecordList) DeepCopyInto ¶
func (in *DNSRecordList) DeepCopyInto(out *DNSRecordList)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*DNSRecordList) DeepCopyObject ¶
func (in *DNSRecordList) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
type DNSRecordSpec ¶
type DNSRecordSpec struct { // ownerID is a unique string used to identify the owner of this record. // If unset or set to an empty string the record UID will be used. // +kubebuilder:validation:Optional // +kubebuilder:validation:XValidation:rule="self == oldSelf",message="OwnerID is immutable" // +kubebuilder:validation:MinLength=6 // +kubebuilder:validation:MaxLength=36 OwnerID string `json:"ownerID,omitempty"` // rootHost is the single root for all endpoints in a DNSRecord. // it is expected all defined endpoints are children of or equal to this rootHost // Must contain at least two groups of valid URL characters separated by a "." // +kubebuilder:validation:MinLength=1 // +kubebuilder:validation:MaxLength=255 // +kubebuilder:validation:Pattern=`^(?:[\w\-.~:\/?#[\]@!$&'()*+,;=]+)\.(?:[\w\-.~:\/?#[\]@!$&'()*+,;=]+)$` RootHost string `json:"rootHost"` // providerRef is a reference to a provider secret. ProviderRef ProviderRef `json:"providerRef"` // endpoints is a list of endpoints that will be published into the dns provider. // +kubebuilder:validation:MinItems=1 // +optional Endpoints []*externaldns.Endpoint `json:"endpoints,omitempty"` // +optional HealthCheck *HealthCheckSpec `json:"healthCheck,omitempty"` }
DNSRecordSpec defines the desired state of DNSRecord +kubebuilder:validation:XValidation:rule="!has(oldSelf.ownerID) || has(self.ownerID)", message="OwnerID can't be unset if it was previously set" +kubebuilder:validation:XValidation:rule="has(oldSelf.ownerID) || !has(self.ownerID)", message="OwnerID can't be set if it was previously unset"
func (*DNSRecordSpec) DeepCopy ¶
func (in *DNSRecordSpec) DeepCopy() *DNSRecordSpec
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DNSRecordSpec.
func (*DNSRecordSpec) DeepCopyInto ¶
func (in *DNSRecordSpec) DeepCopyInto(out *DNSRecordSpec)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type DNSRecordStatus ¶
type DNSRecordStatus struct { // conditions are any conditions associated with the record in the dns provider. // // If publishing the record fails, the "Failed" condition will be set with a // reason and message describing the cause of the failure. Conditions []metav1.Condition `json:"conditions,omitempty"` // observedGeneration is the most recently observed generation of the DNSRecord. // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` // QueuedAt is a time when DNS record was received for the reconciliation QueuedAt metav1.Time `json:"queuedAt,omitempty"` // QueuedFor is a time when we expect a DNS record to be reconciled again QueuedFor metav1.Time `json:"queuedFor,omitempty"` // ValidFor indicates duration since the last reconciliation we consider data in the record to be valid ValidFor string `json:"validFor,omitempty"` // WriteCounter represent a number of consecutive write attempts on the same generation of the record. // It is being reset to 0 when the generation changes or there are no changes to write. WriteCounter int64 `json:"writeCounter,omitempty"` // endpoints are the last endpoints that were successfully published to the provider zone Endpoints []*externaldns.Endpoint `json:"endpoints,omitempty"` HealthCheck *HealthCheckStatus `json:"healthCheck,omitempty"` // ownerID is a unique string used to identify the owner of this record. OwnerID string `json:"ownerID,omitempty"` // DomainOwners is a list of all the owners working against the root domain of this record DomainOwners []string `json:"domainOwners,omitempty"` // zoneID is the provider specific id to which this dns record is publishing endpoints ZoneID string `json:"zoneID,omitempty"` // zoneDomainName is the domain name of the zone that the dns record is publishing endpoints ZoneDomainName string `json:"zoneDomainName,omitempty"` }
DNSRecordStatus defines the observed state of DNSRecord
func (*DNSRecordStatus) DeepCopy ¶
func (in *DNSRecordStatus) DeepCopy() *DNSRecordStatus
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DNSRecordStatus.
func (*DNSRecordStatus) DeepCopyInto ¶
func (in *DNSRecordStatus) DeepCopyInto(out *DNSRecordStatus)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type DNSRecordType ¶
type DNSRecordType string
DNSRecordType is a DNS resource record type. +kubebuilder:validation:Enum=CNAME;A
type HealthCheckSpec ¶ added in v0.2.0
type HealthCheckSpec struct { // Endpoint is the path to append to the host to reach the expected health check. // Must start with "?" or "/", contain only valid URL characters and end with alphanumeric char or "/". For example "/" or "/healthz" are common // +kubebuilder:validation:Pattern=`^(?:\?|\/)[\w\-.~:\/?#\[\]@!$&'()*+,;=]+(?:[a-zA-Z0-9]|\/){1}$` Endpoint string `json:"endpoint,omitempty"` // Port to connect to the host on. Must be either 80, 443 or 1024-49151 // +kubebuilder:validation:XValidation:rule="self in [80, 443] || (self >= 1024 && self <= 49151)",message="Only ports 80, 443, 1024-49151 are allowed" Port *int `json:"port,omitempty"` // Protocol to use when connecting to the host, valid values are "HTTP" or "HTTPS" // +kubebuilder:validation:XValidation:rule="self in ['HTTP','HTTPS']",message="Only HTTP or HTTPS protocols are allowed" Protocol *HealthProtocol `json:"protocol,omitempty"` // FailureThreshold is a limit of consecutive failures that must occur for a host to be considered unhealthy // +kubebuilder:validation:XValidation:rule="self > 0",message="Failure threshold must be greater than 0" FailureThreshold *int `json:"failureThreshold,omitempty"` }
HealthCheckSpec configures health checks in the DNS provider. By default this health check will be applied to each unique DNS A Record for the listeners assigned to the target gateway
func (*HealthCheckSpec) DeepCopy ¶ added in v0.2.0
func (in *HealthCheckSpec) DeepCopy() *HealthCheckSpec
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HealthCheckSpec.
func (*HealthCheckSpec) DeepCopyInto ¶ added in v0.2.0
func (in *HealthCheckSpec) DeepCopyInto(out *HealthCheckSpec)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HealthCheckStatus ¶ added in v0.2.0
type HealthCheckStatus struct { Conditions []metav1.Condition `json:"conditions,omitempty"` Probes []HealthCheckStatusProbe `json:"probes,omitempty"` }
func (*HealthCheckStatus) DeepCopy ¶ added in v0.2.0
func (in *HealthCheckStatus) DeepCopy() *HealthCheckStatus
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HealthCheckStatus.
func (*HealthCheckStatus) DeepCopyInto ¶ added in v0.2.0
func (in *HealthCheckStatus) DeepCopyInto(out *HealthCheckStatus)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HealthCheckStatusProbe ¶ added in v0.2.0
type HealthCheckStatusProbe struct { ID string `json:"id"` IPAddress string `json:"ipAddress"` Host string `json:"host"` Synced bool `json:"synced,omitempty"` Conditions []metav1.Condition `json:"conditions,omitempty"` }
func (*HealthCheckStatusProbe) DeepCopy ¶ added in v0.2.0
func (in *HealthCheckStatusProbe) DeepCopy() *HealthCheckStatusProbe
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HealthCheckStatusProbe.
func (*HealthCheckStatusProbe) DeepCopyInto ¶ added in v0.2.0
func (in *HealthCheckStatusProbe) DeepCopyInto(out *HealthCheckStatusProbe)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HealthProtocol ¶
type HealthProtocol string
const HttpProtocol HealthProtocol = "HTTP"
const HttpsProtocol HealthProtocol = "HTTPS"
type ProviderAccessor ¶
type ProviderAccessor interface { GetNamespace() string GetProviderRef() ProviderRef }
+kubebuilder:object:generate=false
type ProviderRef ¶
type ProviderRef struct { // +kubebuilder:validation:MinLength=1 Name string `json:"name"` }
func (*ProviderRef) DeepCopy ¶
func (in *ProviderRef) DeepCopy() *ProviderRef
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ProviderRef.
func (*ProviderRef) DeepCopyInto ¶
func (in *ProviderRef) DeepCopyInto(out *ProviderRef)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.