Files
login-api/app/controllers/session_info.go
2026-01-15 20:25:17 +01:00

41 lines
1.0 KiB
Go

package controllers
import (
"git.secnex.io/secnex/auth-api/services"
"git.secnex.io/secnex/auth-api/utils"
"github.com/go-playground/validator/v10"
"github.com/gofiber/fiber/v2"
)
type SessionInfoRequest struct {
SessionToken string `json:"token" validate:"required"`
}
func SessionInfoController(c *fiber.Ctx) error {
var request SessionInfoRequest
if err := c.BodyParser(&request); err != nil {
return utils.NewErrorResponse(fiber.StatusBadRequest, &fiber.Map{
"message": "Invalid request body",
}).Send(c)
}
validate := validator.New()
if err := validate.Struct(request); err != nil {
return utils.NewErrorResponse(fiber.StatusBadRequest, &fiber.Map{
"message": "Invalid request body",
}).Send(c)
}
sessionDetails, err := services.SessionInfo(request.SessionToken)
if err != nil {
return utils.NewErrorResponse(fiber.StatusUnauthorized, &fiber.Map{
"message": "Invalid token",
}).Send(c)
}
return utils.NewHTTPResponse(fiber.StatusOK, &fiber.Map{
"message": "OK",
"session": sessionDetails,
}, "", nil, nil).Send(c)
}