Updated QWhisper
* changed api * general whisper debug interface
This commit is contained in:
parent
125bdc3253
commit
0e5aed63dd
@ -9,7 +9,7 @@ import Ethereum 1.0
|
||||
|
||||
Rectangle {
|
||||
id: root
|
||||
property var title: "Whisper"
|
||||
property var title: "Whisper Traffic"
|
||||
property var iconSource: "../facet.png"
|
||||
property var menuItem
|
||||
|
||||
@ -21,10 +21,22 @@ Rectangle {
|
||||
identity = shh.newIdentity()
|
||||
console.log("New identity:", identity)
|
||||
|
||||
var t = shh.watch({topics: ["chat"]})
|
||||
var t = shh.watch({}, root)
|
||||
}
|
||||
|
||||
function onMessage(message) {
|
||||
whisperModel.insert(0, {data: JSON.stringify({from: message.from, payload: eth.toAscii(message.payload)})})
|
||||
}
|
||||
|
||||
RowLayout {
|
||||
id: input
|
||||
anchors {
|
||||
left: parent.left
|
||||
leftMargin: 20
|
||||
top: parent.top
|
||||
topMargin: 20
|
||||
}
|
||||
|
||||
TextField {
|
||||
id: to
|
||||
placeholderText: "To"
|
||||
@ -44,4 +56,20 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TableView {
|
||||
id: txTableView
|
||||
anchors {
|
||||
top: input.bottom
|
||||
topMargin: 10
|
||||
bottom: parent.bottom
|
||||
left: parent.left
|
||||
right: parent.right
|
||||
}
|
||||
TableViewColumn{ role: "data" ; title: "Data" ; width: parent.width - 2 }
|
||||
|
||||
model: ListModel {
|
||||
id: whisperModel
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -381,6 +381,14 @@ func (self *UiLib) ToHex(data string) string {
|
||||
return "0x" + ethutil.Bytes2Hex([]byte(data))
|
||||
}
|
||||
|
||||
func (self *UiLib) ToAscii(data string) string {
|
||||
start := 0
|
||||
if len(data) > 1 && data[0:2] == "0x" {
|
||||
start = 2
|
||||
}
|
||||
return string(ethutil.Hex2Bytes(data[start:]))
|
||||
}
|
||||
|
||||
/*
|
||||
// XXX Refactor me & MOVE
|
||||
func (self *Ethereum) InstallFilter(filter *core.Filter) (id int) {
|
||||
|
23
ui/qt/qwhisper/message.go
Normal file
23
ui/qt/qwhisper/message.go
Normal file
@ -0,0 +1,23 @@
|
||||
package qwhisper
|
||||
|
||||
import (
|
||||
"github.com/ethereum/go-ethereum/crypto"
|
||||
"github.com/ethereum/go-ethereum/ethutil"
|
||||
"github.com/ethereum/go-ethereum/whisper"
|
||||
)
|
||||
|
||||
type Message struct {
|
||||
ref *whisper.Message
|
||||
Flags byte
|
||||
Payload string
|
||||
From string
|
||||
}
|
||||
|
||||
func ToQMessage(msg *whisper.Message) *Message {
|
||||
return &Message{
|
||||
ref: msg,
|
||||
Flags: msg.Flags,
|
||||
Payload: ethutil.Bytes2Hex(msg.Payload),
|
||||
From: ethutil.Bytes2Hex(crypto.FromECDSAPub(msg.Recover())),
|
||||
}
|
||||
}
|
13
ui/qt/qwhisper/watch.go
Normal file
13
ui/qt/qwhisper/watch.go
Normal file
@ -0,0 +1,13 @@
|
||||
package qwhisper
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
type Watch struct {
|
||||
}
|
||||
|
||||
func (self *Watch) Arrived(v unsafe.Pointer) {
|
||||
fmt.Println(v)
|
||||
}
|
@ -3,7 +3,6 @@ package qwhisper
|
||||
import (
|
||||
"fmt"
|
||||
"time"
|
||||
"unsafe"
|
||||
|
||||
"github.com/ethereum/go-ethereum/crypto"
|
||||
"github.com/ethereum/go-ethereum/ethutil"
|
||||
@ -19,13 +18,6 @@ func fromHex(s string) []byte {
|
||||
}
|
||||
func toHex(b []byte) string { return "0x" + ethutil.Bytes2Hex(b) }
|
||||
|
||||
type Watch struct {
|
||||
}
|
||||
|
||||
func (self *Watch) Arrived(v unsafe.Pointer) {
|
||||
fmt.Println(v)
|
||||
}
|
||||
|
||||
type Whisper struct {
|
||||
*whisper.Whisper
|
||||
view qml.Object
|
||||
@ -70,15 +62,18 @@ func (self *Whisper) HasIdentity(key string) bool {
|
||||
return self.Whisper.HasIdentity(crypto.ToECDSA(fromHex(key)))
|
||||
}
|
||||
|
||||
func (self *Whisper) Watch(opts map[string]interface{}) *Watch {
|
||||
func (self *Whisper) Watch(opts map[string]interface{}, view *qml.Common) int {
|
||||
filter := filterFromMap(opts)
|
||||
filter.Fn = func(msg *whisper.Message) {
|
||||
fmt.Println(msg)
|
||||
if view != nil {
|
||||
view.Call("onMessage", ToQMessage(msg))
|
||||
}
|
||||
}
|
||||
|
||||
i := self.Whisper.Watch(filter)
|
||||
self.watches[i] = &Watch{}
|
||||
|
||||
return self.watches[i]
|
||||
return i
|
||||
}
|
||||
|
||||
func filterFromMap(opts map[string]interface{}) (f whisper.Filter) {
|
||||
|
Loading…
Reference in New Issue
Block a user