From 00c3d5dac0545133831f41ea6692aa53d8eb4cde Mon Sep 17 00:00:00 2001 From: Matthew Lemon Date: Sat, 20 Apr 2024 20:13:20 +0100 Subject: Nice refactoring The FilePreparer interface is now nicer. --- cmd/dbasik-api/return.go | 43 ++++++++++++++++++++++++++++++++++--------- 1 file changed, 34 insertions(+), 9 deletions(-) (limited to 'cmd/dbasik-api/return.go') diff --git a/cmd/dbasik-api/return.go b/cmd/dbasik-api/return.go index f172452..2fa6793 100644 --- a/cmd/dbasik-api/return.go +++ b/cmd/dbasik-api/return.go @@ -117,16 +117,41 @@ func contains(slice []string, str string) bool { } type FilePreparer interface { - Prepare(filePath string) error + Prepare() ([]string, error) } -type DirectoryFilePackage struct { +type FileSource struct { FilePath string } +type DirectoryFilePackage struct { + FileSource +} + +func PrepareFiles(fp FilePreparer) ([]string, error) { + ch := make(chan string, 100) + + go func() { + defer close(ch) + files, err := fp.Prepare() + if err != nil { + ch <- err.Error() + } + + for _, f := range files { + ch <- f + } + }() + + var files []string + for f := range ch { + files = append(files, f) + } + + return files, nil +} + func (fp *DirectoryFilePackage) Prepare() ([]string, error) { - // return a slice of the files inside the directory pointed to by fh.FilePath - // and an error if any files, err := filepath.Glob(fp.FilePath + "/*") if err != nil { return nil, err @@ -135,12 +160,10 @@ func (fp *DirectoryFilePackage) Prepare() ([]string, error) { } type ZipFilePackage struct { - FilePath string + FileSource } func (fp *ZipFilePackage) Prepare() ([]string, error) { - // return a slice of the files from inside the zip file pointed to by fh.FilePath - // and an error if any files, err := zip.OpenReader(fp.FilePath) if err != nil { return nil, err @@ -153,10 +176,12 @@ func (fp *ZipFilePackage) Prepare() ([]string, error) { return out, nil } +// NewDirectoryFilePackage creates a new DirectoryFilePackage object with the given filePath to the directory func NewDirectoryFilePackage(filePath string) *DirectoryFilePackage { - return &DirectoryFilePackage{FilePath: filePath} + return &DirectoryFilePackage{FileSource{FilePath: filePath}} } +// NewZipFilePackage creates a new ZipFilePackage object with the given filePath to the zip file func NewZipFilePackage(filePath string) *ZipFilePackage { - return &ZipFilePackage{FilePath: filePath} + return &ZipFilePackage{FileSource{FilePath: filePath}} } -- cgit v1.2.3