indy.nl updates
[mir.git] / source / OpenMir.java
1 import java.io.*;
2 import java.util.*;
3 import java.net.*;
4 import java.lang.reflect.*;
5 import javax.servlet.*;
6 import javax.servlet.http.*;
7 import java.sql.*;
8
9 import freemarker.template.*;
10
11 import mir.misc.*;
12 import mir.servlet.*;
13
14 import mircoders.servlet.*;
15 import mircoders.module.*;
16 import mircoders.entity.*;
17 import mircoders.storage.*;
18
19 /**
20  *  OpenMir.java - main servlet for open posting and comment feature to articles
21  *
22  *  @author RK 1999-2001
23  *
24  */
25
26
27 public class OpenMir extends AbstractServlet {
28
29   //private static boolean                confed=false;
30   private static String lang;
31   public HttpSession session;
32
33   public void doGet(HttpServletRequest req, HttpServletResponse res)
34     throws ServletException, IOException {
35     doPost(req,res);
36   }
37
38   public void doPost(HttpServletRequest req, HttpServletResponse res)
39     throws ServletException, IOException {
40
41     long            startTime = (new java.util.Date()).getTime();
42     long            sessionConnectTime=0;
43
44     // get the configration - this could conflict if 2 mirs are in the
45     // VM maybe? to be checked. -mh
46     if(getServletContext().getAttribute("mir.confed") == null) {
47       getConfig(req);
48     }
49     session = req.getSession();
50
51     if(session.getAttribute("Language")==null){
52       if (req.getParameter("language")!=null) {
53         setLanguage(session, req.getParameter("language"));
54       }
55       else {
56         setLanguage(session, getAcceptLanguage(req));
57       }
58     }
59
60     if (req.getParameter("language")!=null)
61       setLocale(session, new Locale(req.getParameter("language"), "") );
62
63     res.setContentType("text/html");
64     try {
65       ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(),req,res);
66     }
67     catch (ServletModuleUserException e) {
68       handleUserError(req,res,res.getWriter(), e.getMsg());
69     }
70     catch (ServletModuleException e){
71       e.printStackTrace();
72       handleError(req,res,res.getWriter(), "OpenIndy :: ServletException in Module ServletModule -- " + e.toString());
73     }
74     // timing...
75     sessionConnectTime = new java.util.Date().getTime() - startTime;
76     theLog.printInfo("EXECTIME (ServletModuleOpenIndy): " + sessionConnectTime + " ms");
77   }
78
79   private void handleUserError(HttpServletRequest req, HttpServletResponse res,
80                                PrintWriter out, String errorString) {
81     try {
82       theLog.printError(errorString);
83       SimpleHash modelRoot = new SimpleHash();
84       modelRoot.put("errorstring", new SimpleScalar(errorString));
85       modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(new GregorianCalendar())));
86       HTMLTemplateProcessor.process(res,MirConfig.getProp("Mir.UserErrorTemplate"),
87                                     modelRoot, out, req.getLocale() );
88       out.close();
89     }
90     catch (Exception e) {
91       System.err.println("Fehler in UserErrorTemplate");
92     }
93
94   }
95
96   private void handleError(HttpServletRequest req, HttpServletResponse res,PrintWriter out, String errorString) {
97
98     try {
99       theLog.printError(errorString);
100       SimpleHash modelRoot = new SimpleHash();
101       modelRoot.put("errorstring", new SimpleScalar(errorString));
102       modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(
103                                                new GregorianCalendar())));
104       HTMLTemplateProcessor.process(res,MirConfig.getProp("Mir.ErrorTemplate"),
105                                     modelRoot,out, req.getLocale());
106       out.close();
107     }
108     catch (Exception e) {
109       System.err.println("Fehler in ErrorTemplate");
110     }
111
112   }
113
114   public String getServletInfo(){ return "OpenIndy 1.0 rev01"; }
115
116 }
117