1.1 restoration
[mir.git] / source / mircoders / entity / EntityUploadedMedia.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 package mircoders.entity;
31
32 import java.sql.SQLException;
33 import java.util.Map;
34
35 import mir.entity.AbstractEntity;
36 import mir.entity.Entity;
37 import mir.log.LoggerWrapper;
38 import mir.storage.StorageObject;
39 import mir.storage.StorageObjectFailure;
40 import mircoders.storage.DatabaseUploadedMedia;
41
42 /**
43  *
44  * @author mh, mir-coders group
45  * @version $Id: EntityUploadedMedia.java,v 1.26.2.8 2004/11/21 22:07:13 zapata Exp $
46  */
47
48 public class EntityUploadedMedia extends AbstractEntity {
49   public EntityUploadedMedia() {
50     super();
51
52     logger = new LoggerWrapper("Entity.UploadedMedia");
53   }
54
55   public EntityUploadedMedia(StorageObject theStorage) {
56     this();
57
58     setStorage(theStorage);
59   }
60
61   public void update() throws StorageObjectFailure {
62     super.update();
63
64     try {
65       storageObject.executeUpdate(
66           "update content " +
67           "set is_produced='0' " +
68           "from content_x_media cxm " +
69           "where" +
70           "   cxm.content_id=content.id and cxm.media_id=" + getId()
71       );
72
73       storageObject.executeUpdate(
74           "update content " +
75           "set is_produced='0' " +
76           "from comment_x_media cxm, comment c "+
77           "where " +
78           "   cxm.comment_id = c.id and " +
79           "   c.to_media=content.id and " +
80           "   cxm.media_id=" + getId()
81       );
82     }
83     catch (SQLException e) {
84       throw new StorageObjectFailure(e);
85     }
86   }
87
88   public void setFieldValues(Map theStringValues) {
89     if (theStringValues != null) {
90       if (!theStringValues.containsKey("is_published"))
91         theStringValues.put("is_published", "0");
92     }
93     super.setFieldValues(theStringValues);
94   }
95
96
97   /**
98    * fetches the MediaType entry assiciated w/ this media
99    *
100    * @return mir.entity.Entity
101    */
102   public Entity getMediaType() throws StorageObjectFailure {
103     Entity ent = null;
104     try {
105       ent = DatabaseUploadedMedia.getInstance().getMediaType(this);
106     }
107     catch (StorageObjectFailure e) {
108       throw new StorageObjectFailure(e);
109     }
110     return ent;
111   }
112 }