Clean up global discovery timer handing

This commit is contained in:
Jakob Borg 2014-11-19 01:03:43 +04:00
parent bbe7e6525d
commit fe2dd79838

View File

@ -258,64 +258,47 @@ func (d *Discoverer) sendExternalAnnouncements() {
buf = d.announcementPkt() buf = d.announcementPkt()
} }
var bcastTick = time.Tick(d.globalBcastIntv) nextAnnouncement := time.NewTimer(0)
var errTick <-chan time.Time
sendOneAnnouncement := func() {
var ok bool
if debug {
l.Debugf("discover: send announcement -> %v\n%s", remote, hex.Dump(buf))
}
_, err := conn.WriteTo(buf, remote)
if err != nil {
if debug {
l.Debugln("discover: warning:", err)
}
ok = false
} else {
// Verify that the announce server responds positively for our device ID
time.Sleep(1 * time.Second)
res := d.externalLookup(d.myID)
if debug {
l.Debugln("discover: external lookup check:", res)
}
ok = len(res) > 0
}
d.extAnnounceOKmut.Lock()
d.extAnnounceOK = ok
d.extAnnounceOKmut.Unlock()
if ok {
errTick = nil
} else if errTick != nil {
errTick = time.Tick(d.errorRetryIntv)
}
}
// Announce once, immediately
sendOneAnnouncement()
loop:
for { for {
select { select {
case <-d.stopGlobal: case <-d.stopGlobal:
break loop return
case <-errTick: case <-nextAnnouncement.C:
sendOneAnnouncement() var ok bool
case <-bcastTick: if debug {
sendOneAnnouncement() l.Debugf("discover: send announcement -> %v\n%s", remote, hex.Dump(buf))
}
_, err := conn.WriteTo(buf, remote)
if err != nil {
if debug {
l.Debugln("discover: warning:", err)
}
ok = false
} else {
// Verify that the announce server responds positively for our device ID
time.Sleep(1 * time.Second)
res := d.externalLookup(d.myID)
if debug {
l.Debugln("discover: external lookup check:", res)
}
ok = len(res) > 0
}
d.extAnnounceOKmut.Lock()
d.extAnnounceOK = ok
d.extAnnounceOKmut.Unlock()
if ok {
nextAnnouncement.Reset(d.globalBcastIntv)
} else {
nextAnnouncement.Reset(d.errorRetryIntv)
}
} }
} }
if debug {
l.Debugln("discover: stopping global")
}
} }
func (d *Discoverer) recvAnnouncements(b beacon.Interface) { func (d *Discoverer) recvAnnouncements(b beacon.Interface) {