Paperclip/pkg/internal/server/server.go

78 lines
2.0 KiB
Go
Raw Permalink Normal View History

2024-05-17 07:59:51 +00:00
package server
import (
2024-07-16 09:02:16 +00:00
"strings"
"git.solsynth.dev/hydrogen/dealer/pkg/hyper"
"git.solsynth.dev/hydrogen/paperclip/pkg/internal/database"
"git.solsynth.dev/hydrogen/paperclip/pkg/internal/gap"
"git.solsynth.dev/hydrogen/paperclip/pkg/internal/models"
"git.solsynth.dev/hydrogen/paperclip/pkg/internal/server/api"
2024-05-17 07:59:51 +00:00
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/cors"
"github.com/gofiber/fiber/v2/middleware/idempotency"
"github.com/gofiber/fiber/v2/middleware/logger"
jsoniter "github.com/json-iterator/go"
"github.com/rs/zerolog/log"
"github.com/spf13/viper"
)
2024-07-16 10:08:23 +00:00
var app *fiber.App
2024-05-17 07:59:51 +00:00
func NewServer() {
2024-07-16 10:08:23 +00:00
app = fiber.New(fiber.Config{
2024-05-17 07:59:51 +00:00
DisableStartupMessage: true,
EnableIPValidation: true,
ServerHeader: "Hydrogen.Paperclip",
AppName: "Hydrogen.Paperclip",
ProxyHeader: fiber.HeaderXForwardedFor,
JSONEncoder: jsoniter.ConfigCompatibleWithStandardLibrary.Marshal,
JSONDecoder: jsoniter.ConfigCompatibleWithStandardLibrary.Unmarshal,
BodyLimit: 512 * 1024 * 1024 * 1024, // 512 TiB
EnablePrintRoutes: viper.GetBool("debug.print_routes"),
})
2024-07-16 10:08:23 +00:00
app.Use(idempotency.New())
app.Use(cors.New(cors.Config{
2024-05-17 07:59:51 +00:00
AllowCredentials: true,
AllowMethods: strings.Join([]string{
fiber.MethodGet,
fiber.MethodPost,
fiber.MethodHead,
fiber.MethodOptions,
fiber.MethodPut,
fiber.MethodDelete,
fiber.MethodPatch,
}, ","),
AllowOriginsFunc: func(origin string) bool {
return true
},
}))
2024-07-16 10:08:23 +00:00
app.Use(logger.New(logger.Config{
2024-05-17 07:59:51 +00:00
Format: "${status} | ${latency} | ${method} ${path}\n",
Output: log.Logger,
}))
tablePrefix := viper.GetString("database.prefix")
2024-07-16 10:08:23 +00:00
app.Use(gap.H.AuthMiddleware)
app.Use(hyper.LinkAccountMiddleware(
database.C,
tablePrefix+"accounts",
func(u hyper.BaseUser) models.Account {
return models.Account{
BaseUser: u,
}
},
))
2024-05-17 07:59:51 +00:00
2024-07-16 10:08:23 +00:00
api.MapAPIs(app, "/api")
2024-05-17 07:59:51 +00:00
}
func Listen() {
2024-07-16 10:08:23 +00:00
if err := app.Listen(viper.GetString("bind")); err != nil {
2024-05-17 07:59:51 +00:00
log.Fatal().Err(err).Msg("An error occurred when starting server...")
}
}