log4j implemented for the producer subsystem
[mir.git] / source / mircoders / localizer / basic / MirBasicDataModelLocalizer.java
1 /*\r
2  * Copyright (C) 2001, 2002  The Mir-coders group\r
3  *\r
4  * This file is part of Mir.\r
5  *\r
6  * Mir is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 2 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Mir is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with Mir; if not, write to the Free Software\r
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
19  *\r
20  * In addition, as a special exception, The Mir-coders gives permission to link\r
21  * the code of this program with the com.oreilly.servlet library, any library\r
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced\r
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of\r
24  * the above that use the same license as the above), and distribute linked\r
25  * combinations including the two.  You must obey the GNU General Public\r
26  * License in all respects for all of the code used other than the above\r
27  * mentioned libraries.  If you modify this file, you may extend this exception\r
28  * to your version of the file, but you are not obligated to do so.  If you do\r
29  * not wish to do so, delete this exception statement from your version.\r
30  */\r
31 \r
32 package mircoders.localizer.basic;\r
33 \r
34 import java.util.*;\r
35 import mir.entity.*;\r
36 import mir.entity.adapter.*;\r
37 import mir.media.*;\r
38 import mir.misc.*;\r
39 import mir.util.*;\r
40 import mircoders.storage.*;\r
41 import mircoders.global.*;\r
42 import mircoders.entity.*;\r
43 import mircoders.localizer.*;\r
44 \r
45 public class MirBasicDataModelLocalizer implements MirDataModelLocalizer {\r
46   private EntityAdapterModel model;\r
47 \r
48   public MirBasicDataModelLocalizer() {\r
49   }\r
50 \r
51   public EntityAdapterModel adapterModel() throws MirLocalizerFailure {\r
52     if (model==null)\r
53       model = buildModel();\r
54 \r
55     return model;\r
56   };\r
57 \r
58   protected void constructContentAdapterDefinition(EntityAdapterDefinition anEntityAdapterDefinition) throws MirLocalizerFailure {\r
59     try {\r
60       anEntityAdapterDefinition.addDBDateField("creationdate", "webdb_create");\r
61       anEntityAdapterDefinition.addDBDateField("changedate", "webdb_lastchange");\r
62       anEntityAdapterDefinition.addMirDateField("date", "date");\r
63       anEntityAdapterDefinition.addCalculatedField("to_topics", new ContentToTopicsField());\r
64       anEntityAdapterDefinition.addCalculatedField("to_comments", new ContentToCommentsField());\r
65       anEntityAdapterDefinition.addCalculatedField("language", new ContentToLanguageField());\r
66 \r
67       anEntityAdapterDefinition.addCalculatedField("commentcount", new ContentCommentCountField(" and is_published='1'"));\r
68 \r
69       anEntityAdapterDefinition.addCalculatedField("to_media_images",  new ContentToMediaField( "image" ));\r
70       anEntityAdapterDefinition.addCalculatedField("to_uploaded_media", new ContentToMediaField( "uploadedMedia" ));\r
71       anEntityAdapterDefinition.addCalculatedField("to_media_audio", new ContentToMediaField( "audio" ));\r
72       anEntityAdapterDefinition.addCalculatedField("to_media_video", new ContentToMediaField( "video" ));\r
73       anEntityAdapterDefinition.addCalculatedField("to_media_other", new ContentToMediaField( "otherMedia" ));\r
74       anEntityAdapterDefinition.addCalculatedField("to_media_icon", new ContentToIconField());\r
75 \r
76       anEntityAdapterDefinition.addCalculatedField("description_parsed", new FilteredField("description"));\r
77       anEntityAdapterDefinition.addCalculatedField("content_data_parsed", new FilteredField("content_data"));\r
78     }\r
79     catch (Throwable t) {\r
80       throw new MirLocalizerFailure(t.getMessage(), t);\r
81     }\r
82   }\r
83 \r
84   protected void constructCommentAdapterDefinition(EntityAdapterDefinition anEntityAdapterDefinition) throws MirLocalizerFailure {\r
85     try {\r
86       anEntityAdapterDefinition.addDBDateField("creationdate", "webdb_create");\r
87       anEntityAdapterDefinition.addCalculatedField("to_content", new CommentToContentField());\r
88 \r
89       anEntityAdapterDefinition.addCalculatedField("description_parsed", new FilteredField("description"));\r
90       anEntityAdapterDefinition.addCalculatedField("operations", new CommentToOperationsField());\r
91     }\r
92     catch (Throwable t) {\r
93       throw new MirLocalizerFailure(t.getMessage(), t);\r
94     }\r
95   }\r
96 \r
97   protected EntityAdapterModel buildModel() throws MirLocalizerFailure {\r
98     EntityAdapterModel result = new EntityAdapterModel();\r
99 \r
100     try {\r
101       EntityAdapterDefinition definition;\r
102 \r
103       definition = new EntityAdapterDefinition();\r
104       constructContentAdapterDefinition( definition );\r
105       result.addMapping( "content", DatabaseContent.getInstance(), definition);\r
106 \r
107       definition = new EntityAdapterDefinition();\r
108       constructCommentAdapterDefinition( definition );\r
109       result.addMapping( "comment", DatabaseComment.getInstance(), definition);\r
110 \r
111       result.addMapping( "articleType", DatabaseArticleType.getInstance(), new EntityAdapterDefinition());\r
112 \r
113       definition = new EntityAdapterDefinition();\r
114       definition.addDBDateField("creationdate", "webdb_create");\r
115       result.addMapping( "breakingNews", DatabaseBreaking.getInstance(), definition);\r
116 \r
117       result.addMapping( "feature", DatabaseFeature.getInstance(), new EntityAdapterDefinition());\r
118       result.addMapping( "imageType", DatabaseImageType.getInstance(), new EntityAdapterDefinition());\r
119       result.addMapping( "language", DatabaseLanguage.getInstance(), new EntityAdapterDefinition());\r
120       result.addMapping( "mediaFolder", DatabaseMediafolder.getInstance(), new EntityAdapterDefinition());\r
121       result.addMapping( "mediaType", DatabaseMediaType.getInstance(), new EntityAdapterDefinition());\r
122       result.addMapping( "internalMessage", DatabaseMessages.getInstance(), new EntityAdapterDefinition());\r
123       result.addMapping( "topic", DatabaseTopics.getInstance(), new EntityAdapterDefinition());\r
124       result.addMapping( "user", DatabaseUsers.getInstance(), new EntityAdapterDefinition());\r
125       result.addMapping( "media", DatabaseMedia.getInstance(), new EntityAdapterDefinition());\r
126       result.addMapping( "uploadedMedia", DatabaseUploadedMedia.getInstance(), new EntityAdapterDefinition());\r
127       result.addMapping( "image", DatabaseImages.getInstance(), new EntityAdapterDefinition());\r
128       result.addMapping( "audio", DatabaseAudio.getInstance(), new EntityAdapterDefinition());\r
129       result.addMapping( "video", DatabaseVideo.getInstance(), new EntityAdapterDefinition());\r
130       result.addMapping( "otherMedia", DatabaseOther.getInstance(), new EntityAdapterDefinition());\r
131     }\r
132     catch (Throwable t) {\r
133       throw new MirLocalizerFailure(t.getMessage(), t);\r
134     }\r
135 \r
136     return result;\r
137   }\r
138 \r
139   protected class CommentToContentField implements EntityAdapterDefinition.CalculatedField {\r
140     public Object getValue(EntityAdapter anEntityAdapter) {\r
141       try {\r
142         return anEntityAdapter.getToOneRelation(\r
143                     "id="+anEntityAdapter.get("to_media"),\r
144                     "id",\r
145                     "content" );\r
146       }\r
147       catch (Throwable t) {\r
148         throw new RuntimeException(t.getMessage());\r
149       }\r
150     }\r
151   }\r
152 \r
153   protected class CommentToOperationsField implements EntityAdapterDefinition.CalculatedField {\r
154     public Object getValue(EntityAdapter anEntityAdapter) {\r
155       try {\r
156         Map operations = MirGlobal.localizer().adminInterface().simpleCommentOperations();\r
157         Iterator i = operations.entrySet().iterator();\r
158         List availableOperations = new Vector();\r
159 \r
160         while (i.hasNext()) {\r
161           Map.Entry entry = (Map.Entry) i.next();\r
162 \r
163           MirAdminInterfaceLocalizer.MirSimpleEntityOperation operation =\r
164             (MirAdminInterfaceLocalizer.MirSimpleEntityOperation) entry.getValue();\r
165 \r
166           if (operation.isAvailable(anEntityAdapter)) {\r
167             availableOperations.add(entry.getKey());\r
168           }\r
169         };\r
170 \r
171         return availableOperations;\r
172       }\r
173       catch (Throwable t) {\r
174         throw new RuntimeException(t.getMessage());\r
175       }\r
176     }\r
177   }\r
178 \r
179   protected class FilteredField implements EntityAdapterDefinition.CalculatedField {\r
180     String fieldName;\r
181 \r
182     public FilteredField(String aFieldName) {\r
183       fieldName = aFieldName;\r
184     }\r
185 \r
186     public Object getValue(EntityAdapter anEntityAdapter) {\r
187       try {\r
188         if (anEntityAdapter.get("is_html")!=null && anEntityAdapter.get("is_html").equals("1")) {\r
189           return anEntityAdapter.get(fieldName);\r
190         }\r
191         else {\r
192           return MirGlobal.localizer().producerAssistant().filterText((String) anEntityAdapter.get(fieldName));\r
193         }\r
194       }\r
195       catch (Throwable t) {\r
196         throw new RuntimeException(t.getMessage());\r
197       }\r
198     }\r
199   }\r
200 \r
201   protected class ContentToLanguageField implements EntityAdapterDefinition.CalculatedField {\r
202     public Object getValue(EntityAdapter anEntityAdapter) {\r
203       try {\r
204         return anEntityAdapter.getToOneRelation(\r
205                     "id="+anEntityAdapter.get("to_language"),\r
206                     "id",\r
207                     "language" );\r
208       }\r
209       catch (Throwable t) {\r
210         throw new RuntimeException(t.getMessage());\r
211       }\r
212     }\r
213   }\r
214 \r
215   protected class ContentToCommentsField implements EntityAdapterDefinition.CalculatedField {\r
216     public Object getValue(EntityAdapter anEntityAdapter) {\r
217       try {\r
218         return anEntityAdapter.getRelation(\r
219                     "to_media="+anEntityAdapter.get("id")+" and is_published='1'",\r
220                     "webdb_create",\r
221                     "comment" );\r
222       }\r
223       catch (Throwable t) {\r
224         throw new RuntimeException(t.getMessage());\r
225       }\r
226     }\r
227   }\r
228 \r
229   protected class ContentToTopicsField implements EntityAdapterDefinition.CalculatedField {\r
230     public Object getValue(EntityAdapter anEntityAdapter) {\r
231       try {\r
232         return anEntityAdapter.getRelation(\r
233                     "exists (select * from content_x_topic where content_id="+anEntityAdapter.get("id")+" and topic_id=id)",\r
234                     "title",\r
235                     "topic" );\r
236       }\r
237       catch (Throwable t) {\r
238         throw new RuntimeException(t.getMessage());\r
239       }\r
240     }\r
241   }\r
242 \r
243   protected class ContentToMediaField implements EntityAdapterDefinition.CalculatedField {\r
244     String definition;\r
245 \r
246     public ContentToMediaField(String aDefinition) {\r
247       definition = aDefinition;\r
248     }\r
249 \r
250     public Object getValue(EntityAdapter anEntityAdapter) {\r
251       try {\r
252         return anEntityAdapter.getRelation(\r
253           "exists (select * from content_x_media where content_id="+anEntityAdapter.get("id")+" and media_id=id)",\r
254           "title",\r
255           definition);\r
256       }\r
257       catch (Throwable t) {\r
258         throw new RuntimeException(t.getMessage());\r
259       }\r
260     }\r
261   }\r
262 \r
263   protected class ContentToIconField implements EntityAdapterDefinition.CalculatedField {\r
264     public Object getValue(EntityAdapter anEntityAdapter) {\r
265       EntityAdapter media;\r
266       Entity mediaType;\r
267       RewindableIterator iterator;\r
268       Map result;\r
269       MirMedia mediaHandler;\r
270       String tinyIcon;\r
271       String iconAlt;\r
272 \r
273       try {\r
274         iterator = (RewindableIterator) (anEntityAdapter.get("to_uploaded_media"));\r
275         iterator.rewind();\r
276 \r
277         tinyIcon = MirGlobal.getConfigProperty("Producer.Icon.TinyText");\r
278         iconAlt = "Text";\r
279 \r
280         if (iterator.hasNext()) {\r
281           media = (EntityAdapter) iterator.next();\r
282 \r
283           mediaType = ((EntityUploadedMedia) (media.getEntity())).getMediaType();\r
284           mediaHandler = MediaHelper.getHandler( mediaType );\r
285 \r
286           if (mediaHandler.isVideo()) {\r
287             tinyIcon = MirGlobal.getConfigProperty("Producer.Icon.TinyVideo");\r
288             iconAlt = "Video";\r
289           }\r
290           else if (mediaHandler.isAudio()) {\r
291             tinyIcon = MirGlobal.getConfigProperty("Producer.Icon.TinyAudio");\r
292             iconAlt = "Audio";\r
293           }\r
294           else if (mediaHandler.isImage()) {\r
295             tinyIcon = MirGlobal.getConfigProperty("Producer.Icon.TinyImage");\r
296             iconAlt = "Image";\r
297           }\r
298           else {\r
299             tinyIcon = mediaHandler.getTinyIconName();\r
300             iconAlt = mediaHandler.getIconAltName();\r
301           }\r
302 \r
303         }\r
304       }\r
305       catch (Throwable t) {\r
306         System.out.println("ContentToIconField: exception: " +t.getMessage());\r
307         t.printStackTrace(System.out);\r
308         throw new RuntimeException(t.getMessage());\r
309       }\r
310 \r
311       result = new HashMap();\r
312       result.put("tiny_icon", MirGlobal.getConfigProperty("Producer.ImageRoot") + "/" + tinyIcon);\r
313       result.put("icon_alt", iconAlt);\r
314 \r
315       return result;\r
316     }\r
317   }\r
318 \r
319   protected class ContentCommentCountField implements EntityAdapterDefinition.CalculatedField {\r
320     private String extraCondition;\r
321 \r
322     public ContentCommentCountField(String anExtraCondition) {\r
323       super();\r
324 \r
325       extraCondition = anExtraCondition;\r
326     }\r
327 \r
328     public Object getValue(EntityAdapter anEntityAdapter) {\r
329       try {\r
330         return Integer.toString(\r
331             DatabaseComment.getInstance().getSize(\r
332                   "to_media="+anEntityAdapter.get("id")+" " + extraCondition));\r
333       }\r
334       catch (Throwable t) {\r
335         throw new RuntimeException(t.getMessage());\r
336       }\r
337     }\r
338   }\r
339 }\r