2013-07-25 21:26:27 +00:00
|
|
|
package raft
|
|
|
|
|
2013-07-26 19:13:52 +00:00
|
|
|
// Join command interface
|
|
|
|
type JoinCommand interface {
|
|
|
|
CommandName() string
|
|
|
|
Apply(server *Server) (interface{}, error)
|
|
|
|
NodeName() string
|
|
|
|
}
|
|
|
|
|
2013-07-25 21:26:27 +00:00
|
|
|
// Join command
|
2013-07-26 19:13:52 +00:00
|
|
|
type DefaultJoinCommand struct {
|
2013-08-15 23:35:01 +00:00
|
|
|
Name string `json:"name"`
|
|
|
|
ConnectionString string `json:"connectionString"`
|
2013-07-25 21:26:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// The name of the Join command in the log
|
2013-07-26 19:13:52 +00:00
|
|
|
func (c *DefaultJoinCommand) CommandName() string {
|
2013-07-25 21:26:27 +00:00
|
|
|
return "raft:join"
|
|
|
|
}
|
|
|
|
|
2013-07-26 19:13:52 +00:00
|
|
|
func (c *DefaultJoinCommand) Apply(server *Server) (interface{}, error) {
|
2013-08-15 23:35:01 +00:00
|
|
|
err := server.AddPeer(c.Name, c.ConnectionString)
|
2013-07-25 21:26:27 +00:00
|
|
|
|
|
|
|
return []byte("join"), err
|
2013-07-25 22:40:20 +00:00
|
|
|
}
|
2013-07-26 19:13:52 +00:00
|
|
|
|
|
|
|
func (c *DefaultJoinCommand) NodeName() string {
|
|
|
|
return c.Name
|
|
|
|
}
|