com.sun.syndication.feed.synd.SyndEntryImpl Java Examples
The following examples show how to use
com.sun.syndication.feed.synd.SyndEntryImpl.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: StubbornJavaRss.java From StubbornJava with MIT License | 5 votes |
private static String getFeed(HttpUrl host) { SyndFeed feed = new SyndFeedImpl(); feed.setFeedType("rss_2.0"); feed.setTitle("StubbornJava"); feed.setLink(host.toString()); feed.setDescription("Unconventional guides, examples, and blog utilizing modern Java"); List<PostRaw> posts = Posts.getAllRawPosts(); List<SyndEntry> entries = Seq.seq(posts) .map(p -> { SyndEntry entry = new SyndEntryImpl(); entry.setTitle(p.getTitle()); entry.setLink(host.newBuilder().encodedPath(p.getUrl()).build().toString()); entry.setPublishedDate(Date.from(p.getDateCreated() .toLocalDate() .atStartOfDay(ZoneId.systemDefault()) .toInstant())); entry.setUpdatedDate(Date.from(p.getDateUpdated() .toLocalDate() .atStartOfDay(ZoneId.systemDefault()) .toInstant())); SyndContentImpl description = new SyndContentImpl(); description.setType("text/plain"); description.setValue(p.getMetaDesc()); entry.setDescription(description); return entry; }).toList(); feed.setEntries(entries); StringWriter writer = new StringWriter(); SyndFeedOutput output = new SyndFeedOutput(); return Unchecked.supplier(() -> { output.output(feed, writer); return writer.toString(); }).get(); }
Example #2
Source File: StubbornJavaRss.java From StubbornJava with MIT License | 5 votes |
private static String getFeed(HttpUrl host) { SyndFeed feed = new SyndFeedImpl(); feed.setFeedType("rss_2.0"); feed.setTitle("StubbornJava"); feed.setLink(host.toString()); feed.setDescription("Unconventional guides, examples, and blog utilizing modern Java"); List<PostRaw> posts = Posts.getAllRawPosts(); List<SyndEntry> entries = Seq.seq(posts) .map(p -> { SyndEntry entry = new SyndEntryImpl(); entry.setTitle(p.getTitle()); entry.setLink(host.newBuilder().encodedPath(p.getUrl()).build().toString()); entry.setPublishedDate(Date.from(p.getDateCreated() .toLocalDate() .atStartOfDay(ZoneId.systemDefault()) .toInstant())); entry.setUpdatedDate(Date.from(p.getDateUpdated() .toLocalDate() .atStartOfDay(ZoneId.systemDefault()) .toInstant())); SyndContentImpl description = new SyndContentImpl(); description.setType("text/plain"); description.setValue(p.getMetaDesc()); entry.setDescription(description); return entry; }).toList(); feed.setEntries(entries); StringWriter writer = new StringWriter(); SyndFeedOutput output = new SyndFeedOutput(); return Unchecked.supplier(() -> { output.output(feed, writer); return writer.toString(); }).get(); }
Example #3
Source File: RSSFeed.java From olat with Apache License 2.0 | 4 votes |
/** * Constructor. The identityKey is needed to generate personal URLs for the corresponding user. */ protected RSSFeed(final Feed feed, final Identity identity, final Long courseId, final String nodeId,final Translator translator, RepositoryService repositoryService) { super(); // This helper object is required for generating the appropriate URLs for // the given user (identity) final FeedViewHelper helper = new FeedViewHelper(feed, identity, courseId, nodeId, translator, repositoryService); setFeedType("rss_2.0"); setEncoding(RSSServlet.DEFAULT_ENCODING); setTitle(feed.getTitle()); // According to the rss specification, the feed channel description is not // (explicitly) allowed to contain html tags. String strippedDescription = FilterFactory.getHtmlTagsFilter().filter(feed.getDescription()); strippedDescription = strippedDescription.replaceAll(" ", " "); // TODO: remove when filter // does it setDescription(strippedDescription); setLink(helper.getJumpInLink()); setPublishedDate(feed.getLastModified()); // The image if (feed.getImageName() != null) { final SyndImage image = new SyndImageImpl(); image.setDescription(feed.getDescription()); image.setTitle(feed.getTitle()); image.setLink(getLink()); image.setUrl(helper.getImageUrl()); setImage(image); } final List<SyndEntry> episodes = new ArrayList<SyndEntry>(); for (final Item item : feed.getPublishedItems()) { final SyndEntry entry = new SyndEntryImpl(); entry.setTitle(item.getTitle()); final SyndContent itemDescription = new SyndContentImpl(); itemDescription.setType("text/plain"); itemDescription.setValue(helper.getItemDescriptionForBrowser(item)); entry.setDescription(itemDescription); // Link will also be converted to the rss guid tag. Except if there's an // enclosure, then the enclosure url is used. // Use jump-in link far all entries. This will be overriden if the item // has an enclosure. entry.setLink(helper.getJumpInLink() + "#" + item.getGuid()); entry.setPublishedDate(item.getPublishDate()); entry.setUpdatedDate(item.getLastModified()); // The enclosure is the media (audio or video) file of the episode final Enclosure media = item.getEnclosure(); if (media != null) { final SyndEnclosure enclosure = new SyndEnclosureImpl(); enclosure.setUrl(helper.getMediaUrl(item)); enclosure.setType(media.getType()); enclosure.setLength(media.getLength()); // Also set the item link to point to the enclosure entry.setLink(helper.getMediaUrl(item)); final List<SyndEnclosure> enclosures = new ArrayList<SyndEnclosure>(); enclosures.add(enclosure); entry.setEnclosures(enclosures); } episodes.add(entry); } setEntries(episodes); }
Example #4
Source File: RSSFeed.java From olat with Apache License 2.0 | 4 votes |
/** * Constructor. The identityKey is needed to generate personal URLs for the corresponding user. */ protected RSSFeed(final Feed feed, final Identity identity, final Long courseId, final String nodeId, final Translator translator, RepositoryService repositoryService) { super(); // This helper object is required for generating the appropriate URLs for // the given user (identity) final FeedViewHelper helper = new FeedViewHelper(feed, identity, courseId, nodeId, translator, repositoryService); setFeedType("rss_2.0"); setEncoding(DEFAULT_ENCODING); setTitle(feed.getTitle()); // According to the rss specification, the feed channel description is not // (explicitly) allowed to contain html tags. String strippedDescription = FilterFactory.getHtmlTagsFilter().filter(feed.getDescription()); strippedDescription = strippedDescription.replaceAll(" ", " "); // TODO: remove when filter // does it setDescription(strippedDescription); setLink(helper.getJumpInLink()); setPublishedDate(feed.getLastModified()); // The image if (feed.getImageName() != null) { final SyndImage image = new SyndImageImpl(); image.setDescription(feed.getDescription()); image.setTitle(feed.getTitle()); image.setLink(getLink()); image.setUrl(helper.getImageUrl()); setImage(image); } final List<SyndEntry> episodes = new ArrayList<SyndEntry>(); for (final Item item : feed.getPublishedItems()) { final SyndEntry entry = new SyndEntryImpl(); entry.setTitle(item.getTitle()); final SyndContent itemDescription = new SyndContentImpl(); itemDescription.setType("text/plain"); itemDescription.setValue(helper.getItemDescriptionForBrowser(item)); entry.setDescription(itemDescription); // Link will also be converted to the rss guid tag. Except if there's an // enclosure, then the enclosure url is used. // Use jump-in link far all entries. This will be overriden if the item // has an enclosure. entry.setLink(helper.getJumpInLink() + "#" + item.getGuid()); entry.setPublishedDate(item.getPublishDate()); entry.setUpdatedDate(item.getLastModified()); // The enclosure is the media (audio or video) file of the episode final Enclosure media = item.getEnclosure(); if (media != null) { final SyndEnclosure enclosure = new SyndEnclosureImpl(); enclosure.setUrl(helper.getMediaUrl(item)); enclosure.setType(media.getType()); enclosure.setLength(media.getLength()); // Also set the item link to point to the enclosure entry.setLink(helper.getMediaUrl(item)); final List<SyndEnclosure> enclosures = new ArrayList<SyndEnclosure>(); enclosures.add(enclosure); entry.setEnclosures(enclosures); } episodes.add(entry); } setEntries(episodes); }
Example #5
Source File: RomeRssItem.java From megatron-java with Apache License 2.0 | 4 votes |
/** * Constructs an empty item. */ public RomeRssItem(TypedProperties props, RomeRssChannel parentChannel) { this(props, parentChannel, new SyndEntryImpl()); }
Example #6
Source File: RomeSyndicationOperator.java From attic-apex-malhar with Apache License 2.0 | 3 votes |
/** * Get a serializable syndEntry for the given syndEntry. * Not all implementations of syndEntry are serializable according to rome * documentation. This method creates and returns a copy of the original * syndEntry that is java serializable. * * @param syndEntry The syndEntry to create a serializable copy of * @return The serializable copy syndEntry */ private RomeFeedEntry getSerializableEntry(SyndEntry syndEntry) { SyndEntry serSyndEntry = new SyndEntryImpl(); serSyndEntry.copyFrom(syndEntry); //return serSyndEntry; RomeFeedEntry romeFeedEntry = new RomeFeedEntry(serSyndEntry); return romeFeedEntry; }