2018-06-13 02:06:59 +00:00
|
|
|
package p2p
|
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/event"
|
|
|
|
)
|
|
|
|
|
|
|
|
// P2P feed is a one to many subscription feed of the argument type.
|
|
|
|
//
|
|
|
|
// Messages received via p2p protocol are sent to subscribers by these event
|
|
|
|
// feeds. Message consumers should not use event feeds to reply to or broadcast
|
|
|
|
// messages. The p2p server will not relay them to peers. Rather, use the
|
|
|
|
// Send() or Broadcast() method on p2p.Server.
|
|
|
|
//
|
|
|
|
// Event feeds from p2p will always be of type p2p.Message. The message
|
|
|
|
// contains information about the sender, aka the peer, and the message payload
|
|
|
|
// itself.
|
|
|
|
//
|
2018-06-13 03:03:13 +00:00
|
|
|
// feed, err := ps.Feed(MyMessage{})
|
2018-06-13 02:06:59 +00:00
|
|
|
// ch := make(chan p2p.Message, 100) // Choose a reasonable buffer size!
|
2018-06-13 03:03:13 +00:00
|
|
|
// sub := feed.Subscribe(ch)
|
2018-06-13 02:06:59 +00:00
|
|
|
//
|
|
|
|
// // Wait until my message comes from a peer.
|
|
|
|
// msg := <- ch
|
|
|
|
// fmt.Printf("Message received: %v", msg.Data)
|
2018-06-21 03:03:02 +00:00
|
|
|
func (s *Server) Feed(msg interface{}) *event.Feed {
|
2018-07-17 18:39:04 +00:00
|
|
|
var t reflect.Type
|
|
|
|
|
|
|
|
// Support passing reflect.Type as the msg.
|
|
|
|
switch msg.(type) {
|
|
|
|
case reflect.Type:
|
|
|
|
t = msg.(reflect.Type)
|
|
|
|
default:
|
|
|
|
t = reflect.TypeOf(msg)
|
|
|
|
}
|
|
|
|
|
2018-07-25 16:11:15 +00:00
|
|
|
s.mutex.Lock()
|
|
|
|
defer s.mutex.Unlock()
|
2018-06-13 02:06:59 +00:00
|
|
|
if s.feeds[t] == nil {
|
|
|
|
s.feeds[t] = new(event.Feed)
|
|
|
|
}
|
2018-07-25 16:11:15 +00:00
|
|
|
|
2018-06-21 03:03:02 +00:00
|
|
|
return s.feeds[t]
|
2018-06-13 02:06:59 +00:00
|
|
|
}
|