scheme

package
v0.12.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 9, 2021 License: MIT Imports: 23 Imported by: 0

Documentation

Overview

Package scheme implements how to probe or send alert to the URL.

All scheme structs implement Prober and/or Alerter.

Index

Constants

View Source
const (
	HTTP_REDIRECT_MAX = 10
)

Variables

View Source
var (
	ErrUnsupportedDNSType = errors.New("unsupported DNS type")
	ErrConflictDNSType    = errors.New("DNS type in scheme and query is conflicted")
	ErrMissingDomainName  = errors.New("missing domain name")
)
View Source
var (
	ErrInvalidURL        = errors.New("invalid URL")
	ErrMissingScheme     = errors.New("missing scheme in URL")
	ErrUnsupportedScheme = errors.New("unsupported scheme")
	ErrMissingHost       = errors.New("missing target host")
)
View Source
var (
	ErrInvalidSource    = errors.New("invalid source")
	ErrInvalidSourceURL = errors.New("invalid source URL")
	ErrMissingFile      = errors.New("missing file")
)
View Source
var (
	ErrFailedToPreparePing = errors.New("failed to setup ping service")
)
View Source
var (
	ErrInvalidAlertURL = errors.New("invalid alert URL")
)
View Source
var (
	ErrMissingCommand = errors.New("missing command")
)
View Source
var (
	ErrRedirectLoopDetected = errors.New("redirect loop detected")
)
View Source
var (
	ErrTCPPortMissing = errors.New("TCP target's port number is required")
)
View Source
var (
	HTTPUserAgent = "ayd health check"
)

Functions

func SplitScheme

func SplitScheme(scheme string) (subScheme string, separator rune, variant string)

SplitScheme splits scheme of URL.

For example, "http-get" will splited to "http", '-', and "get".

Types

type AlertReporter

type AlertReporter struct {
	Source   *url.URL
	Upstream Reporter
}

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)

func (AlertReporter) Report

func (r AlertReporter) Report(_ *url.URL, rec api.Record)

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

func NewAlerter(target string) (Alerter, error)

func NewAlerterFromURL

func NewAlerterFromURL(u *url.URL) (Alerter, error)

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

func (as AlerterSet) Alert(ctx context.Context, r Reporter, lastRecord api.Record)

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

func NewDNSScheme(u *url.URL) (DNSScheme, error)

NewDNSScheme creates a new DNSScheme. This supports both of for Prober and for Alerter.

func (DNSScheme) Alert

func (s DNSScheme) Alert(ctx context.Context, r Reporter, _ api.Record)

func (DNSScheme) Probe

func (s DNSScheme) Probe(ctx context.Context, r Reporter)

func (DNSScheme) Target

func (s DNSScheme) Target() *url.URL

type DummyScheme

type DummyScheme struct {
	// contains filtered or unexported fields
}

func NewDummyScheme

func NewDummyScheme(u *url.URL) (DummyScheme, error)

func (DummyScheme) Alert

func (s DummyScheme) Alert(ctx context.Context, r Reporter, _ api.Record)

func (DummyScheme) Probe

func (s DummyScheme) Probe(ctx context.Context, r Reporter)

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) Alert

func (s ExecScheme) Alert(ctx context.Context, r Reporter, lastRecord api.Record)

func (ExecScheme) Probe

func (s ExecScheme) Probe(ctx context.Context, r Reporter)

func (ExecScheme) Target

func (s ExecScheme) Target() *url.URL

type FixedSourceReporter

type FixedSourceReporter struct {
	Source    *url.URL
	Upstreams []Reporter
}

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.

func (FixedSourceReporter) Report

func (r FixedSourceReporter) Report(_ *url.URL, rec api.Record)

Report implements Reporter. This method just reports to upstream reporters.

type HTTPScheme

type HTTPScheme struct {
	// contains filtered or unexported fields
}

func NewHTTPScheme

func NewHTTPScheme(u *url.URL) (HTTPScheme, error)

func (HTTPScheme) Alert

func (s HTTPScheme) Alert(ctx context.Context, r Reporter, lastRecord api.Record)

func (HTTPScheme) Probe

func (s HTTPScheme) Probe(ctx context.Context, r Reporter)

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) Alert

func (s PingScheme) Alert(ctx context.Context, r Reporter, _ api.Record)

func (PingScheme) Probe

func (s PingScheme) Probe(ctx context.Context, r Reporter)

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) Alert

func (p PluginScheme) Alert(ctx context.Context, r Reporter, lastRecord api.Record)

func (PluginScheme) Probe

func (p PluginScheme) Probe(ctx context.Context, r Reporter)

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.

func NewProber

func NewProber(rawURL string) (Prober, error)

func NewProberFromURL

func NewProberFromURL(u *url.URL) (Prober, error)

type Reporter

type Reporter interface {
	// Report reports a Record.
	//
	// `source` in argument is the probe's URL.
	Report(source *url.URL, r api.Record)

	// DeactivateTarget marks the target is no longer reported via specified source.
	DeactivateTarget(source *url.URL, targets ...*url.URL)
}

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) Alert

func (p SourceScheme) Alert(ctx context.Context, r Reporter, lastRecord api.Record)

func (SourceScheme) Probe

func (p SourceScheme) Probe(ctx context.Context, r Reporter)

func (SourceScheme) Target

func (p SourceScheme) Target() *url.URL

type TCPScheme

type TCPScheme struct {
	// contains filtered or unexported fields
}

func NewTCPScheme

func NewTCPScheme(u *url.URL) (TCPScheme, error)

func (TCPScheme) Alert

func (s TCPScheme) Alert(ctx context.Context, r Reporter, _ api.Record)

func (TCPScheme) Probe

func (s TCPScheme) Probe(ctx context.Context, r Reporter)

func (TCPScheme) Target

func (s TCPScheme) Target() *url.URL

type TargetTracker

type TargetTracker struct {
	sync.Mutex
	// contains filtered or unexported fields
}

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.

func (*TargetTracker) Report

func (t *TargetTracker) Report(_ *url.URL, rec api.Record)

Report implements Reporter. This method marks as the target is active.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL