Documentation ¶
Overview ¶
Package robot defines the robot which is the root of all robotic parts.
Index ¶
- func AllResourcesByName(r Robot, name string) []interface{}
- func NamesBySubtype(r Robot, subtype resource.Subtype) []string
- func NewUnimplementedLocalInterfaceError(actual interface{}) error
- func ResourceFromProtoMessage(robot Robot, msg *dynamic.Message, subtype resource.Subtype) (interface{}, resource.Name, error)
- func TypeAndMethodDescFromMethod(r Robot, method string) (*resource.RPCSubtype, *desc.MethodDescriptor, error)
- type LocalRobot
- type Refresher
- type RemoteRobot
- type Robot
- type SessionManager
- func (m *SessionManager) All() []*session.Session
- func (m *SessionManager) AssociateResource(id uuid.UUID, resourceName resource.Name)
- func (m *SessionManager) Close()
- func (m *SessionManager) FindByID(id uuid.UUID, ownerID string) (*session.Session, error)
- func (m *SessionManager) ServerInterceptors() session.ServerInterceptors
- func (m *SessionManager) Start(ownerID string, peerConnInfo *pb.PeerConnectionInfo) (*session.Session, error)
- func (m *SessionManager) StreamServerInterceptor(srv interface{}, ss grpc.ServerStream, info *grpc.StreamServerInfo, ...) error
- func (m *SessionManager) UnaryServerInterceptor(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, ...) (interface{}, error)
- type Status
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AllResourcesByName ¶
AllResourcesByName returns an array of all resources that have this simple name.
func NamesBySubtype ¶
NamesBySubtype is a helper for getting all names from the given Robot given the subtype.
func NewUnimplementedLocalInterfaceError ¶ added in v0.1.0
func NewUnimplementedLocalInterfaceError(actual interface{}) error
NewUnimplementedLocalInterfaceError is used when there is a failed interface check.
func ResourceFromProtoMessage ¶ added in v0.2.5
func ResourceFromProtoMessage( robot Robot, msg *dynamic.Message, subtype resource.Subtype, ) (interface{}, resource.Name, error)
ResourceFromProtoMessage attempts to find out the name/resource associated with a gRPC message.
func TypeAndMethodDescFromMethod ¶ added in v0.2.5
func TypeAndMethodDescFromMethod(r Robot, method string) (*resource.RPCSubtype, *desc.MethodDescriptor, error)
TypeAndMethodDescFromMethod attempts to determine the resource subtype and its respective gRPC method information from the given robot and method path. If nothing can be found, grpc.UnimplementedError is returned.
Types ¶
type LocalRobot ¶
type LocalRobot interface { Robot // Config returns the local config used to construct the robot. // This is allowed to be partial or empty. Config(ctx context.Context) (*config.Config, error) // Reconfigure instructs the robot to safely reconfigure itself based // on the given new config. Reconfigure(ctx context.Context, newConfig *config.Config) // StartWeb starts the web server, will return an error if server is already up. StartWeb(ctx context.Context, o weboptions.Options) error // StopWeb stops the web server, will be a noop if server is not up. StopWeb() error // WebAddress returns the address of the web service. WebAddress() (string, error) // ModuleAddress returns the address (path) of the unix socket modules use to contact the parent. ModuleAddress() (string, error) // ModuleManager returns the module manager the robot is using. ModuleManager() modif.ModuleManager }
A LocalRobot is a Robot that can have its parts modified.
type Refresher ¶
type Refresher interface { // Refresh instructs the Robot to manually refresh the contents of itself. Refresh(ctx context.Context) error }
A Refresher can refresh the contents of a robot.
type RemoteRobot ¶
type RemoteRobot interface { Robot // Connected returns whether the remote is connected or not. Connected() bool }
A RemoteRobot is a Robot that was created through a connection.
type Robot ¶
type Robot interface { // DiscoverComponents returns discovered component configurations. DiscoverComponents(ctx context.Context, qs []discovery.Query) ([]discovery.Discovery, error) // RemoteByName returns a remote robot by name. RemoteByName(name string) (Robot, bool) // ResourceByName returns a resource by name ResourceByName(name resource.Name) (interface{}, error) // RemoteNames returns the name of all known remote robots. RemoteNames() []string // ResourceNames returns a list of all known resource names. ResourceNames() []resource.Name // ResourceRPCSubtypes returns a list of all known resource RPC subtypes. ResourceRPCSubtypes() []resource.RPCSubtype // ProcessManager returns the process manager for the robot. ProcessManager() pexec.ProcessManager // OperationManager returns the operation manager the robot is using. OperationManager() *operation.Manager // SessionManager returns the session manager the robot is using. SessionManager() session.Manager // Logger returns the logger the robot is using. Logger() golog.Logger // FrameSystemConfig returns the individual parts that make up a robot's frame system FrameSystemConfig(ctx context.Context, additionalTransforms []*referenceframe.LinkInFrame) (framesystemparts.Parts, error) // TransformPose will transform the pose of the requested poseInFrame to the desired frame in the robot's frame system. TransformPose( ctx context.Context, pose *referenceframe.PoseInFrame, dst string, additionalTransforms []*referenceframe.LinkInFrame, ) (*referenceframe.PoseInFrame, error) // Status takes a list of resource names and returns their corresponding statuses. If no names are passed in, return all statuses. Status(ctx context.Context, resourceNames []resource.Name) ([]Status, error) // Close attempts to cleanly close down all constituent parts of the robot. Close(ctx context.Context) error // StopAll cancels all current and outstanding operations for the robot and stops all actuators and movement StopAll(ctx context.Context, extra map[resource.Name]map[string]interface{}) error }
A Robot encompasses all functionality of some robot comprised of parts, local and remote.
type SessionManager ¶ added in v0.2.5
type SessionManager struct {
// contains filtered or unexported fields
}
SessionManager holds sessions for a particular robot and manages their lifetime.
func NewSessionManager ¶ added in v0.2.5
func NewSessionManager(robot Robot, heartbeatWindow time.Duration) *SessionManager
NewSessionManager creates a new manager for holding sessions.
func (*SessionManager) All ¶ added in v0.2.5
func (m *SessionManager) All() []*session.Session
All returns all active sessions.
func (*SessionManager) AssociateResource ¶ added in v0.2.5
func (m *SessionManager) AssociateResource(id uuid.UUID, resourceName resource.Name)
AssociateResource associates a session ID to a monitored resource such that when a session expires, if a resource is currently associated with that ID based on the order of AssociateResource calls, then it will have its resourc stopped. If id is uuid.Nil, this has no effect other than disassociation with a session. Be sure to include any remote information in the name.
func (*SessionManager) Close ¶ added in v0.2.5
func (m *SessionManager) Close()
Close stops the session manager but will not explicitly expire any sessions.
func (*SessionManager) FindByID ¶ added in v0.2.5
FindByID finds a session by the given ID. If found, a heartbeat is triggered, extending the lifetime of the session. If ownerID is in use but the session in question has a different owner, this is a security violation and we report back no session found.
func (*SessionManager) ServerInterceptors ¶ added in v0.2.5
func (m *SessionManager) ServerInterceptors() session.ServerInterceptors
ServerInterceptors returns gRPC interceptors to work with sessions.
func (*SessionManager) Start ¶ added in v0.2.5
func (m *SessionManager) Start( ownerID string, peerConnInfo *pb.PeerConnectionInfo, ) (*session.Session, error)
Start creates a new session that expects at least one heartbeat within the configured window.
func (*SessionManager) StreamServerInterceptor ¶ added in v0.2.5
func (m *SessionManager) StreamServerInterceptor( srv interface{}, ss grpc.ServerStream, info *grpc.StreamServerInfo, handler grpc.StreamHandler, ) error
StreamServerInterceptor associates the current session (if present) in the current context before passing it to the stream response handler.
func (*SessionManager) UnaryServerInterceptor ¶ added in v0.2.5
func (m *SessionManager) UnaryServerInterceptor( ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler, ) (interface{}, error)
UnaryServerInterceptor associates the current session (if present) in the current context before passing it to the unary response handler.
type Status ¶
Status holds a resource name and its corresponding status. Status is expected to be comprised of string keys and values comprised of primitives, list of primitives, maps with string keys (or at least can be decomposed into one), or lists of the forementioned type of maps. Results with other types of data are not guaranteed.
Directories ¶
Path | Synopsis |
---|---|
Package client contains a gRPC based robot.Robot client.
|
Package client contains a gRPC based robot.Robot client. |
Package framesystem defines and implements the concept of a frame system.
|
Package framesystem defines and implements the concept of a frame system. |
parts
Package framesystemparts provides functionality around a list of framesystem parts
|
Package framesystemparts provides functionality around a list of framesystem parts |
Package robotimpl defines implementations of robot.Robot and robot.LocalRobot.
|
Package robotimpl defines implementations of robot.Robot and robot.LocalRobot. |
Package server contains a gRPC based robot.Robot server implementation.
|
Package server contains a gRPC based robot.Robot server implementation. |
Package web provides gRPC/REST/GUI APIs to control and monitor a robot.
|
Package web provides gRPC/REST/GUI APIs to control and monitor a robot. |
options
Package weboptions provides Options for configuring a web server
|
Package weboptions provides Options for configuring a web server |
stream
Package webstream provides controls for streaming from the web server.
|
Package webstream provides controls for streaming from the web server. |