@lskjs/server
Version:
LSK server.
136 lines (106 loc) • 11.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _omit = _interopRequireDefault(require("lodash/omit"));
var _get = _interopRequireDefault(require("lodash/get"));
var _isPlainObject = _interopRequireDefault(require("lodash/isPlainObject"));
var _isFunction = _interopRequireDefault(require("lodash/isFunction"));
var _default = function _default(ctx) {
return function pack() {
var _this = this;
var raw = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var info = arguments.length > 1 ? arguments[1] : undefined;
var res = this;
var config = (0, _get["default"])(ctx, 'config.server.response', __DEV__ ? {
log: false,
debug: true
} : {});
var status = info.status || (0, _get["default"])(raw, '__status', null);
var isJson;
var wrap;
var data;
if (typeof (0, _get["default"])(raw, '__raw') !== 'undefined') {
wrap = false;
isJson = false;
data = raw.__raw;
} else {
wrap = !(0, _get["default"])(raw, '__pack', false);
isJson = true;
if ((0, _isPlainObject["default"])(raw)) {
data = (0, _omit["default"])(raw, ['__pack', '__raw', '__log', '__status']);
} else if (raw instanceof Error) {
throw raw;
} else if ((0, _isFunction["default"])(raw)) {
data = {};
} else {
data = raw;
}
}
var result;
if (wrap) {
result = {
code: info.code,
message: info.message,
data: data
};
} else {
result = data;
}
if (status) {
res.status(status);
}
if (wrap && config.debug) {
if (info.err) {
result.err = info.err;
}
if (info.debug) {
result.debug = info.debug;
}
if (info.stack) {
result.stack = info.stack;
}
}
var isLog = Boolean((0, _get["default"])(data, '__log') == null ? config.log : (0, _get["default"])(data, '__log'));
var log = function log(str, type) {
if (!isLog) return;
var dest = isLog;
if (isLog === true) dest = str && str.length > 100 ? 'file' : 'console';
if (dest === 'file') {
if (__DEV__) {
var dir = "/tmp/lsk";
try {
require('fs').mkdirSync(dir, {
recursive: true
});
} catch (e) {// ignore
}
try {
var filename = "".concat(dir, "/res_").concat(new Date().toISOString().replace(/[^a-zA-Z0-9]+/gi, '_'), ".").concat(type);
ctx.log.trace(">>>>> #".concat(_this.req.reqId, " ").concat(filename, " [").concat(str.length, " bytes] ").concat(__DEV__ ? '[IGNORE]' : ''));
require('fs').writeFileSync(filename, str);
} catch (e) {// ignore
}
}
return;
} // else
ctx.log.trace('>>>>>');
console.log(str); // eslint-disable-line no-console
ctx.log.trace('<<<<<');
};
if (!isJson) {
log(result, 'txt');
return res.send(result);
}
try {
log(JSON.stringify(result, null, 2), 'json');
} catch (e) {// ignore
}
return res.json(result);
};
};
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/responses/pack.js"],"names":["ctx","pack","raw","info","res","config","__DEV__","log","debug","status","isJson","wrap","data","__raw","Error","result","code","message","err","stack","isLog","Boolean","str","type","dest","length","dir","require","mkdirSync","recursive","e","filename","Date","toISOString","replace","trace","req","reqId","writeFileSync","console","send","JSON","stringify","json"],"mappings":"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","sourcesContent":["import omit from 'lodash/omit';\nimport get from 'lodash/get';\nimport isPlainObject from 'lodash/isPlainObject';\nimport isFunction from 'lodash/isFunction';\n\nexport default ctx =>\n  function pack(raw = {}, info) {\n    const res = this;\n    const config = get(ctx, 'config.server.response', __DEV__ ? { log: false, debug: true } : {});\n    const status = info.status || get(raw, '__status', null);\n    let isJson;\n    let wrap;\n    let data;\n    if (typeof get(raw, '__raw') !== 'undefined') {\n      wrap = false;\n      isJson = false;\n      data = raw.__raw;\n    } else {\n      wrap = !get(raw, '__pack', false);\n      isJson = true;\n      if (isPlainObject(raw)) {\n        data = omit(raw, ['__pack', '__raw', '__log', '__status']);\n      } else if (raw instanceof Error) {\n        throw raw;\n      } else if (isFunction(raw)) {\n        data = {};\n      } else {\n        data = raw;\n      }\n    }\n\n    let result;\n    if (wrap) {\n      result = {\n        code: info.code,\n        message: info.message,\n        data,\n      };\n    } else {\n      result = data;\n    }\n    if (status) {\n      res.status(status);\n    }\n\n    if (wrap && config.debug) {\n      if (info.err) {\n        result.err = info.err;\n      }\n      if (info.debug) {\n        result.debug = info.debug;\n      }\n      if (info.stack) {\n        result.stack = info.stack;\n      }\n    }\n\n    const isLog = Boolean(get(data, '__log') == null ? config.log : get(data, '__log'));\n    const log = (str, type) => {\n      if (!isLog) return;\n      let dest = isLog;\n      if (isLog === true) dest = str && str.length > 100 ? 'file' : 'console';\n\n      if (dest === 'file') {\n        if (__DEV__) {\n          const dir = `/tmp/lsk`;\n          try {\n            require('fs').mkdirSync(dir, { recursive: true });\n          } catch (e) {\n            // ignore\n          }\n          try {\n            const filename = `${dir}/res_${new Date().toISOString().replace(/[^a-zA-Z0-9]+/gi, '_')}.${type}`;\n            ctx.log.trace(`>>>>> #${this.req.reqId} ${filename} [${str.length} bytes] ${__DEV__ ? '[IGNORE]' : ''}`);\n            require('fs').writeFileSync(filename, str);\n          } catch (e) {\n            // ignore\n          }\n        }\n        return;\n      }\n      // else\n      ctx.log.trace('>>>>>');\n      console.log(str); // eslint-disable-line no-console\n      ctx.log.trace('<<<<<');\n    };\n\n    if (!isJson) {\n      log(result, 'txt');\n      return res.send(result);\n    }\n    try {\n      log(JSON.stringify(result, null, 2), 'json');\n    } catch (e) {\n      // ignore\n    }\n    return res.json(result);\n  };\n"]}
//# sourceMappingURL=pack.js.map