mirror of
https://github.com/memohai/Memoh.git
synced 2026-04-25 07:00:48 +09:00
0549f5cafc
Make slash commands easier to navigate in chat by splitting help into levels, compacting list output, and surfacing current selections for model, search, memory, and browser settings. Also route /status to the active conversation session and add an access inspector so users can understand their current command and ACL context.
48 lines
1.2 KiB
Go
48 lines
1.2 KiB
Go
package command
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
func (h *Handler) buildHeartbeatGroup() *CommandGroup {
|
|
g := newCommandGroup("heartbeat", "View heartbeat logs")
|
|
g.DefaultAction = "logs"
|
|
g.Register(SubCommand{
|
|
Name: "logs",
|
|
Usage: "logs - List recent heartbeat logs",
|
|
Handler: func(cc CommandContext) (string, error) {
|
|
items, _, err := h.heartbeatService.ListLogs(cc.Ctx, cc.BotID, 10, 0)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
if len(items) == 0 {
|
|
return "No heartbeat logs found.", nil
|
|
}
|
|
records := make([][]kv, 0, len(items))
|
|
for _, item := range items {
|
|
dur := ""
|
|
if item.CompletedAt != nil {
|
|
dur = fmt.Sprintf("%.1fs", item.CompletedAt.Sub(item.StartedAt).Seconds())
|
|
}
|
|
errMsg := ""
|
|
if item.ErrorMessage != "" {
|
|
errMsg = truncate(item.ErrorMessage, 50)
|
|
}
|
|
rec := []kv{
|
|
{"Time", item.StartedAt.Format("01-02 15:04:05")},
|
|
{"Status", item.Status},
|
|
}
|
|
if dur != "" {
|
|
rec = append(rec, kv{"Duration", dur})
|
|
}
|
|
if errMsg != "" {
|
|
rec = append(rec, kv{"Error", errMsg})
|
|
}
|
|
records = append(records, rec)
|
|
}
|
|
return formatLimitedItems(records, 10, "Use the Web UI for older heartbeat logs."), nil
|
|
},
|
|
})
|
|
return g
|
|
}
|