🎇 file delete
This commit is contained in:
parent
2b97882b42
commit
6613c8a6c1
45
server/controllers/file/delete.go
Normal file
45
server/controllers/file/delete.go
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
package file
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"github.com/Xhofe/alist/drivers/base"
|
||||||
|
"github.com/Xhofe/alist/drivers/operate"
|
||||||
|
"github.com/Xhofe/alist/server/common"
|
||||||
|
"github.com/Xhofe/alist/utils"
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
)
|
||||||
|
|
||||||
|
type DeleteFilesReq struct {
|
||||||
|
Path string `json:"path"`
|
||||||
|
Names []string `json:"names"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func DeleteFiles(c *gin.Context) {
|
||||||
|
var req DeleteFilesReq
|
||||||
|
if err := c.ShouldBind(&req); err != nil {
|
||||||
|
common.ErrorResp(c, err, 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(req.Names) == 0 {
|
||||||
|
common.ErrorResp(c, errors.New("empty file names"), 400)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
for i, name := range req.Names {
|
||||||
|
account, path_, driver, err := common.ParsePath(utils.Join(req.Path, name))
|
||||||
|
if err != nil {
|
||||||
|
common.ErrorResp(c, err, 500)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
clearCache := false
|
||||||
|
if i == len(req.Names)-1 {
|
||||||
|
clearCache = true
|
||||||
|
}
|
||||||
|
err = operate.Delete(driver, account, path_, clearCache)
|
||||||
|
if err != nil {
|
||||||
|
_ = base.DeleteCache(utils.Dir(path_), account)
|
||||||
|
common.ErrorResp(c, err, 500)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
common.SuccessResp(c)
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package controllers
|
package file
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
@ -11,7 +11,7 @@ import (
|
|||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
)
|
)
|
||||||
|
|
||||||
func UploadFile(c *gin.Context) {
|
func UploadFiles(c *gin.Context) {
|
||||||
path := c.PostForm("path")
|
path := c.PostForm("path")
|
||||||
path = utils.ParsePath(path)
|
path = utils.ParsePath(path)
|
||||||
token := c.GetHeader("Authorization")
|
token := c.GetHeader("Authorization")
|
@ -3,6 +3,7 @@ package server
|
|||||||
import (
|
import (
|
||||||
"github.com/Xhofe/alist/server/common"
|
"github.com/Xhofe/alist/server/common"
|
||||||
"github.com/Xhofe/alist/server/controllers"
|
"github.com/Xhofe/alist/server/controllers"
|
||||||
|
"github.com/Xhofe/alist/server/controllers/file"
|
||||||
"github.com/Xhofe/alist/server/middlewares"
|
"github.com/Xhofe/alist/server/middlewares"
|
||||||
"github.com/gin-contrib/cors"
|
"github.com/gin-contrib/cors"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
@ -23,7 +24,7 @@ func InitApiRouter(r *gin.Engine) {
|
|||||||
path.POST("/preview", controllers.Preview)
|
path.POST("/preview", controllers.Preview)
|
||||||
|
|
||||||
//path.POST("/link",middlewares.Auth, controllers.Link)
|
//path.POST("/link",middlewares.Auth, controllers.Link)
|
||||||
public.POST("/upload", controllers.UploadFile)
|
public.POST("/upload", file.UploadFiles)
|
||||||
|
|
||||||
public.GET("/settings", controllers.GetSettingsPublic)
|
public.GET("/settings", controllers.GetSettingsPublic)
|
||||||
}
|
}
|
||||||
@ -49,6 +50,7 @@ func InitApiRouter(r *gin.Engine) {
|
|||||||
admin.DELETE("/meta", controllers.DeleteMeta)
|
admin.DELETE("/meta", controllers.DeleteMeta)
|
||||||
|
|
||||||
admin.POST("/link", controllers.Link)
|
admin.POST("/link", controllers.Link)
|
||||||
|
admin.DELETE("/files", file.DeleteFiles)
|
||||||
}
|
}
|
||||||
WebDav(r)
|
WebDav(r)
|
||||||
Static(r)
|
Static(r)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user