state.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package chat
  2. import (
  3. "context"
  4. "log/slog"
  5. "github.com/ayn2op/discordo/internal/http"
  6. "github.com/diamondburned/arikawa/v3/gateway"
  7. "github.com/diamondburned/arikawa/v3/session"
  8. "github.com/diamondburned/arikawa/v3/state"
  9. "github.com/diamondburned/arikawa/v3/state/store/defaultstore"
  10. "github.com/diamondburned/arikawa/v3/utils/handler"
  11. "github.com/diamondburned/arikawa/v3/utils/httputil"
  12. "github.com/diamondburned/arikawa/v3/utils/httputil/httpdriver"
  13. "github.com/diamondburned/arikawa/v3/utils/ws"
  14. "github.com/diamondburned/ningen/v3"
  15. )
  16. func (v *View) OpenState(token string) error {
  17. identifyProps := http.IdentifyProperties()
  18. gateway.DefaultIdentity = identifyProps
  19. gateway.DefaultPresence = &gateway.UpdatePresenceCommand{
  20. Status: v.cfg.Status,
  21. }
  22. id := gateway.DefaultIdentifier(token)
  23. id.Compress = false
  24. session := session.NewCustom(id, http.NewClient(token), handler.New())
  25. state := state.NewFromSession(session, defaultstore.New())
  26. v.state = ningen.FromState(state)
  27. // Handlers
  28. v.state.AddHandler(v.onRaw)
  29. v.state.AddHandler(v.onReady)
  30. v.state.AddHandler(v.onMessageCreate)
  31. v.state.AddHandler(v.onMessageUpdate)
  32. v.state.AddHandler(v.onMessageDelete)
  33. v.state.AddHandler(v.onReadUpdate)
  34. v.state.AddHandler(v.onGuildMembersChunk)
  35. v.state.AddHandler(v.onGuildMemberRemove)
  36. if v.cfg.TypingIndicator.Receive {
  37. v.state.AddHandler(v.onTypingStart)
  38. }
  39. v.state.StateLog = func(err error) {
  40. slog.Error("state log", "err", err)
  41. }
  42. v.state.OnRequest = append(v.state.OnRequest, httputil.WithHeaders(http.Headers()), v.onRequest)
  43. return v.state.Open(context.TODO())
  44. }
  45. func (v *View) CloseState() error {
  46. if v.state == nil {
  47. return nil
  48. }
  49. return v.state.Close()
  50. }
  51. func (v *View) onRequest(r httpdriver.Request) error {
  52. if req, ok := r.(*httpdriver.DefaultRequest); ok {
  53. slog.Debug("new HTTP request", "method", req.Method, "url", req.URL)
  54. }
  55. return nil
  56. }
  57. func (v *View) onRaw(event *ws.RawEvent) {
  58. slog.Debug(
  59. "new raw event",
  60. "code", event.OriginalCode,
  61. "type", event.OriginalType,
  62. // "data", event.Raw,
  63. )
  64. }
  65. func (v *View) onTypingStart(event *gateway.TypingStartEvent) {
  66. selectedChannel := v.SelectedChannel()
  67. if selectedChannel == nil {
  68. return
  69. }
  70. if selectedChannel.ID != event.ChannelID {
  71. return
  72. }
  73. me, err := v.state.Cabinet.Me()
  74. if err != nil {
  75. slog.Error("failed to get me from state", "err", err)
  76. return
  77. }
  78. if event.UserID == me.ID {
  79. return
  80. }
  81. v.addTyper(event.UserID)
  82. }