speed up filters with another layer of cache map

This commit is contained in:
Ted Unangst 2019-12-23 05:49:51 -05:00
parent a621031071
commit 9cbb67bee8
2 changed files with 65 additions and 19 deletions

80
hfcs.go
View file

@ -67,11 +67,12 @@ func (ft filtType) String() string {
type afiltermap map[filtType][]*Filter
var filtInvalidator cache.Invalidator
var filtcache *cache.Cache
func init() {
// resolve init loop
filtcache = cache.New(cache.Options{Filler: filtcachefiller})
filtcache = cache.New(cache.Options{Filler: filtcachefiller, Invalidator: &filtInvalidator})
}
func filtcachefiller(userid int64) (afiltermap, bool) {
@ -157,7 +158,7 @@ func filtcachefiller(userid int64) (afiltermap, bool) {
func filtcacheclear(userid int64, dur time.Duration) {
time.Sleep(dur + time.Second)
filtcache.Clear(userid)
filtInvalidator.Clear(userid)
}
func getfilters(userid int64, scope filtType) []*Filter {
@ -169,19 +170,44 @@ func getfilters(userid int64, scope filtType) []*Filter {
return nil
}
type arejectmap map[string][]*Filter
var rejectAnyKey = "..."
var rejectcache = cache.New(cache.Options{Filler: func(userid int64) (arejectmap, bool) {
m := make(arejectmap)
filts := getfilters(userid, filtReject)
for _, f := range filts {
if f.Text != "" {
key := rejectAnyKey
m[key] = append(m[key], f)
continue
}
if f.IsAnnounce && f.AnnounceOf != "" {
key := f.AnnounceOf
m[key] = append(m[key], f)
}
if f.Actor != "" {
key := f.Actor
m[key] = append(m[key], f)
}
}
return m, true
}, Invalidator: &filtInvalidator})
func rejectfilters(userid int64, name string) []*Filter {
var m arejectmap
rejectcache.Get(userid, &m)
return m[name]
}
func rejectorigin(userid int64, origin string, isannounce bool) bool {
if o := originate(origin); o != "" {
origin = o
}
filts := getfilters(userid, filtReject)
filts := rejectfilters(userid, origin)
for _, f := range filts {
if f.Text != "" {
continue
}
if f.IsAnnounce {
if !isannounce {
continue
}
if isannounce && f.IsAnnounce {
if f.AnnounceOf == origin {
log.Printf("rejecting announce: %s", origin)
return true
@ -196,13 +222,26 @@ func rejectorigin(userid int64, origin string, isannounce bool) bool {
}
func rejectactor(userid int64, actor string) bool {
origin := originate(actor)
filts := getfilters(userid, filtReject)
filts := rejectfilters(userid, actor)
for _, f := range filts {
if f.IsAnnounce || f.Text != "" {
if f.IsAnnounce {
continue
}
if f.Actor == actor || (origin != "" && f.Actor == origin) {
if f.Actor == actor {
log.Printf("rejecting actor: %s", actor)
return true
}
}
origin := originate(actor)
if origin == "" {
return false
}
filts = rejectfilters(userid, origin)
for _, f := range filts {
if f.IsAnnounce {
continue
}
if f.Actor == origin {
log.Printf("rejecting actor: %s", actor)
return true
}
@ -287,10 +326,17 @@ func matchfilterX(h *Honk, f *Filter) string {
}
func rejectxonk(xonk *Honk) bool {
filts := getfilters(xonk.UserID, filtReject)
var m arejectmap
rejectcache.Get(xonk.UserID, &m)
filts := m[rejectAnyKey]
filts = append(filts, m[xonk.Honker]...)
filts = append(filts, m[xonk.Oonker]...)
for _, a := range xonk.Audience {
filts = append(filts, m[a]...)
}
for _, f := range filts {
if matchfilter(xonk, f) {
log.Printf("rejecting %s because %s", xonk.XID, f.Actor)
if cause := matchfilterX(xonk, f); cause != "" {
log.Printf("rejecting %s because %s", xonk.XID, cause)
return true
}
}

4
web.go
View file

@ -1874,7 +1874,7 @@ func savehfcs(w http.ResponseWriter, r *http.Request) {
if err != nil {
log.Printf("error deleting filter: %s", err)
}
filtcache.Clear(userinfo.UserID)
filtInvalidator.Clear(userinfo.UserID)
http.Redirect(w, r, "/hfcs", http.StatusSeeOther)
return
}
@ -1912,7 +1912,7 @@ func savehfcs(w http.ResponseWriter, r *http.Request) {
log.Printf("error saving filter: %s", err)
}
filtcache.Clear(userinfo.UserID)
filtInvalidator.Clear(userinfo.UserID)
http.Redirect(w, r, "/hfcs", http.StatusSeeOther)
}