com.sun.syndication.feed.synd.SyndEntry Maven / Gradle / Ivy
/*
* Copyright 2004 Sun Microsystems, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package com.sun.syndication.feed.synd;
import java.util.Date;
import java.util.List;
import com.sun.syndication.feed.CopyFrom;
import com.sun.syndication.feed.module.Extendable;
import com.sun.syndication.feed.module.Module;
/**
* Bean interface for entries of SyndFeedImpl feeds.
*
* @author Alejandro Abdelnur
*
*/
public interface SyndEntry extends Cloneable, CopyFrom, Extendable {
/**
* Returns the entry URI.
*
* How the entry URI maps to a concrete feed type (RSS or Atom) depends on
* the concrete feed type. This is explained in detail in Rome documentation,
* Feed and entry URI mapping.
*
* The returned URI is a normalized URI as specified in RFC 2396bis.
*
* @return the entry URI, null if none.
*
*/
String getUri();
/**
* Sets the entry URI.
*
* How the entry URI maps to a concrete feed type (RSS or Atom) depends on
* the concrete feed type. This is explained in detail in Rome documentation,
* Feed and entry URI mapping.
*
* @param uri the entry URI to set, null if none.
*
*/
void setUri(String uri);
/**
* Returns the entry title.
*
* @return the entry title, null if none.
*
*/
String getTitle();
/**
* Sets the entry title.
*
* @param title the entry title to set, null if none.
*
*/
void setTitle(String title);
/**
* Returns the entry title as a text construct.
*
* @return the entry title, null if none.
*
*/
SyndContent getTitleEx();
/**
* Sets the entry title as a text construct.
*
* @param title the entry title to set, null if none.
*
*/
void setTitleEx(SyndContent title);
/**
* Returns the entry link.
*
* @return the entry link, null if none.
*
*/
String getLink();
/**
* Sets the entry link.
*
* @param link the entry link to set, null if none.
*
*/
void setLink(String link);
/**
* Returns the entry links
*
* @return the entry links, null if none.
*
*/
List getLinks();
/**
* Sets the entry links.
*
* @param links the entry links to set, null if none.
*
*/
void setLinks(List links);
/**
* Returns the entry description.
*
* @return the entry description, null if none.
*
*/
SyndContent getDescription();
/**
* Sets the entry description.
*
* @param description the entry description to set, null if none.
*
*/
void setDescription(SyndContent description);
/**
* Returns the entry contents.
*
* @return a list of SyndContentImpl elements with the entry contents,
* an empty list if none.
*
*/
List getContents();
/**
* Sets the entry contents.
*
* @param contents the list of SyndContentImpl elements with the entry contents to set,
* an empty list or null if none.
*
*/
void setContents(List contents);
/**
* Returns the entry enclosures.
*
* @return a list of SyndEnclosure elements with the entry enclosures,
* an empty list if none.
*
*/
public List getEnclosures();
/**
* Sets the entry enclosures.
*
* @param enclosures the list of SyndEnclosure elements with the entry enclosures to set,
* an empty list or null if none.
*
*/
public void setEnclosures(List enclosures);
/**
* Returns the entry published date.
*
* This method is a convenience method, it maps to the Dublin Core module date.
*
* @return the entry published date, null if none.
*
*/
Date getPublishedDate();
/**
* Sets the entry published date.
*
* This method is a convenience method, it maps to the Dublin Core module date.
*
* @param publishedDate the entry published date to set, null if none.
*
*/
void setPublishedDate(Date publishedDate);
/**
* Returns the entry updated date.
*
* @return the entry updated date, null if none.
*
*/
Date getUpdatedDate();
/**
* Sets the entry updated date.
*
* @param updatedDate the entry updated date to set, null if none.
*
*/
void setUpdatedDate(Date updatedDate);
/**
* Returns the entry authors.
*
* For Atom feeds, this returns the authors as a list of SyndPerson objects,
* for RSS feeds this method is a convenience method, it maps to the
* Dublin Core module creator.
*
* @return the feed author, null if none.
*
*/
List getAuthors();
/**
* Sets the entry author.
*
* For Atom feeds, this sets the authors as a list of SyndPerson
* objects, for RSS feeds this method is a convenience method, it maps
* to the Dublin Core module creator.
*
* @param authors the feed author to set, null if none.
*
*/
void setAuthors(List authors);
/**
* Returns the name of the first entry author in the collection of authors.
*
* For Atom feeds, this returns the authors as a list of SyndPerson objects,
* for RSS feeds this method is a convenience method, it maps to the
* Dublin Core module creator.
*
* @return the feed author, null if none.
*
*/
String getAuthor();
/**
* Sets the entry author.
*
* For Atom feeds, this sets the feed author's name, for RSS feeds
* this method is a convenience method, it maps to the Dublin Core
* module creator.
*
* @param author the feed author to set, null if none.
*/
void setAuthor(String author);
/**
* Returns the feed author.
*
* For Atom feeds, this returns the contributors as a list of
* SyndPerson objects
*
* @return the feed author, null if none.
*
*/
List getContributors();
/**
* Sets the feed contributors.
*
* Returns contributors as a list of SyndPerson objects.
*
* @param contributors the feed contributors to set, null if none.
*
*/
void setContributors(List contributors);
/**
* Returns the entry categories.
*
* This method is a convenience method, it maps to the Dublin Core module subjects.
*
* @return a list of SyndCategoryImpl elements with the entry categories,
* an empty list if none.
*
*/
List getCategories();
/**
* Sets the entry categories.
*
* This method is a convenience method, it maps to the Dublin Core module subjects.
*
* @param categories the list of SyndCategoryImpl elements with the entry categories to set,
* an empty list or null if none.
*
*/
void setCategories(List categories);
/**
* Returns the entry source.
*
* This returns the entry source as a SyndFeed
*
* @return the SyndFeed to which this entry is attributed
*
*/
SyndFeed getSource();
/**
* Sets the entry source feed (for use if different from containing feed)
*
* @param source the original SyndFeed that contained this article
*
*/
void setSource(SyndFeed source);
/**
* Return the original item this SyndEntry is generated from.
* The type of the object returned depends on the original type of
* the feed. Atom 0.3/1.0 will return com.sun.syndication.feed.atom.Entry,
* while RSS will return com.sun.syndication.feed.rss.Item.java.
* If this entry was not generated from a WireFeed, or the SyndFeed
* was not set to preserve the WireFeed then it will return null
*
* @return the WireFeed Item or Entry this Entry is generated from, or null
*/
Object getWireEntry();
/**
* Returns the module identified by a given URI.
*
* @param uri the URI of the ModuleImpl.
* @return The module with the given URI, null if none.
*/
public Module getModule(String uri);
/**
* Returns the entry modules.
*
* @return a list of ModuleImpl elements with the entry modules,
* an empty list if none.
*
*/
List getModules();
/**
* Sets the entry modules.
*
* @param modules the list of ModuleImpl elements with the entry modules to set,
* an empty list or null if none.
*
*/
void setModules(List modules);
/**
* Returns foreign markup found at channel level.
*
* @return Opaque object to discourage use
*
*/
public Object getForeignMarkup();
/**
* Sets foreign markup found at channel level.
*
* @param foreignMarkup Opaque object to discourage use
*
*/
public void setForeignMarkup(Object foreignMarkup);
/**
* Creates a deep clone of the object.
*
* @return a clone of the object.
* @throws CloneNotSupportedException thrown if an element of the object cannot be cloned.
*
*/
public Object clone() throws CloneNotSupportedException;
/**
* Returns the first instance of a SyndLink with the specified relation, or null
*
*/
public SyndLink findRelatedLink(String relation);
}