forked from ethereumjs/ethereumjs-monorepo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtransactions.ts
67 lines (53 loc) · 2.76 KB
/
transactions.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// This files contain examples on how to use this module.
// You can run them with tsx, as this project is developed in TypeScript.
// Install the dependencies and run `npx tsx examples/transactions.ts`
import { createLegacyTx, createLegacyTxFromBytesArray } from '@ethereumjs/tx'
import { bytesToHex, hexToBytes, toBytes } from '@ethereumjs/util'
// We create an unsigned transaction.
// Notice we don't set the `to` field because we are creating a new contract.
// This transaction's chain is set to mainnet.
const tx = createLegacyTx({
nonce: 0,
gasPrice: 100,
gasLimit: 1000000000,
value: 0,
data: '0x7f4e616d65526567000000000000000000000000000000000000000000000000003057307f4e616d6552656700000000000000000000000000000000000000000000000000573360455760415160566000396000f20036602259604556330e0f600f5933ff33560f601e5960003356576000335700604158600035560f602b590033560f60365960003356573360003557600035335700',
})
// We sign the transaction with this private key.
const privateKey = hexToBytes('0xe331b6d69882b4cb4ea581d88e0b604039a3de5967688d3dcffdd2270c0fd109')
const signedTx = tx.sign(privateKey)
// We have a signed transaction.
// In order to send the transaction, the account that we signed it with needs to have a certain amount of wei in to.
// To see how much this account needs we can use the getUpfrontCost() method.
const feeCost = signedTx.getUpfrontCost()
console.log('Total Amount of wei needed:' + feeCost.toString())
// Lets serialize the transaction
console.log('---Serialized TX----')
console.log(bytesToHex(signedTx.serialize()))
console.log('--------------------')
// Parsing & Validating Transactions
// If you have a transaction that you want to verify you can parse it.
// If you got it directly from the network it will be rlp encoded.
// You can decode it with the rlp module.
// After that you should have something like:
const rawTx = [
'0x',
'0x09184e72a000',
'0x2710',
'0x0000000000000000000000000000000000000000',
'0x',
'0x7f7465737432000000000000000000000000000000000000000000000000000000600057',
'0x1c',
'0x5e1d3a76fbf824220eafc8c79ad578ad2b67d01b0c2425eb1f1347e8f50882ab',
'0x5bd428537f05f9830e93792f90ea6a3e2d1ee84952dd96edbae9f658f831ab13',
]
const tx2 = createLegacyTxFromBytesArray(rawTx.map(toBytes)) // This is also a mainnet transaction
// So assuming that you were able to parse the transaction, we will now get the sender's address.
console.log('Senders Address: ' + tx2.getSenderAddress().toString())
// Cool now we know who sent the tx!
// Let's verify the signature to make sure it was not some poser.
if (tx2.verifySignature()) {
console.log('Signature Checks out!')
}
// And hopefully it's verified. For the transaction to be totally valid we would
// also need to check the account of the sender and see if they have enough funds.