X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Fmodule%2FModuleTopics.java;h=901dde5bef03168d3dba4d95b890de4aaef1ba2f;hb=1ba06c565ec314b8e189a25e7aead8b3a4ce3ad5;hp=4a132e32d81a6d61c9c5b61af53231830d620b78;hpb=baf56cc3d324ffa8715509e559bbe049739f32f3;p=mir.git diff --git a/source/mircoders/module/ModuleTopics.java b/source/mircoders/module/ModuleTopics.java index 4a132e32..901dde5b 100755 --- a/source/mircoders/module/ModuleTopics.java +++ b/source/mircoders/module/ModuleTopics.java @@ -1,21 +1,48 @@ -package mircoders.module; - -import java.io.*; -import java.lang.*; -import java.util.*; -import java.sql.*; -import javax.servlet.*; -import javax.servlet.http.*; +/* + * 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. + */ -import freemarker.template.*; +package mircoders.module; -import mir.servlet.*; -import mir.module.*; -import mir.entity.*; -import mir.misc.*; -import mir.storage.*; +import java.util.Map; -import mircoders.storage.*; +import mir.entity.Entity; +import mir.entity.EntityList; +import mir.log.LoggerWrapper; +import mir.module.AbstractModule; +import mir.module.ModuleException; +import mir.storage.StorageObject; +import mir.storage.StorageObjectExc; +import mir.storage.StorageObjectFailure; +import mircoders.storage.DatabaseTopics; +import freemarker.template.SimpleList; /* * ThemenModule - @@ -24,19 +51,64 @@ import mircoders.storage.*; * @author RK */ -public class ModuleTopics extends AbstractModule -{ +public class ModuleTopics extends AbstractModule { + + static LoggerWrapper logger = new LoggerWrapper("Module.Topics"); - static Logfile theLog; + public ModuleTopics(StorageObject theStorage) { + this.theStorage = theStorage; + } - public ModuleTopics(StorageObject theStorage) { - this.theStorage = theStorage; - if (theLog == null) - theLog = Logfile.getInstance(this.getClass().getName()); + public SimpleList getTopicsAsSimpleList() throws ModuleException { + try { + return ((DatabaseTopics) theStorage).getPopupData(); + } + catch (StorageObjectFailure e) { + throw new ModuleException(e.toString()); } + } - public SimpleList getTopicsAsSimpleList() { - return ((DatabaseTopics)theStorage).getPopupData(); + /** + * Method getTopicList + * + * @return SimpleList of all Topics sorted by title + * + */ + public EntityList getTopicsList() { + EntityList returnList = null; + try { + returnList = getByWhereClause("", "title", -1); + } + catch (Exception e) { + logger.warn("ModuleTopics.getTopicsList: topics could not be fetched: " + e.getMessage()); + } + return returnList; + } + + /** + * Overrides the AbstractModule.set(), + * All dependent ContentEntities are set unproduced. + * @param theValues Hash mit Spalte/Wert-Paaren + * @return Id des eingef?gten Objekts + * @exception ModuleException + */ + public String set(Map theValues) throws ModuleException { + try { + Entity theEntity = theStorage.selectById((String) theValues.get("id")); + if (theEntity == null) { + throw new ModuleException("No topic with id " + theValues.get("id") + " found"); + } + theEntity.setValues(theValues); + theEntity.update(); + + return theEntity.getId(); + } + catch (StorageObjectFailure e) { + throw new ModuleException(e.toString()); + } + catch (StorageObjectExc e) { + throw new ModuleException(e.toString()); } + } }