Files
crs-app-real/index.js
2021-07-13 17:15:12 +09:00

54 lines
1.5 KiB
JavaScript

const express = require("express")
, expressLogging = require("express-logging")
, logger = require("logops")
, HttpStatus = require('http-status-codes')
, port = 32102
, productController = require('./src/controller/ProductController')
, controllers = {};
process.env["NODE_TLS_REJECT_UNAUTHORIZED"] = 0;
/**
* Express web server starting
*
*/
logger.getContext = function getContext() {
return {
app: 'Extracter'
};
}
var app = express();
app.use(express.json());
app.use(expressLogging(logger));
app.use((req, res, next) => {
logger.debug(Object.assign(req.body, req.query, req.params), 'Request params')
next()
})
app.listen(port, () => {
logger.info('Startup');
});
/**
* Request handlers
*
*/
app.all('*', (req, res, next) => {
let urlSegments = req.url.split('/');
req.params.service = urlSegments[1]
req.params.what = urlSegments.length > 2 ? urlSegments[2] : ''
req.params.args = urlSegments.length > 3 ? urlSegments.slice(3) : []
if(!controllers.hasOwnProperty(req.params.service)) {
let controller = req.params.service.charAt(0).toUpperCase() + req.params.service.slice(1) + 'Controller';
controllers[req.params.service] = productController
logger.info('%s has been loaded', controller)
}
controllers[req.params.service][req.params.service](req, result => {
let body = { code: HttpStatus.OK, message: HttpStatus.getStatusText(HttpStatus.OK), data: result }
if(result.code) body = result
res.json(body)
})
})