| 
									
										
										
										
											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-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-23 15:01:27 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum" | 
					
						
							| 
									
										
										
										
											2014-10-31 14:20:11 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/cmd/utils" | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/logger" | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | 	"gopkg.in/qml.v1" | 
					
						
							| 
									
										
										
										
											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" | 
					
						
							| 
									
										
										
										
											2014-12-05 16:26:39 +01:00
										 |  |  | 	Version          = "0.7.9" | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | var ethereum *eth.Ethereum | 
					
						
							| 
									
										
										
										
											2014-06-26 16:26:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | func run() error { | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | 	utils.InitDataDir(Datadir) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-22 12:40:15 +02:00
										 |  |  | 	stdLog := utils.InitLogging(Datadir, LogFile, LogLevel, DebugFile) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-29 20:32:31 +01:00
										 |  |  | 	db := utils.NewDatabase() | 
					
						
							| 
									
										
										
										
											2014-08-22 12:12:41 +02:00
										 |  |  | 	err := utils.DBSanityCheck(db) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		ErrorWindow(err) | 
					
						
							| 
									
										
										
										
											2014-08-22 12:14:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-22 12:12:41 +02:00
										 |  |  | 		os.Exit(1) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-29 20:32:31 +01:00
										 |  |  | 	keyManager := utils.NewKeyManager(KeyStore, Datadir, db) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// create, import, export keys | 
					
						
							| 
									
										
										
										
											2014-06-29 20:32:31 +01:00
										 |  |  | 	utils.KeyTasks(keyManager, KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive) | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | 	clientIdentity := utils.NewClientIdentity(ClientIdentifier, Version, Identifier) | 
					
						
							| 
									
										
										
										
											2014-08-15 13:27:43 +02:00
										 |  |  | 	ethereum = utils.NewEthereum(db, clientIdentity, keyManager, UseUPnP, OutboundPort, MaxPeer) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 18:41:36 +01:00
										 |  |  | 	if ShowGenesis { | 
					
						
							|  |  |  | 		utils.ShowGenesis(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if StartRpc { | 
					
						
							|  |  |  | 		utils.StartRpc(ethereum, RpcPort) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 17:36:24 +01:00
										 |  |  | 	gui := NewWindow(ethereum, config, clientIdentity, KeyRing, LogLevel) | 
					
						
							| 
									
										
										
										
											2014-08-22 12:40:15 +02:00
										 |  |  | 	gui.stdLog = stdLog | 
					
						
							| 
									
										
										
										
											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() | 
					
						
							|  |  |  | 	}) | 
					
						
							| 
									
										
										
										
											2014-11-15 00:29:27 +01:00
										 |  |  | 	go utils.StartEthereum(ethereum, UseSeed) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	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-10-07 11:18:34 +02:00
										 |  |  | 	if StartWebSockets { | 
					
						
							|  |  |  | 		utils.StartWebSockets(ethereum) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 	} | 
					
						
							|  |  |  | 	// this blocks the thread | 
					
						
							|  |  |  | 	ethereum.WaitForShutdown() | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	logger.Flush() | 
					
						
							| 
									
										
										
										
											2014-06-23 12:20:59 +01:00
										 |  |  | } |