sub

package
v1.27.0 Latest Latest
Warning

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

Go to latest
Published: Apr 30, 2026 License: Apache-2.0 Imports: 10 Imported by: 0

Documentation

Overview

Package sub is used for subscribing to handle requests. It contains the options to use in Connector.Subscribe

Index

Constants

View Source
const (
	TypeFunction     = "function"
	TypeWeb          = "web"
	TypeInboundEvent = "inboundevent"
	TypeTask         = "task"
	TypeWorkflow     = "workflow"
)

Type values identify the kind of a Microbus endpoint behind a subscription.

Variables

This section is empty.

Functions

This section is empty.

Types

type HTTPHandler

type HTTPHandler func(w http.ResponseWriter, r *http.Request) (err error)

HTTPHandler extends the standard http.Handler to also return an error.

type Option

type Option func(sub *Subscription) error

Option is used to construct a subscription in Connector.Subscribe

func At added in v1.27.0

func At(method string, route string) Option

At sets both the method and the route of a subscription in a single option. It is shorthand for Method followed by Route.

func DefaultQueue

func DefaultQueue() Option

DefaultQueue names the queue of this subscription to the hostname of the service. Requests will be load-balanced among all instances of this microservice.

func Description added in v1.27.0

func Description(text string) Option

Description sets a human-readable description for the subscription. Used by the built-in OpenAPI handler.

func Function added in v1.27.0

func Function(inputs any, outputs any) Option

Function declares the subscription as a typed function (RPC) endpoint. The inputs and outputs values are zero-value struct instances used for OpenAPI schema reflection.

func InboundEvent added in v1.27.0

func InboundEvent(inputs any, outputs any) Option

InboundEvent declares the subscription as an inbound event sink. The inputs and outputs values are zero-value struct instances used for OpenAPI schema reflection.

func Infra added in v1.27.0

func Infra() Option

Infra marks the subscription as framework infrastructure that brackets the user lifecycle: it is activated before [OnStartup] runs and deactivated after [OnShutdown] returns. Non-infra subscriptions are activated after OnStartup returns and deactivated before OnShutdown runs, so user code gets a "clean" environment that doesn't receive requests outside the OnStartup/OnShutdown window. Reserved for framework-internal subscriptions whose handlers must be reachable from inside OnStartup and OnShutdown - e.g. the distributed cache.

func Method added in v1.27.0

func Method(method string) Option

Method overrides the default "ANY" method for a Listen subscription. The subscription can be set to a single standard HTTP method such as "GET", "POST", etc. or to "ANY" in order to accept any method.

func NoQueue

func NoQueue() Option

NoQueue sets no queue for this subscription. Requests will be not be load-balanced, all instances of this microservice will receive the request

func Queue

func Queue(queue string) Option

Queue names the queue of the subscription. Requests will be load-balanced among all consumers with the same queue name

func RequiredClaims added in v1.22.0

func RequiredClaims(boolExp string) Option

RequiredClaims requires that the properties of the actor associated with the request satisfy the boolean expression. For example: iss=='my_issuer' && (roles.admin || roles.manager) && region=="US". The =~ and !~ operators evaluate the left operand against a regexp. String constants, including regexp patterns, must be quoted using single quotes, double quotes or backticks. A request that doesn't satisfy the constraint is denied with a 403 forbidden error.

func Route added in v1.27.0

func Route(route string) Option

Route overrides the default ":443/my-subscription" route for a Listen subscription. If the route does not include a hostname, it is resolved relative to the microservice's default hostname. If a port is not specified, 443 is used by default. Port 0 is used to designate any port. Path arguments are designated by curly braces.

Examples of valid routes:

(empty)
/
/path
:1080
:1080/
:1080/path
:0/any/port
/path/with/slash
path/with/no/slash
/section/{section}/page/{page...}
https://www.example.com/path
https://www.example.com:1080/path
//www.example.com:1080/path

func Task added in v1.27.0

func Task(inputs any, outputs any) Option

Task declares the subscription as a workflow task endpoint. The inputs and outputs values are zero-value struct instances used for OpenAPI schema reflection.

func Ultra added in v1.27.0

func Ultra() Option

Ultra clears the Infra flag, restoring the default activation/deactivation behavior where the subscription brackets the user lifecycle from the outside (activated after OnStartup, deactivated before OnShutdown). It is the symmetric counterpart of Infra and is provided for API completeness; in practice subscriptions default to non-infra.

func Web added in v1.27.0

func Web() Option

Web declares the subscription as a raw HTTP web handler endpoint.

func Workflow added in v1.27.0

func Workflow(inputs any, outputs any) Option

Workflow declares the subscription as a workflow graph endpoint. The inputs and outputs values are zero-value struct instances used for OpenAPI schema reflection.

type Subscription

type Subscription struct {
	Name        string
	Description string
	Host        string
	Port        string
	Method      string
	Route       string
	Queue       string
	Handler     any
	Subs        []*transport.Subscription

	RequiredClaims string
	Type           string
	Inputs         any
	Outputs        any
	Infra          bool
	// contains filtered or unexported fields
}

Subscription handles incoming requests. Although technically public, it is used internally and should not be constructed by microservices directly.

func NewSubscription added in v1.27.0

func NewSubscription(name string, defaultHost string, handler HTTPHandler, options ...Option) (*Subscription, error)

NewSubscription creates a new subscription registered by name. The name must be a legal Go-style upper-case identifier (e.g. "MyEndpoint2"). Exactly one feature option (Function, Web, InboundEvent, Task, [Graph]) must be supplied. Defaults filled in after options are applied:

  • Method defaults to "ANY".
  • Route defaults to ":<port>/<kebab-name>" with the port determined by the feature type (443 for function/web, 417 for inbound events, 428 for tasks/graphs).
  • Queue defaults to defaultHost.

func (*Subscription) Apply

func (sub *Subscription) Apply(options ...Option) error

Apply the provided options to the subscription.

func (*Subscription) Canonical

func (sub *Subscription) Canonical() string

Canonical returns the fully-qualified canonical host:port/path of the subscription, not including the scheme or the method.

func (*Subscription) RefreshHostname

func (sub *Subscription) RefreshHostname(defaultHost string) error

RefreshHostname refreshes the subscription for a different hostname.

Jump to

Keyboard shortcuts

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