added some stuff to make sure xml is encoded properly...
[mir.git] / source / mircoders / servlet / ServletModuleHidden.java
1 /*
2  * Copyright (C) 2001, 2002  The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with the com.oreilly.servlet library, any library
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of
24  * the above that use the same license as the above), and distribute linked
25  * combinations including the two.  You must obey the GNU General Public
26  * License in all respects for all of the code used other than the above
27  * mentioned libraries.  If you modify this file, you may extend this exception
28  * to your version of the file, but you are not obligated to do so.  If you do
29  * not wish to do so, delete this exception statement from your version.
30  */
31
32 package mircoders.servlet;
33
34 import java.io.*;
35 import java.sql.*;
36 import java.util.*;
37 import java.net.*;
38 import javax.servlet.*;
39 import javax.servlet.http.*;
40
41 import freemarker.template.*;
42
43 import mir.servlet.*;
44 import mir.module.*;
45 import mir.misc.*;
46 import mir.entity.*;
47 import mir.storage.*;
48 import mir.entity.*;
49 import mir.log.*;
50
51 import mircoders.storage.*;
52 import mircoders.module.*;
53
54 /*
55  *  ServletModuleHidden - output of so called "censored" articles
56  *  @author mh
57  *  @version $Id
58  *
59  */
60
61 public class ServletModuleHidden extends ServletModule
62 {
63
64 // Singelton / Kontruktor
65   private static ServletModuleHidden instance = new ServletModuleHidden();
66   public static ServletModule getInstance() { return instance; }
67
68   private ServletModuleHidden() {
69     logger = new LoggerWrapper("ServletModule.Hidden");
70     templateListString = MirConfig.getProp("ServletModule.Hidden.ListTemplate");
71     try {
72       mainModule = new ModuleContent(DatabaseContent.getInstance());
73     }
74     catch (StorageObjectException e) {
75       logger.error("initialization of servletmoduleHidden failed: " + e.getMessage());
76     }
77   }
78
79
80   public void list(HttpServletRequest req, HttpServletResponse res)
81       throws ServletModuleException
82   {
83 // determine parameter
84     SimpleHash mergeData = new SimpleHash();
85     String query_year = req.getParameter("year");
86     String query_month = req.getParameter("month");
87     String order = "webdb_create";
88
89 // form sql statement
90     String whereClause = "is_published=false AND webdb_create LIKE '"+
91                          query_year+"-"+query_month+"%'";
92
93     logger.debug("ServletModuleHidden.list: whereclause: " + whereClause);
94
95 // fetch and deliver
96     try {
97
98       if ((query_year!=null && !query_year.equals(""))
99           && (query_month!=null && !query_month.equals(""))) {
100         EntityList theList = mainModule.getByWhereClause(whereClause, order, -1);
101         if (theList!=null && theList.size()>0) {
102
103 //make articleHash for comment
104           StringBuffer buf= new StringBuffer("id in (");boolean first=true;
105           for(int i=0;i<theList.size();i++) {
106             if (first==false) buf.append(",");
107             first=false;
108             buf.append(theList.elementAt(i).getValue("to_media"));
109           }
110           buf.append(")");
111           SimpleHash articleHash =
112               HTMLTemplateProcessor.makeSimpleHash(
113               mainModule.getByWhereClause(buf.toString(),-1));
114           mergeData.put("articleHash", articleHash);
115
116 // send the year and month for use in the list template
117           mergeData.put("year", query_year);
118           mergeData.put("month", query_month);
119 // get comment
120           mergeData.put("contentlist",theList);
121         }
122       }
123 // raus damit
124       HTMLTemplateProcessor.process(res, templateListString, mergeData, res.getWriter(), getLocale(req));
125     }
126     catch (ModuleException e) {throw new ServletModuleException(e.toString());}
127     catch (IOException e) {throw new ServletModuleException(e.toString());}
128     catch (Exception e) {throw new ServletModuleException(e.toString());}
129   }
130 }