Include proper image cleanup
This commit is contained in:
parent
cc8693ffaf
commit
0af4a70aed
@ -6,11 +6,9 @@ import (
|
|||||||
"image"
|
"image"
|
||||||
"io"
|
"io"
|
||||||
"io/fs"
|
"io/fs"
|
||||||
"log"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/chai2010/webp"
|
"github.com/chai2010/webp"
|
||||||
"github.com/disintegration/imaging"
|
"github.com/disintegration/imaging"
|
||||||
@ -49,58 +47,67 @@ func SaveImage(src io.Reader, maxHeight, maxWidth int, path string) (string, err
|
|||||||
return filename, nil
|
return filename, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func CleanUpImages(c *Config) {
|
func CleanUpImages(c *Config, db *DB) error {
|
||||||
for {
|
if err := filepath.Walk(c.PicsDir, func(path string, info fs.FileInfo, err error) error {
|
||||||
if err := filepath.Walk(c.PicsDir, func(path string, info fs.FileInfo, err error) error {
|
if err != nil {
|
||||||
if err != nil {
|
return fmt.Errorf("error walking images filepath: %v", err)
|
||||||
return err
|
}
|
||||||
|
|
||||||
|
if !info.IsDir() {
|
||||||
|
imageName := info.Name()
|
||||||
|
imagePath := path
|
||||||
|
imageWasFound := false
|
||||||
|
|
||||||
|
if err = filepath.Walk(c.ArticleDir, func(path string, info fs.FileInfo, err error) error {
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("error walking articles filepath: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !info.IsDir() {
|
||||||
|
mdFile, err := os.Open(path)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("error opening article %v: %v", info.Name(), err)
|
||||||
|
}
|
||||||
|
defer mdFile.Close()
|
||||||
|
|
||||||
|
scanner := bufio.NewScanner(mdFile)
|
||||||
|
|
||||||
|
for scanner.Scan() {
|
||||||
|
if strings.Contains(scanner.Text(), imageName) {
|
||||||
|
imageWasFound = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return scanner.Err()
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}); err != nil {
|
||||||
|
return fmt.Errorf("error walking articles filepath: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if !info.IsDir() {
|
users, err := db.GetAllUsers(c)
|
||||||
imageName := info.Name()
|
if err != nil {
|
||||||
absImageName := path
|
return fmt.Errorf("error getting all users: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
if err = filepath.Walk(c.ArticleDir, func(path string, info fs.FileInfo, err error) error {
|
for _, user := range users {
|
||||||
if err != nil {
|
if imageName == user.ProfilePicLink {
|
||||||
return err
|
imageWasFound = true
|
||||||
}
|
|
||||||
|
|
||||||
if !info.IsDir() {
|
|
||||||
mdFile, err := os.Open(path)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer mdFile.Close()
|
|
||||||
|
|
||||||
scanner := bufio.NewScanner(mdFile)
|
|
||||||
imageWasFound := false
|
|
||||||
|
|
||||||
for scanner.Scan() {
|
|
||||||
if strings.Contains(scanner.Text(), imageName) {
|
|
||||||
imageWasFound = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if !imageWasFound {
|
|
||||||
if err = os.Remove(absImageName); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return scanner.Err()
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
if !imageWasFound {
|
||||||
}); err != nil {
|
if err = os.Remove(imagePath); err != nil {
|
||||||
log.Println(err)
|
return fmt.Errorf("error removing unused image: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
time.Sleep(time.Hour)
|
return nil
|
||||||
|
}); err != nil {
|
||||||
|
return fmt.Errorf("error cleaning up: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -846,6 +846,13 @@ func DeleteArticle(c *b.Config, db *b.DB, s map[string]*Session) http.HandlerFun
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
go func(c *b.Config, db *b.DB) {
|
||||||
|
if err = b.CleanUpImages(c, db); err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
}
|
||||||
|
}(c, db)
|
||||||
|
|
||||||
feed, err := b.GenerateAtomFeed(c, db)
|
feed, err := b.GenerateAtomFeed(c, db)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
|
10
cmd/main.go
10
cmd/main.go
@ -4,6 +4,7 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
|
|
||||||
b "streifling.com/jason/cpolis/cmd/backend"
|
b "streifling.com/jason/cpolis/cmd/backend"
|
||||||
c "streifling.com/jason/cpolis/cmd/calls"
|
c "streifling.com/jason/cpolis/cmd/calls"
|
||||||
@ -32,7 +33,14 @@ func main() {
|
|||||||
sessions, sessionExpiryChan := f.StartSessions()
|
sessions, sessionExpiryChan := f.StartSessions()
|
||||||
defer close(sessionExpiryChan)
|
defer close(sessionExpiryChan)
|
||||||
|
|
||||||
// go b.CleanUpImages(config)
|
go func(c *b.Config, db *b.DB) {
|
||||||
|
for {
|
||||||
|
if err = b.CleanUpImages(c, db); err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
}
|
||||||
|
time.Sleep(time.Hour * 24)
|
||||||
|
}
|
||||||
|
}(config, db)
|
||||||
|
|
||||||
mux := http.NewServeMux()
|
mux := http.NewServeMux()
|
||||||
mux.Handle("/web/static/", http.StripPrefix("/web/static/",
|
mux.Handle("/web/static/", http.StripPrefix("/web/static/",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user