// Messages_p.java
// -----------------------
// part of the AnomicHTTPD caching proxy
// (C) by Michael Peter Christen; mc@yacy.net
// first published on http://www.anomic.de
// Frankfurt, Germany, 2004
// last major change: 28.06.2003
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
// You must compile this file with
// javac -classpath .:../Classes Message.java
// if the shell's current path is HTROOT
import java.io.File;
import java.io.IOException;
import java.util.Date;
import java.util.Iterator;
import java.util.TreeMap;
import net.yacy.cora.date.GenericFormatter;
import net.yacy.cora.document.encoding.UTF8;
import net.yacy.cora.protocol.HeaderFramework;
import net.yacy.cora.protocol.RequestHeader;
import net.yacy.data.MessageBoard;
import net.yacy.http.servlets.YaCyDefaultServlet;
import net.yacy.peers.Seed;
import net.yacy.search.Switchboard;
import net.yacy.search.SwitchboardConstants;
import net.yacy.server.serverObjects;
import net.yacy.server.serverSwitch;
import com.google.common.io.Files;
public class Messages_p {
private static final String PEERSKNOWN = "peersKnown_";
public static String dateString(final Date date) {
return GenericFormatter.SIMPLE_FORMATTER.format(date);
}
public static serverObjects respond(final RequestHeader header, final serverObjects post, final serverSwitch env) {
final Switchboard sb = (Switchboard) env;
final serverObjects prop = new serverObjects();
/* Peer URL base : used by Messages_p.rss to render absolute URL links to this peer */
final String context = YaCyDefaultServlet.getContext(header, sb);
final String peerName = sb.peers.mySeed().getName();
prop.put("context", context);
prop.putXML("peerName", peerName);
// List known hosts for message sending (from Blacklist_p.java)
if (sb.peers != null && sb.peers.sizeConnected() > 0) {
prop.put("peersKnown", "1");
int peerCount = 0;
try {
final TreeMap<String, String> hostList = new TreeMap<String, String>();
final Iterator<Seed> e = sb.peers.seedsConnected(true, false, null, (float) 0.0);
while (e.hasNext()) {
final Seed seed = e.next();
if (seed != null) hostList.put(seed.get(Seed.NAME, "nameless"),seed.hash);
}
String peername;
while ((peername = hostList.firstKey()) != null) {
final String Hash = hostList.get(peername);
prop.put(PEERSKNOWN + "peers_" + peerCount + "_hash", Hash);
prop.putXML(PEERSKNOWN + "peers_" + peerCount + "_name", peername);
hostList.remove(peername);
peerCount++;
}
} catch (final Exception e) {/* */}
prop.put(PEERSKNOWN + "peers", peerCount);
} else {
prop.put("peersKnown", "0");
}
prop.put("mode", "0");
prop.put("mode_error", "0");
String action = ((post == null) ? "list" : post.get("action", "list"));
MessageBoard.entry message;
// first reset notification
final File notifierSource = new File(sb.getAppPath(), sb.getConfig(SwitchboardConstants.HTROOT_PATH, SwitchboardConstants.HTROOT_PATH_DEFAULT) + "/env/grafics/empty.gif");
final File notifierDest = new File(sb.getDataPath(SwitchboardConstants.HTDOCS_PATH, SwitchboardConstants.HTDOCS_PATH_DEFAULT), "notifier.gif");
try {
Files.copy(notifierSource, notifierDest);
} catch (final IOException e) {
}
if (action.equals("delete")) {
final String key = (post == null ? "" : post.get("object", ""));
sb.messageDB.remove(key);
action = "list";
}
if (action.equals("list")) {
prop.put("mode", "0"); //list
try {
final Iterator<String> i = sb.messageDB.keys(null, true);
String key;
boolean dark = true;
int count=0;
while (i.hasNext()) {
key = i.next();
message = sb.messageDB.read(key);
prop.put("mode_messages_"+count+"_dark", ((dark) ? "1" : "0") );
prop.put("mode_messages_"+count+"_date", dateString(message.date()));
prop.putXML("mode_messages_"+count+"_from", message.author());
prop.putXML("mode_messages_"+count+"_to", message.recipient());
prop.putXML("mode_messages_"+count+"_subject", message.subject());
prop.putXML("mode_messages_"+count+"_category", message.category());
prop.putXML("mode_messages_"+count+"_key", key);
prop.put("mode_messages_"+count+"_hash", message.authorHash());
if (header.getPathInfo().endsWith(".rss")) {
// set the peer address
prop.put("mode_messages_"+count+"_context", context);
// set the rfc822 date
prop.put("mode_messages_"+count+"_rfc822Date", HeaderFramework.formatRFC1123(message.date()));
prop.putXML("mode_messages_"+count+"_body",UTF8.String(message.message()));
}
dark = !dark;
count++;
}
prop.put("mode_messages", count);
} catch (final IOException e) {
prop.put("mode_error", "1");//I/O error reading message table
prop.putHTML("mode_error_message", e.getMessage());
}
}
if (action.equals("view")) {
prop.put("mode", "1"); //view
final String key = (post == null ? "" : post.get("object", ""));
message = sb.messageDB.read(key);
if (message == null) throw new NullPointerException("Message with ID " + key + " does not exist");
prop.putXML("mode_from", message.author());
prop.putXML("mode_to", message.recipient());
prop.put("mode_date", dateString(message.date()));
prop.putXML("mode_subject", message.subject());
String theMessage = null;
theMessage = UTF8.String(message.message());
prop.putWiki("mode_message", theMessage);
prop.put("mode_hash", message.authorHash());
prop.putXML("mode_key", key);
}
// return rewrite properties
return prop;
}
}