added more properties to seedlist servlet

pull/1/head
Michael Peter Christen 11 years ago
parent 79771c60c0
commit 67e7dc0cc6

@ -36,6 +36,7 @@ import net.yacy.server.serverSwitch;
* or to generate json (or jsonp) with * or to generate json (or jsonp) with
* http://localhost:8090/yacy/seedlist.json * http://localhost:8090/yacy/seedlist.json
* http://localhost:8090/yacy/seedlist.json?callback=seedlist * http://localhost:8090/yacy/seedlist.json?callback=seedlist
* http://localhost:8090/yacy/seedlist.json?node=true&me=false&address=true
*/ */
public final class seedlist { public final class seedlist {
@ -45,7 +46,10 @@ public final class seedlist {
// return variable that accumulates replacements // return variable that accumulates replacements
final Switchboard sb = (Switchboard) env; final Switchboard sb = (Switchboard) env;
int maxcount = Math.min(LISTMAX, post == null ? Integer.MAX_VALUE : post.getInt("maxcount", Integer.MAX_VALUE)); int maxcount = Math.min(LISTMAX, post == null ? Integer.MAX_VALUE : post.getInt("maxcount", Integer.MAX_VALUE));
final ArrayList<Seed> v = sb.peers.getSeedlist(maxcount, true); boolean nodeonly = post == null || !post.containsKey("node") ? false : post.getBoolean("node");
boolean includeme = post == null || !post.containsKey("me") ? true : post.getBoolean("me");
boolean addressonly = post == null || !post.containsKey("address") ? false : post.getBoolean("address");
final ArrayList<Seed> v = sb.peers.getSeedlist(maxcount, includeme, nodeonly);
final serverObjects prop = new serverObjects(); final serverObjects prop = new serverObjects();
// write simple-encoded seed lines or json // write simple-encoded seed lines or json
@ -66,16 +70,21 @@ public final class seedlist {
prop.putJSON("peers_" + i + "_map_0_k", Seed.HASH); prop.putJSON("peers_" + i + "_map_0_k", Seed.HASH);
prop.putJSON("peers_" + i + "_map_0_v", v.get(i).hash); prop.putJSON("peers_" + i + "_map_0_v", v.get(i).hash);
prop.put("peers_" + i + "_map_0_c", 1); prop.put("peers_" + i + "_map_0_c", 1);
Map<String, String> map = v.get(i).getMap(); Seed seed = v.get(i);
Map<String, String> map = seed.getMap();
int c = 1; int c = 1;
for (Map.Entry<String, String> m: map.entrySet()) { if (!addressonly) {
prop.putJSON("peers_" + i + "_map_" + c + "_k", m.getKey()); for (Map.Entry<String, String> m: map.entrySet()) {
prop.putJSON("peers_" + i + "_map_" + c + "_v", m.getValue()); prop.putJSON("peers_" + i + "_map_" + c + "_k", m.getKey());
prop.put("peers_" + i + "_map_" + c + "_c", 1); prop.putJSON("peers_" + i + "_map_" + c + "_v", m.getValue());
c++; prop.put("peers_" + i + "_map_" + c + "_c", 1);
c++;
}
} }
prop.put("peers_" + i + "_map_" + (c - 1) + "_c", 0); prop.putJSON("peers_" + i + "_map_" + c + "_k", "Address");
prop.put("peers_" + i + "_map", c); prop.putJSON("peers_" + i + "_map_" + c + "_v", seed.getPublicAddress());
prop.put("peers_" + i + "_map_" + c + "_c", 0);
prop.put("peers_" + i + "_map", c + 1);
prop.put("peers_" + i + "_c", i < v.size() - 1 ? 1 : 0); prop.put("peers_" + i + "_c", i < v.size() - 1 ? 1 : 0);
} }
prop.put("peers", v.size()); prop.put("peers", v.size());

Loading…
Cancel
Save