2020-10-15 00:07:38 +03:00
|
|
|
package ffmpeg
|
|
|
|
|
|
|
|
import (
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"sort"
|
|
|
|
|
|
|
|
"github.com/owncast/owncast/config"
|
|
|
|
)
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
// CleanupOldContent will delete old files from the private dir that are no longer being referenced
|
2020-10-15 00:07:38 +03:00
|
|
|
// in the stream.
|
2020-10-16 03:50:17 +03:00
|
|
|
func CleanupOldContent(baseDirectory string) {
|
2020-10-15 00:07:38 +03:00
|
|
|
// Determine how many files we should keep on disk
|
|
|
|
maxNumber := config.Config.GetMaxNumberOfReferencedSegmentsInPlaylist()
|
|
|
|
buffer := 10
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
files, err := getAllFilesRecursive(baseDirectory)
|
2020-10-15 00:07:38 +03:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
// Delete old private HLS files on disk
|
|
|
|
for directory := range files {
|
|
|
|
files := files[directory]
|
|
|
|
if len(files) < maxNumber+buffer {
|
|
|
|
continue
|
|
|
|
}
|
2020-10-15 00:07:38 +03:00
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
filesToDelete := files[maxNumber+buffer:]
|
|
|
|
log.Traceln("Deleting", len(filesToDelete), "old files from", baseDirectory, "for video variant", directory)
|
|
|
|
|
|
|
|
for _, file := range filesToDelete {
|
|
|
|
fileToDelete := filepath.Join(baseDirectory, directory, file.Name())
|
|
|
|
err := os.Remove(fileToDelete)
|
|
|
|
if err != nil {
|
|
|
|
log.Errorln(err)
|
|
|
|
}
|
|
|
|
}
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
func getAllFilesRecursive(baseDirectory string) (map[string][]os.FileInfo, error) {
|
|
|
|
var files = make(map[string][]os.FileInfo)
|
2020-10-15 00:07:38 +03:00
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
var directory string
|
|
|
|
filepath.Walk(baseDirectory, func(path string, info os.FileInfo, err error) error {
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf(err.Error())
|
|
|
|
return err
|
|
|
|
}
|
2020-10-15 00:07:38 +03:00
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
if info.IsDir() {
|
|
|
|
directory = info.Name()
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
if filepath.Ext(info.Name()) == ".ts" {
|
|
|
|
files[directory] = append(files[directory], info)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2020-10-15 00:07:38 +03:00
|
|
|
})
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
// Sort by date so we can delete old files
|
|
|
|
for directory := range files {
|
|
|
|
sort.Slice(files[directory], func(i, j int) bool {
|
|
|
|
return files[directory][i].ModTime().UnixNano() > files[directory][j].ModTime().UnixNano()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return files, nil
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|