mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-11-04 09:25:15 +00:00 
			
		
		
		
	- /schema now returns full openapi/swagger schema - That schema is used to validate incoming requests - And used as a contract in future integration tests - Moved route files up one level - Fixed incorrect 404 reponses when getting objects - Fixed saving new objects and passing jsonschemavalidation
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
const express     = require('express');
 | 
						|
const bodyParser  = require('body-parser');
 | 
						|
const fileUpload  = require('express-fileupload');
 | 
						|
const compression = require('compression');
 | 
						|
const config      = require('./lib/config');
 | 
						|
const log         = require('./logger').express;
 | 
						|
 | 
						|
/**
 | 
						|
 * App
 | 
						|
 */
 | 
						|
const app = express();
 | 
						|
app.use(fileUpload());
 | 
						|
app.use(bodyParser.json());
 | 
						|
app.use(bodyParser.urlencoded({extended: true}));
 | 
						|
 | 
						|
// Gzip
 | 
						|
app.use(compression());
 | 
						|
 | 
						|
/**
 | 
						|
 * General Logging, BEFORE routes
 | 
						|
 */
 | 
						|
 | 
						|
app.disable('x-powered-by');
 | 
						|
app.enable('trust proxy', ['loopback', 'linklocal', 'uniquelocal']);
 | 
						|
app.enable('strict routing');
 | 
						|
 | 
						|
// pretty print JSON when not live
 | 
						|
if (config.debug()) {
 | 
						|
	app.set('json spaces', 2);
 | 
						|
}
 | 
						|
 | 
						|
// CORS for everything
 | 
						|
app.use(require('./lib/express/cors'));
 | 
						|
 | 
						|
// General security/cache related headers + server header
 | 
						|
app.use(function (req, res, next) {
 | 
						|
	let x_frame_options = 'DENY';
 | 
						|
 | 
						|
	if (typeof process.env.X_FRAME_OPTIONS !== 'undefined' && process.env.X_FRAME_OPTIONS) {
 | 
						|
		x_frame_options = process.env.X_FRAME_OPTIONS;
 | 
						|
	}
 | 
						|
 | 
						|
	res.set({
 | 
						|
		'X-XSS-Protection':       '1; mode=block',
 | 
						|
		'X-Content-Type-Options': 'nosniff',
 | 
						|
		'X-Frame-Options':        x_frame_options,
 | 
						|
		'Cache-Control':          'no-cache, no-store, max-age=0, must-revalidate',
 | 
						|
		Pragma:                   'no-cache',
 | 
						|
		Expires:                  0
 | 
						|
	});
 | 
						|
	next();
 | 
						|
});
 | 
						|
 | 
						|
app.use(require('./lib/express/jwt')());
 | 
						|
app.use('/', require('./routes/main'));
 | 
						|
 | 
						|
// production error handler
 | 
						|
// no stacktraces leaked to user
 | 
						|
// eslint-disable-next-line
 | 
						|
app.use(function (err, req, res, next) {
 | 
						|
 | 
						|
	let payload = {
 | 
						|
		error: {
 | 
						|
			code:    err.status,
 | 
						|
			message: err.public ? err.message : 'Internal Error'
 | 
						|
		}
 | 
						|
	};
 | 
						|
 | 
						|
	if (config.debug() || (req.baseUrl + req.path).includes('nginx/certificates')) {
 | 
						|
		payload.debug = {
 | 
						|
			stack:    typeof err.stack !== 'undefined' && err.stack ? err.stack.split('\n') : null,
 | 
						|
			previous: err.previous
 | 
						|
		};
 | 
						|
	}
 | 
						|
 | 
						|
	// Not every error is worth logging - but this is good for now until it gets annoying.
 | 
						|
	if (typeof err.stack !== 'undefined' && err.stack) {
 | 
						|
		if (config.debug()) {
 | 
						|
			log.debug(err.stack);
 | 
						|
		} else if (typeof err.public == 'undefined' || !err.public) {
 | 
						|
			log.warn(err.message);
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	res
 | 
						|
		.status(err.status || 500)
 | 
						|
		.send(payload);
 | 
						|
});
 | 
						|
 | 
						|
module.exports = app;
 |