Mir goes GPL
[mir.git] / source / mircoders / entity / EntityVideo.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 the com.oreilly.servlet library, any library
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of
24  * the above that use the same license as the above), and distribute linked
25  * combinations including the two.  You must obey the GNU General Public
26  * License in all respects for all of the code used other than the above
27  * mentioned libraries.  If you modify this file, you may extend this exception
28  * to your version of the file, but you are not obligated to do so.  If you do
29  * not wish to do so, delete this exception statement from your version.
30  */
31
32 package mircoders.entity;
33
34 import java.lang.*;
35 import java.io.*;
36 import java.util.*;
37 import java.sql.*;
38
39 import mir.entity.*;
40 import mir.misc.*;
41 import mir.storage.*;
42
43 /**
44  * Diese Klasse enthält die Daten eines MetaObjekts
45  *
46  * @author RK
47  * @version 11.11.2000
48  */
49
50
51 public class EntityVideo extends EntityUploadedMedia
52 {
53
54         public EntityVideo()
55         {
56                 super();
57         }
58
59         public EntityVideo(StorageObject theStorage) {
60                 this();
61                 setStorage(theStorage);
62         }
63
64         //
65         // methods
66
67         public byte[] getVideoData() throws StorageObjectException
68         {
69
70                 Connection con=null;Statement stmt=null;
71                 byte[] video_data=null;
72
73                 try {
74                         con = theStorageObject.getPooledCon();
75                         con.setAutoCommit(false);
76                         stmt = con.createStatement();
77                         ResultSet rs = theStorageObject.executeSql(stmt,"select video_data from video where id="+getId());
78                         if(rs!=null) {
79                                 if (rs.next()) {
80                                          video_data = rs.getBytes(1);
81                                 }
82                                 rs.close();
83                         }
84                 }
85                 catch (Exception e) {theLog.printDebugInfo("-- getImage gescheitert: "+e.toString());}
86                 finally {
87                         try {con.setAutoCommit(true); } catch (Exception e) {;}
88                         theStorageObject.freeConnection(con,stmt); }
89
90                 return video_data;
91         }
92
93         public void setVideoData(byte[] uploadData) throws StorageObjectException
94         {
95                 if (uploadData!=null) {
96                         Connection con=null;PreparedStatement pstmt=null;
97                         try {
98
99                                 con = theStorageObject.getPooledCon();
100                                 con.setAutoCommit(false);
101                                 theLog.printDebugInfo("setvideo :: trying to insert video");
102
103                                 // setting values
104                                 String sql = "update videos set image_data=? where id="+getId();
105                                 theLog.printDebugInfo("setvideo: "+ sql);
106                                 pstmt = con.prepareStatement(sql);
107                                 pstmt.setBytes(1, uploadData);
108                                 pstmt.executeUpdate();
109                                 sql="update content set is_produced='0' where to_media="+getId();
110                                 pstmt = con.prepareStatement(sql);
111                                 pstmt.executeUpdate();
112                         }
113                         catch (Exception e) {theLog.printDebugInfo("setvideo :: setvideo gescheitert: "+e.toString());}
114                         finally {
115                                 try {con.setAutoCommit(true); } catch (Exception e) {;}
116                                 theStorageObject.freeConnection(con,pstmt); }
117                 }
118         }
119
120         public void update() throws StorageObjectException {
121                 super.update();
122                 try {
123                         theStorageObject.executeUpdate("update content set is_produced='0' where to_media="+getId());
124                 } catch (SQLException e) {
125                         theLog.printError("video :: update :: failed!! "+ e.toString());
126                 }
127         }
128
129         public void setValues(HashMap theStringValues)
130         {
131                 if (theStringValues != null) {
132                         if (!theStringValues.containsKey("is_published"))
133                          theStringValues.put("is_published","0");
134                 }
135                 super.setValues(theStringValues);
136         }
137
138 }