scripts/mir-setup/README: update with link to new doc on wiki
[mir.git] / source / mircoders / search / AudioSearchTerm.java
1 /*
2  * Copyright (C) 2001, 2002 The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with  any library licensed under the Apache Software License,
22  * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library
23  * (or with modified versions of the above that use the same license as the above),
24  * and distribute linked combinations including the two.  You must obey the
25  * GNU General Public License in all respects for all of the code used other than
26  * the above mentioned libraries.  If you modify this file, you may extend this
27  * exception to your version of the file, but you are not obligated to do so.
28  * If you do not wish to do so, delete this exception statement from your version.
29  */
30
31 package mircoders.search;
32
33 import java.util.ArrayList;
34 import java.util.Iterator;
35 import java.util.List;
36 import java.util.Map;
37
38 import javax.servlet.http.HttpServletRequest;
39
40 import mir.entity.Entity;
41 import mir.entity.EntityBrowser;
42 import mir.storage.DatabaseFailure;
43 import mircoders.storage.DatabaseAudio;
44
45 import org.apache.lucene.document.Document;
46 import org.apache.lucene.document.Field;
47
48 /**
49  * indexes whether an Enity has audio 
50  */
51 public class AudioSearchTerm extends SearchTerm{
52   public AudioSearchTerm() {
53     super(null, "search_hasAudio", "hasAudio", null, "hasAudio");
54   }
55
56   public void index(Document doc, Entity entity) throws DatabaseFailure{
57       //    EntityList audio = DatabaseContentToMedia.getInstance().getAudio((EntityContent) entity);
58     List extraTables = new ArrayList();
59     extraTables.add("content_x_media cxm");
60     Iterator audios = new EntityBrowser(
61                                         DatabaseAudio.getInstance(), "i", extraTables,
62                                         "cxm.content_id="+entity.getId()+"and cxm.media_id=i.id",
63                                         "i.id desc", 30, -1, 0);
64
65
66     if (audios != null && audios.hasNext()){
67       doc.add(Field.Keyword(matchField,"y"));
68     }
69   }
70
71   public String makeTerm(HttpServletRequest req){
72     String wanted = req.getParameter(paramName);
73     if (wanted != null && wanted.equals("y")){
74       return matchField + ":" + "\"" + wanted + "\"";
75     }
76                 return null;
77   }
78
79   public void returnMeta(Map result,Document doc){
80     result.put(templateVariable,doc.get(matchField));
81   }
82 }
83
84