feature/adding-log-file #1
|
@ -0,0 +1,30 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Application struct {
|
||||||
|
Config *Config
|
||||||
|
Mux *http.ServeMux
|
||||||
|
Log *LogFile
|
||||||
|
}
|
||||||
|
|
||||||
|
func (app *Application) routes() {
|
||||||
|
m := http.NewServeMux()
|
||||||
|
|
||||||
|
m.HandleFunc("/healthcheck", healthcheck)
|
||||||
|
m.HandleFunc("/reloadRules", reloadRules(app.Config))
|
||||||
|
m.HandleFunc("/", serveLogger(app.Log)(serveRules(app.Config)))
|
||||||
|
|
||||||
|
app.Mux = m
|
||||||
|
}
|
||||||
|
|
||||||
|
func (app *Application) Setup(port string) *http.Server {
|
||||||
|
app.routes()
|
||||||
|
return &http.Server{
|
||||||
|
Addr: fmt.Sprintf(":%s", port),
|
||||||
|
Handler: app.Mux,
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"embed"
|
||||||
|
"html/template"
|
||||||
|
)
|
||||||
|
|
||||||
|
// go:embed templates/*
|
||||||
|
var tmpls embed.FS
|
||||||
|
|
||||||
|
func GetServeHtml() *template.Template {
|
||||||
|
data, _ := tmpls.ReadFile("success.html")
|
||||||
|
return template.Must(template.New("main").Parse(string(data)))
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetDefaultHtml() []byte {
|
||||||
|
data, _ := tmpls.ReadFile("default.html")
|
||||||
|
return data
|
||||||
|
}
|
|
@ -0,0 +1,71 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"net/http"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func healthcheck(w http.ResponseWriter, r *http.Request) {
|
||||||
|
w.Write([]byte("ok"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func reloadRules(c *Config) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
err := c.LoadMappingFile("")
|
||||||
|
if err != nil {
|
||||||
|
errorLog.Printf("Cannot reload rules: %+v", err)
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.Write([]byte("ok"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func serveRules(c *Config) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if r.Method != http.MethodGet {
|
||||||
|
http.Error(w, http.StatusText(http.StatusMethodNotAllowed), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// if go-get param is absent, return nothing
|
||||||
|
if r.FormValue("go-get") != "1" {
|
||||||
|
w.Write(GetDefaultHtml())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
nameOfPkg := r.Host + r.URL.Path
|
||||||
|
|
||||||
|
var vanityUrl, proto, repoUrl string
|
||||||
|
for _, rule := range c.MappingRules.Mappings {
|
||||||
|
if strings.HasPrefix(strings.ToLower(nameOfPkg), strings.ToLower(rule.VanityUrl+"/")) {
|
||||||
|
repo := strings.Replace(strings.ToLower(nameOfPkg), strings.ToLower(rule.VanityUrl), "", -1)
|
||||||
|
repo = strings.Split(repo, "/")[1]
|
||||||
|
|
||||||
|
vanityUrl = rule.VanityUrl + "/" + repo
|
||||||
|
repoUrl = rule.RealUrl + "/" + repo
|
||||||
|
proto = rule.Protocol
|
||||||
|
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
d := ImportRuleStruct{
|
||||||
|
VanityUrl: vanityUrl,
|
||||||
|
Proto: proto,
|
||||||
|
RepoUrl: repoUrl,
|
||||||
|
}
|
||||||
|
tmpl := GetServeHtml()
|
||||||
|
|
||||||
|
var buf bytes.Buffer
|
||||||
|
err := tmpl.Execute(&buf, &d)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
w.Header().Set("Cache-Control", "public, max-age=500")
|
||||||
|
w.Write(buf.Bytes())
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
// serveLogger is a logging middleware for serving. It generates logs for
|
||||||
|
// requests sent to the server.
|
||||||
|
func serveLogger(l *LogFile) func(http.HandlerFunc) http.HandlerFunc {
|
||||||
|
return func(next http.HandlerFunc) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
l.WriteLog(r)
|
||||||
|
next(w, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// func serveLogger(logger *LogFile, next http.Handler) http.Handler {
|
||||||
|
// return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
// logger.WriteLog(r)
|
||||||
|
// next.ServeHTTP(w, r)
|
||||||
|
// })
|
||||||
|
// }
|
|
@ -0,0 +1,6 @@
|
||||||
|
<html>
|
||||||
|
<head></head>
|
||||||
|
<body>
|
||||||
|
<h5>Nothing here. Move along.</h5>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,7 @@
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
|
||||||
|
<meta name="go-import" content="{{.VanityUrl}} {{.Proto}} {{.RepoUrl}}">
|
||||||
|
<meta name="go-source" content="{{.VanityUrl}} {{.RepoUrl}} {{.RepoUrl}}/tree/main{/dir} {{.RepoUrl}}/blob/main{/dir}/{file}#L{line}">
|
||||||
|
</head>
|
||||||
|
</html>
|
Loading…
Reference in New Issue