Доравботки маршрутизации
This commit is contained in:
@@ -25,7 +25,7 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: '2',
|
name: '2',
|
||||||
mode: 'omnireader', //none, normal, site, reader, omnireader
|
mode: 'omnireader',
|
||||||
ip: '0.0.0.0',
|
ip: '0.0.0.0',
|
||||||
port: '33081',
|
port: '33081',
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ const log = getLog();
|
|||||||
|
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
const compression = require('compression');
|
const compression = require('compression');
|
||||||
const app = express();
|
|
||||||
|
|
||||||
const SqliteConnectionPool = require('./core/SqliteConnectionPool');
|
const SqliteConnectionPool = require('./core/SqliteConnectionPool');
|
||||||
|
|
||||||
@@ -16,6 +15,12 @@ async function main() {
|
|||||||
log('Opening database');
|
log('Opening database');
|
||||||
await connPool.init();
|
await connPool.init();
|
||||||
|
|
||||||
|
//servers
|
||||||
|
for (let server of config.servers) {
|
||||||
|
if (server.mode !== 'none') {
|
||||||
|
const app = express();
|
||||||
|
app.serverConfig = server;
|
||||||
|
|
||||||
let devModule = undefined;
|
let devModule = undefined;
|
||||||
if (config.branch == 'development') {
|
if (config.branch == 'development') {
|
||||||
const devFileName = './dev.js'; //ignored by pkg -50Mb executable size
|
const devFileName = './dev.js'; //ignored by pkg -50Mb executable size
|
||||||
@@ -40,9 +45,6 @@ async function main() {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
//servers
|
|
||||||
for (let server of config.servers) {
|
|
||||||
if (server.mode !== 'none') {
|
|
||||||
app.listen(server.port, server.ip, function() {
|
app.listen(server.port, server.ip, function() {
|
||||||
log(`Server-${server.name} is ready on ${server.ip}:${server.port}, mode: ${server.mode}`);
|
log(`Server-${server.name} is ready on ${server.ip}:${server.port}, mode: ${server.mode}`);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -3,16 +3,26 @@ const c = require('./controllers');
|
|||||||
function initRoutes(app, connPool, config) {
|
function initRoutes(app, connPool, config) {
|
||||||
const misc = new c.MiscController(connPool, config);
|
const misc = new c.MiscController(connPool, config);
|
||||||
|
|
||||||
|
//access
|
||||||
|
const serverMode = app.serverConfig.mode;
|
||||||
|
const [all, normal, site, reader, omnireader] = // eslint-disable-line no-unused-vars
|
||||||
|
[serverMode, 'normal', 'site', 'reader', 'omnireader'];
|
||||||
|
|
||||||
|
//routes
|
||||||
const routes = [
|
const routes = [
|
||||||
['POST', '/api/config', misc, 'getConfig', {}],
|
['POST', '/api/config', misc.getConfig.bind(misc), [all], {}],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
//to app
|
||||||
for (let route of routes) {
|
for (let route of routes) {
|
||||||
const [httpMethod, path, controller, handler, options] = route;
|
let [httpMethod, path, controller, access, options] = route;
|
||||||
|
access = new Set(access);
|
||||||
|
|
||||||
const callback = async function(req, res) {
|
let callback = () => {};
|
||||||
|
if (access.has(serverMode)) {//allowed
|
||||||
|
callback = async function(req, res) {
|
||||||
try {
|
try {
|
||||||
const result = await controller[handler](req, res, options);
|
const result = await controller(req, res, options);
|
||||||
|
|
||||||
if (result !== false)
|
if (result !== false)
|
||||||
res.send(result);
|
res.send(result);
|
||||||
@@ -20,6 +30,11 @@ function initRoutes(app, connPool, config) {
|
|||||||
res.status(500).send({error: e.message});
|
res.status(500).send({error: e.message});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
} else {//forbidden
|
||||||
|
callback = async function(req, res) {
|
||||||
|
res.status(403);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
switch (httpMethod) {
|
switch (httpMethod) {
|
||||||
case 'GET' :
|
case 'GET' :
|
||||||
|
|||||||
Reference in New Issue
Block a user