GoBlog/persistentCache.go

39 lines
1.0 KiB
Go

package main
import (
"database/sql"
"time"
"golang.org/x/sync/singleflight"
)
func cachePersistently(key string, data []byte) error {
date, _ := toLocal(time.Now().String())
_, err := appDb.exec("insert or replace into persistent_cache(key, data, date) values(@key, @data, @date)", sql.Named("key", key), sql.Named("data", data), sql.Named("date", date))
return err
}
var persistentCacheGroup singleflight.Group
func retrievePersistentCache(key string) (data []byte, err error) {
d, err, _ := persistentCacheGroup.Do(key, func() (interface{}, error) {
if row, err := appDb.queryRow("select data from persistent_cache where key = @key", sql.Named("key", key)); err == sql.ErrNoRows {
return nil, nil
} else if err != nil {
return nil, err
} else {
err = row.Scan(&data)
return data, err
}
})
if err != nil {
return nil, err
}
return d.([]byte), nil
}
func clearPersistentCache(pattern string) error {
_, err := appDb.exec("delete from persistent_cache where key like @pattern", sql.Named("pattern", pattern))
return err
}