error handling!
[mir.git] / source / mircoders / producer / ProducerTopics.java
1 package mircoders.producer;
2
3 import java.io.*;
4 import java.lang.*;
5 import java.lang.reflect.*;
6 import java.util.*;
7 import java.sql.*;
8
9 import freemarker.template.*;
10
11 import mir.misc.*;
12 import mir.media.*;
13 import mir.storage.*;
14 import mir.module.*;
15 import mir.entity.*;
16
17 import mircoders.entity.*;
18 import mircoders.storage.*;
19
20
21
22 public class ProducerTopics extends ProducerList {
23
24   public String where;
25   String              currentMediaId;
26   EntityList          upMediaEntityList;
27   EntityList          imageEntityList;
28   EntityList          currentMediaList;
29   Entity              mediaType;
30   EntityMedia         uploadedMedia;
31   Class               mediaHandlerClass=null;
32   MirMedia            mediaHandler=null;
33   String              mediaHandlerName=null;
34   Database            mediaStorage=null;
35   String              tinyIcon;
36   String              iconAlt;
37
38   public void setAdditional(String key, TemplateModel value) {
39     additional.put(key,value);
40   }
41
42   public void handle(PrintWriter htmlout, EntityUsers user, boolean force, boolean sync, String id)
43     throws StorageObjectException, ModuleException {
44     where=id;
45     handle(htmlout,user,force,sync);
46   }
47
48   public void handle(PrintWriter htmlout, EntityUsers user, boolean force, boolean sync)
49     throws StorageObjectException, ModuleException {
50
51     orderBy="date desc, webdb_create desc";
52     listTemplate = MirConfig.getProp("Producer.TopicList.Template");
53
54     EntityList topicsEntityList;
55     if(where==null){
56       topicsEntityList = topicsModule.getByWhereClause("","title", -1);
57     } else {
58       topicsEntityList = topicsModule.getByWhereClause(where,"title", -1);
59     }
60     SimpleList topicsList = HTMLTemplateProcessor.makeSimpleList(topicsEntityList);
61
62     for(int i=0; i < topicsEntityList.size(); i++){
63
64       EntityTopics currentTopic = (EntityTopics)topicsEntityList.elementAt(i);
65
66       try {
67       EntityList contentEntityList = DatabaseContentToTopics.getInstance().getContent(currentTopic);
68       String whereClauseSpecial=null;
69
70       if (contentEntityList!=null || force==true) {
71         if (contentEntityList!=null){
72           boolean first=true;
73           whereClause="is_published='1' AND to_article_type >= 1 AND to_article_type <=2 AND id IN (";
74           whereClauseSpecial="is_published='1' AND to_article_type=3 AND id IN (";
75           for(int j=0; j < contentEntityList.size(); j++){
76             if(first==false) {
77               whereClause += ",";
78               whereClauseSpecial += ",";
79             }
80             EntityContent currentContent = (EntityContent)contentEntityList.elementAt(j);
81             whereClause += currentContent.getId();
82             whereClauseSpecial += currentContent.getId();
83
84             setAdditional("topic",HTMLTemplateProcessor.makeSimpleHash(currentTopic));
85
86             first = false;
87           }
88           whereClause += ")";
89           whereClauseSpecial += ")";
90         }
91
92         if(contentEntityList==null && force==true){
93           //hihi, das ist eigentlich boese
94           whereClause="is_published='1' AND to_article_type>=1 AND id IN (0)";
95         }
96
97         fileDesc = currentTopic.getValue("filename");
98
99         // get the startarticle
100         EntityList entityList = contentModule.getContent(whereClauseSpecial,"date desc, webdb_create desc",0,1);
101         String currentMediaId = null;
102         SimpleHash imageHash = new SimpleHash();
103         EntityContent currentContent;
104         if(entityList != null && entityList.size()==1){
105           currentContent = (EntityContent)entityList.elementAt(0);
106           try {
107               SimpleHash specialHash = HTMLTemplateProcessor.makeSimpleHash(currentContent);
108
109               currentMediaList = DatabaseContentToMedia.getInstance().getUploadedMedia(currentContent);
110               if (currentMediaList!=null && currentMediaList.getCount()>=1) {
111                 SimpleList mediaListAudio = new SimpleList();
112                 SimpleList mediaListImages = new SimpleList();
113                 SimpleList mediaListVideo = new SimpleList();
114                 SimpleList mediaListOther = new SimpleList();
115                 for (int n=0; n < currentMediaList.size();n++) {
116                   upMedia = currentMediaList.elementAt(n);
117                   upMediaSimpleHash = HTMLTemplateProcessor.makeSimpleHash(upMedia);
118                   mediaType = ((EntityMedia)upMedia).getMediaType();
119                   //must be a non-existant to_media_type entry..
120                   if (mediaType != null) {
121                     mediaHandlerName = mediaType.getValue("classname");
122                     mediaStorageName = mediaType.getValue("tablename");
123                     mediaStorageClass = Class.forName("mircoders.storage.Database"+mediaStorageName);
124                     mediaHandlerClass = Class.forName("mir.media.MediaHandler"+mediaHandlerName);
125                     mediaHandler = (MirMedia)mediaHandlerClass.newInstance();
126                     Method m = mediaStorageClass.getMethod("getInstance", null);
127                     mediaStorage = (Database)m.invoke(null, null);
128                     //we most likely need further info
129                     upMedia = mediaStorage.selectById(upMedia.getId());
130                     upMediaSimpleHash.put("url", mediaHandler.getListView(upMedia, mediaType));
131                     if (upMedia.getValue("is_published").equals("1")) {
132                       if (mediaHandler.isImage()) {
133                         mediaListImages.add(upMediaSimpleHash);
134                       } else if (mediaHandler.isAudio()) {
135                         mediaListAudio.add(upMediaSimpleHash);
136                       } else if (mediaHandler.isVideo()) {
137                         mediaListVideo.add(upMediaSimpleHash);
138                       } else {
139                         mediaListOther.add(upMediaSimpleHash);
140                       }
141                     } //end if is_published
142                   } //end if media_type != null
143                 } //end for
144                 specialHash.put("to_media_audio", mediaListAudio);
145                 specialHash.put("to_media_images", mediaListImages);
146                 specialHash.put("to_media_video", mediaListVideo);
147                 specialHash.put("to_media_other", mediaListOther);
148               } //end if currentMediaList != null
149
150               setAdditional("special",specialHash);
151           } catch (Exception e) {
152             theLog.printError("ProducerTopics: problem with start special media: "+currentContent.getId()+" "+e.toString()+" <font color=\"red\">skipping</font>");
153             logHTML(htmlout,"ProducerTopics: problem with start special media: "+currentContent.getId()+" "+e.toString());
154           }
155         }
156
157         //set the list of topics
158         setAdditional("topicslist",topicsList);
159
160         handleIt(htmlout,user,force);
161       }
162       } catch (Exception e) {
163         logHTML(htmlout,"ProducerTopics: problem with topic id: "
164         +currentTopic.getId()+ "<font color=\"red\">skipping</font>");
165       }
166     }
167   }
168
169   public static void main(String argv[]){
170     try {
171       new ProducerOpenPosting().handle(new PrintWriter(System.out), null,false, false);
172     } catch(Exception e) {
173       System.err.println(e.toString());
174     }
175   }
176 }