mirror of
https://github.com/OpenListTeam/OpenList.git
synced 2025-09-19 12:16:24 +08:00

提供一种类似大多数网盘的文件分享操作,这种分享方式可以通过强制 Web 代理隐藏文件源路径,可以设置分享码、最大访问数和过期时间,并且不需要启用 guest 用户。 在全局设置中可以调整: - 是否强制 Web 代理 - 是否允许预览 - 是否允许预览压缩文件 - 分享文件后,点击“复制链接”按钮复制的内容 前端部分:OpenListTeam/OpenList-Frontend#156 文档部分:OpenListTeam/OpenList-Docs#130 Close #183 Close #526 Close #860 Close #892 Close #1079 * feat(share): support more secure file sharing * feat(share): add archive preview * fix(share): fix some bugs * feat(openlist_share): add openlist share driver * fix(share): lack unwrap when get virtual path * fix: use unwrapPath instead of path for virtual file name comparison * fix(share): change request method of /api/share/list from GET to Any * fix(share): path traversal vulnerability in sharing path check * 修复分享alias驱动的文件 没开代理时无法获取URL * fix(sharing): update error message for sharing root link extraction --------- Co-authored-by: Suyunmeng <69945917+Suyunmeng@users.noreply.github.com> Co-authored-by: j2rong4cn <j2rong@qq.com>
84 lines
2.4 KiB
Go
84 lines
2.4 KiB
Go
package sharing
|
|
|
|
import (
|
|
"context"
|
|
stdpath "path"
|
|
|
|
"github.com/OpenListTeam/OpenList/v4/internal/errs"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/model"
|
|
"github.com/OpenListTeam/OpenList/v4/internal/op"
|
|
"github.com/OpenListTeam/OpenList/v4/pkg/utils"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
func list(ctx context.Context, sid, path string, args model.SharingListArgs) (*model.Sharing, []model.Obj, error) {
|
|
sharing, err := op.GetSharingById(sid, args.Refresh)
|
|
if err != nil {
|
|
return nil, nil, errors.WithStack(errs.SharingNotFound)
|
|
}
|
|
if !sharing.Valid() {
|
|
return sharing, nil, errors.WithStack(errs.InvalidSharing)
|
|
}
|
|
if !sharing.Verify(args.Pwd) {
|
|
return sharing, nil, errors.WithStack(errs.WrongShareCode)
|
|
}
|
|
path = utils.FixAndCleanPath(path)
|
|
if len(sharing.Files) == 1 || path != "/" {
|
|
unwrapPath, err := op.GetSharingUnwrapPath(sharing, path)
|
|
if err != nil {
|
|
return nil, nil, errors.WithMessage(err, "failed get sharing unwrap path")
|
|
}
|
|
virtualFiles := op.GetStorageVirtualFilesByPath(unwrapPath)
|
|
storage, actualPath, err := op.GetStorageAndActualPath(unwrapPath)
|
|
if err != nil && len(virtualFiles) == 0 {
|
|
return nil, nil, errors.WithMessage(err, "failed list sharing")
|
|
}
|
|
var objs []model.Obj
|
|
if storage != nil {
|
|
objs, err = op.List(ctx, storage, actualPath, model.ListArgs{
|
|
Refresh: args.Refresh,
|
|
ReqPath: stdpath.Join(sid, path),
|
|
})
|
|
if err != nil && len(virtualFiles) == 0 {
|
|
return nil, nil, errors.WithMessage(err, "failed list sharing")
|
|
}
|
|
}
|
|
om := model.NewObjMerge()
|
|
objs = om.Merge(objs, virtualFiles...)
|
|
model.SortFiles(objs, sharing.OrderBy, sharing.OrderDirection)
|
|
model.ExtractFolder(objs, sharing.ExtractFolder)
|
|
return sharing, objs, nil
|
|
}
|
|
objs := make([]model.Obj, 0, len(sharing.Files))
|
|
for _, f := range sharing.Files {
|
|
if f != "/" {
|
|
isVf := false
|
|
virtualFiles := op.GetStorageVirtualFilesByPath(stdpath.Dir(f))
|
|
for _, vf := range virtualFiles {
|
|
if vf.GetName() == stdpath.Base(f) {
|
|
objs = append(objs, vf)
|
|
isVf = true
|
|
break
|
|
}
|
|
}
|
|
if isVf {
|
|
continue
|
|
}
|
|
} else {
|
|
continue
|
|
}
|
|
storage, actualPath, err := op.GetStorageAndActualPath(f)
|
|
if err != nil {
|
|
continue
|
|
}
|
|
obj, err := op.Get(ctx, storage, actualPath)
|
|
if err != nil {
|
|
continue
|
|
}
|
|
objs = append(objs, obj)
|
|
}
|
|
model.SortFiles(objs, sharing.OrderBy, sharing.OrderDirection)
|
|
model.ExtractFolder(objs, sharing.ExtractFolder)
|
|
return sharing, objs, nil
|
|
}
|