element/delegate.go

50 lines
1.2 KiB
Go
Raw Permalink Normal View History

package element
import (
"time"
2018-09-19 01:59:54 +00:00
"github.com/gogo/protobuf/proto"
"github.com/sirupsen/logrus"
)
// NodeMeta returns local node meta information
2018-09-19 01:59:54 +00:00
func (a *Agent) NodeMeta(limit int) []byte {
data, err := proto.Marshal(a.state)
if err != nil {
logrus.Errorf("error serializing node meta: %s", err)
}
return data
}
// NotifyMsg is used for handling cluster messages
2018-09-19 01:59:54 +00:00
func (a *Agent) NotifyMsg(buf []byte) {
// this can be used to receive messages sent (i.e. SendReliable)
}
// GetBroadcasts is called when user messages can be broadcast
2018-09-19 01:59:54 +00:00
func (a *Agent) GetBroadcasts(overhead, limit int) [][]byte {
return nil
}
// LocalState is the local cluster agent state
2018-09-19 01:59:54 +00:00
func (a *Agent) LocalState(join bool) []byte {
data, err := proto.Marshal(a.state)
if err != nil {
logrus.Errorf("error serializing local state: %s", err)
}
2018-09-19 01:59:54 +00:00
return data
}
// MergeRemoteState is used to store remote peer information
2018-09-19 01:59:54 +00:00
func (a *Agent) MergeRemoteState(buf []byte, join bool) {
var state State
if err := proto.Unmarshal(buf, &state); err != nil {
logrus.Errorf("error parsing remote agent state: %s", err)
return
}
2018-09-19 01:59:54 +00:00
a.state.Updated = time.Now()
a.state.Peers[state.Self.ID] = state.Self
// notify update
2018-09-19 01:59:54 +00:00
a.peerUpdateChan <- true
}