LegacyTransaction
An Ethereum non-typed (legacy) transaction
Extends
BaseTransaction
<Legacy
>
Constructors
new LegacyTransaction()
new LegacyTransaction(
txData
,opts
?):LegacyTransaction
This constructor takes the values, validates them, assigns them and freezes the object.
It is not recommended to use this constructor directly. Instead use the static factory methods to assist in creating a Transaction object from varying data types.
Parameters
• txData: LegacyTxData
• opts?: TxOptions
Returns
Overrides
BaseTransaction<TransactionType.Legacy>.constructor
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:42
Properties
_type
protected
readonly
_type:TransactionType
Inherited from
BaseTransaction._type
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:14
activeCapabilities
protected
activeCapabilities:number
[]
List of tx type defining EIPs, e.g. 1559 (fee market) and 2930 (access lists) for FeeMarketEIP1559Transaction objects
Inherited from
BaseTransaction.activeCapabilities
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:31
cache
cache:
TransactionCache
Inherited from
BaseTransaction.cache
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:24
common
readonly
common:Common
Overrides
BaseTransaction.common
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:12
data
readonly
data:Uint8Array
Inherited from
BaseTransaction.data
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:19
gasLimit
readonly
gasLimit:bigint
Inherited from
BaseTransaction.gasLimit
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:16
gasPrice
readonly
gasPrice:bigint
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:11
nonce
readonly
nonce:bigint
Inherited from
BaseTransaction.nonce
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:15
r?
readonly
optional
r:bigint
Inherited from
BaseTransaction.r
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:21
s?
readonly
optional
s:bigint
Inherited from
BaseTransaction.s
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:22
to?
readonly
optional
to:EthjsAddress
Inherited from
BaseTransaction.to
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:17
txOptions
protected
readonly
txOptions:TxOptions
Inherited from
BaseTransaction.txOptions
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:25
v?
readonly
optional
v:bigint
Inherited from
BaseTransaction.v
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:20
value
readonly
value:bigint
Inherited from
BaseTransaction.value
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:18
Accessors
type
get
type():TransactionType
Returns the transaction type.
Note: legacy txs will return tx type 0
.
Returns
Inherited from
BaseTransaction.type
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:47
Methods
_getSharedErrorPostfix()
protected
_getSharedErrorPostfix():string
Returns the shared error postfix part for _error() method tx type implementations.
Returns
string
Inherited from
BaseTransaction._getSharedErrorPostfix
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:189
_validateCannotExceedMaxInteger()
protected
_validateCannotExceedMaxInteger(values
,bits
?,cannotEqual
?):void
Validates that an object with BigInt values cannot exceed the specified bit limit.
Parameters
• values
Object containing string keys and BigInt values
• bits?: number
Number of bits to check (64 or 256)
• cannotEqual?: boolean
Pass true if the number also cannot equal one less the maximum value
Returns
void
Inherited from
BaseTransaction._validateCannotExceedMaxInteger
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:168
_validateTxV()
protected
_validateTxV(_v
?,common
?):Common
Validates tx’s v
value
Parameters
• _v?: bigint
• common?: Common
Returns
Common
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:118
addSignature()
addSignature(
v
,r
,s
,convertV
?):LegacyTransaction
Returns a new transaction with the same data fields as the current, but now signed
Parameters
• v: bigint
The v
value of the signature
• r: bigint
| Uint8Array
The r
value of the signature
• s: bigint
| Uint8Array
The s
value of the signature
• convertV?: boolean
Set this to true
if the raw output of ecsign
is used. If this is false
(default)
then the raw value passed for v
will be used for the signature. For legacy transactions,
if this is set to true
, it will also set the right v
value for the chain id.
Returns
Overrides
BaseTransaction.addSignature
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:110
errorStr()
errorStr():
string
Return a compact error string representation of the object
Returns
string
Overrides
BaseTransaction.errorStr
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:122
getBaseFee()
getBaseFee():
bigint
The minimum amount of gas the tx must have (DataFee + TxFee + Creation Fee)
Returns
bigint
Inherited from
BaseTransaction.getBaseFee
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:78
getDataFee()
getDataFee():
bigint
The amount of gas paid for the data in this tx
Returns
bigint
Overrides
BaseTransaction.getDataFee
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:90
getEffectivePriorityFee()
getEffectivePriorityFee(
baseFee
?):bigint
Returns the effective priority fee. This is the priority fee which the coinbase will receive once it is included in the block
Parameters
• baseFee?: bigint
Optional baseFee of the block. Note for EIP1559 and EIP4844 this is required.
Returns
bigint
Overrides
BaseTransaction.getEffectivePriorityFee
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:43
getHashedMessageToSign()
getHashedMessageToSign():
Uint8Array
Returns the hashed serialized unsigned tx, which can be used to sign the transaction (e.g. for sending to a hardware wallet).
Returns
Uint8Array
Overrides
BaseTransaction.getHashedMessageToSign
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:86
getMessageToSign()
getMessageToSign():
Uint8Array
[]
Returns the raw unsigned tx, which can be used to sign the transaction (e.g. for sending to a hardware wallet).
Note: the raw message message format for the legacy tx is not RLP encoded and you might need to do yourself with:
Returns
Uint8Array
[]
Overrides
BaseTransaction.getMessageToSign
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:81
getMessageToVerifySignature()
getMessageToVerifySignature():
Uint8Array
Computes a sha3-256 hash which can be used to verify the signature
Returns
Uint8Array
Overrides
BaseTransaction.getMessageToVerifySignature
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:105
getSenderAddress()
getSenderAddress():
EthjsAddress
Returns the sender’s address
Returns
Inherited from
BaseTransaction.getSenderAddress
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:124
getSenderPublicKey()
getSenderPublicKey():
Uint8Array
Returns the public key of the sender
Returns
Uint8Array
Overrides
BaseTransaction.getSenderPublicKey
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:109
getUpfrontCost()
getUpfrontCost():
bigint
The up front amount that an account must have for this transaction to be valid
Returns
bigint
Overrides
BaseTransaction.getUpfrontCost
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:94
getValidationErrors()
getValidationErrors():
string
[]
Validates the transaction signature and minimum gas requirements.
Returns
string
[]
an array of error strings
Inherited from
BaseTransaction.getValidationErrors
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:69
hash()
hash():
Uint8Array
Computes a sha3-256 hash of the serialized tx.
This method can only be used for signed txs (it throws otherwise). Use Transaction.getMessageToSign to get a tx hash for the purpose of signing.
Returns
Uint8Array
Overrides
BaseTransaction.hash
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:101
isSigned()
isSigned():
boolean
Returns
boolean
Inherited from
BaseTransaction.isSigned
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:116
isValid()
isValid():
boolean
Validates the transaction signature and minimum gas requirements.
Returns
boolean
true if the transaction is valid, false otherwise
Inherited from
BaseTransaction.isValid
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:74
raw()
raw():
LegacyTxValuesArray
Returns a Uint8Array Array of the raw Bytes of the legacy transaction, in order.
Format: [nonce, gasPrice, gasLimit, to, value, data, v, r, s]
For legacy txs this is also the correct format to add transactions
to a block with Block.fromValuesArray (use the serialize()
method
for typed txs).
For an unsigned tx this method returns the empty Bytes values
for the signature parameters v
, r
and s
. For an EIP-155 compliant
representation have a look at Transaction.getMessageToSign.
Returns
LegacyTxValuesArray
Overrides
BaseTransaction.raw
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:57
serialize()
serialize():
Uint8Array
Returns the serialized encoding of the legacy transaction.
Format: rlp([nonce, gasPrice, gasLimit, to, value, data, v, r, s])
For an unsigned tx this method uses the empty Uint8Array values for the
signature parameters v
, r
and s
for encoding. For an EIP-155 compliant
representation for external signing use Transaction.getMessageToSign.
Returns
Uint8Array
Overrides
BaseTransaction.serialize
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:67
sign()
sign(
privateKey
):LegacyTransaction
Signs a transaction.
Note that the signed tx is returned as a new object, use as follows:
Parameters
• privateKey: Uint8Array
Returns
Inherited from
BaseTransaction.sign
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:138
supports()
supports(
capability
):boolean
Checks if a tx type defining capability is active on a tx, for example the EIP-1559 fee market mechanism or the EIP-2930 access list feature.
Note that this is different from the tx type itself, so EIP-2930 access lists can very well be active on an EIP-1559 tx for example.
This method can be useful for feature checks if the tx type is unknown (e.g. when instantiated with the tx factory).
See Capabilities
in the types
module for a reference
on all supported capabilities.
Parameters
• capability: Capability
Returns
boolean
Inherited from
BaseTransaction.supports
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:64
toCreationAddress()
toCreationAddress():
boolean
If the tx’s to
is to the creation address
Returns
boolean
Inherited from
BaseTransaction.toCreationAddress
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:96
toJSON()
toJSON():
JsonTx
Returns an object with the JSON representation of the transaction.
Returns
Overrides
BaseTransaction.toJSON
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:114
verifySignature()
verifySignature():
boolean
Determines if the signature is valid
Returns
boolean
Inherited from
BaseTransaction.verifySignature
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:120
_validateNotArray()
protected
static
_validateNotArray(values
):void
Parameters
• values
Returns
void
Inherited from
BaseTransaction._validateNotArray
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/baseTransaction.d.ts:171
fromSerializedTx()
static
fromSerializedTx(serialized
,opts
?):LegacyTransaction
Instantiate a transaction from the serialized tx.
Format: rlp([nonce, gasPrice, gasLimit, to, value, data, v, r, s])
Parameters
• serialized: Uint8Array
• opts?: TxOptions
Returns
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:28
fromTxData()
static
fromTxData(txData
,opts
?):LegacyTransaction
Instantiate a transaction from a data dictionary.
Format: { nonce, gasPrice, gasLimit, to, value, data, v, r, s }
Notes:
- All parameters are optional and have some basic default values
Parameters
• txData: LegacyTxData
• opts?: TxOptions
Returns
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:22
fromValuesArray()
static
fromValuesArray(values
,opts
?):LegacyTransaction
Create a transaction from a values array.
Format: [nonce, gasPrice, gasLimit, to, value, data, v, r, s]
Parameters
• values: LegacyTxValuesArray
• opts?: TxOptions
Returns
Defined in
node_modules/.pnpm/@ethereumjs+tx@5.4.0/node_modules/@ethereumjs/tx/dist/esm/legacyTransaction.d.ts:34