| 
									
										
										
										
											2014-10-23 15:48:53 +02:00
										 |  |  | // Copyright (c) 2013-2014, Jeffrey Wilcke. All rights reserved. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This library 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 2.1 of the License, or (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This 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 | 
					
						
							|  |  |  | // General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | // along with this library; if not, write to the Free Software | 
					
						
							|  |  |  | // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | 
					
						
							|  |  |  | // MA 02110-1301  USA | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-10-23 15:01:27 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/ethchain" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/ethlog" | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/ethutil" | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/utils" | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | const ( | 
					
						
							|  |  |  | 	ClientIdentifier = "Ethereum(G)" | 
					
						
							| 
									
										
										
										
											2014-10-08 12:24:42 +02:00
										 |  |  | 	Version          = "0.7.0" | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | var logger = ethlog.NewLogger("CLI") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	runtime.GOMAXPROCS(runtime.NumCPU()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | 	// If the difftool option is selected ignore all other log output | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 	if DiffTool || Dump { | 
					
						
							| 
									
										
										
										
											2014-07-11 16:04:27 +02:00
										 |  |  | 		LogLevel = 0 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-14 11:49:15 +02:00
										 |  |  | 	utils.InitConfig(VmType, ConfigFile, Datadir, "ETH") | 
					
						
							| 
									
										
										
										
											2014-07-11 16:04:27 +02:00
										 |  |  | 	ethutil.Config.Diff = DiffTool | 
					
						
							| 
									
										
										
										
											2014-07-15 20:34:25 +02:00
										 |  |  | 	ethutil.Config.DiffType = DiffType | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	utils.InitDataDir(Datadir) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	utils.InitLogging(Datadir, LogFile, LogLevel, DebugFile) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-29 18:37:22 +01:00
										 |  |  | 	db := utils.NewDatabase() | 
					
						
							| 
									
										
										
										
											2014-08-22 12:14:37 +02:00
										 |  |  | 	err := utils.DBSanityCheck(db) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2014-10-23 00:59:35 +02:00
										 |  |  | 		fmt.Println(err) | 
					
						
							| 
									
										
										
										
											2014-08-22 12:40:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-22 12:14:37 +02:00
										 |  |  | 		os.Exit(1) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-29 18:37:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	keyManager := utils.NewKeyManager(KeyStore, Datadir, db) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// create, import, export keys | 
					
						
							| 
									
										
										
										
											2014-06-29 18:37:22 +01:00
										 |  |  | 	utils.KeyTasks(keyManager, KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | 	clientIdentity := utils.NewClientIdentity(ClientIdentifier, Version, Identifier) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ethereum := utils.NewEthereum(db, clientIdentity, keyManager, UseUPnP, OutboundPort, MaxPeer) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 	if Dump { | 
					
						
							|  |  |  | 		var block *ethchain.Block | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if len(DumpHash) == 0 && DumpNumber == -1 { | 
					
						
							| 
									
										
										
										
											2014-10-20 12:03:31 +02: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) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-19 13:32:52 +02:00
										 |  |  | 		fmt.Printf("RLP: %x\nstate: %x\nhash: %x\n", ethutil.Rlp(block), block.GetRoot(), block.Hash()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 		// Leave the Println. This needs clean output for piping | 
					
						
							| 
									
										
										
										
											2014-08-17 12:41:23 +02:00
										 |  |  | 		fmt.Printf("%s\n", block.State().Dump()) | 
					
						
							| 
									
										
										
										
											2014-08-06 09:53:12 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		os.Exit(0) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	if ShowGenesis { | 
					
						
							|  |  |  | 		utils.ShowGenesis(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if StartMining { | 
					
						
							|  |  |  | 		utils.StartMining(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// better reworked as cases | 
					
						
							|  |  |  | 	if StartJsConsole { | 
					
						
							|  |  |  | 		InitJsConsole(ethereum) | 
					
						
							|  |  |  | 	} else if len(InputFile) > 0 { | 
					
						
							|  |  |  | 		ExecJsFile(ethereum, InputFile) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if StartRpc { | 
					
						
							|  |  |  | 		utils.StartRpc(ethereum, RpcPort) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-30 23:26:16 +02:00
										 |  |  | 	if StartWebSockets { | 
					
						
							|  |  |  | 		utils.StartWebSockets(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 	utils.StartEthereum(ethereum, UseSeed) | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// this blocks the thread | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	ethereum.WaitForShutdown() | 
					
						
							|  |  |  | 	ethlog.Flush() | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | } |