added:
[mir.git] / source / mircoders / global / MirGlobal.java
index 1c21e32..e64d14a 100755 (executable)
 
 package mircoders.global;
 
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-
 import mir.bundle.BasicBundleFactory;
 import mir.bundle.BundleFactory;
 import mir.bundle.CascadingBundleFactory;
@@ -44,15 +38,21 @@ import mir.config.MirPropertiesConfiguration;
 import mir.entity.adapter.EntityAdapter;
 import mir.log.LoggerEngine;
 import mir.log.LoggerWrapper;
-import mir.misc.ConfigException;
 import mircoders.accesscontrol.AccessControl;
 import mircoders.entity.EntityComment;
 import mircoders.entity.EntityContent;
 import mircoders.entity.EntityUsers;
 import mircoders.localizer.MirAdminInterfaceLocalizer;
-import mircoders.localizer.MirCachingLocalizerDecorator;
+import mircoders.localizer.LocalizerCache;
 import mircoders.localizer.MirLocalizer;
 import mircoders.localizer.MirLocalizerExc;
+import mircoders.localizer.MirLocalizerFailure;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
 
 public class MirGlobal {
   static private MirLocalizer localizer;
@@ -62,11 +62,13 @@ public class MirGlobal {
   static private AccessControl accessControl;
   static private Map articleOperations;
   static private Map commentOperations;
-  static private Map loggedInUsers = new HashMap();
-  static private Map loggedInUserIds = new HashMap();
+  static private final Map loggedInUsers = new HashMap();
+  static private final Map loggedInUserIds = new HashMap();
   static private LoggerWrapper logger = new LoggerWrapper("Global");
   static private LoggerWrapper adminUsageLogger = new LoggerWrapper("AdminUsage");
-//  static private ChangeEngine changeEngine = new ChangeEngine();
+
+  static private ChangeEngine changeEngine = new ChangeEngine();
+
   static private DatabaseEngine databaseEngine;
 
   static private BundleFactory bundleFactory =
@@ -75,6 +77,9 @@ public class MirGlobal {
             new PropertiesFileBundleLoader(
                 config().getHome())));
 
+  private MirGlobal() {
+  }
+
   public synchronized static MirLocalizer localizer() {
     String localizerClassName;
     Class localizerClass;
@@ -86,20 +91,21 @@ public class MirGlobal {
         localizerClass = Class.forName(localizerClassName);
       }
       catch (Throwable t) {
-        throw new ConfigException("localizer class '" +
-            localizerClassName + "' not found: " + t.toString());
+        throw new MirLocalizerFailure("localizer class '" +
+            localizerClassName + "' not found: ", t);
       }
 
-      if (!(MirLocalizer.class.isAssignableFrom(localizerClass)))
-        throw new ConfigException("localizer class '" +
+      if (!MirLocalizer.class.isAssignableFrom(localizerClass)) {
+        throw new MirLocalizerFailure("localizer class '" +
             localizerClassName + "' is not assignable from MirLocalizer");
+      }
 
       try {
-        localizer = new MirCachingLocalizerDecorator((MirLocalizer) localizerClass.newInstance());
+        localizer = new LocalizerCache((MirLocalizer) localizerClass.newInstance());
       }
       catch (Throwable t) {
-        throw new ConfigException("localizer class '" +
-            localizerClassName + "' cannot be instantiated: " + t.toString());
+        throw new MirLocalizerFailure("localizer class '" +
+            localizerClassName + "' cannot be instantiated: " + t.getMessage(), t);
       }
     }
 
@@ -120,7 +126,7 @@ public class MirGlobal {
     return result.toString();
   }
 
-  public synchronized static Abuse abuse() {
+  synchronized public static Abuse abuse() {
     if (abuse==null) {
       try {
         abuse = new Abuse(localizer().dataModel().adapterModel());
@@ -136,17 +142,18 @@ public class MirGlobal {
   /**
    * returns the global change engine (used to track changed files)
    */
-//  public static ChangeEngine getChangeEngine() {
-//    return changeEngine;
-//  }
+  public static ChangeEngine getChangeEngine() {
+    return changeEngine;
+  }
 
   public static MirPropertiesConfiguration config() {
     return MirPropertiesConfiguration.instance();
   }
 
-  public synchronized static DatabaseEngine getDatabaseEngine() {
-    if (databaseEngine==null)
+  synchronized public static DatabaseEngine getDatabaseEngine() {
+    if (databaseEngine==null) {
       databaseEngine = new DatabaseEngine();
+    }
 
     return databaseEngine;
   }
@@ -168,7 +175,7 @@ public class MirGlobal {
     }
   }
 
-  public static synchronized AccessControl accessControl() {
+  synchronized public static AccessControl accessControl() {
     if (accessControl == null) {
       accessControl=new AccessControl();
     }
@@ -177,80 +184,82 @@ public class MirGlobal {
   }
 
   public static void performArticleOperation(EntityUsers aUser, EntityContent  anArticle, String anOperation) {
-    MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation = getArticleOperationForName(anOperation);
+    MirAdminInterfaceLocalizer.EntityOperation operation = getArticleOperationForName(anOperation);
 
     try {
       EntityAdapter user = null;
-      if (aUser!=null)
+      if (aUser!=null) {
           user = localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser);
+      }
 
-      if (operation!=null)
+      if (operation!=null) {
         operation.perform(
             user,
             localizer().dataModel().adapterModel().makeEntityAdapter("content", anArticle));
+      }
     }
     catch (Throwable t) {
-      t.printStackTrace(logger.asPrintWriter(LoggerWrapper.DEBUG_MESSAGE));
-
-      throw new RuntimeException(t.toString());
+      throw new MirGlobalFailure(t.getMessage(), t);
     }
   }
 
   public static void performCommentOperation(EntityUsers aUser, EntityComment  aComment, String anOperation) {
-    MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation = getCommentOperationForName(anOperation);
+    MirAdminInterfaceLocalizer.EntityOperation operation = getCommentOperationForName(anOperation);
 
     try {
       EntityAdapter user = null;
-      if (aUser!=null)
+      if (aUser!=null) {
           user = localizer().dataModel().adapterModel().makeEntityAdapter("user", aUser);
+      }
 
-      if (operation!=null)
+      if (operation!=null) {
         operation.perform(
             user,
             localizer().dataModel().adapterModel().makeEntityAdapter("comment", aComment));
+      }
     }
     catch (Throwable t) {
-      throw new RuntimeException(t.toString());
+      throw new MirGlobalFailure(t.getMessage(), t);
     }
   }
 
-  private synchronized static MirAdminInterfaceLocalizer.MirSimpleEntityOperation
+  private synchronized static MirAdminInterfaceLocalizer.EntityOperation
       getArticleOperationForName(String aName) {
     try {
       if (articleOperations == null) {
         articleOperations = new HashMap();
         Iterator i = localizer().adminInterface().simpleArticleOperations().iterator();
         while (i.hasNext()) {
-          MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation =
-              (MirAdminInterfaceLocalizer.MirSimpleEntityOperation) i.next();
+          MirAdminInterfaceLocalizer.EntityOperation operation =
+              (MirAdminInterfaceLocalizer.EntityOperation) i.next();
           articleOperations.put(operation.getName(), operation);
         }
       }
 
-      return (MirAdminInterfaceLocalizer.MirSimpleEntityOperation) articleOperations.get(aName);
+      return (MirAdminInterfaceLocalizer.EntityOperation) articleOperations.get(aName);
     }
     catch (Throwable t) {
-      throw new RuntimeException(t.toString());
+      throw new MirGlobalFailure(t.getMessage(), t);
     }
   }
 
-  private synchronized static MirAdminInterfaceLocalizer.MirSimpleEntityOperation
+  private synchronized static MirAdminInterfaceLocalizer.EntityOperation
       getCommentOperationForName(String aName) {
     try {
       if (commentOperations == null) {
         commentOperations = new HashMap();
         Iterator i = localizer().adminInterface().simpleCommentOperations().iterator();
         while (i.hasNext()) {
-          MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation =
-              (MirAdminInterfaceLocalizer.MirSimpleEntityOperation) i.next();
+          MirAdminInterfaceLocalizer.EntityOperation operation =
+              (MirAdminInterfaceLocalizer.EntityOperation) i.next();
           commentOperations.put(operation.getName(), operation);
         }
       }
 
-      return (MirAdminInterfaceLocalizer.MirSimpleEntityOperation) commentOperations.get(aName);
+      return (MirAdminInterfaceLocalizer.EntityOperation) commentOperations.get(aName);
     }
     catch (Throwable t) {
-      throw new RuntimeException(t.toString());
+      throw new MirGlobalFailure(t.getMessage(), t);
     }
   }