aboutsummaryrefslogtreecommitdiffstats
path: root/rpc/api/eth.go
diff options
context:
space:
mode:
authorBas van Kervel <bas@ethdev.com>2015-06-24 20:56:53 +0800
committerBas van Kervel <bas@ethdev.com>2015-06-24 20:56:53 +0800
commitdc58568a25e54ea601aefb8e97f427cae0814612 (patch)
treef1d2cad2817364537c833bd5a333dd322de677d4 /rpc/api/eth.go
parentf1a4a6e563ea72affe365d89513e5c83a35e4c28 (diff)
downloadgo-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar.gz
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar.bz2
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar.lz
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar.xz
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.tar.zst
go-tangerine-dc58568a25e54ea601aefb8e97f427cae0814612.zip
added eth.resend
Diffstat (limited to 'rpc/api/eth.go')
-rw-r--r--rpc/api/eth.go18
1 files changed, 18 insertions, 0 deletions
diff --git a/rpc/api/eth.go b/rpc/api/eth.go
index 77c710fb0..2bd7e4cdb 100644
--- a/rpc/api/eth.go
+++ b/rpc/api/eth.go
@@ -6,6 +6,7 @@ import (
"math/big"
"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"
@@ -74,6 +75,7 @@ var (
"eth_hashrate": (*ethApi).Hashrate,
"eth_getWork": (*ethApi).GetWork,
"eth_submitWork": (*ethApi).SubmitWork,
+ "eth_resend": (*ethApi).Resend,
"eth_pendingTransactions": (*ethApi).PendingTransactions,
}
)
@@ -561,6 +563,22 @@ func (self *ethApi) SubmitWork(req *shared.Request) (interface{}, error) {
return self.xeth.RemoteMining().SubmitWork(args.Nonce, common.HexToHash(args.Digest), common.HexToHash(args.Header)), nil
}
+func (self *ethApi) Resend(req *shared.Request) (interface{}, error) {
+ args := new(ResendArgs)
+ if err := self.codec.Decode(req.Params, &args); err != nil {
+ 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
+ }
+
+ self.ethereum.TxPool().RemoveTransactions(types.Transactions{args.Tx.tx})
+
+ return ret, nil
+}
+
func (self *ethApi) PendingTransactions(req *shared.Request) (interface{}, error) {
txs := self.ethereum.TxPool().GetTransactions()