2006-11-30 22:39:24 +00:00
|
|
|
|
2006-12-03 01:27:18 +00:00
|
|
|
from foolscap import Referenceable
|
2006-12-01 01:09:57 +00:00
|
|
|
from foolscap.eventual import eventually
|
2006-11-30 22:39:24 +00:00
|
|
|
from twisted.application import service
|
|
|
|
from twisted.python import log
|
2006-12-02 23:26:26 +00:00
|
|
|
from allmydata.util import idlib
|
2006-12-02 02:17:50 +00:00
|
|
|
from zope.interface import implements
|
|
|
|
from allmydata.interfaces import RIQueenRoster
|
2006-12-03 01:27:18 +00:00
|
|
|
from allmydata import node
|
2006-11-30 22:39:24 +00:00
|
|
|
|
|
|
|
class Roster(service.MultiService, Referenceable):
|
2006-12-02 02:17:50 +00:00
|
|
|
implements(RIQueenRoster)
|
|
|
|
|
2006-12-01 00:43:15 +00:00
|
|
|
def __init__(self):
|
|
|
|
service.MultiService.__init__(self)
|
2006-12-01 01:09:57 +00:00
|
|
|
self.phonebook = {}
|
|
|
|
self.connections = {}
|
2006-12-01 00:43:15 +00:00
|
|
|
|
2006-12-01 01:09:57 +00:00
|
|
|
def remote_hello(self, nodeid, node, pburl):
|
2006-12-02 23:26:26 +00:00
|
|
|
log.msg("contact from %s" % idlib.b2a(nodeid))
|
2006-12-01 01:09:57 +00:00
|
|
|
eventually(self._educate_the_new_peer, node)
|
|
|
|
eventually(self._announce_new_peer, nodeid, pburl)
|
|
|
|
self.phonebook[nodeid] = pburl
|
|
|
|
self.connections[nodeid] = node
|
2006-12-01 00:43:15 +00:00
|
|
|
node.notifyOnDisconnect(self._lost_node, nodeid)
|
|
|
|
|
2006-12-01 01:09:57 +00:00
|
|
|
def _educate_the_new_peer(self, node):
|
|
|
|
node.callRemote("add_peers", new_peers=list(self.phonebook.items()))
|
|
|
|
|
|
|
|
def _announce_new_peer(self, new_nodeid, new_node_pburl):
|
|
|
|
for targetnode in self.connections.values():
|
|
|
|
targetnode.callRemote("add_peers",
|
|
|
|
new_peers=[(new_nodeid, new_node_pburl)])
|
|
|
|
|
2006-12-01 00:43:15 +00:00
|
|
|
def _lost_node(self, nodeid):
|
2006-12-02 23:26:26 +00:00
|
|
|
log.msg("lost contact with %s" % idlib.b2a(nodeid))
|
2006-12-01 01:09:57 +00:00
|
|
|
del self.phonebook[nodeid]
|
|
|
|
del self.connections[nodeid]
|
|
|
|
eventually(self._announce_lost_peer, nodeid)
|
|
|
|
|
|
|
|
def _announce_lost_peer(self, lost_nodeid):
|
|
|
|
for targetnode in self.connections.values():
|
|
|
|
targetnode.callRemote("lost_peers", lost_peers=[lost_nodeid])
|
|
|
|
|
2006-12-01 00:43:15 +00:00
|
|
|
|
2006-11-30 22:39:24 +00:00
|
|
|
|
2006-12-03 01:27:18 +00:00
|
|
|
class Queen(node.Node):
|
2006-11-30 22:39:24 +00:00
|
|
|
CERTFILE = "queen.pem"
|
2006-11-30 23:39:38 +00:00
|
|
|
PORTNUMFILE = "queen.port"
|
2006-12-03 01:27:18 +00:00
|
|
|
NODETYPE = "queen"
|
2006-11-30 22:39:24 +00:00
|
|
|
|
2006-12-03 01:27:18 +00:00
|
|
|
def __init__(self, basedir="."):
|
|
|
|
node.Node.__init__(self, basedir)
|
2006-11-30 22:39:24 +00:00
|
|
|
self.urls = {}
|
2006-12-01 02:38:38 +00:00
|
|
|
|
2006-12-03 01:27:18 +00:00
|
|
|
def tub_ready(self, tub):
|
|
|
|
r = self.add_service(Roster())
|
2006-11-30 23:39:38 +00:00
|
|
|
self.urls["roster"] = self.tub.registerReference(r, "roster")
|
|
|
|
log.msg(" roster is at %s" % self.urls["roster"])
|
2006-11-30 22:39:24 +00:00
|
|
|
|