X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Fentity%2FEntityUploadedMedia.java;h=578ad4b6c4b097407dabec88310750cc284705cf;hb=d74a52d5f65389e5cf89d3fcf14d07afbb78a9f9;hp=7a1ee12f88f9d88bd63ddf7c5116066a5e3d7457;hpb=d6931e16f79f3a98c735e6d49ac689d0d49f9477;p=mir.git diff --git a/source/mircoders/entity/EntityUploadedMedia.java b/source/mircoders/entity/EntityUploadedMedia.java index 7a1ee12f..578ad4b6 100755 --- a/source/mircoders/entity/EntityUploadedMedia.java +++ b/source/mircoders/entity/EntityUploadedMedia.java @@ -1,136 +1,99 @@ +/* + * 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 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.entity; -import java.lang.*; -import java.io.*; -import java.util.*; -import java.sql.*; +import java.sql.SQLException; +import java.util.Map; -import freemarker.template.*; +import mir.entity.AbstractEntity; +import mir.entity.Entity; +import mir.log.LoggerWrapper; +import mir.storage.DatabaseFailure; +import mircoders.storage.DatabaseUploadedMedia; -import mir.entity.*; -import mir.misc.*; -import mir.storage.*; -import mir.media.*; - -import mircoders.storage.*; /** - * Diese Klasse enthält die Daten eines MetaObjekts * - * @author RK - * @version 29.6.1999 + * @author mh, mir-coders group + * @version $Id: EntityUploadedMedia.java,v 1.26.2.13 2005/10/30 00:46:58 zapata Exp $ */ - -public class EntityUploadedMedia extends Entity -{ - - - public EntityUploadedMedia(){ - super(); - } - - public EntityUploadedMedia(StorageObject theStorage) - { - this(); - setStorage(theStorage); - } - - public void setValues(HashMap theStringValues) - { - if (theStringValues != null) { - if (!theStringValues.containsKey("is_published")) - theStringValues.put("is_published","0"); - } - super.setValues(theStringValues); - } - - - /** - * fetches the MediaType entry assiciated w/ this media - * - * @return mir.entity.Entity - */ - public Entity getMediaType() throws StorageObjectException { - Entity ent = null; - try { - ent = DatabaseUploadedMedia.getInstance().getMediaType(this); - } catch (StorageObjectException e) { - throwStorageObjectException(e, "get MediaType failed -- "); - } - return ent; - } - - public String getValue(String key) - { - String returnValue=null; - - if (key!=null) { - if (key.equals("big_icon")) - returnValue=getBigIcon(); - else if (key.equals("descr")) - returnValue=getDescr(); - else - returnValue=super.getValue(key); - } - return returnValue; - } - - public TemplateModel get(java.lang.String key) throws TemplateModelException - { - if (key.equals("url")) - return getUrl(); - - return new SimpleScalar(getValue(key)); - } - - // @todo all these methods should be merged into 1 - // and the MediaHandler should be cached somehow. - private String getBigIcon() - { - MirMedia mediaHandler=null; - Entity mediaType=null; +public class EntityUploadedMedia extends AbstractEntity { + public void update() throws DatabaseFailure { + super.update(); try { - mediaType = getMediaType(); - mediaHandler = MediaHelper.getHandler( mediaType ); - return mediaHandler.getBigIcon(); - } catch (Exception ex) { - theLog.printWarning("-- getBigIcon: could not fetch data " - + this.getClass().toString()+" "+ ex.toString()); + database.executeUpdate( + "update content " + + "set is_produced='0' " + + "from content_x_media cxm " + + "where" + + " cxm.content_id=content.id and cxm.media_id=" + getId() + ); + + database.executeUpdate( + "update content " + + "set is_produced='0' " + + "from comment_x_media cxm, comment c "+ + "where " + + " cxm.comment_id = c.id and " + + " c.to_media=content.id and " + + " cxm.media_id=" + getId() + ); + } + catch (SQLException e) { + throw new DatabaseFailure(e); } - return null; } - private SimpleList getUrl() - { - MirMedia mediaHandler=null; - Entity mediaType=null; - - try { - mediaType = getMediaType(); - mediaHandler = MediaHelper.getHandler( mediaType ); - return mediaHandler.getURL(this, mediaType); - } catch (Exception ex) { - theLog.printWarning("-- getUrl: could not fetch data " - + this.getClass().toString()+" "+ ex.toString()); + public void setFieldValues(Map theStringValues) { + if (theStringValues != null) { + if (!theStringValues.containsKey("is_published")) + theStringValues.put("is_published", "0"); } - return null; + super.setFieldValues(theStringValues); } - private String getDescr() - { - MirMedia mediaHandler=null; - Entity mediaType=null; + /** + * fetches the MediaType entry assiciated w/ this media + * + * @return mir.entity.Entity + */ + public Entity getMediaType() throws DatabaseFailure { + Entity ent = null; try { - mediaType = getMediaType(); - mediaHandler = MediaHelper.getHandler( mediaType ); - return mediaHandler.getDescr(); - } catch (Exception ex) { - theLog.printWarning("-- getDescr: could not fetch data " - + this.getClass().toString()+" "+ ex.toString()); + ent = DatabaseUploadedMedia.getInstance().getMediaType(this); + } + catch (DatabaseFailure e) { + throw new DatabaseFailure(e); } - return null; + return ent; } - }