1.1 restoration
[mir.git] / source / mircoders / search / ImagesSearchTerm.java
index b1fa9ae..275cb44 100755 (executable)
 package mircoders.search;
 
 import java.util.ArrayList;
+import java.util.Iterator;
 import java.util.List;
 import java.util.Map;
 import java.util.StringTokenizer;
+import java.util.Vector;
 import javax.servlet.http.HttpServletRequest;
 
 import mir.entity.Entity;
-import mir.entity.EntityList;
+import mir.entity.EntityBrowser;
 import mir.storage.StorageObjectFailure;
 import mircoders.entity.EntityContent;
-import mircoders.storage.DatabaseContentToMedia;
+import mircoders.entity.EntityImages;
+import mircoders.storage.DatabaseImages;
+
 import org.apache.lucene.document.Document;
 import org.apache.lucene.document.Field;
 
@@ -51,15 +55,25 @@ public class ImagesSearchTerm extends SearchTerm{
   }
 
   public void index(Document doc, Entity entity) throws StorageObjectFailure{
-    EntityList images = DatabaseContentToMedia.getInstance().getImages((EntityContent) entity);
-    if (images != null && images.size()>0){
+    Vector extraTables = new Vector();
+    extraTables.add("content_x_media cxm");
+
+    Iterator images = new EntityBrowser(
+                                       DatabaseImages.getInstance(), "i", extraTables,
+                                       "cxm.content_id="+entity.getId()+"and cxm.media_id=i.id",
+                                       "i.id desc", 30, -1, 0);
+
+
+    if (images != null && images.hasNext()){
       doc.add(Field.Keyword(matchField,"y"));
       String imageURLString = "";
-      for(int k=0;k<images.size();k++){
+      int k=0;
+      while(images.hasNext()){
         if (k != 0){
           imageURLString = imageURLString + ":";
         }
-        imageURLString = imageURLString + (images.elementAt(k)).getFieldValue("icon_path");
+             k++;
+        imageURLString = imageURLString + ((EntityImages) images.next()).getFieldValue("icon_path");
       }
       doc.add(Field.UnIndexed("images",imageURLString));
     }