Paperclip/pkg/internal/models/attachments.go

120 lines
3.5 KiB
Go
Raw Normal View History

2024-05-17 07:59:51 +00:00
package models
2024-08-18 04:01:41 +00:00
import (
"time"
2024-09-11 15:55:46 +00:00
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
2024-09-11 15:55:46 +00:00
"gorm.io/datatypes"
2024-08-18 04:01:41 +00:00
)
2024-05-17 07:59:51 +00:00
2024-07-28 13:03:56 +00:00
const (
AttachmentDstTemporary = 0 // The destination 0 is a reserved config for pre-upload processing
2024-07-28 13:03:56 +00:00
)
const (
AttachmentTypeNormal = iota
AttachmentTypeThumbnail
AttachmentTypeCompressed
)
2024-05-17 07:59:51 +00:00
type Attachment struct {
2024-10-27 05:13:40 +00:00
cruda.BaseModel
2024-05-17 07:59:51 +00:00
2024-08-18 06:09:52 +00:00
// Random ID is for accessing (appear in URL)
Rid string `json:"rid" gorm:"uniqueIndex"`
// Unique ID is for storing (appear in local file name or object name)
Uuid string `json:"uuid"`
Size int64 `json:"size"`
Name string `json:"name"`
Alternative string `json:"alt"`
MimeType string `json:"mimetype"`
HashCode string `json:"hash"`
Destination int `json:"destination"`
RefCount int `json:"ref_count"`
Type uint `json:"type"`
2024-05-17 07:59:51 +00:00
2024-08-18 04:01:41 +00:00
CleanedAt *time.Time `json:"cleaned_at"`
Metadata datatypes.JSONMap `json:"metadata"` // This field is analyzer auto generated metadata
Usermeta datatypes.JSONMap `json:"usermeta"` // This field is user set metadata
ContentRating int `json:"content_rating"` // This field use to filter mature content or not
QualityRating int `json:"quality_rating"` // This field use to filter good content or not
IsAnalyzed bool `json:"is_analyzed"`
IsSelfRef bool `json:"is_self_ref"`
IsIndexable bool `json:"is_indexable"` // Show this attachment in the public directory api or not
2024-05-17 07:59:51 +00:00
UsedCount int `json:"used_count"`
Thumbnail *Attachment `json:"thumbnail"`
ThumbnailID *uint `json:"thumbnail_id"`
Compressed *Attachment `json:"compressed"`
CompressedID *uint `json:"compressed_id"`
Ref *Attachment `json:"ref"`
RefID *uint `json:"ref_id"`
2024-08-18 04:01:41 +00:00
Pool *AttachmentPool `json:"pool"`
PoolID *uint `json:"pool_id"`
2024-12-28 13:41:13 +00:00
Boosts []AttachmentBoost `json:"boosts"`
2024-11-02 17:53:57 +00:00
AccountID uint `json:"account_id"`
2024-12-26 14:41:11 +00:00
// Outdated fields, just for backward compatibility
2024-12-28 13:41:13 +00:00
FileChunks datatypes.JSONMap `json:"file_chunks" gorm:"-"`
IsUploaded bool `json:"is_uploaded" gorm:"-"`
IsMature bool `json:"is_mature" gorm:"-"`
}
// Data model for in progress multipart attachments
type AttachmentFragment struct {
cruda.BaseModel
// Random ID is for accessing (appear in URL)
Rid string `json:"rid" gorm:"uniqueIndex"`
// Unique ID is for storing (appear in local file name or object name)
Uuid string `json:"uuid"`
Size int64 `json:"size"`
Name string `json:"name"`
Alternative string `json:"alt"`
MimeType string `json:"mimetype"`
HashCode string `json:"hash"`
Fingerprint *string `json:"fingerprint"` // Client side generated hash, for continue uploading
FileChunks datatypes.JSONMap `json:"file_chunks"`
Metadata datatypes.JSONMap `json:"metadata"` // This field is analyzer auto generated metadata
Usermeta datatypes.JSONMap `json:"usermeta"` // This field is user set metadata
Pool *AttachmentPool `json:"pool"`
PoolID *uint `json:"pool_id"`
AccountID uint `json:"account_id"`
2024-12-28 05:56:25 +00:00
FileChunksMissing []string `json:"file_chunks_missing" gorm:"-"` // This field use to prompt client which chunks is pending upload, do not store it
}
func (v AttachmentFragment) ToAttachment() Attachment {
return Attachment{
Rid: v.Rid,
Uuid: v.Uuid,
Size: v.Size,
Name: v.Name,
Alternative: v.Alternative,
MimeType: v.MimeType,
HashCode: v.HashCode,
Metadata: v.Metadata,
Usermeta: v.Usermeta,
Destination: AttachmentDstTemporary,
Type: AttachmentTypeNormal,
Pool: v.Pool,
PoolID: v.PoolID,
AccountID: v.AccountID,
}
2024-05-17 07:59:51 +00:00
}