finish up some hfcs matching work

master
Ted Unangst 5 years ago
parent 5672db2380
commit 50e43569e4

@ -203,7 +203,7 @@ func iszonked(userid int64, xid string) bool {
}
func needxonk(user *WhatAbout, x *Honk) bool {
if rejectnote(x) {
if rejectxonk(x) {
log.Printf("not saving thumb biter? %s via %s", x.XID, x.Honker)
return false
}

@ -146,31 +146,59 @@ func stealthmode(userid int64, r *http.Request) bool {
}
// todo
func matchfilter(h *Honk, filts []*Filter) bool {
origin := originate(h.XID)
for _, f := range filts {
if f.Actor == origin || f.Actor == h.Honker {
return true
func matchfilter(h *Honk, f *Filter) bool {
match := true
if match && f.Actor != "" {
match = false
if f.Actor == h.Honker || f.Actor == h.Oonker {
match = true
}
if !match && (f.Actor == originate(h.Honker) ||
f.Actor == originate(h.Oonker) ||
f.Actor == originate(h.XID)) {
match = true
}
if f.Text != "" {
for _, d := range h.Donks {
if d.Desc == f.Text {
return true
if !match && f.IncludeAudience {
for _, a := range h.Audience {
if f.Actor == a || f.Actor == originate(a) {
match = true
break
}
}
}
}
if match && f.Text != "" {
match = false
for _, d := range h.Donks {
if d.Desc == f.Text {
match = true
}
}
}
if match {
return true
}
return false
}
func rejectnote(xonk *Honk) bool {
func rejectxonk(xonk *Honk) bool {
filts := getfilters(xonk.UserID, filtReject)
return matchfilter(xonk, filts)
for _, f := range filts {
if matchfilter(xonk, filts) {
return true
}
}
return false
}
func skipMedia(xonk *Honk) bool {
filts := getfilters(xonk.UserID, filtSkipMedia)
return matchfilter(xonk, filts)
for _, f := range filts {
if matchfilter(xonk, filts) {
return true
}
}
return false
}
// todo

Loading…
Cancel
Save