0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Moved API v0.1 settings upload/downalod routes.yaml methods to use setting handler service

This commit is contained in:
Nazar Gargol 2019-06-20 13:34:22 +02:00
parent 8709f5cc55
commit 06a6dc835d
2 changed files with 14 additions and 57 deletions

View file

@ -6,6 +6,17 @@ const urlService = require('../url');
const common = require('../../../server/lib/common'); const common = require('../../../server/lib/common');
const config = require('../../../server/config'); const config = require('../../../server/config');
/**
* The `routes.yaml` file offers a way to configure your Ghost blog. It's currently a setting feature
* we have added. That's why the `routes.yaml` file is treated as a "setting" right now.
* If we want to add single permissions for this file (e.g. upload/download routes.yaml), we can add later.
*
* How does it work?
*
* - we first reset all url generators (each url generator belongs to one express router)
* - we don't destroy the resources, we only release them (this avoids reloading all resources from the db again)
* - then we reload the whole site app, which will reset all routers and re-create the url generators
*/
const activate = (filePath) => { const activate = (filePath) => {
const settingsPath = config.getContentPath('settings'); const settingsPath = config.getContentPath('settings');
const backupRoutesPath = path.join(settingsPath, `routes-${moment().format('YYYY-MM-DD-HH-mm-ss')}.yaml`); const backupRoutesPath = path.join(settingsPath, `routes-${moment().format('YYYY-MM-DD-HH-mm-ss')}.yaml`);

View file

@ -2,14 +2,10 @@
// RESTful API for the Setting resource // RESTful API for the Setting resource
const Promise = require('bluebird'), const Promise = require('bluebird'),
_ = require('lodash'), _ = require('lodash'),
moment = require('moment-timezone'),
fs = require('fs-extra'),
path = require('path'),
config = require('../../config'),
models = require('../../models'), models = require('../../models'),
canThis = require('../../services/permissions').canThis, canThis = require('../../services/permissions').canThis,
localUtils = require('./utils'), localUtils = require('./utils'),
urlService = require('../../../frontend/services/url'), frontendRouting = require('../../../frontend/services/routing'),
common = require('../../lib/common'), common = require('../../lib/common'),
settingsCache = require('../../services/settings/cache'), settingsCache = require('../../services/settings/cache'),
docName = 'settings'; docName = 'settings';
@ -255,67 +251,17 @@ settings = {
}); });
}, },
/**
* The `routes.yaml` file offers a way to configure your Ghost blog. It's currently a setting feature
* we have added. That's why the `routes.yaml` file is treated as a "setting" right now.
* If we want to add single permissions for this file (e.g. upload/download routes.yaml), we can add later.
*
* How does it work?
*
* - we first reset all url generators (each url generator belongs to one express router)
* - we don't destroy the resources, we only release them (this avoids reloading all resources from the db again)
* - then we reload the whole site app, which will reset all routers and re-create the url generators
*/
upload(options) { upload(options) {
const backupRoutesPath = path.join(config.getContentPath('settings'), `routes-${moment().format('YYYY-MM-DD-HH-mm-ss')}.yaml`);
return localUtils.handlePermissions('settings', 'edit')(options) return localUtils.handlePermissions('settings', 'edit')(options)
.then(() => { .then(() => {
return fs.copy(`${config.getContentPath('settings')}/routes.yaml`, backupRoutesPath); return frontendRouting.settings.activate(options.path);
})
.then(() => {
return fs.copy(options.path, `${config.getContentPath('settings')}/routes.yaml`);
})
.then(() => {
urlService.resetGenerators({releaseResourcesOnly: true});
})
.then(() => {
const siteApp = require('../../web/site/app');
try {
return siteApp.reload();
} catch (err) {
// bring back backup, otherwise your Ghost blog is broken
return fs.copy(backupRoutesPath, `${config.getContentPath('settings')}/routes.yaml`)
.then(() => {
return siteApp.reload();
})
.then(() => {
throw err;
});
}
}); });
}, },
download(options) { download(options) {
const routesPath = path.join(config.getContentPath('settings'), 'routes.yaml');
return localUtils.handlePermissions('settings', 'browse')(options) return localUtils.handlePermissions('settings', 'browse')(options)
.then(() => { .then(() => {
return fs.readFile(routesPath, 'utf-8'); return frontendRouting.settings.serve();
})
.catch((err) => {
if (err.code === 'ENOENT') {
return Promise.resolve([]);
}
if (common.errors.utils.isIgnitionError(err)) {
throw err;
}
throw new common.errors.NotFoundError({
err: err
});
}); });
} }
}; };