linstrom/storage/mediaFile.go

35 lines
1.3 KiB
Go
Raw Normal View History

2024-05-31 09:54:39 +00:00
package storage
import (
"time"
"gorm.io/gorm"
)
type MediaFile struct {
ID string `gorm:"primarykey"`
CreatedAt time.Time
UpdatedAt time.Time
DeletedAt gorm.DeletedAt `gorm:"index"`
Remote bool // whether the attachment is a remote one
Link string // url if remote attachment, identifier if local
2024-05-31 15:21:29 +00:00
Type string // What media type this is, eg image/png
2024-05-31 09:54:39 +00:00
// Whether this media has been cached locally
// Only really used for user and server icons, not attachments
2024-05-31 15:21:29 +00:00
// If true, Link will be read as file path. url otherwise
2024-05-31 09:54:39 +00:00
// Reason: Attachments would take way to much space considering that they are often only loaded a few times at most
// And caching a file for those few times would be a waste of storage
// Caching user and server icons locally however should reduce burden on remote servers by quite a bit though
LocallyCached bool
2024-08-22 17:57:53 +00:00
Sensitive bool // Whether the media is marked as sensitive. If so, hide it in the UI by default
2024-05-31 09:54:39 +00:00
}
2024-05-31 15:21:29 +00:00
// Placeholder media file. Acts as placeholder for media file fields that have not been initialised yet but need a value
var placeholderMediaFile = &MediaFile{
ID: "placeholder",
Remote: false,
Link: "placeholder", // TODO: Replace this with a file path to a staticly included image
Type: "image/png",
LocallyCached: true,
}