Files
phylum/server/internal/command/serve/engine.go
2024-10-20 11:01:05 +05:30

56 lines
1.4 KiB
Go

package serve
import (
"net/http"
"time"
"github.com/gin-contrib/cors"
"github.com/gin-gonic/gin"
"github.com/shroff/phylum/server/internal/core/errors"
)
func createEngine(debug, logBody bool, corsEnabled bool, corsOrigins []string) *gin.Engine {
if !debug {
gin.SetMode(gin.ReleaseMode)
}
engine := gin.New()
engine.Use(gin.Logger(), gin.CustomRecovery(func(c *gin.Context, err any) {
c.AbortWithStatusJSON(http.StatusInternalServerError, gin.H{
"status": 500,
"code": "internal_server_error",
"msg": "Internal Server Error",
})
}))
if debug && logBody {
engine.Use(logBodyMiddleware)
}
if corsEnabled {
engine.Use(cors.New(cors.Config{
AllowOrigins: corsOrigins,
AllowHeaders: []string{"Origin", "Authorization", "Accept", "Accept-Language", "Content-Type"},
AllowMethods: []string{"GET", "POST", "PUT", "PATCH", "DELETE", "HEAD", "OPTIONS", "PROPFIND", "PROPPATCH", "COPY", "MOVE"},
ExposeHeaders: []string{"Content-Length"},
AllowWebSockets: true,
AllowCredentials: true,
MaxAge: 24 * time.Hour,
}))
}
engine.Use(func(c *gin.Context) {
defer func() {
if err := recover(); err != nil {
if e, ok := err.(*errors.Error); ok {
c.AbortWithStatusJSON(e.Status, e)
} else {
// This will be caught by the regular gin error recovery handler
panic(err)
}
}
}()
c.Next()
})
return engine
}