提交 52c2422b 编写于 作者: H HFO4

Feat: list oss files

上级 1afc750d
...@@ -18,6 +18,7 @@ import ( ...@@ -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 { ...@@ -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 {
if recursive { delimiter = "/"
options = append(options, oss.Delimiter("/"))
} }
listRes, err := handler.bucket.ListObjects(options...) marker := ""
if err != nil { var (
return nil, err objects []oss.ObjectProperties
commons []string
)
for {
subRes, err := handler.bucket.ListObjects(oss.Marker(marker), oss.Prefix(base),
oss.MaxKeys(1000), oss.Delimiter(delimiter))
if err != nil {
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(),
return res, err })
}
// 处理文件
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, nil
} }
// Get 获取文件 // Get 获取文件
......
...@@ -146,13 +146,18 @@ func (job *ImportTask) Do() { ...@@ -146,13 +146,18 @@ func (job *ImportTask) Do() {
if parent, ok := pathCache[virtualPath]; ok { if parent, ok := pathCache[virtualPath]; ok {
parentFolder = parent parentFolder = parent
} else { } else {
folder, err := fs.CreateDirectory(context.Background(), virtualPath) exist, folder := fs.IsPathExist(virtualPath)
if err != nil { if exist {
util.Log().Warning("导入任务无法创建用户目录[%s], %s", parentFolder = folder
virtualPath, err) } else {
continue folder, err := fs.CreateDirectory(context.Background(), virtualPath)
if err != nil {
util.Log().Warning("导入任务无法创建用户目录[%s], %s",
virtualPath, err)
continue
}
parentFolder = folder
} }
parentFolder = folder
} }
// 插入文件记录 // 插入文件记录
......
...@@ -142,6 +142,8 @@ func TestImportTask_Do(t *testing.T) { ...@@ -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"}))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册