1
Fork 0
photoview/api/scanner/cleanup_media.go

121 lines
3.1 KiB
Go
Raw Normal View History

package scanner
import (
"os"
"path"
"strconv"
2020-12-17 22:51:43 +01:00
"github.com/photoview/photoview/api/graphql/models"
2021-02-15 17:35:28 +01:00
"github.com/photoview/photoview/api/utils"
"github.com/pkg/errors"
"gorm.io/gorm"
)
func CleanupMedia(db *gorm.DB, albumId int, albumMedia []*models.Media) []error {
albumMediaIds := make([]int, len(albumMedia))
2020-11-23 20:43:00 +01:00
for i, media := range albumMedia {
albumMediaIds[i] = media.ID
}
2020-11-23 20:43:00 +01:00
// Will get from database
var mediaList []models.Media
2020-11-30 21:29:49 +01:00
query := db.Where("album_id = ?", albumId)
// Select media from database that was not found on hard disk
if len(albumMedia) > 0 {
query.Where("NOT id IN (?)", albumMediaIds)
}
2020-11-23 20:43:00 +01:00
2020-11-30 21:29:49 +01:00
if err := query.Find(&mediaList).Error; err != nil {
return []error{errors.Wrap(err, "get media files to be deleted from database")}
}
deleteErrors := make([]error, 0)
mediaIDs := make([]int, 0)
2020-11-23 20:43:00 +01:00
for _, media := range mediaList {
mediaIDs = append(mediaIDs, media.ID)
2021-02-15 17:35:28 +01:00
cachePath := path.Join(utils.MediaCachePath(), strconv.Itoa(int(albumId)), strconv.Itoa(int(media.ID)))
2020-11-23 20:43:00 +01:00
err := os.RemoveAll(cachePath)
if err != nil {
2020-11-23 20:43:00 +01:00
deleteErrors = append(deleteErrors, errors.Wrapf(err, "delete unused cache folder (%s)", cachePath))
}
2020-11-23 20:43:00 +01:00
}
2020-11-30 21:29:49 +01:00
if len(mediaIDs) > 0 {
2021-02-04 22:06:49 +01:00
if err := db.Delete(models.Media{}, mediaIDs).Error; err != nil {
2020-11-30 21:29:49 +01:00
deleteErrors = append(deleteErrors, errors.Wrap(err, "delete old media from database"))
}
}
return deleteErrors
}
2021-01-24 21:30:57 +01:00
// Find and delete old albums in the database and cache that does not exist on the filesystem anymore.
func deleteOldUserAlbums(db *gorm.DB, scannedAlbums []*models.Album, user *models.User) []error {
if len(scannedAlbums) == 0 {
return nil
}
2020-12-22 01:14:43 +01:00
scannedAlbumIDs := make([]interface{}, len(scannedAlbums))
for i, album := range scannedAlbums {
2020-12-22 01:14:43 +01:00
scannedAlbumIDs[i] = album.ID
}
2021-01-24 21:30:57 +01:00
// Old albums to be deleted
var deleteAlbums []models.Album
2020-12-22 01:14:43 +01:00
2021-01-24 21:30:57 +01:00
// Find old albums in database
2020-12-22 01:14:43 +01:00
query := db.
2021-01-24 21:30:57 +01:00
Select("albums.*").
Table("user_albums").
Joins("JOIN albums ON user_albums.album_id = albums.id").
Where("user_id = ?", user.ID).
// Where("album_id IN (?)", userAlbumIDs).
Where("album_id NOT IN (?)", scannedAlbumIDs)
if err := query.Find(&deleteAlbums).Error; err != nil {
return []error{errors.Wrap(err, "get albums to be deleted from database")}
}
2021-01-24 21:30:57 +01:00
if len(deleteAlbums) == 0 {
return []error{}
}
deleteErrors := make([]error, 0)
2021-01-24 21:30:57 +01:00
// Delete old albums from cache
deleteAlbumIDs := make([]int, len(deleteAlbums))
for i, album := range deleteAlbums {
2020-12-22 01:14:43 +01:00
deleteAlbumIDs[i] = album.ID
2021-02-15 17:35:28 +01:00
cachePath := path.Join(utils.MediaCachePath(), strconv.Itoa(int(album.ID)))
err := os.RemoveAll(cachePath)
if err != nil {
deleteErrors = append(deleteErrors, errors.Wrapf(err, "delete unused cache folder (%s)", cachePath))
}
}
2021-01-24 21:30:57 +01:00
// Delete old albums from database
err := db.Transaction(func(tx *gorm.DB) error {
if err := tx.Model(&user).Association("Albums").Delete(deleteAlbums); err != nil {
return err
}
if err := tx.Where("id IN ?", deleteAlbumIDs).Delete(models.Album{}).Error; err != nil {
return err
}
return nil
})
if err != nil {
2020-11-23 20:43:00 +01:00
ScannerError("Could not delete old albums from database:\n%s\n", err)
2021-01-24 21:30:57 +01:00
deleteErrors = append(deleteErrors, err)
}
return deleteErrors
}