controlapi

package
v1.23.0 Latest Latest
Warning

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

Go to latest
Published: Mar 1, 2026 License: Apache-2.0 Imports: 12 Imported by: 0

Documentation

Overview

Package controlapi implements the public API of the control.core microservice, including clients and data structures.

This microservice is created for the sake of generating the client API for the :888 control subscriptions. The microservice itself does nothing and should not be included in applications.

Index

Constants

View Source
const Hostname = "control.core"

Hostname is the default hostname of the microservice.

Variables

View Source
var (
	// HINT: Insert endpoint definitions here
	Ping          = Def{Method: "ANY", Route: `:888/ping`}           // MARKER: Ping
	ConfigRefresh = Def{Method: "ANY", Route: `:888/config-refresh`} // MARKER: ConfigRefresh
	Trace         = Def{Method: "ANY", Route: `:888/trace`}          // MARKER: Trace
	Metrics       = Def{Method: "ANY", Route: `:888/metrics`}        // MARKER: Metrics
	OnNewSubs     = Def{Method: "POST", Route: `:888/on-new-subs`}   // MARKER: OnNewSubs
)

Functions

This section is empty.

Types

type Client

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

Client is a lightweight proxy for making unicast calls to the microservice.

func NewClient

func NewClient(caller service.Publisher) Client

NewClient creates a new unicast client proxy to the microservice.

func (Client) ConfigRefresh

func (_c Client) ConfigRefresh(ctx context.Context) (err error)

ConfigRefresh pulls the latest config values.

func (Client) ForHost

func (_c Client) ForHost(host string) Client

ForHost returns a copy of the client with a different hostname to be applied to requests.

func (Client) Metrics added in v1.19.0

func (_c Client) Metrics(ctx context.Context, method string, relativeURL string, body any) (res *http.Response, err error)

Metrics returns Prometheus metrics.

If a URL is provided, it is resolved relative to the URL of the endpoint. If the body is of type io.Reader, []byte or string, it is serialized in binary form. If it is of type url.Values, it is serialized as form data. All other types are serialized as JSON.

func (Client) Ping

func (_c Client) Ping(ctx context.Context) (pong int, err error)

Ping responds with a pong.

func (Client) Trace

func (_c Client) Trace(ctx context.Context, id string) (err error)

Trace forces exporting a tracing span.

func (Client) WithOptions added in v1.13.1

func (_c Client) WithOptions(opts ...pub.Option) Client

WithOptions returns a copy of the client with options to be applied to requests.

type ConfigRefreshIn

type ConfigRefreshIn struct {
}

ConfigRefreshIn are the input arguments of ConfigRefresh.

type ConfigRefreshOut

type ConfigRefreshOut struct {
}

ConfigRefreshOut are the output arguments of ConfigRefresh.

type ConfigRefreshResponse

type ConfigRefreshResponse multicastResponse // MARKER: ConfigRefresh

ConfigRefreshResponse packs the response of ConfigRefresh.

func (*ConfigRefreshResponse) Get

func (_res *ConfigRefreshResponse) Get() (err error)

Get unpacks the return arguments of ConfigRefresh.

type Def added in v1.23.0

type Def struct {
	Method string
	Route  string
}

Def defines an endpoint of the microservice.

func (*Def) URL added in v1.23.0

func (d *Def) URL() string

URL is the full URL to the endpoint.

type Hook added in v1.19.0

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

Hook assists in the subscription to the events of the microservice.

func NewHook added in v1.19.0

func NewHook(listener service.Subscriber) Hook

NewHook creates a new hook to the events of the microservice.

func (Hook) ForHost added in v1.19.0

func (c Hook) ForHost(host string) Hook

ForHost returns a copy of the hook with a different hostname to be applied to the subscription.

func (Hook) OnNewSubs added in v1.19.0

func (c Hook) OnNewSubs(handler func(ctx context.Context) (err error)) (unsub func() error, err error)

OnNewSubs informs of new subscriptions.

func (Hook) WithOptions added in v1.22.0

func (c Hook) WithOptions(opts ...sub.Option) Hook

WithOptions returns a copy of the hook with options to be applied to subscriptions.

type MulticastClient

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

MulticastClient is a lightweight proxy for making multicast calls to the microservice.

func NewMulticastClient

func NewMulticastClient(caller service.Publisher) MulticastClient

NewMulticastClient creates a new multicast client proxy to the microservice.

func (MulticastClient) ConfigRefresh

func (_c MulticastClient) ConfigRefresh(ctx context.Context) iter.Seq[*ConfigRefreshResponse]

ConfigRefresh pulls the latest config values.

func (MulticastClient) ForHost

func (_c MulticastClient) ForHost(host string) MulticastClient

ForHost returns a copy of the client with a different hostname to be applied to requests.

func (MulticastClient) Metrics added in v1.19.0

func (_c MulticastClient) Metrics(ctx context.Context, method string, relativeURL string, body any) iter.Seq[*pub.Response]

Metrics returns Prometheus metrics.

If a URL is provided, it is resolved relative to the URL of the endpoint. If the body is of type io.Reader, []byte or string, it is serialized in binary form. If it is of type url.Values, it is serialized as form data. All other types are serialized as JSON.

func (MulticastClient) Ping

Ping responds with a pong.

func (MulticastClient) PingInstances

func (_c MulticastClient) PingInstances(ctx context.Context) iter.Seq[*ServiceInfo]

PingInstances performs a ping and returns service info for all instances on the network.

func (MulticastClient) PingServices

func (_c MulticastClient) PingServices(ctx context.Context) iter.Seq[*ServiceInfo]

PingServices performs a ping and returns service info for microservices on the network. Results are deduped on a per-service basis.

func (MulticastClient) PingVersions

func (_c MulticastClient) PingVersions(ctx context.Context) iter.Seq[*ServiceInfo]

PingVersions performs a ping and returns service info for microservice versions on the network. Results are deduped on a per-version basis.

func (MulticastClient) Trace

Trace forces exporting a tracing span.

func (MulticastClient) WithOptions added in v1.13.1

func (_c MulticastClient) WithOptions(opts ...pub.Option) MulticastClient

WithOptions returns a copy of the client with options to be applied to requests.

type MulticastTrigger added in v1.19.0

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

MulticastTrigger is a lightweight proxy for triggering the events of the microservice.

func NewMulticastTrigger added in v1.19.0

func NewMulticastTrigger(caller service.Publisher) MulticastTrigger

NewMulticastTrigger creates a new multicast trigger of events of the microservice.

func (MulticastTrigger) ForHost added in v1.19.0

func (_c MulticastTrigger) ForHost(host string) MulticastTrigger

ForHost returns a copy of the trigger with a different hostname to be applied to requests.

func (MulticastTrigger) OnNewSubs added in v1.19.0

OnNewSubs informs of new subscriptions.

func (MulticastTrigger) WithOptions added in v1.19.0

func (_c MulticastTrigger) WithOptions(opts ...pub.Option) MulticastTrigger

WithOptions returns a copy of the trigger with options to be applied to requests.

type OnNewSubsIn added in v1.19.0

type OnNewSubsIn struct {
}

OnNewSubsIn are the input arguments of OnNewSubs.

type OnNewSubsOut added in v1.19.0

type OnNewSubsOut struct {
}

OnNewSubsOut are the output arguments of OnNewSubs.

type OnNewSubsResponse added in v1.19.0

type OnNewSubsResponse multicastResponse // MARKER: OnNewSubs

OnNewSubsResponse packs the response of OnNewSubs.

func (*OnNewSubsResponse) Get added in v1.19.0

func (_res *OnNewSubsResponse) Get() (err error)

Get unpacks the return arguments of OnNewSubs.

type PingIn

type PingIn struct {
}

PingIn are the input arguments of Ping.

type PingOut

type PingOut struct {
	Pong int `json:"pong,omitzero"`
}

PingOut are the output arguments of Ping.

type PingResponse

type PingResponse multicastResponse // MARKER: Ping

PingResponse packs the response of Ping.

func (*PingResponse) Get

func (_res *PingResponse) Get() (pong int, err error)

Get unpacks the return arguments of Ping.

type ServiceInfo

type ServiceInfo struct {
	Hostname string
	Version  int
	ID       string
}

ServiceInfo is a descriptor of the microservice that answers the ping.

type TraceIn

type TraceIn struct {
	ID string `json:"id,omitzero"`
}

TraceIn are the input arguments of Trace.

type TraceOut

type TraceOut struct {
}

TraceOut are the output arguments of Trace.

type TraceResponse

type TraceResponse multicastResponse // MARKER: Trace

TraceResponse packs the response of Trace.

func (*TraceResponse) Get

func (_res *TraceResponse) Get() (err error)

Get unpacks the return arguments of Trace.

Jump to

Keyboard shortcuts

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