Mir goes GPL
[mir.git] / source / mircoders / producer / ProducerImages.java
index 526ae37..9c360c1 100755 (executable)
@@ -1,3 +1,34 @@
+/*
+ * 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.
+ */
+
 package mircoders.producer;
 
 import java.io.*;
@@ -6,104 +37,19 @@ import java.util.*;
 
 import freemarker.template.*;
 
-import webdb.misc.*;
-import webdb.storage.*;
-import webdb.module.*;
-import webdb.entity.*;
-
+import mir.misc.*;
+import mir.storage.*;
 import mir.module.*;
 import mir.entity.*;
-import mir.storage.*;
-
-
-
-public class ProducerImages extends Producer {
-
-       public static void main(String argv[]){
-               try {
-                       new ProducerContent().handle(new PrintWriter(System.out), null, false,false);
-               } catch(Exception e) { System.err.println(e.toString()); }
-       }
-
-       public void handle(PrintWriter htmlout, EntityUsers user, boolean force, boolean sync)
-               throws StorageObjectException, ModuleException {
-               handle(htmlout,user,force,sync,null);
-       }
-
-       public void handle(PrintWriter htmlout, EntityUsers user, boolean force, boolean sync, String id)
-               throws StorageObjectException, ModuleException
-       {
-               long                sessionConnectTime = 0;
-               long                startTime = (new java.util.Date()).getTime();
-               String              whereClause;
-               String              iconFilename;
-               String              imageFilename;
-               String              productionPath;
-               EntityImage         currentImage;
-               EntityList          batchEntityList;
-
-    int contentBatchsize = Integer.parseInt(Configuration.getProperty("Producer.Content.Batchsize"));
-    String imageHost = Configuration.getProperty("Producer.Image.Host");
-         String imagePath = Configuration.getProperty("Producer.Image.Path");
-         String iconPath = Configuration.getProperty("Producer.Image.IconPath");
-
-               // get batch of non-produced images, that are to be published
-               whereClause="is_published='1'";
-               if (id!= null)
-                       whereClause += " and id="+id;
-               if (force==false) whereClause += " and icon_is_produced='0'";
-
-               batchEntityList = imageModule.getByWhereClause(whereClause, null, 0, contentBatchsize);
-               theLog.printDebugInfo("whereclause: " + whereClause);
-
-
-               while (batchEntityList != null) {
-                       for(int i=0;i<batchEntityList.size();i++) {
-                               theLog.printDebugInfo("trying image: " + i);
-                               currentImage = (EntityImage)batchEntityList.elementAt(i);
-
-                               // make filenames
-                               String date = currentImage.getValue("date");
-
-                               iconFilename = producerDocRoot + iconPath + StringUtil.webdbDate2path(date) +
-                                       currentImage.getId() + (( currentImage.getValue("to_img_type").equals("0") ) ? ".jpg":".gif");
-
-                               imageFilename = currentImage.getId() + (( currentImage.getValue("to_img_type").equals("0") ) ? ".jpg":".gif");
-                               productionPath = imagePath + "/" + imageFilename ;
-
-                               currentImage.setValueForProperty("icon_path",iconFilename);
-                               //currentImage.setValueForProperty("publish_path","imc/germany/" + imageFilename);
-        currentImage.setValueForProperty("publish_path",imageFilename);
-                               currentImage.setValueForProperty("publish_server", imageHost);
-
-                               if (currentImage.getValue("icon_data")!= null && currentImage.getValue("image_data")!= null) {
-                                       // make icon
-                                       boolean iconProduced = produceFile(iconFilename, currentImage.getIcon(), htmlout, true);
-                                       logHTML(htmlout,"icon : " + iconFilename + (( iconProduced==true )? " succeded":" <font color=\"Red\" failed!</font>"));
-                                       // make image
-                                       boolean imageProduced = produceFile(productionPath, currentImage.getImage(), htmlout, false);
-                                       logHTML(htmlout,"image: " + productionPath + ((imageProduced==true)?" succeded":" <font color=\"Red\" failed!</font>"));
 
-                                       // update image-data
-                                       if (iconProduced && imageProduced) {
-                                               currentImage.setValueForProperty("icon_is_produced", "1");
-                                               currentImage.update();
-                                       }
+import mircoders.entity.*;
+import mircoders.storage.*;
 
-                               }
-                       }
 
-                       // if next batch get it...
-                       if (batchEntityList.hasNextBatch()){
-                               batchEntityList = imageModule.getByWhereClause(whereClause, null, batchEntityList.getNextBatch(),contentBatchsize);
-                       } else {
-                               batchEntityList=null;
-                       }
-               }
-               // Finish
-               sessionConnectTime = new java.util.Date().getTime() - startTime;
-               logHTML(htmlout, "Producer.Images finished: " + sessionConnectTime + " ms.");
+public class ProducerImages extends ProducerMedia {
 
-       }
+  protected Database getStorage() throws StorageObjectException {
+    return DatabaseImages.getInstance();
+  }
 
-}
\ No newline at end of file
+}