forked from cerc-io/plugeth
Merge pull request #2215 from bas-vk/estimategas
core: improved check for contract creation
This commit is contained in:
commit
f30b809f00
@ -78,7 +78,7 @@ func MessageCreatesContract(msg Message) bool {
|
|||||||
return msg.To() == nil
|
return msg.To() == nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// IntrinsicGas computes the 'intrisic gas' for a message
|
// IntrinsicGas computes the 'intrinsic gas' for a message
|
||||||
// with the given data.
|
// with the given data.
|
||||||
func IntrinsicGas(data []byte, contractCreation, homestead bool) *big.Int {
|
func IntrinsicGas(data []byte, contractCreation, homestead bool) *big.Int {
|
||||||
igas := new(big.Int)
|
igas := new(big.Int)
|
||||||
|
65
eth/api.go
65
eth/api.go
@ -620,12 +620,12 @@ func (m callmsg) Value() *big.Int { return m.value }
|
|||||||
func (m callmsg) Data() []byte { return m.data }
|
func (m callmsg) Data() []byte { return m.data }
|
||||||
|
|
||||||
type CallArgs struct {
|
type CallArgs struct {
|
||||||
From common.Address `json:"from"`
|
From common.Address `json:"from"`
|
||||||
To common.Address `json:"to"`
|
To *common.Address `json:"to"`
|
||||||
Gas rpc.HexNumber `json:"gas"`
|
Gas rpc.HexNumber `json:"gas"`
|
||||||
GasPrice rpc.HexNumber `json:"gasPrice"`
|
GasPrice rpc.HexNumber `json:"gasPrice"`
|
||||||
Value rpc.HexNumber `json:"value"`
|
Value rpc.HexNumber `json:"value"`
|
||||||
Data string `json:"data"`
|
Data string `json:"data"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *PublicBlockChainAPI) doCall(args CallArgs, blockNr rpc.BlockNumber) (string, *big.Int, error) {
|
func (s *PublicBlockChainAPI) doCall(args CallArgs, blockNr rpc.BlockNumber) (string, *big.Int, error) {
|
||||||
@ -653,7 +653,7 @@ func (s *PublicBlockChainAPI) doCall(args CallArgs, blockNr rpc.BlockNumber) (st
|
|||||||
// Assemble the CALL invocation
|
// Assemble the CALL invocation
|
||||||
msg := callmsg{
|
msg := callmsg{
|
||||||
from: from,
|
from: from,
|
||||||
to: &args.To,
|
to: args.To,
|
||||||
gas: args.Gas.BigInt(),
|
gas: args.Gas.BigInt(),
|
||||||
gasPrice: args.GasPrice.BigInt(),
|
gasPrice: args.GasPrice.BigInt(),
|
||||||
value: args.Value.BigInt(),
|
value: args.Value.BigInt(),
|
||||||
@ -665,6 +665,7 @@ func (s *PublicBlockChainAPI) doCall(args CallArgs, blockNr rpc.BlockNumber) (st
|
|||||||
if msg.gasPrice.Cmp(common.Big0) == 0 {
|
if msg.gasPrice.Cmp(common.Big0) == 0 {
|
||||||
msg.gasPrice = new(big.Int).Mul(big.NewInt(50), common.Shannon)
|
msg.gasPrice = new(big.Int).Mul(big.NewInt(50), common.Shannon)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute the call and return
|
// Execute the call and return
|
||||||
vmenv := core.NewEnv(stateDb, s.bc, msg, block.Header())
|
vmenv := core.NewEnv(stateDb, s.bc, msg, block.Header())
|
||||||
gp := new(core.GasPool).AddGas(common.MaxBig)
|
gp := new(core.GasPool).AddGas(common.MaxBig)
|
||||||
@ -1012,13 +1013,13 @@ func (s *PublicTransactionPoolAPI) sign(address common.Address, tx *types.Transa
|
|||||||
}
|
}
|
||||||
|
|
||||||
type SendTxArgs struct {
|
type SendTxArgs struct {
|
||||||
From common.Address `json:"from"`
|
From common.Address `json:"from"`
|
||||||
To common.Address `json:"to"`
|
To *common.Address `json:"to"`
|
||||||
Gas *rpc.HexNumber `json:"gas"`
|
Gas *rpc.HexNumber `json:"gas"`
|
||||||
GasPrice *rpc.HexNumber `json:"gasPrice"`
|
GasPrice *rpc.HexNumber `json:"gasPrice"`
|
||||||
Value *rpc.HexNumber `json:"value"`
|
Value *rpc.HexNumber `json:"value"`
|
||||||
Data string `json:"data"`
|
Data string `json:"data"`
|
||||||
Nonce *rpc.HexNumber `json:"nonce"`
|
Nonce *rpc.HexNumber `json:"nonce"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// SendTransaction will create a transaction for the given transaction argument, sign it and submit it to the
|
// SendTransaction will create a transaction for the given transaction argument, sign it and submit it to the
|
||||||
@ -1042,12 +1043,12 @@ func (s *PublicTransactionPoolAPI) SendTransaction(args SendTxArgs) (common.Hash
|
|||||||
}
|
}
|
||||||
|
|
||||||
var tx *types.Transaction
|
var tx *types.Transaction
|
||||||
contractCreation := (args.To == common.Address{})
|
contractCreation := (args.To == nil)
|
||||||
|
|
||||||
if contractCreation {
|
if contractCreation {
|
||||||
tx = types.NewContractCreation(args.Nonce.Uint64(), args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
tx = types.NewContractCreation(args.Nonce.Uint64(), args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
||||||
} else {
|
} else {
|
||||||
tx = types.NewTransaction(args.Nonce.Uint64(), args.To, args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
tx = types.NewTransaction(args.Nonce.Uint64(), *args.To, args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
||||||
}
|
}
|
||||||
|
|
||||||
signedTx, err := s.sign(args.From, tx)
|
signedTx, err := s.sign(args.From, tx)
|
||||||
@ -1106,7 +1107,7 @@ func (s *PublicTransactionPoolAPI) Sign(address common.Address, data string) (st
|
|||||||
|
|
||||||
type SignTransactionArgs struct {
|
type SignTransactionArgs struct {
|
||||||
From common.Address
|
From common.Address
|
||||||
To common.Address
|
To *common.Address
|
||||||
Nonce *rpc.HexNumber
|
Nonce *rpc.HexNumber
|
||||||
Value *rpc.HexNumber
|
Value *rpc.HexNumber
|
||||||
Gas *rpc.HexNumber
|
Gas *rpc.HexNumber
|
||||||
@ -1132,23 +1133,21 @@ type Tx struct {
|
|||||||
|
|
||||||
func (tx *Tx) UnmarshalJSON(b []byte) (err error) {
|
func (tx *Tx) UnmarshalJSON(b []byte) (err error) {
|
||||||
req := struct {
|
req := struct {
|
||||||
To common.Address `json:"to"`
|
To *common.Address `json:"to"`
|
||||||
From common.Address `json:"from"`
|
From common.Address `json:"from"`
|
||||||
Nonce *rpc.HexNumber `json:"nonce"`
|
Nonce *rpc.HexNumber `json:"nonce"`
|
||||||
Value *rpc.HexNumber `json:"value"`
|
Value *rpc.HexNumber `json:"value"`
|
||||||
Data string `json:"data"`
|
Data string `json:"data"`
|
||||||
GasLimit *rpc.HexNumber `json:"gas"`
|
GasLimit *rpc.HexNumber `json:"gas"`
|
||||||
GasPrice *rpc.HexNumber `json:"gasPrice"`
|
GasPrice *rpc.HexNumber `json:"gasPrice"`
|
||||||
Hash common.Hash `json:"hash"`
|
Hash common.Hash `json:"hash"`
|
||||||
}{}
|
}{}
|
||||||
|
|
||||||
if err := json.Unmarshal(b, &req); err != nil {
|
if err := json.Unmarshal(b, &req); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
contractCreation := (req.To == (common.Address{}))
|
tx.To = req.To
|
||||||
|
|
||||||
tx.To = &req.To
|
|
||||||
tx.From = req.From
|
tx.From = req.From
|
||||||
tx.Nonce = req.Nonce
|
tx.Nonce = req.Nonce
|
||||||
tx.Value = req.Value
|
tx.Value = req.Value
|
||||||
@ -1172,12 +1171,10 @@ func (tx *Tx) UnmarshalJSON(b []byte) (err error) {
|
|||||||
tx.GasPrice = rpc.NewHexNumber(int64(50000000000))
|
tx.GasPrice = rpc.NewHexNumber(int64(50000000000))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
contractCreation := (req.To == nil)
|
||||||
if contractCreation {
|
if contractCreation {
|
||||||
tx.tx = types.NewContractCreation(tx.Nonce.Uint64(), tx.Value.BigInt(), tx.GasLimit.BigInt(), tx.GasPrice.BigInt(), data)
|
tx.tx = types.NewContractCreation(tx.Nonce.Uint64(), tx.Value.BigInt(), tx.GasLimit.BigInt(), tx.GasPrice.BigInt(), data)
|
||||||
} else {
|
} else {
|
||||||
if tx.To == nil {
|
|
||||||
return fmt.Errorf("need to address")
|
|
||||||
}
|
|
||||||
tx.tx = types.NewTransaction(tx.Nonce.Uint64(), *tx.To, tx.Value.BigInt(), tx.GasLimit.BigInt(), tx.GasPrice.BigInt(), data)
|
tx.tx = types.NewTransaction(tx.Nonce.Uint64(), *tx.To, tx.Value.BigInt(), tx.GasLimit.BigInt(), tx.GasPrice.BigInt(), data)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1226,12 +1223,12 @@ func (s *PublicTransactionPoolAPI) SignTransaction(args *SignTransactionArgs) (*
|
|||||||
}
|
}
|
||||||
|
|
||||||
var tx *types.Transaction
|
var tx *types.Transaction
|
||||||
contractCreation := (args.To == common.Address{})
|
contractCreation := (args.To == nil)
|
||||||
|
|
||||||
if contractCreation {
|
if contractCreation {
|
||||||
tx = types.NewContractCreation(args.Nonce.Uint64(), args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
tx = types.NewContractCreation(args.Nonce.Uint64(), args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
||||||
} else {
|
} else {
|
||||||
tx = types.NewTransaction(args.Nonce.Uint64(), args.To, args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
tx = types.NewTransaction(args.Nonce.Uint64(), *args.To, args.Value.BigInt(), args.Gas.BigInt(), args.GasPrice.BigInt(), common.FromHex(args.Data))
|
||||||
}
|
}
|
||||||
|
|
||||||
signedTx, err := s.sign(args.From, tx)
|
signedTx, err := s.sign(args.From, tx)
|
||||||
@ -1324,7 +1321,7 @@ func (s *PublicTransactionPoolAPI) Resend(tx *Tx, gasPrice, gasLimit *rpc.HexNum
|
|||||||
}
|
}
|
||||||
|
|
||||||
var newTx *types.Transaction
|
var newTx *types.Transaction
|
||||||
contractCreation := (*tx.tx.To() == common.Address{})
|
contractCreation := (tx.tx.To() == nil)
|
||||||
if contractCreation {
|
if contractCreation {
|
||||||
newTx = types.NewContractCreation(tx.tx.Nonce(), tx.tx.Value(), gasPrice.BigInt(), gasLimit.BigInt(), tx.tx.Data())
|
newTx = types.NewContractCreation(tx.tx.Nonce(), tx.tx.Value(), gasPrice.BigInt(), gasLimit.BigInt(), tx.tx.Data())
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user