-import java.io.*;
-import java.util.*;
-import java.net.*;
-import java.lang.reflect.*;
-import javax.servlet.*;
-import javax.servlet.http.*;
-import java.sql.*;
-
-import freemarker.template.*;
-
-import mir.misc.*;
-import mir.servlet.*;
+/*
+ * 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 the com.oreilly.servlet library, 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.
+ */
-import mircoders.servlet.*;
-import mircoders.module.*;
-import mircoders.entity.*;
-import mircoders.storage.*;
+import java.io.IOException;
+import java.io.PrintWriter;
+import java.util.GregorianCalendar;
+import java.util.Locale;
+
+import javax.servlet.ServletException;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import javax.servlet.http.HttpSession;
+
+import mir.config.MirPropertiesConfiguration;
+import mir.misc.HTMLTemplateProcessor;
+import mir.misc.StringUtil;
+import mir.servlet.AbstractServlet;
+import mir.servlet.ServletModuleDispatch;
+import mir.servlet.ServletModuleUserExc;
+import mir.util.ExceptionFunctions;
+import mircoders.servlet.ServletModuleOpenIndy;
+import freemarker.template.SimpleHash;
+import freemarker.template.SimpleScalar;
/**
* OpenMir.java - main servlet for open posting and comment feature to articles
*
- * @author RK 1999-2001
+ * @author RK 1999-2001, the mir-coders group
+ * @version $Id: OpenMir.java,v 1.24 2003/03/08 17:18:19 idfx Exp $
*
*/
-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 String lang;
+ public HttpSession session;
- public void doGet(HttpServletRequest req, HttpServletResponse res)
- throws ServletException, IOException {
- doPost(req,res);
- }
+ public void doGet(HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletException, IOException {
+ doPost(aRequest,aResponse);
+ }
- public void doPost(HttpServletRequest req, HttpServletResponse res)
- throws ServletException, IOException {
+ public void doPost(HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletException, IOException {
+ long startTime = System.currentTimeMillis();
+ long sessionConnectTime=0;
- long startTime = (new java.util.Date()).getTime();
- long sessionConnectTime=0;
+ session = aRequest.getSession();
- if (!confed){
- confed = getConfig(req);
+ if(session.getAttribute("Language")==null){
+ if (aRequest.getParameter("language")!=null) {
+ setLanguage(session, aRequest.getParameter("language"));
+ }
+ else {
+ setLanguage(session, getAcceptLanguage(aRequest));
+ }
}
- HttpSession session = req.getSession(true);
- if(session.getAttribute("Language")==null){
- setLanguage(req,getAcceptLanguage(req));
+ if (session.getAttribute("language")!=null)
+ setLocale(session, new Locale((String) session.getAttribute("language"), "") );
+
+ //make sure client browsers don't cache anything
+ setNoCaching(aResponse);
+
+ aResponse.setContentType("text/html");
+ //aResponse.setContentType("text/html; charset="+MirPropertiesConfiguration.instance().getString("Mir.DefaultHTMLCharset"));
+
+ try {
+ ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(), aRequest, aResponse);
+ }
+ catch (Throwable e) {
+ Throwable cause = ExceptionFunctions.traceCauseException(e);
+
+ if (cause instanceof ServletModuleUserExc)
+ handleUserError(aRequest, aResponse, aResponse.getWriter(), (ServletModuleUserExc) cause);
+ else
+ handleError(aRequest, aResponse, aResponse.getWriter(), cause);
+
}
- 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"; }
+ sessionConnectTime = System.currentTimeMillis() - startTime;
+ logger.debug("EXECTIME (ServletModuleOpenIndy): " + sessionConnectTime + " ms");
+ }
+
+ private void handleUserError(HttpServletRequest aRequest, HttpServletResponse aResponse,
+ PrintWriter out, Throwable anException) {
+ try {
+ logger.info("user error: " + anException.getMessage());
+ SimpleHash modelRoot = new SimpleHash();
+ modelRoot.put("errorstring", new SimpleScalar(anException.getMessage()));
+ modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(new GregorianCalendar())));
+ HTMLTemplateProcessor.process(aResponse,MirPropertiesConfiguration.instance().getString("Mir.OpenIndy.UserErrorTemplate"),
+ modelRoot, out, aRequest.getLocale() );
+ out.close();
+ }
+ catch (Exception e) {
+ logger.error("Error in UserErrorTemplate");
+ }
+ }
+
+ private void handleError(HttpServletRequest aRequest, HttpServletResponse aResponse,PrintWriter out, Throwable anException) {
+ try {
+ logger.error("error: " + anException);
+ SimpleHash modelRoot = new SimpleHash();
+ modelRoot.put("errorstring", new SimpleScalar(anException.getMessage()));
+ modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(
+ new GregorianCalendar())));
+ HTMLTemplateProcessor.process(aResponse,MirPropertiesConfiguration.instance().getString("Mir.OpenIndy.ErrorTemplate"),
+ modelRoot,out, aRequest.getLocale());
+ out.close();
+ }
+ catch (Exception e) {
+ logger.error("Error in ErrorTemplate");
+ }
+
+ }
+
+ public String getServletInfo(){
+ return "OpenMir "+configuration.getString("Mir.Version");
+ }
}