// Settings.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 change: 02.05.2004 // // 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 Settings_p.java // if the shell's current path is HTROOT import java.util.Enumeration; import java.util.HashMap; import java.util.HashSet; import java.util.Iterator; import de.anomic.http.httpRequestHeader; import de.anomic.plasma.plasmaParser; import de.anomic.plasma.plasmaParserConfig; import de.anomic.plasma.plasmaSwitchboard; import de.anomic.plasma.parser.ParserInfo; import de.anomic.server.serverObjects; import de.anomic.server.serverSwitch; import de.anomic.yacy.yacyCore; import de.anomic.yacy.yacySeed; import de.anomic.yacy.yacySeedUploader; public final class Settings_p { public static serverObjects respond(final httpRequestHeader header, final serverObjects post, final serverSwitch env) { // return variable that accumulates replacements final serverObjects prop = new serverObjects(); final plasmaSwitchboard sb = (plasmaSwitchboard) env; //if (post == null) System.out.println("POST: NULL"); else System.out.println("POST: " + post.toString()); final String page = (post == null) ? "general" : post.get("page", "general"); if (page.equals("ProxyAccess")) { prop.put("settingsTables", "Settings_ProxyAccess.inc"); } else if (page.equals("http")) { prop.put("settingsTables", "Settings_Http.inc"); } else if (page.equals("proxy")) { prop.put("settingsTables", "Settings_Proxy.inc"); } else if (page.equals("ServerAccess")) { prop.put("settingsTables", "Settings_ServerAccess.inc"); } else if (page.equals("SystemBehaviour")) { prop.put("settingsTables", "Settings_SystemBehaviour.inc"); } else if (page.equals("seed")) { prop.put("settingsTables", "Settings_Seed.inc"); } else if (page.equals("messageForwarding")) { prop.put("settingsTables", "Settings_MessageForwarding.inc"); } else if (page.equals("parser")) { prop.put("settingsTables", "Settings_Parser.inc"); } else if (page.equals("crawler")) { prop.put("settingsTables", "Settings_Crawler.inc"); } else { prop.put("settingsTables", ""); } prop.put("port", env.getConfig("port", "8080")); prop.putHTML("peerName", env.getConfig("peerName", "nameless")); prop.putHTML("staticIP", env.getConfig("staticIP", "")); String peerLang = env.getConfig("locale.language", "default"); if (peerLang.equals("default")) peerLang = "en"; prop.putHTML("peerLang", peerLang); // http networking settings prop.put("isTransparentProxy", env.getConfig("isTransparentProxy", "false").equals("true") ? "1" : "0"); prop.put("connectionKeepAliveSupport", env.getConfig("connectionKeepAliveSupport", "false").equals("true") ? "1" : "0"); prop.put("proxy.sendViaHeader", env.getConfig("proxy.sendViaHeader", "false").equals("true") ? "1" : "0"); prop.put("proxy.sendXForwardedForHeader", env.getConfig("proxy.sendXForwardedForHeader", "true").equals("true") ? "1" : "0"); // set values String s; int pos; // admin password if (env.getConfig("adminAccountBase64", "").length() == 0) { // no password has been specified prop.put("adminuser","admin"); } else { s = env.getConfig("adminAccount", "admin:void"); pos = s.indexOf(":"); if (pos < 0) { prop.put("adminuser","admin"); } else { prop.put("adminuser",s.substring(0, pos)); } } // remote proxy prop.put("remoteProxyUseChecked", env.getConfig("remoteProxyUse", "false").equals("true") ? 1 : 0); prop.put("remoteProxyUse4Yacy", env.getConfig("remoteProxyUse4Yacy", "true").equals("true") ? 1 : 0); prop.put("remoteProxyUse4SSL", env.getConfig("remoteProxyUse4SSL", "true").equals("true") ? 1 : 0); prop.putHTML("remoteProxyHost", env.getConfig("remoteProxyHost", "")); prop.putHTML("remoteProxyPort", env.getConfig("remoteProxyPort", "")); prop.putHTML("remoteProxyUser", env.getConfig("remoteProxyUser", "")); prop.putHTML("remoteProxyPwd", env.getConfig("remoteProxyPwd", "")); prop.putHTML("remoteProxyNoProxy", env.getConfig("remoteProxyNoProxy", "")); // proxy access filter prop.putHTML("proxyfilter", env.getConfig("proxyClient", "*")); // proxy password if ( env.getConfig("use_proxyAccounts", "false").equals("false") ) { // no password has been specified prop.put("use_proxyAccounts", "0"); //unchecked } else { prop.put("use_proxyAccounts", "1"); //checked /*s = env.getConfig("proxyAccount", "proxy:void"); pos = s.indexOf(":"); if (pos < 0) { prop.put("proxyuser","proxy"); } else { prop.put("proxyuser",s.substring(0, pos)); }*/ } // server access filter prop.putHTML("serverfilter", env.getConfig("serverClient", "*")); // server password if (env.getConfig("serverAccountBase64", "").length() == 0) { // no password has been specified prop.put("serveruser","server"); } else { s = env.getConfig("serverAccount", "server:void"); pos = s.indexOf(":"); if (pos < 0) { prop.put("serveruser","server"); } else { prop.put("serveruser",s.substring(0, pos)); } } // clientIP prop.putHTML("clientIP", (String) header.get(httpRequestHeader.CONNECTION_PROP_CLIENTIP, ""), true); // read an artificial header addendum /* * seed upload settings */ // available methods String enabledUploader = env.getConfig("seedUploadMethod", "none"); // for backward compatiblity .... if ((enabledUploader.equalsIgnoreCase("Ftp")) || ((enabledUploader.equals("")) && (env.getConfig("seedFTPPassword","").length() > 0) && (env.getConfig("seedFilePath", "").length() > 0))) { enabledUploader = "Ftp"; env.setConfig("seedUploadMethod",enabledUploader); } final HashMap uploaders = yacyCore.getSeedUploadMethods(); prop.put("seedUploadMethods", uploaders.size() + 1); prop.put("seedUploadMethods_0_name", "none"); prop.put("seedUploadMethods_0_selected", enabledUploader.equals("none") ? "1" : "0"); prop.put("seedUploadMethods_0_file", ""); int count = 0; final Iterator uploaderKeys = uploaders.keySet().iterator(); while (uploaderKeys.hasNext()) { count++; final String uploaderName = uploaderKeys.next(); prop.put("seedUploadMethods_" +count+ "_name", uploaderName); prop.put("seedUploadMethods_" +count+ "_selected", uploaderName.equals(enabledUploader) ? "1" : "0"); prop.put("seedUploadMethods_" +count+ "_file", "Settings_Seed_Upload" + uploaderName + ".inc"); final yacySeedUploader theUploader = yacyCore.getSeedUploader(uploaderName); final String[] configOptions = theUploader.getConfigurationOptions(); if (configOptions != null) { for (int i=0; i configList = plasmaParser.getParserConfigList(); final plasmaParserConfig[] configArray = configList.values().toArray(new plasmaParserConfig[configList.size()]); final HashSet parserInfos = new HashSet(sb.parser.getAvailableParserList().values()); // // fetching a list of all available mimetypes // List availableParserKeys = Arrays.asList(availableParsers.entrySet().toArray(new ParserInfo[availableParsers.size()])); // // // sort it // Collections.sort(availableParserKeys); // loop through the mimeTypes and add it to the properties final boolean[] allParsersEnabled = new boolean[configList.size()]; for (int i=0; i availableParserIter = parserInfos.iterator(); while (availableParserIter.hasNext()) { final ParserInfo parserInfo = availableParserIter.next(); prop.put("parser_" + parserIdx + "_name", parserInfo.parserName); prop.putHTML("parser_" + parserIdx + "_version", parserInfo.parserVersionNr, true); prop.put("parser_" + parserIdx + "_usage", parserInfo.usageCount); prop.put("parser_" + parserIdx + "_colspan", configArray.length); int mimeIdx = 0; final Enumeration mimeTypeIter = parserInfo.supportedMimeTypes.keys(); while (mimeTypeIter.hasMoreElements()) { final String mimeType = mimeTypeIter.nextElement(); prop.put("parser_" + parserIdx + "_mime_" + mimeIdx + "_mimetype", mimeType); //prop.put("parser_" + parserIdx + "_name", parserName); //prop.put("parser_" + parserIdx + "_shortname", parserName.substring(parserName.lastIndexOf(".")+1)); for (int i=0; i enabledParsers = configArray[i].getEnabledParserList(); prop.put("parser_" + parserIdx + "_mime_" + mimeIdx + "_parserMode_" + i + "_optionName", configArray[i].parserMode + "." + mimeType); prop.put("parser_" + parserIdx + "_mime_" + mimeIdx + "_parserMode_" + i + "_status", enabledParsers.contains(mimeType) ? "1" : "0"); allParsersEnabled[i] &= enabledParsers.contains(mimeType); } prop.put("parser_" + parserIdx + "_mime_" + mimeIdx + "_parserMode", configArray.length); mimeIdx++; } prop.put("parser_" + parserIdx + "_mime", mimeIdx); parserIdx++; } for (int i=0; i