begin

package
v0.4.4 Latest Latest
Warning

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

Go to latest
Published: Jan 17, 2025 License: Apache-2.0 Imports: 13 Imported by: 1

Documentation

Overview

Package begin provides a chain element that can be put at the beginning of the chain, after Connection.Id has been set but before any chain elements that would mutate the Connection on the return path. the begin.New{Client,Server}() guarantee:

Scope

All Request() or Close() events are scoped to a particular Connection, uniquely identified by its Connection.Id

Exclusivity

Only one event is processed for a Connection.Id at a time

Order

Events for a given Connection.Id are processed in the order in which they are received

Close Correctness

When a Close(Connection) event is received, begin will replace the Connection provided with the last Connection successfully returned from the chain for Connection.Id

Midchain Originated Events

A midchain element may originate a Request() or Close() event to be processed from the beginning of the chain (Timeout, Refresh,Heal):

errCh := begin.FromContext(ctx).Request()
errCh := begin.FromContext(ctx).Close()

errCh will receive any error from the firing of the event, and will be closed after the event has fully processed.

Note: if a chain is a server chain continued by a client chain, the beginning of the chain is at the beginning of the server chain, even if there is a subsequent begin.NewClient() in the client chain.

Optionally you may use the CancelContext(context.Context) option:

begin.FromContext(ctx).Request(CancelContext(cancelContext))
begin.FromContext(ctx).Close(CancelContext(cancelContext))

If cancelContext is canceled prior to the processing of the event, the event processing will be skipped, and the errCh returned simply closed.

Midchain Originated Request Event

Example:

begin.FromContext(ctx).Request()

will use the networkservice.NetworkServiceRequest from the chain's last successfully completed Request() event with networkservice.NetworkServiceRequest.Connection replaced with the Connection returned by the chain's last successfully completed Request() event

Chain Placement

begin.New{Server/Client} should always proceed any chain element which: - Maintains state - Mutates the Connection object along the return path of processing a Request() event.

Reasoning

networkservice.NetworkService{Client,Server} processes two kinds of events:

  • Request()
  • Close()

Each Request() or Close() event is scoped to a networkservice.Connection, which can be uniquely identified by its Connection.Id

For a given Connection.Id, at most one event can be processed at a time (exclusivity). For a given Connection.Id, events must be processed in the order they were received (order). For Close(), the Connection passed to it must be identical to the last one returned by the chain to insure all state is correctly cleared (close correctness).

Typically, a chain element receives a Request() or Close() event from the element before it in the chain and sends a Request() or Close() and either terminates processing returning an error, or sends a Request() or Close() event to the next element in the chain.

There are some circumstances in which a Request() or Close() event needs to be originated by a chain element in the middle of the chain, but processed from the beginning of the chain. Examples include (but are not limited to):

  • A server timing out an expired Connection
  • A client refreshing a Connection so that it does not expire
  • A client healing from a lost Connection

In all of these cases, the Request() or Close() event should be processed starting at the beginning of the chain, to ensure that all of the proper side effects occur within the chain.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewClient

NewClient - creates a new begin chain element

func NewServer

NewServer - creates a new begin chain element

Types

type ClientOption

type ClientOption func(*clientOption)

ClientOption - begin client option

func WithReselectFunc

func WithReselectFunc(reselectFunc ReselectFunc) ClientOption

WithReselectFunc - sets a function for changing request parameters on reselect

type EventFactory

type EventFactory interface {
	Request(opts ...Option) <-chan error
	Close(opts ...Option) <-chan error
}

EventFactory - allows firing off a Request or Close event from midchain

func FromContext

func FromContext(ctx context.Context) EventFactory

FromContext - returns EventFactory from context

type Option

type Option func(*option)

Option - event factory option

func CancelContext

func CancelContext(cancelCtx context.Context) Option

CancelContext - optionally provide a context that, when canceled will preclude the event from running

func WithReselect

func WithReselect() Option

WithReselect - optionally clear Mechanism and NetworkServiceName to force reselect

type ReselectFunc

type ReselectFunc func(request *networkservice.NetworkServiceRequest)

ReselectFunc - function for changing request parameters on reselect

var DefaultReselectFunc ReselectFunc = func(request *networkservice.NetworkServiceRequest) {
	if request.GetConnection() != nil {
		request.GetConnection().Mechanism = nil
		request.GetConnection().NetworkServiceEndpointName = ""
		request.GetConnection().State = networkservice.State_RESELECT_REQUESTED
	}
}

DefaultReselectFunc - default ReselectFunc

var ReselectWithSameEndpointFunc ReselectFunc = func(request *networkservice.NetworkServiceRequest) {
	if request.GetConnection() != nil {
		request.GetConnection().Mechanism = nil
		request.GetConnection().State = networkservice.State_RESELECT_REQUESTED
	}
}

ReselectWithSameEndpointFunc - reselect function that doesn't clean NSE name

Jump to

Keyboard shortcuts

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