state.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. package cmd
  2. import (
  3. "context"
  4. "log/slog"
  5. "runtime"
  6. "github.com/ayn2op/discordo/internal/notifications"
  7. "github.com/ayn2op/tview"
  8. "github.com/diamondburned/arikawa/v3/api"
  9. "github.com/diamondburned/arikawa/v3/gateway"
  10. "github.com/diamondburned/arikawa/v3/utils/httputil/httpdriver"
  11. "github.com/diamondburned/arikawa/v3/utils/ws"
  12. "github.com/diamondburned/ningen/v3"
  13. )
  14. func openState(token string) error {
  15. api.UserAgent = app.cfg.Identify.UserAgent
  16. gateway.DefaultIdentity = gateway.IdentifyProperties{
  17. OS: runtime.GOOS,
  18. Device: "",
  19. Browser: app.cfg.Identify.Browser,
  20. BrowserVersion: app.cfg.Identify.BrowserVersion,
  21. BrowserUserAgent: app.cfg.Identify.UserAgent,
  22. }
  23. gateway.DefaultPresence = &gateway.UpdatePresenceCommand{
  24. Status: app.cfg.Identify.Status,
  25. }
  26. discordState = ningen.New(token)
  27. // Handlers
  28. discordState.AddHandler(onReady)
  29. discordState.AddHandler(onMessageCreate)
  30. discordState.AddHandler(onMessageDelete)
  31. discordState.AddHandler(func(event *gateway.GuildMembersChunkEvent) {
  32. app.messagesText.setFetchingChunk(false, uint(len(event.Members)))
  33. })
  34. discordState.AddHandler(func(event *gateway.GuildMemberRemoveEvent) {
  35. app.messageInput.cache.Invalidate(event.GuildID.String()+" "+event.User.Username, discordState.MemberState.SearchLimit)
  36. })
  37. discordState.AddHandler(func(event *ws.RawEvent) {
  38. slog.Debug(
  39. "new raw event",
  40. "code", event.OriginalCode,
  41. "type", event.OriginalType,
  42. "data", event.Raw,
  43. )
  44. })
  45. discordState.StateLog = func(err error) {
  46. slog.Error("state log", "err", err)
  47. }
  48. discordState.OnRequest = append(discordState.OnRequest, onRequest)
  49. return discordState.Open(context.TODO())
  50. }
  51. func onRequest(r httpdriver.Request) error {
  52. req, ok := r.(*httpdriver.DefaultRequest)
  53. if ok {
  54. slog.Debug("new HTTP request", "method", req.Method, "url", req.URL)
  55. }
  56. return nil
  57. }
  58. func onReady(r *gateway.ReadyEvent) {
  59. root := app.guildsTree.GetRoot()
  60. root.ClearChildren()
  61. style := app.cfg.Theme.GuildsTree.PrivateChannelStyle.Style
  62. dmNode := tview.NewTreeNode("Direct Messages").
  63. SetTextStyle(style).
  64. SetSelectedTextStyle(style.Reverse(true))
  65. root.AddChild(dmNode)
  66. for _, folder := range r.UserSettings.GuildFolders {
  67. if folder.ID == 0 && len(folder.GuildIDs) == 1 {
  68. guild, err := discordState.Cabinet.Guild(folder.GuildIDs[0])
  69. if err != nil {
  70. slog.Error(
  71. "failed to get guild from state",
  72. "guild_id",
  73. folder.GuildIDs[0],
  74. "err",
  75. err,
  76. )
  77. continue
  78. }
  79. app.guildsTree.createGuildNode(root, *guild)
  80. } else {
  81. app.guildsTree.createFolderNode(folder)
  82. }
  83. }
  84. app.guildsTree.SetCurrentNode(root)
  85. app.SetFocus(app.guildsTree)
  86. }
  87. func onMessageCreate(m *gateway.MessageCreateEvent) {
  88. if app.guildsTree.selectedChannelID.IsValid() &&
  89. app.guildsTree.selectedChannelID == m.ChannelID {
  90. app.messagesText.createMsg(m.Message)
  91. app.Draw()
  92. }
  93. if err := notifications.HandleIncomingMessage(discordState, m, app.cfg); err != nil {
  94. slog.Error("Notification failed", "err", err)
  95. }
  96. }
  97. func onMessageDelete(m *gateway.MessageDeleteEvent) {
  98. if app.guildsTree.selectedChannelID == m.ChannelID {
  99. app.messagesText.reset()
  100. app.messagesText.drawMsgs(m.ChannelID)
  101. app.Draw()
  102. }
  103. }