ipv6 fix for api /yacy/seedlist.[json|xml], multiple IPs are now

attached to the seed info. API clients must be adopted. Documentation
will be fixed in
http://www.yacy-websuche.de/wiki/index.php/Dev:APIseedlist

Also added a new retrieval option for seeds, they can now be retrieved
by their name with the get parameter name=<name>
pull/1/head
Michael Peter Christen 10 years ago
parent 0f0b60404b
commit 8098a86f1d

@ -21,6 +21,7 @@
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Map; import java.util.Map;
import java.util.Set;
import net.yacy.cora.protocol.RequestHeader; import net.yacy.cora.protocol.RequestHeader;
import net.yacy.peers.Seed; import net.yacy.peers.Seed;
@ -59,6 +60,10 @@ public final class seedlist {
v = new ArrayList<Seed>(1); v = new ArrayList<Seed>(1);
Seed s = sb.peers.get(post.get("id")); Seed s = sb.peers.get(post.get("id"));
if (s != null) v.add(s); if (s != null) v.add(s);
} else if (post != null && post.containsKey("name")) {
v = new ArrayList<Seed>(1);
Seed s = sb.peers.lookupByName(post.get("name"));
if (s != null) v.add(s);
} else { } else {
v= sb.peers.getSeedlist(maxcount, includeme, nodeonly, minversion); v= sb.peers.getSeedlist(maxcount, includeme, nodeonly, minversion);
} }
@ -83,6 +88,8 @@ public final class seedlist {
for (int i = 0; i < v.size(); i++) { for (int i = 0; i < v.size(); i++) {
Seed seed = v.get(i); Seed seed = v.get(i);
if (peername != null && !peername.equals(seed.getName())) continue; if (peername != null && !peername.equals(seed.getName())) continue;
Set<String> ips = seed.getIPs();
if (ips == null || ips.size() == 0) continue;
prop.putJSON("peers_" + count + "_map_0_k", Seed.HASH); prop.putJSON("peers_" + count + "_map_0_k", Seed.HASH);
prop.putJSON("peers_" + count + "_map_0_v", seed.hash); prop.putJSON("peers_" + count + "_map_0_v", seed.hash);
prop.put("peers_" + count + "_map_0_c", 1); prop.put("peers_" + count + "_map_0_c", 1);
@ -91,13 +98,18 @@ public final class seedlist {
if (!addressonly) { if (!addressonly) {
for (Map.Entry<String, String> m: map.entrySet()) { for (Map.Entry<String, String> m: map.entrySet()) {
prop.putJSON("peers_" + count + "_map_" + c + "_k", m.getKey()); prop.putJSON("peers_" + count + "_map_" + c + "_k", m.getKey());
prop.putJSON("peers_" + count + "_map_" + c + "_v", m.getValue()); prop.put("peers_" + count + "_map_" + c + "_v", '"' + serverObjects.toJSON(m.getValue()) + '"');
prop.put("peers_" + count + "_map_" + c + "_c", 1); prop.put("peers_" + count + "_map_" + c + "_c", 1);
c++; c++;
} }
} }
// construct a list of ips
StringBuilder a = new StringBuilder();
a.append('[');
for (String ip: ips) a.append('"').append(serverObjects.toJSON(seed.getPublicAddress(ip))).append('"').append(',');
a.setCharAt(a.length()-1, ']');
prop.putJSON("peers_" + count + "_map_" + c + "_k", "Address"); prop.putJSON("peers_" + count + "_map_" + c + "_k", "Address");
prop.putJSON("peers_" + count + "_map_" + c + "_v", seed.getPublicAddress(seed.getIP())); prop.put("peers_" + count + "_map_" + c + "_v", a.toString());
prop.put("peers_" + count + "_map_" + c + "_c", 0); prop.put("peers_" + count + "_map_" + c + "_c", 0);
prop.put("peers_" + count + "_map", c + 1); prop.put("peers_" + count + "_map", c + 1);
prop.put("peers_" + count + "_c", 1); prop.put("peers_" + count + "_c", 1);
@ -111,9 +123,10 @@ public final class seedlist {
for (int i = 0; i < v.size(); i++) { for (int i = 0; i < v.size(); i++) {
Seed seed = v.get(i); Seed seed = v.get(i);
if (peername != null && !peername.equals(seed.getName())) continue; if (peername != null && !peername.equals(seed.getName())) continue;
Set<String> ips = seed.getIPs();
if (ips == null || ips.size() == 0) continue;
prop.putXML("peers_" + count + "_map_0_k", Seed.HASH); prop.putXML("peers_" + count + "_map_0_k", Seed.HASH);
prop.putXML("peers_" + count + "_map_0_v", seed.hash); prop.putXML("peers_" + count + "_map_0_v", seed.hash);
prop.put("peers_" + count + "_map_0_c", 1);
Map<String, String> map = seed.getMap(); Map<String, String> map = seed.getMap();
int c = 1; int c = 1;
if (!addressonly) { if (!addressonly) {
@ -123,10 +136,12 @@ public final class seedlist {
c++; c++;
} }
} }
prop.putXML("peers_" + count + "_map_" + c + "_k", "Address"); for (String ip: ips) {
prop.putXML("peers_" + count + "_map_" + c + "_v", seed.getPublicAddress(seed.getIP())); prop.putXML("peers_" + count + "_map_" + c + "_k", "Address");
prop.put("peers_" + count + "_map_" + c + "_c", 0); prop.putXML("peers_" + count + "_map_" + c + "_v", seed.getPublicAddress(ip));
prop.put("peers_" + count + "_map", c + 1); c++;
}
prop.put("peers_" + count + "_map", c);
count++; count++;
} }

@ -1,6 +1,6 @@
#[jsonp-start]#{ #[jsonp-start]#{
"peers":[#{peers}#{ "peers":[#{peers}#{
#{map}#"#[k]#":"#[v]#"#(c)#::,#(/c)# #{map}#"#[k]#":#[v]##(c)#::,#(/c)#
#{/map}#}#(c)#::,#(/c)##{/peers}# #{/map}#}#(c)#::,#(/c)##{/peers}#
] ]
}#[jsonp-end]# }#[jsonp-end]#
Loading…
Cancel
Save