package handler import ( "net/http" "strconv" "git.yeij.top/AskaEth/Cyrene/platform-bridge/internal/logging" ) // LogHandler exposes message log retrieval endpoints. type LogHandler struct { logger *logging.Logger } func NewLogHandler(logger *logging.Logger) *LogHandler { return &LogHandler{logger: logger} } func (h *LogHandler) RegisterRoutes(mux *http.ServeMux) { mux.HandleFunc("/api/v1/logs/", h.handleLogs) } func (h *LogHandler) handleLogs(w http.ResponseWriter, r *http.Request) { name := r.URL.Path[len("/api/v1/logs/"):] if name == "" { writeJSON(w, http.StatusBadRequest, errResp("missing platform name in path")) return } limit := 100 if l := r.URL.Query().Get("limit"); l != "" { if n, err := strconv.Atoi(l); err == nil && n > 0 && n <= 1000 { limit = n } } entries, err := h.logger.ReadLogs(name, limit) if err != nil { writeJSON(w, http.StatusInternalServerError, errResp(err.Error())) return } if entries == nil { entries = []logging.LogEntry{} } writeJSON(w, http.StatusOK, map[string]interface{}{ "platform": name, "total": len(entries), "logs": entries, }) }