Passport/pkg/utils/request.go

46 lines
1.2 KiB
Go
Raw Normal View History

2024-04-20 14:50:09 +00:00
package utils
2024-01-26 17:11:32 +00:00
import (
2024-05-17 11:24:14 +00:00
"fmt"
"git.solsynth.dev/hydrogen/passport/pkg/services"
2024-01-26 17:11:32 +00:00
"github.com/go-playground/validator/v10"
"github.com/gofiber/fiber/v2"
"github.com/samber/lo"
"github.com/sujit-baniya/flash"
2024-01-26 17:11:32 +00:00
)
2024-01-31 13:16:54 +00:00
var validation = validator.New(validator.WithRequiredStructEnabled())
2024-01-26 17:11:32 +00:00
func BindAndValidate(c *fiber.Ctx, out any) error {
if err := c.BodyParser(out); err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
} else if err := validation.Struct(out); err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
}
return nil
}
2024-05-17 11:24:14 +00:00
func GetPermissions(c *fiber.Ctx) map[string]any {
return c.Locals("permissions").(map[string]any)
}
func CheckPermissions(c *fiber.Ctx, key string, val any) error {
if !services.HasPermNode(GetPermissions(c), key, val) {
return fiber.NewError(fiber.StatusForbidden, fmt.Sprintf("requires permission: %s = %v", key, val))
}
return nil
}
func GetRedirectUri(c *fiber.Ctx, fallback ...string) *string {
if len(c.Query("redirect_uri")) > 0 {
return lo.ToPtr(c.Query("redirect_uri"))
} else if val, ok := flash.Get(c)["redirect_uri"].(*string); ok {
return val
} else if len(fallback) > 0 {
return &fallback[0]
} else {
return nil
}
}