2014-03-02 14:45:57 -05:00
|
|
|
"use strict";
|
|
|
|
|
|
2014-03-02 14:16:16 -05:00
|
|
|
var nconf = require('nconf'),
|
2014-07-02 16:08:21 -04:00
|
|
|
path = require('path'),
|
2016-02-02 11:42:24 -05:00
|
|
|
async = require('async'),
|
2014-07-02 14:59:48 -04:00
|
|
|
winston = require('winston'),
|
2014-11-14 12:17:24 -05:00
|
|
|
controllers = require('../controllers'),
|
|
|
|
|
plugins = require('../plugins'),
|
2014-07-02 14:07:08 -04:00
|
|
|
express = require('express'),
|
2015-12-09 21:18:56 +02:00
|
|
|
validator = require('validator'),
|
2014-03-06 14:09:10 -05:00
|
|
|
|
2015-09-25 01:52:41 -04:00
|
|
|
accountRoutes = require('./accounts'),
|
|
|
|
|
|
2014-03-05 17:06:24 -05:00
|
|
|
metaRoutes = require('./meta'),
|
|
|
|
|
apiRoutes = require('./api'),
|
|
|
|
|
adminRoutes = require('./admin'),
|
|
|
|
|
feedRoutes = require('./feeds'),
|
2014-03-17 14:18:58 -04:00
|
|
|
pluginRoutes = require('./plugins'),
|
2015-03-02 14:01:18 -05:00
|
|
|
authRoutes = require('./authentication'),
|
|
|
|
|
helpers = require('./helpers');
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2015-03-02 14:01:18 -05:00
|
|
|
var setupPageRoute = helpers.setupPageRoute;
|
2014-03-12 16:07:54 -04:00
|
|
|
|
2014-03-11 18:09:56 -04:00
|
|
|
function mainRoutes(app, middleware, controllers) {
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/', middleware, [], controllers.home);
|
2014-03-11 18:09:56 -04:00
|
|
|
|
2014-11-18 14:54:54 -05:00
|
|
|
var loginRegisterMiddleware = [middleware.redirectToAccountIfLoggedIn];
|
2014-03-10 21:54:30 -04:00
|
|
|
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/login', middleware, loginRegisterMiddleware, controllers.login);
|
|
|
|
|
setupPageRoute(app, '/register', middleware, loginRegisterMiddleware, controllers.register);
|
2016-01-21 11:58:58 +02:00
|
|
|
setupPageRoute(app, '/compose', middleware, [], controllers.compose);
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/confirm/:code', middleware, [], controllers.confirmEmail);
|
|
|
|
|
setupPageRoute(app, '/outgoing', middleware, [], controllers.outgoing);
|
2015-10-11 23:05:33 -04:00
|
|
|
setupPageRoute(app, '/search/:term?', middleware, [], controllers.search.search);
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/reset/:code?', middleware, [], controllers.reset);
|
2014-11-14 12:17:24 -05:00
|
|
|
setupPageRoute(app, '/tos', middleware, [], controllers.termsOfUse);
|
2014-03-12 16:07:54 -04:00
|
|
|
}
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2014-03-12 16:07:54 -04:00
|
|
|
function topicRoutes(app, middleware, controllers) {
|
2014-12-11 22:55:00 -05:00
|
|
|
setupPageRoute(app, '/topic/:topic_id/:slug/:post_index?', middleware, [], controllers.topics.get);
|
2015-04-08 21:16:06 -04:00
|
|
|
setupPageRoute(app, '/topic/:topic_id/:slug?', middleware, [], controllers.topics.get);
|
2014-03-12 16:07:54 -04:00
|
|
|
}
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2014-05-21 16:13:46 -04:00
|
|
|
function tagRoutes(app, middleware, controllers) {
|
2015-04-16 14:31:49 -04:00
|
|
|
setupPageRoute(app, '/tags/:tag', middleware, [middleware.privateTagListing], controllers.tags.getTag);
|
|
|
|
|
setupPageRoute(app, '/tags', middleware, [middleware.privateTagListing], controllers.tags.getTags);
|
2014-05-21 16:13:46 -04:00
|
|
|
}
|
|
|
|
|
|
2014-03-12 16:07:54 -04:00
|
|
|
function categoryRoutes(app, middleware, controllers) {
|
2015-02-13 18:16:36 -05:00
|
|
|
setupPageRoute(app, '/categories', middleware, [], controllers.categories.list);
|
2015-08-17 16:38:05 -04:00
|
|
|
setupPageRoute(app, '/popular/:term?', middleware, [], controllers.popular.get);
|
|
|
|
|
setupPageRoute(app, '/recent', middleware, [], controllers.recent.get);
|
|
|
|
|
setupPageRoute(app, '/unread', middleware, [middleware.authenticate], controllers.unread.get);
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2016-01-06 12:49:14 +02:00
|
|
|
setupPageRoute(app, '/category/:category_id/:slug/:topic_index', middleware, [], controllers.category.get);
|
|
|
|
|
setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.category.get);
|
2014-03-12 16:07:54 -04:00
|
|
|
}
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2014-03-12 16:07:54 -04:00
|
|
|
function userRoutes(app, middleware, controllers) {
|
2014-09-22 21:38:56 -04:00
|
|
|
var middlewares = [middleware.checkGlobalPrivacySettings];
|
2014-03-03 12:30:27 -05:00
|
|
|
|
2015-09-16 14:45:39 -04:00
|
|
|
setupPageRoute(app, '/users', middleware, middlewares, controllers.users.getUsersSortedByJoinDate);
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/users/online', middleware, middlewares, controllers.users.getOnlineUsers);
|
|
|
|
|
setupPageRoute(app, '/users/sort-posts', middleware, middlewares, controllers.users.getUsersSortedByPosts);
|
|
|
|
|
setupPageRoute(app, '/users/sort-reputation', middleware, middlewares, controllers.users.getUsersSortedByReputation);
|
2016-02-03 15:17:42 +02:00
|
|
|
setupPageRoute(app, '/users/banned', middleware, middlewares, controllers.users.getBannedUsers);
|
2016-01-14 11:25:07 +02:00
|
|
|
}
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2015-07-14 17:03:28 -04:00
|
|
|
|
2014-09-22 21:38:56 -04:00
|
|
|
function groupRoutes(app, middleware, controllers) {
|
2015-02-23 14:54:48 -05:00
|
|
|
var middlewares = [middleware.checkGlobalPrivacySettings, middleware.exposeGroupName];
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2014-09-22 21:38:56 -04:00
|
|
|
setupPageRoute(app, '/groups', middleware, middlewares, controllers.groups.list);
|
2015-01-18 17:18:53 -05:00
|
|
|
setupPageRoute(app, '/groups/:slug', middleware, middlewares, controllers.groups.details);
|
2015-01-29 13:37:45 -05:00
|
|
|
setupPageRoute(app, '/groups/:slug/members', middleware, middlewares, controllers.groups.members);
|
2014-03-11 18:09:56 -04:00
|
|
|
}
|
2014-03-01 17:35:47 -05:00
|
|
|
|
2014-03-11 18:09:56 -04:00
|
|
|
module.exports = function(app, middleware) {
|
2014-08-24 12:30:49 -04:00
|
|
|
var router = express.Router(),
|
|
|
|
|
pluginRouter = express.Router(),
|
2014-09-19 22:53:57 -04:00
|
|
|
authRouter = express.Router(),
|
2015-09-14 15:29:26 -04:00
|
|
|
relativePath = nconf.get('relative_path'),
|
|
|
|
|
ensureLoggedIn = require('connect-ensure-login');
|
2014-08-24 12:30:49 -04:00
|
|
|
|
|
|
|
|
pluginRouter.render = function() {
|
|
|
|
|
app.render.apply(app, arguments);
|
|
|
|
|
};
|
2015-10-27 05:25:14 -04:00
|
|
|
controllers.render = function() {
|
|
|
|
|
app.render.apply(app, arguments);
|
|
|
|
|
};
|
2014-09-19 22:53:57 -04:00
|
|
|
|
|
|
|
|
// Set-up for hotswapping (when NodeBB reloads)
|
2014-08-24 12:30:49 -04:00
|
|
|
pluginRouter.hotswapId = 'plugins';
|
2014-09-19 22:53:57 -04:00
|
|
|
authRouter.hotswapId = 'auth';
|
2014-08-24 12:30:49 -04:00
|
|
|
|
2014-09-22 20:31:57 -04:00
|
|
|
app.use(middleware.maintenanceMode);
|
|
|
|
|
|
2015-09-14 15:29:26 -04:00
|
|
|
app.all(relativePath + '(/api|/api/*?)', middleware.prepareAPI);
|
|
|
|
|
app.all(relativePath + '(/api/admin|/api/admin/*?)', middleware.isAdmin);
|
|
|
|
|
app.all(relativePath + '(/admin|/admin/*?)', ensureLoggedIn.ensureLoggedIn(nconf.get('relative_path') + '/login?local=1'), middleware.applyCSRF, middleware.isAdmin);
|
2014-08-24 12:30:49 -04:00
|
|
|
|
|
|
|
|
adminRoutes(router, middleware, controllers);
|
|
|
|
|
metaRoutes(router, middleware, controllers);
|
|
|
|
|
apiRoutes(router, middleware, controllers);
|
|
|
|
|
feedRoutes(router, middleware, controllers);
|
|
|
|
|
pluginRoutes(router, middleware, controllers);
|
|
|
|
|
|
2014-09-22 21:38:56 -04:00
|
|
|
mainRoutes(router, middleware, controllers);
|
|
|
|
|
topicRoutes(router, middleware, controllers);
|
|
|
|
|
tagRoutes(router, middleware, controllers);
|
|
|
|
|
categoryRoutes(router, middleware, controllers);
|
|
|
|
|
accountRoutes(router, middleware, controllers);
|
|
|
|
|
userRoutes(router, middleware, controllers);
|
|
|
|
|
groupRoutes(router, middleware, controllers);
|
2014-09-16 09:32:42 -04:00
|
|
|
|
2014-08-24 12:30:49 -04:00
|
|
|
app.use(relativePath, pluginRouter);
|
2014-12-28 23:01:30 -05:00
|
|
|
app.use(relativePath, router);
|
2014-09-19 22:53:57 -04:00
|
|
|
app.use(relativePath, authRouter);
|
2014-09-20 18:07:46 -04:00
|
|
|
|
2014-07-02 14:07:08 -04:00
|
|
|
if (process.env.NODE_ENV === 'development') {
|
2014-07-02 15:44:09 -04:00
|
|
|
require('./debug')(app, middleware, controllers);
|
2014-07-02 14:07:08 -04:00
|
|
|
}
|
2014-09-22 21:38:56 -04:00
|
|
|
|
2015-10-12 02:18:23 -04:00
|
|
|
app.use(middleware.privateUploads);
|
2014-10-26 17:04:55 -04:00
|
|
|
|
2014-09-22 21:38:56 -04:00
|
|
|
app.use(relativePath, express.static(path.join(__dirname, '../../', 'public'), {
|
|
|
|
|
maxAge: app.enabled('cache') ? 5184000000 : 0
|
|
|
|
|
}));
|
|
|
|
|
|
2014-12-01 20:28:36 -05:00
|
|
|
handle404(app, middleware);
|
|
|
|
|
handleErrors(app, middleware);
|
|
|
|
|
|
2014-08-24 12:30:49 -04:00
|
|
|
|
|
|
|
|
// Add plugin routes
|
2016-02-02 11:42:24 -05:00
|
|
|
async.series([
|
|
|
|
|
async.apply(plugins.reloadRoutes),
|
|
|
|
|
async.apply(authRoutes.reloadRoutes)
|
|
|
|
|
]);
|
2014-04-10 20:31:57 +01:00
|
|
|
};
|
2014-07-02 14:07:08 -04:00
|
|
|
|
2014-12-01 20:28:36 -05:00
|
|
|
function handle404(app, middleware) {
|
2015-10-20 17:39:30 -04:00
|
|
|
var relativePath = nconf.get('relative_path');
|
|
|
|
|
var isLanguage = new RegExp('^' + relativePath + '/language/[\\w]{2,}/.*.json'),
|
|
|
|
|
isClientScript = new RegExp('^' + relativePath + '\\/src\\/.+\\.js');
|
|
|
|
|
|
|
|
|
|
app.use(function(req, res) {
|
2015-03-14 01:05:03 -04:00
|
|
|
if (plugins.hasListeners('action:meta.override404')) {
|
|
|
|
|
return plugins.fireHook('action:meta.override404', {
|
2015-03-06 13:40:35 -05:00
|
|
|
req: req,
|
|
|
|
|
res: res,
|
|
|
|
|
error: {}
|
|
|
|
|
});
|
2014-12-01 20:28:36 -05:00
|
|
|
}
|
2015-03-14 01:05:03 -04:00
|
|
|
|
|
|
|
|
if (isClientScript.test(req.url)) {
|
|
|
|
|
res.type('text/javascript').status(200).send('');
|
|
|
|
|
} else if (isLanguage.test(req.url)) {
|
|
|
|
|
res.status(200).json({});
|
2015-10-20 17:39:30 -04:00
|
|
|
} else if (req.path.startsWith(relativePath + '/uploads')) {
|
|
|
|
|
res.status(404).send('');
|
2015-10-23 13:52:42 -04:00
|
|
|
} else if (req.path === '/favicon.ico') {
|
|
|
|
|
res.status(404).send('');
|
2015-03-14 01:05:03 -04:00
|
|
|
} else if (req.accepts('html')) {
|
|
|
|
|
if (process.env.NODE_ENV === 'development') {
|
|
|
|
|
winston.warn('Route requested but not found: ' + req.url);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.status(404);
|
|
|
|
|
|
|
|
|
|
if (res.locals.isAPI) {
|
2015-08-27 23:14:31 -04:00
|
|
|
return res.json({path: req.path.replace(/^\/api/, ''), title: '[[global:404.title]]'});
|
2015-03-14 01:05:03 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
middleware.buildHeader(req, res, function() {
|
2015-08-27 16:30:43 -04:00
|
|
|
res.render('404', {path: req.path, title: '[[global:404.title]]'});
|
2015-03-14 01:05:03 -04:00
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.status(404).type('txt').send('Not found');
|
|
|
|
|
}
|
2014-12-01 20:28:36 -05:00
|
|
|
});
|
2014-07-02 14:07:08 -04:00
|
|
|
}
|
|
|
|
|
|
2014-12-01 20:28:36 -05:00
|
|
|
function handleErrors(app, middleware) {
|
2015-10-27 05:25:14 -04:00
|
|
|
app.use(function(err, req, res, next) {
|
2014-12-01 20:28:36 -05:00
|
|
|
if (err.code === 'EBADCSRFTOKEN') {
|
2015-05-21 16:24:40 -04:00
|
|
|
winston.error(req.path + '\n', err.message);
|
2014-12-01 20:28:36 -05:00
|
|
|
return res.sendStatus(403);
|
2014-07-02 14:07:08 -04:00
|
|
|
}
|
|
|
|
|
|
2015-01-10 14:50:28 -05:00
|
|
|
if (parseInt(err.status, 10) === 302 && err.path) {
|
2015-03-09 18:22:44 -04:00
|
|
|
return res.locals.isAPI ? res.status(302).json(err.path) : res.redirect(err.path);
|
2015-01-10 14:50:28 -05:00
|
|
|
}
|
|
|
|
|
|
2015-09-11 22:51:25 -04:00
|
|
|
winston.error(req.path + '\n', err.stack);
|
|
|
|
|
|
2014-12-01 20:28:36 -05:00
|
|
|
res.status(err.status || 500);
|
2014-07-02 14:07:08 -04:00
|
|
|
|
2014-12-01 20:28:36 -05:00
|
|
|
if (res.locals.isAPI) {
|
2015-10-27 05:25:14 -04:00
|
|
|
res.json({path: req.path, error: err.message});
|
2014-12-01 20:28:36 -05:00
|
|
|
} else {
|
|
|
|
|
middleware.buildHeader(req, res, function() {
|
2015-12-09 21:18:56 +02:00
|
|
|
res.render('500', {path: req.path, error: validator.escape(err.message)});
|
2014-12-01 20:28:36 -05:00
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
2014-08-18 13:44:27 -04:00
|
|
|
}
|
2014-12-01 20:28:36 -05:00
|
|
|
|