Skip to content

Commit

Permalink
feature: 增加上传多文件时的文件过滤
Browse files Browse the repository at this point in the history
例如上传 png 文件
```bash
upx cp ./tmp/*.png --remote /tmp
```
  • Loading branch information
arrebole committed Mar 29, 2023
1 parent d95719d commit 1d8ceb3
Show file tree
Hide file tree
Showing 3 changed files with 148 additions and 2 deletions.
32 changes: 31 additions & 1 deletion commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -306,16 +306,46 @@ func NewPutCommand() cli.Command {
InitAndCheck(LOGIN, CHECK, c)
localPath := c.Args().First()
upPath := "./"

if c.NArg() > 2 {
fmt.Println("Use the cp command instead of the put command for multiple file uploads")
os.Exit(0)
}

if c.NArg() > 1 {
upPath = c.Args().Get(1)
}

session.Put(localPath, upPath, c.Int("w"))
session.Put(
localPath,
upPath,
c.Int("w"),
)
return nil
},
Flags: []cli.Flag{
cli.IntFlag{Name: "w", Usage: "max concurrent threads", Value: 5},
},
}
}

func NewCopyCommand() cli.Command {
return cli.Command{
Name: "cp",
Usage: "copy multiple directory or file",
Action: func(c *cli.Context) error {
InitAndCheck(LOGIN, CHECK, c)

session.Copy(
c.Args().Tail(),
c.String("r"),
c.Int("w"),
)
return nil
},
Flags: []cli.Flag{
cli.IntFlag{Name: "w", Usage: "max concurrent threads", Value: 5},
cli.StringFlag{Name: "remote", Usage: "remote path", Value: "./"},
},
}
}
Expand Down
117 changes: 116 additions & 1 deletion session.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,13 @@ type delTask struct {
isdir bool
}

type UploadedFile struct {
barId int
LocalPath string
UpPath string
LocalInfo os.FileInfo
}

var (
session *Session
)
Expand Down Expand Up @@ -521,12 +528,42 @@ func (sess *Session) putFileWithProgress(barId int, localPath, upPath string, lo
return idx, err
}

func (sess *Session) putFilesWitchProgress(localFiles []*UploadedFile, workers int) {
var wg sync.WaitGroup

tasks := make(chan *UploadedFile, workers*2)
for w := 0; w < workers; w++ {
wg.Add(1)
go func() {
defer wg.Done()
for task := range tasks {
_, err := sess.putFileWithProgress(
task.barId,
task.LocalPath,
task.UpPath,
task.LocalInfo,
)
if err != nil {
fmt.Println("putFileWithProgress error: ", err.Error())
return
}
}
}()
}

for _, f := range localFiles {
tasks <- f
}

close(tasks)
wg.Wait()
}

func (sess *Session) putDir(localPath, upPath string, workers int) {
type FileInfo struct {
fpath string
fInfo os.FileInfo
}

localFiles := make(chan *FileInfo, workers*2)
var wg sync.WaitGroup
var err error
Expand Down Expand Up @@ -563,6 +600,7 @@ func (sess *Session) putDir(localPath, upPath string, workers int) {
wg.Wait()
}

// Put 上传单文件或单目录
func (sess *Session) Put(localPath, upPath string, workers int) {
upPath = sess.AbsPath(upPath)
localInfo, err := os.Stat(localPath)
Expand Down Expand Up @@ -596,6 +634,83 @@ func (sess *Session) Put(localPath, upPath string, workers int) {
}
}

// Copy put的升级版命令
func (sess *Session) Copy(filenames []string, upPath string, workers int) {
upPath = sess.AbsPath(upPath)

// 多文件上传 upPath 只能是目录
if !strings.HasSuffix(upPath, "/") {
upPath += "/"
}

var (
files []string
dirs []string
)
for _, filename := range filenames {
localInfo, err := os.Stat(filename)
if err != nil {
PrintErrorAndExit("stat %s: %v", filename, err)
}
if localInfo.IsDir() {
dirs = append(dirs, filename)
} else {
files = append(files, filename)
}
}

// 上传目录
for _, localPath := range dirs {
exist, isDir := false, false
if upInfo, _ := sess.updriver.GetInfo(upPath); upInfo != nil {
exist = true
isDir = upInfo.IsDir
} else {
if strings.HasSuffix(upPath, "/") {
isDir = true
}
}
remotePath := upPath
if exist {
if !isDir {
PrintErrorAndExit("put: %s: Not a directory", upPath)
} else {
remotePath = path.Join(upPath, filepath.Base(localPath))
}
}
sess.putDir(localPath, remotePath, workers)
}

// 上传文件
var uploadedFile []*UploadedFile
for _, localPath := range files {
isDir := false
if upInfo, _ := sess.updriver.GetInfo(upPath); upInfo != nil {
isDir = upInfo.IsDir
} else {
if strings.HasSuffix(upPath, "/") {
isDir = true
}
}
remotePath := upPath
if isDir {
remotePath = path.Join(upPath, filepath.Base(localPath))
}

localInfo, err := os.Stat(localPath)
if err != nil {
fmt.Printf("stat %s: %v\n", localPath, err)
}
uploadedFile = append(uploadedFile, &UploadedFile{
barId: -1,
LocalPath: localPath,
UpPath: remotePath,
LocalInfo: localInfo,
})
}
sess.putFilesWitchProgress(uploadedFile, workers)
}

func (sess *Session) rm(fpath string, isAsync bool, isFolder bool) {
err := sess.updriver.Delete(&upyun.DeleteObjectConfig{
Path: fpath,
Expand Down
1 change: 1 addition & 0 deletions upx.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ func main() {
NewTreeCommand(),
NewGetCommand(),
NewPutCommand(),
NewCopyCommand(),
NewRmCommand(),
NewSyncCommand(),
NewAuthCommand(),
Expand Down

0 comments on commit 1d8ceb3

Please sign in to comment.