1
0
Fork 0
mirror of https://github.com/Eggbertx/gochan.git synced 2025-08-20 01:06:24 -07:00
gochan/pkg/posting/tmpcleaner.go
2023-04-14 13:32:17 -07:00

61 lines
1.5 KiB
Go

package posting
import (
"os"
"path"
"time"
"github.com/gochan-org/gochan/pkg/config"
"github.com/gochan-org/gochan/pkg/gcsql"
"github.com/gochan-org/gochan/pkg/gcutil"
)
func tempCleaner() {
ticker := time.Tick(time.Minute * 5)
for range ticker {
for p := range gcsql.TempPosts {
post := &gcsql.TempPosts[p]
if !time.Now().After(post.CreatedOn.Add(time.Minute * 5)) {
continue
}
// temporary post is >= 5 minutes, time to prune it
gcsql.TempPosts[p] = gcsql.TempPosts[len(gcsql.TempPosts)-1]
gcsql.TempPosts = gcsql.TempPosts[:len(gcsql.TempPosts)-1]
upload, err := post.GetUpload()
if err != nil {
continue
}
if upload.OriginalFilename == "" {
continue
}
board, err := post.GetBoard()
if err != nil {
continue
}
systemCritical := config.GetSystemCriticalConfig()
fileSrc := path.Join(systemCritical.DocumentRoot, board.Dir, "src", upload.OriginalFilename)
if err = os.Remove(fileSrc); err != nil {
gcutil.LogError(err).
Str("subject", "tempUpload").
Str("filePath", fileSrc).Send()
}
thumbSrc := upload.ThumbnailPath("thread")
if err = os.Remove(thumbSrc); err != nil {
gcutil.LogError(err).
Str("subject", "tempUpload").
Str("filePath", thumbSrc).Send()
}
if post.IsTopPost {
catalogSrc := upload.ThumbnailPath("catalog")
if err = os.Remove(catalogSrc); err != nil {
gcutil.LogError(err).
Str("subject", "tempUpload").
Str("filePath", catalogSrc).Send()
}
}
}
}
}