Documentation ¶
Overview ¶
Package scheme implements how to probe or send alert to the URL.
All scheme structs implement Prober and/or Alerter.
Index ¶
- Constants
- Variables
- func SplitScheme(scheme string) (subScheme string, separator rune, variant string)
- type AlertReporter
- type Alerter
- type AlerterSet
- type DNSScheme
- type DummyScheme
- type ExecScheme
- type FixedSourceReporter
- type HTTPScheme
- type PingScheme
- type PluginScheme
- type Prober
- type Reporter
- type SourceScheme
- type TCPScheme
- type TargetTracker
- func (t *TargetTracker) Activate(target *url.URL)
- func (t *TargetTracker) DeactivateTarget(_ *url.URL, _ ...*url.URL)
- func (t *TargetTracker) Inactives() []*url.URL
- func (t *TargetTracker) PrepareReporter(source *url.URL, r Reporter) Reporter
- func (t *TargetTracker) Report(_ *url.URL, rec api.Record)
Constants ¶
const (
HTTP_REDIRECT_MAX = 10
)
Variables ¶
var ( ErrUnsupportedDNSType = errors.New("unsupported DNS type") ErrConflictDNSType = errors.New("DNS type in scheme and query is conflicted") ErrMissingDomainName = errors.New("missing domain name") )
var ( ErrInvalidURL = errors.New("invalid URL") ErrMissingScheme = errors.New("missing scheme in URL") ErrUnsupportedScheme = errors.New("unsupported scheme") ErrMissingHost = errors.New("missing target host") )
var ( ErrInvalidSource = errors.New("invalid source") ErrInvalidSourceURL = errors.New("invalid source URL") ErrMissingFile = errors.New("missing file") )
var (
ErrFailedToPreparePing = errors.New("failed to setup ping service")
)
var (
ErrInvalidAlertURL = errors.New("invalid alert URL")
)
var (
ErrMissingCommand = errors.New("missing command")
)
var (
ErrRedirectLoopDetected = errors.New("redirect loop detected")
)
var (
ErrTCPPortMissing = errors.New("TCP target's port number is required")
)
var (
HTTPUserAgent = "ayd health check"
)
Functions ¶
Types ¶
type AlertReporter ¶
AlertReporter is a wrapper of Reporter interface for alert schemes. It replaces source URL, and puts "alert:" prefix to the target URL.
func (AlertReporter) DeactivateTarget ¶
func (r AlertReporter) DeactivateTarget(source *url.URL, targets ...*url.URL)
type Alerter ¶
type Alerter interface { // Target returns the alert target URL. // This URL should not change during lifetime of the instance. Target() *url.URL // Alert sends an alert to the target, and report result(s) to the Reporter. Alert(context.Context, Reporter, api.Record) }
Alerter is the interface to send alerts to somewhere.
func NewAlerter ¶
type AlerterSet ¶
type AlerterSet []Alerter
AlerterSet is a set of alerts. It also implements Alerter alertinterface.
func NewAlerterSet ¶
func NewAlerterSet(targets []string) (AlerterSet, error)
func (AlerterSet) Alert ¶
Alert of AlerterSet calls all Alert methods of children parallelly. This method blocks until all alerts done.
func (AlerterSet) Target ¶
func (as AlerterSet) Target() *url.URL
Target implements Alert interface. This method always returns alert-set: URL.
type DNSScheme ¶
type DNSScheme struct {
// contains filtered or unexported fields
}
DNSScheme is a Prober and Alerter implementation for the DNS protocol.
func NewDNSScheme ¶
NewDNSScheme creates a new DNSScheme. This supports both of for Prober and for Alerter.
type DummyScheme ¶
type DummyScheme struct {
// contains filtered or unexported fields
}
func NewDummyScheme ¶
func NewDummyScheme(u *url.URL) (DummyScheme, error)
func (DummyScheme) Status ¶
func (s DummyScheme) Status() api.Status
func (DummyScheme) Target ¶
func (s DummyScheme) Target() *url.URL
type ExecScheme ¶
type ExecScheme struct {
// contains filtered or unexported fields
}
func NewExecScheme ¶
func NewExecScheme(u *url.URL) (ExecScheme, error)
func (ExecScheme) Target ¶
func (s ExecScheme) Target() *url.URL
type FixedSourceReporter ¶
FixedSourceReporter is a Reporter that overrides source argument.
This struct is used by TargetTracker.
func (FixedSourceReporter) DeactivateTarget ¶
func (r FixedSourceReporter) DeactivateTarget(source *url.URL, targets ...*url.URL)
DeactivateTarget implements Reporter.
type HTTPScheme ¶
type HTTPScheme struct {
// contains filtered or unexported fields
}
func NewHTTPScheme ¶
func NewHTTPScheme(u *url.URL) (HTTPScheme, error)
func (HTTPScheme) Target ¶
func (s HTTPScheme) Target() *url.URL
type PingScheme ¶
type PingScheme struct {
// contains filtered or unexported fields
}
func NewPingScheme ¶
func NewPingScheme(u *url.URL) (PingScheme, error)
func (PingScheme) Target ¶
func (s PingScheme) Target() *url.URL
type PluginScheme ¶
type PluginScheme struct {
// contains filtered or unexported fields
}
PluginScheme is the plugin handler. This implements both of Prober interface and Alerter interface.
func NewPluginAlert ¶
func NewPluginAlert(u *url.URL) (PluginScheme, error)
func NewPluginProbe ¶
func NewPluginProbe(u *url.URL) (PluginScheme, error)
func NewPluginScheme ¶
func NewPluginScheme(u *url.URL, scope string) (PluginScheme, error)
func (PluginScheme) Target ¶
func (p PluginScheme) Target() *url.URL
type Prober ¶
type Prober interface { // Target returns the target URL. // This URL should not change during lifetime of the instance. Target() *url.URL // Probe checks the target is dead or alive, and report result(s) to the Reporter. Probe(context.Context, Reporter) }
Prober is the interface to check the target is dead or alive.
type SourceScheme ¶
type SourceScheme struct {
// contains filtered or unexported fields
}
SourceScheme implements how to load target URLs from file, HTTP, or external command.
func NewSourceAlert ¶
func NewSourceAlert(u *url.URL) (SourceScheme, error)
NewSourceProbe makes a new SourceScheme instance. It checks each URLs in source as an Alerter.
func NewSourceProbe ¶
func NewSourceProbe(u *url.URL) (SourceScheme, error)
NewSourceProbe makes a new SourceScheme instance. It checks each URLs in source as a Prober.
func (SourceScheme) Target ¶
func (p SourceScheme) Target() *url.URL
type TargetTracker ¶
TargetTracker tracks the targets is active or not.
func (*TargetTracker) Activate ¶
func (t *TargetTracker) Activate(target *url.URL)
Activate removes target URL from inactive list and appends to active list.
func (*TargetTracker) DeactivateTarget ¶
func (t *TargetTracker) DeactivateTarget(_ *url.URL, _ ...*url.URL)
DeactivateTarget implements Reporter. it does nothing.
func (*TargetTracker) Inactives ¶
func (t *TargetTracker) Inactives() []*url.URL
Inactives returns the list of inactive targets that not reported since last PrepareReporter called.
func (*TargetTracker) PrepareReporter ¶
func (t *TargetTracker) PrepareReporter(source *url.URL, r Reporter) Reporter
PrepareReporter prepares to tracking a new probe with a new reporter.