mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Vendoring libnetwork @802895f
Signed-off-by: Alessandro Boch <aboch@docker.com>
This commit is contained in:
parent
e07c392c49
commit
9e555ce7c3
17 changed files with 159 additions and 141 deletions
19
vendor/github.com/docker/libnetwork/networkdb/event_delegate.go
generated
vendored
19
vendor/github.com/docker/libnetwork/networkdb/event_delegate.go
generated
vendored
|
@ -1,12 +1,28 @@
|
|||
package networkdb
|
||||
|
||||
import "github.com/hashicorp/memberlist"
|
||||
import (
|
||||
"encoding/json"
|
||||
"net"
|
||||
|
||||
"github.com/Sirupsen/logrus"
|
||||
"github.com/hashicorp/memberlist"
|
||||
)
|
||||
|
||||
type eventDelegate struct {
|
||||
nDB *NetworkDB
|
||||
}
|
||||
|
||||
func (e *eventDelegate) broadcastNodeEvent(addr net.IP, op opType) {
|
||||
value, err := json.Marshal(&NodeAddr{addr})
|
||||
if err == nil {
|
||||
e.nDB.broadcaster.Write(makeEvent(op, NodeTable, "", "", value))
|
||||
} else {
|
||||
logrus.Errorf("Error marshalling node broadcast event %s", addr.String())
|
||||
}
|
||||
}
|
||||
|
||||
func (e *eventDelegate) NotifyJoin(mn *memberlist.Node) {
|
||||
e.broadcastNodeEvent(mn.Addr, opCreate)
|
||||
e.nDB.Lock()
|
||||
// In case the node is rejoining after a failure or leave,
|
||||
// wait until an explicit join message arrives before adding
|
||||
|
@ -24,6 +40,7 @@ func (e *eventDelegate) NotifyJoin(mn *memberlist.Node) {
|
|||
}
|
||||
|
||||
func (e *eventDelegate) NotifyLeave(mn *memberlist.Node) {
|
||||
e.broadcastNodeEvent(mn.Addr, opDelete)
|
||||
e.nDB.deleteNodeTableEntries(mn.Name)
|
||||
e.nDB.deleteNetworkEntriesForNode(mn.Name)
|
||||
e.nDB.Lock()
|
||||
|
|
14
vendor/github.com/docker/libnetwork/networkdb/watch.go
generated
vendored
14
vendor/github.com/docker/libnetwork/networkdb/watch.go
generated
vendored
|
@ -1,6 +1,10 @@
|
|||
package networkdb
|
||||
|
||||
import "github.com/docker/go-events"
|
||||
import (
|
||||
"net"
|
||||
|
||||
"github.com/docker/go-events"
|
||||
)
|
||||
|
||||
type opType uint8
|
||||
|
||||
|
@ -17,6 +21,14 @@ type event struct {
|
|||
Value []byte
|
||||
}
|
||||
|
||||
// NodeTable represents table event for node join and leave
|
||||
const NodeTable = "NodeTable"
|
||||
|
||||
// NodeAddr represents the value carried for node event in NodeTable
|
||||
type NodeAddr struct {
|
||||
Addr net.IP
|
||||
}
|
||||
|
||||
// CreateEvent generates a table entry create event to the watchers
|
||||
type CreateEvent event
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue