open-consul/consul/catalog_endpoint.go
2013-12-11 16:24:34 -08:00

50 lines
1.4 KiB
Go

package consul
import (
"github.com/hashicorp/consul/rpc"
)
// Catalog endpoint is used to manipulate the service catalog
type Catalog struct {
srv *Server
}
/*
* Register : Registers that a node provides a given service
* Deregister : Deregisters that a node provides a given service
* ListDatacenters: List the known datacenters
* ListServices : Lists the available services
* ListNodes : Lists the available nodes
* ServiceNodes: Returns the nodes that are part of a service
* NodeServices: Returns the services that a node is registered for
*/
// Register is used register that a node is providing a given service.
func (c *Catalog) Register(args *rpc.RegisterRequest, reply *struct{}) error {
if done, err := c.srv.forward("Catalog.Register", args.Datacenter, args, reply); done {
return err
}
_, err := c.srv.raftApply(rpc.RegisterRequestType, args)
if err != nil {
c.srv.logger.Printf("[ERR] Register failed: %v", err)
return err
}
return nil
}
// Deregister is used to remove a service registration for a given node.
func (c *Catalog) Deregister(args *rpc.DeregisterRequest, reply *struct{}) error {
if done, err := c.srv.forward("Catalog.Deregister", args.Datacenter, args, reply); done {
return err
}
_, err := c.srv.raftApply(rpc.DeregisterRequestType, args)
if err != nil {
c.srv.logger.Printf("[ERR] Deregister failed: %v", err)
return err
}
return nil
}