go-urlsh/internal/app/fiber.go

74 lines
1.7 KiB
Go
Raw Normal View History

package app
import (
2024-05-04 17:06:01 +02:00
"os"
"code.lila.network/adoralaura/go-urlsh/internal/misc"
"code.lila.network/adoralaura/go-urlsh/internal/web"
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/compress"
"github.com/gofiber/fiber/v2/middleware/cors"
"github.com/gofiber/fiber/v2/middleware/etag"
"github.com/gofiber/fiber/v2/middleware/logger"
"github.com/gofiber/fiber/v2/middleware/recover"
2024-05-04 17:06:01 +02:00
"github.com/gofiber/template/html/v2"
)
func SetupFiber() error {
var prod = false
var port = "3000"
var ip = ""
var proxyheader = "X-Forwarded-For"
2023-04-27 12:34:24 +02:00
var template_engine = html.New("./views", ".tmpl")
if os.Getenv("PROD") == "true" {
prod = true
}
if os.Getenv("PORT") != "" {
port = os.Getenv("PORT")
}
if os.Getenv("LISTEN") != "" {
ip = os.Getenv("LISTEN")
}
if os.Getenv("PROXYHEADER") != "" {
proxyheader = os.Getenv("PROXYHEADER")
}
fiberapp := fiber.New(fiber.Config{
2023-04-28 18:24:09 +02:00
AppName: "go-urlsh",
ProxyHeader: proxyheader,
Prefork: prod,
2024-05-04 17:06:01 +02:00
ErrorHandler: misc.HandleError,
2023-04-28 18:24:09 +02:00
Views: template_engine,
CompressedFileSuffix: ".gz",
})
fiberapp.Use(logger.New(logger.Config{Format: "[${ip}]:${port} ${status} ${method} ${path}\n"}))
fiberapp.Use(etag.New(etag.Config{Weak: false}))
fiberapp.Use(compress.New())
fiberapp.Use(recover.New())
2024-05-04 17:06:01 +02:00
addWebRoutes(fiberapp)
2023-04-27 12:34:24 +02:00
fiberapp.Static("/admin/", "./web")
2023-04-27 10:37:42 +02:00
2024-05-04 17:06:01 +02:00
fiberapp.Get("/", web.HandleIndexGet)
fiberapp.Get("/:id", web.HandleIndexGet)
2023-04-28 18:24:09 +02:00
v1 := fiberapp.Group("/api/v1")
v1.Use(cors.New(cors.Config{AllowOrigins: "*"}))
2024-05-04 17:06:01 +02:00
addApiRoutes(v1)
2023-04-27 10:37:42 +02:00
listenerr := fiberapp.Listen(ip + ":" + port)
if listenerr != nil {
return listenerr
}
return nil
}