mirror of
https://github.com/OpenListTeam/OpenList.git
synced 2025-09-19 20:26:26 +08:00

* feat(task): add task hook,batch task
refactor(move): move use CopyTask
* Update internal/task/batch_task/refresh.go
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Signed-off-by: Seven <53081179+Seven66677731@users.noreply.github.com>
* fix: upload task allFinish judge
* Update internal/task/batch_task/refresh.go
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Signed-off-by: Seven <53081179+Seven66677731@users.noreply.github.com>
* feat: enhance concurrency safety
* 优化代码
* 解压缩
* 修复死锁
* refactor(move): move as task
* 重构,优化
* .
* 优化,修复bug
* .
* 修复bug
* feat: add task retry judge
* 代理Task.SetState函数来判断Task的生命周期
* chore: use OnSucceeded、OnFailed、OnBeforeRetry functions
* 优化
* 优化,去除重复代码
* .
* 优化
* .
* webdav
* Revert "fix(fs):After the file is copied or moved, flush the cache of the directory that was copied or moved to."
This reverts commit 5f03edd683
.
---------
Signed-off-by: Seven <53081179+Seven66677731@users.noreply.github.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: j2rong4cn <j2rong@qq.com>
85 lines
2.1 KiB
Go
85 lines
2.1 KiB
Go
package ftp
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
stdpath "path"
|
|
|
|
"github.com/OpenListTeam/OpenList/v4/internal/conf"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/errs"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/fs"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/model"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/op"
|
|
"github.com/OpenListTeam/OpenList/v4/server/common"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
func Mkdir(ctx context.Context, path string) error {
|
|
user := ctx.Value(conf.UserKey).(*model.User)
|
|
reqPath, err := user.JoinPath(path)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if !user.CanWrite() || !user.CanFTPManage() {
|
|
meta, err := op.GetNearestMeta(stdpath.Dir(reqPath))
|
|
if err != nil {
|
|
if !errors.Is(errors.Cause(err), errs.MetaNotFound) {
|
|
return err
|
|
}
|
|
}
|
|
if !common.CanWrite(meta, reqPath) {
|
|
return errs.PermissionDenied
|
|
}
|
|
}
|
|
return fs.MakeDir(ctx, reqPath)
|
|
}
|
|
|
|
func Remove(ctx context.Context, path string) error {
|
|
user := ctx.Value(conf.UserKey).(*model.User)
|
|
if !user.CanRemove() || !user.CanFTPManage() {
|
|
return errs.PermissionDenied
|
|
}
|
|
reqPath, err := user.JoinPath(path)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return fs.Remove(ctx, reqPath)
|
|
}
|
|
|
|
func Rename(ctx context.Context, oldPath, newPath string) error {
|
|
user := ctx.Value(conf.UserKey).(*model.User)
|
|
srcPath, err := user.JoinPath(oldPath)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
dstPath, err := user.JoinPath(newPath)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
srcDir, srcBase := stdpath.Split(srcPath)
|
|
dstDir, dstBase := stdpath.Split(dstPath)
|
|
if srcDir == dstDir {
|
|
if !user.CanRename() || !user.CanFTPManage() {
|
|
return errs.PermissionDenied
|
|
}
|
|
return fs.Rename(ctx, srcPath, dstBase)
|
|
} else {
|
|
if !user.CanFTPManage() || !user.CanMove() || (srcBase != dstBase && !user.CanRename()) {
|
|
return errs.PermissionDenied
|
|
}
|
|
if _, err = fs.Move(ctx, srcPath, dstDir); err != nil {
|
|
if srcBase != dstBase {
|
|
return err
|
|
}
|
|
if _, err1 := fs.Copy(ctx, srcPath, dstDir); err1 != nil {
|
|
return fmt.Errorf("failed move for %+v, and failed try copying for %+v", err, err1)
|
|
}
|
|
return nil
|
|
}
|
|
if srcBase != dstBase {
|
|
return fs.Rename(ctx, stdpath.Join(dstDir, srcBase), dstBase)
|
|
}
|
|
return nil
|
|
}
|
|
}
|