Browse Source

WIP

pull/1/head
Tovi Jaeschke-Rogers 4 years ago
parent
commit
a12d1b6d2e
10 changed files with 176 additions and 72 deletions
  1. +2
    -2
      Client/Filesystem/CommitFiles.go
  2. +0
    -3
      Client/Filesystem/Config.go
  3. +7
    -4
      Client/Filesystem/FileObject.go
  4. +66
    -40
      Client/Filesystem/FilesystemDiff.go
  5. +1
    -1
      Client/Filesystem/ManageFileBucket.go
  6. +57
    -12
      Client/Filesystem/PickFiles.go
  7. +2
    -1
      Client/Filesystem/Print.go
  8. +1
    -7
      Client/ProgressBar/Bar.go
  9. +35
    -2
      Client/main.go
  10. +5
    -0
      Variables/Variables.go

+ 2
- 2
Client/Filesystem/CommitFiles.go View File

@ -29,10 +29,10 @@ func CommitFiles() error {
if len(fsStatus.PickedFiles) > 0 { if len(fsStatus.PickedFiles) > 0 {
bar = ProgressBar.InitBar("Commiting...", len(fsStatus.PickedFiles)) bar = ProgressBar.InitBar("Commiting...", len(fsStatus.PickedFiles))
for _, f = range fsStatus.PickedFiles { for _, f = range fsStatus.PickedFiles {
e = AddFileToBucket(indexBucket, f)
bar.Increment() bar.Increment()
e = AddFileToBucket(indexBucket, f)
if e != nil { if e != nil {
return e
return nil
} }
} }


+ 0
- 3
Client/Filesystem/Config.go View File

@ -1,15 +1,12 @@
package Filesystem package Filesystem
import ( import (
"crypto/sha1"
"regexp" "regexp"
"PackageManager/Variables" "PackageManager/Variables"
) )
var ( var (
sha1Hash = sha1.New()
PruneRegex []*regexp.Regexp PruneRegex []*regexp.Regexp
IgnoreRegex []*regexp.Regexp IgnoreRegex []*regexp.Regexp
) )


+ 7
- 4
Client/Filesystem/FileObject.go View File

@ -2,10 +2,12 @@ package Filesystem
import ( import (
"bytes" "bytes"
"crypto/sha1"
"encoding/gob" "encoding/gob"
"encoding/hex" "encoding/hex"
"errors" "errors"
"fmt" "fmt"
"hash"
"io" "io"
"os" "os"
"path/filepath" "path/filepath"
@ -141,10 +143,11 @@ func (f FileObject) IsDifferent(fn FileObject) error {
func CreateFileObject(f string) (FileObject, error) { func CreateFileObject(f string) (FileObject, error) {
var ( var (
fo FileObject
fi os.FileInfo
file *os.File
e error
sha1Hash hash.Hash = sha1.New()
fo FileObject
fi os.FileInfo
file *os.File
e error
) )
fi, e = os.Lstat(f) fi, e = os.Lstat(f)


+ 66
- 40
Client/Filesystem/FilesystemDiff.go View File

@ -1,15 +1,18 @@
package Filesystem package Filesystem
import ( import (
"PackageManager/Client/Database"
"PackageManager/Color"
"PackageManager/Variables"
"fmt" "fmt"
"log"
"os" "os"
"path/filepath" "path/filepath"
"github.com/vbauerster/mpb"
"github.com/zenthangplus/goccm"
bolt "go.etcd.io/bbolt" bolt "go.etcd.io/bbolt"
"PackageManager/Client/Database"
"PackageManager/Client/ProgressBar"
"PackageManager/Color"
"PackageManager/Variables"
) )
type FilesystemStatus struct { type FilesystemStatus struct {
@ -66,7 +69,6 @@ func GetFilesystemLength(root string) (int, error) {
// Ignore path in Variables.PruneRegexPaths // Ignore path in Variables.PruneRegexPaths
if i.IsDir() && matchAny(p, PruneRegex) { if i.IsDir() && matchAny(p, PruneRegex) {
log.Println("Prune", p)
return filepath.SkipDir return filepath.SkipDir
} }
@ -87,6 +89,51 @@ func GetFilesystemLength(root string) (int, error) {
return fsCount, e return fsCount, e
} }
func (fsStatus *FilesystemStatus) parseFile(indexBucket, picksBucket *bolt.Bucket, p string, bar *mpb.Bar, c goccm.ConcurrencyManager) {
var (
newFileObject FileObject
knownFileObject FileObject
pick, known []byte
e error
)
defer func() {
bar.Increment()
c.Done()
}()
pick = picksBucket.Get([]byte(p))
known = indexBucket.Get([]byte(p))
if pick != nil {
fsStatus.PickedFiles = append(fsStatus.PickedFiles, p)
return
}
if known != nil {
newFileObject, e = CreateFileObject(p)
if e != nil {
return
}
knownFileObject, e = FromBytes(known)
if e != nil {
return
}
e = newFileObject.IsDifferent(knownFileObject)
if e != nil {
fsStatus.ModifiedFiles = append(fsStatus.ModifiedFiles, p)
}
return
}
fsStatus.NewFiles = append(fsStatus.NewFiles, p)
return
}
func GetFilesystemDiff(root string) (FilesystemStatus, error) { func GetFilesystemDiff(root string) (FilesystemStatus, error) {
var ( var (
fsStatus FilesystemStatus = FilesystemStatus{} fsStatus FilesystemStatus = FilesystemStatus{}
@ -96,10 +143,11 @@ func GetFilesystemDiff(root string) (FilesystemStatus, error) {
picksBucket *bolt.Bucket picksBucket *bolt.Bucket
indexBucket *bolt.Bucket indexBucket *bolt.Bucket
pick, known []byte
bar *mpb.Bar
newFileObject FileObject
knownFileObject FileObject
fsCount int
c goccm.ConcurrencyManager
e error e error
) )
@ -113,6 +161,13 @@ func GetFilesystemDiff(root string) (FilesystemStatus, error) {
root = root + "/" root = root + "/"
} }
fsCount, e = GetFilesystemLength(root)
if e != nil {
return fsStatus, e
}
bar = ProgressBar.InitBar("Scanning...", fsCount)
e = Database.FsDB.View(func(tx *bolt.Tx) error { e = Database.FsDB.View(func(tx *bolt.Tx) error {
picksBucket = tx.Bucket(Variables.FsHashPicksBucket) picksBucket = tx.Bucket(Variables.FsHashPicksBucket)
@ -122,7 +177,6 @@ func GetFilesystemDiff(root string) (FilesystemStatus, error) {
// Ignore path in Variables.PruneRegexPaths // Ignore path in Variables.PruneRegexPaths
if i.IsDir() && matchAny(p, PruneRegex) { if i.IsDir() && matchAny(p, PruneRegex) {
log.Println("Prune", p)
return filepath.SkipDir return filepath.SkipDir
} }
@ -135,37 +189,7 @@ func GetFilesystemDiff(root string) (FilesystemStatus, error) {
return nil return nil
} }
pick = picksBucket.Get([]byte(p))
known = indexBucket.Get([]byte(p))
if pick != nil {
fsStatus.PickedFiles = append(fsStatus.PickedFiles, p)
return nil
}
if known != nil {
newFileObject, e = CreateFileObject(p)
if os.IsNotExist(e) {
return nil
}
if e != nil {
return e
}
knownFileObject, e = FromBytes(known)
if e != nil {
return e
}
e = newFileObject.IsDifferent(knownFileObject)
if e != nil {
fsStatus.ModifiedFiles = append(fsStatus.ModifiedFiles, p)
}
return nil
}
fsStatus.NewFiles = append(fsStatus.NewFiles, p)
go fsStatus.parseFile(indexBucket, picksBucket, p, bar, c)
return nil return nil
}) })
@ -178,6 +202,8 @@ func GetFilesystemDiff(root string) (FilesystemStatus, error) {
return nil return nil
}) })
ProgressBar.CloseBar(bar)
return nil return nil
}) })


+ 1
- 1
Client/Filesystem/ManageFileBucket.go View File

@ -17,7 +17,7 @@ func AddFileToBucket(bucket *bolt.Bucket, filePath string) error {
return nil return nil
} }
if e != nil { if e != nil {
return e
return nil
} }
fileObjectBytes, e = fileObject.ToBytes() fileObjectBytes, e = fileObject.ToBytes()
if e != nil { if e != nil {


+ 57
- 12
Client/Filesystem/PickFiles.go View File

@ -1,20 +1,42 @@
package Filesystem package Filesystem
import ( import (
"PackageManager/Client/Database"
"PackageManager/Client/ProgressBar"
"PackageManager/Variables"
"os"
"github.com/vbauerster/mpb" "github.com/vbauerster/mpb"
bolt "go.etcd.io/bbolt" bolt "go.etcd.io/bbolt"
"PackageManager/Client/Database"
"PackageManager/Client/ProgressBar"
"PackageManager/Variables"
) )
func PickFiles(rootPath string) error {
func pickFilesSingle(rootPath string) error {
var (
indexBucket *bolt.Bucket
picksBucket *bolt.Bucket
e error
)
e = Database.FsDB.Batch(func(tx *bolt.Tx) error {
indexBucket = tx.Bucket(Variables.FsHashIndexBucket)
picksBucket = tx.Bucket(Variables.FsHashPicksBucket)
e = AddFileToBucket(picksBucket, rootPath)
if e != nil {
return e
}
return RemoveFileFromBucket(indexBucket, rootPath)
})
return e
}
func pickFilesRecursive(rootPath string) error {
var ( var (
fsStatus FilesystemStatus fsStatus FilesystemStatus
indexBucket *bolt.Bucket
picksBucket *bolt.Bucket picksBucket *bolt.Bucket
totalLen int
bar *mpb.Bar bar *mpb.Bar
totalLen int
f string f string
e error e error
) )
@ -33,34 +55,39 @@ func PickFiles(rootPath string) error {
bar = ProgressBar.InitBar("Adding...", totalLen) bar = ProgressBar.InitBar("Adding...", totalLen)
e = Database.FsDB.Batch(func(tx *bolt.Tx) error { e = Database.FsDB.Batch(func(tx *bolt.Tx) error {
indexBucket = tx.Bucket(Variables.FsHashIndexBucket)
picksBucket = tx.Bucket(Variables.FsHashPicksBucket) picksBucket = tx.Bucket(Variables.FsHashPicksBucket)
if len(fsStatus.NewFiles) > 0 { if len(fsStatus.NewFiles) > 0 {
for _, f = range fsStatus.NewFiles { for _, f = range fsStatus.NewFiles {
e = AddFileToBucket(picksBucket, f)
bar.Increment() bar.Increment()
e = AddFileToBucket(picksBucket, f)
if e != nil { if e != nil {
return e
return nil
} }
} }
} }
if len(fsStatus.ModifiedFiles) > 0 { if len(fsStatus.ModifiedFiles) > 0 {
for _, f = range fsStatus.ModifiedFiles { for _, f = range fsStatus.ModifiedFiles {
e = AddFileToBucket(picksBucket, f)
bar.Increment() bar.Increment()
e = AddFileToBucket(picksBucket, f)
if e != nil { if e != nil {
return e
return nil
} }
} }
} }
if len(fsStatus.MissingFiles) > 0 { if len(fsStatus.MissingFiles) > 0 {
for _, f = range fsStatus.NewFiles {
e = RemoveFileFromBucket(picksBucket, f)
for _, f = range fsStatus.MissingFiles {
bar.Increment() bar.Increment()
e = RemoveFileFromBucket(indexBucket, f)
if e != nil { if e != nil {
return e
return nil
}
e = RemoveFileFromBucket(picksBucket, f)
if e != nil {
return nil
} }
} }
} }
@ -73,6 +100,24 @@ func PickFiles(rootPath string) error {
return e return e
} }
func PickFiles(rootPath string) error {
var (
rootStat os.FileInfo
e error
)
rootStat, e = os.Stat(rootPath)
if e != nil {
return e
}
if !rootStat.IsDir() {
return pickFilesSingle(rootPath)
}
return pickFilesRecursive(rootPath)
}
func ResetAllPickedFiles() error { func ResetAllPickedFiles() error {
var ( var (
e error e error


+ 2
- 1
Client/Filesystem/Print.go View File

@ -1,6 +1,7 @@
package Filesystem package Filesystem
import ( import (
"PackageManager/Variables"
"fmt" "fmt"
) )
@ -16,7 +17,7 @@ func PrintFilesLength(files []string) {
} }
func PrintFilesOrLength(files []string, color func(...interface{}) string) { func PrintFilesOrLength(files []string, color func(...interface{}) string) {
if len(files) < 25 && len(files) > 0 {
if (Variables.VerboseOutput && len(files) != 0) || (len(files) < 25 && len(files) > 0) {
PrintFiles(files, color) PrintFiles(files, color)
return return
} }


+ 1
- 7
Client/ProgressBar/Bar.go View File

@ -1,15 +1,12 @@
package ProgressBar package ProgressBar
import ( import (
"sync"
"github.com/vbauerster/mpb" "github.com/vbauerster/mpb"
"github.com/vbauerster/mpb/decor" "github.com/vbauerster/mpb/decor"
) )
var ( var (
BarWG sync.WaitGroup
P = mpb.New(mpb.WithWaitGroup(&BarWG))
P = mpb.New()
) )
func InitBar(name string, total int) *mpb.Bar { func InitBar(name string, total int) *mpb.Bar {
@ -17,8 +14,6 @@ func InitBar(name string, total int) *mpb.Bar {
bar *mpb.Bar bar *mpb.Bar
) )
BarWG.Add(1)
bar = P.AddBar(int64(total), bar = P.AddBar(int64(total),
mpb.PrependDecorators( mpb.PrependDecorators(
decor.Name(name), decor.Name(name),
@ -37,5 +32,4 @@ func InitBar(name string, total int) *mpb.Bar {
func CloseBar(bar *mpb.Bar) { func CloseBar(bar *mpb.Bar) {
bar.Abort(false) bar.Abort(false)
BarWG.Done()
} }

+ 35
- 2
Client/main.go View File

@ -3,6 +3,7 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"os"
"PackageManager/Client/Database" "PackageManager/Client/Database"
"PackageManager/Client/Filesystem" "PackageManager/Client/Filesystem"
@ -11,6 +12,29 @@ import (
"PackageManager/Variables" "PackageManager/Variables"
) )
func HelpMsg() {
var helpMsg string
helpMsg = `Usage of %s:
-Af | -add-files
Add files
-Cf | -commit
Add files
-Fd | -fs-diff
Filesystem diff
-Rf | -reset
Reset added files
-V | -verbose
Verbose output
`
helpMsg = fmt.Sprintf(helpMsg, os.Args[0])
fmt.Println(helpMsg)
}
func main() { func main() {
var ( var (
getFilesystemDiffFlag bool getFilesystemDiffFlag bool
@ -22,9 +46,14 @@ func main() {
resetAddedFilesFlag bool resetAddedFilesFlag bool
resetAddedFilesFlagLong bool resetAddedFilesFlagLong bool
verboseOutputFlag bool
verboseOutputFlagLong bool
e error e error
) )
flag.Usage = HelpMsg
e = Helper.CheckRoot() e = Helper.CheckRoot()
if e != nil { if e != nil {
fmt.Println(Color.Fatal(e)) fmt.Println(Color.Fatal(e))
@ -39,6 +68,8 @@ func main() {
// TODO: Rework usage function // TODO: Rework usage function
// Initialise flags // Initialise flags
flag.BoolVar(&verboseOutputFlag, "V", false, "Verbose output")
flag.BoolVar(&verboseOutputFlagLong, "verbose", false, "Verbose output")
flag.BoolVar(&getFilesystemDiffFlag, "Fd", false, "Filesystem diff") flag.BoolVar(&getFilesystemDiffFlag, "Fd", false, "Filesystem diff")
flag.BoolVar(&getFilesystemDiffFlagLong, "fs-diff", false, "Filesystem diff") flag.BoolVar(&getFilesystemDiffFlagLong, "fs-diff", false, "Filesystem diff")
@ -46,14 +77,16 @@ func main() {
flag.BoolVar(&addFileDiffFlag, "Af", false, "Add files") flag.BoolVar(&addFileDiffFlag, "Af", false, "Add files")
flag.BoolVar(&addFileDiffFlagLong, "add-files", false, "Add files") flag.BoolVar(&addFileDiffFlagLong, "add-files", false, "Add files")
flag.BoolVar(&commitAddedFilesFlag, "Cf", false, "Add files")
flag.BoolVar(&commitAddedFilesFlagLong, "commit", false, "Add files")
flag.BoolVar(&commitAddedFilesFlag, "Cf", false, "Commit files")
flag.BoolVar(&commitAddedFilesFlagLong, "commit", false, "Commit files")
flag.BoolVar(&resetAddedFilesFlag, "Rf", false, "Reset added files") flag.BoolVar(&resetAddedFilesFlag, "Rf", false, "Reset added files")
flag.BoolVar(&resetAddedFilesFlagLong, "reset", false, "Reset added files") flag.BoolVar(&resetAddedFilesFlagLong, "reset", false, "Reset added files")
flag.Parse() flag.Parse()
Variables.VerboseOutput = verboseOutputFlag || verboseOutputFlagLong
if getFilesystemDiffFlag || getFilesystemDiffFlagLong { if getFilesystemDiffFlag || getFilesystemDiffFlagLong {
var rootPath string = Variables.RootDir var rootPath string = Variables.RootDir
if len(flag.Args()) > 1 { if len(flag.Args()) > 1 {


+ 5
- 0
Variables/Variables.go View File

@ -2,6 +2,7 @@ package Variables
import ( import (
"os" "os"
"sync"
) )
const ( const (
@ -10,6 +11,9 @@ const (
) )
var ( var (
WG sync.WaitGroup
VerboseOutput bool = false
RootDir string = "/" RootDir string = "/"
FsHashPicksBucket []byte = []byte("FilesystemPicks") FsHashPicksBucket []byte = []byte("FilesystemPicks")
FsHashIndexBucket []byte = []byte("FilesystemIndex") FsHashIndexBucket []byte = []byte("FilesystemIndex")
@ -46,6 +50,7 @@ var (
} }
IgnoreRegexPaths []string = []string{ IgnoreRegexPaths []string = []string{
"^/swapfile$",
"^/etc/passwd$", "^/etc/passwd$",
"^/etc/passwd-$", "^/etc/passwd-$",
"^/etc/group$", "^/etc/group$",


Loading…
Cancel
Save