gowebd/main.go

94 lines
1.8 KiB
Go

package main
import (
"embed"
"fmt"
"net/http"
"time"
"go.wit.com/lib/protobuf/forgepb"
"go.wit.com/lib/protobuf/gitpb"
"go.wit.com/log"
)
// are sent via -ldflags at buildtime
var VERSION string
var BUILDTIME string
//go:embed resources/*
var resources embed.FS
// var accessf, clientf *os.File
var repoMap map[string]string
var gitMap map[string]*gitpb.Repo
var configfile []string
var keysSorted []string
var forge *forgepb.Forge
var HOSTNAME string = "go.wit.com"
var REPOMAP string = "/etc/gowebd/repomap"
var FOOTER string = "/etc/gowebd/footer.html"
var LIBDIR string = "/var/lib/gowebd/"
func main() {
if argv.RepoMap != "" {
REPOMAP = argv.RepoMap
}
if argv.Hostname != "" {
HOSTNAME = argv.Hostname
}
forge = forgepb.Init()
gitMap = make(map[string]*gitpb.Repo)
repoMap = make(map[string]string)
/*
all := forge.Repos.SortByGoPath()
for all.Scan() {
repo := all.Next()
log.Info("forge protobuf has:", repo.GoPath)
}
*/
// parse the repomap file
readRepomap()
// readVersionFile()
http.HandleFunc("/", okHandler)
// go https() // use caddy instead
p := fmt.Sprintf(":%d", argv.Port)
log.Println("HOSTNAME set to:", HOSTNAME)
log.Println("Running on port", p)
err := http.ListenAndServe(p, nil)
if err != nil {
log.Println("Error starting server:", err)
}
}
func formatDuration(d time.Duration) string {
seconds := int(d.Seconds()) % 60
minutes := int(d.Minutes()) % 60
hours := int(d.Hours()) % 24
days := int(d.Hours()) / 24
result := ""
if days > 0 {
result += fmt.Sprintf("%dd ", days)
return result
}
if hours > 0 {
result += fmt.Sprintf("%dh ", hours)
return result
}
if minutes > 0 {
result += fmt.Sprintf("%dm ", minutes)
return result
}
if seconds > 0 {
result += fmt.Sprintf("%ds", seconds)
}
return result
}