package controllers import ( "git.secnex.io/secnex/auth-api/services" "git.secnex.io/secnex/auth-api/utils" "git.secnex.io/secnex/masterlog" "github.com/go-playground/validator/v10" "github.com/gofiber/fiber/v2" ) type LogoutRequest struct { SessionToken string `json:"token" validate:"required"` } func LogoutController(c *fiber.Ctx) error { var request LogoutRequest if err := c.BodyParser(&request); err != nil { return utils.NewErrorResponse(fiber.StatusBadRequest, &fiber.Map{ "message": "Invalid request body", }).Send(c) } masterlog.Debug("Processing logout request", map[string]interface{}{"session_token": request.SessionToken}) validate := validator.New() if err := validate.Struct(request); err != nil { return utils.NewErrorResponse(fiber.StatusBadRequest, &fiber.Map{ "message": "Invalid request body", }).Send(c) } err := services.Logout(request.SessionToken) if err != nil { return utils.NewErrorResponse(fiber.StatusInternalServerError, &fiber.Map{ "message": "Error logging out", }).Send(c) } return utils.NewHTTPResponse(fiber.StatusOK, &fiber.Map{ "message": "OK", }, "", nil, nil).Send(c) }