2013-11-12 00:27:12 -05:00
|
|
|
var admin = require('../controllers/admin'),
|
2013-12-09 23:41:58 -05:00
|
|
|
config = require('../config'),
|
2013-12-30 02:03:29 -05:00
|
|
|
middleware = require('../middleware').middleware;
|
2013-11-12 00:27:12 -05:00
|
|
|
|
|
|
|
module.exports = function (server) {
|
2013-12-28 11:01:08 -05:00
|
|
|
var subdir = config.paths().subdir;
|
2013-11-12 00:27:12 -05:00
|
|
|
// ### Admin routes
|
|
|
|
/* TODO: put these somewhere in admin */
|
2013-11-26 04:38:54 -05:00
|
|
|
server.get('/logout/', function redirect(req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(301, subdir + '/ghost/signout/');
|
2013-11-26 04:38:54 -05:00
|
|
|
});
|
|
|
|
server.get('/signout/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(301, subdir + '/ghost/signout/');
|
2013-11-26 04:38:54 -05:00
|
|
|
});
|
|
|
|
server.get('/signin/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(301, subdir + '/ghost/signin/');
|
2013-11-26 04:38:54 -05:00
|
|
|
});
|
|
|
|
server.get('/signup/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(301, subdir + '/ghost/signup/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
|
|
|
server.get('/ghost/login/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(301, subdir + '/ghost/signin/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2013-11-26 04:38:54 -05:00
|
|
|
|
|
|
|
server.get('/ghost/signout/', admin.logout);
|
2013-12-06 09:13:15 -05:00
|
|
|
server.get('/ghost/signin/', middleware.redirectToSignup, middleware.redirectToDashboard, admin.login);
|
2013-11-12 00:27:12 -05:00
|
|
|
server.get('/ghost/signup/', middleware.redirectToDashboard, admin.signup);
|
|
|
|
server.get('/ghost/forgotten/', middleware.redirectToDashboard, admin.forgotten);
|
2013-11-21 22:17:38 -05:00
|
|
|
server.post('/ghost/forgotten/', admin.generateResetToken);
|
|
|
|
server.get('/ghost/reset/:token', admin.reset);
|
|
|
|
server.post('/ghost/reset/:token', admin.resetPassword);
|
2013-11-12 00:27:12 -05:00
|
|
|
server.post('/ghost/signin/', admin.auth);
|
|
|
|
server.post('/ghost/signup/', admin.doRegister);
|
|
|
|
server.post('/ghost/changepw/', middleware.auth, admin.changepw);
|
|
|
|
server.get('/ghost/editor(/:id)/', middleware.auth, admin.editor);
|
|
|
|
server.get('/ghost/editor/', middleware.auth, admin.editor);
|
|
|
|
server.get('/ghost/content/', middleware.auth, admin.content);
|
|
|
|
server.get('/ghost/settings*', middleware.auth, admin.settings);
|
|
|
|
server.get('/ghost/debug/', middleware.auth, admin.debug.index);
|
|
|
|
|
|
|
|
// We don't want to register bodyParser globally b/c of security concerns, so use multipart only here
|
|
|
|
server.post('/ghost/upload/', middleware.auth, admin.uploader);
|
|
|
|
|
|
|
|
// redirect to /ghost and let that do the authentication to prevent redirects to /ghost//admin etc.
|
2013-11-17 13:40:26 -05:00
|
|
|
server.get(/\/((ghost-admin|admin|wp-admin|dashboard|signin)\/?)$/, function (req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(subdir + '/ghost/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2013-11-17 13:40:26 -05:00
|
|
|
server.get(/\/(ghost$\/?)/, middleware.auth, function (req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2013-12-28 11:01:08 -05:00
|
|
|
res.redirect(subdir + '/ghost/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2013-12-06 09:13:15 -05:00
|
|
|
server.get('/ghost/', middleware.redirectToSignup, middleware.auth, admin.index);
|
2013-11-12 00:27:12 -05:00
|
|
|
};
|