X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Fstorage%2FDatabaseContentToMedia.java;h=7b5305c0991542740c48dcfaf1b10ba0250f8952;hb=f5ddd64c4b6a071d8f0bd2f08e95dbf98c7713fb;hp=e154fcb6705a04313837d02752254c5770bca146;hpb=c785369f4ca9b7a6b295464041c14206c6db84bf;p=mir.git diff --git a/source/mircoders/storage/DatabaseContentToMedia.java b/source/mircoders/storage/DatabaseContentToMedia.java index e154fcb6..7b5305c0 100755 --- a/source/mircoders/storage/DatabaseContentToMedia.java +++ b/source/mircoders/storage/DatabaseContentToMedia.java @@ -1,3 +1,34 @@ +/* + * Copyright (C) 2001, 2002 The Mir-coders group + * + * This file is part of Mir. + * + * Mir is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * Mir is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Mir; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * In addition, as a special exception, The Mir-coders gives permission to link + * the code of this program with the com.oreilly.servlet library, any library + * licensed under the Apache Software License, The Sun (tm) Java Advanced + * Imaging library (JAI), The Sun JIMI library (or with modified versions of + * the above that use the same license as the above), and distribute linked + * combinations including the two. You must obey the GNU General Public + * License in all respects for all of the code used other than the above + * mentioned libraries. If you modify this file, you may extend this exception + * to your version of the file, but you are not obligated to do so. If you do + * not wish to do so, delete this exception statement from your version. + */ + package mircoders.storage; import java.lang.*; @@ -23,7 +54,10 @@ public class DatabaseContentToMedia extends Database implements StorageObject{ private static DatabaseContentToMedia instance; - public static DatabaseContentToMedia getInstance() + // the following *has* to be sychronized cause this static method + // could get preemted and we could end up with 2 instances of DatabaseFoo. + // see the "Singletons with needles and thread" article at JavaWorld -mh + public synchronized static DatabaseContentToMedia getInstance() throws StorageObjectException { if (instance == null) { instance = new DatabaseContentToMedia(); @@ -38,10 +72,16 @@ public class DatabaseContentToMedia extends Database implements StorageObject{ super(); this.hasTimestamp = false; this.theTable="content_x_media"; + try { this.theEntityClass = Class.forName("mir.entity.GenericEntity"); } + catch (Exception e) { throw new StorageObjectException(e.toString()); } } - - public EntityList getMedia(EntityContent content) { + /** + * get all the media-files belonging to a content entity + * + */ + public EntityList getMedia(EntityContent content) + throws StorageObjectException { EntityList returnList=null; if (content != null) { // get all to_topic from media_x_topic @@ -50,16 +90,185 @@ public class DatabaseContentToMedia extends Database implements StorageObject{ String subselect = "id in (select media_id from " + theTable + " where content_id=" + id+")"; try { - returnList = DatabaseMedia.getInstance().selectByWhereClause(subselect,-1); + // media should stay in uploaded order. this is especially important + // for photo stories which require a specific chronologic order. + // this is why we have the the second parameter "id" + returnList = DatabaseMedia.getInstance().selectByWhereClause(subselect,"id",-1); } catch (Exception e) { theLog.printDebugInfo("-- get media failed " + e.toString()); + throw new StorageObjectException("-- get media failed " + e.toString()); + } + } + return returnList; + } + + public boolean hasMedia(EntityContent content) + throws StorageObjectException { + String wc = "content_id="+content.getId(); + if( content != null) { + try { + if(selectByWhereClause(wc,-1).size() == 0) + return false; + else + return true; + } catch (Exception e) { + theLog.printError("-- hasMedia failed " + e.toString()); + throw new StorageObjectException("-- hasMedia failed " + e.toString()); + } + } else { + theLog.printError("-- hasMedia failed: content is NULL"); + throw new StorageObjectException("-- hasMedia failed: content is NULL"); + } + } + + + + + /** + * get all the audio belonging to a content entity + * + */ + public EntityList getAudio(EntityContent content) + throws StorageObjectException { + EntityList returnList=null; + if (content != null) { + // get all to_topic from media_x_topic + String id = content.getId(); + //this is not supported by mysql + String subselect = "id in (select media_id from " + theTable + " where content_id=" + id+")"; + + try { + // media should stay in uploaded order. this is especially important + // for photo stories which require a specific chronologic order. + // this is why we have the the second parameter "id" + returnList = DatabaseAudio.getInstance().selectByWhereClause(subselect,"id",-1); + } catch (Exception e) { + theLog.printDebugInfo("-- get audio failed " + e.toString()); + throw new StorageObjectException("-- get audio failed " + e.toString()); + } + } + return returnList; + } + + /** + * get all the video belonging to a content entity + * + */ + public EntityList getVideo(EntityContent content) + throws StorageObjectException { + EntityList returnList=null; + if (content != null) { + // get all to_topic from media_x_topic + String id = content.getId(); + //this is not supported by mysql + String subselect = "id in (select media_id from " + theTable + " where content_id=" + id+")"; + + try { + // media should stay in uploaded order. this is especially important + // for photo stories which require a specific chronologic order. + // this is why we have the the second parameter "id" + returnList = DatabaseVideo.getInstance().selectByWhereClause(subselect,"id",-1); + } catch (Exception e) { + theLog.printDebugInfo("-- get video failed " + e.toString()); + throw new StorageObjectException("-- get video failed " + e.toString()); + } + } + return returnList; + } + + /** + * get all the images belonging to a content entity + * + */ + public EntityList getImages(EntityContent content) + throws StorageObjectException { + EntityList returnList=null; + if (content != null) { + // get all to_topic from media_x_topic + String id = content.getId(); + //this is not supported by mysql + String subselect = "id in (select media_id from " + theTable + " where content_id=" + id+")"; + + try { + // media should stay in uploaded order. this is especially important + // for photo stories which require a specific chronologic order. + // this is why we have the the second parameter "id" + returnList = DatabaseImages.getInstance().selectByWhereClause(subselect,"id",-1); + } catch (Exception e) { + theLog.printDebugInfo("-- get images failed " + e.toString()); + throw new StorageObjectException("-- get images failed " + e.toString()); } } return returnList; } - public void setMedia(String contentId, String[] mediaId) { + /** + * get all the uploaded/other Media belonging to a content entity + * + */ + public EntityList getOther(EntityContent content) + throws StorageObjectException + { + /** @todo this should only fetch published media / rk */ + + EntityList returnList=null; + if (content != null) { + // get all to_topic from media_x_topic + String id = content.getId(); + //this is not supported by mysql + String subselect = "id in (select media_id from " + theTable + + " where content_id=" + id+")"; + + try { + // media should stay in uploaded order. this is especially important + // for photo stories which require a specific chronologic order. + // this is why we have the the second parameter "id" + returnList = DatabaseOther.getInstance().selectByWhereClause(subselect, + "id"); + } catch (Exception e) { + e.printStackTrace(); + theLog.printDebugInfo("-- get Other failed " + e.toString()); + throw new StorageObjectException("-- get Other failed " + + e.toString()); + } + } + return returnList; + } + + /** + * get all the uploaded/other Media belonging to a content entity + * + */ + public EntityList getUploadedMedia(EntityContent content) + throws StorageObjectException + { + /** @todo this should only fetch published media / rk */ + + EntityList returnList=null; + if (content != null) { + // get all to_topic from media_x_topic + String id = content.getId(); + //this is not supported by mysql + String subselect = "id in (select media_id from " + theTable + + " where content_id=" + id+")"; + + try { + returnList = DatabaseUploadedMedia.getInstance().selectByWhereClause(subselect, + "id"); + } catch (Exception e) { + e.printStackTrace(); + theLog.printDebugInfo("-- get uploadedMedia failed " + e.toString()); + throw new StorageObjectException("-- get uploadedMedia failed " + + e.toString()); + } + } + return returnList; + } + + + public void setMedia(String contentId, String[] mediaId) + throws StorageObjectException { if (contentId == null){ return; } @@ -68,7 +277,7 @@ public class DatabaseContentToMedia extends Database implements StorageObject{ } //first delete all row with content_id=contentId String sql = "delete from "+ theTable +" where content_id=" + contentId; - + Connection con=null;Statement stmt=null; try { con = getPooledCon(); @@ -77,10 +286,11 @@ public class DatabaseContentToMedia extends Database implements StorageObject{ ResultSet rs = executeSql(stmt,sql); } catch (Exception e) { theLog.printDebugInfo("-- set media failed -- delete"); + throw new StorageObjectException("-- set media failed -- delete"+e.toString()); } finally { freeConnection(con,stmt); } - + //now insert //first delete all row with content_id=contentId for (int i=0;i