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
JavaScript
"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;