all repos — elgit @ f661e6e4ce1177352b5bc40238351920cc25a69b

fork of legit: web frontend for git, written in go

config: add repo.ignore
Anirudh Oppiliappan x@icyphox.sh
Thu, 22 Dec 2022 21:13:49 +0530
commit

f661e6e4ce1177352b5bc40238351920cc25a69b

parent

2b57b6e0b1b936f45aa4ed8fd0ed2f57b7d370f3

4 files changed, 60 insertions(+), 10 deletions(-)

jump to
M config/config.goconfig/config.go
@@ -12,6 +12,7 @@ Repo struct { 		ScanPath   string   `yaml:"scanPath"`
 		Readme     []string `yaml:"readme"`
 		MainBranch []string `yaml:"mainBranch"`
+		Ignore     []string `yaml:"ignore,omitempty"`
 	} `yaml:"repo"`
 	Dirs struct {
 		Templates string `yaml:"templates"`
M readmereadme
@@ -39,6 +39,9 @@ - README.md       mainBranch:
         - master
         - main
+      ignore:
+        - foo
+        - bar
     dirs:
       templates: ./templates
       static: ./static
@@ -56,6 +59,7 @@ • repo.scanPath: where all your git repos live (or die). legit doesn't   traverse subdirs yet.
 • repo.readme: readme files to look for. Markdown isn't rendered.
 • repo.mainBranch: main branch names to look for.
+• repo.ignore: repos to ignore.
 • server.name: used for go-import meta tags and clone URLs.
 
 
M routes/routes.goroutes/routes.go
@@ -35,6 +35,10 @@ 	infos := []info{}
 
 	for _, dir := range dirs {
+		if d.isIgnored(dir.Name()) {
+			continue
+		}
+
 		path := filepath.Join(d.c.Repo.ScanPath, dir.Name())
 		gr, err := git.Open(path, "")
 		if err != nil {
@@ -77,8 +81,13 @@ } 
 func (d *deps) RepoIndex(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 	name = filepath.Clean(name)
 	path := filepath.Join(d.c.Repo.ScanPath, name)
+
 	gr, err := git.Open(path, "")
 	if err != nil {
 		d.Write404(w)
@@ -136,6 +145,10 @@ } 
 func (d *deps) RepoTree(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 	treePath := flow.Param(r.Context(), "...")
 	ref := flow.Param(r.Context(), "ref")
 
@@ -166,6 +179,10 @@ } 
 func (d *deps) FileContent(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 	treePath := flow.Param(r.Context(), "...")
 	ref := flow.Param(r.Context(), "ref")
 
@@ -190,6 +207,10 @@ } 
 func (d *deps) Log(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 	ref := flow.Param(r.Context(), "ref")
 
 	path := filepath.Join(d.c.Repo.ScanPath, name)
@@ -224,6 +245,10 @@ } 
 func (d *deps) Diff(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 	ref := flow.Param(r.Context(), "ref")
 
 	path := filepath.Join(d.c.Repo.ScanPath, name)
@@ -261,6 +286,10 @@ } 
 func (d *deps) Refs(w http.ResponseWriter, r *http.Request) {
 	name := flow.Param(r.Context(), "name")
+	if d.isIgnored(name) {
+		d.Write404(w)
+		return
+	}
 
 	path := filepath.Join(d.c.Repo.ScanPath, name)
 	gr, err := git.Open(path, "")
@@ -305,13 +334,3 @@ f = filepath.Clean(filepath.Join(d.c.Dirs.Static, f)) 
 	http.ServeFile(w, r, f)
 }
-
-func getDescription(path string) (desc string) {
-	db, err := os.ReadFile(filepath.Join(path, "description"))
-	if err == nil {
-		desc = string(db)
-	} else {
-		desc = ""
-	}
-	return
-}
A routes/util.go
@@ -0,0 +1,26 @@+package routes
+
+import (
+	"os"
+	"path/filepath"
+)
+
+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
+}