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) }