2025-04-19 15:38:48 +08:00

26 lines
1.1 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.validateYParity = exports.serialize = exports.getHashedMessageToSign = void 0;
const rlp_1 = require("@ethereumjs/rlp");
const util_1 = require("@ethereumjs/util");
const keccak_js_1 = require("ethereum-cryptography/keccak.js");
const util_js_1 = require("../util.js");
const legacy_js_1 = require("./legacy.js");
function getHashedMessageToSign(tx) {
const keccakFunction = tx.common.customCrypto.keccak256 ?? keccak_js_1.keccak256;
return keccakFunction(tx.getMessageToSign());
}
exports.getHashedMessageToSign = getHashedMessageToSign;
function serialize(tx, base) {
return (0, util_1.concatBytes)((0, util_js_1.txTypeBytes)(tx.type), rlp_1.RLP.encode(base ?? tx.raw()));
}
exports.serialize = serialize;
function validateYParity(tx) {
const { v } = tx;
if (v !== undefined && v !== util_1.BIGINT_0 && v !== util_1.BIGINT_1) {
const msg = (0, legacy_js_1.errorMsg)(tx, 'The y-parity of the transaction should either be 0 or 1');
throw new Error(msg);
}
}
exports.validateYParity = validateYParity;
//# sourceMappingURL=eip2718.js.map