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.

186 lines (142 loc) 7.48 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 _lodash = require("lodash"); var _path = _interopRequireDefault(require("path")); var _fsExtraPromisify = _interopRequireDefault(require("fs-extra-promisify")); 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 Folder /// @page api /// @description This is used to output data to the Folder var Folder = /*#__PURE__*/function (_Base) { (0, _inherits2["default"])(Folder, _Base); var _super = _createSuper(Folder); /// # @name constructor /// # @arg {object} options - The base options /// # @arg {object} output_options - The output options function Folder() { 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, Folder); _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"])(Folder, [{ 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: // 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 = 5; return _fsExtraPromisify["default"].ensureDir(this.output_options.output); case 5: this.prepared = true; case 6: 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 is 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; var fileToWriteTo; 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: // Some files may contain an id or key property that contains backslashes so we must // be sure to create the directory structure and file before trying to write to the file // otherwise the writeFile function will fail with a `no such file or directory` error. fileToWriteTo = _path["default"].join(this.output_options.output, (0, _concat["default"])(_context2 = "".concat(id, ".")).call(_context2, this.output_options.format)); _context3.next = 7; return _fsExtraPromisify["default"].ensureFile(fileToWriteTo); case 7: return _context3.abrupt("return", _fsExtraPromisify["default"].writeFile(fileToWriteTo, data)); case 8: case "end": return _context3.stop(); } } }, _callee2, this); })); function output(_x, _x2) { return _output.apply(this, arguments); } return output; }() }]); return Folder; }(_base["default"]); exports["default"] = Folder;