2024-12-17 20:48:08 -06:00
|
|
|
package forgepb
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/destel/rill"
|
|
|
|
"go.wit.com/lib/protobuf/gitpb"
|
|
|
|
"go.wit.com/log"
|
|
|
|
)
|
|
|
|
|
|
|
|
// rill is awesome. long live rill
|
|
|
|
// attempt scan with rill
|
|
|
|
func (f *Forge) rillUpdate(pool1 int, pool2 int) (int, error) {
|
|
|
|
var repos []*gitpb.Repo
|
|
|
|
all := f.Repos.SortByFullPath()
|
|
|
|
for all.Scan() {
|
|
|
|
repo := all.Next()
|
|
|
|
repos = append(repos, repo)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Convert a slice of user IDs into a channel
|
|
|
|
ids := rill.FromSlice(repos, nil)
|
|
|
|
|
|
|
|
// Read users from the API.
|
|
|
|
// Concurrency = 20
|
|
|
|
rills := rill.Map(ids, pool1, func(repo *gitpb.Repo) (*gitpb.Repo, error) {
|
|
|
|
return repo, nil
|
|
|
|
})
|
|
|
|
|
|
|
|
var counter int
|
|
|
|
// Activate users.
|
|
|
|
// Concurrency = 10
|
|
|
|
err := rill.ForEach(rills, pool2, func(repo *gitpb.Repo) error {
|
|
|
|
counter += 1
|
|
|
|
return f.updateRepo(repo)
|
|
|
|
})
|
|
|
|
|
|
|
|
return counter, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *Forge) updateRepo(repo *gitpb.Repo) error {
|
|
|
|
if !repo.IsValidDir() {
|
|
|
|
log.Printf("%10s %-50s", "bad git dir\n", repo.FullPath)
|
|
|
|
f.Repos.DeleteByFullPath(repo.FullPath)
|
|
|
|
f.configSave = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if repo.DidRepoChange() {
|
|
|
|
f.configSave = true
|
2024-12-17 21:14:39 -06:00
|
|
|
log.Info("repo changed ", repo.FullPath, repo.StateChange)
|
2024-12-17 20:48:08 -06:00
|
|
|
if err := repo.Reload(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2024-12-17 21:14:39 -06:00
|
|
|
} else {
|
|
|
|
// log.Info("repo did not change", repo.FullPath, repo.StateChange)
|
2024-12-17 20:48:08 -06:00
|
|
|
}
|
|
|
|
if f.Config.IsReadOnly(repo.GetGoPath()) {
|
|
|
|
if repo.ReadOnly {
|
|
|
|
} else {
|
|
|
|
log.Info("readonly flag on repo is wrong", repo.GetGoPath())
|
|
|
|
repo.ReadOnly = true
|
|
|
|
f.configSave = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|