Lynxie/commands/meta.go

81 lines
1.8 KiB
Go

package commands
import (
"flag"
"fmt"
"runtime"
"runtime/debug"
"strings"
"time"
"github.com/Fluffy-Bean/lynxie/app"
)
func RegisterMetaCommands(a *app.App) {
a.RegisterCommand("ping", registerPong(a))
a.RegisterCommand("debug", registerDebug(a))
}
func registerPong(a *app.App) func(h *app.Handler, args []string) {
return func(h *app.Handler, args []string) {
var options struct {
latency bool
}
cmd := flag.NewFlagSet("pong", flag.ContinueOnError)
cmd.BoolVar(&options.latency, "latency", false, "Display the latency of ping")
cmd.Parse(args)
if options.latency {
h.Session.ChannelMessageSend(
h.Message.ChannelID,
fmt.Sprintf("Pong! %dms", h.Session.HeartbeatLatency().Milliseconds()),
)
} else {
h.Session.ChannelMessageSend(
h.Message.ChannelID,
"Pong!",
)
}
}
}
func registerDebug(a *app.App) func(h *app.Handler, args []string) {
return func(h *app.Handler, args []string) {
modified := false
revision := "-"
tags := "-"
_go := strings.TrimPrefix(runtime.Version(), "go")
gcCount := runtime.MemStats{}.NumGC
localTime := time.Now().Local().Format("2006-01-02 15:04:05")
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":
tags = strings.ReplaceAll(setting.Value, ",", " ")
}
}
if modified {
revision += " (uncommitted changes)"
}
h.Session.ChannelMessageSend(
h.Message.ChannelID,
fmt.Sprintf(
"``` Revision :: %s\nBuild Tags :: %s\nGo version :: %s\n OS/Arch :: %s\n GC Count :: %d\nLocal Time :: %s```",
revision,
tags,
_go,
runtime.GOOS+"/"+runtime.GOARCH,
gcCount,
localTime,
),
)
}
}