Skip to content
This repository has been archived by the owner on May 21, 2024. It is now read-only.

Rebase statediffing service with 1.9.9 #2

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
181 commits
Select commit Hold shift + click to select a range
d13d4e7
README: accounts in alloc field should exist (#20005)
FlashSheridan Sep 10, 2019
b38b67b
common, graphql: fix hash/address decoding + UI content type
karalabe Sep 10, 2019
3f508dd
core, metrics, p2p: switch some invalid counters to gauges
karalabe Sep 10, 2019
c8edd62
core/state: optimize some internals during encoding
holiman Sep 5, 2019
8f545e4
eth: remove unused field (#20049)
trung Sep 10, 2019
9bf45a8
tests: expose internal RunNoVerify method (#20051)
holiman Sep 11, 2019
9b7a698
all: make unit tests work with Go 1.13 (#20053)
fjl Sep 11, 2019
0b88628
travis, Dockerfile, appveyor: bump to Go 1.13
karalabe Sep 12, 2019
19ee463
build: switch PPA from Gophers dep to manual download
karalabe Sep 12, 2019
b634ddf
Revert "build: switch PPA from Gophers dep to manual download" (#20061)
karalabe Sep 12, 2019
f231018
core: remove unused gas return in ApplyTransaction (#20065)
rmulhol Sep 12, 2019
5948e15
rlp: improve nil pointer handling (#20064)
fjl Sep 13, 2019
3b815cd
cmd/evm: make evm default to all ethash protocol changes
holiman Sep 13, 2019
044c44e
core/state: accumulate writes and only update tries when must
karalabe Aug 12, 2019
17a0938
core: add blockchain test too for revert cornercase
holiman Sep 16, 2019
129649f
common/mclock: clean up AfterFunc support (#20054)
fjl Sep 16, 2019
3aa8cfc
core: smaller txpool status locking (#20080)
holiman Sep 17, 2019
f8fea87
core: dedup known transactions without global lock, track metrics
karalabe Sep 17, 2019
9e25464
les: multiple server bugfixes (#20079)
zsfelfoldi Sep 17, 2019
6bdf944
core: fix tx dedup return error count
karalabe Sep 18, 2019
4e147fa
params: activate Istanbul on Ropsten and Görli
soc1c Sep 19, 2019
db7491f
params: bump CHTs for the 1.9.4 release
karalabe Sep 19, 2019
510358f
core/forkid, params: fix tests, enable Istanbul on Rinkeby + testers
karalabe Sep 19, 2019
bc29f18
vendor: pull in USB Windows fixes
karalabe Sep 19, 2019
3f5fd57
params: release Geth v1.9.4 stable
karalabe Sep 19, 2019
f893b9d
params: start v1.9.5 release cycle
karalabe Sep 19, 2019
86e8a36
params: remove legacy bootnodes
skylenet Sep 19, 2019
41258ce
core/state: fix state object deep copy (#20100)
rjl493456442 Sep 20, 2019
ddb3749
params: release Geth v1.9.5 stable
fjl Sep 20, 2019
524e521
params: start v1.9.6 release cycle
fjl Sep 20, 2019
05e4e73
core/state: fix copy-commit-copy (#20113)
karalabe Sep 24, 2019
439a1ed
dashboard: log host+port
holiman Sep 24, 2019
0f030d5
les: fix checkpoint sync (#20120)
rjl493456442 Sep 25, 2019
ae4c946
p2p/dnsdisc: add implementation of EIP-1459 (#20094)
fjl Sep 25, 2019
b7c22d0
tests/solidity: add contract to test every opcode (#19283)
lhendre Sep 26, 2019
db3aac4
internal/ethapi: support block number or hash on state-related method…
ryanschneider Sep 26, 2019
cca42b3
core/blockchain: remove block from futureBlocks on error (#19763)
ywzqwwt Sep 26, 2019
6fd8d65
core/state: fix database leak and copy tests (#19306)
zcheng9 Sep 26, 2019
660a9f6
core: initialize current block/fastblock atomics to nil, fix #19286 (…
holiman Sep 26, 2019
b6280e8
ethdb/leveldb: disable seek compaction (#20130)
rjl493456442 Sep 26, 2019
1f97547
p2p: measure subprotocol bandwidth usage
karalabe Sep 27, 2019
7c73292
github: Added capital P (#20139)
kishore-hariram Sep 30, 2019
8ba6c63
tests: update test suite for istanbul (#20082)
holiman Oct 2, 2019
4a2c02d
cmd/bootnode: fix exit behavior with -genkey (#20110)
dherbst Oct 2, 2019
440c22b
les: add empty "les" ENR entry for servers (#20145)
fjl Oct 2, 2019
e57dcb0
params: release Geth v1.9.6 stable
fjl Oct 3, 2019
5aef43b
params: begin v1.9.7 release cycle
fjl Oct 3, 2019
fad5775
cmd/utils: fix command line flag resolve (#20167)
rjl493456442 Oct 15, 2019
c56dd7a
params: check fork ordering when initializing new genesis, fixes #201…
holiman Oct 16, 2019
2d6ba6d
p2p/dnsdisc: update to latest EIP-1459 spec (#20168)
fjl Oct 16, 2019
3907f79
p2p/simulations: add node properties support and utility functions (#…
chadsr Oct 17, 2019
cf22e8b
README: use new miner threads flag instead of legacy minerthreads fla…
jeffwalsh Oct 17, 2019
a5be7ce
Changed http:// to https:// on links in log/README.md (#20178)
sandakersmann Oct 18, 2019
f801dc9
dashboard: change links in README to https (#20181)
sandakersmann Oct 18, 2019
1b2cdc2
metrics: change links in README.md to https (#20182)
sandakersmann Oct 20, 2019
d23dd69
miner: add generate and import unit test (#20111)
rjl493456442 Oct 20, 2019
ccca2e7
accounts/abi/bind: take into account gas price during gas estimation …
pdyraga Oct 21, 2019
d64c85c
clef: resolve windows pipes, fixes #20121 (#20166)
holiman Oct 24, 2019
f52b6a2
consensus: fix possessives in comments. (#20209)
gballet Oct 28, 2019
c8a13c8
cmd/evm: remove surrounding whitespace in hex input code (#20211)
michaelforney Oct 28, 2019
d235225
trie: remove node ordering slice in sync batch (#19929)
rjl493456442 Oct 28, 2019
256b262
core/asm: assembly parser label fixes (#20210)
michaelforney Oct 29, 2019
d58bf2a
eth/downloader: fix data race in downloader
holiman Oct 25, 2019
8bfae73
cmd/devp2p, p2p: dial using node iterator, discovery crawler (#20132)
fjl Oct 29, 2019
a84b873
eth: eth/64 - extend handshake packet with fork id
karalabe Sep 30, 2019
667eb35
core/forkid: add two clauses for more precise validation (#20220)
karalabe Oct 30, 2019
0408371
miner: increase import time allowance (#20217)
rjl493456442 Oct 30, 2019
f3f64f9
cmd/devp2p, core/forkid: make forkid.Filter API uniform
karalabe Oct 31, 2019
15ab4d8
params, core/forkid: configure mainnet istanbul block 9069K (#20222)
holiman Oct 31, 2019
456d057
accounts/abi: add internalType information and fix issues (#20179)
rjl493456442 Oct 31, 2019
30b82e4
appveyor: bump to Go 1.13.4
SamuelMarks Nov 2, 2019
6866bfe
les: rework clientpool (#20077)
rjl493456442 Nov 2, 2019
5523fa0
cmd/puppeth: integrate istanbul into puppeth (#19926)
rjl493456442 Nov 4, 2019
cd70baa
core/evm: avoid copying memory for input in calls (#20177)
holiman Nov 4, 2019
2846308
travis, build, internal: use own Go bundle for PPA builds (#20240)
karalabe Nov 5, 2019
20cb48a
travis: bump linter to Go 1.13.x
karalabe Nov 5, 2019
49a0139
params: hard-code new CHTs for the 1.9.7 release
karalabe Nov 6, 2019
691ab54
les: fix and slim the unit tests of les (#20247)
rjl493456442 Nov 6, 2019
e5e855c
params: release Geth v1.9.7
karalabe Nov 7, 2019
bde09a3
params: begin v1.9.8 release cycle
karalabe Nov 7, 2019
79cfb3b
p2p/enode: mock DNS resolver in URL parsing test (#20252)
fjl Nov 7, 2019
e8a1cb0
travis: enable test suite on ARM64 (#20219)
gballet Nov 8, 2019
354c1e2
p2p: fix bug in TestPeerDisconnect (#20277)
Nov 13, 2019
61690f5
dashboard: send current block to the dashboard client (#19762)
kurkomisi Nov 13, 2019
2d04713
miner: increase worker test timeout (#20268)
gballet Nov 13, 2019
b173398
les: implement server priority API (#20070)
zsfelfoldi Nov 13, 2019
a38d627
accounts/abi/bind, cmd/abigen: implement alias for abigen (#20244)
rjl493456442 Nov 14, 2019
19a4fdf
rpc: fix typo example code (#20284)
Jorropo Nov 14, 2019
82771dd
cmd/faucet: use github.com/gorilla/websocket (#20283)
fjl Nov 14, 2019
b5f5619
dashboard: remove the dashboard (#20279)
fjl Nov 14, 2019
4baa8bb
whisper/whisperv6: fix staticcheck issues (#20288)
gballet Nov 14, 2019
01dafdc
build: gather info to investigate why builds fail on ARM (#20281)
gballet Nov 14, 2019
dd3a02f
params: finish sentence in comment (#20291)
meowsbits Nov 14, 2019
1b8755d
core/vm: fix tracer interface parameter name (#20294)
nebojsa94 Nov 15, 2019
ff5d3b6
internal/ethapi: don't query wallets at every execution of gas estima…
holiman Nov 11, 2019
fe05134
cmd/evm: Allow loading input from file (#20273)
michaelforney Nov 17, 2019
0d01c9d
rpc, p2p/simulations: use github.com/gorilla/websocket (#20289)
fjl Nov 18, 2019
2ec77ef
build: use golangci-lint (#20295)
fjl Nov 18, 2019
f94f9a1
travis: remove traces and use travis_wait in ARM build (#20296)
gballet Nov 18, 2019
203263e
core: s/isEIP155/isHomestead/g (fix IntrinsicGas signature var name) …
meowsbits Nov 18, 2019
6fd2b31
les: rename UpdateBalance to AddBalance and simplify return format (#…
zsfelfoldi Nov 18, 2019
36f409d
travis: use travis_wait for both install and build (#20309)
gballet Nov 18, 2019
5a9ee5e
build: add test cmd flag -v for verbose logs (#20298)
meowsbits Nov 18, 2019
b8b1edd
cmd/clef: fix staticcheck warnings (#20314)
fjl Nov 18, 2019
2bd68c3
consensus/clique: add clique_status API method (#20103)
holiman Nov 18, 2019
308a5b3
consensus/clique: fix struct tags for status API (#20316)
fjl Nov 18, 2019
03ea59d
cmd/ethkey: fix file permissions in changepassword command (#20313)
fjl Nov 19, 2019
3ef5328
p2p/netutil: fix staticcheck warning (#20315)
fjl Nov 19, 2019
24fd557
core/rawdb: check hash before return data from ancient db (#20195)
rjl493456442 Nov 19, 2019
daad644
travis: deactivate arm build during push (#20321)
gballet Nov 19, 2019
d5380c0
ethclient: remove use of common.ToHex (#20326)
fjl Nov 19, 2019
3b56400
cmd/wnode: remove uses of common.ToHex (#20327)
fjl Nov 19, 2019
2aace48
event: remove unused field 'closed' (#20324)
fjl Nov 19, 2019
a6a20fd
.github: remove 'nonsense' from CODEOWNERS (#20329)
gballet Nov 19, 2019
1a52d18
whisper/whisperv6: fix staticcheck warnings (#20328)
fjl Nov 19, 2019
2ecd59c
p2p: remove unused code (#20325)
fjl Nov 19, 2019
eb08eec
p2p/simulations: fix staticcheck warnings (#20322)
fjl Nov 19, 2019
61b32fd
internal/web3ext, les: update clique JS and make it work with the lig…
fjl Nov 19, 2019
0093c73
rpc: remove 'exported or builtin' restriction for parameters (#20332)
fjl Nov 20, 2019
086f2b5
core: fix staticcheck warnings (#20323)
fjl Nov 20, 2019
cf06a76
miner: fix data race in tests (#20310)
rjl493456442 Nov 20, 2019
bbb3124
cmd/puppeth: update chain spec of parity (#20241)
rjl493456442 Nov 20, 2019
09254ef
go.mod, vendor: switch to Go modules
karalabe Nov 18, 2019
d1da933
travis: explicitly enable go modules in Go 1.11 and 1.12
karalabe Nov 18, 2019
c5eca30
accounts/abi/bind: switch binding test to go modules
karalabe Nov 18, 2019
ee797b4
travis, build: aggregate and upload go mod dependencies for PPA
karalabe Nov 18, 2019
bf66b43
go.mod: tidy up the modules to avoid xgo writes to go.sum
karalabe Nov 18, 2019
d0e1a29
build, internal/build: drop own file/folder copier
karalabe Nov 18, 2019
c0108bd
travis: fake build ppa only for go module dependencies
karalabe Nov 18, 2019
891816a
mobile: fix CopyFile switch to package cp
karalabe Nov 18, 2019
a0dbe54
tests: refactor TestState to dedupe walk callback
meowsbits Nov 20, 2019
4380659
build, travis: use ephemeral debsrc GOPATH to get mod deps
karalabe Nov 20, 2019
5d287ee
tests: enable TransactionTests Istanbul case (#20337)
meowsbits Nov 20, 2019
223c330
cmd/puppeth: x-spec nonce data type, use types.BlockNonce
meowsbits Nov 20, 2019
a6544ea
cmd/puppeth: make ssh prompt more user-friendly
holiman Nov 21, 2019
103037a
common/hexutil: improve GraphQL error messages (#20353)
fjl Nov 21, 2019
00ae676
build: pull in ci.go dependencies for the PPA builder
karalabe Nov 21, 2019
2f20253
common: improve GraphQL error messages (#20354)
fjl Nov 21, 2019
d4520b0
core/types: remove BlockBy sorting code (#20355)
fjl Nov 21, 2019
04d05f4
build: skip go clean on PPA, messes with the module trick
karalabe Nov 21, 2019
f42ce3d
accounts/abi/bind/backends: remove unused assignment (#20359)
fjl Nov 21, 2019
4b528b5
accounts/abi: fix staticcheck warnings (#20358)
fjl Nov 21, 2019
928f05a
core/state: fix staticcheck warnings (#20357)
fjl Nov 22, 2019
693fa15
metrics: fix issues reported by staticcheck (#20365)
gballet Nov 22, 2019
abee9f2
trie: remove unused code (#20366)
fjl Nov 22, 2019
5fc4f93
p2p/discv5: add deprecation warning and remove unused code (#20367)
fjl Nov 22, 2019
5c70ccb
tests, signer: remove staticcheck warnings (#20364)
gballet Nov 23, 2019
af378c2
core/asm: allow numbers in labels (#20362)
michaelforney Nov 23, 2019
9081848
miner: fix staticcheck warnings (#20375)
gballet Nov 24, 2019
c69a5ac
eth/tracers: fix staticcheck warnings (#20379)
gballet Nov 24, 2019
dace204
trie: replace bigcache with fastcache (#19971)
rjl493456442 Nov 25, 2019
a9acff7
cmd/geth: remove network id from version cmd
meowsbits Nov 25, 2019
d25502d
rlp: fix staticcheck warnings (#20368)
fjl Nov 25, 2019
9464c4f
accounts/abi/bind: avoid reclaring structs (#20381)
rjl493456442 Nov 25, 2019
32c5dde
accounts/keystore: fix staticcheck warnings (#20373)
gballet Nov 25, 2019
0053af9
p2p/discover: slow down lookups on empty table (#20389)
fjl Nov 26, 2019
a66f2be
les: fix clientInfo deadlock (#20395)
zsfelfoldi Nov 26, 2019
0c5d762
params: release go-ethereum v1.9.8
karalabe Nov 26, 2019
c8a26e0
params: begin v1.9.9 release cycle
karalabe Nov 26, 2019
c00aff6
cmd: fix command help messages in modules (#20203)
zacscoding Nov 26, 2019
6ab9ca8
les: fix staticcheck warnings (#20371)
gballet Nov 27, 2019
7e31c1c
core: fix staticcheck warnings (#20384)
gballet Nov 27, 2019
9a5c634
core/rawdb: fix reinit regression caused by the hash check PR
karalabe Nov 27, 2019
035fbf4
deps: update fastcache to 1.5.3
holiman Nov 27, 2019
01580dd
consensus/ethash: refactor remote sealer (#20335)
fjl Nov 28, 2019
3ce1ffb
log: fix staticcheck warnings (#20388)
gballet Nov 28, 2019
e6a40ea
trie: remove dead code (#20405)
rjl493456442 Nov 28, 2019
fe2eb82
cmd/faucet, cmd/geth: fix staticcheck warnings (#20374)
gballet Nov 29, 2019
9431c43
internal: fix staticcheck warnings (#20380)
gballet Nov 29, 2019
6f764e5
accounts/scwallet: fix staticcheck warnings (#20370)
gballet Nov 29, 2019
ac68fd2
internal/web3ext: add debug_accountRange (#20410)
xinluyin Nov 29, 2019
ac34619
accounts/usbwallet: fix staticcheck warnings (#20372)
gballet Nov 29, 2019
d8f79aa
core, miner: remove PostChainEvents (#19396)
rjl493456442 Nov 29, 2019
d05cf37
accounts/abi/bind: fix destructive packing of *big.Int (#20412)
MariusVanDerWijden Dec 2, 2019
f08a025
trie: track dirty cache metrics, track clean writes on commit
karalabe Dec 2, 2019
24ebeb4
params: update CHTs for v1.9.9 release
karalabe Dec 5, 2019
1ffa09a
p2p/enode: remove data race in sliceIter (#20421)
MariusVanDerWijden Dec 5, 2019
4993a36
consensus/ethash, params: eip-2384: bump difficulty bomb (#20347)
holiman Dec 6, 2019
10e11ef
params: release Geth v1.9.9
karalabe Dec 6, 2019
a7ac3a2
Update test block hashes
elizabethengelman Dec 20, 2019
e3bcdd6
Cleanup after rebasing v1.9.9
elizabethengelman Dec 20, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
rpc, p2p/simulations: use github.com/gorilla/websocket (ethereum#20289)
* rpc: improve codec abstraction

rpc.ServerCodec is an opaque interface. There was only one way to get a
codec using existing APIs: rpc.NewJSONCodec. This change exports
newCodec (as NewFuncCodec) and NewJSONCodec (as NewCodec). It also makes
all codec methods non-public to avoid showing internals in godoc.

While here, remove codec options in tests because they are not
supported anymore.

* p2p/simulations: use github.com/gorilla/websocket

This package was the last remaining user of golang.org/x/net/websocket.
Migrating to the new library wasn't straightforward because it is no
longer possible to treat WebSocket connections as a net.Conn.

* vendor: delete golang.org/x/net/websocket

* rpc: fix godoc comments and run gofmt
  • Loading branch information
fjl authored and elizabethengelman committed Dec 20, 2019
commit 0d01c9d14d6298928c9eddd2650cc79bca7f0e02
48 changes: 27 additions & 21 deletions p2p/simulations/adapters/exec.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ import (
"github.com/ethereum/go-ethereum/p2p"
"github.com/ethereum/go-ethereum/p2p/enode"
"github.com/ethereum/go-ethereum/rpc"
"golang.org/x/net/websocket"
"github.com/gorilla/websocket"
)

func init() {
Expand Down Expand Up @@ -118,7 +118,7 @@ func (e *ExecAdapter) NewNode(config *NodeConfig) (Node, error) {
conf.Stack.P2P.NAT = nil
conf.Stack.NoUSB = true

// listen on a localhost port, which we set when we
// Listen on a localhost port, which we set when we
// initialise NodeConfig (usually a random port)
conf.Stack.P2P.ListenAddr = fmt.Sprintf(":%d", config.Port)

Expand Down Expand Up @@ -205,17 +205,17 @@ func (n *ExecNode) Start(snapshots map[string][]byte) (err error) {
}
n.Cmd = cmd

// read the WebSocket address from the stderr logs
// Wait for the node to start.
status := <-statusC
if status.Err != "" {
return errors.New(status.Err)
}
client, err := rpc.DialWebsocket(ctx, status.WSEndpoint, "http://localhost")
client, err := rpc.DialWebsocket(ctx, status.WSEndpoint, "")
if err != nil {
return fmt.Errorf("can't connect to RPC server: %v", err)
}

// node ready :)
// Node ready :)
n.client = client
n.wsAddr = status.WSEndpoint
n.Info = status.NodeInfo
Expand Down Expand Up @@ -314,31 +314,37 @@ func (n *ExecNode) NodeInfo() *p2p.NodeInfo {

// ServeRPC serves RPC requests over the given connection by dialling the
// node's WebSocket address and joining the two connections
func (n *ExecNode) ServeRPC(clientConn net.Conn) error {
conn, err := websocket.Dial(n.wsAddr, "", "http://localhost")
func (n *ExecNode) ServeRPC(clientConn *websocket.Conn) error {
conn, _, err := websocket.DefaultDialer.Dial(n.wsAddr, nil)
if err != nil {
return err
}
var wg sync.WaitGroup
wg.Add(2)
join := func(src, dst net.Conn) {
defer wg.Done()
io.Copy(dst, src)
// close the write end of the destination connection
if cw, ok := dst.(interface {
CloseWrite() error
}); ok {
cw.CloseWrite()
} else {
dst.Close()
}
}
go join(conn, clientConn)
go join(clientConn, conn)
go wsCopy(&wg, conn, clientConn)
go wsCopy(&wg, clientConn, conn)
wg.Wait()
conn.Close()
return nil
}

func wsCopy(wg *sync.WaitGroup, src, dst *websocket.Conn) {
defer wg.Done()
for {
msgType, r, err := src.NextReader()
if err != nil {
return
}
w, err := dst.NextWriter(msgType)
if err != nil {
return
}
if _, err = io.Copy(w, r); err != nil {
return
}
}
}

// Snapshots creates snapshots of the services by calling the
// simulation_snapshot RPC method
func (n *ExecNode) Snapshots() (map[string][]byte, error) {
Expand Down
8 changes: 5 additions & 3 deletions p2p/simulations/adapters/inproc.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (
"github.com/ethereum/go-ethereum/p2p/enode"
"github.com/ethereum/go-ethereum/p2p/simulations/pipes"
"github.com/ethereum/go-ethereum/rpc"
"github.com/gorilla/websocket"
)

// SimAdapter is a NodeAdapter which creates in-memory simulation nodes and
Expand Down Expand Up @@ -210,13 +211,14 @@ func (sn *SimNode) Client() (*rpc.Client, error) {
}

// ServeRPC serves RPC requests over the given connection by creating an
// in-memory client to the node's RPC server
func (sn *SimNode) ServeRPC(conn net.Conn) error {
// in-memory client to the node's RPC server.
func (sn *SimNode) ServeRPC(conn *websocket.Conn) error {
handler, err := sn.node.RPCHandler()
if err != nil {
return err
}
handler.ServeCodec(rpc.NewJSONCodec(conn), rpc.OptionMethodInvocation|rpc.OptionSubscriptions)
codec := rpc.NewFuncCodec(conn, conn.WriteJSON, conn.ReadJSON)
handler.ServeCodec(codec, 0)
return nil
}

Expand Down
3 changes: 2 additions & 1 deletion p2p/simulations/adapters/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ import (
"github.com/ethereum/go-ethereum/p2p/enode"
"github.com/ethereum/go-ethereum/p2p/enr"
"github.com/ethereum/go-ethereum/rpc"
"github.com/gorilla/websocket"
)

// Node represents a node in a simulation network which is created by a
Expand All @@ -51,7 +52,7 @@ type Node interface {
Client() (*rpc.Client, error)

// ServeRPC serves RPC requests over the given connection
ServeRPC(net.Conn) error
ServeRPC(*websocket.Conn) error

// Start starts the node with the given snapshots
Start(snapshots map[string][]byte) error
Expand Down
18 changes: 11 additions & 7 deletions p2p/simulations/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ import (
"github.com/ethereum/go-ethereum/p2p/enode"
"github.com/ethereum/go-ethereum/p2p/simulations/adapters"
"github.com/ethereum/go-ethereum/rpc"
"github.com/gorilla/websocket"
"github.com/julienschmidt/httprouter"
"golang.org/x/net/websocket"
)

// DefaultClient is the default simulation API client which expects the API
Expand Down Expand Up @@ -654,16 +654,20 @@ func (s *Server) Options(w http.ResponseWriter, req *http.Request) {
w.WriteHeader(http.StatusOK)
}

var wsUpgrade = websocket.Upgrader{
CheckOrigin: func(*http.Request) bool { return true },
}

// NodeRPC forwards RPC requests to a node in the network via a WebSocket
// connection
func (s *Server) NodeRPC(w http.ResponseWriter, req *http.Request) {
node := req.Context().Value("node").(*Node)

handler := func(conn *websocket.Conn) {
node.ServeRPC(conn)
conn, err := wsUpgrade.Upgrade(w, req, nil)
if err != nil {
return
}

websocket.Server{Handler: handler}.ServeHTTP(w, req)
defer conn.Close()
node := req.Context().Value("node").(*Node)
node.ServeRPC(conn)
}

// ServeHTTP implements the http.Handler interface by delegating to the
Expand Down
12 changes: 6 additions & 6 deletions rpc/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ func (c *Client) newClientConn(conn ServerCodec) *clientConn {

func (cc *clientConn) close(err error, inflightReq *requestOp) {
cc.handler.close(err, inflightReq)
cc.codec.Close()
cc.codec.close()
}

type readOp struct {
Expand Down Expand Up @@ -484,7 +484,7 @@ func (c *Client) write(ctx context.Context, msg interface{}) error {
return err
}
}
err := c.writeConn.Write(ctx, msg)
err := c.writeConn.writeJSON(ctx, msg)
if err != nil {
c.writeConn = nil
}
Expand All @@ -511,7 +511,7 @@ func (c *Client) reconnect(ctx context.Context) error {
c.writeConn = newconn
return nil
case <-c.didClose:
newconn.Close()
newconn.close()
return ErrClientQuit
}
}
Expand Down Expand Up @@ -558,7 +558,7 @@ func (c *Client) dispatch(codec ServerCodec) {

// Reconnect:
case newcodec := <-c.reconnected:
log.Debug("RPC client reconnected", "reading", reading, "conn", newcodec.RemoteAddr())
log.Debug("RPC client reconnected", "reading", reading, "conn", newcodec.remoteAddr())
if reading {
// Wait for the previous read loop to exit. This is a rare case which
// happens if this loop isn't notified in time after the connection breaks.
Expand Down Expand Up @@ -612,9 +612,9 @@ func (c *Client) drainRead() {
// read decodes RPC messages from a codec, feeding them into dispatch.
func (c *Client) read(codec ServerCodec) {
for {
msgs, batch, err := codec.Read()
msgs, batch, err := codec.readBatch()
if _, ok := err.(*json.SyntaxError); ok {
codec.Write(context.Background(), errorMessage(&parseError{err.Error()}))
codec.writeJSON(context.Background(), errorMessage(&parseError{err.Error()}))
}
if err != nil {
c.readErr <- err
Expand Down
10 changes: 5 additions & 5 deletions rpc/handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,8 +85,8 @@ func newHandler(connCtx context.Context, conn jsonWriter, idgen func() ID, reg *
serverSubs: make(map[ID]*Subscription),
log: log.Root(),
}
if conn.RemoteAddr() != "" {
h.log = h.log.New("conn", conn.RemoteAddr())
if conn.remoteAddr() != "" {
h.log = h.log.New("conn", conn.remoteAddr())
}
h.unsubscribeCb = newCallback(reflect.Value{}, reflect.ValueOf(h.unsubscribe))
return h
Expand All @@ -97,7 +97,7 @@ func (h *handler) handleBatch(msgs []*jsonrpcMessage) {
// Emit error response for empty batches:
if len(msgs) == 0 {
h.startCallProc(func(cp *callProc) {
h.conn.Write(cp.ctx, errorMessage(&invalidRequestError{"empty batch"}))
h.conn.writeJSON(cp.ctx, errorMessage(&invalidRequestError{"empty batch"}))
})
return
}
Expand All @@ -122,7 +122,7 @@ func (h *handler) handleBatch(msgs []*jsonrpcMessage) {
}
h.addSubscriptions(cp.notifiers)
if len(answers) > 0 {
h.conn.Write(cp.ctx, answers)
h.conn.writeJSON(cp.ctx, answers)
}
for _, n := range cp.notifiers {
n.activate()
Expand All @@ -139,7 +139,7 @@ func (h *handler) handleMsg(msg *jsonrpcMessage) {
answer := h.handleCallMsg(cp, msg)
h.addSubscriptions(cp.notifiers)
if answer != nil {
h.conn.Write(cp.ctx, answer)
h.conn.writeJSON(cp.ctx, answer)
}
for _, n := range cp.notifiers {
n.activate()
Expand Down
26 changes: 13 additions & 13 deletions rpc/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,29 +47,29 @@ type httpConn struct {
client *http.Client
req *http.Request
closeOnce sync.Once
closed chan interface{}
closeCh chan interface{}
}

// httpConn is treated specially by Client.
func (hc *httpConn) Write(context.Context, interface{}) error {
panic("Write called on httpConn")
func (hc *httpConn) writeJSON(context.Context, interface{}) error {
panic("writeJSON called on httpConn")
}

func (hc *httpConn) RemoteAddr() string {
func (hc *httpConn) remoteAddr() string {
return hc.req.URL.String()
}

func (hc *httpConn) Read() ([]*jsonrpcMessage, bool, error) {
<-hc.closed
func (hc *httpConn) readBatch() ([]*jsonrpcMessage, bool, error) {
<-hc.closeCh
return nil, false, io.EOF
}

func (hc *httpConn) Close() {
hc.closeOnce.Do(func() { close(hc.closed) })
func (hc *httpConn) close() {
hc.closeOnce.Do(func() { close(hc.closeCh) })
}

func (hc *httpConn) Closed() <-chan interface{} {
return hc.closed
func (hc *httpConn) closed() <-chan interface{} {
return hc.closeCh
}

// HTTPTimeouts represents the configuration params for the HTTP RPC server.
Expand Down Expand Up @@ -116,7 +116,7 @@ func DialHTTPWithClient(endpoint string, client *http.Client) (*Client, error) {

initctx := context.Background()
return newClient(initctx, func(context.Context) (ServerCodec, error) {
return &httpConn{client: client, req: req, closed: make(chan interface{})}, nil
return &httpConn{client: client, req: req, closeCh: make(chan interface{})}, nil
})
}

Expand Down Expand Up @@ -195,7 +195,7 @@ type httpServerConn struct {
func newHTTPServerConn(r *http.Request, w http.ResponseWriter) ServerCodec {
body := io.LimitReader(r.Body, maxRequestContentLength)
conn := &httpServerConn{Reader: body, Writer: w, r: r}
return NewJSONCodec(conn)
return NewCodec(conn)
}

// Close does nothing and always returns nil.
Expand Down Expand Up @@ -266,7 +266,7 @@ func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {

w.Header().Set("content-type", contentType)
codec := newHTTPServerConn(r, w)
defer codec.Close()
defer codec.close()
s.serveSingleRequest(ctx, codec)
}

Expand Down
4 changes: 2 additions & 2 deletions rpc/inproc.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ func DialInProc(handler *Server) *Client {
initctx := context.Background()
c, _ := newClient(initctx, func(context.Context) (ServerCodec, error) {
p1, p2 := net.Pipe()
go handler.ServeCodec(NewJSONCodec(p1), OptionMethodInvocation|OptionSubscriptions)
return NewJSONCodec(p2), nil
go handler.ServeCodec(NewCodec(p1), 0)
return NewCodec(p2), nil
})
return c
}
4 changes: 2 additions & 2 deletions rpc/ipc.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ func (s *Server) ServeListener(l net.Listener) error {
return err
}
log.Trace("Accepted RPC connection", "conn", conn.RemoteAddr())
go s.ServeCodec(NewJSONCodec(conn), OptionMethodInvocation|OptionSubscriptions)
go s.ServeCodec(NewCodec(conn), 0)
}
}

Expand All @@ -51,6 +51,6 @@ func DialIPC(ctx context.Context, endpoint string) (*Client, error) {
if err != nil {
return nil, err
}
return NewJSONCodec(conn), err
return NewCodec(conn), err
})
}
Loading