@ -28,6 +28,7 @@ import (
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common/hexutil"
"github.com/ethereum/go-ethereum/common/hexutil"
"github.com/ethereum/go-ethereum/common/math"
"github.com/ethereum/go-ethereum/common/math"
"github.com/ethereum/go-ethereum/consensus/misc"
"github.com/ethereum/go-ethereum/core/state"
"github.com/ethereum/go-ethereum/core/state"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/eth/filters"
"github.com/ethereum/go-ethereum/eth/filters"
@ -253,6 +254,10 @@ func (t *Transaction) EffectiveGasPrice(ctx context.Context) (*hexutil.Big, erro
if err != nil || tx == nil {
if err != nil || tx == nil {
return nil , err
return nil , err
}
}
// Pending tx
if t . block == nil {
return nil , nil
}
header , err := t . block . resolveHeader ( ctx )
header , err := t . block . resolveHeader ( ctx )
if err != nil || header == nil {
if err != nil || header == nil {
return nil , err
return nil , err
@ -293,6 +298,30 @@ func (t *Transaction) MaxPriorityFeePerGas(ctx context.Context) (*hexutil.Big, e
}
}
}
}
func ( t * Transaction ) EffectiveTip ( ctx context . Context ) ( * hexutil . Big , error ) {
tx , err := t . resolve ( ctx )
if err != nil || tx == nil {
return nil , err
}
// Pending tx
if t . block == nil {
return nil , nil
}
header , err := t . block . resolveHeader ( ctx )
if err != nil || header == nil {
return nil , err
}
if header . BaseFee == nil {
return ( * hexutil . Big ) ( tx . GasPrice ( ) ) , nil
}
tip , err := tx . EffectiveGasTip ( header . BaseFee )
if err != nil {
return nil , err
}
return ( * hexutil . Big ) ( tip ) , nil
}
func ( t * Transaction ) Value ( ctx context . Context ) ( hexutil . Big , error ) {
func ( t * Transaction ) Value ( ctx context . Context ) ( hexutil . Big , error ) {
tx , err := t . resolve ( ctx )
tx , err := t . resolve ( ctx )
if err != nil || tx == nil {
if err != nil || tx == nil {
@ -606,6 +635,22 @@ func (b *Block) BaseFeePerGas(ctx context.Context) (*hexutil.Big, error) {
return ( * hexutil . Big ) ( header . BaseFee ) , nil
return ( * hexutil . Big ) ( header . BaseFee ) , nil
}
}
func ( b * Block ) NextBaseFeePerGas ( ctx context . Context ) ( * hexutil . Big , error ) {
header , err := b . resolveHeader ( ctx )
if err != nil {
return nil , err
}
chaincfg := b . backend . ChainConfig ( )
if header . BaseFee == nil {
// Make sure next block doesn't enable EIP-1559
if ! chaincfg . IsLondon ( new ( big . Int ) . Add ( header . Number , common . Big1 ) ) {
return nil , nil
}
}
nextBaseFee := misc . CalcBaseFee ( chaincfg , header )
return ( * hexutil . Big ) ( nextBaseFee ) , nil
}
func ( b * Block ) Parent ( ctx context . Context ) ( * Block , error ) {
func ( b * Block ) Parent ( ctx context . Context ) ( * Block , error ) {
if _ , err := b . resolveHeader ( ctx ) ; err != nil {
if _ , err := b . resolveHeader ( ctx ) ; err != nil {
return nil , err
return nil , err