photoprism/internal/query/file_shares.go
Michael Mayer e3bb8b19dd Routing: Prefix frontend UI routes with /library #840 #2466
Also improves migrations and updates the db schema docs.

Signed-off-by: Michael Mayer <michael@photoprism.app>
2022-10-15 21:54:11 +02:00

58 lines
1.2 KiB
Go

package query
import (
"time"
"github.com/photoprism/photoprism/internal/entity"
)
// FileShares returns up to 100 file shares for a given account id and status.
func FileShares(accountId uint, status string) (result []entity.FileShare, err error) {
s := Db().Where(&entity.FileShare{})
if accountId > 0 {
s = s.Where("service_id = ?", accountId)
}
if status != "" {
s = s.Where("status = ?", status)
}
s = s.Order("created_at ASC")
s = s.Limit(100).Offset(0)
s = s.Preload("File")
if err := s.Find(&result).Error; err != nil {
return result, err
}
return result, nil
}
// ExpiredFileShares returns up to 100 expired file shares for a given account.
func ExpiredFileShares(account entity.Service) (result []entity.FileShare, err error) {
if account.ShareExpires <= 0 {
return result, nil
}
s := Db().Where(&entity.FileShare{})
exp := time.Now().Add(time.Duration(-1*account.ShareExpires) * time.Second)
s = s.Where("service_id = ?", account.ID)
s = s.Where("status = ?", entity.FileShareShared)
s = s.Where("updated_at < ?", exp)
s = s.Order("updated_at ASC")
s = s.Limit(100).Offset(0)
s = s.Preload("File")
if err := s.Find(&result).Error; err != nil {
return result, err
}
return result, nil
}