state.go 3.0 KB

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