2024-11-27 14:41:57 -06:00
|
|
|
package gitpb
|
|
|
|
|
|
|
|
import (
|
2024-11-27 21:40:06 -06:00
|
|
|
"errors"
|
|
|
|
"os"
|
2024-11-27 14:41:57 -06:00
|
|
|
"path/filepath"
|
2024-12-16 00:21:08 -06:00
|
|
|
"time"
|
2024-11-27 21:40:06 -06:00
|
|
|
|
|
|
|
"go.wit.com/log"
|
2024-12-16 00:21:08 -06:00
|
|
|
timestamppb "google.golang.org/protobuf/types/known/timestamppb"
|
2024-11-27 14:41:57 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
// scans in a new git repo. If it detects the repo is a golang project,
|
|
|
|
// then it parses the go.mod/go.sum files
|
|
|
|
// TODO: try adding python, rails, perl, rust, other language things?
|
|
|
|
// I probably will never have time to try that, but I'd take patches for anyone
|
|
|
|
// that might see this note and feel so inclined.
|
2024-12-03 00:35:50 -06:00
|
|
|
func (all *Repos) NewGoPath(basepath string, gopath string, url string) (*Repo, error) {
|
|
|
|
if gopath == "" {
|
|
|
|
return nil, errors.New("blank gopath")
|
|
|
|
}
|
2024-11-27 14:55:39 -06:00
|
|
|
if r := all.FindByGoPath(gopath); r != nil {
|
2024-12-15 08:48:42 -06:00
|
|
|
log.Info("gitpb.NewGoPath() already has gopath", r.GoPath)
|
|
|
|
log.Info("gitpb.NewGoPath() already has FullPath", r.FullPath)
|
|
|
|
log.Info("gitpb.NewGoPath() already has URL", r.URL)
|
2024-11-27 14:41:57 -06:00
|
|
|
// already had this gopath
|
2024-12-07 16:50:26 -06:00
|
|
|
return r, errors.New("gitpb.NewGoPath() duplicate gopath " + gopath)
|
2024-11-27 21:40:06 -06:00
|
|
|
}
|
2024-12-03 00:35:50 -06:00
|
|
|
log.Info("gitpb.NewGoPath() Attempting to add new path", basepath, gopath)
|
2024-11-27 21:40:06 -06:00
|
|
|
|
|
|
|
// if .git doesn't exist, error out here
|
|
|
|
gitpath := filepath.Join(basepath, gopath, ".git")
|
|
|
|
_, err := os.Stat(gitpath)
|
|
|
|
if err != nil {
|
2024-12-03 00:35:50 -06:00
|
|
|
log.Warn("gitpb.NewGoPath() not a git directory", gitpath)
|
2024-11-27 21:40:06 -06:00
|
|
|
return nil, err
|
2024-11-27 14:41:57 -06:00
|
|
|
}
|
2024-11-27 21:40:06 -06:00
|
|
|
|
2024-11-27 14:41:57 -06:00
|
|
|
// add a new one here
|
|
|
|
newr := Repo{
|
|
|
|
FullPath: filepath.Join(basepath, gopath),
|
|
|
|
GoPath: gopath,
|
2024-12-03 00:35:50 -06:00
|
|
|
URL: url,
|
2024-11-27 14:41:57 -06:00
|
|
|
}
|
2024-12-01 10:46:32 -06:00
|
|
|
newr.Tags = new(GitTags)
|
2024-11-29 01:23:51 -06:00
|
|
|
newr.UpdateGitTags()
|
2024-12-01 10:46:32 -06:00
|
|
|
newr.GoDeps = new(GoDeps)
|
|
|
|
|
2024-12-01 16:04:07 -06:00
|
|
|
switch newr.goListRepoType() {
|
2024-12-03 00:35:50 -06:00
|
|
|
case "plugin":
|
|
|
|
newr.GoPlugin = true
|
|
|
|
case "protobuf":
|
|
|
|
newr.GoProtobuf = true
|
2024-12-01 10:46:32 -06:00
|
|
|
case "library":
|
|
|
|
newr.GoLibrary = true
|
|
|
|
case "binary":
|
|
|
|
newr.GoBinary = true
|
|
|
|
}
|
2024-11-27 14:41:57 -06:00
|
|
|
|
2024-12-16 00:21:08 -06:00
|
|
|
lastpull, err := newr.LastGitPull()
|
|
|
|
if err == nil {
|
|
|
|
newr.LastPull = timestamppb.New(lastpull)
|
|
|
|
}
|
|
|
|
|
2024-12-03 00:35:50 -06:00
|
|
|
if all.AppendUniqueGoPath(&newr) {
|
|
|
|
// worked
|
|
|
|
return &newr, nil
|
2024-12-16 00:21:08 -06:00
|
|
|
} else {
|
|
|
|
// this is dumb, probably never happens. todo: use Repos.Lock()
|
|
|
|
if r := all.FindByGoPath(gopath); r != nil {
|
|
|
|
// already had this gopath
|
|
|
|
return r, errors.New("gitpb.NewGoPath() AppendUnique() failed but Find() worked" + gopath)
|
|
|
|
}
|
2024-11-27 21:40:06 -06:00
|
|
|
}
|
2024-12-16 00:21:08 -06:00
|
|
|
// todo: use Repos.Lock()
|
2024-12-07 16:50:26 -06:00
|
|
|
return nil, errors.New("repo gitpb.NewGoPath() should never have gotten here " + gopath)
|
2024-11-29 21:51:30 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) SetDevelBranchName(bname string) {
|
|
|
|
repo.DevelBranchName = bname
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) SetUserBranchName(bname string) {
|
|
|
|
repo.UserBranchName = bname
|
|
|
|
}
|
2024-12-16 00:21:08 -06:00
|
|
|
|
|
|
|
func (repo *Repo) GitChanged() bool {
|
|
|
|
fullfile := filepath.Join(repo.FullPath, ".git/FETCH_HEAD")
|
|
|
|
lasttime, err := repo.LastGitPull()
|
|
|
|
if err == nil {
|
|
|
|
// if error, something is wrong, assume true
|
|
|
|
log.Info("gitpb:", fullfile, "changed")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
newtime := repo.LastPull.AsTime()
|
|
|
|
|
|
|
|
if lasttime == newtime {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
log.Info("gitpb:", fullfile, "changed")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) GitPullAge() time.Duration {
|
|
|
|
lastpull, err := repo.LastGitPull()
|
|
|
|
if err == nil {
|
|
|
|
// if error, something is wrong, assume true
|
|
|
|
ltime := repo.LastPull.AsTime()
|
|
|
|
return time.Since(ltime)
|
|
|
|
}
|
|
|
|
|
|
|
|
return time.Since(lastpull)
|
|
|
|
}
|