Documentation ¶
Index ¶
- Constants
- Variables
- func BigCmp(a, b BigInt) int
- func BigDivFloat(num, den BigInt) float64
- func DecodeHexString(s string) ([]byte, error)
- func DecodeHexStringTrimSpace(s string) ([]byte, error)
- func DecodeRLP(data []byte) (interface{}, error)
- func EncodeRLP(val interface{}) ([]byte, error)
- func EthAddressFromPubKey(pubk []byte) ([]byte, error)
- func EthBloomSet(f EthBytes, data []byte)
- func IsEthAddress(addr address.Address) bool
- func One[R any](r R, err error) R
- func SetEip155ChainID(val int)
- type Actor
- type ActorV4
- type ActorV5
- type BigInt
- type ChainMsg
- type Eth1559TxArgs
- func (tx *Eth1559TxArgs) InitialiseSignature(sig typescrypto.Signature) error
- func (tx *Eth1559TxArgs) Sender() (address.Address, error)
- func (tx *Eth1559TxArgs) Signature() (*typescrypto.Signature, error)
- func (tx *Eth1559TxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
- func (tx *Eth1559TxArgs) ToRlpSignedMsg() ([]byte, error)
- func (tx *Eth1559TxArgs) ToRlpUnsignedMsg() ([]byte, error)
- func (tx *Eth1559TxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
- func (tx *Eth1559TxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
- func (tx *Eth1559TxArgs) TxHash() (EthHash, error)
- func (tx *Eth1559TxArgs) Type() int
- type EthAddress
- func CastEthAddress(b []byte) (EthAddress, error)
- func EthAddressFromActorID(id abi.ActorID) EthAddress
- func EthAddressFromFilecoinAddress(addr address.Address) (EthAddress, error)
- func GetContractEthAddressFromCode(sender EthAddress, salt [32]byte, initcode []byte) (EthAddress, error)
- func ParseEthAddress(s string) (EthAddress, error)
- func TryEthAddressFromFilecoinAddress(addr address.Address, allowID bool) (EthAddress, bool, error)
- type EthAddressList
- type EthBigInt
- type EthBlock
- type EthBlockNumberOrHash
- type EthBytes
- type EthCall
- type EthCallTraceAction
- type EthCallTraceResult
- type EthCreateTraceAction
- type EthCreateTraceResult
- type EthEstimateGasParams
- type EthFeeHistory
- type EthFeeHistoryParams
- type EthFilterID
- type EthFilterResult
- type EthFilterSpec
- type EthHash
- type EthHashList
- type EthLegacy155TxArgs
- func (tx *EthLegacy155TxArgs) GetLegacyTx() *EthLegacyHomesteadTxArgs
- func (tx *EthLegacy155TxArgs) InitialiseSignature(sig typescrypto.Signature) error
- func (tx *EthLegacy155TxArgs) Sender() (address.Address, error)
- func (tx *EthLegacy155TxArgs) Signature() (*typescrypto.Signature, error)
- func (tx *EthLegacy155TxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
- func (tx *EthLegacy155TxArgs) ToRawTxBytesSigned() ([]byte, error)
- func (tx *EthLegacy155TxArgs) ToRlpSignedMsg() ([]byte, error)
- func (tx *EthLegacy155TxArgs) ToRlpUnsignedMsg() ([]byte, error)
- func (tx *EthLegacy155TxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
- func (tx *EthLegacy155TxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
- func (tx *EthLegacy155TxArgs) TxHash() (EthHash, error)
- func (tx *EthLegacy155TxArgs) Type() int
- type EthLegacyHomesteadTxArgs
- func (tx *EthLegacyHomesteadTxArgs) InitialiseSignature(sig typescrypto.Signature) error
- func (tx *EthLegacyHomesteadTxArgs) Sender() (address.Address, error)
- func (tx *EthLegacyHomesteadTxArgs) Signature() (*typescrypto.Signature, error)
- func (tx *EthLegacyHomesteadTxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
- func (tx *EthLegacyHomesteadTxArgs) ToRlpSignedMsg() ([]byte, error)
- func (tx *EthLegacyHomesteadTxArgs) ToRlpUnsignedMsg() ([]byte, error)
- func (tx *EthLegacyHomesteadTxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
- func (tx *EthLegacyHomesteadTxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
- func (tx *EthLegacyHomesteadTxArgs) TxHash() (EthHash, error)
- func (tx *EthLegacyHomesteadTxArgs) Type() int
- type EthLog
- type EthNonce
- type EthSubscribeParams
- type EthSubscriptionID
- type EthSubscriptionParams
- type EthSubscriptionResponse
- type EthSyncingResult
- type EthTopicSpec
- type EthTrace
- type EthTraceBlock
- type EthTraceFilterCriteria
- type EthTraceFilterResult
- type EthTraceReplayBlockTransaction
- type EthTraceTransaction
- type EthTransaction
- type EthTx
- type EthTxReceipt
- type EthUint64
- type FIL
- func (f FIL) Format(s fmt.State, ch rune)
- func (f FIL) MarshalJSON() ([]byte, error)
- func (f FIL) MarshalText() (text []byte, err error)
- func (f FIL) Nano() string
- func (f FIL) Short() string
- func (f FIL) String() string
- func (f FIL) Unitless() string
- func (f *FIL) UnmarshalJSON(by []byte) error
- func (f *FIL) UnmarshalText(text []byte) error
- type Message
- func (m *Message) ChainLength() int
- func (m *Message) Cid() cid.Cid
- func (m *Message) EffectiveGasPremium(baseFee abi.TokenAmount) abi.TokenAmount
- func (m *Message) EqualCall(o *Message) bool
- func (m *Message) Equals(o *Message) bool
- func (t *Message) MarshalCBOR(w io.Writer) error
- func (m *Message) MarshalJSON() ([]byte, error)
- func (m *Message) RequiredFunds() abi.TokenAmount
- func (m *Message) Serialize() ([]byte, error)
- func (m *Message) SerializeWithCid() (cid.Cid, []byte, error)
- func (m *Message) SigningBytes(sigType crypto.SigType) ([]byte, error)
- func (m *Message) String() string
- func (m *Message) ToStorageBlock() (blocks.Block, error)
- func (t *Message) UnmarshalCBOR(r io.Reader) (err error)
- func (m *Message) VMMessage() *Message
- func (m *Message) ValidForBlockInclusion(minGas int64, version network.Version) error
- type RawMessage
- type RawSignedMessage
- type RlpPackable
- type SignedMessage
- func (smsg *SignedMessage) ChainLength() int
- func (smsg *SignedMessage) Cid() cid.Cid
- func (t *SignedMessage) MarshalCBOR(w io.Writer) error
- func (sm *SignedMessage) MarshalJSON() ([]byte, error)
- func (smsg *SignedMessage) Serialize() ([]byte, error)
- func (smsg *SignedMessage) SerializeWithCid() (cid.Cid, []byte, error)
- func (smsg *SignedMessage) String() string
- func (smsg *SignedMessage) ToStorageBlock() (blocks.Block, error)
- func (t *SignedMessage) UnmarshalCBOR(r io.Reader) (err error)
- func (smsg *SignedMessage) VMMessage() *Message
Constants ¶
const ( EthAddressLength = 20 EthHashLength = 32 )
const ( EthLegacyTxType = 0x00 EIP1559TxType = 0x02 )
const ( EthEIP1559TxSignatureLen = 65 EthLegacyHomesteadTxSignatureLen = 66 EthLegacyHomesteadTxSignaturePrefix = 0x01 EthLegacy155TxSignaturePrefix = 0x02 EthLegacyHomesteadTxChainID = 0x00 )
const EthBloomSize = 2048
const MessageVersion = 0
const SafeEpochDelay = abi.ChainEpoch(30)
Research into Filecoin chain behaviour suggests that probabilistic finality generally approaches the intended stability guarantee at, or near, 30 epochs. Although a strictly "finalized" safe recommendation remains 900 epochs. See https://github.com/filecoin-project/FIPs/blob/master/FRCs/frc-0089.md
Variables ¶
var ( AttoFil = NewInt(1) FemtoFil = BigMul(AttoFil, NewInt(1000)) PicoFil = BigMul(FemtoFil, NewInt(1000)) NanoFil = BigMul(PicoFil, NewInt(1000)) )
var ( EmptyEthBloom = [EthBloomSize / 8]byte{} FullEthBloom = [EthBloomSize / 8]byte{} EmptyEthHash = EthHash{} EmptyUncleHash = One(ParseEthHash("0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347")) // Keccak-256 of an RLP of an empty array EmptyRootHash = One(ParseEthHash("0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421")) // Keccak-256 hash of the RLP of null EmptyEthInt = EthUint64(0) EmptyEthNonce = [8]byte{0, 0, 0, 0, 0, 0, 0, 0} )
var ( EthLegacy155TxSignatureLen0 int EthLegacy155TxSignatureLen1 int )
var Eip155ChainID = 314
mainnet
var EmptyInt = BigInt{}
var ErrActorNotFound = errors.New("actor not found")
var ErrInvalidAddress = errors.New("invalid Filecoin Eth address")
var (
EthBigIntZero = EthBigInt{Int: big.Zero().Int}
)
var TotalFilecoinInt = FromFil(params.FilBase)
var ZeroAddress address.Address = One(address.NewFromString("f3yaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaby2smx7a"))
var ZeroFIL = fbig.NewInt(0)
Functions ¶
func BigDivFloat ¶
func DecodeHexString ¶
func EthAddressFromPubKey ¶
EthAddressFromPubKey returns the Ethereum address corresponding to an uncompressed secp256k1 public key.
func EthBloomSet ¶
func IsEthAddress ¶
func IsEthAddress(addr address.Address) bool
func SetEip155ChainID ¶
func SetEip155ChainID(val int)
Types ¶
type Actor ¶
type Actor = ActorV5
func (*Actor) IncrementSeqNum ¶
func (t *Actor) IncrementSeqNum()
IncrementSeqNum increments the seq number.
type ActorV4 ¶
type ActorV4 struct { // Code is a CID of the VM code for this actor's implementation (or a constant for actors implemented in Go code). // Code may be nil for an uninitialized actor (which exists because it has received a balance). Code cid.Cid // Head is the CID of the root of the actor's state tree. Head cid.Cid // Nonce is the number expected on the next message from this actor. // Messages are processed in strict, contiguous order. Nonce uint64 // Balance is the amount of attoFIL in the actor's account. Balance abi.TokenAmount }
Actor is the central abstraction of entities in the system.
Both individual accounts, as well as contracts (user & system level) are represented as actors. An actor has the following core functionality implemented on a system level: - track a Filecoin balance, using the `Balance` field - execute code stored in the `Code` field - read & write memory - replay protection, using the `Nonce` field
Value sent to a non-existent address will be tracked as an empty actor that has a Balance but nil Code and Memory. You must nil check Code cids before comparing them.
More specific capabilities for individual accounts or contract specific must be implemented inside the code.
Not safe for concurrent access.
type ActorV5 ¶
type ActorV5 struct { // Identifies the type of actor (string coded as a CID), see `chain/actors/actors.go`. Code cid.Cid Head cid.Cid Nonce uint64 Balance BigInt // The f4 address of the actor, if any. DelegatedAddress *address.Address }
Actor State for state tree version 5
type Eth1559TxArgs ¶ added in v1.16.0
type Eth1559TxArgs struct { ChainID int `json:"chainId"` Nonce int `json:"nonce"` To *EthAddress `json:"to"` Value big.Int `json:"value"` MaxFeePerGas big.Int `json:"maxFeePerGas"` MaxPriorityFeePerGas big.Int `json:"maxPriorityFeePerGas"` GasLimit int `json:"gasLimit"` Input []byte `json:"input"` V big.Int `json:"v"` R big.Int `json:"r"` S big.Int `json:"s"` }
func Eth1559TxArgsFromUnsignedFilecoinMessage ¶ added in v1.16.0
func Eth1559TxArgsFromUnsignedFilecoinMessage(msg *Message) (*Eth1559TxArgs, error)
func (*Eth1559TxArgs) InitialiseSignature ¶ added in v1.16.0
func (tx *Eth1559TxArgs) InitialiseSignature(sig typescrypto.Signature) error
func (*Eth1559TxArgs) Sender ¶ added in v1.16.0
func (tx *Eth1559TxArgs) Sender() (address.Address, error)
func (*Eth1559TxArgs) Signature ¶ added in v1.16.0
func (tx *Eth1559TxArgs) Signature() (*typescrypto.Signature, error)
func (*Eth1559TxArgs) ToEthTx ¶ added in v1.16.0
func (tx *Eth1559TxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
func (*Eth1559TxArgs) ToRlpSignedMsg ¶ added in v1.16.0
func (tx *Eth1559TxArgs) ToRlpSignedMsg() ([]byte, error)
func (*Eth1559TxArgs) ToRlpUnsignedMsg ¶ added in v1.16.0
func (tx *Eth1559TxArgs) ToRlpUnsignedMsg() ([]byte, error)
func (*Eth1559TxArgs) ToUnsignedFilecoinMessage ¶ added in v1.16.0
func (tx *Eth1559TxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
func (*Eth1559TxArgs) ToVerifiableSignature ¶ added in v1.16.0
func (tx *Eth1559TxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
func (*Eth1559TxArgs) TxHash ¶ added in v1.16.0
func (tx *Eth1559TxArgs) TxHash() (EthHash, error)
func (*Eth1559TxArgs) Type ¶ added in v1.16.0
func (tx *Eth1559TxArgs) Type() int
type EthAddress ¶
type EthAddress [EthAddressLength]byte
func CastEthAddress ¶
func CastEthAddress(b []byte) (EthAddress, error)
CastEthAddress interprets bytes as an EthAddress, performing some basic checks.
func EthAddressFromActorID ¶ added in v1.15.0
func EthAddressFromActorID(id abi.ActorID) EthAddress
func EthAddressFromFilecoinAddress ¶
func EthAddressFromFilecoinAddress(addr address.Address) (EthAddress, error)
func GetContractEthAddressFromCode ¶
func GetContractEthAddressFromCode(sender EthAddress, salt [32]byte, initcode []byte) (EthAddress, error)
func ParseEthAddress ¶
func ParseEthAddress(s string) (EthAddress, error)
ParseEthAddress parses an Ethereum address from a hex string.
func TryEthAddressFromFilecoinAddress ¶
func TryEthAddressFromFilecoinAddress(addr address.Address, allowID bool) (EthAddress, bool, error)
This API assumes that if an ID address is passed in, it doesn't have an equivalent delegated address
func (EthAddress) IsMaskedID ¶
func (ea EthAddress) IsMaskedID() bool
func (EthAddress) MarshalJSON ¶
func (ea EthAddress) MarshalJSON() ([]byte, error)
func (EthAddress) String ¶
func (ea EthAddress) String() string
func (EthAddress) ToFilecoinAddress ¶
func (ea EthAddress) ToFilecoinAddress() (address.Address, error)
func (*EthAddress) UnmarshalJSON ¶
func (ea *EthAddress) UnmarshalJSON(b []byte) error
type EthAddressList ¶
type EthAddressList []EthAddress
EthAddressSpec represents a list of addresses. The JSON decoding must treat a string as equivalent to an array with one value, for example "0x8888f1f195afa192cfee86069858" must be decoded as [ "0x8888f1f195afa192cfee86069858" ]
func (*EthAddressList) UnmarshalJSON ¶
func (e *EthAddressList) UnmarshalJSON(b []byte) error
type EthBigInt ¶
EthBigInt represents a large integer whose zero value serializes to "0x0".
func (EthBigInt) MarshalJSON ¶
func (*EthBigInt) UnmarshalJSON ¶
type EthBlock ¶
type EthBlock struct { Hash EthHash `json:"hash"` ParentHash EthHash `json:"parentHash"` Sha3Uncles EthHash `json:"sha3Uncles"` Miner EthAddress `json:"miner"` StateRoot EthHash `json:"stateRoot"` TransactionsRoot EthHash `json:"transactionsRoot"` ReceiptsRoot EthHash `json:"receiptsRoot"` LogsBloom EthBytes `json:"logsBloom"` Difficulty EthUint64 `json:"difficulty"` TotalDifficulty EthUint64 `json:"totalDifficulty"` Number EthUint64 `json:"number"` GasLimit EthUint64 `json:"gasLimit"` GasUsed EthUint64 `json:"gasUsed"` Timestamp EthUint64 `json:"timestamp"` Extradata EthBytes `json:"extraData"` MixHash EthHash `json:"mixHash"` Nonce EthNonce `json:"nonce"` BaseFeePerGas EthBigInt `json:"baseFeePerGas"` Size EthUint64 `json:"size"` // can be []EthTx or []string depending on query params Transactions []interface{} `json:"transactions"` Uncles []EthHash `json:"uncles"` }
func NewEthBlock ¶
type EthBlockNumberOrHash ¶ added in v1.14.0
type EthBlockNumberOrHash struct { // PredefinedBlock can be one of "earliest", "pending" or "latest". We could merge this // field with BlockNumber if the latter could store negative numbers representing // each predefined value (e.g. -1 for "earliest", -2 for "pending" and -3 for "latest") PredefinedBlock *string `json:"-"` BlockNumber *EthUint64 `json:"blockNumber,omitempty"` BlockHash *EthHash `json:"blockHash,omitempty"` RequireCanonical bool `json:"requireCanonical,omitempty"` }
func NewEthBlockNumberOrHashFromHexString ¶ added in v1.14.0
func NewEthBlockNumberOrHashFromHexString(str string) (EthBlockNumberOrHash, error)
func NewEthBlockNumberOrHashFromNumber ¶ added in v1.14.0
func NewEthBlockNumberOrHashFromNumber(number EthUint64) EthBlockNumberOrHash
func NewEthBlockNumberOrHashFromPredefined ¶ added in v1.14.0
func NewEthBlockNumberOrHashFromPredefined(predefined string) EthBlockNumberOrHash
func (EthBlockNumberOrHash) MarshalJSON ¶ added in v1.14.0
func (e EthBlockNumberOrHash) MarshalJSON() ([]byte, error)
func (*EthBlockNumberOrHash) UnmarshalJSON ¶ added in v1.14.0
func (e *EthBlockNumberOrHash) UnmarshalJSON(b []byte) error
type EthBytes ¶
type EthBytes []byte
EthBytes represent arbitrary bytes. A nil or empty slice serializes to "0x".
func (EthBytes) MarshalJSON ¶
func (*EthBytes) UnmarshalJSON ¶
type EthCall ¶
type EthCall struct { From *EthAddress `json:"from"` To *EthAddress `json:"to"` Gas EthUint64 `json:"gas"` GasPrice EthBigInt `json:"gasPrice"` Value EthBigInt `json:"value"` Data EthBytes `json:"data"` }
func (*EthCall) UnmarshalJSON ¶
type EthCallTraceAction ¶ added in v1.15.0
type EthCallTraceAction struct { CallType string `json:"callType"` From EthAddress `json:"from"` To EthAddress `json:"to"` Gas EthUint64 `json:"gas"` Value EthBigInt `json:"value"` Input EthBytes `json:"input"` }
type EthCallTraceResult ¶ added in v1.15.0
type EthCreateTraceAction ¶ added in v1.15.0
type EthCreateTraceAction struct { From EthAddress `json:"from"` Gas EthUint64 `json:"gas"` Value EthBigInt `json:"value"` Init EthBytes `json:"init"` }
type EthCreateTraceResult ¶ added in v1.15.0
type EthCreateTraceResult struct { Address *EthAddress `json:"address,omitempty"` GasUsed EthUint64 `json:"gasUsed"` Code EthBytes `json:"code"` }
type EthEstimateGasParams ¶ added in v1.15.0
type EthEstimateGasParams struct { Tx EthCall BlkParam *EthBlockNumberOrHash }
EthEstimateGasParams handles raw jsonrpc params for eth_estimateGas
func (EthEstimateGasParams) MarshalJSON ¶ added in v1.15.0
func (e EthEstimateGasParams) MarshalJSON() ([]byte, error)
func (*EthEstimateGasParams) UnmarshalJSON ¶ added in v1.15.0
func (e *EthEstimateGasParams) UnmarshalJSON(b []byte) error
type EthFeeHistory ¶
type EthFeeHistoryParams ¶
type EthFeeHistoryParams struct { BlkCount EthUint64 NewestBlkNum string RewardPercentiles *[]float64 }
EthFeeHistoryParams handles raw jsonrpc params for eth_feeHistory
func (EthFeeHistoryParams) MarshalJSON ¶
func (e EthFeeHistoryParams) MarshalJSON() ([]byte, error)
func (*EthFeeHistoryParams) UnmarshalJSON ¶
func (e *EthFeeHistoryParams) UnmarshalJSON(b []byte) error
type EthFilterID ¶
type EthFilterID EthHash
func (EthFilterID) MarshalJSON ¶
func (h EthFilterID) MarshalJSON() ([]byte, error)
func (EthFilterID) String ¶
func (h EthFilterID) String() string
func (*EthFilterID) UnmarshalJSON ¶
func (h *EthFilterID) UnmarshalJSON(b []byte) error
type EthFilterResult ¶
type EthFilterResult struct {
Results []interface{}
}
FilterResult represents the response from executing a filter: a list of block hashes, a list of transaction hashes or a list of logs This is a union type. Only one field will be populated. The JSON encoding must produce an array of the populated field.
func (EthFilterResult) MarshalJSON ¶
func (h EthFilterResult) MarshalJSON() ([]byte, error)
func (*EthFilterResult) UnmarshalJSON ¶
func (h *EthFilterResult) UnmarshalJSON(b []byte) error
type EthFilterSpec ¶
type EthFilterSpec struct { // Interpreted as an epoch (in hex) or one of "latest" for last mined block, "earliest" for first, // "pending" for not yet committed messages. // Optional, default: "latest". FromBlock *string `json:"fromBlock,omitempty"` // Interpreted as an epoch (in hex) or one of "latest" for last mined block, "earliest" for first, // "pending" for not yet committed messages. // Optional, default: "latest". ToBlock *string `json:"toBlock,omitempty"` // Actor address or a list of addresses from which event logs should originate. // Optional, default nil. // The JSON decoding must treat a string as equivalent to an array with one value, for example // "0x8888f1f195afa192cfee86069858" must be decoded as [ "0x8888f1f195afa192cfee86069858" ] Address EthAddressList `json:"address"` // List of topics to be matched. // Optional, default: empty list Topics EthTopicSpec `json:"topics"` // Restricts event logs returned to those emitted from messages contained in this tipset. // If BlockHash is present in the filter criteria, then neither FromBlock nor ToBlock are allowed. // Added in EIP-234 BlockHash *EthHash `json:"blockHash,omitempty"` }
type EthHash ¶
type EthHash [EthHashLength]byte
func EthHashFromCid ¶
func EthHashFromTxBytes ¶
func ParseEthHash ¶
func (EthHash) MarshalJSON ¶
func (EthHash) ToCid ¶
func (h EthHash) ToCid() cid.Cid
Should ONLY be used for blocks and Filecoin messages. Eth transactions expect a different hashing scheme.
func (*EthHash) UnmarshalJSON ¶
type EthHashList ¶
type EthHashList []EthHash
EthHashList represents a list of EthHashes. The JSON decoding treats string values as equivalent to arrays with one value.
func (*EthHashList) UnmarshalJSON ¶
func (e *EthHashList) UnmarshalJSON(b []byte) error
type EthLegacy155TxArgs ¶ added in v1.16.0
type EthLegacy155TxArgs struct {
// contains filtered or unexported fields
}
EthLegacy155TxArgs is a legacy Ethereum transaction that uses the EIP-155 chain replay protection mechanism by incorporating the chainId in the signature. See how the `V` value in the signature is derived from the chainId at https://github.com/ethereum/go-ethereum/blob/86a1f0c39494c8f5caddf6bd9fbddd4bdfa944fd/core/types/transaction_signing.go#L424 For EthLegacy155TxArgs, the digest that is used to create a signed transaction includes the `ChainID` but the serialised RLP transaction does not include the `ChainID` as an explicit field. Instead, the `ChainID` is included in the V value of the signature as mentioned above.
func NewEthLegacy155TxArgs ¶ added in v1.16.0
func NewEthLegacy155TxArgs(tx *EthLegacyHomesteadTxArgs) *EthLegacy155TxArgs
func (*EthLegacy155TxArgs) GetLegacyTx ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) GetLegacyTx() *EthLegacyHomesteadTxArgs
func (*EthLegacy155TxArgs) InitialiseSignature ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) InitialiseSignature(sig typescrypto.Signature) error
func (*EthLegacy155TxArgs) Sender ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) Sender() (address.Address, error)
func (*EthLegacy155TxArgs) Signature ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) Signature() (*typescrypto.Signature, error)
func (*EthLegacy155TxArgs) ToEthTx ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
func (*EthLegacy155TxArgs) ToRawTxBytesSigned ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToRawTxBytesSigned() ([]byte, error)
func (*EthLegacy155TxArgs) ToRlpSignedMsg ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToRlpSignedMsg() ([]byte, error)
func (*EthLegacy155TxArgs) ToRlpUnsignedMsg ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToRlpUnsignedMsg() ([]byte, error)
func (*EthLegacy155TxArgs) ToUnsignedFilecoinMessage ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
func (*EthLegacy155TxArgs) ToVerifiableSignature ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
func (*EthLegacy155TxArgs) TxHash ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) TxHash() (EthHash, error)
func (*EthLegacy155TxArgs) Type ¶ added in v1.16.0
func (tx *EthLegacy155TxArgs) Type() int
type EthLegacyHomesteadTxArgs ¶ added in v1.16.0
type EthLegacyHomesteadTxArgs struct { Nonce int `json:"nonce"` GasPrice big.Int `json:"gasPrice"` GasLimit int `json:"gasLimit"` To *EthAddress `json:"to"` Value big.Int `json:"value"` Input []byte `json:"input"` V big.Int `json:"v"` R big.Int `json:"r"` S big.Int `json:"s"` }
func (*EthLegacyHomesteadTxArgs) InitialiseSignature ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) InitialiseSignature(sig typescrypto.Signature) error
func (*EthLegacyHomesteadTxArgs) Sender ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) Sender() (address.Address, error)
func (*EthLegacyHomesteadTxArgs) Signature ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) Signature() (*typescrypto.Signature, error)
func (*EthLegacyHomesteadTxArgs) ToEthTx ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) ToEthTx(smsg *SignedMessage) (EthTx, error)
func (*EthLegacyHomesteadTxArgs) ToRlpSignedMsg ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) ToRlpSignedMsg() ([]byte, error)
func (*EthLegacyHomesteadTxArgs) ToRlpUnsignedMsg ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) ToRlpUnsignedMsg() ([]byte, error)
func (*EthLegacyHomesteadTxArgs) ToUnsignedFilecoinMessage ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) ToUnsignedFilecoinMessage(from address.Address) (*Message, error)
func (*EthLegacyHomesteadTxArgs) ToVerifiableSignature ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) ToVerifiableSignature(sig []byte) ([]byte, error)
func (*EthLegacyHomesteadTxArgs) TxHash ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) TxHash() (EthHash, error)
func (*EthLegacyHomesteadTxArgs) Type ¶ added in v1.16.0
func (tx *EthLegacyHomesteadTxArgs) Type() int
type EthLog ¶
type EthLog struct { // Address is the address of the actor that produced the event log. Address EthAddress `json:"address"` // Data is the value of the event log, excluding topics Data EthBytes `json:"data"` // List of topics associated with the event log. Topics []EthHash `json:"topics"` // Indicates whether the log was removed due to a chain reorganization. Removed bool `json:"removed"` // LogIndex is the index of the event log in the sequence of events produced by the message execution. // (this is the index in the events AMT on the message receipt) LogIndex EthUint64 `json:"logIndex"` // TransactionIndex is the index in the tipset of the transaction that produced the event log. // The index corresponds to the sequence of messages produced by ChainGetParentMessages TransactionIndex EthUint64 `json:"transactionIndex"` // TransactionHash is the hash of the RLP message that produced the event log. TransactionHash EthHash `json:"transactionHash"` // BlockHash is the hash of the tipset containing the message that produced the log. BlockHash EthHash `json:"blockHash"` // BlockNumber is the epoch of the tipset containing the message. BlockNumber EthUint64 `json:"blockNumber"` }
EthLog represents the results of an event filter execution.
type EthNonce ¶
type EthNonce [8]byte
func (EthNonce) MarshalJSON ¶
func (*EthNonce) UnmarshalJSON ¶
type EthSubscribeParams ¶
type EthSubscribeParams struct { EventType string Params *EthSubscriptionParams }
EthSubscribeParams handles raw jsonrpc params for eth_subscribe
func (EthSubscribeParams) MarshalJSON ¶
func (e EthSubscribeParams) MarshalJSON() ([]byte, error)
func (*EthSubscribeParams) UnmarshalJSON ¶
func (e *EthSubscribeParams) UnmarshalJSON(b []byte) error
type EthSubscriptionID ¶
type EthSubscriptionID EthHash
An opaque identifier generated by the Lotus node to refer to an active subscription.
func (EthSubscriptionID) MarshalJSON ¶
func (h EthSubscriptionID) MarshalJSON() ([]byte, error)
func (EthSubscriptionID) String ¶
func (h EthSubscriptionID) String() string
func (*EthSubscriptionID) UnmarshalJSON ¶
func (h *EthSubscriptionID) UnmarshalJSON(b []byte) error
type EthSubscriptionParams ¶
type EthSubscriptionParams struct { // List of topics to be matched. // Optional, default: empty list Topics EthTopicSpec `json:"topics,omitempty"` // Actor address or a list of addresses from which event logs should originate. // Optional, default nil. // The JSON decoding must treat a string as equivalent to an array with one value, for example // "0x8888f1f195afa192cfee86069858" must be decoded as [ "0x8888f1f195afa192cfee86069858" ] Address EthAddressList `json:"address"` }
type EthSubscriptionResponse ¶
type EthSubscriptionResponse struct { // The persistent identifier for the subscription which can be used to unsubscribe. SubscriptionID EthSubscriptionID `json:"subscription"` // The object matching the subscription. This may be a Block (tipset), a Transaction (message) or an EthLog Result interface{} `json:"result"` }
type EthSyncingResult ¶ added in v1.14.0
type EthSyncingResult struct { DoneSync bool StartingBlock EthUint64 CurrentBlock EthUint64 HighestBlock EthUint64 }
func (EthSyncingResult) MarshalJSON ¶ added in v1.14.0
func (sr EthSyncingResult) MarshalJSON() ([]byte, error)
type EthTopicSpec ¶
type EthTopicSpec []EthHashList
TopicSpec represents a specification for matching by topic. An empty spec means all topics will be matched. Otherwise topics are matched conjunctively in the first dimension of the slice and disjunctively in the second dimension. Topics are matched in order. An event log with topics [A, B] will be matched by the following topic specs: [] "all" [[A]] "A in first position (and anything after)" [nil, [B] ] "anything in first position AND B in second position (and anything after)" [[A], [B]] "A in first position AND B in second position (and anything after)" [[A, B], [A, B]] "(A OR B) in first position AND (A OR B) in second position (and anything after)"
The JSON decoding must treat string values as equivalent to arrays with one value, for example { "A", [ "B", "C" ] } must be decoded as [ [ A ], [ B, C ] ]
type EthTraceBlock ¶ added in v1.14.0
type EthTraceFilterCriteria ¶ added in v1.17.0
type EthTraceFilterCriteria struct { // Interpreted as an epoch (in hex) or one of "latest" for last mined block, "pending" for not yet committed messages. // Optional, default: "latest". // Note: "earliest" is not a permitted value. FromBlock *string `json:"fromBlock,omitempty"` // Interpreted as an epoch (in hex) or one of "latest" for last mined block, "pending" for not yet committed messages. // Optional, default: "latest". // Note: "earliest" is not a permitted value. ToBlock *string `json:"toBlock,omitempty"` // Actor address or a list of addresses from which transactions that generate traces should originate. // Optional, default: nil. // The JSON decoding must treat a string as equivalent to an array with one value, for example // "0x8888f1f195afa192cfee86069858" must be decoded as [ "0x8888f1f195afa192cfee86069858" ] FromAddress EthAddressList `json:"fromAddress,omitempty"` // Actor address or a list of addresses to which transactions that generate traces are sent. // Optional, default: nil. // The JSON decoding must treat a string as equivalent to an array with one value, for example // "0x8888f1f195afa192cfee86069858" must be decoded as [ "0x8888f1f195afa192cfee86069858" ] ToAddress EthAddressList `json:"toAddress,omitempty"` // After specifies the offset for pagination of trace results. The number of traces to skip before returning results. // Optional, default: nil. After *EthUint64 `json:"after,omitempty"` // Limits the number of traces returned. // Optional, default: all traces. Count *EthUint64 `json:"count,omitempty"` }
EthTraceFilterCriteria defines the criteria for filtering traces.
type EthTraceFilterResult ¶ added in v1.17.0
type EthTraceReplayBlockTransaction ¶ added in v1.14.0
type EthTraceTransaction ¶ added in v1.16.0
type EthTransaction ¶ added in v1.16.0
type EthTransaction interface { Type() int Sender() (address.Address, error) Signature() (*typescrypto.Signature, error) InitialiseSignature(sig typescrypto.Signature) error ToUnsignedFilecoinMessage(from address.Address) (*Message, error) ToRlpUnsignedMsg() ([]byte, error) ToRlpSignedMsg() ([]byte, error) TxHash() (EthHash, error) ToVerifiableSignature(sig []byte) ([]byte, error) ToEthTx(*SignedMessage) (EthTx, error) }
EthTransaction defines the interface for Ethereum-like transactions. It provides methods to convert transactions to various formats, retrieve transaction details, and manipulate transaction signatures.
func EthTransactionFromSignedFilecoinMessage ¶ added in v1.16.0
func EthTransactionFromSignedFilecoinMessage(smsg *SignedMessage) (EthTransaction, error)
func ParseEthTransaction ¶ added in v1.16.0
func ParseEthTransaction(data []byte) (EthTransaction, error)
type EthTx ¶
type EthTx struct { ChainID EthUint64 `json:"chainId"` Nonce EthUint64 `json:"nonce"` Hash EthHash `json:"hash"` BlockHash *EthHash `json:"blockHash"` BlockNumber *EthUint64 `json:"blockNumber"` TransactionIndex *EthUint64 `json:"transactionIndex"` From EthAddress `json:"from"` To *EthAddress `json:"to"` Value EthBigInt `json:"value"` Type EthUint64 `json:"type"` Input EthBytes `json:"input"` Gas EthUint64 `json:"gas"` MaxFeePerGas *EthBigInt `json:"maxFeePerGas,omitempty"` MaxPriorityFeePerGas *EthBigInt `json:"maxPriorityFeePerGas,omitempty"` GasPrice *EthBigInt `json:"gasPrice,omitempty"` AccessList []EthHash `json:"accessList"` V EthBigInt `json:"v"` R EthBigInt `json:"r"` S EthBigInt `json:"s"` }
func (*EthTx) GasPremium ¶ added in v1.16.0
type EthTxReceipt ¶
type EthTxReceipt struct { TransactionHash EthHash `json:"transactionHash"` TransactionIndex EthUint64 `json:"transactionIndex"` BlockHash EthHash `json:"blockHash"` BlockNumber EthUint64 `json:"blockNumber"` From EthAddress `json:"from"` To *EthAddress `json:"to"` // Logs // LogsBloom StateRoot EthHash `json:"root"` Status EthUint64 `json:"status"` ContractAddress *EthAddress `json:"contractAddress"` CumulativeGasUsed EthUint64 `json:"cumulativeGasUsed"` GasUsed EthUint64 `json:"gasUsed"` EffectiveGasPrice EthBigInt `json:"effectiveGasPrice"` LogsBloom EthBytes `json:"logsBloom"` Logs []EthLog `json:"logs"` Type EthUint64 `json:"type"` }
type EthUint64 ¶
type EthUint64 uint64
func EthUint64FromBytes ¶
Parse a uint64 from big-endian encoded bytes.
func EthUint64FromHex ¶
func (EthUint64) MarshalJSON ¶
func (*EthUint64) UnmarshalJSON ¶
UnmarshalJSON should be able to parse these types of input: 1. a JSON string containing a hex-encoded uint64 starting with 0x 2. a JSON string containing an uint64 in decimal 3. a string containing an uint64 in decimal
type FIL ¶
type FIL BigInt
func MustParseFIL ¶
func (FIL) MarshalJSON ¶
func (FIL) MarshalText ¶
func (*FIL) UnmarshalJSON ¶
func (*FIL) UnmarshalText ¶
type Message ¶
type Message struct { Version uint64 To address.Address From address.Address // When receiving a message from a user account the nonce in // the message must match the expected nonce in the from actor. // This prevents replay attacks. Nonce uint64 Value abi.TokenAmount GasLimit int64 GasFeeCap abi.TokenAmount GasPremium abi.TokenAmount Method abi.MethodNum Params []byte }
func DecodeMessage ¶
func (*Message) ChainLength ¶
func (*Message) EffectiveGasPremium ¶ added in v1.12.0
func (m *Message) EffectiveGasPremium(baseFee abi.TokenAmount) abi.TokenAmount
EffectiveGasPremium returns the effective gas premium claimable by the miner given the supplied base fee.
Filecoin clamps the gas premium at GasFeeCap - BaseFee, if lower than the specified premium.
func (*Message) MarshalJSON ¶
func (*Message) RequiredFunds ¶
func (m *Message) RequiredFunds() abi.TokenAmount
func (*Message) SerializeWithCid ¶
func (*Message) SigningBytes ¶
type RawMessage ¶
type RawMessage Message
type RawSignedMessage ¶
type RawSignedMessage SignedMessage
type RlpPackable ¶ added in v1.16.0
type RlpPackable interface {
// contains filtered or unexported methods
}
type SignedMessage ¶
SignedMessage contains a message and its signature
func ToSignedFilecoinMessage ¶ added in v1.16.0
func ToSignedFilecoinMessage(tx EthTransaction) (*SignedMessage, error)
func (*SignedMessage) Cid ¶
func (smsg *SignedMessage) Cid() cid.Cid
func (*SignedMessage) MarshalCBOR ¶
func (t *SignedMessage) MarshalCBOR(w io.Writer) error
func (*SignedMessage) MarshalJSON ¶
func (sm *SignedMessage) MarshalJSON() ([]byte, error)
func (*SignedMessage) Serialize ¶
func (smsg *SignedMessage) Serialize() ([]byte, error)
Serialize return message binary
func (*SignedMessage) SerializeWithCid ¶
func (smsg *SignedMessage) SerializeWithCid() (cid.Cid, []byte, error)
Serialize return message binary
func (*SignedMessage) String ¶
func (smsg *SignedMessage) String() string
String return message json string
func (*SignedMessage) ToStorageBlock ¶
func (smsg *SignedMessage) ToStorageBlock() (blocks.Block, error)
func (*SignedMessage) UnmarshalCBOR ¶
func (t *SignedMessage) UnmarshalCBOR(r io.Reader) (err error)
func (*SignedMessage) VMMessage ¶
func (smsg *SignedMessage) VMMessage() *Message