Modify: remove PositionAbsolute scheme in folder
This commit is contained in:
parent
8b3fd8ec66
commit
b3f13c56bc
5 changed files with 20 additions and 20 deletions
|
@ -9,11 +9,11 @@ import (
|
|||
type Folder struct {
|
||||
// 表字段
|
||||
gorm.Model
|
||||
Name string
|
||||
ParentID uint `gorm:"index:parent_id"`
|
||||
Position string `gorm:"size:65536"`
|
||||
OwnerID uint `gorm:"index:owner_id"`
|
||||
PositionAbsolute string `gorm:"size:65536"`
|
||||
Name string
|
||||
ParentID uint `gorm:"index:parent_id"`
|
||||
Position string `gorm:"size:65536"`
|
||||
OwnerID uint `gorm:"index:owner_id"`
|
||||
//PositionAbsolute string `gorm:"size:65536"`
|
||||
}
|
||||
|
||||
// Create 创建目录
|
||||
|
|
|
@ -140,10 +140,9 @@ func (user *User) BeforeSave() (err error) {
|
|||
func (user *User) AfterCreate(tx *gorm.DB) (err error) {
|
||||
// 创建用户的默认根目录
|
||||
defaultFolder := &Folder{
|
||||
Name: "根目录",
|
||||
Position: ".",
|
||||
OwnerID: user.ID,
|
||||
PositionAbsolute: "/",
|
||||
Name: "根目录",
|
||||
Position: ".",
|
||||
OwnerID: user.ID,
|
||||
}
|
||||
tx.Create(defaultFolder)
|
||||
return err
|
||||
|
|
|
@ -42,7 +42,7 @@ func (fs *FileSystem) AddFile(ctx context.Context, parent *model.Folder) (*model
|
|||
Size: file.GetSize(),
|
||||
FolderID: parent.ID,
|
||||
PolicyID: fs.User.Policy.ID,
|
||||
Dir: parent.PositionAbsolute,
|
||||
//Dir: parent.PositionAbsolute,
|
||||
}
|
||||
_, err := newFile.Create()
|
||||
|
||||
|
|
|
@ -22,7 +22,7 @@ func TestFileSystem_AddFile(t *testing.T) {
|
|||
Model: gorm.Model{
|
||||
ID: 1,
|
||||
},
|
||||
PositionAbsolute: "/我的文件",
|
||||
Position: "/",
|
||||
}
|
||||
fs := FileSystem{
|
||||
User: &model.User{
|
||||
|
|
|
@ -136,9 +136,9 @@ func (fs *FileSystem) ListDeleteFiles(ctx context.Context, paths []string) error
|
|||
// pathProcessor为最终对象路径的处理钩子。
|
||||
// 有些情况下(如在分享页面列对象)时,
|
||||
// 路径需要截取掉被分享目录路径之前的部分。
|
||||
func (fs *FileSystem) List(ctx context.Context, path string, pathProcessor func(string) string) ([]Object, error) {
|
||||
func (fs *FileSystem) List(ctx context.Context, dirPath string, pathProcessor func(string) string) ([]Object, error) {
|
||||
// 获取父目录
|
||||
isExist, folder := fs.IsPathExist(path)
|
||||
isExist, folder := fs.IsPathExist(dirPath)
|
||||
// 不存在时返回空的结果
|
||||
if !isExist {
|
||||
return nil, nil
|
||||
|
@ -177,11 +177,13 @@ func (fs *FileSystem) List(ctx context.Context, path string, pathProcessor func(
|
|||
}
|
||||
|
||||
for _, file := range childFiles {
|
||||
filePath := path.Join(folder.Position, folder.Name, file.Name)
|
||||
|
||||
if processedPath == "" {
|
||||
if pathProcessor != nil {
|
||||
processedPath = pathProcessor(file.Dir)
|
||||
processedPath = pathProcessor(filePath)
|
||||
} else {
|
||||
processedPath = file.Dir
|
||||
processedPath = filePath
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -230,11 +232,10 @@ func (fs *FileSystem) CreateDirectory(ctx context.Context, fullPath string) erro
|
|||
|
||||
// 创建目录
|
||||
newFolder := model.Folder{
|
||||
Name: dir,
|
||||
ParentID: parent.ID,
|
||||
Position: base,
|
||||
OwnerID: fs.User.ID,
|
||||
PositionAbsolute: fullPath,
|
||||
Name: dir,
|
||||
ParentID: parent.ID,
|
||||
Position: base,
|
||||
OwnerID: fs.User.ID,
|
||||
}
|
||||
_, err := newFolder.Create()
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue