| 
									
										
										
										
											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-08-23 15:43:16 +02:00
										 |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"encoding/json" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 	"strconv" | 
					
						
							| 
									
										
										
										
											2014-12-04 10:28:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 14:20:11 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/cmd/utils" | 
					
						
							| 
									
										
										
										
											2014-12-04 10:28:02 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/core/types" | 
					
						
							| 
									
										
										
										
											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-08-23 15:43:16 +02:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type plugin struct { | 
					
						
							|  |  |  | 	Name string `json:"name"` | 
					
						
							|  |  |  | 	Path string `json:"path"` | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-16 12:07:16 +02:00
										 |  |  | // LogPrint writes to the GUI log. | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | func (gui *Gui) LogPrint(level logger.LogLevel, msg string) { | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	/* | 
					
						
							|  |  |  | 		str := strings.TrimRight(s, "\n") | 
					
						
							|  |  |  | 		lines := strings.Split(str, "\n") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		view := gui.getObjectByName("infoView") | 
					
						
							|  |  |  | 		for _, line := range lines { | 
					
						
							|  |  |  | 			view.Call("addLog", line) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	*/ | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-12-01 20:18:09 +01:00
										 |  |  | func (gui *Gui) Transact(recipient, value, gas, gasPrice, d string) (string, error) { | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	var data string | 
					
						
							|  |  |  | 	if len(recipient) == 0 { | 
					
						
							|  |  |  | 		code, err := ethutil.Compile(d, false) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2014-12-01 20:18:09 +01:00
										 |  |  | 			return "", err | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		data = ethutil.Bytes2Hex(code) | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		data = ethutil.Bytes2Hex(utils.FormatTransactionData(d)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-05 19:53:53 +01:00
										 |  |  | 	return gui.xeth.Transact(gui.privateKey(), recipient, value, gas, gasPrice, data) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (gui *Gui) SetCustomIdentifier(customIdentifier string) { | 
					
						
							|  |  |  | 	gui.clientIdentity.SetCustomIdentifier(customIdentifier) | 
					
						
							|  |  |  | 	gui.config.Save("id", customIdentifier) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (gui *Gui) GetCustomIdentifier() string { | 
					
						
							|  |  |  | 	return gui.clientIdentity.GetCustomIdentifier() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | // functions that allow Gui to implement interface guilogger.LogSystem | 
					
						
							|  |  |  | func (gui *Gui) SetLogLevel(level logger.LogLevel) { | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	gui.logLevel = level | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	gui.eth.Logger().SetLogLevel(level) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	gui.config.Save("loglevel", level) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | func (gui *Gui) GetLogLevel() logger.LogLevel { | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	return gui.logLevel | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Gui) AddPlugin(pluginPath string) { | 
					
						
							| 
									
										
										
										
											2014-09-08 00:50:25 +02:00
										 |  |  | 	self.plugins[pluginPath] = plugin{Name: pluginPath, Path: pluginPath} | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	json, _ := json.MarshalIndent(self.plugins, "", "    ") | 
					
						
							|  |  |  | 	ethutil.WriteFile(ethutil.Config.ExecPath+"/plugins.json", json) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (self *Gui) RemovePlugin(pluginPath string) { | 
					
						
							|  |  |  | 	delete(self.plugins, pluginPath) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	json, _ := json.MarshalIndent(self.plugins, "", "    ") | 
					
						
							|  |  |  | 	ethutil.WriteFile(ethutil.Config.ExecPath+"/plugins.json", json) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // this extra function needed to give int typecast value to gui widget | 
					
						
							|  |  |  | // that sets initial loglevel to default | 
					
						
							|  |  |  | func (gui *Gui) GetLogLevelInt() int { | 
					
						
							|  |  |  | 	return int(gui.logLevel) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | func (self *Gui) DumpState(hash, path string) { | 
					
						
							|  |  |  | 	var stateDump []byte | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if len(hash) == 0 { | 
					
						
							| 
									
										
										
										
											2014-12-10 19:59:12 +01:00
										 |  |  | 		stateDump = self.eth.ChainManager().State().Dump() | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2014-11-18 16:58:22 +01:00
										 |  |  | 		var block *types.Block | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 		if hash[0] == '#' { | 
					
						
							|  |  |  | 			i, _ := strconv.Atoi(hash[1:]) | 
					
						
							| 
									
										
										
										
											2014-10-20 12:03:31 +02:00
										 |  |  | 			block = self.eth.ChainManager().GetBlockByNumber(uint64(i)) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2014-10-20 12:03:31 +02:00
										 |  |  | 			block = self.eth.ChainManager().GetBlock(ethutil.Hex2Bytes(hash)) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if block == nil { | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 			guilogger.Infof("block err: not found %s\n", hash) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 			return | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-07 13:17:48 +01:00
										 |  |  | 		stateDump = state.New(block.Root(), self.eth.Db()).Dump() | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	file, err := os.OpenFile(path[7:], os.O_CREATE|os.O_RDWR, os.ModePerm) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 		guilogger.Infoln("dump err: ", err) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	defer file.Close() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-31 12:56:05 +01:00
										 |  |  | 	guilogger.Infof("dumped state (%s) to %s\n", hash, path) | 
					
						
							| 
									
										
										
										
											2014-08-23 15:43:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	file.Write(stateDump) | 
					
						
							|  |  |  | } |