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-04-11 23:46:15 -04:00
|
|
|
express = require('express'),
|
2014-07-28 15:19:49 +02:00
|
|
|
utils = require('../utils'),
|
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;
|
|
|
|
|
2014-04-11 23:46:15 -04:00
|
|
|
adminRoutes = function (middleware) {
|
|
|
|
var router = express.Router(),
|
2014-07-17 10:33:21 -04:00
|
|
|
subdir = config.paths.subdir;
|
2014-04-11 23:46:15 -04:00
|
|
|
|
2013-11-12 00:27:12 -05:00
|
|
|
// ### Admin routes
|
2014-07-14 13:29:45 +01:00
|
|
|
router.get(/^\/(logout|signout)\/$/, function redirect(req, res) {
|
2013-11-12 00:27:12 -05:00
|
|
|
/*jslint unparam:true*/
|
2014-07-28 15:19:49 +02:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + utils.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
|
|
|
});
|
2014-07-14 13:29:45 +01:00
|
|
|
router.get(/^\/signup\/$/, function redirect(req, res) {
|
2013-11-26 10:38:54 +01:00
|
|
|
/*jslint unparam:true*/
|
2014-07-28 15:19:49 +02:00
|
|
|
res.set({'Cache-Control': 'public, max-age=' + utils.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
|
|
|
|
2013-11-12 00:27:12 -05:00
|
|
|
// redirect to /ghost and let that do the authentication to prevent redirects to /ghost//admin etc.
|
2014-07-14 13:29:45 +01:00
|
|
|
router.get(/^\/((ghost-admin|admin|wp-admin|dashboard|signin|login)\/?)$/, 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-07-01 00:26:08 +01:00
|
|
|
|
2014-08-23 17:23:34 +01:00
|
|
|
router.get(/^\/ghost\//, middleware.redirectToSetup, admin.index);
|
2014-04-11 23:46:15 -04:00
|
|
|
|
|
|
|
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 13:41:19 +01:00
|
|
|
};
|
|
|
|
|
2014-09-10 00:06:24 -04:00
|
|
|
module.exports = adminRoutes;
|