--- /dev/null
+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