mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Escape RSS post title
closes #755 - added html escape for post title - changed author for rss feed to current user - added simple test to check rss is working
This commit is contained in:
parent
cb38bb961a
commit
141361c40e
2 changed files with 57 additions and 37 deletions
|
@ -7,6 +7,7 @@
|
||||||
var Ghost = require('../../ghost'),
|
var Ghost = require('../../ghost'),
|
||||||
api = require('../api'),
|
api = require('../api'),
|
||||||
RSS = require('rss'),
|
RSS = require('rss'),
|
||||||
|
_ = require('underscore'),
|
||||||
|
|
||||||
ghost = new Ghost(),
|
ghost = new Ghost(),
|
||||||
frontendControllers;
|
frontendControllers;
|
||||||
|
@ -66,58 +67,61 @@ frontendControllers = {
|
||||||
'rss': function (req, res) {
|
'rss': function (req, res) {
|
||||||
// Initialize RSS
|
// Initialize RSS
|
||||||
var siteUrl = ghost.config().url,
|
var siteUrl = ghost.config().url,
|
||||||
|
pageParam = req.params.page !== undefined ? parseInt(req.params.page, 10) : 1,
|
||||||
|
feed;
|
||||||
|
//needs refact for multi user to not use first user as default
|
||||||
|
api.users.read({id : 1}).then(function (user) {
|
||||||
feed = new RSS({
|
feed = new RSS({
|
||||||
title: ghost.settings('title'),
|
title: ghost.settings('title'),
|
||||||
description: ghost.settings('description'),
|
description: ghost.settings('description'),
|
||||||
generator: 'Ghost v' + res.locals.version,
|
generator: 'Ghost v' + res.locals.version,
|
||||||
author: ghost.settings('author'),
|
author: user.attributes.name,
|
||||||
feed_url: siteUrl + '/rss/',
|
feed_url: siteUrl + '/rss/',
|
||||||
site_url: siteUrl,
|
site_url: siteUrl,
|
||||||
ttl: '60'
|
ttl: '60'
|
||||||
}),
|
});
|
||||||
// Parse the page number
|
|
||||||
pageParam = req.params.page !== undefined ? parseInt(req.params.page, 10) : 1;
|
|
||||||
|
|
||||||
// No negative pages
|
// No negative pages
|
||||||
if (isNaN(pageParam) || pageParam < 1) {
|
if (isNaN(pageParam) || pageParam < 1) {
|
||||||
return res.redirect("/rss/");
|
return res.redirect("/rss/");
|
||||||
}
|
|
||||||
|
|
||||||
if (pageParam === 1 && req.route.path === '/rss/:page/') {
|
|
||||||
return res.redirect('/rss/');
|
|
||||||
}
|
|
||||||
|
|
||||||
api.posts.browse({page: pageParam}).then(function (page) {
|
|
||||||
var maxPage = page.pages;
|
|
||||||
|
|
||||||
// A bit of a hack for situations with no content.
|
|
||||||
if (maxPage === 0) {
|
|
||||||
maxPage = 1;
|
|
||||||
page.pages = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If page is greater than number of pages we have, redirect to last page
|
if (pageParam === 1 && req.route.path === '/rss/:page/') {
|
||||||
if (pageParam > maxPage) {
|
return res.redirect('/rss/');
|
||||||
return res.redirect("/rss/" + maxPage + "/");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ghost.doFilter('prePostsRender', page.posts, function (posts) {
|
api.posts.browse({page: pageParam}).then(function (page) {
|
||||||
posts.forEach(function (post) {
|
var maxPage = page.pages;
|
||||||
var item = {
|
|
||||||
title: post.title,
|
|
||||||
guid: post.uuid,
|
|
||||||
url: siteUrl + '/' + post.slug + '/',
|
|
||||||
date: post.published_at
|
|
||||||
};
|
|
||||||
|
|
||||||
if (post.meta_description !== null) {
|
// A bit of a hack for situations with no content.
|
||||||
item.push({ description: post.meta_description });
|
if (maxPage === 0) {
|
||||||
}
|
maxPage = 1;
|
||||||
|
page.pages = 1;
|
||||||
|
}
|
||||||
|
|
||||||
feed.item(item);
|
// If page is greater than number of pages we have, redirect to last page
|
||||||
|
if (pageParam > maxPage) {
|
||||||
|
return res.redirect("/rss/" + maxPage + "/");
|
||||||
|
}
|
||||||
|
|
||||||
|
ghost.doFilter('prePostsRender', page.posts, function (posts) {
|
||||||
|
posts.forEach(function (post) {
|
||||||
|
var item = {
|
||||||
|
title: _.escape(post.title),
|
||||||
|
guid: post.uuid,
|
||||||
|
url: siteUrl + '/' + post.slug + '/',
|
||||||
|
date: post.published_at
|
||||||
|
};
|
||||||
|
|
||||||
|
if (post.meta_description !== null) {
|
||||||
|
item.push({ description: post.meta_description });
|
||||||
|
}
|
||||||
|
|
||||||
|
feed.item(item);
|
||||||
|
});
|
||||||
|
res.set('Content-Type', 'text/xml');
|
||||||
|
res.send(feed.xml());
|
||||||
});
|
});
|
||||||
res.set('Content-Type', 'text/xml');
|
|
||||||
res.send(feed.xml());
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
16
core/test/functional/frontend/02_rss_test.js
Normal file
16
core/test/functional/frontend/02_rss_test.js
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
/**
|
||||||
|
* Tests if RSS exists and is working
|
||||||
|
*/
|
||||||
|
casper.test.begin('Ensure that RSS is available', 3, function suite(test) {
|
||||||
|
test.filename = 'rss_test.png';
|
||||||
|
|
||||||
|
casper.start(url + 'rss/', function (response) {
|
||||||
|
test.assertEqual(response.status, 200, 'Response status should be 200.');
|
||||||
|
test.assert(this.getPageContent().indexOf('<rss') >= 0, 'Feed should contain <rss');
|
||||||
|
test.assert(this.getPageContent().indexOf('</rss>') >= 0, 'Feed should contain </rss>');
|
||||||
|
});
|
||||||
|
|
||||||
|
casper.run(function () {
|
||||||
|
test.done();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Add table
Reference in a new issue