added eth.pendingTransactions
This commit is contained in:
		
							parent
							
								
									22c7ce0162
								
							
						
					
					
						commit
						f1a4a6e563
					
				| @ -6,9 +6,11 @@ import ( | |||||||
| 	"math/big" | 	"math/big" | ||||||
| 
 | 
 | ||||||
| 	"github.com/ethereum/go-ethereum/common" | 	"github.com/ethereum/go-ethereum/common" | ||||||
|  | 	"github.com/ethereum/go-ethereum/eth" | ||||||
| 	"github.com/ethereum/go-ethereum/rpc/codec" | 	"github.com/ethereum/go-ethereum/rpc/codec" | ||||||
| 	"github.com/ethereum/go-ethereum/rpc/shared" | 	"github.com/ethereum/go-ethereum/rpc/shared" | ||||||
| 	"github.com/ethereum/go-ethereum/xeth" | 	"github.com/ethereum/go-ethereum/xeth" | ||||||
|  | 	"gopkg.in/fatih/set.v0" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const ( | const ( | ||||||
| @ -19,6 +21,7 @@ const ( | |||||||
| // See https://github.com/ethereum/wiki/wiki/JSON-RPC
 | // See https://github.com/ethereum/wiki/wiki/JSON-RPC
 | ||||||
| type ethApi struct { | type ethApi struct { | ||||||
| 	xeth     *xeth.XEth | 	xeth     *xeth.XEth | ||||||
|  | 	ethereum *eth.Ethereum | ||||||
| 	methods  map[string]ethhandler | 	methods  map[string]ethhandler | ||||||
| 	codec    codec.ApiCoder | 	codec    codec.ApiCoder | ||||||
| } | } | ||||||
| @ -71,12 +74,13 @@ var ( | |||||||
| 		"eth_hashrate":                            (*ethApi).Hashrate, | 		"eth_hashrate":                            (*ethApi).Hashrate, | ||||||
| 		"eth_getWork":                             (*ethApi).GetWork, | 		"eth_getWork":                             (*ethApi).GetWork, | ||||||
| 		"eth_submitWork":                          (*ethApi).SubmitWork, | 		"eth_submitWork":                          (*ethApi).SubmitWork, | ||||||
|  | 		"eth_pendingTransactions":                 (*ethApi).PendingTransactions, | ||||||
| 	} | 	} | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // create new ethApi instance
 | // create new ethApi instance
 | ||||||
| func NewEthApi(xeth *xeth.XEth, codec codec.Codec) *ethApi { | func NewEthApi(xeth *xeth.XEth, eth *eth.Ethereum, codec codec.Codec) *ethApi { | ||||||
| 	return ðApi{xeth, ethMapping, codec.New(nil)} | 	return ðApi{xeth, eth, ethMapping, codec.New(nil)} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // collection with supported methods
 | // collection with supported methods
 | ||||||
| @ -556,3 +560,29 @@ 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 | 	return self.xeth.RemoteMining().SubmitWork(args.Nonce, common.HexToHash(args.Digest), common.HexToHash(args.Header)), nil | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func (self *ethApi) PendingTransactions(req *shared.Request) (interface{}, error) { | ||||||
|  | 	txs := self.ethereum.TxPool().GetTransactions() | ||||||
|  | 
 | ||||||
|  | 	// grab the accounts from the account manager. This will help with determening which
 | ||||||
|  | 	// transactions should be returned.
 | ||||||
|  | 	accounts, err := self.ethereum.AccountManager().Accounts() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	// Add the accouns to a new set
 | ||||||
|  | 	accountSet := set.New() | ||||||
|  | 	for _, account := range accounts { | ||||||
|  | 		accountSet.Add(account.Address) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	var ltxs []*tx | ||||||
|  | 	for _, tx := range txs { | ||||||
|  | 		if from, _ := tx.From(); accountSet.Has(from) { | ||||||
|  | 			ltxs = append(ltxs, newTx(tx)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return ltxs, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -5,8 +5,11 @@ import ( | |||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"math/big" | 	"math/big" | ||||||
| 
 | 
 | ||||||
|  | 	"strconv" | ||||||
|  | 
 | ||||||
| 	"github.com/ethereum/go-ethereum/common" | 	"github.com/ethereum/go-ethereum/common" | ||||||
| 	"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/rpc/shared" | 	"github.com/ethereum/go-ethereum/rpc/shared" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| @ -858,3 +861,34 @@ func (args *SubmitWorkArgs) UnmarshalJSON(b []byte) (err error) { | |||||||
| 
 | 
 | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | type tx struct { | ||||||
|  | 	tx *types.Transaction | ||||||
|  | 
 | ||||||
|  | 	To       string | ||||||
|  | 	From     string | ||||||
|  | 	Nonce    string | ||||||
|  | 	Value    string | ||||||
|  | 	Data     string | ||||||
|  | 	GasLimit string | ||||||
|  | 	GasPrice string | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func newTx(t *types.Transaction) *tx { | ||||||
|  | 	from, _ := t.From() | ||||||
|  | 	var to string | ||||||
|  | 	if t := t.To(); t != nil { | ||||||
|  | 		to = t.Hex() | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return &tx{ | ||||||
|  | 		tx:       t, | ||||||
|  | 		To:       to, | ||||||
|  | 		From:     from.Hex(), | ||||||
|  | 		Value:    t.Amount.String(), | ||||||
|  | 		Nonce:    strconv.Itoa(int(t.Nonce())), | ||||||
|  | 		Data:     "0x" + common.Bytes2Hex(t.Data()), | ||||||
|  | 		GasLimit: t.GasLimit.String(), | ||||||
|  | 		GasPrice: t.GasPrice().String(), | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
| @ -15,6 +15,14 @@ web3._extend({ | |||||||
| 			inputFormatter: [web3._extend.formatters.formatInputString,web3._extend.formatters.formatInputString], | 			inputFormatter: [web3._extend.formatters.formatInputString,web3._extend.formatters.formatInputString], | ||||||
| 			outputFormatter: web3._extend.formatters.formatOutputString | 			outputFormatter: web3._extend.formatters.formatOutputString | ||||||
| 		}) | 		}) | ||||||
|  | 	], | ||||||
|  | 	properties: | ||||||
|  | 	[ | ||||||
|  | 		new web3._extend.Property({ | ||||||
|  | 			name: 'pendingTransactions', | ||||||
|  | 			getter: 'eth_pendingTransactions', | ||||||
|  | 			outputFormatter: function(obj) { return obj; } | ||||||
|  | 		}) | ||||||
| 	] | 	] | ||||||
| }); | }); | ||||||
| ` | ` | ||||||
|  | |||||||
| @ -84,6 +84,7 @@ var ( | |||||||
| 			"hashrate", | 			"hashrate", | ||||||
| 			"getWork", | 			"getWork", | ||||||
| 			"submitWork", | 			"submitWork", | ||||||
|  | 			"pendingTransactions", | ||||||
| 		}, | 		}, | ||||||
| 		"miner": []string{ | 		"miner": []string{ | ||||||
| 			"hashrate", | 			"hashrate", | ||||||
| @ -149,7 +150,7 @@ func ParseApiString(apistr string, codec codec.Codec, xeth *xeth.XEth, eth *eth. | |||||||
| 		case shared.DbApiName: | 		case shared.DbApiName: | ||||||
| 			apis[i] = NewDbApi(xeth, eth, codec) | 			apis[i] = NewDbApi(xeth, eth, codec) | ||||||
| 		case shared.EthApiName: | 		case shared.EthApiName: | ||||||
| 			apis[i] = NewEthApi(xeth, codec) | 			apis[i] = NewEthApi(xeth, eth, codec) | ||||||
| 		case shared.MinerApiName: | 		case shared.MinerApiName: | ||||||
| 			apis[i] = NewMinerApi(eth, codec) | 			apis[i] = NewMinerApi(eth, codec) | ||||||
| 		case shared.NetApiName: | 		case shared.NetApiName: | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user