#1 scan all projects for last modified
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
gari 2021-11-30 23:09:34 +01:00
parent 2fc606beae
commit 3a82bf1776
3 changed files with 63 additions and 41 deletions

View file

@ -4,13 +4,13 @@ import (
"git.entr0py.de/garionion/murphy/scanner" "git.entr0py.de/garionion/murphy/scanner"
"git.entr0py.de/garionion/murphy/store" "git.entr0py.de/garionion/murphy/store"
"github.com/mehdioa/nlog" "github.com/mehdioa/nlog"
"sync"
) )
var log *nlog.Logger var log *nlog.Logger
const source = "/mnt/clarkson" const source = "/mnt/clarkson"
func main() { func main() {
formatter := nlog.NewTextFormatter(true, true) formatter := nlog.NewTextFormatter(true, true)
log = nlog.NewLogger(nlog.DebugLevel, formatter) log = nlog.NewLogger(nlog.DebugLevel, formatter)
@ -18,4 +18,8 @@ func main() {
s := store.NewStore(log) s := store.NewStore(log)
scanner.InitScanner(s, source) scanner.InitScanner(s, source)
wg := new(sync.WaitGroup)
wg.Add(2)
wg.Wait()
} }

View file

@ -1,56 +1,57 @@
package scanner package scanner
import ( import (
"fmt" "git.entr0py.de/garionion/murphy/store"
store "git.entr0py.de/garionion/murphy/store"
"github.com/karrick/godirwalk" "github.com/karrick/godirwalk"
"github.com/mehdioa/nlog" "github.com/mehdioa/nlog"
"github.com/oriser/regroup" "github.com/oriser/regroup"
"io/ioutil" "io/ioutil"
"os"
"path" "path"
"strings"
"time" "time"
) )
type Scanner struct { func scan(p *store.Project) {
TargetPath string log := p.Logger
LastChange time.Time log.Infof("Scanning %s", p.ProjectName)
Created time.Time lastModified := time.Time{}
ProjectName string err := godirwalk.Walk(p.TargetPath, &godirwalk.Options{
Logger *nlog.Logger
}
func NewScanner(target, projectName string, createdAt time.Time, logger *nlog.Logger) *Scanner {
projectLogger := logger.New("Scanner", nlog.Data{"Project": projectName,})
scanner := &Scanner{TargetPath: target, Created: createdAt, ProjectName: projectName, Logger: logger}
projectLogger.Infof("Scanning %s", projectName)
err := godirwalk.Walk(target, &godirwalk.Options{
Callback: func(osPathname string, de *godirwalk.Dirent) error { Callback: func(osPathname string, de *godirwalk.Dirent) error {
// Following string operation is not most performant way fi, err := os.Stat(osPathname)
// of doing this, but common enough to warrant a simple if err != nil {
// example here: log.Errorf("Error while getting Stats on %s: %v", osPathname, err)
if strings.Contains(osPathname, ".git") { return err
return godirwalk.SkipThis }
modtime := fi.ModTime()
if modtime.After(lastModified) {
lastModified = modtime
} }
fmt.Printf("%s %s\n", de.ModeType(), osPathname)
return nil return nil
}, },
Unsorted: true, // (optional) set true for faster yet non-deterministic enumeration (see godoc) Unsorted: true, // (optional) set true for faster yet non-deterministic enumeration (see godoc)
}) })
if err != nil { if err != nil {
projectLogger.Errorf("Error scanning %s: %s", projectName, err) log.Errorf("Error scanning %s: %v", p.ProjectName, err)
} }
return scanner log.Infof("Found last modification time %v", lastModified)
p.LastChange = lastModified
} }
func NewProject(target, projectName string, createdAt time.Time, logger *nlog.Logger) *store.Project {
projectLogger := logger.New("Project", nlog.Data{"Project": projectName})
project := &store.Project{TargetPath: target, Created: createdAt, ProjectName: projectName, Logger: projectLogger}
go scan(project)
return project
}
func InitScanner(s *store.Store, sourcePath string) { func InitScanner(s *store.Store, sourcePath string) {
s.Logger.Infof("Initializing scanner") s.Logger.Infof("Initializing scanner")
scanners := map[string]*Scanner{} projects := s.GetProjects()
RootScanner(sourcePath, scanners, s.Logger) rootScanner(sourcePath, projects, s.Logger)
s.Logger.Infof("Found %d projects", len(projects))
} }
func RootScanner(rootPath string, scanners map[string]*Scanner, logger *nlog.Logger) { func rootScanner(rootPath string, projects map[string]*store.Project, logger *nlog.Logger) {
resorts, err := ioutil.ReadDir(rootPath) resorts, err := ioutil.ReadDir(rootPath)
if err != nil { if err != nil {
logger.Errorf("Error reading directory %s: %v", rootPath, err) logger.Errorf("Error reading directory %s: %v", rootPath, err)
@ -61,14 +62,14 @@ func RootScanner(rootPath string, scanners map[string]*Scanner, logger *nlog.Log
if r.IsDir() && r.Name()[0] != '.' { if r.IsDir() && r.Name()[0] != '.' {
resort := path.Join(rootPath, r.Name()) resort := path.Join(rootPath, r.Name())
logger.Debugf("Found directory: %s", resort) logger.Debugf("Found directory: %s", resort)
projects, err := ioutil.ReadDir(resort) projectsDir, err := ioutil.ReadDir(resort)
if err != nil { if err != nil {
logger.Errorf("Error reading directory %s: %v", projects, err) logger.Errorf("Error reading directory %s: %v", projects, err)
return return
} }
for _, p := range projects { for _, p := range projectsDir {
if p.IsDir() { if p.IsDir() {
_, mapContainsProject := scanners[p.Name()] _, mapContainsProject := projects[p.Name()]
if mapContainsProject { if mapContainsProject {
continue continue
} }
@ -86,15 +87,17 @@ func RootScanner(rootPath string, scanners map[string]*Scanner, logger *nlog.Log
createdAt, err := time.Parse("2006-01-02", createdAtString) createdAt, err := time.Parse("2006-01-02", createdAtString)
if err != nil { if err != nil {
logger.Errorf("Failed to parse date %s: %v, skipping %s", createdAtString, err, p.Name()) logger.Errorf("Failed to parse date %s: %v, Using Null-Time for %s", createdAtString, err, p.Name())
createdAt = time.Time{}
} }
scanner := NewScanner(projectPath, projectName, createdAt, logger) scanner := NewProject(projectPath, projectName, createdAt, logger)
scanners[p.Name()] = scanner projects[p.Name()] = scanner
} else { } else {
logger.Debugf("Ignoring Directory %s", projectPath) logger.Debugf("Ignoring Directory %s", projectPath)
} }
} }
} }
} }
} }
return
} }

View file

@ -2,18 +2,33 @@ package store
import ( import (
"github.com/mehdioa/nlog" "github.com/mehdioa/nlog"
"sync"
"time" "time"
) )
type Store struct { type Store struct {
TargetPath []string TargetPath []string
SourcePath []string SourcePath []string
GracePeriod time.Duration GracePeriod time.Duration
Logger *nlog.Logger Projects map[string]*Project
Logger *nlog.Logger
lock sync.RWMutex
} }
func NewStore(Logger *nlog.Logger) *Store{ type Project struct {
store := &Store{Logger: Logger} TargetPath string
LastChange time.Time
Created time.Time
ProjectName string
Logger *nlog.Node
}
func NewStore(Logger *nlog.Logger) *Store {
store := &Store{Logger: Logger, Projects: make(map[string]*Project)}
return store return store
} }
func (store *Store) GetProjects() map[string]*Project {
return store.Projects
}