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;
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;
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 =
new PropertiesFileBundleLoader(
config().getHome())));
+ private MirGlobal() {
+ }
+
public synchronized static MirLocalizer localizer() {
String localizerClassName;
Class localizerClass;
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);
}
}
return result.toString();
}
- public synchronized static Abuse abuse() {
+ synchronized public static Abuse abuse() {
if (abuse==null) {
try {
abuse = new Abuse(localizer().dataModel().adapterModel());
/**
* 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;
}
}
}
- public static synchronized AccessControl accessControl() {
+ synchronized public static AccessControl accessControl() {
if (accessControl == null) {
accessControl=new AccessControl();
}
}
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);
}
}