Skip to content

Commit

Permalink
adopted ViewProfile to be used in search interface to fetch local pro…
Browse files Browse the repository at this point in the history
…file

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@2021 6c8d7289-2bf4-0310-a012-ef5d649a1542
  • Loading branch information
orbiter committed Apr 11, 2006
1 parent 41afcca commit b007563
Show file tree
Hide file tree
Showing 3 changed files with 116 additions and 76 deletions.
12 changes: 12 additions & 0 deletions htroot/ViewProfile.html
Expand Up @@ -5,9 +5,17 @@
#%env/templates/metas.template%#
</head>
<body marginheight="0" marginwidth="0" leftmargin="0" topmargin="0">
#(display)#
#%env/templates/simpleheader.template%#
::
#%env/templates/header.template%#
#(/display)#
<br><br>
#(localremotepeer)#
<h2>Local Peer Profile:</h2>
::
<h2>Remote Peer Profile:</h2>
#(/localremotepeer)#
<p>
#(success)#
Wrong access of this page
Expand Down Expand Up @@ -80,6 +88,10 @@ <h2>Remote Peer Profile:</h2>

</table>
#(/success)#
#(display)#
#%env/templates/simplefooter.template%#
::
#%env/templates/footer.template%#
#(/display)#
</body>
</html>
178 changes: 103 additions & 75 deletions htroot/ViewProfile.java
Expand Up @@ -45,11 +45,14 @@
// javac -classpath .:../Classes Blacklist_p.java
// if the shell's current path is HTROOT

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Properties;

import de.anomic.http.httpHeader;
import de.anomic.plasma.plasmaSwitchboard;
Expand All @@ -65,99 +68,124 @@
public class ViewProfile {

public static serverObjects respond(httpHeader header, serverObjects post, serverSwitch env) {
//listManager.switchboard = (plasmaSwitchboard) env;
serverObjects prop = new serverObjects();
plasmaSwitchboard switchboard = (plasmaSwitchboard) env;
wikiCode wikiTransformer = new wikiCode(switchboard);
// listManager.switchboard = (plasmaSwitchboard) env;
serverObjects prop = new serverObjects();
plasmaSwitchboard switchboard = (plasmaSwitchboard) env;
wikiCode wikiTransformer = new wikiCode(switchboard);
boolean authenticated = switchboard.adminAuthenticated(header) >= 2;
int display = ((post == null) || (!authenticated)) ? 0 : post.getInt("display", 0);
prop.put("display", display);
String hash = (post == null) ? null : (String) post.get("hash");

if ((post != null) && (post.containsKey("hash")) && (yacyCore.seedDB != null)) { //no nullpointer error..
yacySeed seed = yacyCore.seedDB.getConnected((String)post.get("hash"));
if ((hash == null) || (yacyCore.seedDB == null)) {
// wrong access
prop.put("success","0");
return prop;
}

// get the profile
HashMap profile = null;
if (hash.equals("localhash")) {
// read the profile from local peer
Properties p = new Properties();
FileInputStream fileIn = null;
try {
fileIn = new FileInputStream(new File("DATA/SETTINGS/profile.txt"));
p.load(fileIn);
} catch(IOException e) {} finally {
if (fileIn != null) try { fileIn.close(); fileIn = null; } catch (Exception e) {}
}
profile = new HashMap();
profile.putAll(p);
prop.put("success", "3"); // everything ok
prop.put("localremotepeer", 0);
prop.put("success_peername", yacyCore.seedDB.mySeed.getName());
} else {
// read the profile from remote peer
yacySeed seed = yacyCore.seedDB.getConnected(hash);
if (seed == null) {
seed = yacyCore.seedDB.getDisconnected((String)post.get("hash"));
seed = yacyCore.seedDB.getDisconnected(hash);
if (seed == null) {
prop.put("success","1"); // peer unknown
prop.put("success", "1"); // peer unknown
} else {
prop.put("success","2"); // peer known, but disconnected
prop.put("success", "2"); // peer known, but disconnected
prop.put("success_peername", seed.getName());
}
} else {
prop.put("success","3"); // everything ok
prop.put("success", "3"); // everything ok
// process news if existent
try {
yacyNewsRecord record = yacyCore.newsPool.getByOriginator(yacyNewsPool.INCOMING_DB, "prfleupd", seed.hash);
if (record != null) yacyCore.newsPool.moveOff(yacyNewsPool.INCOMING_DB, record.id());
} catch (IOException e) {}

// read profile from other peer
HashMap profile = yacyClient.getProfile(seed);
profile = yacyClient.getProfile(seed);
yacyCore.log.logInfo("fetched profile:" + profile);
Iterator i;
if(profile != null){
i = profile.entrySet().iterator();
}else{
i = (new ArrayList()).iterator();
}
Map.Entry entry;
//all known keys which should be set as they are
ArrayList knownKeys = new ArrayList();
knownKeys.add("name");
knownKeys.add("nickname");
//knownKeys.add("homepage");//+http
knownKeys.add("email");
knownKeys.add("icq");
knownKeys.add("jabber");
knownKeys.add("yahoo");
knownKeys.add("msn");
knownKeys.add("comment");

//empty values
Iterator it=knownKeys.iterator();
while(it.hasNext()){
prop.put("success_"+(String)it.next(), 0);
}

//number of not explicitly recognized but displayed items
int numUnknown=0;
while (i.hasNext()) {
entry = (Map.Entry) i.next();
String key=(String)entry.getKey();
String value=new String();

//only comments get "wikified"
//this prevents broken links ending in <br>
if(key.equals("comment")){
value=wikiTransformer.transform( ((String)entry.getValue()).replaceAll("\r","").replaceAll("\\\\n","\n") );
}
//else only HTML tags get transformed to regular text
else{
value=wikiCode.replaceHTML( ((String)entry.getValue()).replaceAll("\r","").replaceAll("\\\\n","\n") );
}
}
prop.put("localremotepeer", 1);
prop.put("success_peername", seed.getName());
}
Iterator i;
if (profile != null) {
i = profile.entrySet().iterator();
} else {
i = (new ArrayList()).iterator();
}
Map.Entry entry;
// all known keys which should be set as they are
ArrayList knownKeys = new ArrayList();
knownKeys.add("name");
knownKeys.add("nickname");
// knownKeys.add("homepage");//+http
knownKeys.add("email");
knownKeys.add("icq");
knownKeys.add("jabber");
knownKeys.add("yahoo");
knownKeys.add("msn");
knownKeys.add("comment");

//empty values
Iterator it = knownKeys.iterator();
while (it.hasNext()) {
prop.put("success_" + (String) it.next(), 0);
}

//number of not explicitly recognized but displayed items
int numUnknown = 0;
while (i.hasNext()) {
entry = (Map.Entry) i.next();
String key = (String) entry.getKey();
String value = new String();

//all known Keys which should be set as they are
if(knownKeys.contains(key)){
prop.put("success_"+key, 1);
prop.put("success_"+key+"_value", value);
//special handling, hide flower if no icq uin is set
}else if(key.equals("homepage")){
if(! (value.startsWith("http")) ){
value="http://"+value;
}
prop.put("success_"+key, 1);
prop.put("success_"+key+"_value", value);
//This will display unknown items(of newer versions) as plaintext
}else{//unknown
prop.put("success_other_"+numUnknown+"_key", key);
prop.put("success_other_"+numUnknown+"_value", value);
numUnknown++;
}
// only comments get "wikified"
// this prevents broken links ending in <br>
if (key.equals("comment")) {
value = wikiTransformer.transform(((String) entry.getValue()).replaceAll("\r", "").replaceAll("\\\\n", "\n"));
} else { // else only HTML tags get transformed to regular text
value = wikiCode.replaceHTML(((String) entry.getValue()).replaceAll("\r", "").replaceAll("\\\\n", "\n"));
}

//all known Keys which should be set as they are
if (knownKeys.contains(key)) {
prop.put("success_" + key, 1);
prop.put("success_" + key + "_value", value);
//special handling, hide flower if no icq uin is set
} else if (key.equals("homepage")) {
if (!(value.startsWith("http"))) {
value = "http://" + value;
}
prop.put("success_other", numUnknown);
//prop.putAll(profile);
prop.put("success_peername", seed.getName());
prop.put("success_" + key, 1);
prop.put("success_" + key + "_value", value);
//This will display unknown items(of newer versions) as plaintext
} else {
//unknown
prop.put("success_other_" + numUnknown + "_key", key);
prop.put("success_other_" + numUnknown + "_value", value);
numUnknown++;
}
} else {
prop.put("success","0"); // wrong access
}
prop.put("success_other", numUnknown);

return prop;
}
Expand Down
2 changes: 1 addition & 1 deletion htroot/env/templates/simpleheader.template
Expand Up @@ -22,6 +22,6 @@
<a href="http://www.yacy-websearch.net/wiki/" class="MenuItemLink">Help / Wiki</a>&nbsp;</td>
<td class="MenuSubSpacer"></td>
<td width="25%" class="MenuSubItem">&nbsp;
<a href="/ConfigProfile_p.html" class="MenuItemLink">Peer Owner Profile</a>&nbsp;</td>
<a href="/ViewProfile.html?hash=localhash" class="MenuItemLink">Peer Owner Profile</a>&nbsp;</td>
</tr>
</table><br>

0 comments on commit b007563

Please sign in to comment.