mirror of
https://github.com/kubernetes-sigs/external-dns.git
synced 2025-08-06 01:26:59 +02:00
* Make suitableType() be Endpoint method With this change it becomes possible to work with endpoint of empty type in packages other than "provider". Also it seems logical for a smart property getter without side effects to be a method rather than a function in different package * Make plan computation work correctly with multi-target domains * fix drawing * drop comments * fix boilerplate header * fix comment * fix the bug with empty map * rework registry to support random lables * serialize->serializeLabel function rename * golint for err variable naming * add additional test * add tests for current case where one resource can generate multiple endpoints * make labels have its own type, add serialization as a method * add comment for exported error * use greater rather than not equal zero * update changelog
74 lines
2.1 KiB
Go
74 lines
2.1 KiB
Go
/*
|
|
Copyright 2017 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package endpoint
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
)
|
|
|
|
const (
|
|
// RecordTypeA is a RecordType enum value
|
|
RecordTypeA = "A"
|
|
// RecordTypeCNAME is a RecordType enum value
|
|
RecordTypeCNAME = "CNAME"
|
|
// RecordTypeTXT is a RecordType enum value
|
|
RecordTypeTXT = "TXT"
|
|
)
|
|
|
|
// TTL is a structure defining the TTL of a DNS record
|
|
type TTL int64
|
|
|
|
// IsConfigured returns true if TTL is configured, false otherwise
|
|
func (ttl TTL) IsConfigured() bool {
|
|
return ttl > 0
|
|
}
|
|
|
|
// Endpoint is a high-level way of a connection between a service and an IP
|
|
type Endpoint struct {
|
|
// The hostname of the DNS record
|
|
DNSName string
|
|
// The target the DNS record points to
|
|
Target string
|
|
// RecordType type of record, e.g. CNAME, A, TXT etc
|
|
RecordType string
|
|
// TTL for the record
|
|
RecordTTL TTL
|
|
// Labels stores labels defined for the Endpoint
|
|
Labels Labels
|
|
}
|
|
|
|
// NewEndpoint initialization method to be used to create an endpoint
|
|
func NewEndpoint(dnsName, target, recordType string) *Endpoint {
|
|
return NewEndpointWithTTL(dnsName, target, recordType, TTL(0))
|
|
}
|
|
|
|
// NewEndpointWithTTL initialization method to be used to create an endpoint with a TTL struct
|
|
func NewEndpointWithTTL(dnsName, target, recordType string, ttl TTL) *Endpoint {
|
|
return &Endpoint{
|
|
DNSName: strings.TrimSuffix(dnsName, "."),
|
|
Target: strings.TrimSuffix(target, "."),
|
|
RecordType: recordType,
|
|
Labels: NewLabels(),
|
|
RecordTTL: ttl,
|
|
}
|
|
}
|
|
|
|
func (e *Endpoint) String() string {
|
|
return fmt.Sprintf("%s %d IN %s %s", e.DNSName, e.RecordTTL, e.RecordType, e.Target)
|
|
}
|