mirror of https://github.com/cloudreve/Cloudreve
Feat: list oss files
parent
1afc750dae
commit
52c2422be9
|
@ -18,6 +18,7 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"net/url"
|
"net/url"
|
||||||
"path"
|
"path"
|
||||||
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
@ -100,39 +101,72 @@ func (handler *Driver) InitOSSClient() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (handler Driver) List(ctx context.Context, path string, recursive bool) ([]response.Object, error) {
|
// List 列出OSS上的文件
|
||||||
|
func (handler Driver) List(ctx context.Context, base string, recursive bool) ([]response.Object, error) {
|
||||||
// 初始化客户端
|
// 初始化客户端
|
||||||
if err := handler.InitOSSClient(); err != nil {
|
if err := handler.InitOSSClient(); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// 列取文件
|
// 列取文件
|
||||||
options := []oss.Option{
|
base = strings.TrimPrefix(base, "/")
|
||||||
oss.Prefix(strings.TrimPrefix(path, "/")),
|
delimiter := ""
|
||||||
|
if !recursive {
|
||||||
|
delimiter = "/"
|
||||||
}
|
}
|
||||||
if recursive {
|
marker := ""
|
||||||
options = append(options, oss.Delimiter("/"))
|
var (
|
||||||
}
|
objects []oss.ObjectProperties
|
||||||
listRes, err := handler.bucket.ListObjects(options...)
|
commons []string
|
||||||
|
)
|
||||||
|
|
||||||
|
for {
|
||||||
|
subRes, err := handler.bucket.ListObjects(oss.Marker(marker), oss.Prefix(base),
|
||||||
|
oss.MaxKeys(1000), oss.Delimiter(delimiter))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
objects = append(objects, subRes.Objects...)
|
||||||
|
commons = append(commons, subRes.CommonPrefixes...)
|
||||||
|
marker = subRes.NextMarker
|
||||||
|
if marker == "" {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 处理列取结果
|
// 处理列取结果
|
||||||
res := make([]response.Object, len(listRes.CommonPrefixes)+len(listRes.Objects))
|
res := make([]response.Object, 0, len(objects)+len(commons))
|
||||||
// 处理目录
|
// 处理目录
|
||||||
//for _,object := range listRes.CommonPrefixes{
|
for _, object := range commons {
|
||||||
// res = append(res,response.Object{
|
rel, err := filepath.Rel(base, object)
|
||||||
// Name: "",
|
if err != nil {
|
||||||
// RelativePath: "",
|
continue
|
||||||
// Source: "",
|
}
|
||||||
// Size: 0,
|
res = append(res, response.Object{
|
||||||
// IsDir: false,
|
Name: path.Base(object),
|
||||||
// LastModify: time.Time{},
|
RelativePath: filepath.ToSlash(rel),
|
||||||
// })
|
Size: 0,
|
||||||
//}
|
IsDir: true,
|
||||||
|
LastModify: time.Now(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 处理文件
|
||||||
|
for _, object := range objects {
|
||||||
|
rel, err := filepath.Rel(base, object.Key)
|
||||||
|
if err != nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
res = append(res, response.Object{
|
||||||
|
Name: path.Base(object.Key),
|
||||||
|
Source: object.Key,
|
||||||
|
RelativePath: filepath.ToSlash(rel),
|
||||||
|
Size: uint64(object.Size),
|
||||||
|
IsDir: false,
|
||||||
|
LastModify: object.LastModified,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
return res, err
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get 获取文件
|
// Get 获取文件
|
||||||
|
|
|
@ -145,6 +145,10 @@ func (job *ImportTask) Do() {
|
||||||
parentFolder := &model.Folder{}
|
parentFolder := &model.Folder{}
|
||||||
if parent, ok := pathCache[virtualPath]; ok {
|
if parent, ok := pathCache[virtualPath]; ok {
|
||||||
parentFolder = parent
|
parentFolder = parent
|
||||||
|
} else {
|
||||||
|
exist, folder := fs.IsPathExist(virtualPath)
|
||||||
|
if exist {
|
||||||
|
parentFolder = folder
|
||||||
} else {
|
} else {
|
||||||
folder, err := fs.CreateDirectory(context.Background(), virtualPath)
|
folder, err := fs.CreateDirectory(context.Background(), virtualPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -154,6 +158,7 @@ func (job *ImportTask) Do() {
|
||||||
}
|
}
|
||||||
parentFolder = folder
|
parentFolder = folder
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 插入文件记录
|
// 插入文件记录
|
||||||
_, err := fs.AddFile(addFileCtx, parentFolder)
|
_, err := fs.AddFile(addFileCtx, parentFolder)
|
||||||
|
|
|
@ -142,6 +142,8 @@ func TestImportTask_Do(t *testing.T) {
|
||||||
mock.ExpectCommit()
|
mock.ExpectCommit()
|
||||||
// 查找父目录,但是不存在
|
// 查找父目录,但是不存在
|
||||||
mock.ExpectQuery("SELECT(.+)folders").WillReturnRows(sqlmock.NewRows([]string{"id"}))
|
mock.ExpectQuery("SELECT(.+)folders").WillReturnRows(sqlmock.NewRows([]string{"id"}))
|
||||||
|
// 仍然不存在
|
||||||
|
mock.ExpectQuery("SELECT(.+)folders").WillReturnRows(sqlmock.NewRows([]string{"id"}))
|
||||||
// 创建文件时查找父目录,仍然不存在
|
// 创建文件时查找父目录,仍然不存在
|
||||||
mock.ExpectQuery("SELECT(.+)folders").WillReturnRows(sqlmock.NewRows([]string{"id"}))
|
mock.ExpectQuery("SELECT(.+)folders").WillReturnRows(sqlmock.NewRows([]string{"id"}))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue