2019-08-05 23:03:41 +03:00
|
|
|
import
|
2021-04-06 13:33:24 +02:00
|
|
|
nimcrypto/keccak,
|
|
|
|
".."/[common, rlp, keys]
|
2019-08-05 23:03:41 +03:00
|
|
|
|
|
|
|
const
|
2021-05-14 22:34:32 +07:00
|
|
|
EIP155_CHAIN_ID_OFFSET* = 35'i64
|
2019-08-05 23:03:41 +03:00
|
|
|
|
2021-06-26 15:18:42 +07:00
|
|
|
func rlpEncodeLegacy(tx: Transaction): auto =
|
|
|
|
var w = initRlpWriter()
|
|
|
|
w.startList(6)
|
|
|
|
w.append(tx.nonce)
|
|
|
|
w.append(tx.gasPrice)
|
|
|
|
w.append(tx.gasLimit)
|
|
|
|
w.append(tx.to)
|
|
|
|
w.append(tx.value)
|
|
|
|
w.append(tx.payload)
|
|
|
|
w.finish()
|
2019-08-05 23:03:41 +03:00
|
|
|
|
2021-06-26 15:18:42 +07:00
|
|
|
func rlpEncodeEip155(tx: Transaction): auto =
|
|
|
|
let chainId = (tx.V - EIP155_CHAIN_ID_OFFSET) div 2
|
|
|
|
var w = initRlpWriter()
|
|
|
|
w.startList(9)
|
|
|
|
w.append(tx.nonce)
|
|
|
|
w.append(tx.gasPrice)
|
|
|
|
w.append(tx.gasLimit)
|
|
|
|
w.append(tx.to)
|
|
|
|
w.append(tx.value)
|
|
|
|
w.append(tx.payload)
|
|
|
|
w.append(chainId)
|
|
|
|
w.append(0)
|
|
|
|
w.append(0)
|
|
|
|
w.finish()
|
2019-08-05 23:03:41 +03:00
|
|
|
|
2021-06-26 15:18:42 +07:00
|
|
|
func rlpEncodeEip2930(tx: Transaction): auto =
|
|
|
|
var w = initRlpWriter()
|
|
|
|
w.append(1)
|
|
|
|
w.startList(8)
|
|
|
|
w.append(tx.chainId.uint64)
|
|
|
|
w.append(tx.nonce)
|
|
|
|
w.append(tx.gasPrice)
|
|
|
|
w.append(tx.gasLimit)
|
|
|
|
w.append(tx.to)
|
|
|
|
w.append(tx.value)
|
|
|
|
w.append(tx.payload)
|
|
|
|
w.append(tx.accessList)
|
|
|
|
w.finish()
|
2021-05-15 14:26:51 +07:00
|
|
|
|
2021-06-26 15:18:42 +07:00
|
|
|
func rlpEncodeEip1559(tx: Transaction): auto =
|
|
|
|
var w = initRlpWriter()
|
|
|
|
w.append(2)
|
|
|
|
w.startList(9)
|
|
|
|
w.append(tx.chainId.uint64)
|
|
|
|
w.append(tx.nonce)
|
|
|
|
w.append(tx.maxPriorityFee)
|
|
|
|
w.append(tx.maxFee)
|
|
|
|
w.append(tx.gasLimit)
|
|
|
|
w.append(tx.to)
|
|
|
|
w.append(tx.value)
|
|
|
|
w.append(tx.payload)
|
|
|
|
w.append(tx.accessList)
|
|
|
|
w.finish()
|
2021-05-15 14:26:51 +07:00
|
|
|
|
2021-06-26 15:18:42 +07:00
|
|
|
func rlpEncode*(tx: Transaction): auto =
|
|
|
|
case tx.txType
|
|
|
|
of TxLegacy:
|
|
|
|
if tx.V >= EIP155_CHAIN_ID_OFFSET:
|
|
|
|
tx.rlpEncodeEIP155
|
|
|
|
else:
|
|
|
|
tx.rlpEncodeLegacy
|
|
|
|
of TxEip2930:
|
|
|
|
tx.rlpEncodeEip2930
|
|
|
|
of TxEip1559:
|
|
|
|
tx.rlpEncodeEip1559
|
2021-05-14 22:34:32 +07:00
|
|
|
|
|
|
|
func txHashNoSignature*(tx: Transaction): Hash256 =
|
2021-06-26 15:18:42 +07:00
|
|
|
# Hash transaction without signature
|
|
|
|
keccak256.digest(rlpEncode(tx))
|