Author: xor
Date: 2008-11-01 14:03:26 +0000 (Sat, 01 Nov 2008)
New Revision: 23278

Added:
   trunk/plugins/FMSPlugin/FMS.java
Removed:
   trunk/plugins/FMSPlugin/FMSPlugin.java
Log:
Move content of old class FMS to class FMSPlugin and rename FMSPlugin to FMS.

Copied: trunk/plugins/FMSPlugin/FMS.java (from rev 23277, 
trunk/plugins/FMSPlugin/FMSPlugin.java)
===================================================================
--- trunk/plugins/FMSPlugin/FMS.java                            (rev 0)
+++ trunk/plugins/FMSPlugin/FMS.java    2008-11-01 14:03:26 UTC (rev 23278)
@@ -0,0 +1,344 @@
+/* This code is part of Freenet. It is distributed under the GNU General
+ * Public License, version 2 (or at your option any later version). See
+ * http://www.gnu.org/ for further details of the GPL. */
+package plugins.FMSPlugin;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.ArrayList;
+import java.util.List;
+
+import plugins.FMSPlugin.ui.Errors;
+import plugins.FMSPlugin.ui.IdentityEditor;
+import plugins.FMSPlugin.ui.Messages;
+import plugins.FMSPlugin.ui.Status;
+import plugins.FMSPlugin.ui.Welcome;
+
+import com.db4o.Db4o;
+import com.db4o.ObjectContainer;
+import com.db4o.ObjectSet;
+import com.db4o.config.Configuration;
+
+import freenet.client.HighLevelSimpleClient;
+import freenet.clients.http.PageMaker;
+import freenet.clients.http.PageMaker.THEME;
+import freenet.keys.FreenetURI;
+import freenet.l10n.L10n.LANGUAGE;
+import freenet.pluginmanager.DownloadPluginHTTPException;
+import freenet.pluginmanager.FredPlugin;
+import freenet.pluginmanager.FredPluginFCP;
+import freenet.pluginmanager.FredPluginHTTP;
+import freenet.pluginmanager.FredPluginL10n;
+import freenet.pluginmanager.FredPluginThemed;
+import freenet.pluginmanager.FredPluginThreadless;
+import freenet.pluginmanager.FredPluginVersioned;
+import freenet.pluginmanager.NotFoundPluginHTTPException;
+import freenet.pluginmanager.PluginHTTPException;
+import freenet.pluginmanager.PluginReplySender;
+import freenet.pluginmanager.PluginRespirator;
+import freenet.pluginmanager.RedirectPluginHTTPException;
+import freenet.support.HTMLNode;
+import freenet.support.Logger;
+import freenet.support.SimpleFieldSet;
+import freenet.support.api.Bucket;
+import freenet.support.api.HTTPRequest;
+import freenet.support.api.HTTPUploadedFile;
+import freenet.support.io.TempBucketFactory;
+
+/**
+ * @author saces
+ *
+ */
+public class FMS implements FredPlugin, FredPluginFCP, FredPluginHTTP, 
FredPluginL10n, FredPluginThemed, FredPluginThreadless, FredPluginVersioned {
+
+       public static String SELF_URI = "/plugins/plugins.FMSPlugin.FMSPlugin";
+       public static String SELF_TITLE = "Freenet Message System";
+       public static String WOT_NAME = "plugins.WoT.WoT";
+
+       public final String MESSAGEBASE = "fms";
+
+       public PluginRespirator pr;
+
+       public PageMaker pm;
+
+       private LANGUAGE language;
+       private THEME theme;
+
+       private HighLevelSimpleClient client;
+
+       private FMSDealer dealer;
+
+       public ObjectContainer db_config;
+       public ObjectContainer db_cache;
+       
+       public TempBucketFactory tbf;
+       
+       public void runPlugin(PluginRespirator pr2) {
+
+               Logger.error(this, "Start");
+
+               pr = pr2;
+
+               pm = pr.getPageMaker();
+               pm.addNavigationLink(SELF_URI + "/", "Home", "FMS plugin home", 
false, null);
+               pm.addNavigationLink(SELF_URI + "/ownidentities", "Own 
Identities", "Manage your own identities", false, null);
+               pm.addNavigationLink(SELF_URI + "/knownidentities", "Known 
Identities", "Manage others identities", false, null);
+               pm.addNavigationLink(SELF_URI + "/messages", "Messages", "View 
Messages", false, null);
+               pm.addNavigationLink(SELF_URI + "/status", "Dealer status", 
"Show what happens in background", false, null);
+               pm.addNavigationLink("/", "Fproxy", "Back to nodes home", 
false, null);
+
+               client = pr.getHLSimpleClient();
+
+               Configuration config_config = Db4o.newConfiguration();
+               /*      We re-use all information from the WoT-plugin's 
database.
+               
config_config.objectClass(FMSOwnIdentity.class).objectField("requestUri").indexed(true);
+               
config_config.objectClass(FMSIdentity.class).objectField("requestUri").indexed(true);
+               */
+               db_config = Db4o.openFile(config_config, "fms_conf.db4o");
+
+               Configuration cache_config = Db4o.newConfiguration();
+               for(String f : FMSMessage.getIndexedFields())
+                       
cache_config.objectClass(FMSMessage.class).objectField(f).indexed(true);
+               for(String f : FMSBoard.getIndexedFields())
+                       
cache_config.objectClass(FMSBoard.class).objectField(f).indexed(true);
+               db_cache = Db4o.openFile(cache_config, "fms_cache.db4o");
+
+               // while develop wipe cache on startup
+               ObjectSet<Object> result = db_cache.queryByExample(new 
Object());
+               if (result.size() > 0) {
+                       for (Object o : result) {
+                               db_cache.delete(o);
+                       }
+                       db_cache.commit();
+               }
+
+               dealer = new FMSDealer(pr.getNode().executor);
+
+               tbf = pr.getNode().clientCore.tempBucketFactory;
+       }
+
+       public void terminate() {
+               dealer.killMe();
+               db_config.close();
+               db_cache.close();
+       }
+
+       public String handleHTTPGet(HTTPRequest request) throws 
PluginHTTPException {
+
+               if (request.isParameterSet("formPassword")) {
+                       String pass = request.getParam("formPassword");
+                       if ((pass.length() == 0) || 
!pass.equals(pr.getNode().clientCore.formPassword)) {
+                               return Errors.makeErrorPage(this, "Buh! Invalid 
form password");
+                       }
+               }
+
+               String page = request.getPath().substring(SELF_URI.length());
+               if ((page.length() < 1) || ("/".equals(page)))
+                       return Welcome.makeWelcomePage(this);
+
+               if ("/status".equals(page)) {
+                       return Status.makeStatusPage(this);
+               }
+               
+               if ("/ownidentities".equals(page))
+                       return IdentityEditor.makeOwnIdentitiesPage(this, 
request);
+
+               if ("/knownidentities".equals(page))
+                       return IdentityEditor.makeKnownIdentitiesPage(this, 
request);
+
+               if ("/messages".equals(page))
+                       return Messages.makeMessagesPage(this, request);
+
+               throw new NotFoundPluginHTTPException("Resource not found in 
FMSPlugin", page);
+       }
+       
+       public void handle(PluginReplySender replysender, SimpleFieldSet 
params, Bucket data, int accesstype) {
+               SimpleFieldSet sfs = new SimpleFieldSet(true);
+               sfs.putOverwrite("Hello", "Nice try ;)");
+               sfs.putOverwrite("Sorry", "Not implemeted yet :(");
+       }
+
+       public String handleHTTPPost(HTTPRequest request) throws 
PluginHTTPException {
+               String pass = request.getPartAsString("formPassword", 32);
+               if ((pass.length() == 0) || 
!pass.equals(pr.getNode().clientCore.formPassword)) {
+                       return Errors.makeErrorPage(this, "Buh! Invalid form 
password");
+               }
+
+               String page = request.getPath().substring(SELF_URI.length());
+
+               if (page.length() < 1)
+                       throw new NotFoundPluginHTTPException("Resource not 
found", page);
+
+               if (page.equals("/exportDB")) {
+                       StringWriter sw = new StringWriter();
+                       try {
+                               Backup.exportConfigDb(db_config, sw);
+                       } catch (IOException e) {
+                               Logger.error(this, "Error While exporting 
database!", e);
+                               return Errors.makeErrorPage(this, "Server 
BuhBuh! " + e.getMessage());
+                       }
+                       throw new 
DownloadPluginHTTPException(sw.toString().getBytes(), "fms-kidding.xml", 
"fms-clone/db-backup");
+               }
+               
+               if (page.equals("/importDB")) {
+                       HTTPUploadedFile file = 
request.getUploadedFile("filename");
+                       if (file == null || file.getFilename().trim().length() 
== 0) {
+                               return Errors.makeErrorPage(this, "No file to 
import selected!");
+                       }
+                       try {
+                               Backup.importConfigDb(db_config, 
file.getData().getInputStream());
+                       } catch (Exception e) {
+                               Logger.error(this, "Error While importing db 
from: " + file.getFilename(), e);
+                               return Errors.makeErrorPage(this, "Error While 
importing db from: " + file.getFilename() + e.getMessage());
+                       }
+                       throw new RedirectPluginHTTPException("", SELF_URI);
+               }
+
+               if (page.equals("/createownidentity")) {
+                       List<String> err = new ArrayList<String>();
+                       String nick = request.getPartAsString("nick", 
1024).trim();
+                       String requestUri = 
request.getPartAsString("requestURI", 1024);
+                       String insertUri = request.getPartAsString("insertURI", 
1024);
+                       boolean publish = 
"true".equals(request.getPartAsString("publishTrustList", 24));
+
+                       IdentityEditor.checkNick(err, nick);
+
+                       if ((requestUri.length() == 0) && (insertUri.length() 
== 0)) {
+                               FreenetURI[] kp = client.generateKeyPair("fms");
+                               insertUri = kp[0].toString();
+                               requestUri = kp[1].toString();
+                               err.add("URI was empty, I generated one for 
you.");
+                               return 
IdentityEditor.makeNewOwnIdentityPage(this, nick, requestUri, insertUri, 
publish, err);
+                       }
+
+                       IdentityEditor.checkInsertURI(err, insertUri);
+                       IdentityEditor.checkRequestURI(err, requestUri);
+
+                       if (err.size() == 0) {
+                               // FIXME: use identity manager to implement this
+                               throw new UnsupportedOperationException();
+                               /*
+                               FMSOwnIdentity oi = new FMSOwnIdentity(nick, 
requestUri, insertUri, publish);
+                               IdentityEditor.addNewOwnIdentity(db_config, oi, 
err);
+                               */
+                       }
+
+                       if (err.size() == 0) {
+                               throw new RedirectPluginHTTPException("", 
SELF_URI + "/ownidentities");
+                       }
+
+                       return IdentityEditor.makeNewOwnIdentityPage(this, 
nick, requestUri, insertUri, publish, err);
+               }
+
+               if (page.equals("/addknownidentity")) {
+                       List<String> err = new ArrayList<String>();
+
+                       String requestUri = 
request.getPartAsString("requestURI", 1024);
+
+                       if (requestUri.length() == 0) {
+                               err.add("Are you jokingly? URI was empty.");
+                               return 
IdentityEditor.makeNewKnownIdentityPage(this, requestUri, err);
+                       }
+
+                       IdentityEditor.checkRequestURI(err, requestUri);
+
+                       if (err.size() == 0) {
+                               // FIXME: use identity manager to implement this
+                               throw new UnsupportedOperationException();
+                               /*
+                               FMSIdentity i = new FMSIdentity("", requestUri);
+                               IdentityEditor.addNewKnownIdentity(db_config, 
i, err);
+                               */
+                       }
+
+                       if (err.size() == 0) {
+                               throw new RedirectPluginHTTPException("", 
SELF_URI + "/knownidentities");
+                       }
+
+                       return IdentityEditor.makeNewKnownIdentityPage(this, 
requestUri, err);
+               }
+
+               if (page.equals("/deleteOwnIdentity")) {
+                       List<String> err = new ArrayList<String>();
+
+                       String requestUri = request.getPartAsString("identity", 
1024);
+                       if (requestUri.length() == 0) {
+                               err.add("Are you jokingly? URI was empty.");
+                               return 
IdentityEditor.makeDeleteOwnIdentityPage(this, requestUri, err);
+                       }
+
+                       if (request.isPartSet("confirmed")) {
+                               IdentityEditor.deleteIdentity(this, requestUri, 
err);
+                       } else {
+                               err.add("Please confirm.");
+                       }
+
+                       if (err.size() > 0) {
+                               return 
IdentityEditor.makeDeleteOwnIdentityPage(this, requestUri, err);
+                       }
+                       throw new RedirectPluginHTTPException("", SELF_URI + 
"/ownidentities");
+                       // return IdentityEditor.makeDeleteOwnIdentityPage(fms, 
requestUri,
+                       // err);
+               }
+
+               if (page.equals("/deleteIdentity")) {
+                       List<String> err = new ArrayList<String>();
+
+                       String requestUri = request.getPartAsString("identity", 
1024);
+                       if (requestUri.length() == 0) {
+                               err.add("Are you jokingly? URI was empty.");
+                               return 
IdentityEditor.makeDeleteKnownIdentityPage(this, requestUri, err);
+                       }
+
+                       if (request.isPartSet("confirmed")) {
+                               IdentityEditor.deleteIdentity(this, requestUri, 
err);
+                       } else {
+                               err.add("Please confirm.");
+                       }
+
+                       if (err.size() > 0) {
+                               return 
IdentityEditor.makeDeleteKnownIdentityPage(this, requestUri, err);
+                       }
+                       throw new RedirectPluginHTTPException("", SELF_URI + 
"/knownidentities");
+               }
+               throw new NotFoundPluginHTTPException("Resource not found", 
page);
+       }
+
+       public String getVersion() {
+               return "? r" + Version.svnRevision;
+       }
+
+       public String getString(String key) {
+               // Logger.error(this, "Request translation for "+key);
+               return key;
+       }
+
+       public void setLanguage(LANGUAGE newLanguage) {
+               language = newLanguage;
+               Logger.error(this, "Set LANGUAGE to: " + language.isoCode);
+       }
+
+       public void setTheme(THEME newTheme) {
+               theme= newTheme;
+               Logger.error(this, "Set THEME to: " + theme.code);
+       }
+       
+       public boolean isWoTpresent() {
+               FredPluginFCP plug = 
pr.getNode().pluginManager.getFCPPlugin(FMS.WOT_NAME);
+               return (plug != null);
+       }
+
+       public long countIdentities() {
+               return db_config.queryByExample(FMSIdentity.class).size() - 
countOwnIdentities();
+       }
+
+       public long countOwnIdentities() {
+               return db_config.queryByExample(FMSOwnIdentity.class).size();
+       }
+       
+
+       final public HTMLNode getPageNode() {
+               return pm.getPageNode(FMS.SELF_TITLE, null);
+       }
+
+}


Property changes on: trunk/plugins/FMSPlugin/FMS.java
___________________________________________________________________
Name: svn:mime-type
   + text/plain
Name: svn:mergeinfo
   + 

Deleted: trunk/plugins/FMSPlugin/FMSPlugin.java
===================================================================
--- trunk/plugins/FMSPlugin/FMSPlugin.java      2008-11-01 13:42:23 UTC (rev 
23277)
+++ trunk/plugins/FMSPlugin/FMSPlugin.java      2008-11-01 14:03:26 UTC (rev 
23278)
@@ -1,317 +0,0 @@
-/* This code is part of Freenet. It is distributed under the GNU General
- * Public License, version 2 (or at your option any later version). See
- * http://www.gnu.org/ for further details of the GPL. */
-package plugins.FMSPlugin;
-
-import java.io.IOException;
-import java.io.StringWriter;
-import java.util.ArrayList;
-import java.util.List;
-
-import plugins.FMSPlugin.ui.Errors;
-import plugins.FMSPlugin.ui.IdentityEditor;
-import plugins.FMSPlugin.ui.Messages;
-import plugins.FMSPlugin.ui.Status;
-import plugins.FMSPlugin.ui.Welcome;
-
-import com.db4o.Db4o;
-import com.db4o.ObjectContainer;
-import com.db4o.ObjectSet;
-import com.db4o.config.Configuration;
-
-import freenet.client.HighLevelSimpleClient;
-import freenet.clients.http.PageMaker;
-import freenet.clients.http.PageMaker.THEME;
-import freenet.keys.FreenetURI;
-import freenet.l10n.L10n.LANGUAGE;
-import freenet.pluginmanager.DownloadPluginHTTPException;
-import freenet.pluginmanager.FredPlugin;
-import freenet.pluginmanager.FredPluginFCP;
-import freenet.pluginmanager.FredPluginHTTP;
-import freenet.pluginmanager.FredPluginL10n;
-import freenet.pluginmanager.FredPluginThemed;
-import freenet.pluginmanager.FredPluginThreadless;
-import freenet.pluginmanager.FredPluginVersioned;
-import freenet.pluginmanager.NotFoundPluginHTTPException;
-import freenet.pluginmanager.PluginHTTPException;
-import freenet.pluginmanager.PluginReplySender;
-import freenet.pluginmanager.PluginRespirator;
-import freenet.pluginmanager.RedirectPluginHTTPException;
-import freenet.support.Logger;
-import freenet.support.SimpleFieldSet;
-import freenet.support.api.Bucket;
-import freenet.support.api.HTTPRequest;
-import freenet.support.api.HTTPUploadedFile;
-
-/**
- * @author saces
- *
- */
-public class FMSPlugin implements FredPlugin, FredPluginFCP, FredPluginHTTP, 
FredPluginL10n, FredPluginThemed, FredPluginThreadless, FredPluginVersioned {
-
-       public static String SELF_URI = "/plugins/plugins.FMSPlugin.FMSPlugin";
-       public static String SELF_TITLE = "FMS clone";
-       public static String WOT_NAME = "plugins.WoT.WoT";
-
-       public final String MESSAGEBASE = "fms";
-
-       private PluginRespirator pr;
-
-       private PageMaker pm;
-
-       private LANGUAGE language;
-       private THEME theme;
-
-       private HighLevelSimpleClient client;
-
-       private FMSDealer dealer;
-
-       private ObjectContainer db_config;
-       private ObjectContainer db_cache;
-
-       private FMS fms;
-
-       public void runPlugin(PluginRespirator pr2) {
-
-               Logger.error(this, "Start");
-
-               pr = pr2;
-
-               pm = pr.getPageMaker();
-               pm.addNavigationLink(SELF_URI + "/", "Home", "FMS plugin home", 
false, null);
-               pm.addNavigationLink(SELF_URI + "/ownidentities", "Own 
Identities", "Manage your own identities", false, null);
-               pm.addNavigationLink(SELF_URI + "/knownidentities", "Known 
Identities", "Manage others identities", false, null);
-               pm.addNavigationLink(SELF_URI + "/messages", "Messages", "View 
Messages", false, null);
-               pm.addNavigationLink(SELF_URI + "/status", "Dealer status", 
"Show what happens in background", false, null);
-               pm.addNavigationLink("/", "Fproxy", "Back to nodes home", 
false, null);
-
-               client = pr.getHLSimpleClient();
-
-               Configuration config_config = Db4o.newConfiguration();
-               
config_config.objectClass(FMSOwnIdentity.class).objectField("requestUri").indexed(true);
-               
config_config.objectClass(FMSIdentity.class).objectField("requestUri").indexed(true);
-               db_config = Db4o.openFile(config_config, "fms_conf.db4o");
-
-               Configuration cache_config = Db4o.newConfiguration();
-               db_cache = Db4o.openFile(cache_config, "fms_cache.db4o");
-
-               // while develop wipe cache on startup
-               ObjectSet<Object> result = db_cache.queryByExample(new 
Object());
-               if (result.size() > 0) {
-                       for (Object o : result) {
-                               db_cache.delete(o);
-                       }
-                       db_cache.commit();
-               }
-
-               dealer = new FMSDealer(pr.getNode().executor);
-
-               fms = new FMS(pr.getNode().clientCore.tempBucketFactory, pm, 
pr, db_config, db_cache);
-       }
-
-       public void terminate() {
-               dealer.killMe();
-               db_config.close();
-               db_cache.close();
-       }
-
-       public String handleHTTPGet(HTTPRequest request) throws 
PluginHTTPException {
-
-               if (request.isParameterSet("formPassword")) {
-                       String pass = request.getParam("formPassword");
-                       if ((pass.length() == 0) || 
!pass.equals(pr.getNode().clientCore.formPassword)) {
-                               return Errors.makeErrorPage(fms, "Buh! Invalid 
form password");
-                       }
-               }
-
-               String page = request.getPath().substring(SELF_URI.length());
-               if ((page.length() < 1) || ("/".equals(page)))
-                       return Welcome.makeWelcomePage(fms);
-
-               if ("/status".equals(page)) {
-                       return Status.makeStatusPage(fms);
-               }
-               
-               if ("/ownidentities".equals(page))
-                       return IdentityEditor.makeOwnIdentitiesPage(fms, 
request);
-
-               if ("/knownidentities".equals(page))
-                       return IdentityEditor.makeKnownIdentitiesPage(fms, 
request);
-
-               if ("/messages".equals(page))
-                       return Messages.makeMessagesPage(fms, request);
-
-               throw new NotFoundPluginHTTPException("Resource not found in 
FMSPlugin", page);
-       }
-       
-       public void handle(PluginReplySender replysender, SimpleFieldSet 
params, Bucket data, int accesstype) {
-               SimpleFieldSet sfs = new SimpleFieldSet(true);
-               sfs.putOverwrite("Hello", "Nice try ;)");
-               sfs.putOverwrite("Sorry", "Not implemeted yet :(");
-       }
-
-       public String handleHTTPPost(HTTPRequest request) throws 
PluginHTTPException {
-               String pass = request.getPartAsString("formPassword", 32);
-               if ((pass.length() == 0) || 
!pass.equals(pr.getNode().clientCore.formPassword)) {
-                       return Errors.makeErrorPage(fms, "Buh! Invalid form 
password");
-               }
-
-               String page = request.getPath().substring(SELF_URI.length());
-
-               if (page.length() < 1)
-                       throw new NotFoundPluginHTTPException("Resource not 
found", page);
-
-               if (page.equals("/exportDB")) {
-                       StringWriter sw = new StringWriter();
-                       try {
-                               Backup.exportConfigDb(db_config, sw);
-                       } catch (IOException e) {
-                               Logger.error(this, "Error While exporting 
database!", e);
-                               return Errors.makeErrorPage(fms, "Server 
BuhBuh! " + e.getMessage());
-                       }
-                       throw new 
DownloadPluginHTTPException(sw.toString().getBytes(), "fms-kidding.xml", 
"fms-clone/db-backup");
-               }
-               
-               if (page.equals("/importDB")) {
-                       HTTPUploadedFile file = 
request.getUploadedFile("filename");
-                       if (file == null || file.getFilename().trim().length() 
== 0) {
-                               return Errors.makeErrorPage(fms, "No file to 
import selected!");
-                       }
-                       try {
-                               Backup.importConfigDb(db_config, 
file.getData().getInputStream());
-                       } catch (Exception e) {
-                               Logger.error(this, "Error While importing db 
from: " + file.getFilename(), e);
-                               return Errors.makeErrorPage(fms, "Error While 
importing db from: " + file.getFilename() + e.getMessage());
-                       }
-                       throw new RedirectPluginHTTPException("", SELF_URI);
-               }
-
-               if (page.equals("/createownidentity")) {
-                       List<String> err = new ArrayList<String>();
-                       String nick = request.getPartAsString("nick", 
1024).trim();
-                       String requestUri = 
request.getPartAsString("requestURI", 1024);
-                       String insertUri = request.getPartAsString("insertURI", 
1024);
-                       boolean publish = 
"true".equals(request.getPartAsString("publishTrustList", 24));
-
-                       IdentityEditor.checkNick(err, nick);
-
-                       if ((requestUri.length() == 0) && (insertUri.length() 
== 0)) {
-                               FreenetURI[] kp = client.generateKeyPair("fms");
-                               insertUri = kp[0].toString();
-                               requestUri = kp[1].toString();
-                               err.add("URI was empty, I generated one for 
you.");
-                               return 
IdentityEditor.makeNewOwnIdentityPage(fms, nick, requestUri, insertUri, 
publish, err);
-                       }
-
-                       IdentityEditor.checkInsertURI(err, insertUri);
-                       IdentityEditor.checkRequestURI(err, requestUri);
-
-                       if (err.size() == 0) {
-                               // FIXME: use identity manager to implement this
-                               throw new UnsupportedOperationException();
-                               /*
-                               FMSOwnIdentity oi = new FMSOwnIdentity(nick, 
requestUri, insertUri, publish);
-                               IdentityEditor.addNewOwnIdentity(db_config, oi, 
err);
-                               */
-                       }
-
-                       if (err.size() == 0) {
-                               throw new RedirectPluginHTTPException("", 
SELF_URI + "/ownidentities");
-                       }
-
-                       return IdentityEditor.makeNewOwnIdentityPage(fms, nick, 
requestUri, insertUri, publish, err);
-               }
-
-               if (page.equals("/addknownidentity")) {
-                       List<String> err = new ArrayList<String>();
-
-                       String requestUri = 
request.getPartAsString("requestURI", 1024);
-
-                       if (requestUri.length() == 0) {
-                               err.add("Are you jokingly? URI was empty.");
-                               return 
IdentityEditor.makeNewKnownIdentityPage(fms, requestUri, err);
-                       }
-
-                       IdentityEditor.checkRequestURI(err, requestUri);
-
-                       if (err.size() == 0) {
-                               // FIXME: use identity manager to implement this
-                               throw new UnsupportedOperationException();
-                               /*
-                               FMSIdentity i = new FMSIdentity("", requestUri);
-                               IdentityEditor.addNewKnownIdentity(db_config, 
i, err);
-                               */
-                       }
-
-                       if (err.size() == 0) {
-                               throw new RedirectPluginHTTPException("", 
SELF_URI + "/knownidentities");
-                       }
-
-                       return IdentityEditor.makeNewKnownIdentityPage(fms, 
requestUri, err);
-               }
-
-               if (page.equals("/deleteOwnIdentity")) {
-                       List<String> err = new ArrayList<String>();
-
-                       String requestUri = request.getPartAsString("identity", 
1024);
-                       if (requestUri.length() == 0) {
-                               err.add("Are you jokingly? URI was empty.");
-                               return 
IdentityEditor.makeDeleteOwnIdentityPage(fms, requestUri, err);
-                       }
-
-                       if (request.isPartSet("confirmed")) {
-                               IdentityEditor.deleteIdentity(fms, requestUri, 
err);
-                       } else {
-                               err.add("Please confirm.");
-                       }
-
-                       if (err.size() > 0) {
-                               return 
IdentityEditor.makeDeleteOwnIdentityPage(fms, requestUri, err);
-                       }
-                       throw new RedirectPluginHTTPException("", SELF_URI + 
"/ownidentities");
-                       // return IdentityEditor.makeDeleteOwnIdentityPage(fms, 
requestUri,
-                       // err);
-               }
-
-               if (page.equals("/deleteIdentity")) {
-                       List<String> err = new ArrayList<String>();
-
-                       String requestUri = request.getPartAsString("identity", 
1024);
-                       if (requestUri.length() == 0) {
-                               err.add("Are you jokingly? URI was empty.");
-                               return 
IdentityEditor.makeDeleteKnownIdentityPage(fms, requestUri, err);
-                       }
-
-                       if (request.isPartSet("confirmed")) {
-                               IdentityEditor.deleteIdentity(fms, requestUri, 
err);
-                       } else {
-                               err.add("Please confirm.");
-                       }
-
-                       if (err.size() > 0) {
-                               return 
IdentityEditor.makeDeleteKnownIdentityPage(fms, requestUri, err);
-                       }
-                       throw new RedirectPluginHTTPException("", SELF_URI + 
"/knownidentities");
-               }
-               throw new NotFoundPluginHTTPException("Resource not found", 
page);
-       }
-
-       public String getVersion() {
-               return "? r" + Version.svnRevision;
-       }
-
-       public String getString(String key) {
-               // Logger.error(this, "Request translation for "+key);
-               return key;
-       }
-
-       public void setLanguage(LANGUAGE newLanguage) {
-               language = newLanguage;
-               Logger.error(this, "Set LANGUAGE to: " + language.isoCode);
-       }
-
-       public void setTheme(THEME newTheme) {
-               theme= newTheme;
-               Logger.error(this, "Set THEME to: " + theme.code);
-       }
-}


Reply via email to