The SDK split the HTTP server scaffolding into the new checker-sdk-go/checker/server subpackage. Update main.go to import server and call server.New, and isolate the interactive form code behind the standalone build tag so plugin/builtin builds skip net/http entirely.
27 lines
1 KiB
Go
27 lines
1 KiB
Go
// Command plugin is the happyDomain plugin entrypoint for the ping checker.
|
|
//
|
|
// It is built as a Go plugin (`go build -buildmode=plugin`) and loaded at
|
|
// runtime by happyDomain.
|
|
package main
|
|
|
|
import (
|
|
ping "git.happydns.org/checker-ping/checker"
|
|
sdk "git.happydns.org/checker-sdk-go/checker"
|
|
)
|
|
|
|
// Version is the plugin's version. It defaults to "custom-build" and is
|
|
// meant to be overridden by the CI at link time:
|
|
//
|
|
// go build -buildmode=plugin -ldflags "-X main.Version=1.2.3" -o checker-ping.so ./plugin
|
|
var Version = "custom-build"
|
|
|
|
// NewCheckerPlugin is the symbol resolved by happyDomain when loading the
|
|
// .so file. It returns the checker definition and the observation provider
|
|
// that the host will register in its global registries.
|
|
func NewCheckerPlugin() (*sdk.CheckerDefinition, sdk.ObservationProvider, error) {
|
|
// Propagate the plugin's version to the checker package so it shows up
|
|
// in CheckerDefinition.Version.
|
|
ping.Version = Version
|
|
prvd := ping.Provider()
|
|
return prvd.(sdk.CheckerDefinitionProvider).Definition(), prvd, nil
|
|
}
|