rebuilding head
[mir.git] / source / mircoders / entity / EntityContent.java
index 968c06e..10fc102 100755 (executable)
@@ -33,43 +33,25 @@ package mircoders.entity;
 import java.sql.Connection;
 import java.sql.SQLException;
 import java.sql.Statement;
-import java.util.HashMap;
 import java.util.Map;
 
-import mir.entity.Entity;
-import mir.entity.EntityList;
+import mir.entity.AbstractEntity;
 import mir.log.LoggerWrapper;
 import mir.storage.StorageObject;
-import mir.storage.StorageObjectExc;
 import mir.storage.StorageObjectFailure;
-import mircoders.storage.DatabaseContent;
 import mircoders.storage.DatabaseContentToMedia;
-import mircoders.storage.DatabaseContentToTopics;
 
 /**
  * this class implements mapping of one line of the database table content
  * to a java object
  *
- * @version $Id: EntityContent.java,v 1.20 2003/09/03 18:29:04 zapata Exp $
+ * @version $Id: EntityContent.java,v 1.21 2004/11/06 19:56:13 idfx Exp $
  * @author mir-coders group
  *
  */
 
 
-public class EntityContent extends Entity
-{
-
-  String mirconf_extLinkName  = configuration.getString("Producer.ExtLinkName");
-  String mirconf_intLinkName  = configuration.getString("Producer.IntLinkName");
-  String mirconf_mailLinkName = configuration.getString("Producer.MailLinkName");
-  String mirconf_imageRoot    = configuration.getString("Producer.ImageRoot");
-
-  //this should always be transient i.e it can never be stored in the db
-  //or ObjectStore. (so the ObjectStore should only be caching what comes
-  //directly out of the DB. @todo confirm this with rk. -mh
-  Map _entCache = new HashMap();
-  Boolean _hasMedia = null;
-
+public class EntityContent extends AbstractEntity {
   // constructors
 
   public EntityContent()
@@ -85,34 +67,30 @@ public class EntityContent extends Entity
     setStorage(theStorage);
   }
 
-  //
-  // methods
-
   /**
    * set is_produced flag for the article
    */
-
   public void setProduced(boolean yesno) throws StorageObjectFailure
   {
     String value = (yesno) ? "1":"0";
-    if (value.equals( getValue("is_produced") )) return;
+    if (value.equals( getFieldValue("is_produced") )) return;
 
     Connection con=null;Statement stmt=null;
     String sql = "update content set is_produced='" + value + "' where id='" + getId()+"'";
     try {
-      con = theStorageObject.getPooledCon();
-      /** @todo should be preparedStatement: faster!! */
+      con = storageObject.obtainConnection();
+      /** todo should be preparedStatement: faster!! */
       stmt = con.createStatement();
-      theStorageObject.executeUpdate(stmt,sql);
+      storageObject.executeUpdate(stmt,sql);
     }
     catch (StorageObjectFailure e) {
-      throwStorageObjectFailure(e, "\n -- set produced failed");
+      throw e;
     }
     catch (SQLException e) {
-      throwStorageObjectFailure(e, "\n -- set produced failed");
+      throw new StorageObjectFailure(e);
     }
     finally {
-      theStorageObject.freeConnection(con,stmt);
+      storageObject.freeConnection(con,stmt);
     }
   }
 
@@ -126,33 +104,20 @@ public class EntityContent extends Entity
   public void dettach(String anArticleId, String aMediaId) throws StorageObjectFailure
   {
     if (aMediaId!=null){
-      try{
-        DatabaseContentToMedia.getInstance().delete(anArticleId, aMediaId);
-      }
-      catch (Exception e){
-        throwStorageObjectFailure(e, "\n -- failed to get instance");
-      }
+      DatabaseContentToMedia.getInstance().delete(anArticleId, aMediaId);
 
       setProduced(false);
     }
   }
 
   /**
-   * Attaches media to an article
-   *
-   * @param mid
-   * @throws StorageObjectFailure
+   * Attaches media to the article
    */
 
   public void attach(String aMediaId) throws StorageObjectFailure
   {
     if (aMediaId!=null) {
-      try{
-        DatabaseContentToMedia.getInstance().addMedia(getId(),aMediaId);
-      }
-      catch(StorageObjectFailure e){
-        throwStorageObjectFailure(e, "attach: could not get the instance");
-      }
+      DatabaseContentToMedia.getInstance().addMedia(getId(),aMediaId);
       setProduced(false);
     }
     else {
@@ -161,9 +126,9 @@ public class EntityContent extends Entity
   }
 
   /**
-   * overridden method setValues to patch creator_main_url
+   * overridden method setFieldValues to patch creator_main_url
    */
-  public void setValues(Map theStringValues) {
+  public void setFieldValues(Map theStringValues) {
     if (theStringValues != null) {
       if (theStringValues.containsKey("creator_main_url")){
         if (((String)theStringValues.get("creator_main_url")).equalsIgnoreCase("http://")){
@@ -174,19 +139,6 @@ public class EntityContent extends Entity
         }
       }
     }
-    super.setValues(theStringValues);
-  }
-
-  private boolean hasMedia() throws StorageObjectFailure
-  {
-    if (_hasMedia == null) {
-      try {
-        _hasMedia =
-            new Boolean(DatabaseContentToMedia.getInstance().hasMedia(this));
-      } catch (StorageObjectExc e) {
-        throw new StorageObjectFailure(e);
-      }
-    }
-    return _hasMedia.booleanValue();
+    super.setFieldValues(theStringValues);
   }
 }