*/
-public class OpenMir extends AbstractServlet
-{
- private static Logfile theLog;
- private static boolean confed=false;
- private static String lang;
+public class OpenMir extends AbstractServlet {
+
+ //private static boolean confed=false;
+ private static String lang;
+ public HttpSession session;
+
+ public void doGet(HttpServletRequest req, HttpServletResponse res)
+ throws ServletException, IOException {
+ doPost(req,res);
+ }
+
+ public void doPost(HttpServletRequest req, HttpServletResponse res)
+ throws ServletException, IOException {
+
+ long startTime = (new java.util.Date()).getTime();
+ long sessionConnectTime=0;
+
+ // get the configration
+ if(getServletContext().getAttribute("mir.confed") == null) {
+ getConfig(req);
+ }
+ session = req.getSession();
+
+ if(session.getAttribute("Language")==null){
+ setLanguage(session,getAcceptLanguage(req));
+ }
- public void doGet(HttpServletRequest req, HttpServletResponse res)
- throws ServletException, IOException {
- doPost(req,res);
- }
+ res.setContentType("text/html");
+ try {
+ ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(),req,res);
+ }
+ catch (ServletModuleUserException e) {
+ handleUserError(req,res,res.getWriter(), e.getMsg());
+ }
+ catch (ServletModuleException e){
+ e.printStackTrace();
+ handleError(req,res,res.getWriter(), "OpenIndy :: ServletException in Module ServletModule -- " + e.toString());
+ }
+ // timing...
+ sessionConnectTime = new java.util.Date().getTime() - startTime;
+ theLog.printInfo("EXECTIME (ServletModuleOpenIndy): " + sessionConnectTime + " ms");
+ }
+
+ private void handleUserError(HttpServletRequest req, HttpServletResponse res,
+ PrintWriter out, String errorString) {
+ try {
+ theLog.printError(errorString);
+ SimpleHash modelRoot = new SimpleHash();
+ modelRoot.put("errorstring", new SimpleScalar(errorString));
+ modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(new GregorianCalendar())));
+ HTMLTemplateProcessor.process(res,MirConfig.getProp("Mir.UserErrorTemplate"),
+ modelRoot, out, req.getLocale() );
+ out.close();
+ }
+ catch (Exception e) {
+ System.err.println("Fehler in UserErrorTemplate");
+ }
- public void doPost(HttpServletRequest req, HttpServletResponse res)
- throws ServletException, IOException {
+ }
- long startTime = (new java.util.Date()).getTime();
- long sessionConnectTime=0;
+ private void handleError(HttpServletRequest req, HttpServletResponse res,PrintWriter out, String errorString) {
- if (!confed){
- confed = getConfig(req);
+ try {
+ theLog.printError(errorString);
+ SimpleHash modelRoot = new SimpleHash();
+ modelRoot.put("errorstring", new SimpleScalar(errorString));
+ modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(
+ new GregorianCalendar())));
+ HTMLTemplateProcessor.process(res,MirConfig.getProp("Mir.ErrorTemplate"),
+ modelRoot,out, req.getLocale());
+ out.close();
}
-
- HttpSession session = req.getSession(true);
- if(session.getAttribute("Language")==null){
- setLanguage(req,getAcceptLanguage(req));
+ catch (Exception e) {
+ System.err.println("Fehler in ErrorTemplate");
}
- res.setContentType("text/html");
- try {
- ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(),req,res);
- }
- catch (ServletModuleException e){ handleError(res.getWriter(), "OpenIndy :: ServletException in Module ServletModule -- " + e.toString()); }
- // timing...
- sessionConnectTime = new java.util.Date().getTime() - startTime;
- theLog.printInfo("EXECTIME (ServletModuleOpenIndy): " + sessionConnectTime + " ms");
- }
-
- private void handleError(PrintWriter out, String errorString) {
-
- try {
- theLog.printError(errorString);
- SimpleHash modelRoot = new SimpleHash();
- modelRoot.put("errorstring", new SimpleScalar(errorString));
- modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(new GregorianCalendar())));
- HTMLTemplateProcessor.process(Configuration.getProperty("Mir.ErrorTemplate"),modelRoot,out);
- out.close();
- }
- catch (Exception e) {
- System.err.println("Fehler in ErrorTemplate");
- }
-
- }
-
- public String getServletInfo(){ return "OpenIndy 1.0 rev01"; }
+ }
+
+ public String getServletInfo(){ return "OpenIndy 1.0 rev01"; }
}