Documentation ¶
Index ¶
- Constants
- Variables
- func AddKeyToRouter(routeSvc ProtocolService, recKey string) error
- func GetRouterConfig(routeSvc ProtocolService, endpoint string) (string, []string, error)
- type Config
- type Grant
- type KeylistUpdate
- type KeylistUpdateResponse
- type ProtocolService
- type Request
- type Service
- func (s *Service) Accept(msgType string) bool
- func (s *Service) AddKey(recKey string) error
- func (s *Service) Config() (*Config, error)
- func (s *Service) GetConnection() (string, error)
- func (s *Service) HandleInbound(msg service.DIDCommMsg, myDID, theirDID string) (string, error)
- func (s *Service) HandleOutbound(msg service.DIDCommMsg, myDID, theirDID string) error
- func (s *Service) Name() string
- func (s *Service) Register(connectionID string) error
- func (s *Service) Unregister() error
- type Update
- type UpdateResponse
Constants ¶
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 ¶
var ErrConnectionNotFound = errors.New("connection not found")
ErrConnectionNotFound connection not found error
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.
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 ¶
Request route request message. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination#route-request
type Service ¶
Service for Route Coordination protocol. https://github.com/hyperledger/aries-rfcs/tree/master/features/0211-route-coordination
func (*Service) AddKey ¶
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) GetConnection ¶
GetConnection returns the connectionID of the router.
func (*Service) HandleInbound ¶
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) Register ¶
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 ¶
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.