2 bugfixes...
authorzapata <zapata>
Sat, 20 Sep 2003 10:54:17 +0000 (10:54 +0000)
committerzapata <zapata>
Sat, 20 Sep 2003 10:54:17 +0000 (10:54 +0000)
source/default.properties
source/mircoders/global/MirGlobal.java
source/mircoders/localizer/basic/MirBasicAdminInterfaceLocalizer.java
source/mircoders/servlet/ServletModuleContent.java
source/mircoders/servlet/ServletModuleMediafolder.java

index 6474ab7..be0990c 100755 (executable)
@@ -104,6 +104,26 @@ Mir.Localizer.OpenPosting.GeneratorLibrary= default=freemarker(etc/open/)
 # 0 = links, 1 = checkboxes, 2 = a listbox
 Mir.Localizer.Admin.ListOperationsFlavor=1
 
+
+
+# How should the topics be presented on the article edit page?
+# <key>:<listtype>:<listparameter>:<condition>:<order>
+#
+# key:
+#     a unique key per topic category
+# listtype:
+#     0 = in a multiselect list box, 1 = checkboxes, 2 = a dropdown listbox
+# listparameter:
+#     number of rows for multiselect list box, number of columns for checkboxes
+# condition:
+#     what sql condition should the topics of this category be of
+# order:
+#     what sql order should the topics be ordered by
+
+Mir.Localizer.Admin.TopicLists = \
+   topic:1:3:archiv_url='bla':title   ,\
+   rest:1:3:archiv_url<>'bla':title   \
+
 # How should the topics be presented on the article edit page?
 # 0 = in a multiselect list box, 1 = checkboxes
 Mir.Localizer.Admin.TopicListFlavor=1
index b7fea6e..4eb40e6 100755 (executable)
@@ -38,6 +38,7 @@ import java.util.Vector;
 \r
 import mir.config.MirPropertiesConfiguration;\r
 import mir.config.MirPropertiesConfiguration.PropertiesConfigExc;\r
+import mir.entity.adapter.EntityAdapter;\r
 import mir.log.LoggerWrapper;\r
 import mir.misc.ConfigException;\r
 import mircoders.accesscontrol.AccessControl;\r
@@ -138,9 +139,13 @@ public class MirGlobal {
     MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation = getArticleOperationForName(anOperation);\r
 \r
     try {\r
+      EntityAdapter user = null;\r
+      if (aUser!=null)\r
+          user = localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser);\r
+\r
       if (operation!=null)\r
         operation.perform(\r
-            localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser),\r
+            user,\r
             localizer().dataModel().adapterModel().makeEntityAdapter("content", anArticle));\r
     }\r
     catch (Throwable t) {\r
@@ -154,9 +159,13 @@ public class MirGlobal {
     MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation = getCommentOperationForName(anOperation);\r
 \r
     try {\r
+      EntityAdapter user = null;\r
+      if (aUser!=null)\r
+          user = localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser);\r
+\r
       if (operation!=null)\r
         operation.perform(\r
-            localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser),\r
+            user,\r
             localizer().dataModel().adapterModel().makeEntityAdapter("comment", aComment));\r
     }\r
     catch (Throwable t) {\r
index bb606a8..47516de 100755 (executable)
@@ -1,35 +1,35 @@
-/*
- * Copyright (C) 2001, 2002 The Mir-coders group
- *
- * This file is part of Mir.
- *
- * Mir 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.
- *
- * Mir 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 Mir; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
- *
- * In addition, as a special exception, The Mir-coders gives permission to link
- * the code of this program with  any library licensed under the Apache Software License,
- * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library
- * (or with modified versions of the above that use the same license as the above),
- * and distribute linked combinations including the two.  You must obey the
- * GNU General Public License in all respects for all of the code used other than
- * the above mentioned libraries.  If you modify this file, you may extend this
- * exception to your version of the file, but you are not obligated to do so.
- * If you do not wish to do so, delete this exception statement from your version.
- */
-
-package mircoders.localizer.basic;
-
+/*\r
+ * Copyright (C) 2001, 2002 The Mir-coders group\r
+ *\r
+ * This file is part of Mir.\r
+ *\r
+ * Mir is free software; you can redistribute it and/or modify\r
+ * it under the terms of the GNU General Public License as published by\r
+ * the Free Software Foundation; either version 2 of the License, or\r
+ * (at your option) any later version.\r
+ *\r
+ * Mir is distributed in the hope that it will be useful,\r
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
+ * GNU General Public License for more details.\r
+ *\r
+ * You should have received a copy of the GNU General Public License\r
+ * along with Mir; if not, write to the Free Software\r
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
+ *\r
+ * In addition, as a special exception, The Mir-coders gives permission to link\r
+ * the code of this program with  any library licensed under the Apache Software License,\r
+ * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library\r
+ * (or with modified versions of the above that use the same license as the above),\r
+ * and distribute linked combinations including the two.  You must obey the\r
+ * GNU General Public License in all respects for all of the code used other than\r
+ * the above mentioned libraries.  If you modify this file, you may extend this\r
+ * exception to your version of the file, but you are not obligated to do so.\r
+ * If you do not wish to do so, delete this exception statement from your version.\r
+ */\r
+\r
+package mircoders.localizer.basic;\r
+\r
 import java.util.Arrays;\r
 import java.util.GregorianCalendar;\r
 import java.util.HashMap;\r
@@ -41,6 +41,7 @@ import java.util.Set;
 import java.util.Vector;\r
 \r
 import mir.entity.Entity;\r
+import mir.log.*;\r
 import mir.entity.adapter.EntityAdapter;\r
 import mir.misc.StringUtil;\r
 import mir.storage.StorageObjectFailure;\r
@@ -52,299 +53,306 @@ import mircoders.localizer.MirAdminInterfaceLocalizer;
 import mircoders.localizer.MirAdminInterfaceLocalizer.MirSimpleEntityOperation;\r
 import mircoders.localizer.MirLocalizerExc;\r
 import mircoders.localizer.MirLocalizerFailure;\r
-import mircoders.storage.DatabaseContent;
-
-
-public class MirBasicAdminInterfaceLocalizer implements MirAdminInterfaceLocalizer {
-  private Vector simpleCommentOperations;
-  private Vector simpleArticleOperations;
-  private Map simpleCommentOperationsMap;
-  private Map simpleArticleOperationsMap;
-
-  public MirBasicAdminInterfaceLocalizer() throws MirLocalizerFailure, MirLocalizerExc {
-    simpleCommentOperations = new Vector();
-    simpleArticleOperations = new Vector();
-    simpleCommentOperationsMap = new HashMap();
-    simpleArticleOperationsMap = new HashMap();
-
-    addSimpleArticleOperation(new ChangeArticleFieldOperation("newswire", "to_article_type", "0", "1", false));
-    addSimpleArticleOperation(new ModifyArticleFieldOperation("unhide", "is_published", "1", false));
-    addSimpleArticleOperation(new ModifyArticleFieldOperation("hide", "is_published", "0", false));
-
-    addSimpleCommentOperation(new ModifyCommentFieldOperation("unhide", "is_published", "1"));
-    addSimpleCommentOperation(new ModifyCommentFieldOperation("hide", "is_published", "0"));
-  }
-
-  public String makePasswordDigest(String aPassword) {
-    return aPassword;
-  }
-
-  public void initializeArticle(Map anArticle) {
-    anArticle.put("is_published", "0");
-    anArticle.put("date", StringUtil.date2webdbDate(new GregorianCalendar()));
-  };
-
-  public List simpleCommentOperations() {
-    return simpleCommentOperations;
-  };
-
-  public List simpleArticleOperations() {
-    return simpleArticleOperations;
-  };
-
-  public MirSimpleEntityOperation simpleArticleOperationForName(String aName) {
-    return (MirSimpleEntityOperation) simpleArticleOperationsMap.get(aName);
-  };
-
-  public MirSimpleEntityOperation simpleCommentOperationForName(String aName) {
-    return (MirSimpleEntityOperation) simpleCommentOperationsMap.get(aName);
-  };
-
-  public void removeSimpleArticleOperation(String aName) {
-    simpleArticleOperations.remove(simpleArticleOperationsMap.get(aName));
-    simpleArticleOperationsMap.remove(aName);
-  }
-
-  public void addSimpleArticleOperation(MirSimpleEntityOperation anOperation) {
-    removeSimpleArticleOperation(anOperation.getName());
-    simpleArticleOperationsMap.put(anOperation.getName(), anOperation);
-    simpleArticleOperations.add(anOperation);
-  }
-
-  public void removeSimpleCommentOperation(String aName) {
-    simpleCommentOperations.remove(simpleCommentOperationsMap.get(aName));
-    simpleCommentOperationsMap.remove(aName);
-  }
-
-  public void addSimpleCommentOperation(MirSimpleEntityOperation anOperation) {
-    removeSimpleCommentOperation(anOperation.getName());
-    simpleCommentOperationsMap.put(anOperation.getName(), anOperation);
-    simpleCommentOperations.add(anOperation);
-  }
-
-  protected abstract static class EntityModifyingOperation implements MirSimpleEntityOperation {
-    private String name;
-
-    protected EntityModifyingOperation(String aName) {
-      name = aName;
-    }
-
-    public String getName() {
-      return name;
-    };
-
-    public boolean isAvailable(EntityAdapter anEntity) {
-      try {
-        Entity entity = anEntity.getEntity();
-        return isAvailable(entity);
-      }
-      catch (Throwable t) {
-        return false;
-      }
-    };
-
-    public void perform(EntityAdapter aUser, EntityAdapter anEntity) throws MirLocalizerExc, MirLocalizerFailure {
-      Entity entity = anEntity.getEntity();
-      try {
-        performModification(aUser, entity);
-        entity.update();
-      }
-      catch (Throwable t) {
-        throw new MirLocalizerFailure(t);
-      }
-    };
-
-    protected abstract boolean isAvailable(Entity anEntity) throws StorageObjectFailure ;
-    protected abstract void performModification(EntityAdapter aUser, Entity anEntity)  throws MirLocalizerExc, MirLocalizerFailure ;
-  }
-
-  public static abstract class CommentModifyingOperation extends EntityModifyingOperation {
-    public CommentModifyingOperation(String aName) {
-      super(aName);
-    }
-
-    protected boolean isAvailable(Entity anEntity) throws StorageObjectFailure {
-      return anEntity instanceof EntityComment && isAvailable((EntityComment) anEntity);
-    }
-
-    protected void performModification(EntityAdapter aUser, Entity anEntity) throws StorageObjectFailure {
-      performModification(aUser, (EntityComment) anEntity);
-      DatabaseContent.getInstance().setUnproduced("id="+anEntity.getValue("to_media"));
-    };
-
-    protected abstract boolean isAvailable(EntityComment aComment) throws StorageObjectFailure ;
-    protected abstract void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure ;
-  }
-
-  public static abstract class ArticleModifyingOperation extends EntityModifyingOperation {
-    private boolean logOperation;
-
-    public ArticleModifyingOperation(String aName, boolean aLogOperation) {
-      super(aName);
-
-      logOperation = aLogOperation;
-    }
-
-    protected boolean isAvailable(Entity anEntity) throws StorageObjectFailure {
-      return anEntity instanceof EntityContent && isAvailable((EntityContent) anEntity);
-    }
-
-    protected void performModification(EntityAdapter aUser, Entity anEntity) throws StorageObjectFailure {
-      performModification(aUser, (EntityContent) anEntity);
-      anEntity.setValueForProperty("is_produced", "0");
-
-      if (logOperation) {
-        StringBuffer line = new StringBuffer();
-
-        line.append(DateTimeFunctions.advancedDateFormat(
-            MirGlobal.config().getString("Mir.DefaultDateTimeFormat"),
-            (new GregorianCalendar()).getTime(),
-            MirGlobal.config().getString("Mir.DefaultTimezone")));
-        line.append(" ");
-        if (aUser!=null)
-          line.append(aUser.get("login"));
-        else
-          line.append("unknown");
-
-        line.append(" ");
-        line.append(getName());
-        ((EntityContent) anEntity).appendToComments(line.toString());
-      }
-    };
-
-    protected abstract boolean isAvailable(EntityContent anArticle) throws StorageObjectFailure ;
-    protected abstract void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure ;
-  }
-
-  protected static class SetCommentFieldOperation extends CommentModifyingOperation {
-    private String field;
-    private String value;
-
-    public SetCommentFieldOperation(String aName, String aField, String aValue) {
-      super(aName);
-
-      field = aField;
-      value = aValue;
-    }
-
-    protected boolean isAvailable(EntityComment aComment) {
-      return true;
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {
-      aComment.setValueForProperty(field, value);
-    }
-  }
-
-  protected static class SetCommentFieldsOperation extends CommentModifyingOperation {
-    private Map values;
-
-    public SetCommentFieldsOperation(String aName, String aFields[], String aValues[]) throws MirLocalizerExc {
-      super(aName);
-
-      values = new HashMap();
-
-      for (int i=0; i<aFields.length; i++)
-        values.put(aFields[i], aValues[i]);
-    }
-
-    protected boolean isAvailable(EntityComment aComment) {
-      return true;
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {
-      Iterator i = values.entrySet().iterator();
-
-      while (i.hasNext()) {
-        Map.Entry entry = (Map.Entry) i.next();
-        aComment.setValueForProperty((String) entry.getKey(), (String) entry.getValue());
-      }
-    }
-  }
-
-
-  protected static class ModifyCommentFieldOperation extends CommentModifyingOperation {
-    private String field;
-    private String value;
-
-    public ModifyCommentFieldOperation(String aName, String aField, String aValue) {
-      super(aName);
-
-      field = aField;
-      value = aValue;
-    }
-
-    protected boolean isAvailable(EntityComment aComment) {
-      return aComment.getValue(field) == null || !aComment.getValue(field).equals(value);
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {
-      aComment.setValueForProperty(field, value);
-    }
-  }
-
-  protected static class SetArticleFieldOperation extends ArticleModifyingOperation {
-    private String field;
-    private String value;
-
-    public SetArticleFieldOperation(String aName, String aField, String aValue, boolean aLogOperation) {
-      super(aName, aLogOperation);
-
-      field = aField;
-      value = aValue;
-    }
-
-    protected boolean isAvailable(EntityContent anArticle) {
-      return true;
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {
-      anArticle.setValueForProperty(field, value);
-    }
-  }
-
-  protected static class ModifyArticleFieldOperation extends ArticleModifyingOperation {
-    private String field;
-    private String value;
-
-    public ModifyArticleFieldOperation(String aName, String aField, String aValue, boolean aLogOperation) {
-      super(aName, aLogOperation);
-
-      field = aField;
-      value = aValue;
-    }
-
-    protected boolean isAvailable(EntityContent anArticle) {
-      return anArticle.getValue(field) == null || !anArticle.getValue(field).equals(value);
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {
-      anArticle.setValueForProperty(field, value);
-    }
-  }
-
-  protected static class ChangeArticleFieldOperation extends ArticleModifyingOperation {
-    private String field;
-    private Set oldValues;
-    private String newValue;
-
-    public ChangeArticleFieldOperation(String aName, String aField, String anOldValues[], String aNewValue, boolean aLogOperation) {
-      super(aName, aLogOperation);
-
-      field = aField;
-      newValue = aNewValue;
-      oldValues = new HashSet(Arrays.asList(anOldValues));
-    }
-    public ChangeArticleFieldOperation(String aName, String aField, String anOldValue, String aNewValue, boolean aLogOperation) {
-      this(aName, aField, new String[] {anOldValue}, aNewValue, aLogOperation);
-    }
-
-    protected boolean isAvailable(EntityContent anArticle) {
-      return anArticle.getValue(field) != null && oldValues.contains(anArticle.getValue(field));
-    }
-
-    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {
-      anArticle.setValueForProperty(field, newValue);
-    }
-  }
-}
+import mircoders.storage.DatabaseContent;\r
+\r
+\r
+public class MirBasicAdminInterfaceLocalizer implements MirAdminInterfaceLocalizer {\r
+  private Vector simpleCommentOperations;\r
+  private Vector simpleArticleOperations;\r
+  private Map simpleCommentOperationsMap;\r
+  private Map simpleArticleOperationsMap;\r
+  protected static LoggerWrapper logger = new LoggerWrapper("Localizer.AdminInterface");;\r
+\r
+  public MirBasicAdminInterfaceLocalizer() throws MirLocalizerFailure, MirLocalizerExc {\r
+\r
+    simpleCommentOperations = new Vector();\r
+    simpleArticleOperations = new Vector();\r
+    simpleCommentOperationsMap = new HashMap();\r
+    simpleArticleOperationsMap = new HashMap();\r
+\r
+    addSimpleArticleOperation(new ChangeArticleFieldOperation("newswire", "to_article_type", "0", "1", false));\r
+    addSimpleArticleOperation(new ModifyArticleFieldOperation("unhide", "is_published", "1", false));\r
+    addSimpleArticleOperation(new ModifyArticleFieldOperation("hide", "is_published", "0", false));\r
+\r
+    addSimpleCommentOperation(new ModifyCommentFieldOperation("unhide", "is_published", "1"));\r
+    addSimpleCommentOperation(new ModifyCommentFieldOperation("hide", "is_published", "0"));\r
+  }\r
+\r
+  public String makePasswordDigest(String aPassword) {\r
+    return aPassword;\r
+  }\r
+\r
+  public void initializeArticle(Map anArticle) {\r
+    anArticle.put("is_published", "0");\r
+    anArticle.put("date", StringUtil.date2webdbDate(new GregorianCalendar()));\r
+  };\r
+\r
+  public List simpleCommentOperations() {\r
+    return simpleCommentOperations;\r
+  };\r
+\r
+  public List simpleArticleOperations() {\r
+    return simpleArticleOperations;\r
+  };\r
+\r
+  public MirSimpleEntityOperation simpleArticleOperationForName(String aName) {\r
+    return (MirSimpleEntityOperation) simpleArticleOperationsMap.get(aName);\r
+  };\r
+\r
+  public MirSimpleEntityOperation simpleCommentOperationForName(String aName) {\r
+    return (MirSimpleEntityOperation) simpleCommentOperationsMap.get(aName);\r
+  };\r
+\r
+  public void removeSimpleArticleOperation(String aName) {\r
+    simpleArticleOperations.remove(simpleArticleOperationsMap.get(aName));\r
+    simpleArticleOperationsMap.remove(aName);\r
+  }\r
+\r
+  public void addSimpleArticleOperation(MirSimpleEntityOperation anOperation) {\r
+    removeSimpleArticleOperation(anOperation.getName());\r
+    simpleArticleOperationsMap.put(anOperation.getName(), anOperation);\r
+    simpleArticleOperations.add(anOperation);\r
+  }\r
+\r
+  public void removeSimpleCommentOperation(String aName) {\r
+    simpleCommentOperations.remove(simpleCommentOperationsMap.get(aName));\r
+    simpleCommentOperationsMap.remove(aName);\r
+  }\r
+\r
+  public void addSimpleCommentOperation(MirSimpleEntityOperation anOperation) {\r
+    removeSimpleCommentOperation(anOperation.getName());\r
+    simpleCommentOperationsMap.put(anOperation.getName(), anOperation);\r
+    simpleCommentOperations.add(anOperation);\r
+  }\r
+\r
+  protected abstract static class EntityModifyingOperation implements MirSimpleEntityOperation {\r
+    private String name;\r
+\r
+    protected EntityModifyingOperation(String aName) {\r
+      name = aName;\r
+    }\r
+\r
+    public String getName() {\r
+      return name;\r
+    };\r
+\r
+    public boolean isAvailable(EntityAdapter anEntity) {\r
+      try {\r
+        Entity entity = anEntity.getEntity();\r
+        return isAvailable(entity);\r
+      }\r
+      catch (Throwable t) {\r
+        return false;\r
+      }\r
+    };\r
+\r
+    public void perform(EntityAdapter aUser, EntityAdapter anEntity) throws MirLocalizerExc, MirLocalizerFailure {\r
+      Entity entity = anEntity.getEntity();\r
+      try {\r
+        performModification(aUser, entity);\r
+        entity.update();\r
+      }\r
+      catch (Throwable t) {\r
+        throw new MirLocalizerFailure(t);\r
+      }\r
+    };\r
+\r
+    protected abstract boolean isAvailable(Entity anEntity) throws StorageObjectFailure ;\r
+    protected abstract void performModification(EntityAdapter aUser, Entity anEntity)  throws MirLocalizerExc, MirLocalizerFailure ;\r
+  }\r
+\r
+  public static abstract class CommentModifyingOperation extends EntityModifyingOperation {\r
+    public CommentModifyingOperation(String aName) {\r
+      super(aName);\r
+    }\r
+\r
+    protected boolean isAvailable(Entity anEntity) throws StorageObjectFailure {\r
+      return anEntity instanceof EntityComment && isAvailable((EntityComment) anEntity);\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, Entity anEntity) throws StorageObjectFailure {\r
+      performModification(aUser, (EntityComment) anEntity);\r
+      DatabaseContent.getInstance().setUnproduced("id="+anEntity.getValue("to_media"));\r
+    };\r
+\r
+    protected abstract boolean isAvailable(EntityComment aComment) throws StorageObjectFailure ;\r
+    protected abstract void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure ;\r
+  }\r
+\r
+  public static abstract class ArticleModifyingOperation extends EntityModifyingOperation {\r
+    private boolean logOperation;\r
+\r
+    public ArticleModifyingOperation(String aName, boolean aLogOperation) {\r
+      super(aName);\r
+\r
+      logOperation = aLogOperation;\r
+    }\r
+\r
+    protected boolean isAvailable(Entity anEntity) throws StorageObjectFailure {\r
+      return anEntity instanceof EntityContent && isAvailable((EntityContent) anEntity);\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, Entity anEntity) throws StorageObjectFailure {\r
+      performModification(aUser, (EntityContent) anEntity);\r
+      anEntity.setValueForProperty("is_produced", "0");\r
+\r
+      if (logOperation) {\r
+        try {\r
+          StringBuffer line = new StringBuffer();\r
+\r
+          line.append(DateTimeFunctions.advancedDateFormat(\r
+              MirGlobal.config().getString("Mir.DefaultDateTimeFormat"),\r
+              (new GregorianCalendar()).getTime(),\r
+              MirGlobal.config().getString("Mir.DefaultTimezone")));\r
+          line.append(" ");\r
+          if (aUser != null)\r
+            line.append(aUser.get("login"));\r
+          else\r
+            line.append("unknown");\r
+\r
+          line.append(" ");\r
+          line.append(getName());\r
+          ( (EntityContent) anEntity).appendToComments(line.toString());\r
+        }\r
+        catch (Throwable t) {\r
+          logger.error("Error while trying to log an article operation: " + t.toString());\r
+        }\r
+      }\r
+    };\r
+\r
+    protected abstract boolean isAvailable(EntityContent anArticle) throws StorageObjectFailure ;\r
+    protected abstract void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure ;\r
+  }\r
+\r
+  protected static class SetCommentFieldOperation extends CommentModifyingOperation {\r
+    private String field;\r
+    private String value;\r
+\r
+    public SetCommentFieldOperation(String aName, String aField, String aValue) {\r
+      super(aName);\r
+\r
+      field = aField;\r
+      value = aValue;\r
+    }\r
+\r
+    protected boolean isAvailable(EntityComment aComment) {\r
+      return true;\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {\r
+      aComment.setValueForProperty(field, value);\r
+    }\r
+  }\r
+\r
+  protected static class SetCommentFieldsOperation extends CommentModifyingOperation {\r
+    private Map values;\r
+\r
+    public SetCommentFieldsOperation(String aName, String aFields[], String aValues[]) throws MirLocalizerExc {\r
+      super(aName);\r
+\r
+      values = new HashMap();\r
+\r
+      for (int i=0; i<aFields.length; i++)\r
+        values.put(aFields[i], aValues[i]);\r
+    }\r
+\r
+    protected boolean isAvailable(EntityComment aComment) {\r
+      return true;\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {\r
+      Iterator i = values.entrySet().iterator();\r
+\r
+      while (i.hasNext()) {\r
+        Map.Entry entry = (Map.Entry) i.next();\r
+        aComment.setValueForProperty((String) entry.getKey(), (String) entry.getValue());\r
+      }\r
+    }\r
+  }\r
+\r
+\r
+  protected static class ModifyCommentFieldOperation extends CommentModifyingOperation {\r
+    private String field;\r
+    private String value;\r
+\r
+    public ModifyCommentFieldOperation(String aName, String aField, String aValue) {\r
+      super(aName);\r
+\r
+      field = aField;\r
+      value = aValue;\r
+    }\r
+\r
+    protected boolean isAvailable(EntityComment aComment) {\r
+      return aComment.getValue(field) == null || !aComment.getValue(field).equals(value);\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityComment aComment) throws StorageObjectFailure {\r
+      aComment.setValueForProperty(field, value);\r
+    }\r
+  }\r
+\r
+  protected static class SetArticleFieldOperation extends ArticleModifyingOperation {\r
+    private String field;\r
+    private String value;\r
+\r
+    public SetArticleFieldOperation(String aName, String aField, String aValue, boolean aLogOperation) {\r
+      super(aName, aLogOperation);\r
+\r
+      field = aField;\r
+      value = aValue;\r
+    }\r
+\r
+    protected boolean isAvailable(EntityContent anArticle) {\r
+      return true;\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {\r
+      anArticle.setValueForProperty(field, value);\r
+    }\r
+  }\r
+\r
+  protected static class ModifyArticleFieldOperation extends ArticleModifyingOperation {\r
+    private String field;\r
+    private String value;\r
+\r
+    public ModifyArticleFieldOperation(String aName, String aField, String aValue, boolean aLogOperation) {\r
+      super(aName, aLogOperation);\r
+\r
+      field = aField;\r
+      value = aValue;\r
+    }\r
+\r
+    protected boolean isAvailable(EntityContent anArticle) {\r
+      return anArticle.getValue(field) == null || !anArticle.getValue(field).equals(value);\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {\r
+      anArticle.setValueForProperty(field, value);\r
+    }\r
+  }\r
+\r
+  protected static class ChangeArticleFieldOperation extends ArticleModifyingOperation {\r
+    private String field;\r
+    private Set oldValues;\r
+    private String newValue;\r
+\r
+    public ChangeArticleFieldOperation(String aName, String aField, String anOldValues[], String aNewValue, boolean aLogOperation) {\r
+      super(aName, aLogOperation);\r
+\r
+      field = aField;\r
+      newValue = aNewValue;\r
+      oldValues = new HashSet(Arrays.asList(anOldValues));\r
+    }\r
+    public ChangeArticleFieldOperation(String aName, String aField, String anOldValue, String aNewValue, boolean aLogOperation) {\r
+      this(aName, aField, new String[] {anOldValue}, aNewValue, aLogOperation);\r
+    }\r
+\r
+    protected boolean isAvailable(EntityContent anArticle) {\r
+      return anArticle.getValue(field) != null && oldValues.contains(anArticle.getValue(field));\r
+    }\r
+\r
+    protected void performModification(EntityAdapter aUser, EntityContent anArticle) throws StorageObjectFailure {\r
+      anArticle.setValueForProperty(field, newValue);\r
+    }\r
+  }\r
+}\r
index 3ce6552..f7471ee 100755 (executable)
@@ -61,7 +61,7 @@ import mircoders.storage.DatabaseContentToTopics;
  *  ServletModuleContent -\r
  *  deliver html for the article admin form.\r
  *\r
- * @version $Id: ServletModuleContent.java,v 1.52.2.8 2003/09/19 02:54:51 zapata Exp $\r
+ * @version $Id: ServletModuleContent.java,v 1.52.2.9 2003/09/20 10:54:18 zapata Exp $\r
  * @author rk, mir-coders\r
  *\r
  */\r
@@ -328,6 +328,31 @@ public class ServletModuleContent extends ServletModule
       }\r
       responseData.put("article", article);\r
 \r
+/*\r
+\r
+      Map topicsMap = new HashMap();\r
+\r
+      String[] topicCategories = configuration.getStringArray("Mir.Localizer.Admin.TopicListOrder");\r
+\r
+      for (int i = 0; i<topicCategories; i++) {\r
+        Map categoryMap = new HashMap();\r
+\r
+        String key="";\r
+        String listtype="";\r
+        String listparameter="";\r
+\r
+                 topic:1:3:archiv_url='bla':title\r
+\r
+        topicsMap.put(key, categoryMap);\r
+      }\r
+\r
+\r
+      responseData.put("topics", topicsMap);\r
+\r
+\r
+*/\r
+\r
+\r
       responseData.put("topics",\r
           new EntityIteratorAdapter("", configuration.getString("Mir.Localizer.Admin.TopicListOrder"),\r
           20, MirGlobal.localizer().dataModel().adapterModel(), "topic"));\r
index bb33dd2..68408d5 100755 (executable)
@@ -44,6 +44,7 @@ import mir.servlet.ServletModule;
 import mir.storage.StorageObjectFailure;\r
 import mircoders.module.ModuleMediafolder;\r
 import mircoders.storage.DatabaseMediafolder;\r
+import mircoders.global.*;\r
 \r
 public class ServletModuleMediafolder extends ServletModule\r
 {\r
@@ -55,10 +56,12 @@ public class ServletModuleMediafolder extends ServletModule
     logger = new LoggerWrapper("ServletModule.Mediafolder");\r
 \r
     try {\r
+      model = MirGlobal.localizer().dataModel().adapterModel();\r
+      definition = "mediaFolder";\r
       mainModule = new ModuleMediafolder(DatabaseMediafolder.getInstance());\r
     }\r
-    catch (StorageObjectFailure e) {\r
-      logger.error("Failed to initialize ServletModuleMediafolder: " + e.getMessage());\r
+    catch (Throwable t) {\r
+      logger.error("Failed to initialize ServletModuleMediafolder: " + t.toString());\r
     }\r
   }\r
 \r