don't need to retry low prio communications

This commit is contained in:
Ted Unangst 2020-09-29 21:16:07 -04:00
parent 534691a61a
commit 69fea996ad
3 changed files with 25 additions and 11 deletions

View File

@ -997,7 +997,7 @@ func rubadubdub(user *WhatAbout, req junk.Junk) {
j["published"] = time.Now().UTC().Format(time.RFC3339) j["published"] = time.Now().UTC().Format(time.RFC3339)
j["object"] = req j["object"] = req
deliverate(0, user.ID, actor, j.ToBytes()) deliverate(0, user.ID, actor, j.ToBytes(), true)
} }
func itakeitallback(user *WhatAbout, xid string, owner string, folxid string) { func itakeitallback(user *WhatAbout, xid string, owner string, folxid string) {
@ -1016,7 +1016,7 @@ func itakeitallback(user *WhatAbout, xid string, owner string, folxid string) {
j["object"] = f j["object"] = f
j["published"] = time.Now().UTC().Format(time.RFC3339) j["published"] = time.Now().UTC().Format(time.RFC3339)
deliverate(0, user.ID, owner, j.ToBytes()) deliverate(0, user.ID, owner, j.ToBytes(), true)
} }
func subsub(user *WhatAbout, xid string, owner string, folxid string) { func subsub(user *WhatAbout, xid string, owner string, folxid string) {
@ -1033,7 +1033,7 @@ func subsub(user *WhatAbout, xid string, owner string, folxid string) {
j["object"] = xid j["object"] = xid
j["published"] = time.Now().UTC().Format(time.RFC3339) j["published"] = time.Now().UTC().Format(time.RFC3339)
deliverate(0, user.ID, owner, j.ToBytes()) deliverate(0, user.ID, owner, j.ToBytes(), true)
} }
func activatedonks(donks []*Donk) []junk.Junk { func activatedonks(donks []*Donk) []junk.Junk {
@ -1340,7 +1340,7 @@ func sendchonk(user *WhatAbout, ch *Chonk) {
rcpts := make(map[string]bool) rcpts := make(map[string]bool)
rcpts[ch.Target] = true rcpts[ch.Target] = true
for a := range rcpts { for a := range rcpts {
go deliverate(0, user.ID, a, msg) go deliverate(0, user.ID, a, msg, true)
} }
} }
@ -1375,13 +1375,25 @@ func honkworldwide(user *WhatAbout, honk *Honk) {
} }
} }
for a := range rcpts { for a := range rcpts {
go deliverate(0, user.ID, a, msg) go deliverate(0, user.ID, a, msg, doesitmatter(honk.What))
} }
if honk.Public && len(honk.Onts) > 0 { if honk.Public && len(honk.Onts) > 0 {
collectiveaction(honk) collectiveaction(honk)
} }
} }
func doesitmatter(what string) bool {
switch what {
case "ack":
return false
case "react":
return false
case "deack":
return false
}
return true
}
func collectiveaction(honk *Honk) { func collectiveaction(honk *Honk) {
user := getserveruser() user := getserveruser()
for _, ont := range honk.Onts { for _, ont := range honk.Onts {
@ -1408,7 +1420,7 @@ func collectiveaction(honk *Honk) {
} }
msg := j.ToBytes() msg := j.ToBytes()
for a := range rcpts { for a := range rcpts {
go deliverate(0, user.ID, a, msg) go deliverate(0, user.ID, a, msg, false)
} }
} }
} }
@ -1708,7 +1720,7 @@ func updateMe(username string) {
} }
} }
for a := range rcpts { for a := range rcpts {
go deliverate(0, user.ID, a, msg) go deliverate(0, user.ID, a, msg, false)
} }
} }

View File

@ -72,7 +72,7 @@ func clearoutbound(rcpt string) {
var garage = gate.NewLimiter(40) var garage = gate.NewLimiter(40)
func deliverate(goarounds int64, userid int64, rcpt string, msg []byte) { func deliverate(goarounds int64, userid int64, rcpt string, msg []byte, prio bool) {
garage.Start() garage.Start()
defer garage.Finish() defer garage.Finish()
@ -99,7 +99,9 @@ func deliverate(goarounds int64, userid int64, rcpt string, msg []byte) {
err := PostMsg(ki.keyname, ki.seckey, inbox, msg) err := PostMsg(ki.keyname, ki.seckey, inbox, msg)
if err != nil { if err != nil {
log.Printf("failed to post json to %s: %s", inbox, err) log.Printf("failed to post json to %s: %s", inbox, err)
sayitagain(goarounds+1, userid, rcpt, msg) if prio {
sayitagain(goarounds+1, userid, rcpt, msg)
}
return return
} }
} }
@ -162,7 +164,7 @@ func redeliverator() {
continue continue
} }
log.Printf("redeliverating %s try %d", rcpt, goarounds) log.Printf("redeliverating %s try %d", rcpt, goarounds)
deliverate(goarounds, userid, rcpt, msg) deliverate(goarounds, userid, rcpt, msg, true)
} else if d.When.Before(nexttime) { } else if d.When.Before(nexttime) {
nexttime = d.When nexttime = d.When
} }

2
web.go
View File

@ -2287,7 +2287,7 @@ func apihandler(w http.ResponseWriter, r *http.Request) {
rcpts := boxuprcpts(user, r.Form["rcpt"], public) rcpts := boxuprcpts(user, r.Form["rcpt"], public)
msg := []byte(r.FormValue("msg")) msg := []byte(r.FormValue("msg"))
for rcpt := range rcpts { for rcpt := range rcpts {
go deliverate(0, userid, rcpt, msg) go deliverate(0, userid, rcpt, msg, true)
} }
default: default:
http.Error(w, "unknown action", http.StatusNotFound) http.Error(w, "unknown action", http.StatusNotFound)