Generic SRV records checker for happyDomain.
For each SRV record attached to an svcs.UnknownSRV service, the checker
resolves every target and probes reachability:
- DNS resolution (A/AAAA), CNAME detection (RFC 2782 violation),
null-target detection (RFC 2782 "service explicitly unavailable")
- TCP connect to target:port for _tcp SRVs
- UDP probe for _udp SRVs, using ICMP port-unreachable detection
The checker also publishes TLS endpoints (host, port, SNI) for every
SRV target hitting a well-known direct-TLS port (443, 465, 636, 853,
993, 995, 5061, 5223, …) via the EndpointDiscoverer SDK interface, so
a downstream TLS checker can pick them up.
The HTML report groups records as cards and surfaces the most common
failure scenarios (DNS failure, CNAME target, TCP unreachable,
null-target) at the top with remediation guidance.
28 lines
837 B
Go
28 lines
837 B
Go
package checker
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
sdk "git.happydns.org/checker-sdk-go/checker"
|
|
)
|
|
|
|
type rulePresent struct{}
|
|
|
|
func RulePresent() sdk.CheckRule { return &rulePresent{} }
|
|
func (rulePresent) Name() string { return "srv_records_present" }
|
|
func (rulePresent) Description() string {
|
|
return "At least one SRV record is published for this service."
|
|
}
|
|
func (rulePresent) Evaluate(ctx context.Context, obs sdk.ObservationGetter, _ sdk.CheckerOptions) []sdk.CheckState {
|
|
d, cs := getData(ctx, obs)
|
|
if cs != nil {
|
|
return []sdk.CheckState{*cs}
|
|
}
|
|
if len(d.Records) == 0 {
|
|
return []sdk.CheckState{{Status: sdk.StatusCrit, Code: "srv_missing",
|
|
Message: "No SRV records published."}}
|
|
}
|
|
return []sdk.CheckState{{Status: sdk.StatusOK, Code: "srv_present",
|
|
Message: fmt.Sprintf("%d SRV record(s) published.", len(d.Records))}}
|
|
}
|