Lynxie/commands/debug/debug.go
2025-03-31 11:36:18 +01:00

92 lines
1.9 KiB
Go

package debug
import (
"fmt"
"runtime"
"runtime/debug"
"strings"
"time"
"github.com/Fluffy-Bean/lynxie/app"
"github.com/Fluffy-Bean/lynxie/utils"
"github.com/bwmarrin/discordgo"
)
func RegisterDebugCommands(a *app.App) {
a.RegisterCommand("debug", registerDebug(a))
}
func registerDebug(a *app.App) app.Callback {
return func(h *app.Handler, args []string) app.Error {
modified := false
revision := "-"
buildTags := "-"
goVersion := strings.TrimPrefix(runtime.Version(), "go")
gcCount := runtime.MemStats{}.NumGC
localTime := time.Now().Local().Format("2006-01-02 15:04:05")
latency := h.Session.HeartbeatLatency().Milliseconds()
info, _ := debug.ReadBuildInfo()
for _, setting := range info.Settings {
switch setting.Key {
case "vcs.revision":
revision = setting.Value
case "vcs.modified":
modified = setting.Value == "true"
case "-tags":
buildTags = strings.ReplaceAll(setting.Value, ",", " ")
}
}
if modified {
revision += " (modified)"
}
h.Session.ChannelMessageSendComplex(h.Message.ChannelID, &discordgo.MessageSend{
Embed: &discordgo.MessageEmbed{
Title: "Lynxie",
Fields: []*discordgo.MessageEmbedField{
{
Name: "Revision",
Value: revision,
Inline: false,
},
{
Name: "Build Tags",
Value: buildTags,
Inline: false,
},
{
Name: "Go version",
Value: goVersion,
Inline: false,
},
{
Name: "OS/Arch",
Value: runtime.GOOS + "/" + runtime.GOARCH,
Inline: false,
},
{
Name: "GC Count",
Value: fmt.Sprint(gcCount),
Inline: false,
},
{
Name: "Local Time",
Value: localTime,
Inline: false,
},
{
Name: "Latency",
Value: fmt.Sprintf("%dms", latency),
Inline: false,
},
},
Color: utils.ColorFromRGB(255, 255, 255),
},
Reference: h.Reference,
})
return app.Error{}
}
}