Vulcan/packages/example-forum/lib/server/rss.js
2017-09-29 09:19:23 +09:00

103 lines
3.1 KiB
JavaScript

import RSS from 'rss';
import { Posts } from '../modules/posts/index.js';
import { Comments } from '../modules/comments/index.js';
import { Utils, getSetting, registerSetting } from 'meteor/vulcan:core';
import { Picker } from 'meteor/meteorhacks:picker';
registerSetting('forum.RSSLinksPointTo', 'link', 'Where to point RSS links to');
Posts.addView('rss', Posts.views.new); // default to 'new' view for RSS feed
const getMeta = (url) => {
const siteUrl = getSetting('siteUrl', Meteor.absoluteUrl());
return {
title: getSetting('title'),
description: getSetting('tagline'),
feed_url: siteUrl+url,
site_url: siteUrl,
image_url: siteUrl+'img/favicon.png'
};
};
export const servePostRSS = (terms, url) => {
const feed = new RSS(getMeta(url));
let parameters = Posts.getParameters(terms);
delete parameters['options']['sort']['sticky'];
parameters.options.limit = 50;
const postsCursor = Posts.find(parameters.selector, parameters.options);
postsCursor.forEach((post) => {
const description = !!post.body ? post.body+'</br></br>' : '';
const feedItem = {
title: post.title,
description: description + `<a href="${Posts.getPageUrl(post, true)}">Discuss</a>`,
author: post.author,
date: post.postedAt,
guid: post._id,
url: (getSetting('forum.RSSLinksPointTo', 'link') === 'link') ? Posts.getLink(post) : Posts.getPageUrl(post, true)
};
if (post.thumbnailUrl) {
const url = Utils.addHttp(post.thumbnailUrl);
feedItem.custom_elements = [{'imageUrl':url}, {'content': url}];
}
feed.item(feedItem);
});
return feed.xml();
};
export const serveCommentRSS = (terms, url) => {
const feed = new RSS(getMeta(url));
const commentsCursor = Comments.find({isDeleted: {$ne: true}}, {sort: {postedAt: -1}, limit: 20});
commentsCursor.forEach(function(comment) {
const post = Posts.findOne(comment.postId);
feed.item({
title: 'Comment on ' + post.title,
description: `${comment.body}</br></br><a href='${Comments.getPageUrl(comment, true)}'>Discuss</a>`,
author: comment.author,
date: comment.postedAt,
url: Comments.getPageUrl(comment, true),
guid: comment._id
});
});
return feed.xml();
};
Picker.route('/feed.xml', function(params, req, res, next) {
if (typeof params.query.view === 'undefined') {
params.query.view = 'rss';
}
res.end(servePostRSS(params.query, 'feed.xml'));
});
Picker.route('/rss/posts/new.xml', function(params, req, res, next) {
res.end(servePostRSS({view: 'new'}, '/rss/posts/new.xml'));
});
Picker.route('/rss/posts/top.xml', function(params, req, res, next) {
res.end(servePostRSS({view: 'top'}, '/rss/posts/top.xml'));
});
Picker.route('/rss/posts/best.xml', function(params, req, res, next) {
res.end(servePostRSS({view: 'best'}, '/rss/posts/best.xml'));
});
Picker.route('/rss/category/:slug/feed.xml', function(params, req, res, next) {
res.end(servePostRSS({view: 'new', cat: params.slug}, '/rss/category/:slug/feed.xml'));
});
Picker.route('/rss/comments.xml', function(params, req, res, next) {
res.end(serveCommentRSS({}, '/rss/comments.xml'));
});