From c6d6ca283d24f7860dfa185c95a3d7b4a90afc60 Mon Sep 17 00:00:00 2001 From: Jeffrey Wilcke Date: Fri, 28 Feb 2014 17:04:45 +0100 Subject: [PATCH 1/9] Update README.md --- README.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/README.md b/README.md index 034b35f9721d..986c5e486f8d 100644 --- a/README.md +++ b/README.md @@ -5,8 +5,7 @@ Ethereum Ethereum Go Client (c) Jeffrey Wilcke -The current state is "Proof of Concept 3". For build instructions see -the [Wiki](https://github.com/ethereum/go-ethereum/wiki/Building-Edge). +The current state is "Proof of Concept 3". For the development Go Package please see [eth-go package](https://github.com/ethereum/eth-go). From b0be8474162bd3d12669600f4072c422089bc77a Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 3 Mar 2014 00:53:10 +0100 Subject: [PATCH 2/9] Updated to use the state on the blocks --- dev_console.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/dev_console.go b/dev_console.go index 09e06aa22e09..5a69ffa9e68c 100644 --- a/dev_console.go +++ b/dev_console.go @@ -158,7 +158,7 @@ func (i *Console) ParseInput(input string) bool { fmt.Println(value) case "getaddr": encoded, _ := hex.DecodeString(tokens[1]) - addr := i.ethereum.BlockManager.BlockChain().CurrentBlock.GetAddr(encoded) + addr := i.ethereum.BlockManager.BlockChain().CurrentBlock.State().GetAccount(encoded) fmt.Println("addr:", addr) case "block": encoded, _ := hex.DecodeString(tokens[1]) From 00533003b7e5369260f63e65b88e2f08ab33350b Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 3 Mar 2014 00:53:24 +0100 Subject: [PATCH 3/9] Get rid of the xpm files --- net.pxm | Bin 95418 -> 0 bytes tx.pxm | Bin 93227 -> 0 bytes 2 files changed, 0 insertions(+), 0 deletions(-) delete mode 100644 net.pxm delete mode 100644 tx.pxm diff --git a/net.pxm b/net.pxm deleted file mode 100644 index 20d45d08c652610fe5942b6156e047736e501e17..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 95418 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

xNm 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 diff --git a/tx.pxm b/tx.pxm deleted file mode 100644 index 881420da9670686061c113d6fb2c6f27c72ac1bb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 93227 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 From a482b0cc1b7ddbeae00988c7dd10391df01b0009 Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 3 Mar 2014 00:54:05 +0100 Subject: [PATCH 4/9] WIP Makefile --- Makefile | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 Makefile diff --git a/Makefile b/Makefile new file mode 100644 index 000000000000..4da4c551c824 --- /dev/null +++ b/Makefile @@ -0,0 +1,20 @@ +UNAME = $(shell uname) + +# Default is building +all: + go install + +install: +# Linux build +ifeq ($(UNAME),Linux) + mkdir /usr/local/ethereal + files=(wallet.qml net.png network.png new.png tx.png) + for file in "${files[@]}"; do + cp $file /usr/share/ethereal + done + cp $GOPATH/bin/go-ethereum /usr/local/bin/ethereal +endif +# OS X build +ifeq ($(UNAME),Darwin) + # Execute py script +endif From 3d2c3b0107d438dd081c57ef74036f4c5a03855f Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 3 Mar 2014 00:54:41 +0100 Subject: [PATCH 5/9] Using asset path helper (includes a debug path atm) --- ui/gui.go | 9 +-- ui/ui_lib.go | 27 +++++++ wallet.qml | 198 ++++++++++++++++++++++++++++++--------------------- 3 files changed, 147 insertions(+), 87 deletions(-) diff --git a/ui/gui.go b/ui/gui.go index 389fe4f68e22..196d2cd76d7d 100644 --- a/ui/gui.go +++ b/ui/gui.go @@ -9,8 +9,6 @@ import ( "github.com/ethereum/eth-go/ethdb" "github.com/ethereum/eth-go/ethutil" "github.com/niemeyer/qml" - "bitbucket.org/kardianos/osext" - "path/filepath" "math/big" "strings" ) @@ -87,15 +85,12 @@ func (ui *Gui) Start() { // Create a new QML engine ui.engine = qml.NewEngine() - // Get Binary Directory - exedir , _ := osext.ExecutableFolder() - // Load the main QML interface - component, err := ui.engine.LoadFile(filepath.Join(exedir, "wallet.qml")) + component, err := ui.engine.LoadFile(AssetPath("wallet.qml")) if err != nil { panic(err) } - ui.engine.LoadFile(filepath.Join(exedir, "transactions.qml")) + ui.engine.LoadFile(AssetPath("transactions.qml")) ui.win = component.CreateWindow(nil) diff --git a/ui/ui_lib.go b/ui/ui_lib.go index c956fd03241d..2a1abee237ea 100644 --- a/ui/ui_lib.go +++ b/ui/ui_lib.go @@ -1,9 +1,13 @@ package ethui import ( + "bitbucket.org/kardianos/osext" "github.com/ethereum/eth-go" "github.com/ethereum/eth-go/ethutil" "github.com/niemeyer/qml" + "path" + "path/filepath" + "runtime" ) // UI Library that has some basic functionality exposed @@ -38,3 +42,26 @@ func (ui *UiLib) Connect(button qml.Object) { func (ui *UiLib) ConnectToPeer(addr string) { ui.eth.ConnectToPeer(addr) } + +func (ui *UiLib) AssetPath(p string) string { + return AssetPath(p) +} + +func AssetPath(p string) string { + var base string + switch runtime.GOOS { + case "darwin": + // Get Binary Directory + exedir, _ := osext.ExecutableFolder() + base = filepath.Join(exedir, "../Resources") + base = "/Users/jeffrey/go/src/github.com/ethereum/go-ethereum" + case "linux": + base = "/usr/share/ethereal" + case "window": + fallthrough + default: + base = "." + } + + return path.Join(base, p) +} diff --git a/wallet.qml b/wallet.qml index e86551ad68b9..39bc21f39d14 100644 --- a/wallet.qml +++ b/wallet.qml @@ -115,116 +115,141 @@ ApplicationWindow { } } } - - } - - property var txModel: ListModel { - id: txModel } Rectangle { - id: historyView - property var title: "Transactions" + id: mainView + color: "#00000000" anchors.right: parent.right anchors.left: menu.right anchors.bottom: parent.bottom anchors.top: parent.top - TableView { - id: txTableView - anchors.fill: parent - TableViewColumn{ role: "value" ; title: "Value" ; width: 100 } - TableViewColumn{ role: "address" ; title: "Address" ; width: 430 } - model: txModel + property var txModel: ListModel { + id: txModel } - } - Rectangle { - id: newTxView - property var title: "New transaction" - visible: false - anchors.right: parent.right - anchors.left: menu.right - anchors.bottom: parent.bottom - anchors.top: parent.top - color: "#00000000" + Rectangle { + id: historyView + anchors.fill: parent - ColumnLayout { - width: 400 - anchors.left: parent.left - anchors.top: parent.top - anchors.leftMargin: 5 - anchors.topMargin: 5 - TextField { - id: txAmount - width: 200 - placeholderText: "Amount" - } + property var title: "Transactions" + TableView { + id: txTableView + anchors.fill: parent + TableViewColumn{ role: "value" ; title: "Value" ; width: 100 } + TableViewColumn{ role: "address" ; title: "Address" ; width: 430 } - TextField { - id: txReceiver - placeholderText: "Receiver Address (or empty for contract)" - Layout.fillWidth: true + model: txModel } + } - Label { - text: "Transaction data" - } - TextArea { - id: codeView + Rectangle { + id: newTxView + property var title: "New transaction" + visible: false + anchors.fill: parent + color: "#00000000" + + ColumnLayout { + width: 400 + anchors.left: parent.left + anchors.top: parent.top + anchors.leftMargin: 5 anchors.topMargin: 5 - Layout.fillWidth: true - width: parent.width /2 - } + TextField { + id: txAmount + width: 200 + placeholderText: "Amount" + } + + TextField { + id: txReceiver + placeholderText: "Receiver Address (or empty for contract)" + Layout.fillWidth: true + } - Button { - text: "Send" - onClicked: { - console.log(eth.createTx(txReceiver.text, txAmount.text, codeView.text)) + Label { + text: "Transaction data" + } + TextArea { + id: codeView + anchors.topMargin: 5 + Layout.fillWidth: true + width: parent.width /2 + } + + Button { + text: "Send" + onClicked: { + console.log(eth.createTx(txReceiver.text, txAmount.text, codeView.text)) + } } } } - } - Rectangle { - id: networkView - property var title: "Network" - visible: false - anchors.right: parent.right - anchors.bottom: parent.bottom - anchors.top: parent.top + Rectangle { + id: networkView + property var title: "Network" + visible: false + anchors.fill: parent + + TableView { + id: blockTable + width: parent.width + anchors.top: parent.top + anchors.bottom: logView.top + TableViewColumn{ role: "number" ; title: "#" ; width: 100 } + TableViewColumn{ role: "hash" ; title: "Hash" ; width: 560 } + + model: blockModel + + /* + onDoubleClicked: { + popup.visible = true + popup.block = eth.getBlock(blockModel.get(row).hash) + popup.hashLabel.text = popup.block.hash + } + */ + } - TableView { - id: blockTable - width: parent.width - anchors.top: parent.top - anchors.bottom: logView.top - TableViewColumn{ role: "number" ; title: "#" ; width: 100 } - TableViewColumn{ role: "hash" ; title: "Hash" ; width: 560 } + property var logModel: ListModel { + id: logModel + } - model: blockModel + TableView { + id: logView + width: parent.width + height: 150 + anchors.bottom: parent.bottom + TableViewColumn{ role: "description" ; title: "log" } - onDoubleClicked: { - popup.visible = true - popup.block = eth.getBlock(blockModel.get(row).hash) - popup.hashLabel.text = popup.block.hash + model: logModel } } - property var logModel: ListModel { - id: logModel + /* + signal addPlugin(string name) + Component { + id: pluginWindow + Rectangle { + anchors.fill: parent + Label { + id: pluginTitle + anchors.centerIn: parent + text: "Hello world" + } + Component.onCompleted: setView(this) + } } - TableView { - id: logView - width: parent.width - height: 150 - anchors.bottom: parent.bottom - TableViewColumn{ role: "description" ; title: "log" } - - model: logModel + onAddPlugin: { + var pluginWin = pluginWindow.createObject(mainView) + console.log(pluginWin) + pluginWin.pluginTitle.text = "Test" } + */ } } @@ -249,6 +274,7 @@ ApplicationWindow { } text: "Connect" } + Button { id: importAppButton anchors.left: connectButton.right @@ -304,6 +330,10 @@ ApplicationWindow { anchors.left: parent.left anchors.leftMargin: 10 placeholderText: "address:port" + onAccepted: { + ui.connectToPeer(addrField.text) + addPeerWin.visible = false + } } Button { anchors.left: addrField.right @@ -315,6 +345,9 @@ ApplicationWindow { addPeerWin.visible = false } } + Component.onCompleted: { + addrField.focus = true + } } Window { @@ -346,6 +379,11 @@ ApplicationWindow { } + function loadPlugin(name) { + console.log("Loading plugin" + name) + mainView.addPlugin(name) + } + function setWalletValue(value) { walletValueLabel.text = value } From 833a1a4eab01392b69339762cf8fe443697138a2 Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 3 Mar 2014 11:32:58 +0100 Subject: [PATCH 6/9] Block mining log --- ethereum.go | 1 + 1 file changed, 1 insertion(+) diff --git a/ethereum.go b/ethereum.go index 336cd4d0011f..07a40b10fe63 100644 --- a/ethereum.go +++ b/ethereum.go @@ -186,6 +186,7 @@ func main() { txs := ethereum.TxPool.Flush() // Create a new block which we're going to mine block := ethereum.BlockManager.BlockChain().NewBlock(addr, txs) + log.Println("Mining on new block. Includes", len(block.Transactions()), "transactions") // Apply all transactions to the block ethereum.BlockManager.ApplyTransactions(block, block.Transactions()) From 827505985652ac164d1f670797396d0f46774fb2 Mon Sep 17 00:00:00 2001 From: obscuren Date: Wed, 5 Mar 2014 10:44:33 +0100 Subject: [PATCH 7/9] Moved qml files, conform to the new server model. QML files got moved to their own directories. QML now has a ui helper which should find assets in the correct resource directory --- ethereum.go | 15 ++++++------ test_app.qml => qml/test_app.qml | 0 transactions.qml => qml/transactions.qml | 0 wallet.qml => qml/wallet.qml | 10 ++++---- ui/gui.go | 29 ++++++++++++------------ 5 files changed, 27 insertions(+), 27 deletions(-) rename test_app.qml => qml/test_app.qml (100%) rename transactions.qml => qml/transactions.qml (100%) rename wallet.qml => qml/wallet.qml (97%) diff --git a/ethereum.go b/ethereum.go index 07a40b10fe63..36cd75e4771d 100644 --- a/ethereum.go +++ b/ethereum.go @@ -144,7 +144,7 @@ func main() { } if ShowGenesis { - fmt.Println(ethereum.BlockManager.BlockChain().Genesis()) + fmt.Println(ethereum.BlockChain().Genesis()) os.Exit(0) } @@ -183,23 +183,24 @@ func main() { addr := keyRing.Get(1).Bytes() for { - txs := ethereum.TxPool.Flush() + txs := ethereum.TxPool().Flush() // Create a new block which we're going to mine - block := ethereum.BlockManager.BlockChain().NewBlock(addr, txs) + block := ethereum.BlockChain().NewBlock(addr, txs) log.Println("Mining on new block. Includes", len(block.Transactions()), "transactions") // Apply all transactions to the block - ethereum.BlockManager.ApplyTransactions(block, block.Transactions()) + ethereum.StateManager().ApplyTransactions(block, block.Transactions()) - ethereum.BlockManager.AccumelateRewards(block, block) + ethereum.StateManager().AccumelateRewards(block, block) // Search the nonce block.Nonce = pow.Search(block) ethereum.Broadcast(ethwire.MsgBlockTy, []interface{}{block.Value().Val}) - err := ethereum.BlockManager.ProcessBlock(block) + err := ethereum.StateManager().ProcessBlock(block) if err != nil { log.Println(err) } else { - log.Println("\n+++++++ MINED BLK +++++++\n", ethereum.BlockManager.BlockChain().CurrentBlock) + //log.Println("\n+++++++ MINED BLK +++++++\n", ethereum.BlockChain().CurrentBlock) + log.Printf("🔨 Mined block %x\n", block.Hash()) } } }() diff --git a/test_app.qml b/qml/test_app.qml similarity index 100% rename from test_app.qml rename to qml/test_app.qml diff --git a/transactions.qml b/qml/transactions.qml similarity index 100% rename from transactions.qml rename to qml/transactions.qml diff --git a/wallet.qml b/qml/wallet.qml similarity index 97% rename from wallet.qml rename to qml/wallet.qml index 39bc21f39d14..7fc7f5447d8f 100644 --- a/wallet.qml +++ b/qml/wallet.qml @@ -85,7 +85,7 @@ ApplicationWindow { anchors.right: parent.right height: 200 Image { - source: "tx.png" + source: ui.assetPath("tx.png") anchors.horizontalCenter: parent.horizontalCenter MouseArea { anchors.fill: parent @@ -95,7 +95,7 @@ ApplicationWindow { } } Image { - source: "new.png" + source: ui.assetPath("new.png") anchors.horizontalCenter: parent.horizontalCenter MouseArea { anchors.fill: parent @@ -105,7 +105,7 @@ ApplicationWindow { } } Image { - source: "net.png" + source: ui.assetPath("net.png") anchors.horizontalCenter: parent.horizontalCenter MouseArea { anchors.fill: parent @@ -300,7 +300,7 @@ ApplicationWindow { id: peerImage anchors.right: parent.right width: 10; height: 10 - source: "network.png" + source: ui.assetPath("network.png") } } } @@ -365,7 +365,7 @@ ApplicationWindow { width: 150 fillMode: Image.PreserveAspectFit smooth: true - source: "facet.png" + source: ui.assetPath("facet.png") x: 10 y: 10 } diff --git a/ui/gui.go b/ui/gui.go index 196d2cd76d7d..fa65ea4f6175 100644 --- a/ui/gui.go +++ b/ui/gui.go @@ -57,7 +57,7 @@ type Gui struct { // Create GUI, but doesn't start it func New(ethereum *eth.Ethereum) *Gui { - lib := &EthLib{blockManager: ethereum.BlockManager, blockChain: ethereum.BlockManager.BlockChain(), txPool: ethereum.TxPool} + lib := &EthLib{blockManager: ethereum.StateManager(), blockChain: ethereum.BlockChain(), txPool: ethereum.TxPool()} db, err := ethdb.NewLDBDatabase("tx_database") if err != nil { panic(err) @@ -66,7 +66,7 @@ func New(ethereum *eth.Ethereum) *Gui { key := ethutil.Config.Db.GetKeys()[0] addr := key.Address() - ethereum.BlockManager.WatchAddr(addr) + ethereum.StateManager().WatchAddr(addr) return &Gui{eth: ethereum, lib: lib, txDb: db, addr: addr} } @@ -84,24 +84,23 @@ func (ui *Gui) Start() { ethutil.Config.Log.Infoln("[GUI] Starting GUI") // Create a new QML engine ui.engine = qml.NewEngine() + context := ui.engine.Context() + + // Expose the eth library and the ui library to QML + context.SetVar("eth", ui.lib) + context.SetVar("ui", &UiLib{engine: ui.engine, eth: ui.eth}) // Load the main QML interface - component, err := ui.engine.LoadFile(AssetPath("wallet.qml")) + component, err := ui.engine.LoadFile(AssetPath("qml/wallet.qml")) if err != nil { panic(err) } - ui.engine.LoadFile(AssetPath("transactions.qml")) + ui.engine.LoadFile(AssetPath("qml/transactions.qml")) ui.win = component.CreateWindow(nil) - context := ui.engine.Context() - - // Expose the eth library and the ui library to QML - context.SetVar("eth", ui.lib) - context.SetVar("ui", &UiLib{engine: ui.engine, eth: ui.eth}) - // Register the ui as a block processor - ui.eth.BlockManager.SecondaryBlockProcessor = ui + //ui.eth.BlockManager.SecondaryBlockProcessor = ui //ui.eth.TxPool.SecondaryProcessor = ui // Add the ui as a log system so we can log directly to the UGI @@ -120,7 +119,7 @@ func (ui *Gui) Start() { func (ui *Gui) setInitialBlockChain() { // Load previous 10 blocks - chain := ui.eth.BlockManager.BlockChain().GetChain(ui.eth.BlockManager.BlockChain().CurrentBlock.Hash(), 10) + chain := ui.eth.BlockChain().GetChain(ui.eth.BlockChain().CurrentBlock.Hash(), 10) for _, block := range chain { ui.ProcessBlock(block) } @@ -144,9 +143,9 @@ func (ui *Gui) ProcessBlock(block *ethchain.Block) { // Simple go routine function that updates the list of peers in the GUI func (ui *Gui) update() { txChan := make(chan ethchain.TxMsg, 1) - ui.eth.TxPool.Subscribe(txChan) + ui.eth.TxPool().Subscribe(txChan) - account := ui.eth.BlockManager.GetAddrState(ui.addr).Account + account := ui.eth.StateManager().GetAddrState(ui.addr).Account unconfirmedFunds := new(big.Int) ui.win.Root().Call("setWalletValue", fmt.Sprintf("%v", ethutil.CurrencyToString(account.Amount))) for { @@ -159,7 +158,7 @@ func (ui *Gui) update() { ui.win.Root().Call("addTx", NewTxFromTransaction(tx)) ui.txDb.Put(tx.Hash(), tx.RlpEncode()) - ui.eth.BlockManager.GetAddrState(ui.addr).Nonce += 1 + ui.eth.StateManager().GetAddrState(ui.addr).Nonce += 1 unconfirmedFunds.Sub(unconfirmedFunds, tx.Value) } else if bytes.Compare(tx.Recipient, ui.addr) == 0 { ui.win.Root().Call("addTx", NewTxFromTransaction(tx)) From f7fb5b902c8b216c835c10fc4676b7b08fb90d04 Mon Sep 17 00:00:00 2001 From: obscuren Date: Wed, 5 Mar 2014 10:44:43 +0100 Subject: [PATCH 8/9] Conform to the new server model --- dev_console.go | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/dev_console.go b/dev_console.go index 5a69ffa9e68c..ead4b55e5ecf 100644 --- a/dev_console.go +++ b/dev_console.go @@ -158,11 +158,11 @@ func (i *Console) ParseInput(input string) bool { fmt.Println(value) case "getaddr": encoded, _ := hex.DecodeString(tokens[1]) - addr := i.ethereum.BlockManager.BlockChain().CurrentBlock.State().GetAccount(encoded) + addr := i.ethereum.BlockChain().CurrentBlock.State().GetAccount(encoded) fmt.Println("addr:", addr) case "block": encoded, _ := hex.DecodeString(tokens[1]) - block := i.ethereum.BlockManager.BlockChain().GetBlock(encoded) + block := i.ethereum.BlockChain().GetBlock(encoded) info := block.BlockInfo() fmt.Printf("++++++++++ #%d ++++++++++\n%v\n", info.Number, block) case "say": @@ -182,7 +182,7 @@ func (i *Console) ParseInput(input string) bool { key := ethutil.Config.Db.GetKeys()[0] tx.Sign(key.PrivateKey) - i.ethereum.TxPool.QueueTransaction(tx) + i.ethereum.TxPool().QueueTransaction(tx) fmt.Printf("%x\n", tx.Hash()) } @@ -204,7 +204,7 @@ func (i *Console) ParseInput(input string) bool { key := ethutil.Config.Db.GetKeys()[0] contract.Sign(key.PrivateKey) - i.ethereum.TxPool.QueueTransaction(contract) + i.ethereum.TxPool().QueueTransaction(contract) fmt.Printf("%x\n", contract.Hash()[12:]) case "exit", "quit", "q": From fbd53f0e34b636074941f5ea7b151bf173c5ed17 Mon Sep 17 00:00:00 2001 From: obscuren Date: Wed, 5 Mar 2014 10:57:14 +0100 Subject: [PATCH 9/9] Renamed block manager to state manager --- ui/gui.go | 2 +- ui/library.go | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/ui/gui.go b/ui/gui.go index fa65ea4f6175..5f0b6e52d68a 100644 --- a/ui/gui.go +++ b/ui/gui.go @@ -57,7 +57,7 @@ type Gui struct { // Create GUI, but doesn't start it func New(ethereum *eth.Ethereum) *Gui { - lib := &EthLib{blockManager: ethereum.StateManager(), blockChain: ethereum.BlockChain(), txPool: ethereum.TxPool()} + lib := &EthLib{stateManager: ethereum.StateManager(), blockChain: ethereum.BlockChain(), txPool: ethereum.TxPool()} db, err := ethdb.NewLDBDatabase("tx_database") if err != nil { panic(err) diff --git a/ui/library.go b/ui/library.go index 3bbb01314dcd..8dda0a89e994 100644 --- a/ui/library.go +++ b/ui/library.go @@ -9,7 +9,7 @@ import ( ) type EthLib struct { - blockManager *ethchain.BlockManager + stateManager *ethchain.StateManager blockChain *ethchain.BlockChain txPool *ethchain.TxPool } @@ -32,7 +32,7 @@ func (lib *EthLib) CreateTx(receiver, a, data string) string { amount := ethutil.Big(a) code := ethchain.Compile(strings.Split(data, "\n")) tx := ethchain.NewTransaction(hash, amount, code) - tx.Nonce = lib.blockManager.GetAddrState(keyRing.Get(1).Bytes()).Nonce + tx.Nonce = lib.stateManager.GetAddrState(keyRing.Get(1).Bytes()).Nonce tx.Sign(keyRing.Get(0).Bytes())