UNPKG

@meterio/devkit

Version:

Typescript library to aid DApp development on Meter network

238 lines 17.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Transaction = void 0; const address_1 = require("./cry/address"); const blake2b_1 = require("./cry/blake2b"); const secp256k1_1 = require("./cry/secp256k1"); const rlp_1 = require("./rlp"); /** Transaction class defines Meter's multi-clause transaction */ class Transaction { /** decode from Buffer to transaction * @param raw encoded buffer * @param unsigned to indicator if the encoded buffer contains signature */ static decode(raw, unsigned) { let body; let signature; if (unsigned) { body = unsignedTxRLP.decode(raw); } else { const decoded = txRLP.decode(raw); signature = decoded.signature; delete decoded.signature; body = decoded; } const reserved = body.reserved; if (reserved.length > 0) { if (reserved[reserved.length - 1].length === 0) { throw new Error('invalid reserved fields: not trimmed'); } const features = featuresKind.buffer(reserved[0], 'reserved.features').decode(); body.reserved = { features, }; if (reserved.length > 1) { body.reserved.unused = reserved.slice(1); } } else { delete body.reserved; } const tx = new Transaction(body); if (signature) { tx.signature = signature; } return tx; } /** * construct a transaction object with given body * @param body body of tx */ constructor(body) { this.body = Object.assign({}, body); } /** * returns transaction ID * null returned if something wrong (e.g. invalid signature) */ get id() { if (!this._signatureValid) { return null; } try { const signingHash = this.signingHash(); const pubKey = secp256k1_1.secp256k1.recover(signingHash, this.signature.slice(0, 65)); const origin = (0, address_1.publicKeyToAddress)(pubKey); return '0x' + (0, blake2b_1.blake2b256)(signingHash, origin).toString('hex'); } catch (_a) { return null; } } /** * compute signing hashes. * It returns tx hash for origin or delegator depends on param `delegateFor`. * @param delegateFor address of intended tx origin. If set, the returned hash is for delegator to sign. */ signingHash(delegateFor) { const reserved = this._encodeReserved(); const buf = unsignedTxRLP.encode(Object.assign(Object.assign({}, this.body), { reserved })); const hash = (0, blake2b_1.blake2b256)(buf); if (delegateFor) { if (!/^0x[0-9a-f]{40}$/i.test(delegateFor)) { throw new Error('delegateFor expected address'); } return (0, blake2b_1.blake2b256)(hash, Buffer.from(delegateFor.slice(2), 'hex')); } return hash; } /** returns tx origin. null returned if no signature or not incorrectly signed */ get origin() { if (!this._signatureValid) { return null; } try { const signingHash = this.signingHash(); const pubKey = secp256k1_1.secp256k1.recover(signingHash, this.signature.slice(0, 65)); return '0x' + (0, address_1.publicKeyToAddress)(pubKey).toString('hex'); } catch (_a) { return null; } } /** returns tx delegator. null returned if no signature or not incorrectly signed */ get delegator() { if (!this.delegated) { return null; } if (!this._signatureValid) { return null; } const origin = this.origin; if (!origin) { return null; } try { const signingHash = this.signingHash(origin); const pubKey = secp256k1_1.secp256k1.recover(signingHash, this.signature.slice(65)); return '0x' + (0, address_1.publicKeyToAddress)(pubKey).toString('hex'); } catch (_a) { return null; } } /** returns whether delegated. see https://github.com/dfinlab/VIPs/blob/master/vips/VIP-191.md */ get delegated() { return ((((this.body.reserved || {}).features || 0) & Transaction.DELEGATED_MASK) === Transaction.DELEGATED_MASK); } /** returns intrinsic gas it takes */ get intrinsicGas() { return Transaction.intrinsicGas(this.body.clauses); } /** encode into Buffer */ encode() { const reserved = this._encodeReserved(); if (this.signature) { return txRLP.encode(Object.assign(Object.assign({}, this.body), { reserved, signature: this.signature })); } return unsignedTxRLP.encode(Object.assign(Object.assign({}, this.body), { reserved })); } _encodeReserved() { const reserved = this.body.reserved || {}; const list = [ featuresKind.data(reserved.features || 0, 'reserved.features').encode(), ...(reserved.unused || []), ]; // trim while (list.length > 0) { if (list[list.length - 1].length === 0) { list.pop(); } else { break; } } return list; } get _signatureValid() { const expectedSigLen = this.delegated ? 65 * 2 : 65; return this.signature ? this.signature.length === expectedSigLen : false; } } Transaction.DELEGATED_MASK = 1; exports.Transaction = Transaction; (function (Transaction) { /** * calculates intrinsic gas that a tx costs with the given clauses. * @param clauses */ function intrinsicGas(clauses) { const txGas = 5000; const clauseGas = 16000; const clauseGasContractCreation = 48000; if (clauses.length === 0) { return txGas + clauseGas; } return clauses.reduce((sum, c) => { if (c.to) { sum += clauseGas; } else { sum += clauseGasContractCreation; } sum += dataGas(c.data); return sum; }, txGas); } Transaction.intrinsicGas = intrinsicGas; function dataGas(data) { const zgas = 4; const nzgas = 68; let sum = 0; for (let i = 2; i < data.length; i += 2) { if (data.substr(i, 2) === '00') { sum += zgas; } else { sum += nzgas; } } return sum; } })(Transaction = exports.Transaction || (exports.Transaction = {})); exports.Transaction = Transaction; const unsignedTxRLP = new rlp_1.RLP({ name: 'tx', kind: [ { name: 'chainTag', kind: new rlp_1.RLP.NumericKind(1) }, { name: 'blockRef', kind: new rlp_1.RLP.CompactFixedBlobKind(8) }, { name: 'expiration', kind: new rlp_1.RLP.NumericKind(4) }, { name: 'clauses', kind: { item: [ { name: 'to', kind: new rlp_1.RLP.NullableFixedBlobKind(20) }, { name: 'value', kind: new rlp_1.RLP.NumericKind(32) }, { name: 'token', kind: new rlp_1.RLP.NumericKind(1) }, { name: 'data', kind: new rlp_1.RLP.BlobKind() }, ], }, }, { name: 'gasPriceCoef', kind: new rlp_1.RLP.NumericKind(1) }, { name: 'gas', kind: new rlp_1.RLP.NumericKind(8) }, { name: 'dependsOn', kind: new rlp_1.RLP.NullableFixedBlobKind(32) }, { name: 'nonce', kind: new rlp_1.RLP.NumericKind(8) }, { name: 'reserved', kind: { item: new rlp_1.RLP.BufferKind() } }, ], }); const txRLP = new rlp_1.RLP({ name: 'tx', kind: [ ...unsignedTxRLP.profile.kind, { name: 'signature', kind: new rlp_1.RLP.BufferKind() }, ], }); const featuresKind = new rlp_1.RLP.NumericKind(4); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../src/transaction.ts"],"names":[],"mappings":"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"}