@lskjs/server
Version:
LSK server.
669 lines (556 loc) • 47.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _get3 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _applyDecoratedDescriptor2 = _interopRequireDefault(require("@babel/runtime/helpers/applyDecoratedDescriptor"));
var _express = _interopRequireDefault(require("express"));
var _path2 = _interopRequireDefault(require("path"));
var _mapValues = _interopRequireDefault(require("lodash/mapValues"));
var _get4 = _interopRequireDefault(require("lodash/get"));
var _forEach = _interopRequireDefault(require("lodash/forEach"));
var _flattenDeep = _interopRequireDefault(require("lodash/flattenDeep"));
var _map = _interopRequireDefault(require("lodash/map"));
var _connectStaticFile = _interopRequireDefault(require("connect-static-file"));
var _apiquery = _interopRequireDefault(require("@lskjs/apiquery"));
var _autobind = _interopRequireDefault(require("@lskjs/utils/autobind"));
var _i = _interopRequireDefault(require("@lskjs/i18"));
var _server = _interopRequireDefault(require("@lskjs/db/server"));
var _e2 = _interopRequireDefault(require("@lskjs/utils/e"));
var _module = _interopRequireDefault(require("@lskjs/module"));
var _http = _interopRequireDefault(require("http"));
var _config = _interopRequireDefault(require("./config"));
var _ws = _interopRequireDefault(require("./ws"));
var _class, _temp;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
var DEBUG = __DEV__ && false;
var ServerApp = (_class = (_temp = /*#__PURE__*/function (_Module) {
(0, _inherits2["default"])(ServerApp, _Module);
var _super = _createSuper(ServerApp);
function ServerApp() {
var _this;
(0, _classCallCheck2["default"])(this, ServerApp);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
_this._module = 'app';
_this.name = 'App';
_this.i18 = new _i["default"]({
ctx: (0, _assertThisInitialized2["default"])(_this)
});
_this.getDocsRouter = require('./methods/getDocsRouter')["default"];
_this.getDocsTemplate = function () {
return 'deprecated';
};
_this.expressResolve = require('./methods/expressResolve')["default"];
_this.runRedis = require('./methods/runRedis')["default"];
_this.runRoutes = require('./methods/runRoutes')["default"];
return _this;
}
(0, _createClass2["default"])(ServerApp, [{
key: "init",
value: function () {
var _init = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var _this2 = this;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return (0, _get3["default"])((0, _getPrototypeOf2["default"])(ServerApp.prototype), "init", this).call(this);
case 2:
if (DEBUG) this.log.trace('ServerApp init');
this.express = this.createExpress(); // this.app = this.express; // Fallback
this.serverConfig = this.config.server || _config["default"];
this.httpServer = _http["default"].createServer(this.express);
if (this.serverConfig.express && Object.keys(this.serverConfig.express).length) {
this.log.trace('serverConfig.express:', this.serverConfig.express);
(0, _forEach["default"])(this.serverConfig.express || {}, function (value, key) {
_this2.express.set(key, value);
});
}
_context.next = 9;
return this.getDatabase();
case 9:
this.db = _context.sent;
this.responses = this.getResponses();
if (DEBUG) this.log.debug('responses', Object.keys(this.responses));
if (DEBUG) this.log.debug('serverConfig.middlewares', this.serverConfig.middlewares);
this.middlewares = this.getMiddlewares();
this.log.debug('middlewares', Object.keys(this.middlewares));
this.helpers = this.getHelpers();
if (DEBUG) this.log.debug('helpers', Object.keys(this.helpers));
this.statics = this._getStatics();
this.log.debug('statics', this.statics);
this.api = new _apiquery["default"]({
url: this.url('/'),
log: this.log
});
if (this.serverConfig.ws) this.initWs();
if (!this.i18) {
_context.next = 24;
break;
}
_context.next = 24;
return this.i18.setState({
log: this.log,
config: this.config.i18,
getLocale: this.getLocale
}).init();
case 24:
case "end":
return _context.stop();
}
}
}, _callee, this);
}));
function init() {
return _init.apply(this, arguments);
}
return init;
}()
}, {
key: "afterInit",
value: function () {
var _afterInit = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
// super.afterInit(...arguments);
this.models = this.getMongooseModels();
this.log.debug('models', Object.keys(this.models));
_context2.next = 4;
return this.runModels();
case 4:
case "end":
return _context2.stop();
}
}
}, _callee2, this);
}));
function afterInit() {
return _afterInit.apply(this, arguments);
}
return afterInit;
}()
}, {
key: "url",
value: function url(str) {
var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
var query = '';
if (params && Object.keys(params.length)) {
query = "?".concat((0, _map["default"])(params, function (val, key) {
return "".concat(key, "=").concat(val);
}).join('&'));
} // `http://127.0.0.1:${this.config.port || this.serverConfig.port}`,
return "".concat(this.config.url || this.serverConfig.url || '/').concat(str).concat(query);
}
}, {
key: "e",
value: function e() {
for (var _len2 = arguments.length, params = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
params[_key2] = arguments[_key2];
}
return _e2["default"].call.apply(_e2["default"], [this].concat(params));
} // emit(...args) {
// this.modules && this.modules.events && this.modules.events.emit(...args); // eslint-disable-line
// }
// on(...args) {
// this.modules && this.modules.events && this.modules.events.on(...args); // eslint-disable-line
// }
// once(...args) {
// this.modules && this.modules.events && this.modules.events.once(...args); // eslint-disable-line
// }
}, {
key: "getMiddlewares",
value: function getMiddlewares() {
return require('./middlewares')["default"](this); // eslint-disable-line
}
}, {
key: "getMongooseModels",
value: function getMongooseModels() {
var _this3 = this;
var models = this.getModels();
(0, _forEach["default"])(this.modules, function (mdl, moduleName) {
var models2 = {};
if (mdl.getModels) {
models2 = mdl.getModels();
} else if (mdl.models) {
models2 = mdl.models;
} // console.log('models2', Object.keys(models2));
(0, _forEach["default"])(models2, function (model, modelName) {
if (models[modelName]) {
_this3.log.error("ServerApp.getMongooseModels: CONFLICT modules/".concat(moduleName, "/").concat(modelName)); // eslint-disable-line no-console
return;
}
models[modelName] = models2[modelName];
});
});
return (0, _mapValues["default"])(models, function (model) {
if (model._universal) {
return model.getMongooseModel(_this3.db);
}
return model;
});
}
}, {
key: "getModels",
value: function getModels() {
return {};
}
}, {
key: "getDatabase",
value: function getDatabase() {
return this.config.db ? (0, _server["default"])(this, this.config.db) : null;
}
}, {
key: "getErrors",
value: function getErrors() {
return require('./getErrors')["default"](this);
}
}, {
key: "getResponses",
value: function getResponses() {
return require('./responses')["default"](this);
}
}, {
key: "getHelpers",
value: function getHelpers() {
return require('./helpers')["default"](this);
}
}, {
key: "getStaticsDir",
value: function getStaticsDir(dirPath) {
var fs = require('fs');
var readdirSync = fs.readdirSync;
var files = readdirSync(dirPath).filter(function (p) {
return p !== '.' && p !== '..';
});
var res = {};
files.forEach(function (file) {
res["/".concat(file)] = "".concat(dirPath, "/").concat(file);
});
return res;
}
}, {
key: "getEnv",
value: function getEnv(req) {
return {
__ROOT_STATE__: {
token: req.token,
user: req.user,
req: {
token: req.token,
user: req.user
},
config: this.config.client || {}
},
__DEV__: __DEV__,
__STAGE__: global.__STAGE__
};
}
}, {
key: "getStatics",
value: function getStatics() {
if (this.serverConfig && this.serverConfig["public"]) {
return this.getStaticsDir(this.serverConfig["public"]);
}
return {};
}
}, {
key: "_getStatics",
value: function _getStatics() {
return (0, _mapValues["default"])(this.getStatics() || {}, function (p) {
return _path2["default"].resolve(p);
});
}
}, {
key: "runStatics",
value: function runStatics() {
var _this4 = this;
(0, _forEach["default"])(this.statics, function (_path, url) {
_this4.express.use(url, _express["default"]["static"](_path));
_this4.express.use(url, (0, _connectStaticFile["default"])(_path));
});
}
}, {
key: "getUsingMiddlewares",
value: function getUsingMiddlewares() {
return [this.middlewares.extendReqRes, this.middlewares.reqLog, this.middlewares.accessLogger, this.middlewares.reqParser, this.middlewares.reqData, this.middlewares.parseToken, this.middlewares.parseUser, this.middlewares.i18];
}
}, {
key: "initWs",
value: function initWs() {
this.ws = (0, _ws["default"])(this);
this.ws.wrapExpress(this.express);
}
}, {
key: "runWs",
value: function () {
var _runWs = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
var transports;
return _regenerator["default"].wrap(function _callee3$(_context3) {
while (1) {
switch (_context3.prev = _context3.next) {
case 0:
if (this.serverConfig.ws) {
_context3.next = 2;
break;
}
return _context3.abrupt("return");
case 2:
if (DEBUG) this.log.trace('ServerApp.runWs');
this.ws.serveClient(false);
this.ws.attach(this.httpServer);
transports = this.serverConfig.ws.transports || ['websocket'];
this.ws.set('transports', transports);
if (this.serverConfig.ws.origins) this.ws.set('origins', this.serverConfig.ws.origins);
case 8:
case "end":
return _context3.stop();
}
}
}, _callee3, this);
}));
function runWs() {
return _runWs.apply(this, arguments);
}
return runWs;
}()
}, {
key: "runMiddlewares",
value: function runMiddlewares() {
var _this5 = this;
if (DEBUG) this.log.trace('ServerApp.runMiddlewares');
var middlewares = (0, _flattenDeep["default"])(this.getUsingMiddlewares());
middlewares.forEach(function (middleware) {
if (middleware && typeof middleware === 'function') _this5.express.use(middleware);
});
}
}, {
key: "runDefaultRoute",
value: function runDefaultRoute() {
var _this6 = this;
if (DEBUG) this.log.trace('ServerApp.runDefaultRoute');
this.express.use(function (req, res, next) {
next(_this6.e('ROUTE_NOT_FOUND', {
status: 404
}));
});
}
}, {
key: "runCatchErrors",
value: function runCatchErrors() {
if (this.middlewares.catchError) this.express.use(this.middlewares.catchError);
}
}, {
key: "runModels",
value: function runModels() {
var _this7 = this;
var promises = (0, _map["default"])(this.models, /*#__PURE__*/function () {
var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4(model, name) {
return _regenerator["default"].wrap(function _callee4$(_context4) {
while (1) {
switch (_context4.prev = _context4.next) {
case 0:
if (!model.run) {
_context4.next = 4;
break;
}
_context4.next = 3;
return model.run(_this7);
case 3:
_this7.models[name] = _context4.sent;
case 4:
case "end":
return _context4.stop();
}
}
}, _callee4);
}));
return function (_x, _x2) {
return _ref.apply(this, arguments);
};
}());
return Promise.all(promises);
}
}, {
key: "run",
// getI18 = require('../Uapp/i18/getI18').default;
// getI18Params = require('../Uapp/i18/getI18Params').default;
// getLocale = require('../Uapp/i18/getLocale').default;
// initI18 = require('../Uapp/i18/initI18').default;
value: function () {
var _run = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
var _get2;
var _len3,
args,
_key3,
_args5 = arguments;
return _regenerator["default"].wrap(function _callee5$(_context5) {
while (1) {
switch (_context5.prev = _context5.next) {
case 0:
for (_len3 = _args5.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
args[_key3] = _args5[_key3];
}
_context5.next = 3;
return (_get2 = (0, _get3["default"])((0, _getPrototypeOf2["default"])(ServerApp.prototype), "run", this)).call.apply(_get2, [this].concat(args));
case 3:
if (DEBUG) this.log.trace('ServerApp.run');
if (!this.db) {
_context5.next = 7;
break;
}
_context5.next = 7;
return this.db.run();
case 7:
if (!this.serverConfig.ws) {
_context5.next = 10;
break;
}
_context5.next = 10;
return this.runWs();
case 10:
if (!this.config.redis) {
_context5.next = 13;
break;
}
_context5.next = 13;
return this.runRedis();
case 13:
this.runStatics();
this.runMiddlewares();
case 15:
case "end":
return _context5.stop();
}
}
}, _callee5, this);
}));
function run() {
return _run.apply(this, arguments);
}
return run;
}()
}, {
key: "createExpress",
value: function createExpress() {
return (0, _express["default"])();
}
}, {
key: "afterRun",
value: function () {
var _afterRun = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
var _this8 = this;
return _regenerator["default"].wrap(function _callee6$(_context6) {
while (1) {
switch (_context6.prev = _context6.next) {
case 0:
if (DEBUG) this.log.trace('ServerApp afterRun');
this.runRoutes();
this.runDefaultRoute();
this.runCatchErrors();
return _context6.abrupt("return", new Promise(function (resolve) {
_this8.httpInstance = _this8.httpServer.listen(_this8.config.port || _this8.serverConfig.port, function () {
resolve(_this8);
});
}));
case 5:
case "end":
return _context6.stop();
}
}
}, _callee6, this);
}));
function afterRun() {
return _afterRun.apply(this, arguments);
}
return afterRun;
}()
}, {
key: "stop",
value: function () {
var _stop = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
var _this9 = this;
return _regenerator["default"].wrap(function _callee7$(_context7) {
while (1) {
switch (_context7.prev = _context7.next) {
case 0:
_context7.next = 2;
return (0, _get3["default"])((0, _getPrototypeOf2["default"])(ServerApp.prototype), "stop", this).call(this);
case 2:
if (!this.db) {
_context7.next = 5;
break;
}
_context7.next = 5;
return this.db.stop();
case 5:
_context7.next = 7;
return new Promise(function (resolved) {
if (_this9.httpInstance) {
_this9.httpInstance.close(resolved);
} else {
resolved();
}
});
case 7:
case "end":
return _context7.stop();
}
}
}, _callee7, this);
}));
function stop() {
return _stop.apply(this, arguments);
}
return stop;
}()
}, {
key: "started",
value: function () {
var _started = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee8() {
var timing, str;
return _regenerator["default"].wrap(function _callee8$(_context8) {
while (1) {
switch (_context8.prev = _context8.next) {
case 0:
timing = global.timing ? "[".concat(global.timing(), "ms]") : '';
str = "\uD83C\uDF83 The server is running at http://127.0.0.1:".concat(this.httpInstance.address().port, "/ ").concat(timing);
if (__DEV__) {
console.log(str); // eslint-disable-line no-console
} else {
this.log.warn(str);
}
case 3:
case "end":
return _context8.stop();
}
}
}, _callee8, this);
}));
function started() {
return _started.apply(this, arguments);
}
return started;
}()
}]);
return ServerApp;
}(_module["default"]), _temp), ((0, _applyDecoratedDescriptor2["default"])(_class.prototype, "url", [_autobind["default"]], Object.getOwnPropertyDescriptor(_class.prototype, "url"), _class.prototype)), _class);
exports["default"] = ServerApp;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ServerApp.js"],"names":["DEBUG","__DEV__","ServerApp","_module","name","i18","I18","ctx","getDocsRouter","require","getDocsTemplate","expressResolve","runRedis","runRoutes","log","trace","express","createExpress","serverConfig","config","server","defaultServerConfig","httpServer","http","createServer","Object","keys","length","value","key","set","getDatabase","db","responses","getResponses","debug","middlewares","getMiddlewares","helpers","getHelpers","statics","_getStatics","api","Apiquery","url","ws","initWs","setState","getLocale","init","models","getMongooseModels","runModels","str","params","query","val","join","e","call","getModels","modules","mdl","moduleName","models2","model","modelName","error","_universal","getMongooseModel","dirPath","fs","readdirSync","files","filter","p","res","forEach","file","req","__ROOT_STATE__","token","user","client","__STAGE__","global","getStaticsDir","getStatics","path","resolve","_path","use","extendReqRes","reqLog","accessLogger","reqParser","reqData","parseToken","parseUser","wrapExpress","serveClient","attach","transports","origins","getUsingMiddlewares","middleware","next","status","catchError","promises","run","Promise","all","args","runWs","redis","runStatics","runMiddlewares","runDefaultRoute","runCatchErrors","httpInstance","listen","port","stop","resolved","close","timing","address","console","warn","Module","autobind"],"mappings":"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","sourcesContent":["/* eslint-disable global-require */\nimport express from 'express';\nimport path from 'path';\nimport mapValues from 'lodash/mapValues';\nimport get from 'lodash/get';\nimport forEach from 'lodash/forEach';\nimport flattenDeep from 'lodash/flattenDeep';\nimport map from 'lodash/map';\nimport staticFileMiddleware from 'connect-static-file';\nimport Apiquery from '@lskjs/apiquery';\nimport autobind from '@lskjs/utils/autobind';\nimport I18 from '@lskjs/i18';\nimport db from '@lskjs/db/server';\nimport e from '@lskjs/utils/e';\nimport Module from '@lskjs/module';\nimport http from 'http';\nimport defaultServerConfig from './config';\n\nimport createWs from './ws';\n\nconst DEBUG = __DEV__ && false;\nexport default class ServerApp extends Module {\n  _module = 'app';\n  name = 'App';\n  // Api = Api;\n  i18 = new I18({ ctx: this });\n  async init() {\n    await super.init();\n    if (DEBUG) this.log.trace('ServerApp init');\n    this.express = this.createExpress();\n    // this.app = this.express; // Fallback\n    this.serverConfig = this.config.server || defaultServerConfig;\n    this.httpServer = http.createServer(this.express);\n    if (this.serverConfig.express && Object.keys(this.serverConfig.express).length) {\n      this.log.trace('serverConfig.express:', this.serverConfig.express);\n      forEach(this.serverConfig.express || {}, (value, key) => {\n        this.express.set(key, value);\n      });\n    }\n    this.db = await this.getDatabase();\n    this.responses = this.getResponses();\n    if (DEBUG) this.log.debug('responses', Object.keys(this.responses));\n    if (DEBUG) this.log.debug('serverConfig.middlewares', this.serverConfig.middlewares);\n    this.middlewares = this.getMiddlewares();\n    this.log.debug('middlewares', Object.keys(this.middlewares));\n    this.helpers = this.getHelpers();\n    if (DEBUG) this.log.debug('helpers', Object.keys(this.helpers));\n    this.statics = this._getStatics();\n    this.log.debug('statics', this.statics);\n    this.api = new Apiquery({\n      url: this.url('/'),\n      log: this.log,\n    });\n    if (this.serverConfig.ws) this.initWs();\n    if (this.i18) {\n      await this.i18\n        .setState({\n          log: this.log,\n          config: this.config.i18,\n          getLocale: this.getLocale,\n        })\n        .init();\n    }\n  }\n\n  async afterInit() {\n    // super.afterInit(...arguments);\n    this.models = this.getMongooseModels();\n    this.log.debug('models', Object.keys(this.models));\n    await this.runModels();\n  }\n\n  @autobind\n  url(str, params = null) {\n    let query = '';\n    if (params && Object.keys(params.length)) {\n      query = `?${map(params, (val, key) => `${key}=${val}`).join('&')}`;\n    }\n    // `http://127.0.0.1:${this.config.port || this.serverConfig.port}`,\n    return `${this.config.url || this.serverConfig.url || '/'}${str}${query}`;\n  }\n\n  e(...params) {\n    return e.call(this, ...params);\n  }\n\n  // emit(...args) {\n  //   this.modules && this.modules.events && this.modules.events.emit(...args); // eslint-disable-line\n  // }\n  // on(...args) {\n  //   this.modules && this.modules.events && this.modules.events.on(...args); // eslint-disable-line\n  // }\n  // once(...args) {\n  //   this.modules && this.modules.events && this.modules.events.once(...args); // eslint-disable-line\n  // }\n\n  getMiddlewares() {\n    return require('./middlewares').default(this); // eslint-disable-line\n  }\n  getMongooseModels() {\n    const models = this.getModels();\n    forEach(this.modules, (mdl, moduleName) => {\n      let models2 = {};\n      if (mdl.getModels) {\n        models2 = mdl.getModels();\n      } else if (mdl.models) {\n        models2 = mdl.models;\n      }\n      // console.log('models2', Object.keys(models2));\n      forEach(models2, (model, modelName) => {\n        if (models[modelName]) {\n          this.log.error(`ServerApp.getMongooseModels: CONFLICT modules/${moduleName}/${modelName}`); // eslint-disable-line no-console\n          return;\n        }\n        models[modelName] = models2[modelName];\n      });\n    });\n    return mapValues(models, model => {\n      if (model._universal) {\n        return model.getMongooseModel(this.db);\n      }\n      return model;\n    });\n  }\n  getModels() {\n    return {};\n  }\n  getDatabase() {\n    return this.config.db ? db(this, this.config.db) : null;\n  }\n  getErrors() {\n    return require('./getErrors').default(this);\n  }\n  getResponses() {\n    return require('./responses').default(this);\n  }\n  getHelpers() {\n    return require('./helpers').default(this);\n  }\n  getStaticsDir(dirPath) {\n    const fs = require('fs');\n    const { readdirSync } = fs;\n    const files = readdirSync(dirPath).filter(p => p !== '.' && p !== '..');\n    const res = {};\n    files.forEach(file => {\n      res[`/${file}`] = `${dirPath}/${file}`;\n    });\n    return res;\n  }\n\n  getEnv(req) {\n    return {\n      __ROOT_STATE__: {\n        token: req.token,\n        user: req.user,\n        req: {\n          token: req.token,\n          user: req.user,\n        },\n        config: this.config.client || {},\n      },\n      __DEV__,\n      __STAGE__: global.__STAGE__,\n    };\n  }\n\n  getStatics() {\n    if (this.serverConfig && this.serverConfig.public) {\n      return this.getStaticsDir(this.serverConfig.public);\n    }\n    return {};\n  }\n\n  _getStatics() {\n    return mapValues(this.getStatics() || {}, p => path.resolve(p));\n  }\n\n  runStatics() {\n    forEach(this.statics, (_path, url) => {\n      this.express.use(url, express.static(_path));\n      this.express.use(url, staticFileMiddleware(_path));\n    });\n  }\n\n  getUsingMiddlewares() {\n    return [\n      this.middlewares.extendReqRes,\n      this.middlewares.reqLog,\n      this.middlewares.accessLogger,\n      this.middlewares.reqParser,\n      this.middlewares.reqData,\n      this.middlewares.parseToken,\n      this.middlewares.parseUser,\n      this.middlewares.i18,\n    ];\n  }\n\n  initWs() {\n    this.ws = createWs(this);\n    this.ws.wrapExpress(this.express);\n  }\n  async runWs() {\n    if (!this.serverConfig.ws) return;\n    if (DEBUG) this.log.trace('ServerApp.runWs');\n    this.ws.serveClient(false);\n    this.ws.attach(this.httpServer);\n    const transports = this.serverConfig.ws.transports || ['websocket'];\n    this.ws.set('transports', transports);\n    if (this.serverConfig.ws.origins) this.ws.set('origins', this.serverConfig.ws.origins);\n  }\n\n  runMiddlewares() {\n    if (DEBUG) this.log.trace('ServerApp.runMiddlewares');\n    const middlewares = flattenDeep(this.getUsingMiddlewares());\n    middlewares.forEach(middleware => {\n      if (middleware && typeof middleware === 'function') this.express.use(middleware);\n    });\n  }\n  runDefaultRoute() {\n    if (DEBUG) this.log.trace('ServerApp.runDefaultRoute');\n    this.express.use((req, res, next) => {\n      next(this.e('ROUTE_NOT_FOUND', { status: 404 }));\n    });\n  }\n\n  runCatchErrors() {\n    if (this.middlewares.catchError) this.express.use(this.middlewares.catchError);\n  }\n\n  runModels() {\n    const promises = map(this.models, async (model, name) => {\n      if (model.run) {\n        this.models[name] = await model.run(this);\n      }\n    });\n    return Promise.all(promises);\n  }\n\n  getDocsRouter = require('./methods/getDocsRouter').default;\n  getDocsTemplate = () => 'deprecated';\n\n  expressResolve = require('./methods/expressResolve').default;\n  runRedis = require('./methods/runRedis').default;\n  runRoutes = require('./methods/runRoutes').default;\n  // getI18 = require('../Uapp/i18/getI18').default;\n  // getI18Params = require('../Uapp/i18/getI18Params').default;\n  // getLocale = require('../Uapp/i18/getLocale').default;\n  // initI18 = require('../Uapp/i18/initI18').default;\n\n  async run(...args) {\n    await super.run(...args);\n    if (DEBUG) this.log.trace('ServerApp.run');\n    if (this.db) await this.db.run();\n    if (this.serverConfig.ws) await this.runWs();\n    if (this.config.redis) await this.runRedis();\n    this.runStatics();\n    this.runMiddlewares();\n  }\n\n  createExpress() {\n    return express();\n  }\n\n  async afterRun() {\n    if (DEBUG) this.log.trace('ServerApp afterRun');\n    this.runRoutes();\n    this.runDefaultRoute();\n    this.runCatchErrors();\n    return new Promise(resolve => {\n      this.httpInstance = this.httpServer.listen(this.config.port || this.serverConfig.port, () => {\n        resolve(this);\n      });\n    });\n  }\n  async stop() {\n    await super.stop();\n    if (this.db) await this.db.stop();\n    await new Promise(resolved => {\n      if (this.httpInstance) {\n        this.httpInstance.close(resolved);\n      } else {\n        resolved();\n      }\n    });\n  }\n\n  async started() {\n    const timing = global.timing ? `[${global.timing()}ms]` : '';\n    const str = `🎃  The server is running at http://127.0.0.1:${this.httpInstance.address().port}/ ${timing}`;\n    if (__DEV__) {\n      console.log(str); // eslint-disable-line no-console\n    } else {\n      this.log.warn(str);\n    }\n  }\n}\n"]}
//# sourceMappingURL=ServerApp.js.map