mirror of https://github.com/status-im/consul.git
consul: expose UserEvent from Serf
This commit is contained in:
parent
e6f9edffed
commit
1c341e6766
|
@ -372,6 +372,15 @@ func (a *Agent) WANMembers() []serf.Member {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserEvent is used to fire an event via the Serf layer on the LAN
|
||||||
|
func (a *Agent) UserEvent(name string, payload []byte) error {
|
||||||
|
if a.server != nil {
|
||||||
|
return a.server.UserEvent(name, payload)
|
||||||
|
} else {
|
||||||
|
return a.client.UserEvent(name, payload)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// StartSync is called once Services and Checks are registered.
|
// StartSync is called once Services and Checks are registered.
|
||||||
// This is called to prevent a race between clients and the anti-entropy routines
|
// This is called to prevent a race between clients and the anti-entropy routines
|
||||||
func (a *Agent) StartSync() {
|
func (a *Agent) StartSync() {
|
||||||
|
|
|
@ -201,6 +201,11 @@ func (c *Client) RemoveFailedNode(node string) error {
|
||||||
return c.serf.RemoveFailedNode(node)
|
return c.serf.RemoveFailedNode(node)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserEvent is used to fire an event via the Serf layer
|
||||||
|
func (c *Client) UserEvent(name string, payload []byte) error {
|
||||||
|
return c.serf.UserEvent(userEventName(name), payload, false)
|
||||||
|
}
|
||||||
|
|
||||||
// lanEventHandler is used to handle events from the lan Serf cluster
|
// lanEventHandler is used to handle events from the lan Serf cluster
|
||||||
func (c *Client) lanEventHandler() {
|
func (c *Client) lanEventHandler() {
|
||||||
for {
|
for {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package consul
|
package consul
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -13,6 +14,11 @@ const (
|
||||||
StatusReap = serf.MemberStatus(-1)
|
StatusReap = serf.MemberStatus(-1)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// userEventName computes the name of a user event
|
||||||
|
func userEventName(name string) string {
|
||||||
|
return fmt.Sprintf("consul:event:%s")
|
||||||
|
}
|
||||||
|
|
||||||
// lanEventHandler is used to handle events from the lan Serf cluster
|
// lanEventHandler is used to handle events from the lan Serf cluster
|
||||||
func (s *Server) lanEventHandler() {
|
func (s *Server) lanEventHandler() {
|
||||||
for {
|
for {
|
||||||
|
|
|
@ -530,6 +530,11 @@ func (s *Server) RemoveFailedNode(node string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserEvent is used to fire an event via the Serf layer on the LAN
|
||||||
|
func (s *Server) UserEvent(name string, payload []byte) error {
|
||||||
|
return s.serfLAN.UserEvent(userEventName(name), payload, false)
|
||||||
|
}
|
||||||
|
|
||||||
// IsLeader checks if this server is the cluster leader
|
// IsLeader checks if this server is the cluster leader
|
||||||
func (s *Server) IsLeader() bool {
|
func (s *Server) IsLeader() bool {
|
||||||
return s.raft.State() == raft.Leader
|
return s.raft.State() == raft.Leader
|
||||||
|
|
Loading…
Reference in New Issue