UNPKG

@coolwallet/zen

Version:
188 lines (155 loc) 31.8 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.addressToOutScript = addressToOutScript; exports.pubkeyToAddressAndOutScript = pubkeyToAddressAndOutScript; exports.createUnsignedTransactions = createUnsignedTransactions; exports.composeFinalTransaction = composeFinalTransaction; var _core = require("@coolwallet/core"); var types = _interopRequireWildcard(require("../config/types")); var bufferUtil = _interopRequireWildcard(require("./bufferUtil")); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } var bs58check = require('bs58check'); var zencashjs = require('zencashjs'); function addressToOutScript(address) { var decode = bs58check.decode(address); var prefix = decode.slice(0, 2).toString('hex'); var outHash = decode.slice(2, decode.length); var scriptType, outScript; if (prefix === '2089') { scriptType = types.ScriptType.P2PKH; outScript = Buffer.from("76a914".concat(outHash.toString('hex'), "88ac"), 'hex'); } else if (prefix === '2096') { scriptType = types.ScriptType.P2SH; outScript = Buffer.from("a914".concat(outHash.toString('hex'), "87"), 'hex'); } else { throw new _core.error.SDKError(addressToOutScript.name, "Invalid Address '".concat(address, "'")); } return { scriptType: scriptType, outScript: outScript, outHash: outHash }; } function pubkeyToAddressAndOutScript(pubkey, scriptType) { if (scriptType !== types.ScriptType.P2PKH && scriptType !== types.ScriptType.P2SH) { throw new _core.error.SDKError(pubkeyToAddressAndOutScript.name, "Unsupport ScriptType '".concat(scriptType, "'")); } var address = zencashjs.address.pubKeyToAddr(pubkey); var _addressToOutScript = addressToOutScript(address), outScript = _addressToOutScript.outScript, outHash = _addressToOutScript.outHash; return { address: address, outScript: outScript, hash: outHash }; } function createUnsignedTransactions(scriptType, inputs, output, change) { var version = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 1; var lockTime = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 0; var versionBuf = bufferUtil.toReverseUintBuffer(version, 4); var lockTimeBuf = bufferUtil.toReverseUintBuffer(lockTime, 4); var inputsCount = bufferUtil.toVarUintBuffer(inputs.length); var preparedInputs = inputs.map(function (_ref) { var preTxHash = _ref.preTxHash, preIndex = _ref.preIndex, sequence = _ref.sequence, addressIndex = _ref.addressIndex, pubkeyBuf = _ref.pubkeyBuf, scriptPubKey = _ref.scriptPubKey; if (!pubkeyBuf) { throw new _core.error.SDKError(createUnsignedTransactions.name, 'Public Key not exists !!'); } var preOutPointBuf = Buffer.concat([Buffer.from(preTxHash, 'hex').reverse(), bufferUtil.toReverseUintBuffer(preIndex, 4)]); var sequenceBuf = sequence ? bufferUtil.toReverseUintBuffer(sequence, 4) : Buffer.from('ffffffff', 'hex'); var scriptLen; var scriptPubKeyBuf = Buffer.from(scriptPubKey, 'hex'); if (scriptType == types.ScriptType.P2PKH) { scriptLen = 25; } else { scriptLen = 23; } var blockHashLen = parseInt(scriptPubKeyBuf[scriptLen].toString()); var blockHashBuf = scriptPubKeyBuf.slice(scriptLen + 1, scriptLen + 1 + blockHashLen); var blockHeightLen = parseInt(scriptPubKeyBuf[scriptLen + 1 + blockHashLen].toString()); var blockHeightBuf = scriptPubKeyBuf.slice(scriptLen + 1 + blockHashLen + 1, scriptLen + 1 + blockHashLen + 1 + blockHeightLen); return { addressIndex: addressIndex, pubkeyBuf: pubkeyBuf, preOutPointBuf: preOutPointBuf, sequenceBuf: sequenceBuf, blockHashBuf: blockHashBuf, blockHeightBuf: blockHeightBuf }; }); var _addressToOutScript2 = addressToOutScript(output.address), outputType = _addressToOutScript2.scriptType, outputScript = _addressToOutScript2.outScript; var outValue = bufferUtil.toReverseUintBuffer(output.value, 8); var outBlockHashBuf = Buffer.from(output.blockHash, 'hex').reverse(); var outBlockHeightBuf = bufferUtil.toVarUintBuffer(output.blockHeight).reverse(); var outScriptPubKey = Buffer.concat([outputScript, bufferUtil.toVarUintBuffer(outBlockHashBuf.length), outBlockHashBuf, bufferUtil.toVarUintBuffer(outBlockHeightBuf.length), outBlockHeightBuf, Buffer.from('b4', 'hex')]); var outScriptPubKeyLen = bufferUtil.toVarUintBuffer(outScriptPubKey.length); var outputArray = [Buffer.concat([outValue, outScriptPubKeyLen, outScriptPubKey])]; if (change) { if (!change.pubkeyBuf) throw new _core.error.SDKError(createUnsignedTransactions.name, 'Public Key not exists !!'); var _pubkeyToAddressAndOu = pubkeyToAddressAndOutScript(change.pubkeyBuf, scriptType), changeScript = _pubkeyToAddressAndOu.outScript; var changeValue = bufferUtil.toReverseUintBuffer(change.value, 8); var changeBlockHashBuf = Buffer.from(change.blockHash, 'hex'); var changeBlockHeightBuf = bufferUtil.toVarUintBuffer(change.blockHeight); var changeScriptPubKey = Buffer.concat([changeScript, bufferUtil.toVarUintBuffer(changeBlockHashBuf.length), changeBlockHashBuf.reverse(), bufferUtil.toVarUintBuffer(changeBlockHeightBuf.length), changeBlockHeightBuf.reverse(), Buffer.from('b4', 'hex')]); var changeScriptPubKeyLen = bufferUtil.toVarUintBuffer(changeScriptPubKey.length); outputArray.push(Buffer.concat([changeValue, changeScriptPubKeyLen, changeScriptPubKey])); } var outputsCount = bufferUtil.toVarUintBuffer(change ? 2 : 1); var outputsBuf = Buffer.concat(outputArray); var unsignedTransactions = preparedInputs.map(function (_ref2) { var pubkeyBuf = _ref2.pubkeyBuf, preOutPointBuf = _ref2.preOutPointBuf, sequenceBuf = _ref2.sequenceBuf, blockHashBuf = _ref2.blockHashBuf, blockHeightBuf = _ref2.blockHeightBuf; var _pubkeyToAddressAndOu2 = pubkeyToAddressAndOutScript(pubkeyBuf, scriptType), preOutScriptBuf = _pubkeyToAddressAndOu2.outScript; var fullInput = Buffer.concat([preOutScriptBuf, bufferUtil.toVarUintBuffer(blockHashBuf.length), blockHashBuf.reverse(), bufferUtil.toVarUintBuffer(blockHeightBuf.length), blockHeightBuf.reverse(), Buffer.from('b4', 'hex')]); //const fullInputLen = return Buffer.concat([versionBuf, bufferUtil.toVarUintBuffer(1), preOutPointBuf, bufferUtil.toVarUintBuffer(fullInput.length), fullInput, sequenceBuf, outputsCount, outputsBuf, lockTimeBuf, Buffer.from('81000000', 'hex')]); }); return { preparedData: { versionBuf: versionBuf, inputsCount: inputsCount, preparedInputs: preparedInputs, outputType: outputType, outputsCount: outputsCount, outputsBuf: outputsBuf, lockTimeBuf: lockTimeBuf }, unsignedTransactions: unsignedTransactions }; } function composeFinalTransaction(scriptType, preparedData, signatures) { var versionBuf = preparedData.versionBuf, inputsCount = preparedData.inputsCount, preparedInputs = preparedData.preparedInputs, outputsCount = preparedData.outputsCount, outputsBuf = preparedData.outputsBuf, lockTimeBuf = preparedData.lockTimeBuf; if (scriptType !== types.ScriptType.P2PKH && scriptType !== types.ScriptType.P2SH) { throw new _core.error.SDKError(composeFinalTransaction.name, "Unsupport ScriptType '".concat(scriptType, "'")); } var inputsBuf = Buffer.concat(preparedInputs.map(function (data, i) { var pubkeyBuf = data.pubkeyBuf, preOutPointBuf = data.preOutPointBuf, sequenceBuf = data.sequenceBuf; var signature = signatures[i]; var inScript = Buffer.concat([Buffer.from((signature.length + 1).toString(16), 'hex'), signature, Buffer.from('81', 'hex'), Buffer.from(pubkeyBuf.length.toString(16), 'hex'), pubkeyBuf]); return Buffer.concat([preOutPointBuf, bufferUtil.toVarUintBuffer(inScript.length), inScript, sequenceBuf]); })); return Buffer.concat([versionBuf, inputsCount, inputsBuf, outputsCount, outputsBuf, lockTimeBuf]); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/transactionUtil.ts"],"names":["bs58check","require","zencashjs","addressToOutScript","address","decode","prefix","slice","toString","outHash","length","scriptType","outScript","types","ScriptType","P2PKH","Buffer","from","P2SH","error","SDKError","name","pubkeyToAddressAndOutScript","pubkey","pubKeyToAddr","hash","createUnsignedTransactions","inputs","output","change","version","lockTime","versionBuf","bufferUtil","toReverseUintBuffer","lockTimeBuf","inputsCount","toVarUintBuffer","preparedInputs","map","preTxHash","preIndex","sequence","addressIndex","pubkeyBuf","scriptPubKey","preOutPointBuf","concat","reverse","sequenceBuf","scriptLen","scriptPubKeyBuf","blockHashLen","parseInt","blockHashBuf","blockHeightLen","blockHeightBuf","outputType","outputScript","outValue","value","outBlockHashBuf","blockHash","outBlockHeightBuf","blockHeight","outScriptPubKey","outScriptPubKeyLen","outputArray","changeScript","changeValue","changeBlockHashBuf","changeBlockHeightBuf","changeScriptPubKey","changeScriptPubKeyLen","push","outputsCount","outputsBuf","unsignedTransactions","preOutScriptBuf","fullInput","preparedData","composeFinalTransaction","signatures","inputsBuf","data","i","signature","inScript"],"mappings":"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","sourcesContent":["import { error } from '@coolwallet/core';\nimport * as types from '../config/types';\nimport * as bufferUtil from './bufferUtil';\nconst bs58check = require('bs58check');\nconst zencashjs = require('zencashjs');\n\nexport function addressToOutScript(address: string): {\n  scriptType: types.ScriptType;\n  outScript: Buffer;\n  outHash: Buffer;\n} {\n  const decode = bs58check.decode(address);\n  const prefix = decode.slice(0, 2).toString('hex');\n  const outHash = decode.slice(2, decode.length);\n  let scriptType, outScript;\n  if (prefix === '2089') {\n    scriptType = types.ScriptType.P2PKH;\n    outScript = Buffer.from(`76a914${outHash.toString('hex')}88ac`, 'hex');\n  } else if (prefix === '2096') {\n    scriptType = types.ScriptType.P2SH;\n    outScript = Buffer.from(`a914${outHash.toString('hex')}87`, 'hex');\n  } else {\n    throw new error.SDKError(addressToOutScript.name, `Invalid Address '${address}'`);\n  }\n  return { scriptType, outScript, outHash };\n}\n\nexport function pubkeyToAddressAndOutScript(\n  pubkey: Buffer,\n  scriptType: types.ScriptType\n): {\n  address: string;\n  outScript: Buffer;\n  hash: Buffer;\n} {\n  if (scriptType !== types.ScriptType.P2PKH && scriptType !== types.ScriptType.P2SH) {\n    throw new error.SDKError(pubkeyToAddressAndOutScript.name, `Unsupport ScriptType '${scriptType}'`);\n  }\n  const address = zencashjs.address.pubKeyToAddr(pubkey);\n  const { outScript, outHash } = addressToOutScript(address);\n  return { address, outScript, hash: outHash };\n}\n\nexport function createUnsignedTransactions(\n  scriptType: types.ScriptType,\n  inputs: Array<types.Input>,\n  output: types.Output,\n  change: types.Change | undefined,\n  version: number = 1,\n  lockTime: number = 0\n): {\n  preparedData: types.PreparedData;\n  unsignedTransactions: Array<Buffer>;\n} {\n  const versionBuf = bufferUtil.toReverseUintBuffer(version, 4);\n  const lockTimeBuf = bufferUtil.toReverseUintBuffer(lockTime, 4);\n  const inputsCount = bufferUtil.toVarUintBuffer(inputs.length);\n  const preparedInputs = inputs.map(({ preTxHash, preIndex, sequence, addressIndex, pubkeyBuf, scriptPubKey }) => {\n    if (!pubkeyBuf) {\n      throw new error.SDKError(createUnsignedTransactions.name, 'Public Key not exists !!');\n    }\n    const preOutPointBuf = Buffer.concat([\n      Buffer.from(preTxHash, 'hex').reverse(),\n      bufferUtil.toReverseUintBuffer(preIndex, 4),\n    ]);\n    const sequenceBuf = sequence ? bufferUtil.toReverseUintBuffer(sequence, 4) : Buffer.from('ffffffff', 'hex');\n    let scriptLen;\n    const scriptPubKeyBuf = Buffer.from(scriptPubKey, 'hex');\n    if (scriptType == types.ScriptType.P2PKH) {\n      scriptLen = 25;\n    } else {\n      scriptLen = 23;\n    }\n\n    const blockHashLen = parseInt(scriptPubKeyBuf[scriptLen].toString());\n    const blockHashBuf = scriptPubKeyBuf.slice(scriptLen + 1, scriptLen + 1 + blockHashLen);\n    const blockHeightLen = parseInt(scriptPubKeyBuf[scriptLen + 1 + blockHashLen].toString());\n    const blockHeightBuf = scriptPubKeyBuf.slice(\n      scriptLen + 1 + blockHashLen + 1,\n      scriptLen + 1 + blockHashLen + 1 + blockHeightLen\n    );\n    return {\n      addressIndex,\n      pubkeyBuf,\n      preOutPointBuf,\n      sequenceBuf,\n      blockHashBuf,\n      blockHeightBuf,\n    };\n  });\n\n  const { scriptType: outputType, outScript: outputScript } = addressToOutScript(output.address);\n\n  const outValue = bufferUtil.toReverseUintBuffer(output.value, 8);\n  const outBlockHashBuf = Buffer.from(output.blockHash, 'hex').reverse();\n  const outBlockHeightBuf = bufferUtil.toVarUintBuffer(output.blockHeight).reverse();\n  const outScriptPubKey = Buffer.concat([\n    outputScript,\n    bufferUtil.toVarUintBuffer(outBlockHashBuf.length),\n    outBlockHashBuf,\n    bufferUtil.toVarUintBuffer(outBlockHeightBuf.length),\n    outBlockHeightBuf,\n    Buffer.from('b4', 'hex'),\n  ]);\n  const outScriptPubKeyLen = bufferUtil.toVarUintBuffer(outScriptPubKey.length);\n  const outputArray = [Buffer.concat([outValue, outScriptPubKeyLen, outScriptPubKey])];\n  if (change) {\n    if (!change.pubkeyBuf) throw new error.SDKError(createUnsignedTransactions.name, 'Public Key not exists !!');\n\n    const { outScript: changeScript } = pubkeyToAddressAndOutScript(change.pubkeyBuf, scriptType);\n    const changeValue = bufferUtil.toReverseUintBuffer(change.value, 8);\n    const changeBlockHashBuf = Buffer.from(change.blockHash, 'hex');\n    const changeBlockHeightBuf = bufferUtil.toVarUintBuffer(change.blockHeight);\n    const changeScriptPubKey = Buffer.concat([\n      changeScript,\n      bufferUtil.toVarUintBuffer(changeBlockHashBuf.length),\n      changeBlockHashBuf.reverse(),\n      bufferUtil.toVarUintBuffer(changeBlockHeightBuf.length),\n      changeBlockHeightBuf.reverse(),\n      Buffer.from('b4', 'hex'),\n    ]);\n    const changeScriptPubKeyLen = bufferUtil.toVarUintBuffer(changeScriptPubKey.length);\n    outputArray.push(Buffer.concat([changeValue, changeScriptPubKeyLen, changeScriptPubKey]));\n  }\n\n  const outputsCount = bufferUtil.toVarUintBuffer(change ? 2 : 1);\n  const outputsBuf = Buffer.concat(outputArray);\n\n  const unsignedTransactions = preparedInputs.map(\n    ({ pubkeyBuf, preOutPointBuf, sequenceBuf, blockHashBuf, blockHeightBuf }) => {\n      const { outScript: preOutScriptBuf } = pubkeyToAddressAndOutScript(pubkeyBuf, scriptType);\n      const fullInput = Buffer.concat([\n        preOutScriptBuf,\n        bufferUtil.toVarUintBuffer(blockHashBuf.length),\n        blockHashBuf.reverse(),\n        bufferUtil.toVarUintBuffer(blockHeightBuf.length),\n        blockHeightBuf.reverse(),\n        Buffer.from('b4', 'hex'),\n      ]);\n      //const fullInputLen =\n      return Buffer.concat([\n        versionBuf,\n        bufferUtil.toVarUintBuffer(1),\n        preOutPointBuf,\n        bufferUtil.toVarUintBuffer(fullInput.length),\n        fullInput,\n        sequenceBuf,\n        outputsCount,\n        outputsBuf,\n        lockTimeBuf,\n        Buffer.from('81000000', 'hex'),\n      ]);\n    }\n  );\n\n  return {\n    preparedData: {\n      versionBuf,\n      inputsCount,\n      preparedInputs,\n      outputType,\n      outputsCount,\n      outputsBuf,\n      lockTimeBuf,\n    },\n    unsignedTransactions,\n  };\n}\n\nexport function composeFinalTransaction(\n  scriptType: types.ScriptType,\n  preparedData: types.PreparedData,\n  signatures: Array<Buffer>\n): Buffer {\n  const { versionBuf, inputsCount, preparedInputs, outputsCount, outputsBuf, lockTimeBuf } = preparedData;\n\n  if (scriptType !== types.ScriptType.P2PKH && scriptType !== types.ScriptType.P2SH) {\n    throw new error.SDKError(composeFinalTransaction.name, `Unsupport ScriptType '${scriptType}'`);\n  }\n\n  const inputsBuf = Buffer.concat(\n    preparedInputs.map((data, i) => {\n      const { pubkeyBuf, preOutPointBuf, sequenceBuf } = data;\n      const signature = signatures[i];\n      const inScript = Buffer.concat([\n        Buffer.from((signature.length + 1).toString(16), 'hex'),\n        signature,\n        Buffer.from('81', 'hex'),\n        Buffer.from(pubkeyBuf.length.toString(16), 'hex'),\n        pubkeyBuf,\n      ]);\n      return Buffer.concat([preOutPointBuf, bufferUtil.toVarUintBuffer(inScript.length), inScript, sequenceBuf]);\n    })\n  );\n  return Buffer.concat([versionBuf, inputsCount, inputsBuf, outputsCount, outputsBuf, lockTimeBuf]);\n}\n"]}