lure/cmd/lure-api-server/main.go

100 lines
2.2 KiB
Go
Raw Normal View History

2022-12-18 05:01:50 +00:00
package main
import (
2022-12-21 05:46:04 +00:00
"context"
2022-12-18 05:01:50 +00:00
"flag"
"net"
"net/http"
"os"
"github.com/twitchtv/twirp"
"go.arsenm.dev/logger"
"go.arsenm.dev/logger/log"
"go.arsenm.dev/lure/internal/api"
2022-12-21 05:46:04 +00:00
"go.arsenm.dev/lure/internal/repos"
2022-12-18 05:01:50 +00:00
)
func init() {
log.Logger = logger.NewPretty(os.Stderr)
}
func main() {
2022-12-21 05:46:04 +00:00
ctx := context.Background()
2022-12-18 05:01:50 +00:00
addr := flag.String("a", ":8080", "Listen address for API server")
logFile := flag.String("l", "", "Output file for JSON log")
flag.Parse()
if *logFile != "" {
fl, err := os.Create(*logFile)
if err != nil {
log.Fatal("Error creating log file").Err(err).Send()
}
defer fl.Close()
log.Logger = logger.NewMulti(log.Logger, logger.NewJSON(fl))
}
2022-12-21 05:46:04 +00:00
err := repos.Pull(ctx, gdb, cfg.Repos)
if err != nil {
log.Fatal("Error pulling repositories").Err(err).Send()
}
sigCh := make(chan struct{}, 200)
go repoPullWorker(ctx, sigCh)
var handler http.Handler
handler = api.NewAPIServer(
2022-12-18 05:01:50 +00:00
lureWebAPI{db: gdb},
twirp.WithServerPathPrefix(""),
)
2023-01-12 02:07:49 +00:00
handler = withAcceptLanguage(handler)
2022-12-21 05:46:04 +00:00
handler = allowAllCORSHandler(handler)
handler = handleWebhook(handler, sigCh)
2022-12-18 05:01:50 +00:00
ln, err := net.Listen("tcp", *addr)
if err != nil {
log.Fatal("Error starting listener").Err(err).Send()
}
log.Info("Starting HTTP API server").Str("addr", ln.Addr().String()).Send()
2022-12-21 05:46:04 +00:00
err = http.Serve(ln, handler)
2022-12-18 05:01:50 +00:00
if err != nil {
log.Fatal("Error while running server").Err(err).Send()
}
}
2022-12-20 22:02:57 +00:00
func allowAllCORSHandler(h http.Handler) http.Handler {
return http.HandlerFunc(func(res http.ResponseWriter, req *http.Request) {
res.Header().Set("Access-Control-Allow-Origin", "*")
res.Header().Set("Access-Control-Allow-Headers", "*")
if req.Method == http.MethodOptions {
return
}
h.ServeHTTP(res, req)
})
}
2023-01-12 02:07:49 +00:00
2023-01-29 05:08:35 +00:00
type (
acceptLanguageKey struct{}
langParameterKey struct{}
)
2023-01-12 02:07:49 +00:00
func withAcceptLanguage(h http.Handler) http.Handler {
return http.HandlerFunc(func(res http.ResponseWriter, req *http.Request) {
ctx := req.Context()
langs := req.Header.Get("Accept-Language")
ctx = context.WithValue(ctx, acceptLanguageKey{}, langs)
2023-01-29 05:08:35 +00:00
2023-01-12 02:07:49 +00:00
lang := req.URL.Query().Get("lang")
ctx = context.WithValue(ctx, langParameterKey{}, lang)
2023-01-29 05:08:35 +00:00
2023-01-12 02:07:49 +00:00
req = req.WithContext(ctx)
h.ServeHTTP(res, req)
})
}