| 
									
										
										
										
											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-11-15 00:29:27 +01:00
										 |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2014-07-30 01:05:40 +02:00
										 |  |  | 	"os" | 
					
						
							|  |  |  | 	"runtime" | 
					
						
							| 
									
										
										
										
											2014-11-15 00:29:27 +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-15 13:00:09 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/eth" | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/logger" | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/p2p" | 
					
						
							| 
									
										
										
										
											2015-01-28 20:50:09 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/ui/qt/webengine" | 
					
						
							| 
									
										
										
										
											2015-01-28 14:51:54 +01:00
										 |  |  | 	"github.com/obscuren/qml" | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | const ( | 
					
						
							| 
									
										
										
										
											2014-09-17 15:58:44 +02:00
										 |  |  | 	ClientIdentifier = "Mist" | 
					
						
							| 
									
										
										
										
											2015-03-08 00:59:26 +01:00
										 |  |  | 	Version          = "0.9.0" | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | var ethereum *eth.Ethereum | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | var mainlogger = logger.NewLogger("MAIN") | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | func run() error { | 
					
						
							| 
									
										
										
										
											2015-01-28 20:50:09 +01:00
										 |  |  | 	webengine.Initialize() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-03 17:36:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-15 00:29:27 +01:00
										 |  |  | 	tstart := time.Now() | 
					
						
							| 
									
										
										
										
											2014-10-14 11:49:15 +02:00
										 |  |  | 	config := 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{ | 
					
						
							| 
									
										
										
										
											2015-02-19 10:38:36 +01:00
										 |  |  | 		Name:         p2p.MakeName(ClientIdentifier, Version), | 
					
						
							|  |  |  | 		KeyStore:     KeyStore, | 
					
						
							|  |  |  | 		DataDir:      Datadir, | 
					
						
							|  |  |  | 		LogFile:      LogFile, | 
					
						
							|  |  |  | 		LogLevel:     LogLevel, | 
					
						
							|  |  |  | 		MaxPeers:     MaxPeer, | 
					
						
							|  |  |  | 		Port:         OutboundPort, | 
					
						
							|  |  |  | 		NAT:          NAT, | 
					
						
							|  |  |  | 		Shh:          true, | 
					
						
							|  |  |  | 		BootNodes:    BootNodes, | 
					
						
							|  |  |  | 		NodeKey:      NodeKey, | 
					
						
							|  |  |  | 		KeyRing:      KeyRing, | 
					
						
							|  |  |  | 		Dial:         true, | 
					
						
							|  |  |  | 		MinerThreads: MinerThreads, | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	}) | 
					
						
							| 
									
										
										
										
											2014-08-22 12:12:41 +02:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 		mainlogger.Fatalln(err) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +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
										 |  |  | 
 | 
					
						
							|  |  |  | 	if StartRpc { | 
					
						
							| 
									
										
										
										
											2015-02-28 01:00:42 +01:00
										 |  |  | 		utils.StartRpc(ethereum, RpcListenAddress, RpcPort) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-05 03:16:16 +01:00
										 |  |  | 	gui := NewWindow(ethereum, config, KeyRing, LogLevel) | 
					
						
							| 
									
										
										
										
											2014-06-26 10:47:45 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 	utils.RegisterInterrupt(func(os.Signal) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 		gui.Stop() | 
					
						
							|  |  |  | 	}) | 
					
						
							| 
									
										
										
										
											2015-02-07 00:38:36 +01:00
										 |  |  | 	go utils.StartEthereum(ethereum) | 
					
						
							| 
									
										
										
										
											2014-11-15 00:29:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	fmt.Println("ETH stack took", time.Since(tstart)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	// gui blocks the main thread | 
					
						
							|  |  |  | 	gui.Start(AssetPath) | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	runtime.GOMAXPROCS(runtime.NumCPU()) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// This is a bit of a cheat, but ey! | 
					
						
							|  |  |  | 	os.Setenv("QTWEBKIT_INSPECTOR_SERVER", "127.0.0.1:99999") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	qml.Run(run) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var interrupted = false | 
					
						
							|  |  |  | 	utils.RegisterInterrupt(func(os.Signal) { | 
					
						
							|  |  |  | 		interrupted = true | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	utils.HandleInterrupt() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	// we need to run the interrupt callbacks in case gui is closed | 
					
						
							|  |  |  | 	// this skips if we got here by actual interrupt stopping the GUI | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 	if !interrupted { | 
					
						
							|  |  |  | 		utils.RunInterruptCallbacks(os.Interrupt) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	logger.Flush() | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | } |