2023-11-16 15:06:59 +00:00
|
|
|
package hypertext
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2023-11-25 15:06:23 +00:00
|
|
|
"time"
|
|
|
|
|
|
|
|
roadsign "code.smartsheep.studio/goatworks/roadsign/pkg"
|
2023-11-16 15:06:59 +00:00
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"github.com/gofiber/fiber/v2/middleware/limiter"
|
2023-11-25 15:06:23 +00:00
|
|
|
"github.com/gofiber/fiber/v2/middleware/logger"
|
2023-11-16 15:06:59 +00:00
|
|
|
"github.com/rs/zerolog/log"
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
)
|
|
|
|
|
|
|
|
func InitServer() *fiber.App {
|
|
|
|
app := fiber.New(fiber.Config{
|
|
|
|
AppName: "RoadSign",
|
|
|
|
ServerHeader: fmt.Sprintf("RoadSign v%s", roadsign.AppVersion),
|
|
|
|
DisableStartupMessage: true,
|
|
|
|
EnableIPValidation: true,
|
|
|
|
Prefork: viper.GetBool("performance.prefork"),
|
|
|
|
BodyLimit: viper.GetInt("hypertext.limitation.max_body_size"),
|
|
|
|
})
|
|
|
|
|
2023-11-30 14:35:40 +00:00
|
|
|
if viper.GetBool("performance.request_logging") {
|
|
|
|
app.Use(logger.New(logger.Config{
|
|
|
|
Output: log.Logger,
|
|
|
|
Format: "[Proxies] [${time}] ${status} - ${latency} ${method} ${path}\n",
|
|
|
|
}))
|
|
|
|
}
|
2023-11-25 15:06:23 +00:00
|
|
|
|
2023-11-16 15:06:59 +00:00
|
|
|
if viper.GetInt("hypertext.limitation.max_qps") > 0 {
|
|
|
|
app.Use(limiter.New(limiter.Config{
|
|
|
|
Max: viper.GetInt("hypertext.limitation.max_qps"),
|
|
|
|
Expiration: 1 * time.Second,
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
|
|
|
UseProxies(app)
|
|
|
|
|
|
|
|
return app
|
|
|
|
}
|
|
|
|
|
2023-11-17 16:23:40 +00:00
|
|
|
func RunServer(app *fiber.App, ports []string, securedPorts []string, pem string, key string) {
|
|
|
|
for _, port := range ports {
|
2023-11-16 15:06:59 +00:00
|
|
|
port := port
|
|
|
|
go func() {
|
|
|
|
if err := app.Listen(port); err != nil {
|
|
|
|
log.Panic().Err(err).Msg("An error occurred when listening hypertext tls ports.")
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
2023-11-17 16:23:40 +00:00
|
|
|
for _, port := range securedPorts {
|
2023-11-16 15:06:59 +00:00
|
|
|
port := port
|
|
|
|
go func() {
|
|
|
|
if err := app.ListenTLS(port, pem, key); err != nil {
|
|
|
|
log.Panic().Err(err).Msg("An error occurred when listening hypertext tls ports.")
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
}
|