This repository has been archived on 2025-08-09. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
web-app-template/main.go
Tim Wundenberg 6f22e066ab
All checks were successful
Build Docker Image / Explore-Gitea-Actions (push) Successful in 45s
Build and Push Docker Image / Explore-Gitea-Actions (push) Successful in 46s
fix: restructure handler.go #181
2024-09-15 12:58:06 +02:00

63 lines
1.1 KiB
Go

package main
import (
"me-fit/handler"
"me-fit/utils"
"database/sql"
"log"
"log/slog"
"net/http"
"github.com/joho/godotenv"
_ "github.com/mattn/go-sqlite3"
"github.com/prometheus/client_golang/prometheus/promhttp"
)
func main() {
slog.Info("Starting server...")
err := godotenv.Load()
if err != nil {
log.Fatal("Error loading .env file")
}
utils.MustInitEnv()
db, err := sql.Open("sqlite3", "./data.db")
if err != nil {
log.Fatal("Could not open Database data.db: ", err)
}
defer db.Close()
utils.MustRunMigrations(db)
startPrometheus()
var server = http.Server{
Addr: ":8080",
Handler: handler.GetHandler(db),
}
slog.Info("Starting server on " + server.Addr)
err = server.ListenAndServe()
if err != nil {
panic(err)
}
}
func startPrometheus() {
var prometheusServer = http.Server{
Addr: ":8081",
Handler: promhttp.Handler(),
}
go func() {
slog.Info("Starting prometheus server on " + prometheusServer.Addr)
err := prometheusServer.ListenAndServe()
if err != nil {
log.Fatal("Could not start prometheus server: ", err)
}
}()
}