Initial revision
[mir.git] / source / mircoders / producer / ProducerImages.java
diff --git a/source/mircoders/producer/ProducerImages.java b/source/mircoders/producer/ProducerImages.java
new file mode 100755 (executable)
index 0000000..526ae37
--- /dev/null
@@ -0,0 +1,109 @@
+package mircoders.producer;
+
+import java.io.*;
+import java.lang.*;
+import java.util.*;
+
+import freemarker.template.*;
+
+import webdb.misc.*;
+import webdb.storage.*;
+import webdb.module.*;
+import webdb.entity.*;
+
+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();
+                                       }
+
+                               }
+                       }
+
+                       // 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.");
+
+       }
+
+}
\ No newline at end of file