routes/util.go (view raw)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 |
package routes import ( "io/fs" "log" "net/http" "os" "path/filepath" "strings" "git.icyphox.sh/legit/git" ) func isGoModule(gr *git.GitRepo) bool { _, err := gr.FileContent("go.mod") return err == nil } func getDisplayName(name string) string { l := len(name) - 4 if name[l:] == ".git" { name = name[:l] } return name } func getDescription(path string) (desc string) { db, err := os.ReadFile(filepath.Join(path, "description")) if err == nil { desc = string(db) } else { desc = "" } return } func (d *deps) isIgnored(name string) bool { for _, i := range d.c.Repo.Ignore { if name == i { return true } } return false } type repoInfo struct { Git *git.GitRepo Path string Category string } func (d *deps) getAllRepos() ([]repoInfo, error) { repos := []repoInfo{} max := strings.Count(d.c.Repo.ScanPath, string(os.PathSeparator)) + 2 err := filepath.WalkDir(d.c.Repo.ScanPath, func(path string, de fs.DirEntry, err error) error { if err != nil { return err } if de.IsDir() { // Check if we've exceeded our recursion depth if strings.Count(path, string(os.PathSeparator)) > max { return fs.SkipDir } if d.isIgnored(path) { return fs.SkipDir } // A bare repo should always have at least a HEAD file, if it // doesn't we can continue recursing if _, err := os.Lstat(filepath.Join(path, "HEAD")); err == nil { repo, err := git.Open(path, "") if err != nil { log.Println(err) } else { relpath, _ := filepath.Rel(d.c.Repo.ScanPath, path) repos = append(repos, repoInfo{ Git: repo, Path: relpath, Category: d.category(path), }) // Since we found a Git repo, we don't want to recurse // further return fs.SkipDir } } } return nil }) return repos, err } func (d *deps) category(path string) string { return strings.TrimPrefix(filepath.Dir(strings.TrimPrefix(path, d.c.Repo.ScanPath)), string(os.PathSeparator)) } func setContentDisposition(w http.ResponseWriter, name string) { h := "inline; filename=\"" + name + "\"" w.Header().Add("Content-Disposition", h) } func setGZipMIME(w http.ResponseWriter) { setMIME(w, "application/gzip") } func setMIME(w http.ResponseWriter, mime string) { w.Header().Add("Content-Type", mime) } |