| 
									
										
										
										
											2015-01-06 12:13:57 +01:00
										 |  |  | /* | 
					
						
							|  |  |  | 	This file is part of go-ethereum | 
					
						
							| 
									
										
										
										
											2014-10-23 15:48:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-06 12:13:57 +01:00
										 |  |  | 	go-ethereum is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | 	it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  | 	the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | 	(at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	go-ethereum 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 General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | 	along with go-ethereum.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @authors | 
					
						
							|  |  |  |  * 	Jeffrey Wilcke <i@jev.io> | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"os" | 
					
						
							| 
									
										
										
										
											2014-07-30 01:05:40 +02:00
										 |  |  | 	"runtime" | 
					
						
							| 
									
										
										
										
											2014-12-23 18:35:36 +01:00
										 |  |  | 	"time" | 
					
						
							| 
									
										
										
										
											2014-07-30 01:05:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 14:20:11 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/cmd/utils" | 
					
						
							| 
									
										
										
										
											2014-12-04 10:53:49 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core/types" | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/eth" | 
					
						
							| 
									
										
										
										
											2014-10-23 15:01:27 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/ethutil" | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/logger" | 
					
						
							| 
									
										
										
										
											2015-01-07 13:17:48 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/state" | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | const ( | 
					
						
							|  |  |  | 	ClientIdentifier = "Ethereum(G)" | 
					
						
							| 
									
										
										
										
											2015-01-30 14:37:07 +01:00
										 |  |  | 	Version          = "0.8.2" | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | var clilogger = logger.NewLogger("CLI") | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	runtime.GOMAXPROCS(runtime.NumCPU()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-23 14:33:15 +01:00
										 |  |  | 	defer func() { | 
					
						
							|  |  |  | 		logger.Flush() | 
					
						
							|  |  |  | 	}() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 10:47:45 +01:00
										 |  |  | 	utils.HandleInterrupt() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 	// precedence: code-internal flag default < config file < environment variables < command line | 
					
						
							|  |  |  | 	Init() // parsing command line | 
					
						
							| 
									
										
										
										
											2014-07-11 16:04:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-07 01:21:55 +01:00
										 |  |  | 	if PrintVersion { | 
					
						
							|  |  |  | 		printVersion() | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-14 11:49:15 +02:00
										 |  |  | 	utils.InitConfig(VmType, ConfigFile, Datadir, "ETH") | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	ethereum, err := eth.New(ð.Config{ | 
					
						
							|  |  |  | 		Name:       ClientIdentifier, | 
					
						
							|  |  |  | 		Version:    Version, | 
					
						
							|  |  |  | 		KeyStore:   KeyStore, | 
					
						
							|  |  |  | 		DataDir:    Datadir, | 
					
						
							|  |  |  | 		LogFile:    LogFile, | 
					
						
							|  |  |  | 		LogLevel:   LogLevel, | 
					
						
							|  |  |  | 		Identifier: Identifier, | 
					
						
							|  |  |  | 		MaxPeers:   MaxPeer, | 
					
						
							|  |  |  | 		Port:       OutboundPort, | 
					
						
							|  |  |  | 		NATType:    PMPGateway, | 
					
						
							|  |  |  | 		PMPGateway: PMPGateway, | 
					
						
							|  |  |  | 		KeyRing:    KeyRing, | 
					
						
							| 
									
										
										
										
											2015-01-05 17:10:42 +01:00
										 |  |  | 		Shh:        SHH, | 
					
						
							|  |  |  | 		Dial:       Dial, | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	}) | 
					
						
							| 
									
										
										
										
											2015-01-05 17:10:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-22 12:14:37 +02:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 		clilogger.Fatalln(err) | 
					
						
							| 
									
										
										
										
											2014-08-22 12:14:37 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-01-05 17:10:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	utils.KeyTasks(ethereum.KeyManager(), KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 	if Dump { | 
					
						
							| 
									
										
										
										
											2014-11-18 19:52:45 +01:00
										 |  |  | 		var block *types.Block | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if len(DumpHash) == 0 && DumpNumber == -1 { | 
					
						
							| 
									
										
										
										
											2014-12-18 13:17:24 +01:00
										 |  |  | 			block = ethereum.ChainManager().CurrentBlock() | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 		} else if len(DumpHash) > 0 { | 
					
						
							| 
									
										
										
										
											2014-10-20 12:03:31 +02:00
										 |  |  | 			block = ethereum.ChainManager().GetBlock(ethutil.Hex2Bytes(DumpHash)) | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2014-10-20 12:03:31 +02:00
										 |  |  | 			block = ethereum.ChainManager().GetBlockByNumber(uint64(DumpNumber)) | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if block == nil { | 
					
						
							|  |  |  | 			fmt.Fprintln(os.Stderr, "block not found") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// We want to output valid JSON | 
					
						
							|  |  |  | 			fmt.Println("{}") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			os.Exit(1) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Leave the Println. This needs clean output for piping | 
					
						
							| 
									
										
										
										
											2015-01-07 13:17:48 +01:00
										 |  |  | 		statedb := state.New(block.Root(), ethereum.Db()) | 
					
						
							|  |  |  | 		fmt.Printf("%s\n", statedb.Dump()) | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-29 14:20:42 +01:00
										 |  |  | 		fmt.Println(block) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 		return | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if StartMining { | 
					
						
							|  |  |  | 		utils.StartMining(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-23 14:33:15 +01:00
										 |  |  | 	if len(ImportChain) > 0 { | 
					
						
							| 
									
										
										
										
											2014-12-23 18:35:36 +01:00
										 |  |  | 		start := time.Now() | 
					
						
							| 
									
										
										
										
											2014-12-23 15:37:03 +01:00
										 |  |  | 		err := utils.ImportChain(ethereum, ImportChain) | 
					
						
							| 
									
										
										
										
											2014-12-23 14:33:15 +01:00
										 |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			clilogger.Infoln(err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-12-24 14:54:06 +01:00
										 |  |  | 		clilogger.Infoln("import done in", time.Since(start)) | 
					
						
							| 
									
										
										
										
											2014-12-23 15:37:03 +01:00
										 |  |  | 		return | 
					
						
							| 
									
										
										
										
											2014-12-23 14:33:15 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 	if StartRpc { | 
					
						
							|  |  |  | 		utils.StartRpc(ethereum, RpcPort) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-30 23:26:16 +02:00
										 |  |  | 	if StartWebSockets { | 
					
						
							| 
									
										
										
										
											2015-01-27 12:28:58 -06:00
										 |  |  | 		utils.StartWebSockets(ethereum, WsPort) | 
					
						
							| 
									
										
										
										
											2014-09-30 23:26:16 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-02 13:04:00 -06:00
										 |  |  | 	utils.StartEthereum(ethereum, SeedNode) | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-05 17:10:42 +01:00
										 |  |  | 	if StartJsConsole { | 
					
						
							|  |  |  | 		InitJsConsole(ethereum) | 
					
						
							|  |  |  | 	} else if len(InputFile) > 0 { | 
					
						
							|  |  |  | 		ExecJsFile(ethereum, InputFile) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 	// this blocks the thread | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	ethereum.WaitForShutdown() | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-01-07 01:21:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | func printVersion() { | 
					
						
							|  |  |  | 	fmt.Printf(`%v %v | 
					
						
							|  |  |  | PV=%d | 
					
						
							|  |  |  | GOOS=%s | 
					
						
							|  |  |  | GO=%s | 
					
						
							|  |  |  | GOPATH=%s | 
					
						
							|  |  |  | GOROOT=%s | 
					
						
							|  |  |  | `, ClientIdentifier, Version, eth.ProtocolVersion, runtime.GOOS, runtime.Version(), os.Getenv("GOPATH"), runtime.GOROOT()) | 
					
						
							|  |  |  | } |