app.js 2.28 KB
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = startApp;

var _express = _interopRequireDefault(require("express"));

var _cors = _interopRequireDefault(require("cors"));

var _bodyParser = _interopRequireDefault(require("body-parser"));

var _logger = _interopRequireDefault(require("../utils/logger/logger"));

var _app_config = _interopRequireDefault(require("../config/app_config"));

var _v = _interopRequireDefault(require("uuid/v4"));

var _responseTime = _interopRequireDefault(require("response-time"));

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

var app = (0, _express.default)();
var TAG = "[Application] ";
app.use((0, _cors.default)());
app.use(_bodyParser.default.json({
  limit: '50mb'
}));
app.use(function (req, res, next) {
  req.headers.__reqId = "[" + (0, _v.default)() + "] ";
  req.specialType = "request";
  req.startTime = new Date().getTime(); // stamp time start inservice

  _logger.default.info(req, "".concat(TAG, "Call \"").concat(req.originalUrl, "\""));

  _logger.default.info(req, "".concat(TAG, ":: Request Header :: ").concat(JSON.stringify(req.headers)));

  _logger.default.info(req, "".concat(TAG, ":: Request Data :: ").concat(JSON.stringify(req.body)));

  next();
});
app.use((0, _responseTime.default)(function (req, res, time) {
  var totalTimeInService = time;

  if (totalTimeInService > 100) {
    _logger.default.warning(req, TAG + "Total time in service [over 100ms] : ", Math.round(totalTimeInService), " ms");
  } else {
    _logger.default.info(req, TAG + "Total time in service : ", Math.round(totalTimeInService), " ms");
  }
}));
/**
 * Show App Detail
 */

app.all("/app/version", function (req, res) {
  res.send({
    appName: _app_config.default.appName,
    description: _app_config.default.description,
    version: _app_config.default.version
  });
});

function startApp() {
  var server = app.listen(_app_config.default.systemConfig.APP_START_PORT, function () {
    _logger.default.info("".concat(TAG, "Starting ").concat(_app_config.default.appName, " (Version ").concat(_app_config.default.version, ") , Listening on port ").concat(_app_config.default.systemConfig.APP_START_PORT, " !"));
  }); // Set timeout for server

  server.setTimeout(1000 * 60 * 30);
}