mirror of
https://github.com/halejohn/Cloudreve.git
synced 2026-01-26 09:34:57 +08:00
Feat: preview shared text/doc file
This commit is contained in:
@@ -46,7 +46,7 @@ func PreviewShare(c *gin.Context) {
|
||||
defer cancel()
|
||||
|
||||
var service share.SingleFileService
|
||||
if err := c.ShouldBindUri(&service); err == nil {
|
||||
if err := c.ShouldBindQuery(&service); err == nil {
|
||||
res := service.PreviewContent(ctx, c, false)
|
||||
// 是否需要重定向
|
||||
if res.Code == -301 {
|
||||
@@ -61,3 +61,32 @@ func PreviewShare(c *gin.Context) {
|
||||
c.JSON(200, ErrorResponse(err))
|
||||
}
|
||||
}
|
||||
|
||||
// PreviewShareText 预览文本文件
|
||||
func PreviewShareText(c *gin.Context) {
|
||||
// 创建上下文
|
||||
ctx, cancel := context.WithCancel(context.Background())
|
||||
defer cancel()
|
||||
|
||||
var service share.SingleFileService
|
||||
if err := c.ShouldBindQuery(&service); err == nil {
|
||||
res := service.PreviewContent(ctx, c, true)
|
||||
// 是否有错误发生
|
||||
if res.Code != 0 {
|
||||
c.JSON(200, res)
|
||||
}
|
||||
} else {
|
||||
c.JSON(200, ErrorResponse(err))
|
||||
}
|
||||
}
|
||||
|
||||
// GetShareDocPreview 创建分享Office文档预览地址
|
||||
func GetShareDocPreview(c *gin.Context) {
|
||||
var service share.SingleFileService
|
||||
if err := c.ShouldBindQuery(&service); err == nil {
|
||||
res := service.CreateDocPreviewSession(c)
|
||||
c.JSON(200, res)
|
||||
} else {
|
||||
c.JSON(200, ErrorResponse(err))
|
||||
}
|
||||
}
|
||||
|
||||
@@ -176,6 +176,10 @@ func InitMasterRouter() *gin.Engine {
|
||||
share.POST("download/:id", controllers.GetShareDownload)
|
||||
// 预览分享文件
|
||||
share.GET("preview/:id", controllers.PreviewShare)
|
||||
// 取得Office文档预览地址
|
||||
share.GET("doc/:id", controllers.GetShareDocPreview)
|
||||
// 获取文本文件内容
|
||||
share.GET("content/:id", controllers.PreviewShareText)
|
||||
}
|
||||
|
||||
// 需要登录保护的
|
||||
|
||||
Reference in New Issue
Block a user