mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-11 05:20:05 +00:00
fe1bb62bad
This PR significantly changes the APIs for instantiating Ethereum nodes in a Go program. The new APIs are not backwards-compatible, but we feel that this is made up for by the much simpler way of registering services on node.Node. You can find more information and rationale in the design document: https://gist.github.com/renaynay/5bec2de19fde66f4d04c535fd24f0775. There is also a new feature in Node's Go API: it is now possible to register arbitrary handlers on the user-facing HTTP server. In geth, this facility is used to enable GraphQL. There is a single minor change relevant for geth users in this PR: The GraphQL API is no longer available separately from the JSON-RPC HTTP server. If you want GraphQL, you need to enable it using the ./geth --http --graphql flag combination. The --graphql.port and --graphql.addr flags are no longer available. # Conflicts: # cmd/faucet/faucet.go # cmd/geth/chaincmd.go # cmd/geth/config.go # cmd/geth/consolecmd.go # cmd/geth/main.go # cmd/utils/flags.go # cmd/wnode/main.go # core/rawdb/freezer.go # eth/api_backend.go # eth/backend.go # ethclient/ethclient_test.go # ethstats/ethstats.go # graphql/service.go # internal/ethapi/backend.go # les/api_backend.go # les/api_test.go # les/checkpointoracle/oracle.go # les/client.go # les/commons.go # les/server.go # miner/stresstest/stress_clique.go # miner/stresstest/stress_ethash.go # mobile/geth.go # node/api.go # node/node.go # node/node_example_test.go # node/node_test.go # node/rpcstack.go # node/rpcstack_test.go # node/service.go # node/service_test.go # node/utils_test.go # p2p/simulations/examples/ping-pong.go # p2p/testing/peerpool.go # p2p/testing/protocolsession.go # p2p/testing/protocoltester.go # whisper/mailserver/server_test.go # whisper/whisperv6/api_test.go # whisper/whisperv6/filter_test.go # whisper/whisperv6/whisper.go # whisper/whisperv6/whisper_test.go
119 lines
3.7 KiB
Go
119 lines
3.7 KiB
Go
// Copyright 2016 The go-ethereum Authors
|
|
// This file is part of the go-ethereum library.
|
|
//
|
|
// The go-ethereum library is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// The go-ethereum library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
package node
|
|
|
|
import (
|
|
"os"
|
|
"os/user"
|
|
"path/filepath"
|
|
"runtime"
|
|
"strings"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/p2p"
|
|
"github.com/ledgerwatch/turbo-geth/p2p/nat"
|
|
"github.com/ledgerwatch/turbo-geth/rpc"
|
|
)
|
|
|
|
const (
|
|
DefaultHTTPHost = "localhost" // Default host interface for the HTTP RPC server
|
|
DefaultHTTPPort = 8545 // Default TCP port for the HTTP RPC server
|
|
DefaultWSHost = "localhost" // Default host interface for the websocket RPC server
|
|
DefaultWSPort = 8546 // Default TCP port for the websocket RPC server
|
|
DefaultGraphQLHost = "localhost" // Default host interface for the GraphQL server
|
|
DefaultGraphQLPort = 8547 // Default TCP port for the GraphQL server
|
|
)
|
|
|
|
// DefaultConfig contains reasonable default settings.
|
|
var DefaultConfig = Config{
|
|
DataDir: DefaultDataDir(),
|
|
HTTPPort: DefaultHTTPPort,
|
|
HTTPModules: []string{"net", "web3"},
|
|
HTTPVirtualHosts: []string{"localhost"},
|
|
HTTPTimeouts: rpc.DefaultHTTPTimeouts,
|
|
WSPort: DefaultWSPort,
|
|
WSModules: []string{"net", "web3"},
|
|
GraphQLVirtualHosts: []string{"localhost"},
|
|
P2P: p2p.Config{
|
|
ListenAddr: ":30303",
|
|
MaxPeers: 50,
|
|
NAT: nat.Any(),
|
|
},
|
|
}
|
|
|
|
const dirname = "TurboGeth"
|
|
|
|
// DefaultDataDir is the default data directory to use for the databases and other
|
|
// persistence requirements.
|
|
func DefaultDataDir() string {
|
|
// Try to place the data folder in the user's home dir
|
|
home := homeDir()
|
|
if home != "" {
|
|
switch runtime.GOOS {
|
|
case "darwin":
|
|
return filepath.Join(home, "Library", dirname)
|
|
case "windows":
|
|
// We used to put everything in %HOME%\AppData\Roaming, but this caused
|
|
// problems with non-typical setups. If this fallback location exists and
|
|
// is non-empty, use it, otherwise DTRT and check %LOCALAPPDATA%.
|
|
fallback := filepath.Join(home, "AppData", "Roaming", dirname)
|
|
appdata := windowsAppData()
|
|
if appdata == "" || isNonEmptyDir(fallback) {
|
|
return fallback
|
|
}
|
|
return filepath.Join(appdata, dirname)
|
|
default:
|
|
if xdgDataDir := os.Getenv("XDG_DATA_HOME"); xdgDataDir != "" {
|
|
return filepath.Join(xdgDataDir, strings.ToLower(dirname))
|
|
}
|
|
return filepath.Join(home, ".local/share", strings.ToLower(dirname))
|
|
}
|
|
}
|
|
// As we cannot guess a stable location, return empty and handle later
|
|
return ""
|
|
}
|
|
|
|
func windowsAppData() string {
|
|
v := os.Getenv("LOCALAPPDATA")
|
|
if v == "" {
|
|
// Windows XP and below don't have LocalAppData. Crash here because
|
|
// we don't support Windows XP and undefining the variable will cause
|
|
// other issues.
|
|
panic("environment variable LocalAppData is undefined")
|
|
}
|
|
return v
|
|
}
|
|
|
|
func isNonEmptyDir(dir string) bool {
|
|
f, err := os.Open(dir)
|
|
if err != nil {
|
|
return false
|
|
}
|
|
names, _ := f.Readdir(1)
|
|
f.Close()
|
|
return len(names) > 0
|
|
}
|
|
|
|
func homeDir() string {
|
|
if home := os.Getenv("HOME"); home != "" {
|
|
return home
|
|
}
|
|
if usr, err := user.Current(); err == nil {
|
|
return usr.HomeDir
|
|
}
|
|
return ""
|
|
}
|