mirror of https://github.com/cloudreve/Cloudreve
Merge ef86b6b79a
into fe7cf5d0d8
commit
1f26dfede4
|
@ -97,6 +97,15 @@ var (
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"dav": {},
|
"dav": {},
|
||||||
|
// Allow manipulating thumbnail metadata via public PatchMetadata API
|
||||||
|
"thumb": {
|
||||||
|
// Only supported thumb metadata currently is thumb:disabled
|
||||||
|
dbfs.ThumbDisabledKey: func(ctx context.Context, m *manager, patch *fs.MetadataPatch) error {
|
||||||
|
// Presence of this key disables thumbnails; value is ignored.
|
||||||
|
// We allow both setting and removing this key.
|
||||||
|
return nil
|
||||||
|
},
|
||||||
|
},
|
||||||
customizeMetadataSuffix: {
|
customizeMetadataSuffix: {
|
||||||
iconColorMetadataKey: validateColor(false),
|
iconColorMetadataKey: validateColor(false),
|
||||||
emojiIconMetadataKey: func(ctx context.Context, m *manager, patch *fs.MetadataPatch) error {
|
emojiIconMetadataKey: func(ctx context.Context, m *manager, patch *fs.MetadataPatch) error {
|
||||||
|
|
|
@ -19,6 +19,10 @@ import (
|
||||||
|
|
||||||
const thumbTempFolder = "thumb"
|
const thumbTempFolder = "thumb"
|
||||||
|
|
||||||
|
// BuiltinSupportedExts lists file extensions supported by the built-in
|
||||||
|
// thumbnail generator. Extensions are lowercased and do not include the dot.
|
||||||
|
var BuiltinSupportedExts = []string{"jpg", "jpeg", "png", "gif"}
|
||||||
|
|
||||||
// Thumb 缩略图
|
// Thumb 缩略图
|
||||||
type Thumb struct {
|
type Thumb struct {
|
||||||
src image.Image
|
src image.Image
|
||||||
|
|
|
@ -618,12 +618,13 @@ func initMasterRouter(dep dependency.Dep) *gin.Engine {
|
||||||
controllers.ServeEntity,
|
controllers.ServeEntity,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
// 获取缩略图
|
// get thumb
|
||||||
file.GET("thumb",
|
file.GET("thumb",
|
||||||
middleware.ContextHint(),
|
middleware.ContextHint(),
|
||||||
controllers.FromQuery[explorer.FileThumbService](explorer.FileThumbParameterCtx{}),
|
controllers.FromQuery[explorer.FileThumbService](explorer.FileThumbParameterCtx{}),
|
||||||
controllers.Thumb,
|
controllers.Thumb,
|
||||||
)
|
)
|
||||||
|
// reset thumb removed; use metadata patch to re-enable thumbnails
|
||||||
// Delete files
|
// Delete files
|
||||||
file.DELETE("",
|
file.DELETE("",
|
||||||
controllers.FromJSON[explorer.DeleteFileService](explorer.DeleteFileParameterCtx{}),
|
controllers.FromJSON[explorer.DeleteFileService](explorer.DeleteFileParameterCtx{}),
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
package basic
|
package basic
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/cloudreve/Cloudreve/v4/application/dependency"
|
"sort"
|
||||||
"github.com/cloudreve/Cloudreve/v4/inventory"
|
"strings"
|
||||||
"github.com/cloudreve/Cloudreve/v4/inventory/types"
|
|
||||||
"github.com/cloudreve/Cloudreve/v4/pkg/setting"
|
"github.com/cloudreve/Cloudreve/v4/application/dependency"
|
||||||
"github.com/cloudreve/Cloudreve/v4/service/user"
|
"github.com/cloudreve/Cloudreve/v4/inventory"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/cloudreve/Cloudreve/v4/inventory/types"
|
||||||
"github.com/mojocn/base64Captcha"
|
"github.com/cloudreve/Cloudreve/v4/pkg/setting"
|
||||||
|
"github.com/cloudreve/Cloudreve/v4/pkg/thumb"
|
||||||
|
"github.com/cloudreve/Cloudreve/v4/service/user"
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"github.com/mojocn/base64Captcha"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SiteConfig 站点全局设置序列
|
// SiteConfig 站点全局设置序列
|
||||||
|
@ -47,7 +51,10 @@ type SiteConfig struct {
|
||||||
MaxBatchSize int `json:"max_batch_size,omitempty"`
|
MaxBatchSize int `json:"max_batch_size,omitempty"`
|
||||||
ThumbnailWidth int `json:"thumbnail_width,omitempty"`
|
ThumbnailWidth int `json:"thumbnail_width,omitempty"`
|
||||||
ThumbnailHeight int `json:"thumbnail_height,omitempty"`
|
ThumbnailHeight int `json:"thumbnail_height,omitempty"`
|
||||||
CustomProps []types.CustomProps `json:"custom_props,omitempty"`
|
CustomProps []types.CustomProps `json:"custom_props,omitempty"`
|
||||||
|
|
||||||
|
// Thumbnail section
|
||||||
|
ThumbExts []string `json:"thumb_exts,omitempty"`
|
||||||
|
|
||||||
// App settings
|
// App settings
|
||||||
AppPromotion bool `json:"app_promotion,omitempty"`
|
AppPromotion bool `json:"app_promotion,omitempty"`
|
||||||
|
@ -71,10 +78,10 @@ type (
|
||||||
)
|
)
|
||||||
|
|
||||||
func (s *GetSettingService) GetSiteConfig(c *gin.Context) (*SiteConfig, error) {
|
func (s *GetSettingService) GetSiteConfig(c *gin.Context) (*SiteConfig, error) {
|
||||||
dep := dependency.FromContext(c)
|
dep := dependency.FromContext(c)
|
||||||
settings := dep.SettingProvider()
|
settings := dep.SettingProvider()
|
||||||
|
|
||||||
switch s.Section {
|
switch s.Section {
|
||||||
case "login":
|
case "login":
|
||||||
legalDocs := settings.LegalDocuments(c)
|
legalDocs := settings.LegalDocuments(c)
|
||||||
return &SiteConfig{
|
return &SiteConfig{
|
||||||
|
@ -115,12 +122,53 @@ func (s *GetSettingService) GetSiteConfig(c *gin.Context) (*SiteConfig, error) {
|
||||||
}, nil
|
}, nil
|
||||||
case "app":
|
case "app":
|
||||||
appSetting := settings.AppSetting(c)
|
appSetting := settings.AppSetting(c)
|
||||||
return &SiteConfig{
|
return &SiteConfig{
|
||||||
AppPromotion: appSetting.Promotion,
|
AppPromotion: appSetting.Promotion,
|
||||||
}, nil
|
}, nil
|
||||||
default:
|
case "thumb":
|
||||||
break
|
// Return supported thumbnail extensions from enabled generators.
|
||||||
}
|
exts := map[string]bool{}
|
||||||
|
if settings.BuiltinThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range thumb.BuiltinSupportedExts {
|
||||||
|
exts[e] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if settings.FFMpegThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range settings.FFMpegThumbExts(c) {
|
||||||
|
exts[strings.ToLower(e)] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if settings.VipsThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range settings.VipsThumbExts(c) {
|
||||||
|
exts[strings.ToLower(e)] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if settings.LibreOfficeThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range settings.LibreOfficeThumbExts(c) {
|
||||||
|
exts[strings.ToLower(e)] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if settings.MusicCoverThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range settings.MusicCoverThumbExts(c) {
|
||||||
|
exts[strings.ToLower(e)] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if settings.LibRawThumbGeneratorEnabled(c) {
|
||||||
|
for _, e := range settings.LibRawThumbExts(c) {
|
||||||
|
exts[strings.ToLower(e)] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// map -> sorted slice
|
||||||
|
result := make([]string, 0, len(exts))
|
||||||
|
for e := range exts {
|
||||||
|
result = append(result, e)
|
||||||
|
}
|
||||||
|
sort.Strings(result)
|
||||||
|
return &SiteConfig{ThumbExts: result}, nil
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
u := inventory.UserFromContext(c)
|
u := inventory.UserFromContext(c)
|
||||||
siteBasic := settings.SiteBasic(c)
|
siteBasic := settings.SiteBasic(c)
|
||||||
|
|
Loading…
Reference in New Issue