| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- package cmd
- import (
- "context"
- "log/slog"
- "runtime"
- "github.com/ayn2op/discordo/internal/notifications"
- "github.com/ayn2op/tview"
- "github.com/diamondburned/arikawa/v3/api"
- "github.com/diamondburned/arikawa/v3/gateway"
- "github.com/diamondburned/arikawa/v3/utils/httputil/httpdriver"
- "github.com/diamondburned/arikawa/v3/utils/ws"
- "github.com/diamondburned/ningen/v3"
- )
- func openState(token string) error {
- api.UserAgent = app.cfg.Identify.UserAgent
- gateway.DefaultIdentity = gateway.IdentifyProperties{
- OS: runtime.GOOS,
- Device: "",
- Browser: app.cfg.Identify.Browser,
- BrowserVersion: app.cfg.Identify.BrowserVersion,
- BrowserUserAgent: app.cfg.Identify.UserAgent,
- }
- gateway.DefaultPresence = &gateway.UpdatePresenceCommand{
- Status: app.cfg.Identify.Status,
- }
- discordState = ningen.New(token)
- // Handlers
- discordState.AddHandler(onReady)
- discordState.AddHandler(onMessageCreate)
- discordState.AddHandler(onMessageDelete)
- discordState.AddHandler(func(event *gateway.GuildMembersChunkEvent) {
- app.messagesText.setFetchingChunk(false, uint(len(event.Members)))
- })
- discordState.AddHandler(func(event *gateway.GuildMemberRemoveEvent) {
- app.messageInput.cache.Invalidate(event.GuildID.String()+" "+event.User.Username, discordState.MemberState.SearchLimit)
- })
- discordState.AddHandler(func(event *ws.RawEvent) {
- slog.Debug(
- "new raw event",
- "code", event.OriginalCode,
- "type", event.OriginalType,
- "data", event.Raw,
- )
- })
- discordState.StateLog = func(err error) {
- slog.Error("state log", "err", err)
- }
- discordState.OnRequest = append(discordState.OnRequest, onRequest)
- return discordState.Open(context.TODO())
- }
- func onRequest(r httpdriver.Request) error {
- req, ok := r.(*httpdriver.DefaultRequest)
- if ok {
- slog.Debug("new HTTP request", "method", req.Method, "url", req.URL)
- }
- return nil
- }
- func onReady(r *gateway.ReadyEvent) {
- root := app.guildsTree.GetRoot()
- root.ClearChildren()
- style := app.cfg.Theme.GuildsTree.PrivateChannelStyle.Style
- dmNode := tview.NewTreeNode("Direct Messages").
- SetTextStyle(style).
- SetSelectedTextStyle(style.Reverse(true))
- root.AddChild(dmNode)
- for _, folder := range r.UserSettings.GuildFolders {
- if folder.ID == 0 && len(folder.GuildIDs) == 1 {
- guild, err := discordState.Cabinet.Guild(folder.GuildIDs[0])
- if err != nil {
- slog.Error(
- "failed to get guild from state",
- "guild_id",
- folder.GuildIDs[0],
- "err",
- err,
- )
- continue
- }
- app.guildsTree.createGuildNode(root, *guild)
- } else {
- app.guildsTree.createFolderNode(folder)
- }
- }
- app.guildsTree.SetCurrentNode(root)
- app.SetFocus(app.guildsTree)
- }
- func onMessageCreate(msg *gateway.MessageCreateEvent) {
- if app.guildsTree.selectedChannelID.IsValid() &&
- app.guildsTree.selectedChannelID == msg.ChannelID {
- app.messagesText.createMsg(msg.Message)
- app.Draw()
- }
- if err := notifications.HandleIncomingMessage(discordState, msg, app.cfg); err != nil {
- slog.Error("Notification failed", "err", err)
- }
- }
- func onMessageDelete(msg *gateway.MessageDeleteEvent) {
- if app.guildsTree.selectedChannelID == msg.ChannelID {
- app.messagesText.reset()
- app.messagesText.drawMsgs(msg.ChannelID)
- app.Draw()
- }
- }
|