|
@ -26,13 +26,13 @@ type Reactor interface { |
|
|
//--------------------------------------
|
|
|
//--------------------------------------
|
|
|
|
|
|
|
|
|
type BaseReactor struct { |
|
|
type BaseReactor struct { |
|
|
QuitService // Provides Start, Stop, .Quit
|
|
|
|
|
|
|
|
|
BaseService // Provides Start, Stop, .Quit
|
|
|
Switch *Switch |
|
|
Switch *Switch |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func NewBaseReactor(log log15.Logger, name string, impl Reactor) *BaseReactor { |
|
|
func NewBaseReactor(log log15.Logger, name string, impl Reactor) *BaseReactor { |
|
|
return &BaseReactor{ |
|
|
return &BaseReactor{ |
|
|
QuitService: *NewQuitService(log, name, impl), |
|
|
|
|
|
|
|
|
BaseService: *NewBaseService(log, name, impl), |
|
|
Switch: nil, |
|
|
Switch: nil, |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -195,8 +195,10 @@ func (sw *Switch) OnStop() { |
|
|
// NOTE: This performs a blocking handshake before the peer is added.
|
|
|
// NOTE: This performs a blocking handshake before the peer is added.
|
|
|
// CONTRACT: Iff error is returned, peer is nil, and conn is immediately closed.
|
|
|
// CONTRACT: Iff error is returned, peer is nil, and conn is immediately closed.
|
|
|
func (sw *Switch) AddPeerWithConnection(conn net.Conn, outbound bool) (*Peer, error) { |
|
|
func (sw *Switch) AddPeerWithConnection(conn net.Conn, outbound bool) (*Peer, error) { |
|
|
|
|
|
|
|
|
// Filter by addr (ie. ip:port)
|
|
|
// Filter by addr (ie. ip:port)
|
|
|
if err := sw.FilterConnByAddr(conn.RemoteAddr()); err != nil { |
|
|
if err := sw.FilterConnByAddr(conn.RemoteAddr()); err != nil { |
|
|
|
|
|
conn.Close() |
|
|
return nil, err |
|
|
return nil, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -217,6 +219,7 @@ func (sw *Switch) AddPeerWithConnection(conn net.Conn, outbound bool) (*Peer, er |
|
|
|
|
|
|
|
|
// Filter by p2p-key
|
|
|
// Filter by p2p-key
|
|
|
if err := sw.FilterConnByPubKey(sconn.(*SecretConnection).RemotePubKey()); err != nil { |
|
|
if err := sw.FilterConnByPubKey(sconn.(*SecretConnection).RemotePubKey()); err != nil { |
|
|
|
|
|
sconn.Close() |
|
|
return nil, err |
|
|
return nil, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -466,30 +469,45 @@ func MakeConnectedSwitches(n int, initSwitch func(int, *Switch) *Switch, connect |
|
|
switches[i] = makeSwitch(i, "testing", "123.123.123", initSwitch) |
|
|
switches[i] = makeSwitch(i, "testing", "123.123.123", initSwitch) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if err := StartSwitches(switches); err != nil { |
|
|
|
|
|
panic(err) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
for i := 0; i < n; i++ { |
|
|
for i := 0; i < n; i++ { |
|
|
for j := i; j < n; j++ { |
|
|
for j := i; j < n; j++ { |
|
|
connect(switches, i, j) |
|
|
connect(switches, i, j) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
// Wait for things to happen, peers to get added...
|
|
|
|
|
|
// TODO: better
|
|
|
|
|
|
time.Sleep(100 * time.Millisecond * time.Duration(n*n)) |
|
|
|
|
|
|
|
|
|
|
|
if err := StartSwitches(switches); err != nil { |
|
|
|
|
|
panic(err) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return switches |
|
|
return switches |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var PanicOnAddPeerErr = false |
|
|
|
|
|
|
|
|
// Will connect switches i and j via net.Pipe()
|
|
|
// Will connect switches i and j via net.Pipe()
|
|
|
|
|
|
// Blocks until a conection is established.
|
|
|
// NOTE: caller ensures i and j are within bounds
|
|
|
// NOTE: caller ensures i and j are within bounds
|
|
|
func Connect2Switches(switches []*Switch, i, j int) { |
|
|
func Connect2Switches(switches []*Switch, i, j int) { |
|
|
switchI := switches[i] |
|
|
switchI := switches[i] |
|
|
switchJ := switches[j] |
|
|
switchJ := switches[j] |
|
|
c1, c2 := net.Pipe() |
|
|
c1, c2 := net.Pipe() |
|
|
go switchI.AddPeerWithConnection(c1, false) // AddPeer is blocking, requires handshake.
|
|
|
|
|
|
go switchJ.AddPeerWithConnection(c2, true) |
|
|
|
|
|
|
|
|
doneCh := make(chan struct{}) |
|
|
|
|
|
go func() { |
|
|
|
|
|
_, err := switchI.AddPeerWithConnection(c1, false) // AddPeer is blocking, requires handshake.
|
|
|
|
|
|
if PanicOnAddPeerErr && err != nil { |
|
|
|
|
|
panic(err) |
|
|
|
|
|
} |
|
|
|
|
|
doneCh <- struct{}{} |
|
|
|
|
|
}() |
|
|
|
|
|
go func() { |
|
|
|
|
|
_, err := switchJ.AddPeerWithConnection(c2, true) |
|
|
|
|
|
if PanicOnAddPeerErr && err != nil { |
|
|
|
|
|
panic(err) |
|
|
|
|
|
} |
|
|
|
|
|
doneCh <- struct{}{} |
|
|
|
|
|
}() |
|
|
|
|
|
<-doneCh |
|
|
|
|
|
<-doneCh |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func StartSwitches(switches []*Switch) error { |
|
|
func StartSwitches(switches []*Switch) error { |
|
|