Package de.nava.informa.impl.hibernate

Source Code of de.nava.informa.impl.hibernate.Item

//
// Informa -- RSS Library for Java
// Copyright (c) 2002 by Niko Schmuck
//
// Niko Schmuck
// http://sourceforge.net/projects/informa
// mailto:niko_schmuck@users.sourceforge.net
//
// This library is free software.
//
// You may redistribute it and/or modify it under the terms of the GNU
// Lesser General Public License as published by the Free Software Foundation.
//
// Version 2.1 of the license should be included with this distribution in
// the file LICENSE. If the license is not included with this distribution,
// you may find a copy at the FSF web site at 'www.gnu.org' or 'www.fsf.org',
// or you may write to the Free Software Foundation, 675 Mass Ave, Cambridge,
// MA 02139 USA.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied waranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//


// $Id: Item.java,v 1.27 2006/12/04 23:43:27 italobb Exp $

package de.nava.informa.impl.hibernate;

import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;

import org.jdom.Element;

import de.nava.informa.core.CategoryIF;
import de.nava.informa.core.ChannelIF;
import de.nava.informa.core.ItemEnclosureIF;
import de.nava.informa.core.ItemGuidIF;
import de.nava.informa.core.ItemIF;
import de.nava.informa.core.ItemSourceIF;
import de.nava.informa.utils.XmlPathUtils;

/**
* Hibernate implementation of the ItemIF interface.
*
* @author Niko Schmuck (niko@nava.de)
*/
public class Item implements ItemIF {

  private static final long serialVersionUID = 899115671959509447L;

  private long id = -1;
  private String title;
  private String description;
  private URL link;
  private Collection<CategoryIF> categories;
  private String creator;
  private String subject;
  private Date date;
  private Date found;
  private ItemGuidIF guid;
  private URL comments;
  private ItemEnclosureIF enclosure;
  private ItemSourceIF source;
  private ChannelIF channel;
  private Element itemElement;
  private boolean unRead;

  public Item() {
    this(null, null, "[Unnamed item]", null, null);
  }

  public Item(String title, String description, URL link) {
    this(null, null, title, description, link);
  }

  public Item(ChannelIF channel, String title, String description, URL link) {
    this(null, channel, title, description, link);
  }

  public Item(Element itemElement, String title, String description, URL link) {
    this(itemElement, null, title, description, link);
  }

  public Item(Element itemElement, ChannelIF channel, String title, String description, URL link) {
    this.itemElement = itemElement;
    this.channel = channel;
    this.title = title;
    this.description = description;
    this.link = link;
    this.categories = new ArrayList<CategoryIF>();
    this.unRead = true;
  }

  // --------------------------------------------------------------
  // implementation of ItemIF interface
  // --------------------------------------------------------------

  /**
   * @return integer representation of identity.
   */
  public long getId() {
    return id;
  }

  public void setId(long id) {
    this.id = id;
  }

  /**
   * @return parent channel.
   */
  public ChannelIF getChannel() {
    return channel;
  }

  public void setChannel(ChannelIF parentChannel) {
    this.channel = parentChannel;
  }

  /**
   * @return title.
   */
  public String getTitle() {
    return title;
  }

  public void setTitle(String aTitle) {
    this.title = aTitle;
  }

  /**
   * @return description.
   */
  public String getDescription() {
    return description;
  }

  public void setDescription(String aDescription) {
    this.description = aDescription;
  }

  /**
   * @return unread flag.
   */
  public boolean getUnRead() {
    return unRead;
  }

  public void setUnRead(boolean val) {
    this.unRead = val;
  }

  /**
   * @return link to original article.
   */
  public String getLinkString() {
    return (link == null) ? null : link.toString();
  }

  public void setLinkString(String linkStr) {
    if (linkStr == null || linkStr.trim().length() == 0) {
      link = null;
      return;
    } else {
      try {
        this.link = new URL(linkStr);
      } catch (MalformedURLException e) {
        e.printStackTrace();
      }
    }
  }
  
  public URL getLink() {
    return link;
  }

  public void setLink(URL aLink) {
    this.link = aLink;
  }

  /**
   * @return categories.
   */
  public Collection getCategories() {
    return categories;
  }

  public void setCategories(Collection<CategoryIF> aCategories) {
    this.categories = aCategories;
  }

  public void addCategory(CategoryIF category) {
    categories.add(category);
  }

  public void removeCategory(CategoryIF category) {
    categories.remove(category);
  }

  /**
   * @return creator.
   */
  public String getCreator() {
    return creator;
  }

  public void setCreator(String aCreator) {
    this.creator = aCreator;
  }

  /**
   * @return subject.
   */
  public String getSubject() {
    return subject;
  }

  public void setSubject(String aSubject) {
    this.subject = aSubject;
  }

  /**
   * @return date.
   */
  public Date getDate() {
    return date;
  }

  public void setDate(Date aDate) {
    this.date = aDate;
  }

  /**
   * @return date when item was found.
   */
  public Date getFound() {
    return found;
  }

  public void setFound(Date foundDate) {
    this.found = foundDate;
  }

  /**
   * @return guid.
   */
  public ItemGuidIF getGuid() {
    return guid;
  }

  public void setGuid(ItemGuidIF guid) {
    this.guid = guid;
  }

  /**
   * @return comments.
   */
  public String getCommentsString() {
    return (comments == null) ? null : comments.toExternalForm();
  }

  public void setCommentsString(String commentsStr) {
    if (commentsStr == null || commentsStr.trim().length() == 0) {
      comments = null;
      return;
    } else {
      try {
        this.comments = new URL(commentsStr);
      } catch (MalformedURLException e) {
        e.printStackTrace();
        this.comments = null;
      }
    }
  }

  public URL getComments() {
    return comments;
  }

  public void setComments(URL comments) {
    this.comments = comments;
  }

  /**
   * @return source.
   */
  public ItemSourceIF getSource() {
    return source;
  }

  public void setSource(ItemSourceIF aSource) {
    this.source = aSource;
  }

  /**
   * @return enclosure.
   */
  public ItemEnclosureIF getEnclosure() {
    return enclosure;
  }

  public void setEnclosure(ItemEnclosureIF anEnclosure) {
    this.enclosure = anEnclosure;
  }

  public String getElementValue(final String path) {
    return XmlPathUtils.getElementValue(itemElement, path);
  }

  public String[] getElementValues(final String path, final String[] elements) {
    return XmlPathUtils.getElementValues(itemElement, path, elements);
  }

  public String getAttributeValue(final String path, final String attribute) {
    return XmlPathUtils.getAttributeValue(itemElement, path, attribute);
  }

  public String[] getAttributeValues(final String path, final String[] attributes) {
    return XmlPathUtils.getAttributeValues(itemElement, path, attributes);
  }

  // ----------------------------------------------------------------------
  // overwrite default method implementation from Object
  // ----------------------------------------------------------------------

  /**
   * Returns a string representation of the object.
   *
   * @return  a string representation of the object.
   */
  public String toString() {
    return "[Item (" + id + "): " + title + "]";
  }

  // ----------------------------------------------------------------------
  // overwrite default method implementation from Object
  // ----------------------------------------------------------------------

  /**
   * Indicates whether some other object is "equal to" this one.
   *
   * @param   o the reference object with which to compare.
   *
   * @return  <code>true</code> if this object is the same as the obj
   *          argument; <code>false</code> otherwise.
   *
   * NOTE: Please keep this code in sync with de.nava.informa.impl.hibernate.Item.equals().
   *
   * @see     #hashCode()
   */
  public boolean equals(Object o) {
    if (this == o) return true;
    if (!(o instanceof ItemIF)) return false;

    final ItemIF item = (ItemIF) o;

    final String itemTitle = item.getTitle();
    if (title != null
      ? !title.equals(itemTitle)
      : itemTitle != null) return false;

    // Comparison of links uses synchronized code of Java-NET.
    // This may hurt multi-threaded applications. So, please think twice
    // before using direct comparison of links.
    final URL itemLink = item.getLink();
    if (link != null
      ? itemLink == null || !link.toString().equalsIgnoreCase(itemLink.toString())
      : itemLink != null) return false;

    final String itemDescription = item.getDescription();
    if (description != null
      ? !description.equals(itemDescription)
      : itemDescription != null) return false;

    return true;
  }

  /**
   * Returns a hash code value for the object. This method is
   * supported for the benefit of hashtables such as those provided by
   * <code>java.util.Hashtable</code>.
   *
   * NOTE: Please keep this code in sync with de.nava.informa.impl.basic.Item.hashCode().
   *
   * @return a hash code value for this object.
   */
  public int hashCode() {
    StringBuffer sb = new StringBuffer(64);
    // This looks like a bug because it is not symmetrical with the accompanying equals().
    // sb.append(title).append(description).append(link);
    sb.append(title).append(description).append(link);
    return sb.toString().hashCode();
  }
}
TOP

Related Classes of de.nava.informa.impl.hibernate.Item

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.