2024-05-17 07:59:51 +00:00
|
|
|
package models
|
|
|
|
|
2024-08-18 04:01:41 +00:00
|
|
|
import (
|
2024-12-28 17:03:22 +00:00
|
|
|
"context"
|
|
|
|
"fmt"
|
2024-08-18 04:01:41 +00:00
|
|
|
"time"
|
2024-09-11 15:55:46 +00:00
|
|
|
|
2024-12-25 15:52:00 +00:00
|
|
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
|
2024-12-28 17:03:22 +00:00
|
|
|
"github.com/eko/gocache/lib/v4/cache"
|
|
|
|
"github.com/eko/gocache/lib/v4/marshaler"
|
|
|
|
|
|
|
|
localCache "git.solsynth.dev/hypernet/paperclip/pkg/internal/cache"
|
2024-12-25 15:52:00 +00:00
|
|
|
|
2024-09-11 15:55:46 +00:00
|
|
|
"gorm.io/datatypes"
|
2024-12-28 17:03:22 +00:00
|
|
|
"gorm.io/gorm"
|
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 (
|
2024-11-06 15:01:29 +00:00
|
|
|
AttachmentDstTemporary = 0 // The destination 0 is a reserved config for pre-upload processing
|
2024-07-28 13:03:56 +00:00
|
|
|
)
|
|
|
|
|
2024-12-28 05:31:31 +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"`
|
|
|
|
|
2024-11-06 15:01:29 +00:00
|
|
|
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"`
|
2024-12-28 07:42:19 +00:00
|
|
|
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"`
|
|
|
|
|
2024-12-26 13:53:09 +00:00
|
|
|
Metadata datatypes.JSONMap `json:"metadata"` // This field is analyzer auto generated metadata
|
|
|
|
Usermeta datatypes.JSONMap `json:"usermeta"` // This field is user set metadata
|
|
|
|
|
2024-12-28 05:31:31 +00:00
|
|
|
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
|
2024-12-26 13:53:09 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
2024-12-28 05:31:31 +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"`
|
|
|
|
|
2024-07-28 16:01:51 +00:00
|
|
|
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:"-"`
|
2024-12-28 05:31:31 +00:00
|
|
|
}
|
|
|
|
|
2024-12-28 17:03:22 +00:00
|
|
|
func (v *Attachment) AfterUpdate(tx *gorm.DB) error {
|
|
|
|
cacheManager := cache.New[any](localCache.S)
|
|
|
|
marshal := marshaler.New(cacheManager)
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
_ = marshal.Delete(
|
|
|
|
ctx,
|
|
|
|
fmt.Sprintf("attachment#%s", v.Rid),
|
|
|
|
)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-12-28 05:31:31 +00:00
|
|
|
// 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
|
2024-12-28 05:31:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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,
|
2024-12-28 07:42:19 +00:00
|
|
|
Type: AttachmentTypeNormal,
|
2024-12-28 05:31:31 +00:00
|
|
|
Pool: v.Pool,
|
|
|
|
PoolID: v.PoolID,
|
|
|
|
AccountID: v.AccountID,
|
|
|
|
}
|
2024-05-17 07:59:51 +00:00
|
|
|
}
|