UNPKG

fakeit-facet

Version:

Command-line utility that generates fake data which can be output as JSON, YAML, CSON, or CSV formats based on models defined in YAML.

191 lines (145 loc) 7.44 kB
"use strict"; var _Reflect$construct = require("@babel/runtime-corejs3/core-js-stable/reflect/construct"); var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property"); var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault"); _Object$defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat")); var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs3/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/asyncToGenerator")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/createClass")); var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/getPrototypeOf")); var _path = _interopRequireDefault(require("path")); var _lodash = require("lodash"); var _fsExtraPromisify = _interopRequireDefault(require("fs-extra-promisify")); var _admZip = _interopRequireDefault(require("adm-zip")); var _defaultOptions = _interopRequireDefault(require("./default-options")); var _base = _interopRequireDefault(require("../base")); function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { 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 { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } /// @name Zip /// @page api /// @description This is used to output data to the console var Zip = /*#__PURE__*/function (_Base) { (0, _inherits2["default"])(Zip, _Base); var _super = _createSuper(Zip); /// # @name constructor /// # @arg {object} options - The base options /// # @arg {object} output_options - The output options function Zip() { var _this; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var output_options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; (0, _classCallCheck2["default"])(this, Zip); _this = _super.call(this, options); _this.output_options = (0, _lodash.extend)({}, _defaultOptions["default"], output_options); _this.prepared = false; return _this; } /// # @name prepare /// # @description /// # This is used to prepare the saving functionality that is determined by the /// # options that were passed to the constructor. /// # It sets a variable of `this.preparing` that ultimately calls `this.setup` that returns a promise. /// # This way when you go to save data it, that function will know if the setup is complete or not and /// # wait for it to be done before it starts saving data. /// # @returns {promise} - The setup function that was called /// # @async (0, _createClass2["default"])(Zip, [{ key: "prepare", value: function prepare() { this.preparing = true; this.preparing = this.setup(); return this.preparing; } /// # @name setup /// # @description /// # This is used to setup the saving function that will be used. }, { key: "setup", value: function () { var _setup = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() { return _regenerator["default"].wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: if (!(this.preparing == null)) { _context.next = 2; break; } return _context.abrupt("return", this.prepare()); case 2: this.zip = new _admZip["default"](); // Resolve the output path to make sure it's absolute this.output_options.output = this.resolvePaths(this.output_options.output)[0]; // eslint-disable-line // Ensure there is a directory to write to. This way we can use `fs.writeFile` // instead of `fs.outputFile` which has extra checks that we can skip over _context.next = 6; return _fsExtraPromisify["default"].ensureDir(this.output_options.output); case 6: // theres noting to setup for the Console output // this is just here so that all the Outputters are setup the same this.prepared = true; case 7: case "end": return _context.stop(); } } }, _callee, this); })); function setup() { return _setup.apply(this, arguments); } return setup; }() /// # @name output /// # @description /// # This is used to output the data that's passed to it /// # @arg {string} id - The id to use for this data /// # @arg {object, array, string} data - The data that you want to be saved /// # @async }, { key: "output", value: function () { var _output = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(id, data) { var _context2; return _regenerator["default"].wrap(function _callee2$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: if (!(this.prepared !== true)) { _context3.next = 4; break; } if (this.preparing == null) { this.prepare(); } _context3.next = 4; return this.preparing; case 4: this.zip.addFile(_path["default"].join((0, _concat["default"])(_context2 = "".concat(id, ".")).call(_context2, this.output_options.format)), data); case 5: case "end": return _context3.stop(); } } }, _callee2, this); })); function output(_x, _x2) { return _output.apply(this, arguments); } return output; }() /// # @name finalize /// # @description /// # This will output the zip file to the output folder /// # @async }, { key: "finalize", value: function finalize() { return _fsExtraPromisify["default"].writeFile(_path["default"].join(this.output_options.output, this.output_options.archive), this.zip.toBuffer()); } }]); return Zip; }(_base["default"]); exports["default"] = Zip;