From 8e03d19ccc249cac396a1395f134a8ea82fcad3c Mon Sep 17 00:00:00 2001 From: Brian Warner <warner@allmydata.com> Date: Tue, 16 Jan 2007 21:01:18 -0700 Subject: [PATCH] webish: add PBURL to the all-peers table on the welcome page --- src/allmydata/client.py | 4 ++++ src/allmydata/web/welcome.xhtml | 2 ++ src/allmydata/webish.py | 22 ++++++++++++++++------ 3 files changed, 22 insertions(+), 6 deletions(-) diff --git a/src/allmydata/client.py b/src/allmydata/client.py index 0fe2c7e6..41801695 100644 --- a/src/allmydata/client.py +++ b/src/allmydata/client.py @@ -29,6 +29,7 @@ class Client(node.Node, Referenceable): node.Node.__init__(self, basedir) self.queen = None # self.queen is either None or a RemoteReference self.all_peers = set() + self.peer_pburls = {} self.connections = {} self.add_service(StorageServer(os.path.join(basedir, self.STOREDIR))) self.add_service(Uploader()) @@ -105,6 +106,7 @@ class Client(node.Node, Referenceable): self.log("weird, I already had an entry for them") return self.all_peers.add(nodeid) + self.peer_pburls[nodeid] = pburl if nodeid not in self.connections: d = self.tub.getReference(pburl) def _got_reference(ref, which_nodeid): @@ -122,6 +124,8 @@ class Client(node.Node, Referenceable): self.all_peers.remove(nodeid) else: self.log("weird, I didn't have an entry for them") + if nodeid in self.peer_pburls: + del self.peer_pburls[nodeid] if nodeid in self.connections: del self.connections[nodeid] diff --git a/src/allmydata/web/welcome.xhtml b/src/allmydata/web/welcome.xhtml index 7adb96ae..d162a01f 100644 --- a/src/allmydata/web/welcome.xhtml +++ b/src/allmydata/web/welcome.xhtml @@ -24,10 +24,12 @@ <tr n:pattern="header"> <td>PeerID</td> <td>Connected?</td> + <td>PBURL</td> </tr> <tr n:pattern="item" n:render="row"> <td><tt><n:slot name="peerid"/></tt></td> <td><n:slot name="connected"/></td> + <td><n:slot name="pburl"/></td> </tr> <tr n:pattern="empty"><td>no peers!</td></tr> </table> diff --git a/src/allmydata/webish.py b/src/allmydata/webish.py index d0569c9c..27332217 100644 --- a/src/allmydata/webish.py +++ b/src/allmydata/webish.py @@ -39,15 +39,25 @@ class Welcome(rend.Page): return len(client.all_peers) def data_num_connected_peers(self, ctx, data): return len(IClient(ctx).connections) + def data_peers(self, ctx, data): - return sorted(IClient(ctx).all_peers) + d = [] + client = IClient(ctx) + for nodeid in sorted(client.all_peers): + if nodeid in client.connections: + connected = "yes" + else: + connected = "no" + pburl = client.peer_pburls[nodeid] + row = (idlib.b2a(nodeid), connected, pburl) + d.append(row) + return d + def render_row(self, ctx, data): - if data in IClient(ctx).connections: - connected = "yes" - else: - connected = "no" - ctx.fillSlots("peerid", idlib.b2a(data)) + nodeid_a, connected, pburl = data + ctx.fillSlots("peerid", nodeid_a) ctx.fillSlots("connected", connected) + ctx.fillSlots("pburl", pburl) return ctx.tag # this is a form where users can download files by URI -- 2.45.2