diff options
author | Bas van Kervel <bas@ethdev.com> | 2015-07-10 17:35:15 +0800 |
---|---|---|
committer | Bas van Kervel <bas@ethdev.com> | 2015-07-28 16:42:31 +0800 |
commit | 7e31df39877d95446b48c8064e55ebef48d4e5c6 (patch) | |
tree | 7092be5bdfe8cff0c7ec014576b87add78b8f79b /rpc/api/eth.go | |
parent | 5a810758dbe75dce9537d464ac0e5b5385b0e78f (diff) | |
download | dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar.gz dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar.bz2 dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar.lz dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar.xz dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.tar.zst dexon-7e31df39877d95446b48c8064e55ebef48d4e5c6.zip |
bugfix, pending transaction was resend with new gas price/limit but not removed from transaction pool
Diffstat (limited to 'rpc/api/eth.go')
-rw-r--r-- | rpc/api/eth.go | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/rpc/api/eth.go b/rpc/api/eth.go index 6c4745504..3fbb8d755 100644 --- a/rpc/api/eth.go +++ b/rpc/api/eth.go @@ -21,8 +21,9 @@ import ( "encoding/json" "math/big" + "fmt" + "github.com/ethereum/go-ethereum/common" - "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/eth" "github.com/ethereum/go-ethereum/rpc/codec" "github.com/ethereum/go-ethereum/rpc/shared" @@ -578,14 +579,17 @@ func (self *ethApi) Resend(req *shared.Request) (interface{}, error) { return nil, shared.NewDecodeParamError(err.Error()) } - ret, err := self.xeth.Transact(args.Tx.From, args.Tx.To, args.Tx.Nonce, args.Tx.Value, args.GasLimit, args.GasPrice, args.Tx.Data) - if err != nil { - return nil, err - } + from := common.HexToAddress(args.Tx.From) - self.ethereum.TxPool().RemoveTransactions(types.Transactions{args.Tx.tx}) + pending := self.ethereum.TxPool().GetTransactions() + for _, p := range pending { + if pFrom, err := p.From(); err == nil && pFrom == from && p.SigHash() == args.Tx.tx.SigHash() { + self.ethereum.TxPool().RemoveTx(common.HexToHash(args.Tx.Hash)) + return self.xeth.Transact(args.Tx.From, args.Tx.To, args.Tx.Nonce, args.Tx.Value, args.GasLimit, args.GasPrice, args.Tx.Data) + } + } - return ret, nil + return nil, fmt.Errorf("Transaction %s not found", args.Tx.Hash) } func (self *ethApi) PendingTransactions(req *shared.Request) (interface{}, error) { |