2014-03-23 16:49:43 -05:00
|
|
|
var frontend = require('../controllers/frontend'),
|
|
|
|
config = require('../config'),
|
2015-12-10 10:00:02 -05:00
|
|
|
errors = require('../errors'),
|
2014-04-11 22:46:15 -05:00
|
|
|
express = require('express'),
|
2014-07-28 08:19:49 -05:00
|
|
|
utils = require('../utils'),
|
2013-12-30 02:03:29 -05:00
|
|
|
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 07:41:19 -05:00
|
|
|
frontendRoutes;
|
|
|
|
|
2015-05-30 15:18:26 -05:00
|
|
|
frontendRoutes = function frontendRoutes(middleware) {
|
2014-04-11 22:46:15 -05:00
|
|
|
var router = express.Router(),
|
2015-04-16 14:40:32 -05:00
|
|
|
subdir = config.paths.subdir,
|
2015-05-26 08:01:52 -05:00
|
|
|
routeKeywords = config.routeKeywords,
|
|
|
|
indexRouter = express.Router(),
|
|
|
|
tagRouter = express.Router({mergeParams: true}),
|
|
|
|
authorRouter = express.Router({mergeParams: true}),
|
|
|
|
rssRouter = express.Router({mergeParams: true}),
|
|
|
|
privateRouter = express.Router();
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2015-12-10 10:00:02 -05:00
|
|
|
function redirect301(res, path) {
|
2014-09-16 16:02:31 -05:00
|
|
|
/*jslint unparam:true*/
|
|
|
|
res.set({'Cache-Control': 'public, max-age=' + utils.ONE_YEAR_S});
|
2015-12-10 10:00:02 -05:00
|
|
|
res.redirect(301, path);
|
|
|
|
}
|
|
|
|
|
|
|
|
function handlePageParam(req, res, next, page) {
|
|
|
|
var pageRegex = new RegExp('/' + routeKeywords.page + '/(.*)?/'),
|
|
|
|
rssRegex = new RegExp('/rss/(.*)?/');
|
|
|
|
|
|
|
|
page = parseInt(page, 10);
|
|
|
|
|
|
|
|
if (page === 1) {
|
|
|
|
// Page 1 is an alias, do a permanent 301 redirect
|
|
|
|
if (rssRegex.test(req.url)) {
|
|
|
|
return redirect301(res, req.originalUrl.replace(rssRegex, '/rss/'));
|
|
|
|
} else {
|
|
|
|
return redirect301(res, req.originalUrl.replace(pageRegex, '/'));
|
|
|
|
}
|
|
|
|
} else if (page < 1 || isNaN(page)) {
|
|
|
|
// Nothing less than 1 is a valid page number, go straight to a 404
|
|
|
|
return next(new errors.NotFoundError());
|
|
|
|
} else {
|
|
|
|
// Set req.params.page to the already parsed number, and continue
|
|
|
|
req.params.page = page;
|
|
|
|
return next();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ### Admin routes
|
|
|
|
router.get(/^\/(logout|signout)\/$/, function redirectToSignout(req, res) {
|
|
|
|
redirect301(res, subdir + '/ghost/signout/');
|
2014-09-16 16:02:31 -05:00
|
|
|
});
|
2015-05-30 15:18:26 -05:00
|
|
|
router.get(/^\/signup\/$/, function redirectToSignup(req, res) {
|
2015-12-10 10:00:02 -05:00
|
|
|
redirect301(res, subdir + '/ghost/signup/');
|
2014-09-16 16:02:31 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
// redirect to /ghost and let that do the authentication to prevent redirects to /ghost//admin etc.
|
2015-05-30 15:18:26 -05:00
|
|
|
router.get(/^\/((ghost-admin|admin|wp-admin|dashboard|signin|login)\/?)$/, function redirectToAdmin(req, res) {
|
2015-12-10 10:00:02 -05:00
|
|
|
redirect301(res, subdir + '/ghost/');
|
2014-09-16 16:02:31 -05:00
|
|
|
});
|
|
|
|
|
2015-03-26 02:01:39 -05:00
|
|
|
// password-protected frontend route
|
2015-05-26 08:01:52 -05:00
|
|
|
privateRouter.route('/')
|
|
|
|
.get(
|
2015-07-15 11:01:23 -05:00
|
|
|
middleware.privateBlogging.isPrivateSessionAuth,
|
2015-05-26 08:01:52 -05:00
|
|
|
frontend.private
|
|
|
|
)
|
|
|
|
.post(
|
2015-07-15 11:01:23 -05:00
|
|
|
middleware.privateBlogging.isPrivateSessionAuth,
|
2015-05-26 14:04:27 -05:00
|
|
|
middleware.spamPrevention.protected,
|
2015-07-15 11:01:23 -05:00
|
|
|
middleware.privateBlogging.authenticateProtection,
|
2015-05-26 08:01:52 -05:00
|
|
|
frontend.private
|
|
|
|
);
|
2015-03-26 02:01:39 -05:00
|
|
|
|
2015-05-26 08:01:52 -05:00
|
|
|
rssRouter.route('/rss/').get(frontend.rss);
|
|
|
|
rssRouter.route('/rss/:page/').get(frontend.rss);
|
|
|
|
rssRouter.route('/feed/').get(function redirect(req, res) {
|
2015-12-10 10:00:02 -05:00
|
|
|
redirect301(res, subdir + '/rss/');
|
2014-03-23 16:49:43 -05:00
|
|
|
});
|
2015-12-10 10:00:02 -05:00
|
|
|
rssRouter.param('page', handlePageParam);
|
2014-03-23 16:49:43 -05:00
|
|
|
|
2015-05-26 08:01:52 -05:00
|
|
|
// Index
|
2015-10-25 15:00:29 -05:00
|
|
|
indexRouter.route('/').get(frontend.index);
|
|
|
|
indexRouter.route('/' + routeKeywords.page + '/:page/').get(frontend.index);
|
2015-12-10 10:00:02 -05:00
|
|
|
indexRouter.param('page', handlePageParam);
|
2015-05-26 08:01:52 -05:00
|
|
|
indexRouter.use(rssRouter);
|
|
|
|
|
2014-07-20 11:32:14 -05:00
|
|
|
// Tags
|
2015-05-26 08:01:52 -05:00
|
|
|
tagRouter.route('/').get(frontend.tag);
|
|
|
|
tagRouter.route('/' + routeKeywords.page + '/:page/').get(frontend.tag);
|
2015-10-23 12:18:39 -05:00
|
|
|
tagRouter.route('/edit?').get(function redirect(req, res) {
|
|
|
|
res.redirect(subdir + '/ghost/settings/tags/' + req.params.slug + '/');
|
|
|
|
});
|
2015-12-10 10:00:02 -05:00
|
|
|
tagRouter.param('page', handlePageParam);
|
2015-05-26 08:01:52 -05:00
|
|
|
tagRouter.use(rssRouter);
|
2014-07-20 11:32:14 -05:00
|
|
|
|
|
|
|
// Authors
|
2015-05-26 08:01:52 -05:00
|
|
|
authorRouter.route('/').get(frontend.author);
|
2015-09-23 08:33:09 -05:00
|
|
|
authorRouter.route('/edit?').get(function redirect(req, res) {
|
|
|
|
res.redirect(subdir + '/ghost/team/' + req.params.slug + '/');
|
|
|
|
});
|
2015-05-26 08:01:52 -05:00
|
|
|
authorRouter.route('/' + routeKeywords.page + '/:page/').get(frontend.author);
|
2015-12-10 10:00:02 -05:00
|
|
|
authorRouter.param('page', handlePageParam);
|
2015-05-26 08:01:52 -05:00
|
|
|
authorRouter.use(rssRouter);
|
|
|
|
|
|
|
|
// Mount the Routers
|
|
|
|
router.use('/' + routeKeywords.private + '/', privateRouter);
|
|
|
|
router.use('/' + routeKeywords.author + '/:slug/', authorRouter);
|
|
|
|
router.use('/' + routeKeywords.tag + '/:slug/', tagRouter);
|
|
|
|
router.use('/', indexRouter);
|
2015-04-16 14:40:32 -05:00
|
|
|
|
|
|
|
// Post Live Preview
|
|
|
|
router.get('/' + routeKeywords.preview + '/:uuid', frontend.preview);
|
2014-07-20 11:32:14 -05:00
|
|
|
|
|
|
|
// Default
|
2014-04-11 22:46:15 -05:00
|
|
|
router.get('*', frontend.single);
|
|
|
|
|
|
|
|
return router;
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 07:41:19 -05:00
|
|
|
};
|
2014-03-23 16:49:43 -05:00
|
|
|
|
2014-09-09 23:06:24 -05:00
|
|
|
module.exports = frontendRoutes;
|