mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
0e13ef8767
* 🎨 rotation config - every parameter is configureable - increase default number of files to 100 * 🎨 ghost.log location - example: content/logs/http___my_ghost_blog_com_ghost.log - user can change the path to something custom by setting logging.path * 🛠 add response-time as dependency * 🎨 readable PrettyStream - tidy up - generic handling (was important to support more use cases, for example: logging.info({ anyKey: anyValue })) - common log format - less code 🕵🏻 * 🎨 GhostLogger cleanup - remove setLoggers -> this function had too much of redundant code - instead: add smart this.log function - remove logging.request (---> GhostLogger just forwards the values, it doesn't matter if that is a request or not a request) - make .warn .debug .info .error small and smart * 🎨 app.js: add response time as middleware and remove logging.request * 🎨 setStdoutStream and setFileStream - redesign GhostLogger to add CustomLoggers very easily ----> Example CustomLogger function CustomLogger(options) { // Base iterates over defined transports // EXAMPLE: ['stdout', 'elasticsearch'] Base.call(this, options); } util.inherits(...); // OVERRIDE default stdout stream and your own!!! CustomLogger.prototype.setStdoutStream = function() {} // add a new stream // get's called automatically when transport elasticsearch is defined CustomLogger.prototype.setElasticsearchStream = function() {} * 🎨 log into multiple file by default - content/logs/domain.error.log --> contains only the errors - content/logs/domain.log --> contains everything - rotation for both files * 🔥 remove logging.debug and use npm debug only * ✨ shortcuts for mode and level * 🎨 jshint/jscs * 🎨 stdout as much as possible for an error * 🎨 fix tests * 🎨 remove req.ip from log output, remove response-time dependency * 🎨 create middleware for logging - added TODO to move logging middleware to ignition
75 lines
2 KiB
JavaScript
75 lines
2 KiB
JavaScript
var debug = require('debug')('ghost:app'),
|
|
express = require('express'),
|
|
|
|
// app requires
|
|
config = require('./config'),
|
|
|
|
// middleware
|
|
compress = require('compression'),
|
|
netjet = require('netjet'),
|
|
|
|
// local middleware
|
|
ghostLocals = require('./middleware/ghost-locals'),
|
|
logRequest = require('./middleware/log-request');
|
|
|
|
module.exports = function setupParentApp() {
|
|
debug('ParentApp setup start');
|
|
var parentApp = express();
|
|
|
|
// ## Global settings
|
|
|
|
// Make sure 'req.secure' is valid for proxied requests
|
|
// (X-Forwarded-Proto header will be checked, if present)
|
|
parentApp.enable('trust proxy');
|
|
|
|
parentApp.use(logRequest);
|
|
|
|
if (debug.enabled) {
|
|
// debug keeps a timer, so this is super useful
|
|
parentApp.use((function () {
|
|
var reqDebug = require('debug')('ghost:req');
|
|
return function debugLog(req, res, next) {
|
|
reqDebug('Request', req.originalUrl);
|
|
next();
|
|
};
|
|
})());
|
|
}
|
|
|
|
// enabled gzip compression by default
|
|
if (config.get('server').compress !== false) {
|
|
parentApp.use(compress());
|
|
}
|
|
|
|
// Preload link headers
|
|
if (config.get('preloadHeaders')) {
|
|
parentApp.use(netjet({
|
|
cache: {
|
|
max: config.get('preloadHeaders')
|
|
}
|
|
}));
|
|
}
|
|
|
|
// This sets global res.locals which are needed everywhere
|
|
parentApp.use(ghostLocals);
|
|
|
|
// @TODO where should this live?!
|
|
// Load helpers
|
|
require('./helpers').loadCoreHelpers();
|
|
debug('Helpers done');
|
|
|
|
// Mount the apps on the parentApp
|
|
// API
|
|
// @TODO: finish refactoring the API app
|
|
// @TODO: decide what to do with these paths - config defaults? config overrides?
|
|
parentApp.use('/ghost/api/v0.1/', require('./api/app')());
|
|
|
|
// ADMIN
|
|
parentApp.use('/ghost', require('./admin')());
|
|
|
|
// BLOG
|
|
parentApp.use(require('./blog')());
|
|
|
|
debug('ParentApp setup end');
|
|
|
|
return parentApp;
|
|
};
|