From e1abb2b14b61d4bf05fc8461ee7f9a5ef1001418 Mon Sep 17 00:00:00 2001 From: obscuren Date: Mon, 8 Dec 2014 14:25:52 +0100 Subject: [PATCH] Additional checks and debug output --- envelope.go | 4 ++-- peer.go | 5 +++++ whisper.go | 7 +++++++ 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/envelope.go b/envelope.go index f925484..8e66a7b 100644 --- a/envelope.go +++ b/envelope.go @@ -12,7 +12,7 @@ import ( ) const ( - DefaultTtl = 50 * time.Second + DefaultPow = 50 * time.Millisecond ) type Envelope struct { @@ -56,7 +56,7 @@ func NewEnvelope(ttl time.Duration, topics [][]byte, data *Message) *Envelope { } func (self *Envelope) Seal() { - self.proveWork(DefaultTtl) + self.proveWork(DefaultPow) } func (self *Envelope) proveWork(dura time.Duration) { diff --git a/peer.go b/peer.go index 3471ddb..d42b374 100644 --- a/peer.go +++ b/peer.go @@ -81,11 +81,16 @@ func (self *peer) broadcast(envelopes []*Envelope) error { if err := self.ws.WriteMsg(msg); err != nil { return err } + self.peer.Infoln("broadcasted", i, "message(s)") } return nil } +func (self *peer) addKnown(envelope *Envelope) { + self.known.Add(envelope.Hash()) +} + func (self *peer) handleStatus() error { ws := self.ws diff --git a/whisper.go b/whisper.go index 255bd21..78e4d48 100644 --- a/whisper.go +++ b/whisper.go @@ -2,6 +2,7 @@ package whisper import ( "bytes" + "fmt" "sync" "time" @@ -34,6 +35,8 @@ const ( envelopesMsg = 0x01 ) +const defaultTtl = 50 * time.Second + type Whisper struct { pub, sec []byte protocol p2p.Protocol @@ -55,6 +58,8 @@ func New(pub, sec []byte) *Whisper { } go whisper.update() + whisper.Send(defaultTtl, nil, NewMessage([]byte("Hello world. This is whisper-go"))) + // p2p whisper sub protocol handler whisper.protocol = p2p.Protocol{ Name: "shh", @@ -102,6 +107,7 @@ func (self *Whisper) msgHandler(peer *p2p.Peer, ws p2p.MsgReadWriter) error { } self.add(envelope) + wpeer.addKnown(envelope) } } @@ -110,6 +116,7 @@ func (self *Whisper) add(envelope *Envelope) { self.mmu.Lock() defer self.mmu.Unlock() + fmt.Println("add", envelope) self.messages[envelope.Hash()] = envelope if self.expiry[envelope.Expiry] == nil { self.expiry[envelope.Expiry] = set.NewNonTS()