diff --git a/cmd/utils/cmd.go b/cmd/utils/cmd.go index 6642a3242a..5e828c63f0 100644 --- a/cmd/utils/cmd.go +++ b/cmd/utils/cmd.go @@ -5,13 +5,12 @@ import ( "github.com/dominant-strategies/go-quai/common" "github.com/dominant-strategies/go-quai/core/vm" - "github.com/dominant-strategies/go-quai/eth" - quai "github.com/dominant-strategies/go-quai/eth" - "github.com/dominant-strategies/go-quai/eth/ethconfig" "github.com/dominant-strategies/go-quai/internal/quaiapi" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/node" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai" + "github.com/dominant-strategies/go-quai/quai/quaiconfig" "github.com/dominant-strategies/go-quai/quaistats" "github.com/spf13/viper" "io" @@ -52,7 +51,7 @@ func StartQuaiBackend() (*quai.QuaiBackend, error) { stackZone.Wait() }() - return ð.QuaiBackend{}, nil + return &quai.QuaiBackend{}, nil } func StartNode(stack *node.Node) { @@ -63,10 +62,10 @@ func StartNode(stack *node.Node) { } // makeConfigNode loads quai configuration and creates a blank node instance. -func makeConfigNode(nodeLocation common.Location) (*node.Node, ethconfig.QuaiConfig) { +func makeConfigNode(nodeLocation common.Location) (*node.Node, quaiconfig.QuaiConfig) { // Load defaults. - cfg := ethconfig.QuaiConfig{ - Quai: ethconfig.Defaults, + cfg := quaiconfig.QuaiConfig{ + Quai: quaiconfig.Defaults, Node: defaultNodeConfig(), } @@ -84,7 +83,7 @@ func makeConfigNode(nodeLocation common.Location) (*node.Node, ethconfig.QuaiCon // TODO: Apply stats if viper.IsSet(QuaiStatsURLFlag.Name) { - cfg.Ethstats.URL = viper.GetString(QuaiStatsURLFlag.Name) + cfg.Quaistats.URL = viper.GetString(QuaiStatsURLFlag.Name) } nodeCtx := nodeLocation.Context() @@ -110,8 +109,8 @@ func makeFullNode(nodeLocation common.Location) *node.Node { backend, _ := RegisterQuaiService(stack, cfg.Quai, cfg.Node.NodeLocation.Context()) sendfullstats := viper.GetBool(SendFullStatsFlag.Name) // Add the Quai Stats daemon if requested. - if cfg.Ethstats.URL != "" { - RegisterQuaiStatsService(stack, backend, cfg.Ethstats.URL, sendfullstats) + if cfg.Quaistats.URL != "" { + RegisterQuaiStatsService(stack, backend, cfg.Quaistats.URL, sendfullstats) } return stack } @@ -119,8 +118,8 @@ func makeFullNode(nodeLocation common.Location) *node.Node { // RegisterQuaiService adds a Quai client to the stack. // The second return value is the full node instance, which may be nil if the // node is running as a light client. -func RegisterQuaiService(stack *node.Node, cfg ethconfig.Config, nodeCtx int) (quaiapi.Backend, error) { - backend, err := eth.New(stack, &cfg, nodeCtx) +func RegisterQuaiService(stack *node.Node, cfg quaiconfig.Config, nodeCtx int) (quaiapi.Backend, error) { + backend, err := quai.New(stack, &cfg, nodeCtx) if err != nil { Fatalf("Failed to register the Quai service: %v", err) } diff --git a/cmd/utils/flags.go b/cmd/utils/flags.go index d91426c1b9..a2a4797e2b 100644 --- a/cmd/utils/flags.go +++ b/cmd/utils/flags.go @@ -19,12 +19,12 @@ import ( "github.com/dominant-strategies/go-quai/common/fdlimit" "github.com/dominant-strategies/go-quai/core" "github.com/dominant-strategies/go-quai/core/rawdb" - "github.com/dominant-strategies/go-quai/eth/ethconfig" - "github.com/dominant-strategies/go-quai/eth/gasprice" "github.com/dominant-strategies/go-quai/ethdb" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/node" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai/gasprice" + "github.com/dominant-strategies/go-quai/quai/quaiconfig" "github.com/pelletier/go-toml/v2" gopsutil "github.com/shirou/gopsutil/mem" "github.com/spf13/cobra" @@ -324,7 +324,7 @@ var ( TxLookupLimitFlag = Flag{ Name: "txlookuplimit", - Value: ethconfig.Defaults.TxLookupLimit, + Value: quaiconfig.Defaults.TxLookupLimit, Usage: "Number of recent blocks to maintain transactions index for (default = about one year, 0 = entire chain)" + generateEnvDoc("txlookuplimit"), } @@ -362,37 +362,37 @@ var ( } TxPoolPriceLimitFlag = Flag{ Name: "txpool.pricelimit", - Value: ethconfig.Defaults.TxPool.PriceLimit, + Value: quaiconfig.Defaults.TxPool.PriceLimit, Usage: "Minimum gas price limit to enforce for acceptance into the pool" + generateEnvDoc("txpool.pricelimit"), } TxPoolPriceBumpFlag = Flag{ Name: "txpool.pricebump", - Value: ethconfig.Defaults.TxPool.PriceBump, + Value: quaiconfig.Defaults.TxPool.PriceBump, Usage: "Price bump percentage to replace an already existing transaction" + generateEnvDoc("txpool.pricebump"), } TxPoolAccountSlotsFlag = Flag{ Name: "txpool.accountslots", - Value: ethconfig.Defaults.TxPool.AccountSlots, + Value: quaiconfig.Defaults.TxPool.AccountSlots, Usage: "Minimum number of executable transaction slots guaranteed per account" + generateEnvDoc("txpool.accountslots"), } TxPoolGlobalSlotsFlag = Flag{ Name: "txpool.globalslots", - Value: ethconfig.Defaults.TxPool.GlobalSlots, + Value: quaiconfig.Defaults.TxPool.GlobalSlots, Usage: "Maximum number of executable transaction slots for all accounts" + generateEnvDoc("txpool.globalslots"), } TxPoolAccountQueueFlag = Flag{ Name: "txpool.accountqueue", - Value: ethconfig.Defaults.TxPool.AccountQueue, + Value: quaiconfig.Defaults.TxPool.AccountQueue, Usage: "Maximum number of non-executable transaction slots permitted per account" + generateEnvDoc("txpool.accountqueue"), } TxPoolGlobalQueueFlag = Flag{ Name: "txpool.globalqueue", - Value: ethconfig.Defaults.TxPool.GlobalQueue, + Value: quaiconfig.Defaults.TxPool.GlobalQueue, Usage: "Maximum number of non-executable transaction slots for all accounts" + generateEnvDoc("txpool.globalqueue"), } TxPoolLifetimeFlag = Flag{ Name: "txpool.lifetime", - Value: ethconfig.Defaults.TxPool.Lifetime, + Value: quaiconfig.Defaults.TxPool.Lifetime, Usage: "Maximum amount of time non-executable transaction are queued" + generateEnvDoc("txpool.lifetime"), } CacheFlag = Flag{ @@ -412,12 +412,12 @@ var ( } CacheTrieJournalFlag = Flag{ Name: "cache.trie.journal", - Value: ethconfig.Defaults.TrieCleanCacheJournal, + Value: quaiconfig.Defaults.TrieCleanCacheJournal, Usage: "Disk journal directory for trie cache to survive node restarts" + generateEnvDoc("cache.trie.journal"), } CacheTrieRejournalFlag = Flag{ Name: "cache.trie.rejournal", - Value: ethconfig.Defaults.TrieCleanCacheRejournal, + Value: quaiconfig.Defaults.TrieCleanCacheRejournal, Usage: "Time interval to regenerate the trie cache journal" + generateEnvDoc("cache.trie.rejournal"), } CacheGCFlag = Flag{ @@ -449,7 +449,7 @@ var ( // Miner settings MinerGasPriceFlag = Flag{ Name: "miner.gasprice", - Value: newBigIntValue(ethconfig.Defaults.Miner.GasPrice), + Value: newBigIntValue(quaiconfig.Defaults.Miner.GasPrice), Usage: "Minimum gas price for mining a transaction" + generateEnvDoc("miner.gasprice"), } // Account settings @@ -492,7 +492,7 @@ var ( } RPCGlobalGasCapFlag = Flag{ Name: "rpc.gascap", - Value: ethconfig.Defaults.RPCGasCap, + Value: quaiconfig.Defaults.RPCGasCap, Usage: "Sets a cap on gas that can be used in eth_call/estimateGas (0=infinite)" + generateEnvDoc("vmdebug"), } QuaiStatsURLFlag = Flag{ @@ -570,33 +570,33 @@ var ( // Gas price oracle settings GpoBlocksFlag = Flag{ Name: "gpo.blocks", - Value: ethconfig.Defaults.GPO.Blocks, + Value: quaiconfig.Defaults.GPO.Blocks, Usage: "Number of recent blocks to check for gas prices" + generateEnvDoc("gpo.blocks"), } GpoPercentileFlag = Flag{ Name: "gpo.percentile", - Value: ethconfig.Defaults.GPO.Percentile, + Value: quaiconfig.Defaults.GPO.Percentile, Usage: "Suggested gas price is the given percentile of a set of recent transaction gas prices" + generateEnvDoc("gpo.percentile"), } GpoMaxGasPriceFlag = Flag{ Name: "gpo.maxprice", - Value: ethconfig.Defaults.GPO.MaxPrice.Int64(), + Value: quaiconfig.Defaults.GPO.MaxPrice.Int64(), Usage: "Maximum gas price will be recommended by gpo" + generateEnvDoc("gpo.maxprice"), } GpoIgnoreGasPriceFlag = Flag{ Name: "gpo.ignoreprice", - Value: ethconfig.Defaults.GPO.IgnorePrice.Int64(), + Value: quaiconfig.Defaults.GPO.IgnorePrice.Int64(), Usage: "Gas price below which gpo will ignore transactions" + generateEnvDoc("gpo.ignoreprice"), } DomUrl = Flag{ Name: "dom.url", - Value: ethconfig.Defaults.DomUrl, + Value: quaiconfig.Defaults.DomUrl, Usage: "Dominant chain websocket url" + generateEnvDoc("dom.url"), } SubUrls = Flag{ Name: "sub.urls", - Value: ethconfig.Defaults.DomUrl, + Value: quaiconfig.Defaults.DomUrl, Usage: "Subordinate chain websocket urls" + generateEnvDoc("sub.urls"), } CoinbaseAddressFlag = Flag{ @@ -830,7 +830,7 @@ func setWS(cfg *node.Config, nodeLocation common.Location) { } // setDomUrl sets the dominant chain websocket url. -func setDomUrl(cfg *ethconfig.Config, nodeLocation common.Location) { +func setDomUrl(cfg *quaiconfig.Config, nodeLocation common.Location) { // only set the dom url if the node is not prime if nodeLocation != nil { if len(nodeLocation) == 1 { @@ -843,7 +843,7 @@ func setDomUrl(cfg *ethconfig.Config, nodeLocation common.Location) { } // setSubUrls sets the subordinate chain urls -func setSubUrls(cfg *ethconfig.Config, nodeLocation common.Location) { +func setSubUrls(cfg *quaiconfig.Config, nodeLocation common.Location) { // only set the sub urls if its not the zone if len(nodeLocation) != 2 { if nodeLocation == nil { @@ -856,7 +856,7 @@ func setSubUrls(cfg *ethconfig.Config, nodeLocation common.Location) { // setGasLimitCeil sets the gas limit ceils based on the network that is // running -func setGasLimitCeil(cfg *ethconfig.Config) { +func setGasLimitCeil(cfg *quaiconfig.Config) { switch { case viper.GetBool(ColosseumFlag.Name): cfg.Miner.GasCeil = params.ColosseumGasCeil @@ -881,7 +881,7 @@ func makeSubUrls() []string { } // setSlicesRunning sets the slices running flag -func setSlicesRunning(cfg *ethconfig.Config) { +func setSlicesRunning(cfg *quaiconfig.Config) { slices := strings.Split(viper.GetString(SlicesRunningFlag.Name), ",") // Sanity checks @@ -924,7 +924,7 @@ func HexAddress(account string, nodeLocation common.Location) (common.Address, e // setEtherbase retrieves the etherbase either from the directly specified // command line flags or from the keystore if CLI indexed. -func setEtherbase(cfg *ethconfig.Config) { +func setEtherbase(cfg *quaiconfig.Config) { coinbaseMap, err := ParseCoinbaseAddresses() if err != nil { log.Fatalf("error parsing coinbase addresses: %s", err) @@ -1080,7 +1080,7 @@ func setTxPool(cfg *core.TxPoolConfig, nodeLocation common.Location) { } } -func setConsensusEngineConfig(cfg *ethconfig.Config) { +func setConsensusEngineConfig(cfg *quaiconfig.Config) { if cfg.ConsensusEngine == "blake3" { // Override any default configs for hard coded networks. switch { @@ -1151,7 +1151,7 @@ func setConsensusEngineConfig(cfg *ethconfig.Config) { } } -func setWhitelist(cfg *ethconfig.Config) { +func setWhitelist(cfg *quaiconfig.Config) { whitelist := viper.GetString(WhitelistFlag.Name) if whitelist == "" { return @@ -1213,8 +1213,8 @@ func CheckExclusive(args ...interface{}) { } } -// SetQuaiConfig applies eth-related command line flags to the config. -func SetQuaiConfig(stack *node.Node, cfg *ethconfig.Config, nodeLocation common.Location) { +// SetQuaiConfig applies quai-related command line flags to the config. +func SetQuaiConfig(stack *node.Node, cfg *quaiconfig.Config, nodeLocation common.Location) { // Avoid conflicting network flags CheckExclusive(ColosseumFlag, DeveloperFlag, GardenFlag, OrchardFlag, LocalFlag, LighthouseFlag) CheckExclusive(DeveloperFlag, ExternalSignerFlag) // Can't use both ephemeral unlocked and external signer diff --git a/internal/quaiapi/api.go b/internal/quaiapi/api.go index c3a99e1300..23ed6bceb0 100644 --- a/internal/quaiapi/api.go +++ b/internal/quaiapi/api.go @@ -35,9 +35,9 @@ import ( "github.com/dominant-strategies/go-quai/core/types" "github.com/dominant-strategies/go-quai/core/vm" "github.com/dominant-strategies/go-quai/crypto" - "github.com/dominant-strategies/go-quai/eth/abi" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai/abi" "github.com/dominant-strategies/go-quai/rlp" "github.com/dominant-strategies/go-quai/rpc" ) diff --git a/p2p/node/api.go b/p2p/node/api.go index 3dd5157afe..48fb5fcba4 100644 --- a/p2p/node/api.go +++ b/p2p/node/api.go @@ -9,10 +9,10 @@ import ( "github.com/dominant-strategies/go-quai/cmd/utils" "github.com/dominant-strategies/go-quai/core/types" - "github.com/dominant-strategies/go-quai/eth" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/p2p" quaiprotocol "github.com/dominant-strategies/go-quai/p2p/protocol" + "github.com/dominant-strategies/go-quai/quai" "github.com/dominant-strategies/go-quai/common" pubsub "github.com/libp2p/go-libp2p-pubsub" @@ -94,7 +94,7 @@ func (p *P2PNode) Stop() error { } } -func (p *P2PNode) SetConsensusBackend(be eth.ConsensusAPI) { +func (p *P2PNode) SetConsensusBackend(be quai.ConsensusAPI) { p.consensus = be } diff --git a/p2p/node/node.go b/p2p/node/node.go index e7aaac2338..c5437ac967 100644 --- a/p2p/node/node.go +++ b/p2p/node/node.go @@ -22,10 +22,10 @@ import ( "github.com/dominant-strategies/go-quai/cmd/utils" "github.com/dominant-strategies/go-quai/common" "github.com/dominant-strategies/go-quai/core/types" - "github.com/dominant-strategies/go-quai/eth" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/p2p/protocol" "github.com/dominant-strategies/go-quai/p2p/pubsubManager" + "github.com/dominant-strategies/go-quai/quai" lru "github.com/hashicorp/golang-lru/v2" ) @@ -35,7 +35,7 @@ type P2PNode struct { host.Host // Backend for handling consensus data - consensus eth.ConsensusAPI + consensus quai.ConsensusAPI // List of peers to introduce us to the network bootpeers []peer.AddrInfo diff --git a/eth/abi/abi.go b/quai/abi/abi.go similarity index 100% rename from eth/abi/abi.go rename to quai/abi/abi.go diff --git a/eth/abi/abi_test.go b/quai/abi/abi_test.go similarity index 100% rename from eth/abi/abi_test.go rename to quai/abi/abi_test.go diff --git a/eth/abi/argument.go b/quai/abi/argument.go similarity index 100% rename from eth/abi/argument.go rename to quai/abi/argument.go diff --git a/eth/abi/doc.go b/quai/abi/doc.go similarity index 100% rename from eth/abi/doc.go rename to quai/abi/doc.go diff --git a/eth/abi/error.go b/quai/abi/error.go similarity index 100% rename from eth/abi/error.go rename to quai/abi/error.go diff --git a/eth/abi/event.go b/quai/abi/event.go similarity index 100% rename from eth/abi/event.go rename to quai/abi/event.go diff --git a/eth/abi/event_test.go b/quai/abi/event_test.go similarity index 100% rename from eth/abi/event_test.go rename to quai/abi/event_test.go diff --git a/eth/abi/method.go b/quai/abi/method.go similarity index 100% rename from eth/abi/method.go rename to quai/abi/method.go diff --git a/eth/abi/method_test.go b/quai/abi/method_test.go similarity index 100% rename from eth/abi/method_test.go rename to quai/abi/method_test.go diff --git a/eth/abi/pack.go b/quai/abi/pack.go similarity index 100% rename from eth/abi/pack.go rename to quai/abi/pack.go diff --git a/eth/abi/pack_test.go b/quai/abi/pack_test.go similarity index 100% rename from eth/abi/pack_test.go rename to quai/abi/pack_test.go diff --git a/eth/abi/packing_test.go b/quai/abi/packing_test.go similarity index 100% rename from eth/abi/packing_test.go rename to quai/abi/packing_test.go diff --git a/eth/abi/reflect.go b/quai/abi/reflect.go similarity index 100% rename from eth/abi/reflect.go rename to quai/abi/reflect.go diff --git a/eth/abi/reflect_test.go b/quai/abi/reflect_test.go similarity index 100% rename from eth/abi/reflect_test.go rename to quai/abi/reflect_test.go diff --git a/eth/abi/topics.go b/quai/abi/topics.go similarity index 100% rename from eth/abi/topics.go rename to quai/abi/topics.go diff --git a/eth/abi/topics_test.go b/quai/abi/topics_test.go similarity index 100% rename from eth/abi/topics_test.go rename to quai/abi/topics_test.go diff --git a/eth/abi/type.go b/quai/abi/type.go similarity index 100% rename from eth/abi/type.go rename to quai/abi/type.go diff --git a/eth/abi/type_test.go b/quai/abi/type_test.go similarity index 100% rename from eth/abi/type_test.go rename to quai/abi/type_test.go diff --git a/eth/abi/unpack.go b/quai/abi/unpack.go similarity index 100% rename from eth/abi/unpack.go rename to quai/abi/unpack.go diff --git a/eth/abi/unpack_test.go b/quai/abi/unpack_test.go similarity index 100% rename from eth/abi/unpack_test.go rename to quai/abi/unpack_test.go diff --git a/eth/api.go b/quai/api.go similarity index 88% rename from eth/api.go rename to quai/api.go index 90b5242bc8..90aeb3e293 100644 --- a/eth/api.go +++ b/quai/api.go @@ -14,7 +14,7 @@ // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . -package eth +package quai import ( "compress/gzip" @@ -125,13 +125,13 @@ func (api *PrivateMinerAPI) SetRecommitInterval(interval int) { // PrivateAdminAPI is the collection of Quai full node-related APIs // exposed over the private admin endpoint. type PrivateAdminAPI struct { - eth *Quai + quai *Quai } // NewPrivateAdminAPI creates a new API definition for the full node private // admin methods of the Quai service. -func NewPrivateAdminAPI(eth *Quai) *PrivateAdminAPI { - return &PrivateAdminAPI{eth: eth} +func NewPrivateAdminAPI(quai *Quai) *PrivateAdminAPI { + return &PrivateAdminAPI{quai: quai} } // ExportChain exports the current blockchain into a local file, @@ -141,7 +141,7 @@ func (api *PrivateAdminAPI) ExportChain(file string, first *uint64, last *uint64 return false, errors.New("last cannot be specified without first") } if first != nil && last == nil { - head := api.eth.Core().CurrentHeader().NumberU64(api.eth.core.NodeCtx()) + head := api.quai.Core().CurrentHeader().NumberU64(api.quai.core.NodeCtx()) last = &head } if _, err := os.Stat(file); err == nil { @@ -164,10 +164,10 @@ func (api *PrivateAdminAPI) ExportChain(file string, first *uint64, last *uint64 // Export the blockchain if first != nil { - if err := api.eth.Core().ExportN(writer, *first, *last); err != nil { + if err := api.quai.Core().ExportN(writer, *first, *last); err != nil { return false, err } - } else if err := api.eth.Core().Export(writer); err != nil { + } else if err := api.quai.Core().Export(writer); err != nil { return false, err } return true, nil @@ -218,12 +218,12 @@ func (api *PrivateAdminAPI) ImportChain(file string) (bool, error) { break } - if hasAllBlocks(api.eth.Core(), blocks) { + if hasAllBlocks(api.quai.Core(), blocks) { blocks = blocks[:0] continue } // Import the batch and reset the buffer - if _, err := api.eth.Core().InsertChain(blocks); err != nil { + if _, err := api.quai.Core().InsertChain(blocks); err != nil { return false, fmt.Errorf("batch %d: failed to insert: %v", batch, err) } blocks = blocks[:0] @@ -234,13 +234,13 @@ func (api *PrivateAdminAPI) ImportChain(file string) (bool, error) { // PublicDebugAPI is the collection of Quai full node APIs exposed // over the public debugging endpoint. type PublicDebugAPI struct { - eth *Quai + quai *Quai } // NewPublicDebugAPI creates a new API definition for the full node- // related public debug methods of the Quai service. -func NewPublicDebugAPI(eth *Quai) *PublicDebugAPI { - return &PublicDebugAPI{eth: eth} +func NewPublicDebugAPI(quai *Quai) *PublicDebugAPI { + return &PublicDebugAPI{quai: quai} } // DumpBlock retrieves the entire state of the database at a given block. @@ -254,14 +254,14 @@ func (api *PublicDebugAPI) DumpBlock(blockNr rpc.BlockNumber) (state.Dump, error } var block *types.Block if blockNr == rpc.LatestBlockNumber { - block = api.eth.core.CurrentBlock() + block = api.quai.core.CurrentBlock() } else { - block = api.eth.core.GetBlockByNumber(uint64(blockNr)) + block = api.quai.core.GetBlockByNumber(uint64(blockNr)) } if block == nil { return state.Dump{}, fmt.Errorf("block #%d not found", blockNr) } - stateDb, err := api.eth.core.StateAt(block.Root()) + stateDb, err := api.quai.core.StateAt(block.Root()) if err != nil { return state.Dump{}, err } @@ -271,18 +271,18 @@ func (api *PublicDebugAPI) DumpBlock(blockNr rpc.BlockNumber) (state.Dump, error // PrivateDebugAPI is the collection of Quai full node APIs exposed over // the private debugging endpoint. type PrivateDebugAPI struct { - eth *Quai + quai *Quai } // NewPrivateDebugAPI creates a new API definition for the full node-related // private debug methods of the Quai service. -func NewPrivateDebugAPI(eth *Quai) *PrivateDebugAPI { - return &PrivateDebugAPI{eth: eth} +func NewPrivateDebugAPI(quai *Quai) *PrivateDebugAPI { + return &PrivateDebugAPI{quai: quai} } // Preimage is a debug API function that returns the preimage for a sha3 hash, if known. func (api *PrivateDebugAPI) Preimage(ctx context.Context, hash common.Hash) (hexutil.Bytes, error) { - if preimage := rawdb.ReadPreimage(api.eth.ChainDb(), hash); preimage != nil { + if preimage := rawdb.ReadPreimage(api.quai.ChainDb(), hash); preimage != nil { return preimage, nil } return nil, errors.New("unknown preimage") @@ -300,7 +300,7 @@ type BadBlockArgs struct { func (api *PrivateDebugAPI) GetBadBlocks(ctx context.Context) ([]*BadBlockArgs, error) { var ( err error - blocks = rawdb.ReadAllBadBlocks(api.eth.chainDb) + blocks = rawdb.ReadAllBadBlocks(api.quai.chainDb) results = make([]*BadBlockArgs, 0, len(blocks)) ) for _, block := range blocks { @@ -313,7 +313,7 @@ func (api *PrivateDebugAPI) GetBadBlocks(ctx context.Context) ([]*BadBlockArgs, } else { blockRlp = fmt.Sprintf("0x%x", rlpBytes) } - if blockJSON, err = quaiapi.RPCMarshalBlock(block, true, true, api.eth.core.NodeLocation()); err != nil { + if blockJSON, err = quaiapi.RPCMarshalBlock(block, true, true, api.quai.core.NodeLocation()); err != nil { blockJSON = map[string]interface{}{"error": err.Error()} } results = append(results, &BadBlockArgs{ @@ -342,24 +342,24 @@ func (api *PublicDebugAPI) AccountRange(blockNrOrHash rpc.BlockNumberOrHash, sta } else { var block *types.Block if number == rpc.LatestBlockNumber { - block = api.eth.core.CurrentBlock() + block = api.quai.core.CurrentBlock() } else { - block = api.eth.core.GetBlockByNumber(uint64(number)) + block = api.quai.core.GetBlockByNumber(uint64(number)) } if block == nil { return state.IteratorDump{}, fmt.Errorf("block #%d not found", number) } - stateDb, err = api.eth.core.StateAt(block.Root()) + stateDb, err = api.quai.core.StateAt(block.Root()) if err != nil { return state.IteratorDump{}, err } } } else if hash, ok := blockNrOrHash.Hash(); ok { - block := api.eth.core.GetBlockByHash(hash) + block := api.quai.core.GetBlockByHash(hash) if block == nil { return state.IteratorDump{}, fmt.Errorf("block %s not found", hash.Hex()) } - stateDb, err = api.eth.core.StateAt(block.Root()) + stateDb, err = api.quai.core.StateAt(block.Root()) if err != nil { return state.IteratorDump{}, err } @@ -396,11 +396,11 @@ type storageEntry struct { // StorageRangeAt returns the storage at the given block height and transaction index. func (api *PrivateDebugAPI) StorageRangeAt(blockHash common.Hash, txIndex int, contractAddress common.Address, keyStart hexutil.Bytes, maxResult int) (StorageRangeResult, error) { // Retrieve the block - block := api.eth.core.GetBlockByHash(blockHash) + block := api.quai.core.GetBlockByHash(blockHash) if block == nil { return StorageRangeResult{}, fmt.Errorf("block %#x not found", blockHash) } - _, _, statedb, err := api.eth.core.StateAtTransaction(block, txIndex, 0) + _, _, statedb, err := api.quai.core.StateAtTransaction(block, txIndex, 0) if err != nil { return StorageRangeResult{}, err } @@ -446,20 +446,20 @@ func storageRangeAt(st state.Trie, start []byte, maxResult int) (StorageRangeRes func (api *PrivateDebugAPI) GetModifiedAccountsByNumber(startNum uint64, endNum *uint64) ([]common.Address, error) { var startBlock, endBlock *types.Block - startBlock = api.eth.core.GetBlockByNumber(startNum) + startBlock = api.quai.core.GetBlockByNumber(startNum) if startBlock == nil { return nil, fmt.Errorf("start block %x not found", startNum) } - nodeCtx := api.eth.core.NodeCtx() + nodeCtx := api.quai.core.NodeCtx() if endNum == nil { endBlock = startBlock - startBlock = api.eth.core.GetBlockByHash(startBlock.ParentHash(nodeCtx)) + startBlock = api.quai.core.GetBlockByHash(startBlock.ParentHash(nodeCtx)) if startBlock == nil { return nil, fmt.Errorf("block %x has no parent", endBlock.Number(nodeCtx)) } } else { - endBlock = api.eth.core.GetBlockByNumber(*endNum) + endBlock = api.quai.core.GetBlockByNumber(*endNum) if endBlock == nil { return nil, fmt.Errorf("end block %d not found", *endNum) } @@ -474,20 +474,20 @@ func (api *PrivateDebugAPI) GetModifiedAccountsByNumber(startNum uint64, endNum // With one parameter, returns the list of accounts modified in the specified block. func (api *PrivateDebugAPI) GetModifiedAccountsByHash(startHash common.Hash, endHash *common.Hash) ([]common.Address, error) { var startBlock, endBlock *types.Block - startBlock = api.eth.core.GetBlockByHash(startHash) + startBlock = api.quai.core.GetBlockByHash(startHash) if startBlock == nil { return nil, fmt.Errorf("start block %x not found", startHash) } - nodeCtx := api.eth.core.NodeCtx() + nodeCtx := api.quai.core.NodeCtx() if endHash == nil { endBlock = startBlock - startBlock = api.eth.core.GetBlockByHash(startBlock.ParentHash(nodeCtx)) + startBlock = api.quai.core.GetBlockByHash(startBlock.ParentHash(nodeCtx)) if startBlock == nil { return nil, fmt.Errorf("block %x has no parent", endBlock.Number(nodeCtx)) } } else { - endBlock = api.eth.core.GetBlockByHash(*endHash) + endBlock = api.quai.core.GetBlockByHash(*endHash) if endBlock == nil { return nil, fmt.Errorf("end block %x not found", *endHash) } @@ -496,12 +496,12 @@ func (api *PrivateDebugAPI) GetModifiedAccountsByHash(startHash common.Hash, end } func (api *PrivateDebugAPI) getModifiedAccounts(startBlock, endBlock *types.Block) ([]common.Address, error) { - nodeLocation := api.eth.core.NodeLocation() - nodeCtx := api.eth.core.NodeCtx() + nodeLocation := api.quai.core.NodeLocation() + nodeCtx := api.quai.core.NodeCtx() if startBlock.NumberU64(nodeCtx) >= endBlock.NumberU64(nodeCtx) { return nil, fmt.Errorf("start block height (%d) must be less than end block height (%d)", startBlock.NumberU64(nodeCtx), endBlock.NumberU64(nodeCtx)) } - triedb := api.eth.Core().StateCache().TrieDB() + triedb := api.quai.Core().StateCache().TrieDB() oldTrie, err := trie.NewSecure(startBlock.Root(), triedb) if err != nil { diff --git a/eth/api_backend.go b/quai/api_backend.go similarity index 74% rename from eth/api_backend.go rename to quai/api_backend.go index f22c6b811f..803bf8b8e1 100644 --- a/eth/api_backend.go +++ b/quai/api_backend.go @@ -14,7 +14,7 @@ // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . -package eth +package quai import ( "context" @@ -29,71 +29,71 @@ import ( "github.com/dominant-strategies/go-quai/core/state" "github.com/dominant-strategies/go-quai/core/types" "github.com/dominant-strategies/go-quai/core/vm" - "github.com/dominant-strategies/go-quai/eth/gasprice" "github.com/dominant-strategies/go-quai/ethdb" "github.com/dominant-strategies/go-quai/event" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai/gasprice" "github.com/dominant-strategies/go-quai/rpc" ) // QuaiAPIBackend implements quaiapi.Backend for full nodes type QuaiAPIBackend struct { extRPCEnabled bool - eth *Quai + quai *Quai gpo *gasprice.Oracle } // ChainConfig returns the active chain configuration. func (b *QuaiAPIBackend) ChainConfig() *params.ChainConfig { - return b.eth.core.Config() + return b.quai.core.Config() } func (b *QuaiAPIBackend) TxPool() *core.TxPool { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.core.TxPool() + return b.quai.core.TxPool() } func (b *QuaiAPIBackend) NodeLocation() common.Location { - return b.eth.core.NodeLocation() + return b.quai.core.NodeLocation() } func (b *QuaiAPIBackend) NodeCtx() int { - return b.eth.core.NodeCtx() + return b.quai.core.NodeCtx() } func (b *QuaiAPIBackend) CurrentBlock() *types.Block { - return b.eth.core.CurrentBlock() + return b.quai.core.CurrentBlock() } // CurrentLogEntropy returns the logarithm of the total entropy reduction since genesis for our current head block func (b *QuaiAPIBackend) CurrentLogEntropy() *big.Int { - return b.eth.core.CurrentLogEntropy() + return b.quai.core.CurrentLogEntropy() } // TotalLogS returns the total entropy reduction if the chain since genesis to the given header func (b *QuaiAPIBackend) TotalLogS(header *types.Header) *big.Int { - return b.eth.core.TotalLogS(header) + return b.quai.core.TotalLogS(header) } // CalcOrder returns the order of the block within the hierarchy of chains func (b *QuaiAPIBackend) CalcOrder(header *types.Header) (*big.Int, int, error) { - return b.eth.core.CalcOrder(header) + return b.quai.core.CalcOrder(header) } func (b *QuaiAPIBackend) HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error) { // Pending block is only known by the miner if number == rpc.PendingBlockNumber { - block := b.eth.core.PendingBlock() + block := b.quai.core.PendingBlock() return block.Header(), nil } // Otherwise resolve and return the block if number == rpc.LatestBlockNumber { - return b.eth.core.CurrentBlock().Header(), nil + return b.quai.core.CurrentBlock().Header(), nil } - return b.eth.core.GetHeaderByNumber(uint64(number)), nil + return b.quai.core.GetHeaderByNumber(uint64(number)), nil } func (b *QuaiAPIBackend) HeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Header, error) { @@ -101,11 +101,11 @@ func (b *QuaiAPIBackend) HeaderByNumberOrHash(ctx context.Context, blockNrOrHash return b.HeaderByNumber(ctx, blockNr) } if hash, ok := blockNrOrHash.Hash(); ok { - header := b.eth.core.GetHeaderByHash(hash) + header := b.quai.core.GetHeaderByHash(hash) if header == nil { return nil, errors.New("header for hash not found") } - if blockNrOrHash.RequireCanonical && b.eth.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { + if blockNrOrHash.RequireCanonical && b.quai.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { return nil, errors.New("hash is not currently canonical") } return header, nil @@ -114,20 +114,20 @@ func (b *QuaiAPIBackend) HeaderByNumberOrHash(ctx context.Context, blockNrOrHash } func (b *QuaiAPIBackend) HeaderByHash(ctx context.Context, hash common.Hash) (*types.Header, error) { - return b.eth.core.GetHeaderByHash(hash), nil + return b.quai.core.GetHeaderByHash(hash), nil } func (b *QuaiAPIBackend) BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error) { // Pending block is only known by the miner if number == rpc.PendingBlockNumber { - block := b.eth.core.PendingBlock() + block := b.quai.core.PendingBlock() return block, nil } // Otherwise resolve and return the block if number == rpc.LatestBlockNumber { - number = rpc.BlockNumber(b.eth.core.CurrentHeader().NumberU64(b.NodeCtx())) + number = rpc.BlockNumber(b.quai.core.CurrentHeader().NumberU64(b.NodeCtx())) } - block := b.eth.core.GetBlockByNumber(uint64(number)) + block := b.quai.core.GetBlockByNumber(uint64(number)) if block != nil { return block, nil } @@ -135,7 +135,7 @@ func (b *QuaiAPIBackend) BlockByNumber(ctx context.Context, number rpc.BlockNumb } func (b *QuaiAPIBackend) BlockByHash(ctx context.Context, hash common.Hash) (*types.Block, error) { - return b.eth.core.GetBlockByHash(hash), nil + return b.quai.core.GetBlockByHash(hash), nil } func (b *QuaiAPIBackend) BlockByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Block, error) { @@ -143,14 +143,14 @@ func (b *QuaiAPIBackend) BlockByNumberOrHash(ctx context.Context, blockNrOrHash return b.BlockByNumber(ctx, blockNr) } if hash, ok := blockNrOrHash.Hash(); ok { - header := b.eth.core.GetHeaderByHash(hash) + header := b.quai.core.GetHeaderByHash(hash) if header == nil { return nil, errors.New("header for hash not found") } - if blockNrOrHash.RequireCanonical && b.eth.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { + if blockNrOrHash.RequireCanonical && b.quai.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { return nil, errors.New("hash is not currently canonical") } - block := b.eth.core.GetBlock(hash, header.NumberU64(b.NodeCtx())) + block := b.quai.core.GetBlock(hash, header.NumberU64(b.NodeCtx())) if block == nil { return nil, errors.New("header found, but block body is missing") } @@ -160,17 +160,17 @@ func (b *QuaiAPIBackend) BlockByNumberOrHash(ctx context.Context, blockNrOrHash } func (b *QuaiAPIBackend) PendingBlockAndReceipts() (*types.Block, types.Receipts) { - return b.eth.core.PendingBlockAndReceipts() + return b.quai.core.PendingBlockAndReceipts() } func (b *QuaiAPIBackend) StateAndHeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*state.StateDB, *types.Header, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, nil, errors.New("stateAndHeaderByNumber can only be called in zone chain") } // Pending state is only known by the miner if number == rpc.PendingBlockNumber { - block := b.eth.core.Pending() + block := b.quai.core.Pending() return &state.StateDB{}, block.Header(), nil } // Otherwise resolve the block number and return its state @@ -181,12 +181,12 @@ func (b *QuaiAPIBackend) StateAndHeaderByNumber(ctx context.Context, number rpc. if header == nil { return nil, nil, errors.New("header not found") } - stateDb, err := b.eth.Core().StateAt(header.Root()) + stateDb, err := b.quai.Core().StateAt(header.Root()) return stateDb, header, err } func (b *QuaiAPIBackend) StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*state.StateDB, *types.Header, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, nil, errors.New("stateAndHeaderByNumberOrHash can only be called in zone chain") } @@ -201,38 +201,38 @@ func (b *QuaiAPIBackend) StateAndHeaderByNumberOrHash(ctx context.Context, block if header == nil { return nil, nil, errors.New("header for hash not found") } - if blockNrOrHash.RequireCanonical && b.eth.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { + if blockNrOrHash.RequireCanonical && b.quai.core.GetCanonicalHash(header.NumberU64(b.NodeCtx())) != hash { return nil, nil, errors.New("hash is not currently canonical") } - stateDb, err := b.eth.Core().StateAt(header.Root()) + stateDb, err := b.quai.Core().StateAt(header.Root()) return stateDb, header, err } return nil, nil, errors.New("invalid arguments; neither block nor hash specified") } func (b *QuaiAPIBackend) GetReceipts(ctx context.Context, hash common.Hash) (types.Receipts, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("getReceipts can only be called in zone chain") } - return b.eth.core.GetReceiptsByHash(hash), nil + return b.quai.core.GetReceiptsByHash(hash), nil } // GetBloom returns the bloom for the given block hash func (b *QuaiAPIBackend) GetBloom(hash common.Hash) (*types.Bloom, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("getBloom can only be called in zone chain") } - return b.eth.core.Slice().HeaderChain().GetBloom(hash) + return b.quai.core.Slice().HeaderChain().GetBloom(hash) } func (b *QuaiAPIBackend) GetLogs(ctx context.Context, hash common.Hash) ([][]*types.Log, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("getLogs can only be called in zone chain") } - receipts := b.eth.core.GetReceiptsByHash(hash) + receipts := b.quai.core.GetReceiptsByHash(hash) if receipts == nil { return nil, nil } @@ -245,68 +245,68 @@ func (b *QuaiAPIBackend) GetLogs(ctx context.Context, hash common.Hash) ([][]*ty func (b *QuaiAPIBackend) GetEVM(ctx context.Context, msg core.Message, state *state.StateDB, header *types.Header, vmConfig *vm.Config) (*vm.EVM, func() error, error) { vmError := func() error { return nil } - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, vmError, errors.New("getEvm can only be called in zone chain") } if vmConfig == nil { - vmConfig = b.eth.core.GetVMConfig() + vmConfig = b.quai.core.GetVMConfig() } txContext := core.NewEVMTxContext(msg) - context := core.NewEVMBlockContext(header, b.eth.Core(), nil) - return vm.NewEVM(context, txContext, state, b.eth.core.Config(), *vmConfig), vmError, nil + context := core.NewEVMBlockContext(header, b.quai.Core(), nil) + return vm.NewEVM(context, txContext, state, b.quai.core.Config(), *vmConfig), vmError, nil } func (b *QuaiAPIBackend) SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.Core().SubscribeRemovedLogsEvent(ch) + return b.quai.Core().SubscribeRemovedLogsEvent(ch) } func (b *QuaiAPIBackend) SubscribePendingLogsEvent(ch chan<- []*types.Log) event.Subscription { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.core.SubscribePendingLogs(ch) + return b.quai.core.SubscribePendingLogs(ch) } func (b *QuaiAPIBackend) SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription { - return b.eth.Core().SubscribeChainEvent(ch) + return b.quai.Core().SubscribeChainEvent(ch) } func (b *QuaiAPIBackend) SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription { - return b.eth.Core().SubscribeChainHeadEvent(ch) + return b.quai.Core().SubscribeChainHeadEvent(ch) } func (b *QuaiAPIBackend) SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription { - return b.eth.Core().SubscribeChainSideEvent(ch) + return b.quai.Core().SubscribeChainSideEvent(ch) } func (b *QuaiAPIBackend) SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.Core().SubscribeLogsEvent(ch) + return b.quai.Core().SubscribeLogsEvent(ch) } func (b *QuaiAPIBackend) SendTx(ctx context.Context, signedTx *types.Transaction) error { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return errors.New("sendTx can only be called in zone chain") } - return b.eth.Core().AddLocal(signedTx) + return b.quai.Core().AddLocal(signedTx) } func (b *QuaiAPIBackend) GetPoolTransactions() (types.Transactions, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("getPoolTransactions can only be called in zone chain") } - pending, err := b.eth.core.TxPoolPending(false) + pending, err := b.quai.core.TxPoolPending(false) if err != nil { return nil, err } @@ -318,60 +318,60 @@ func (b *QuaiAPIBackend) GetPoolTransactions() (types.Transactions, error) { } func (b *QuaiAPIBackend) GetPoolTransaction(hash common.Hash) *types.Transaction { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.core.Get(hash) + return b.quai.core.Get(hash) } func (b *QuaiAPIBackend) GetTransaction(ctx context.Context, txHash common.Hash) (*types.Transaction, common.Hash, uint64, uint64, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, common.Hash{}, 0, 0, errors.New("getTransaction can only be called in zone chain") } - tx, blockHash, blockNumber, index := rawdb.ReadTransaction(b.eth.ChainDb(), txHash) + tx, blockHash, blockNumber, index := rawdb.ReadTransaction(b.quai.ChainDb(), txHash) return tx, blockHash, blockNumber, index, nil } func (b *QuaiAPIBackend) GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return 0, errors.New("getPoolNonce can only be called in zone chain") } - return b.eth.core.Nonce(addr), nil + return b.quai.core.Nonce(addr), nil } func (b *QuaiAPIBackend) Stats() (pending int, queued int) { - return b.eth.core.Stats() + return b.quai.core.Stats() } func (b *QuaiAPIBackend) TxPoolContent() (map[common.InternalAddress]types.Transactions, map[common.InternalAddress]types.Transactions) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, nil } - return b.eth.core.Content() + return b.quai.core.Content() } func (b *QuaiAPIBackend) TxPoolContentFrom(addr common.Address) (types.Transactions, types.Transactions) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, nil } - return b.eth.core.ContentFrom(addr) + return b.quai.core.ContentFrom(addr) } func (b *QuaiAPIBackend) SubscribeNewTxsEvent(ch chan<- core.NewTxsEvent) event.Subscription { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil } - return b.eth.core.SubscribeNewTxsEvent(ch) + return b.quai.core.SubscribeNewTxsEvent(ch) } func (b *QuaiAPIBackend) SuggestGasTipCap(ctx context.Context) (*big.Int, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("suggestTipCap can only be called in zone chain") } @@ -383,11 +383,11 @@ func (b *QuaiAPIBackend) FeeHistory(ctx context.Context, blockCount int, lastBlo } func (b *QuaiAPIBackend) ChainDb() ethdb.Database { - return b.eth.ChainDb() + return b.quai.ChainDb() } func (b *QuaiAPIBackend) EventMux() *event.TypeMux { - return b.eth.EventMux() + return b.quai.EventMux() } func (b *QuaiAPIBackend) ExtRPCEnabled() bool { @@ -395,136 +395,136 @@ func (b *QuaiAPIBackend) ExtRPCEnabled() bool { } func (b *QuaiAPIBackend) RPCGasCap() uint64 { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return 0 } - return b.eth.config.RPCGasCap + return b.quai.config.RPCGasCap } func (b *QuaiAPIBackend) RPCTxFeeCap() float64 { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return 0 } - return b.eth.config.RPCTxFeeCap + return b.quai.config.RPCTxFeeCap } func (b *QuaiAPIBackend) BloomStatus() (uint64, uint64) { - sections, _, _ := b.eth.bloomIndexer.Sections() + sections, _, _ := b.quai.bloomIndexer.Sections() return params.BloomBitsBlocks, sections } func (b *QuaiAPIBackend) ServiceFilter(ctx context.Context, session *bloombits.MatcherSession) { for i := 0; i < bloomFilterThreads; i++ { - go session.Multiplex(bloomRetrievalBatch, bloomRetrievalWait, b.eth.bloomRequests) + go session.Multiplex(bloomRetrievalBatch, bloomRetrievalWait, b.quai.bloomRequests) } } func (b *QuaiAPIBackend) Engine() consensus.Engine { - return b.eth.engine + return b.quai.engine } func (b *QuaiAPIBackend) CurrentHeader() *types.Header { - return b.eth.core.CurrentHeader() + return b.quai.core.CurrentHeader() } func (b *QuaiAPIBackend) StateAtBlock(ctx context.Context, block *types.Block, reexec uint64, base *state.StateDB, checkLive bool) (*state.StateDB, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, errors.New("stateAtBlock can only be called in zone chain") } - return b.eth.core.StateAtBlock(block, reexec, base, checkLive) + return b.quai.core.StateAtBlock(block, reexec, base, checkLive) } func (b *QuaiAPIBackend) StateAtTransaction(ctx context.Context, block *types.Block, txIndex int, reexec uint64) (core.Message, vm.BlockContext, *state.StateDB, error) { - nodeCtx := b.eth.core.NodeCtx() + nodeCtx := b.quai.core.NodeCtx() if nodeCtx != common.ZONE_CTX { return nil, vm.BlockContext{}, nil, errors.New("stateAtTransaction can only be called in zone chain") } - return b.eth.core.StateAtTransaction(block, txIndex, reexec) + return b.quai.core.StateAtTransaction(block, txIndex, reexec) } func (b *QuaiAPIBackend) Append(header *types.Header, manifest types.BlockManifest, domPendingHeader *types.Header, domTerminus common.Hash, domOrigin bool, newInboundEtxs types.Transactions) (types.Transactions, bool, bool, error) { - return b.eth.core.Append(header, manifest, domPendingHeader, domTerminus, domOrigin, newInboundEtxs) + return b.quai.core.Append(header, manifest, domPendingHeader, domTerminus, domOrigin, newInboundEtxs) } func (b *QuaiAPIBackend) DownloadBlocksInManifest(hash common.Hash, manifest types.BlockManifest, entropy *big.Int) { - b.eth.core.DownloadBlocksInManifest(hash, manifest, entropy) + b.quai.core.DownloadBlocksInManifest(hash, manifest, entropy) } func (b *QuaiAPIBackend) ConstructLocalMinedBlock(header *types.Header) (*types.Block, error) { - return b.eth.core.ConstructLocalMinedBlock(header) + return b.quai.core.ConstructLocalMinedBlock(header) } func (b *QuaiAPIBackend) InsertBlock(ctx context.Context, block *types.Block) (int, error) { - return b.eth.core.InsertChain([]*types.Block{block}) + return b.quai.core.InsertChain([]*types.Block{block}) } func (b *QuaiAPIBackend) WriteBlock(block *types.Block) { - b.eth.core.WriteBlock(block) + b.quai.core.WriteBlock(block) } func (b *QuaiAPIBackend) PendingBlock() *types.Block { - return b.eth.core.PendingBlock() + return b.quai.core.PendingBlock() } func (b *QuaiAPIBackend) SubRelayPendingHeader(pendingHeader types.PendingHeader, newEntropy *big.Int, location common.Location, subReorg bool, order int) { - b.eth.core.SubRelayPendingHeader(pendingHeader, newEntropy, location, subReorg, order) + b.quai.core.SubRelayPendingHeader(pendingHeader, newEntropy, location, subReorg, order) } func (b *QuaiAPIBackend) UpdateDom(oldTerminus common.Hash, pendingHeader types.PendingHeader, location common.Location) { - b.eth.core.UpdateDom(oldTerminus, pendingHeader, location) + b.quai.core.UpdateDom(oldTerminus, pendingHeader, location) } func (b *QuaiAPIBackend) RequestDomToAppendOrFetch(hash common.Hash, entropy *big.Int, order int) { - b.eth.core.RequestDomToAppendOrFetch(hash, entropy, order) + b.quai.core.RequestDomToAppendOrFetch(hash, entropy, order) } func (b *QuaiAPIBackend) ProcessingState() bool { - return b.eth.core.ProcessingState() + return b.quai.core.ProcessingState() } func (b *QuaiAPIBackend) NewGenesisPendingHeader(pendingHeader *types.Header) { - b.eth.core.NewGenesisPendigHeader(pendingHeader) + b.quai.core.NewGenesisPendigHeader(pendingHeader) } func (b *QuaiAPIBackend) GetPendingHeader() (*types.Header, error) { - return b.eth.core.GetPendingHeader() + return b.quai.core.GetPendingHeader() } func (b *QuaiAPIBackend) GetManifest(blockHash common.Hash) (types.BlockManifest, error) { - return b.eth.core.GetManifest(blockHash) + return b.quai.core.GetManifest(blockHash) } func (b *QuaiAPIBackend) GetSubManifest(slice common.Location, blockHash common.Hash) (types.BlockManifest, error) { - return b.eth.core.GetSubManifest(slice, blockHash) + return b.quai.core.GetSubManifest(slice, blockHash) } func (b *QuaiAPIBackend) AddPendingEtxs(pEtxs types.PendingEtxs) error { - return b.eth.core.AddPendingEtxs(pEtxs) + return b.quai.core.AddPendingEtxs(pEtxs) } func (b *QuaiAPIBackend) AddPendingEtxsRollup(pEtxsRollup types.PendingEtxsRollup) error { - return b.eth.core.AddPendingEtxsRollup(pEtxsRollup) + return b.quai.core.AddPendingEtxsRollup(pEtxsRollup) } func (b *QuaiAPIBackend) SubscribePendingHeaderEvent(ch chan<- *types.Header) event.Subscription { - return b.eth.core.SubscribePendingHeader(ch) + return b.quai.core.SubscribePendingHeader(ch) } func (b *QuaiAPIBackend) GenerateRecoveryPendingHeader(pendingHeader *types.Header, checkpointHashes types.Termini) error { - return b.eth.core.GenerateRecoveryPendingHeader(pendingHeader, checkpointHashes) + return b.quai.core.GenerateRecoveryPendingHeader(pendingHeader, checkpointHashes) } func (b *QuaiAPIBackend) GetPendingEtxsRollupFromSub(hash common.Hash, location common.Location) (types.PendingEtxsRollup, error) { - return b.eth.core.GetPendingEtxsRollupFromSub(hash, location) + return b.quai.core.GetPendingEtxsRollupFromSub(hash, location) } func (b *QuaiAPIBackend) GetPendingEtxsFromSub(hash common.Hash, location common.Location) (types.PendingEtxs, error) { - return b.eth.core.GetPendingEtxsFromSub(hash, location) + return b.quai.core.GetPendingEtxsFromSub(hash, location) } func (b *QuaiAPIBackend) SetSyncTarget(header *types.Header) { - b.eth.core.SetSyncTarget(header) + b.quai.core.SetSyncTarget(header) } diff --git a/eth/api_test.go b/quai/api_test.go similarity index 99% rename from eth/api_test.go rename to quai/api_test.go index b14676abd2..d3b0d4027f 100644 --- a/eth/api_test.go +++ b/quai/api_test.go @@ -14,7 +14,7 @@ // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . -package eth +package quai import ( "bytes" diff --git a/eth/backend.go b/quai/backend.go similarity index 94% rename from eth/backend.go rename to quai/backend.go index 1fb6d52589..6bf32c9f0d 100644 --- a/eth/backend.go +++ b/quai/backend.go @@ -15,7 +15,7 @@ // along with the go-ethereum library. If not, see . // Package quai implements the Quai protocol. -package eth +package quai import ( "fmt" @@ -31,25 +31,25 @@ import ( "github.com/dominant-strategies/go-quai/core/state/pruner" "github.com/dominant-strategies/go-quai/core/types" "github.com/dominant-strategies/go-quai/core/vm" - "github.com/dominant-strategies/go-quai/eth/ethconfig" - "github.com/dominant-strategies/go-quai/eth/filters" - "github.com/dominant-strategies/go-quai/eth/gasprice" "github.com/dominant-strategies/go-quai/ethdb" "github.com/dominant-strategies/go-quai/event" "github.com/dominant-strategies/go-quai/internal/quaiapi" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/node" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai/filters" + "github.com/dominant-strategies/go-quai/quai/gasprice" + "github.com/dominant-strategies/go-quai/quai/quaiconfig" "github.com/dominant-strategies/go-quai/rpc" ) // Config contains the configuration options of the ETH protocol. // Deprecated: use ethconfig.Config instead. -type Config = ethconfig.Config +type Config = quaiconfig.Config // Quai implements the Quai full node service. type Quai struct { - config *ethconfig.Config + config *quaiconfig.Config // Handlers core *core.Core @@ -74,11 +74,11 @@ type Quai struct { // New creates a new Quai object (including the // initialisation of the common Quai object) -func New(stack *node.Node, config *ethconfig.Config, nodeCtx int) (*Quai, error) { +func New(stack *node.Node, config *quaiconfig.Config, nodeCtx int) (*Quai, error) { // Ensure configuration values are compatible and sane if config.Miner.GasPrice == nil || config.Miner.GasPrice.Cmp(common.Big0) <= 0 { - log.Warn("Sanitizing invalid miner gas price", "provided", config.Miner.GasPrice, "updated", ethconfig.Defaults.Miner.GasPrice) - config.Miner.GasPrice = new(big.Int).Set(ethconfig.Defaults.Miner.GasPrice) + log.Warn("Sanitizing invalid miner gas price", "provided", config.Miner.GasPrice, "updated", quaiconfig.Defaults.Miner.GasPrice) + config.Miner.GasPrice = new(big.Int).Set(quaiconfig.Defaults.Miner.GasPrice) } if config.NoPruning && config.TrieDirtyCache > 0 { if config.SnapshotCache > 0 { @@ -134,13 +134,13 @@ func New(stack *node.Node, config *ethconfig.Config, nodeCtx int) (*Quai, error) blake3Config := config.Blake3Pow blake3Config.NotifyFull = config.Miner.NotifyFull blake3Config.NodeLocation = config.NodeLocation - quai.engine = ethconfig.CreateBlake3ConsensusEngine(stack, config.NodeLocation, &blake3Config, config.Miner.Notify, config.Miner.Noverify, chainDb) + quai.engine = quaiconfig.CreateBlake3ConsensusEngine(stack, config.NodeLocation, &blake3Config, config.Miner.Notify, config.Miner.Noverify, chainDb) } else { // Transfer mining-related config to the progpow config. progpowConfig := config.Progpow progpowConfig.NodeLocation = config.NodeLocation progpowConfig.NotifyFull = config.Miner.NotifyFull - quai.engine = ethconfig.CreateProgpowConsensusEngine(stack, config.NodeLocation, &progpowConfig, config.Miner.Notify, config.Miner.Noverify, chainDb) + quai.engine = quaiconfig.CreateProgpowConsensusEngine(stack, config.NodeLocation, &progpowConfig, config.Miner.Notify, config.Miner.Noverify, chainDb) } log.Info("Initialised chain configuration", "config", chainConfig) diff --git a/eth/bloombits.go b/quai/bloombits.go similarity index 99% rename from eth/bloombits.go rename to quai/bloombits.go index 81f95ba1fa..fadeb80f63 100644 --- a/eth/bloombits.go +++ b/quai/bloombits.go @@ -14,7 +14,7 @@ // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . -package eth +package quai import ( "time" diff --git a/eth/filters/api.go b/quai/filters/api.go similarity index 100% rename from eth/filters/api.go rename to quai/filters/api.go diff --git a/eth/filters/api_test.go b/quai/filters/api_test.go similarity index 100% rename from eth/filters/api_test.go rename to quai/filters/api_test.go diff --git a/eth/filters/bench_test.go b/quai/filters/bench_test.go similarity index 100% rename from eth/filters/bench_test.go rename to quai/filters/bench_test.go diff --git a/eth/filters/filter.go b/quai/filters/filter.go similarity index 100% rename from eth/filters/filter.go rename to quai/filters/filter.go diff --git a/eth/filters/filter_system.go b/quai/filters/filter_system.go similarity index 100% rename from eth/filters/filter_system.go rename to quai/filters/filter_system.go diff --git a/eth/filters/filter_system_test.go b/quai/filters/filter_system_test.go similarity index 100% rename from eth/filters/filter_system_test.go rename to quai/filters/filter_system_test.go diff --git a/eth/filters/filter_test.go b/quai/filters/filter_test.go similarity index 100% rename from eth/filters/filter_test.go rename to quai/filters/filter_test.go diff --git a/eth/gasprice/feehistory.go b/quai/gasprice/feehistory.go similarity index 100% rename from eth/gasprice/feehistory.go rename to quai/gasprice/feehistory.go diff --git a/eth/gasprice/feehistory_test.go b/quai/gasprice/feehistory_test.go similarity index 100% rename from eth/gasprice/feehistory_test.go rename to quai/gasprice/feehistory_test.go diff --git a/eth/gasprice/gasprice.go b/quai/gasprice/gasprice.go similarity index 100% rename from eth/gasprice/gasprice.go rename to quai/gasprice/gasprice.go diff --git a/eth/gasprice/gasprice_test.go b/quai/gasprice/gasprice_test.go similarity index 100% rename from eth/gasprice/gasprice_test.go rename to quai/gasprice/gasprice_test.go diff --git a/eth/interface.go b/quai/interface.go similarity index 99% rename from eth/interface.go rename to quai/interface.go index b0d03ea084..a45e9cab4f 100644 --- a/eth/interface.go +++ b/quai/interface.go @@ -1,4 +1,4 @@ -package eth +package quai import ( "github.com/dominant-strategies/go-quai/common" diff --git a/eth/p2p_backend.go b/quai/p2p_backend.go similarity index 99% rename from eth/p2p_backend.go rename to quai/p2p_backend.go index a757ad58fc..8292dec804 100644 --- a/eth/p2p_backend.go +++ b/quai/p2p_backend.go @@ -1,4 +1,4 @@ -package eth +package quai import ( "github.com/dominant-strategies/go-quai/common" diff --git a/eth/ethconfig/config.go b/quai/quaiconfig/config.go similarity index 96% rename from eth/ethconfig/config.go rename to quai/quaiconfig/config.go index fc7f95353d..f819e839b2 100644 --- a/eth/ethconfig/config.go +++ b/quai/quaiconfig/config.go @@ -14,8 +14,8 @@ // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . -// Package ethconfig contains the configuration of the ETH and LES protocols. -package ethconfig +// Package quaiconfig contains the configuration of the ETH and LES protocols. +package quaiconfig import ( "math/big" @@ -26,11 +26,11 @@ import ( "github.com/dominant-strategies/go-quai/consensus/blake3pow" "github.com/dominant-strategies/go-quai/consensus/progpow" "github.com/dominant-strategies/go-quai/core" - "github.com/dominant-strategies/go-quai/eth/gasprice" "github.com/dominant-strategies/go-quai/ethdb" "github.com/dominant-strategies/go-quai/log" "github.com/dominant-strategies/go-quai/node" "github.com/dominant-strategies/go-quai/params" + "github.com/dominant-strategies/go-quai/quai/gasprice" ) type QuaistatsConfig struct { @@ -38,9 +38,9 @@ type QuaistatsConfig struct { } type QuaiConfig struct { - Quai Config - Node node.Config - Ethstats QuaistatsConfig + Quai Config + Node node.Config + Quaistats QuaistatsConfig } // FullNodeGPO contains default gasprice oracle settings for full node. diff --git a/eth/ethconfig/gen_config.go b/quai/quaiconfig/gen_config.go similarity index 98% rename from eth/ethconfig/gen_config.go rename to quai/quaiconfig/gen_config.go index 0f47affa63..68d7faa726 100644 --- a/eth/ethconfig/gen_config.go +++ b/quai/quaiconfig/gen_config.go @@ -1,6 +1,6 @@ // Code generated by github.com/fjl/gencodec. DO NOT EDIT. -package ethconfig +package quaiconfig import ( "time" @@ -8,7 +8,7 @@ import ( "github.com/dominant-strategies/go-quai/common" "github.com/dominant-strategies/go-quai/consensus/progpow" "github.com/dominant-strategies/go-quai/core" - "github.com/dominant-strategies/go-quai/eth/gasprice" + "github.com/dominant-strategies/go-quai/quai/gasprice" ) // MarshalTOML marshals as TOML. diff --git a/eth/tracers/api_test.go b/quai/tracers/api_test.go similarity index 100% rename from eth/tracers/api_test.go rename to quai/tracers/api_test.go diff --git a/eth/tracers/tracers_test.go b/quai/tracers/tracers_test.go similarity index 100% rename from eth/tracers/tracers_test.go rename to quai/tracers/tracers_test.go