route

package
v0.1.3-0...-617a0de Latest Latest
Warning

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

Go to latest
Published: Mar 25, 2020 License: Apache-2.0 Imports: 15 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// Coordination route coordination protocol
	Coordination = "routecoordination"

	// RouteCoordinationSpec defines the route coordination spec
	CoordinationSpec = "https://didcomm.org/routecoordination/1.0/"

	// RouteRequestMsgType defines the route coordination request message type.
	RequestMsgType = CoordinationSpec + "route-request"

	// RouteGrantMsgType defines the route coordination request grant message type.
	GrantMsgType = CoordinationSpec + "route-grant"

	// KeyListUpdateMsgType defines the route coordination key list update message type.
	KeylistUpdateMsgType = CoordinationSpec + "keylist_update"

	// KeyListUpdateResponseMsgType defines the route coordination key list update message response type.
	KeylistUpdateResponseMsgType = CoordinationSpec + "keylist_update_response"
)

constants for route coordination spec types

Variables

View Source
var ErrConnectionNotFound = errors.New("connection not found")

ErrConnectionNotFound connection not found error

View Source
var ErrRouterNotRegistered = errors.New("router not registered")

ErrRouterNotRegistered router not registered error

Functions

func AddKeyToRouter

func AddKeyToRouter(routeSvc ProtocolService, recKey string) error

AddKeyToRouter util to add the recipient keys to the router.

func GetRouterConfig

func GetRouterConfig(routeSvc ProtocolService, endpoint string) (string, []string, error)

GetRouterConfig util to get the router configuration. The endpoint is overridden with routers endpoint, if router is registered. Returns endpoint, routingKeys and error.

Types

type Config

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

Config provides the router configuration.

func NewConfig

func NewConfig(endpoint string, keys []string) *Config

NewConfig creates new config instance.

func (*Config) Endpoint

func (c *Config) Endpoint() string

Endpoint returns router endpoint.

func (*Config) Keys

func (c *Config) Keys() []string

Keys returns routing keys.

type Grant

type Grant struct {
	Type        string   `json:"@type,omitempty"`
	ID          string   `json:"@id,omitempty"`
	Endpoint    string   `json:"endpoint,omitempty"`
	RoutingKeys []string `json:"routing_keys,omitempty"`
}

Grant route grant message. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination#route-grant

type KeylistUpdate

type KeylistUpdate struct {
	Type    string   `json:"@type,omitempty"`
	ID      string   `json:"@id,omitempty"`
	Updates []Update `json:"updates,omitempty"`
}

KeylistUpdate route keylist update message. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination#keylist-update

type KeylistUpdateResponse

type KeylistUpdateResponse struct {
	Type    string           `json:"@type,omitempty"`
	ID      string           `json:"@id,omitempty"`
	Updated []UpdateResponse `json:"updated,omitempty"`
}

KeylistUpdateResponse route keylist update response message. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination#keylist-update-response

type ProtocolService

type ProtocolService interface {
	// AddKey adds agents recKey to the router
	AddKey(recKey string) error

	// Config gives back the router configuration
	Config() (*Config, error)
}

ProtocolService service interface for router.

type Request

type Request struct {
	Type string `json:"@type,omitempty"`
	ID   string `json:"@id,omitempty"`
}

Request route request message. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination#route-request

type Service

type Service struct {
	service.Action
	service.Message
	// contains filtered or unexported fields
}

Service for Route Coordination protocol. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination

func New

func New(prov provider) (*Service, error)

New return route coordination service.

func (*Service) Accept

func (s *Service) Accept(msgType string) bool

Accept checks whether the service can handle the message type.

func (*Service) AddKey

func (s *Service) AddKey(recKey string) error

AddKey adds a recKey of the agent to the registered router. This method blocks until a response is received from the router or it times out. TODO https://github.com/hyperledger/aries-framework-go/issues/1076 Support for multiple routers TODO https://github.com/hyperledger/aries-framework-go/issues/1105 Support to Add multiple

recKeys to the Router

func (*Service) Config

func (s *Service) Config() (*Config, error)

Config fetches the router config - endpoint and routingKeys.

func (*Service) GetConnection

func (s *Service) GetConnection() (string, error)

GetConnection returns the connectionID of the router.

func (*Service) HandleInbound

func (s *Service) HandleInbound(msg service.DIDCommMsg, myDID, theirDID string) (string, error)

HandleInbound handles inbound route coordination messages.

func (*Service) HandleOutbound

func (s *Service) HandleOutbound(msg service.DIDCommMsg, myDID, theirDID string) error

HandleOutbound handles outbound route coordination messages.

func (*Service) Name

func (s *Service) Name() string

Name of the service

func (*Service) Register

func (s *Service) Register(connectionID string) error

Register registers the agent with the router on the other end of the connection identified by connectionID. This method blocks until a response is received from the router or it times out. The agent is registered with the router and retrieves the router endpoint and routing keys. This function throws an error if the agent is already registered against a router. TODO https://github.com/hyperledger/aries-framework-go/issues/1076 Register agent with

multiple routers

func (*Service) Unregister

func (s *Service) Unregister() error

Unregister unregisters the agent with the router.

type Update

type Update struct {
	RecipientKey string `json:"recipient_key,omitempty"`
	Action       string `json:"action,omitempty"`
}

Update route key update message.

type UpdateResponse

type UpdateResponse struct {
	RecipientKey string `json:"recipient_key,omitempty"`
	Action       string `json:"action,omitempty"`
	Result       string `json:"result,omitempty"`
}

UpdateResponse route key update response message.

Jump to

Keyboard shortcuts

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