import mir.misc.StringUtil;
import mir.servlet.AbstractServlet;
import mir.servlet.ServletModuleDispatch;
-import mir.servlet.ServletModuleException;
-import mir.servlet.ServletModuleUserException;
+import mir.servlet.ServletModuleExc;
+import mir.servlet.ServletModuleUserExc;
+import mir.servlet.ServletModuleFailure;
+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, the mir-coders group
- * @version $Id: OpenMir.java,v 1.21 2003/03/05 19:23:14 idfx Exp $
+ * @version $Id: OpenMir.java,v 1.22 2003/03/06 05:40:38 zapata Exp $
*
*/
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 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;
- session = req.getSession();
+ session = aRequest.getSession();
if(session.getAttribute("Language")==null){
- if (req.getParameter("language")!=null) {
- setLanguage(session, req.getParameter("language"));
+ if (aRequest.getParameter("language")!=null) {
+ setLanguage(session, aRequest.getParameter("language"));
}
else {
- setLanguage(session, getAcceptLanguage(req));
+ setLanguage(session, getAcceptLanguage(aRequest));
}
}
- if (req.getParameter("language")!=null)
- setLocale(session, new Locale(req.getParameter("language"), "") );
+ if (session.getAttribute("language")!=null)
+ setLocale(session, new Locale((String) session.getAttribute("language"), "") );
//make sure client browsers don't cache anything
- setNoCaching(res);
+ setNoCaching(aResponse);
+
+ aResponse.setContentType("text/html");
+ //aResponse.setContentType("text/html; charset="+MirPropertiesConfiguration.instance().getString("Mir.DefaultHTMLCharset"));
- res.setContentType("text/html");
- //res.setContentType("text/html; charset="+MirPropertiesConfiguration.instance().getString("Mir.DefaultHTMLCharset"));
try {
- ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(),req,res);
+ ServletModuleDispatch.dispatch(ServletModuleOpenIndy.getInstance(), aRequest, aResponse);
}
- catch (ServletModuleUserException e) {
- handleUserError(req,res,res.getWriter(), e.getMessage());
- }
- catch (ServletModuleException e){
- e.printStackTrace();
- handleError(req,res,res.getWriter(), "OpenIndy :: ServletException in Module ServletModule -- " + e.getMessage());
+ 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);
+
}
- // timing...
+
sessionConnectTime = System.currentTimeMillis() - startTime;
logger.debug("EXECTIME (ServletModuleOpenIndy): " + sessionConnectTime + " ms");
}
- private void handleUserError(HttpServletRequest req, HttpServletResponse res,
- PrintWriter out, String errorString) {
+ private void handleUserError(HttpServletRequest aRequest, HttpServletResponse aResponse,
+ PrintWriter out, Throwable anException) {
try {
- logger.error(errorString);
+ logger.info("user error: " + anException.getMessage());
SimpleHash modelRoot = new SimpleHash();
- modelRoot.put("errorstring", new SimpleScalar(errorString));
+ modelRoot.put("errorstring", new SimpleScalar(anException.getMessage()));
modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(new GregorianCalendar())));
- HTMLTemplateProcessor.process(res,MirPropertiesConfiguration.instance().getString("Mir.UserErrorTemplate"),
- modelRoot, out, req.getLocale() );
+ HTMLTemplateProcessor.process(aResponse,MirPropertiesConfiguration.instance().getString("Mir.UserErrorTemplate"),
+ modelRoot, out, aRequest.getLocale() );
out.close();
}
catch (Exception e) {
}
- private void handleError(HttpServletRequest req, HttpServletResponse res,PrintWriter out, String errorString) {
+ private void handleError(HttpServletRequest aRequest, HttpServletResponse aResponse,PrintWriter out, Throwable anException) {
try {
- logger.error(errorString);
+ logger.error("error: " + anException);
SimpleHash modelRoot = new SimpleHash();
- modelRoot.put("errorstring", new SimpleScalar(errorString));
+ modelRoot.put("errorstring", new SimpleScalar(anException.getMessage()));
modelRoot.put("date", new SimpleScalar(StringUtil.date2readableDateTime(
new GregorianCalendar())));
- HTMLTemplateProcessor.process(res,MirPropertiesConfiguration.instance().getString("Mir.ErrorTemplate"),
- modelRoot,out, req.getLocale());
+ HTMLTemplateProcessor.process(aResponse,MirPropertiesConfiguration.instance().getString("Mir.ErrorTemplate"),
+ modelRoot,out, aRequest.getLocale());
out.close();
}
catch (Exception e) {