UNPKG

@coolwallet/btc

Version:
267 lines (197 loc) 21.5 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _core = require("@coolwallet/core"); var _transactionUtil = require("./utils/transactionUtil"); var _sign = require("./sign"); var _types = require("./config/types"); var _param = require("./config/param"); var _tweakUtil = require("./utils/tweakUtil"); function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } 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; } } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } var BTC = /*#__PURE__*/function (_COIN$ECDSACoin) { _inherits(BTC, _COIN$ECDSACoin); var _super = _createSuper(BTC); function BTC() { var _this; _classCallCheck(this, BTC); _this = _super.call(this, _param.COIN_TYPE); _this.addressToOutScript = _transactionUtil.addressToOutScript; return _this; } _createClass(BTC, [{ key: "getAddress", value: function () { var _getAddress = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(transport, appPrivateKey, appId, scriptType, addressIndex, purpose) { var publicKey, _pubkeyToAddressAndOu, address; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.next = 2; return this.getPublicKey(transport, appPrivateKey, appId, addressIndex, purpose); case 2: publicKey = _context.sent; if (scriptType === _types.ScriptType.P2TR) { publicKey = (0, _tweakUtil.tweak)(publicKey); } _pubkeyToAddressAndOu = (0, _transactionUtil.pubkeyToAddressAndOutScript)(Buffer.from(publicKey, 'hex'), scriptType), address = _pubkeyToAddressAndOu.address; return _context.abrupt("return", address); case 6: case "end": return _context.stop(); } } }, _callee, this); })); function getAddress(_x, _x2, _x3, _x4, _x5, _x6) { return _getAddress.apply(this, arguments); } return getAddress; }() }, { key: "getAddressAndOutScript", value: function () { var _getAddressAndOutScript = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(transport, appPrivateKey, appId, scriptType, addressIndex, purpose) { var publicKey; return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: _context2.next = 2; return this.getPublicKey(transport, appPrivateKey, appId, addressIndex, purpose); case 2: publicKey = _context2.sent; if (scriptType === _types.ScriptType.P2TR) { publicKey = (0, _tweakUtil.tweak)(publicKey); } return _context2.abrupt("return", (0, _transactionUtil.pubkeyToAddressAndOutScript)(Buffer.from(publicKey, 'hex'), scriptType)); case 5: case "end": return _context2.stop(); } } }, _callee2, this); })); function getAddressAndOutScript(_x7, _x8, _x9, _x10, _x11, _x12) { return _getAddressAndOutScript.apply(this, arguments); } return getAddressAndOutScript; }() }, { key: "getAddressAndOutScriptByAccountKey", value: function () { var _getAddressAndOutScriptByAccountKey = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(accPublicKey, accChainCode, addressIndex, scriptType) { var publicKey; return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: publicKey = this.getAddressPublicKey(accPublicKey, accChainCode, addressIndex); if (scriptType === _types.ScriptType.P2TR) { publicKey = (0, _tweakUtil.tweak)(publicKey); } return _context3.abrupt("return", (0, _transactionUtil.pubkeyToAddressAndOutScript)(Buffer.from(publicKey, 'hex'), scriptType)); case 3: case "end": return _context3.stop(); } } }, _callee3, this); })); function getAddressAndOutScriptByAccountKey(_x13, _x14, _x15, _x16) { return _getAddressAndOutScriptByAccountKey.apply(this, arguments); } return getAddressAndOutScriptByAccountKey; }() }, { key: "signTransaction", value: function () { var _signTransaction = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(signTxData) { var _iterator, _step, input, _pubkey, pubkey; return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: _iterator = _createForOfIteratorHelper(signTxData.inputs); _context4.prev = 1; _iterator.s(); case 3: if ((_step = _iterator.n()).done) { _context4.next = 11; break; } input = _step.value; _context4.next = 7; return this.getPublicKey(signTxData.transport, signTxData.appPrivateKey, signTxData.appId, input.addressIndex, input.purposeIndex); case 7: _pubkey = _context4.sent; if (signTxData.scriptType === _types.ScriptType.P2TR) { input.pubkeyBuf = Buffer.from((0, _tweakUtil.tweak)(_pubkey), 'hex'); } else { input.pubkeyBuf = Buffer.from(_pubkey, 'hex'); } case 9: _context4.next = 3; break; case 11: _context4.next = 16; break; case 13: _context4.prev = 13; _context4.t0 = _context4["catch"](1); _iterator.e(_context4.t0); case 16: _context4.prev = 16; _iterator.f(); return _context4.finish(16); case 19: if (!signTxData.change) { _context4.next = 24; break; } _context4.next = 22; return this.getPublicKey(signTxData.transport, signTxData.appPrivateKey, signTxData.appId, signTxData.change.addressIndex, signTxData.change.purposeIndex); case 22: pubkey = _context4.sent; // eslint-disable-next-line no-param-reassign if (signTxData.scriptType === _types.ScriptType.P2TR) { signTxData.change.pubkeyBuf = Buffer.from((0, _tweakUtil.tweak)(pubkey), 'hex'); } else { signTxData.change.pubkeyBuf = Buffer.from(pubkey, 'hex'); } case 24: return _context4.abrupt("return", (0, _sign.signBTCTransaction)(signTxData)); case 25: case "end": return _context4.stop(); } } }, _callee4, this, [[1, 13, 16, 19]]); })); function signTransaction(_x17) { return _signTransaction.apply(this, arguments); } return signTransaction; }() }]); return BTC; }(_core.coin.ECDSACoin); exports["default"] = BTC; //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6WyJCVEMiLCJDT0lOX1RZUEUiLCJhZGRyZXNzVG9PdXRTY3JpcHQiLCJ0cmFuc3BvcnQiLCJhcHBQcml2YXRlS2V5IiwiYXBwSWQiLCJzY3JpcHRUeXBlIiwiYWRkcmVzc0luZGV4IiwicHVycG9zZSIsImdldFB1YmxpY0tleSIsInB1YmxpY0tleSIsIlNjcmlwdFR5cGUiLCJQMlRSIiwiQnVmZmVyIiwiZnJvbSIsImFkZHJlc3MiLCJhY2NQdWJsaWNLZXkiLCJhY2NDaGFpbkNvZGUiLCJnZXRBZGRyZXNzUHVibGljS2V5Iiwic2lnblR4RGF0YSIsImlucHV0cyIsImlucHV0IiwicHVycG9zZUluZGV4IiwicHVia2V5IiwicHVia2V5QnVmIiwiY2hhbmdlIiwiQ09JTiIsIkVDRFNBQ29pbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBRXFCQSxHOzs7OztBQUduQixpQkFBYztBQUFBOztBQUFBOztBQUNaLDhCQUFNQyxnQkFBTjtBQUNBLFVBQUtDLGtCQUFMLEdBQTBCQSxtQ0FBMUI7QUFGWTtBQUdiOzs7OztnRkFFRCxpQkFDRUMsU0FERixFQUVFQyxhQUZGLEVBR0VDLEtBSEYsRUFJRUMsVUFKRixFQUtFQyxZQUxGLEVBTUVDLE9BTkY7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsdUJBUXdCLEtBQUtDLFlBQUwsQ0FBa0JOLFNBQWxCLEVBQTZCQyxhQUE3QixFQUE0Q0MsS0FBNUMsRUFBbURFLFlBQW5ELEVBQWlFQyxPQUFqRSxDQVJ4Qjs7QUFBQTtBQVFNRSxnQkFBQUEsU0FSTjs7QUFTRSxvQkFBSUosVUFBVSxLQUFLSyxrQkFBV0MsSUFBOUIsRUFBb0M7QUFDbENGLGtCQUFBQSxTQUFTLEdBQUcsc0JBQU1BLFNBQU4sQ0FBWjtBQUNEOztBQVhILHdDQVlzQixrREFB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RUFLbkJZLFVBQVUsQ0FBQ00sTUFBWCxDQUFrQkgsWUFMQyxDQWpCekI7O0FBQUE7QUFpQlVDLGdCQUFBQSxNQWpCVjs7QUF3Qkk7QUFDQSxvQkFBSUosVUFBVSxDQUFDYixVQUFYLEtBQTBCSyxrQkFBV0MsSUFBekMsRUFBK0M7QUFDN0NPLGtCQUFBQSxVQUFVLENBQUNNLE1BQVgsQ0FBa0JELFNBQWxCLEdBQThCWCxNQUFNLENBQUNDLElBQVAsQ0FBWSxzQkFBTVMsTUFBTixDQUFaLEVBQTJCLEtBQTNCLENBQTlCO0FBQ0QsaUJBRkQsTUFFTztBQUNMSixrQkFBQUEsVUFBVSxDQUFDTSxNQUFYLENBQWtCRCxTQUFsQixHQUE4QlgsTUFBTSxDQUFDQyxJQUFQLENBQVlTLE1BQVosRUFBb0IsS0FBcEIsQ0FBOUI7QUFDRDs7QUE3Qkw7QUFBQSxrREErQlMsOEJBQW1CSixVQUFuQixDQS9CVDs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxPOzs7Ozs7Ozs7OztFQXBEK0JPLFdBQUtDLFMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb2luIGFzIENPSU4gfSBmcm9tICdAY29vbHdhbGxldC9jb3JlJztcbmltcG9ydCB7IGFkZHJlc3NUb091dFNjcmlwdCwgcHVia2V5VG9BZGRyZXNzQW5kT3V0U2NyaXB0IH0gZnJvbSAnLi91dGlscy90cmFuc2FjdGlvblV0aWwnO1xuaW1wb3J0IHsgc2lnbkJUQ1RyYW5zYWN0aW9uIH0gZnJvbSAnLi9zaWduJztcbmltcG9ydCB7IFNjcmlwdFR5cGUsIHNpZ25UeFR5cGUsIFRyYW5zcG9ydCB9IGZyb20gJy4vY29uZmlnL3R5cGVzJztcbmltcG9ydCB7IENPSU5fVFlQRSB9IGZyb20gJy4vY29uZmlnL3BhcmFtJztcbmltcG9ydCB7IHR3ZWFrIH0gZnJvbSAnLi91dGlscy90d2Vha1V0aWwnO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBCVEMgZXh0ZW5kcyBDT0lOLkVDRFNBQ29pbiBpbXBsZW1lbnRzIENPSU4uQ29pbiB7XG4gIHB1YmxpYyBhZGRyZXNzVG9PdXRTY3JpcHQ6IChhZGRyZXNzOiBzdHJpbmcpID0+IHsgc2NyaXB0VHlwZTogU2NyaXB0VHlwZTsgb3V0U2NyaXB0OiBCdWZmZXI7IG91dEhhc2g/OiBCdWZmZXIgfTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcihDT0lOX1RZUEUpO1xuICAgIHRoaXMuYWRkcmVzc1RvT3V0U2NyaXB0ID0gYWRkcmVzc1RvT3V0U2NyaXB0O1xuICB9XG5cbiAgYXN5bmMgZ2V0QWRkcmVzcyhcbiAgICB0cmFuc3BvcnQ6IFRyYW5zcG9ydCxcbiAgICBhcHBQcml2YXRlS2V5OiBzdHJpbmcsXG4gICAgYXBwSWQ6IHN0cmluZyxcbiAgICBzY3JpcHRUeXBlOiBTY3JpcHRUeXBlLFxuICAgIGFkZHJlc3NJbmRleDogbnVtYmVyLFxuICAgIHB1cnBvc2U/OiBudW1iZXJcbiAgKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICBsZXQgcHVibGljS2V5ID0gYXdhaXQgdGhpcy5nZXRQdWJsaWNLZXkodHJhbnNwb3J0LCBhcHBQcml2YXRlS2V5LCBhcHBJZCwgYWRkcmVzc0luZGV4LCBwdXJwb3NlKTtcbiAgICBpZiAoc2NyaXB0VHlwZSA9PT0gU2NyaXB0VHlwZS5QMlRSKSB7XG4gICAgICBwdWJsaWNLZXkgPSB0d2VhayhwdWJsaWNLZXkpO1xuICAgIH1cbiAgICBjb25zdCB7IGFkZHJlc3MgfSA9IHB1YmtleVRvQWRkcmVzc0FuZE91dFNjcmlwdChCdWZmZXIuZnJvbShwdWJsaWNLZXksICdoZXgnKSwgc2NyaXB0VHlwZSk7XG4gICAgcmV0dXJuIGFkZHJlc3M7XG4gIH1cblxuICBhc3luYyBnZXRBZGRyZXNzQW5kT3V0U2NyaXB0KFxuICAgIHRyYW5zcG9ydDogVHJhbnNwb3J0LFxuICAgIGFwcFByaXZhdGVLZXk6IHN0cmluZyxcbiAgICBhcHBJZDogc3RyaW5nLFxuICAgIHNjcmlwdFR5cGU6IFNjcmlwdFR5cGUsXG4gICAgYWRkcmVzc0luZGV4OiBudW1iZXIsXG4gICAgcHVycG9zZT86IG51bWJlclxuICApOiBQcm9taXNlPHsgYWRkcmVzczogc3RyaW5nOyBvdXRTY3JpcHQ6IEJ1ZmZlciB9PiB7XG4gICAgbGV0IHB1YmxpY0tleSA9IGF3YWl0IHRoaXMuZ2V0UHVibGljS2V5KHRyYW5zcG9ydCwgYXBwUHJpdmF0ZUtleSwgYXBwSWQsIGFkZHJlc3NJbmRleCwgcHVycG9zZSk7XG4gICAgaWYgKHNjcmlwdFR5cGUgPT09IFNjcmlwdFR5cGUuUDJUUikge1xuICAgICAgcHVibGljS2V5ID0gdHdlYWsocHVibGljS2V5KTtcbiAgICB9XG4gICAgcmV0dXJuIHB1YmtleVRvQWRkcmVzc0FuZE91dFNjcmlwdChCdWZmZXIuZnJvbShwdWJsaWNLZXksICdoZXgnKSwgc2NyaXB0VHlwZSk7XG4gIH1cblxuICBhc3luYyBnZXRBZGRyZXNzQW5kT3V0U2NyaXB0QnlBY2NvdW50S2V5KFxuICAgIGFjY1B1YmxpY0tleTogc3RyaW5nLFxuICAgIGFjY0NoYWluQ29kZTogc3RyaW5nLFxuICAgIGFkZHJlc3NJbmRleDogbnVtYmVyLFxuICAgIHNjcmlwdFR5cGU6IFNjcmlwdFR5cGVcbiAgKTogUHJvbWlzZTx7IGFkZHJlc3M6IHN0cmluZzsgb3V0U2NyaXB0OiBCdWZmZXIgfT4ge1xuICAgIGxldCBwdWJsaWNLZXkgPSB0aGlzLmdldEFkZHJlc3NQdWJsaWNLZXkoYWNjUHVibGljS2V5LCBhY2NDaGFpbkNvZGUsIGFkZHJlc3NJbmRleCk7XG4gICAgaWYgKHNjcmlwdFR5cGUgPT09IFNjcmlwdFR5cGUuUDJUUikge1xuICAgICAgcHVibGljS2V5ID0gdHdlYWsocHVibGljS2V5KTtcbiAgICB9XG4gICAgcmV0dXJuIHB1YmtleVRvQWRkcmVzc0FuZE91dFNjcmlwdChCdWZmZXIuZnJvbShwdWJsaWNLZXksICdoZXgnKSwgc2NyaXB0VHlwZSk7XG4gIH1cblxuICBhc3luYyBzaWduVHJhbnNhY3Rpb24oc2lnblR4RGF0YTogc2lnblR4VHlwZSk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgZm9yIChjb25zdCBpbnB1dCBvZiBzaWduVHhEYXRhLmlucHV0cykge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWF3YWl0LWluLWxvb3BcbiAgICAgIGNvbnN0IHB1YmtleSA9IGF3YWl0IHRoaXMuZ2V0UHVibGljS2V5KFxuICAgICAgICBzaWduVHhEYXRhLnRyYW5zcG9ydCxcbiAgICAgICAgc2lnblR4RGF0YS5hcHBQcml2YXRlS2V5LFxuICAgICAgICBzaWduVHhEYXRhLmFwcElkLFxuICAgICAgICBpbnB1dC5hZGRyZXNzSW5kZXgsXG4gICAgICAgIGlucHV0LnB1cnBvc2VJbmRleFxuICAgICAgKTtcbiAgICAgIGlmIChzaWduVHhEYXRhLnNjcmlwdFR5cGUgPT09IFNjcmlwdFR5cGUuUDJUUikge1xuICAgICAgICBpbnB1dC5wdWJrZXlCdWYgPSBCdWZmZXIuZnJvbSh0d2VhayhwdWJrZXkpLCAnaGV4Jyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpbnB1dC5wdWJrZXlCdWYgPSBCdWZmZXIuZnJvbShwdWJrZXksICdoZXgnKTtcbiAgICAgIH1cbiAgICB9XG4gICAgaWYgKHNpZ25UeERhdGEuY2hhbmdlKSB7XG4gICAgICBjb25zdCBwdWJrZXkgPSBhd2FpdCB0aGlzLmdldFB1YmxpY0tleShcbiAgICAgICAgc2lnblR4RGF0YS50cmFuc3BvcnQsXG4gICAgICAgIHNpZ25UeERhdGEuYXBwUHJpdmF0ZUtleSxcbiAgICAgICAgc2lnblR4RGF0YS5hcHBJZCxcbiAgICAgICAgc2lnblR4RGF0YS5jaGFuZ2UuYWRkcmVzc0luZGV4LFxuICAgICAgICBzaWduVHhEYXRhLmNoYW5nZS5wdXJwb3NlSW5kZXhcbiAgICAgICk7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICAgIGlmIChzaWduVHhEYXRhLnNjcmlwdFR5cGUgPT09IFNjcmlwdFR5cGUuUDJUUikge1xuICAgICAgICBzaWduVHhEYXRhLmNoYW5nZS5wdWJrZXlCdWYgPSBCdWZmZXIuZnJvbSh0d2VhayhwdWJrZXkpLCAnaGV4Jyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBzaWduVHhEYXRhLmNoYW5nZS5wdWJrZXlCdWYgPSBCdWZmZXIuZnJvbShwdWJrZXksICdoZXgnKTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHNpZ25CVENUcmFuc2FjdGlvbihzaWduVHhEYXRhKTtcbiAgfVxufVxuIl19