blob: c7359525e5e67a687c589d87a97f894698cf6f68 [file] [log] [blame]
package impl
import (
"fmt"
"veyron/services/mgmt/node"
"veyron/services/mgmt/node/config"
"veyron2/ipc"
"veyron2/security"
)
// dispatcher holds the state of the node manager dispatcher.
type dispatcher struct {
auth security.Authorizer
internal *internalState
config *config.State
}
// NewDispatcher is the node manager dispatcher factory.
func NewDispatcher(auth security.Authorizer, config *config.State) (*dispatcher, error) {
if err := config.Validate(); err != nil {
return nil, fmt.Errorf("Invalid config %v: %v", config, err)
}
return &dispatcher{
auth: auth,
internal: &internalState{
channels: make(map[string]map[string]chan string),
updating: false,
},
config: config,
}, nil
}
// DISPATCHER INTERFACE IMPLEMENTATION
func (d *dispatcher) Lookup(suffix string) (ipc.Invoker, security.Authorizer, error) {
// TODO(caprita): Split out the logic that operates on the node manager
// from the logic that operates on the applications that the node
// manager runs. We can have different invoker implementations,
// dispatching based on the suffix ("nm" vs. "apps").
return ipc.ReflectInvoker(node.NewServerNode(&invoker{
internal: d.internal,
config: d.config,
suffix: suffix,
})), d.auth, nil
}