2013-11-12 00:27:12 -05:00
|
|
|
var admin = require('../controllers/admin'),
|
2013-12-09 23:41:58 -05:00
|
|
|
config = require('../config'),
|
2014-03-23 21:49:43 +00:00
|
|
|
middleware = require('../middleware').middleware,
|
|
|
|
|
|
|
|
ONE_HOUR_S = 60 * 60,
|
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 13:41:19 +01:00
|
|
|
ONE_YEAR_S = 365 * 24 * ONE_HOUR_S,
|
2013-11-12 00:27:12 -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 13:41:19 +01:00
|
|
|
adminRoutes;
|
|
|
|
|
|
|
|
adminRoutes = function (server) {
|
2014-03-09 23:44:08 -04:00
|
|
|
// Have ember route look for hits first
|
|
|
|
// to prevent conflicts with pre-existing routes
|
|
|
|
server.get('/ghost/ember/*', admin.index);
|
|
|
|
|
2014-01-05 01:40:53 -05:00
|
|
|
var subdir = config().paths.subdir;
|
2013-11-12 00:27:12 -05:00
|
|
|
// ### Admin routes
|
2013-11-26 10:38:54 +01:00
|
|
|
server.get('/logout/', function redirect(req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2014-03-23 21:49:43 +00:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + ONE_YEAR_S});
|
2013-12-28 16:01:08 +00:00
|
|
|
res.redirect(301, subdir + '/ghost/signout/');
|
2013-11-26 10:38:54 +01:00
|
|
|
});
|
|
|
|
server.get('/signout/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2014-03-23 21:49:43 +00:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + ONE_YEAR_S});
|
2013-12-28 16:01:08 +00:00
|
|
|
res.redirect(301, subdir + '/ghost/signout/');
|
2013-11-26 10:38:54 +01:00
|
|
|
});
|
|
|
|
server.get('/signin/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2014-03-23 21:49:43 +00:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + ONE_YEAR_S});
|
2013-12-28 16:01:08 +00:00
|
|
|
res.redirect(301, subdir + '/ghost/signin/');
|
2013-11-26 10:38:54 +01:00
|
|
|
});
|
|
|
|
server.get('/signup/', function redirect(req, res) {
|
|
|
|
/*jslint unparam:true*/
|
2014-03-23 21:49:43 +00:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + ONE_YEAR_S});
|
2013-12-28 16:01:08 +00:00
|
|
|
res.redirect(301, subdir + '/ghost/signup/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2013-11-26 10:38:54 +01:00
|
|
|
|
2014-02-25 10:51:12 +00:00
|
|
|
server.get('/ghost/signout/', admin.signout);
|
2014-06-01 15:30:50 -04:00
|
|
|
server.post('/ghost/signout/', admin.doSignout);
|
2014-02-25 10:51:12 +00:00
|
|
|
server.get('/ghost/signin/', middleware.redirectToSignup, middleware.redirectToDashboard, admin.signin);
|
|
|
|
server.post('/ghost/signin/', admin.doSignin);
|
2013-11-12 00:27:12 -05:00
|
|
|
server.get('/ghost/signup/', middleware.redirectToDashboard, admin.signup);
|
2014-02-25 10:51:12 +00:00
|
|
|
server.post('/ghost/signup/', admin.doSignup);
|
2013-11-12 00:27:12 -05:00
|
|
|
server.get('/ghost/forgotten/', middleware.redirectToDashboard, admin.forgotten);
|
2014-02-25 10:51:12 +00:00
|
|
|
server.post('/ghost/forgotten/', admin.doForgotten);
|
2013-11-21 21:17:38 -06:00
|
|
|
server.get('/ghost/reset/:token', admin.reset);
|
2014-02-25 10:51:12 +00:00
|
|
|
server.post('/ghost/reset/:token', admin.doReset);
|
|
|
|
server.post('/ghost/changepw/', admin.doChangePassword);
|
2013-11-12 00:27:12 -05:00
|
|
|
|
2014-05-01 01:50:24 +00:00
|
|
|
server.get('/ghost/editor/:id/:action', admin.editor);
|
|
|
|
server.get('/ghost/editor/:id/', admin.editor);
|
2014-02-14 11:00:11 +01:00
|
|
|
server.get('/ghost/editor/', admin.editor);
|
|
|
|
server.get('/ghost/content/', admin.content);
|
|
|
|
server.get('/ghost/settings*', admin.settings);
|
|
|
|
server.get('/ghost/debug/', admin.debug.index);
|
|
|
|
|
2014-02-27 16:48:38 +01:00
|
|
|
server.get('/ghost/export/', admin.debug.exportContent);
|
|
|
|
|
2014-02-25 10:51:12 +00:00
|
|
|
server.post('/ghost/upload/', middleware.busboy, admin.upload);
|
2013-11-12 00:27:12 -05:00
|
|
|
|
|
|
|
// redirect to /ghost and let that do the authentication to prevent redirects to /ghost//admin etc.
|
2013-11-17 18:40:26 +00: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 16:01:08 +00:00
|
|
|
res.redirect(subdir + '/ghost/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2014-02-19 15:56:06 -07:00
|
|
|
server.get(/\/ghost$/, function (req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2013-12-28 16:01:08 +00:00
|
|
|
res.redirect(subdir + '/ghost/');
|
2013-11-12 00:27:12 -05:00
|
|
|
});
|
2014-02-26 23:15:31 +00:00
|
|
|
server.get('/ghost/', admin.indexold);
|
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 13:41:19 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = adminRoutes;
|