UNPKG

@lskjs/server

Version:

LSK server.

669 lines (556 loc) 47.6 kB
"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