UNPKG

@coolwallet/sol

Version:
140 lines (139 loc) 17.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.signAllTransactions = signAllTransactions; exports.signMessage = signMessage; exports.signTransaction = signTransaction; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _core = require("@coolwallet/core"); var _message = require("./message"); var _Transaction = require("./utils/Transaction"); var _versionedTransaction = require("./utils/versionedTransaction"); var _scriptUtil = require("./utils/scriptUtil"); var _transaction = require("@coolwallet/core/lib/transaction"); function executeScriptWithPreActions(_x, _x2, _x3) { return _executeScriptWithPreActions.apply(this, arguments); } function _executeScriptWithPreActions() { _executeScriptWithPreActions = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(signData, script, argument) { var transport, appPrivateKey, appId, confirmCB, authorizedCB, preActions, action; return _regenerator["default"].wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: transport = signData.transport, appPrivateKey = signData.appPrivateKey, appId = signData.appId, confirmCB = signData.confirmCB, authorizedCB = signData.authorizedCB; preActions = [function () { return _core.apdu.tx.sendScript(transport, script); }]; action = function action() { return _core.apdu.tx.executeScript(transport, appId, appPrivateKey, argument); }; return _context.abrupt("return", _core.tx.flow.getSingleSignatureFromCoolWalletV2(transport, preActions, action, confirmCB, authorizedCB, _transaction.SignatureType.EDDSA)); case 4: case "end": return _context.stop(); } } }, _callee); })); return _executeScriptWithPreActions.apply(this, arguments); } function signAllTransactions(_x4, _x5) { return _signAllTransactions.apply(this, arguments); } function _signAllTransactions() { _signAllTransactions = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2(signTxData, preActions) { var transport, confirmCB, authorizedCB, _yield$getScriptSigni, actions, signatures; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: transport = signTxData.transport, confirmCB = signTxData.confirmCB, authorizedCB = signTxData.authorizedCB; _context2.next = 3; return (0, _scriptUtil.getScriptSigningActions)(signTxData); case 3: _yield$getScriptSigni = _context2.sent; actions = _yield$getScriptSigni.actions; _context2.next = 7; return _core.tx.flow.getSignaturesFromCoolWalletV2(transport, preActions, actions, confirmCB, authorizedCB, _transaction.SignatureType.EDDSA); case 7: signatures = _context2.sent; return _context2.abrupt("return", signatures.map(function (signature) { return new Uint8Array(signature); })); case 9: case "end": return _context2.stop(); } } }, _callee2); })); return _signAllTransactions.apply(this, arguments); } function signTransaction(_x6, _x7, _x8, _x9) { return _signTransaction.apply(this, arguments); } function _signTransaction() { _signTransaction = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3(signTxData, rawTx, script, argument) { var signature, signatureUint8Arrays, serializedTransaction; return _regenerator["default"].wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: _context3.next = 2; return executeScriptWithPreActions(signTxData, script, argument); case 2: signature = _context3.sent; if (!(rawTx instanceof _message.Message || rawTx instanceof _message.MessageV0)) { _context3.next = 10; break; } signatureUint8Arrays = signTxData.transaction.signatures; signatureUint8Arrays[0] = new Uint8Array(signature); serializedTransaction = new _versionedTransaction.VersionedTransaction(rawTx, signatureUint8Arrays).serialize(); return _context3.abrupt("return", Buffer.from(serializedTransaction).toString('hex')); case 10: if (!(rawTx instanceof _Transaction.Transaction)) { _context3.next = 14; break; } return _context3.abrupt("return", rawTx.toTxString(signature.toString('hex'))); case 14: throw new Error('Invalid transaction type'); case 15: case "end": return _context3.stop(); } } }, _callee3); })); return _signTransaction.apply(this, arguments); } function signMessage(_x10, _x11, _x12) { return _signMessage.apply(this, arguments); } function _signMessage() { _signMessage = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4(signMsgData, script, argument) { var signature; return _regenerator["default"].wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: _context4.next = 2; return executeScriptWithPreActions(signMsgData, script, argument); case 2: signature = _context4.sent; return _context4.abrupt("return", signature.toString('hex')); case 4: case "end": return _context4.stop(); } } }, _callee4); })); return _signMessage.apply(this, arguments); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_core","require","_message","_Transaction","_versionedTransaction","_scriptUtil","_transaction","executeScriptWithPreActions","_x","_x2","_x3","_executeScriptWithPreActions","apply","arguments","_asyncToGenerator2","_regenerator","mark","_callee","signData","script","argument","transport","appPrivateKey","appId","confirmCB","authorizedCB","preActions","action","wrap","_callee$","_context","prev","next","apdu","tx","sendScript","executeScript","abrupt","flow","getSingleSignatureFromCoolWalletV2","SignatureType","EDDSA","stop","signAllTransactions","_x4","_x5","_signAllTransactions","_callee2","signTxData","_yield$getScriptSigni","actions","signatures","_callee2$","_context2","getScriptSigningActions","sent","getSignaturesFromCoolWalletV2","map","signature","Uint8Array","signTransaction","_x6","_x7","_x8","_x9","_signTransaction","_callee3","rawTx","signatureUint8Arrays","serializedTransaction","_callee3$","_context3","Message","MessageV0","transaction","VersionedTransaction","serialize","Buffer","from","toString","Transaction","toTxString","Error","signMessage","_x10","_x11","_x12","_signMessage","_callee4","signMsgData","_callee4$","_context4"],"sources":["../src/sign.ts"],"sourcesContent":["import { tx, apdu } from '@coolwallet/core';\nimport * as types from './config/types';\nimport { Message, MessageV0, VersionedMessage } from './message';\n\nimport { Transaction } from './utils/Transaction';\nimport { VersionedTransaction } from './utils/versionedTransaction';\nimport { getScriptSigningActions } from './utils/scriptUtil';\nimport { SignatureType } from '@coolwallet/core/lib/transaction';\nimport { signVersionedTransactionType } from './config/types';\n\nasync function executeScriptWithPreActions(\n  signData: types.SignDataType,\n  script: string,\n  argument: string\n): Promise<Buffer | { r: string; s: string }> {\n  const { transport, appPrivateKey, appId, confirmCB, authorizedCB } = signData;\n\n  const preActions = [() => apdu.tx.sendScript(transport, script)];\n  const action = () => apdu.tx.executeScript(transport, appId, appPrivateKey, argument);\n\n  return tx.flow.getSingleSignatureFromCoolWalletV2(\n    transport,\n    preActions,\n    action,\n    confirmCB,\n    authorizedCB,\n    SignatureType.EDDSA\n  );\n}\n\nasync function signAllTransactions(\n  signTxData: types.signVersionedTransactions,\n  preActions: Array<() => Promise<void>>\n): Promise<Array<Uint8Array>> {\n  const { transport, confirmCB, authorizedCB } = signTxData;\n  const { actions } = await getScriptSigningActions(signTxData);\n  const signatures = (await tx.flow.getSignaturesFromCoolWalletV2(\n    transport,\n    preActions,\n    actions,\n    confirmCB,\n    authorizedCB,\n    SignatureType.EDDSA\n  )) as Array<Buffer>;\n\n  return signatures.map((signature) => {\n    return new Uint8Array(signature);\n  });\n}\n\nasync function signTransaction(\n  signTxData: types.signTxType,\n  rawTx: Transaction | VersionedMessage,\n  script: string,\n  argument: string\n): Promise<string> {\n  const signature = (await executeScriptWithPreActions(signTxData, script, argument)) as Buffer;\n  if (rawTx instanceof Message || rawTx instanceof MessageV0) {\n    const signatureUint8Arrays = (signTxData as signVersionedTransactionType).transaction.signatures;\n    signatureUint8Arrays[0] = new Uint8Array(signature);\n    const serializedTransaction = new VersionedTransaction(rawTx, signatureUint8Arrays).serialize();\n    return Buffer.from(serializedTransaction).toString('hex');\n  } else if (rawTx instanceof Transaction) {\n    return rawTx.toTxString(signature.toString('hex'));\n  } else {\n    throw new Error('Invalid transaction type');\n  }\n}\n\nasync function signMessage(signMsgData: types.signMsgType, script: string, argument: string): Promise<string> {\n  const signature = await executeScriptWithPreActions(signMsgData, script, argument);\n  return signature.toString('hex');\n}\nexport { signTransaction, signMessage, signAllTransactions };\n"],"mappings":"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","ignoreList":[]}