inbox.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. package sqlite
  2. import (
  3. "context"
  4. "strings"
  5. "github.com/pkg/errors"
  6. "google.golang.org/protobuf/encoding/protojson"
  7. storepb "github.com/usememos/memos/proto/gen/store"
  8. "github.com/usememos/memos/store"
  9. )
  10. func (d *DB) CreateInbox(ctx context.Context, create *store.Inbox) (*store.Inbox, error) {
  11. messageString := "{}"
  12. if create.Message != nil {
  13. bytes, err := protojson.Marshal(create.Message)
  14. if err != nil {
  15. return nil, errors.Wrap(err, "failed to marshal inbox message")
  16. }
  17. messageString = string(bytes)
  18. }
  19. fields := []string{"`sender_id`", "`receiver_id`", "`status`", "`message`"}
  20. placeholder := []string{"?", "?", "?", "?"}
  21. args := []any{create.SenderID, create.ReceiverID, create.Status, messageString}
  22. stmt := "INSERT INTO `inbox` (" + strings.Join(fields, ", ") + ") VALUES (" + strings.Join(placeholder, ", ") + ") RETURNING `id`, `created_ts`"
  23. if err := d.db.QueryRowContext(ctx, stmt, args...).Scan(
  24. &create.ID,
  25. &create.CreatedTs,
  26. ); err != nil {
  27. return nil, err
  28. }
  29. return create, nil
  30. }
  31. func (d *DB) ListInboxes(ctx context.Context, find *store.FindInbox) ([]*store.Inbox, error) {
  32. where, args := []string{"1 = 1"}, []any{}
  33. if find.ID != nil {
  34. where, args = append(where, "`id` = ?"), append(args, *find.ID)
  35. }
  36. if find.SenderID != nil {
  37. where, args = append(where, "`sender_id` = ?"), append(args, *find.SenderID)
  38. }
  39. if find.ReceiverID != nil {
  40. where, args = append(where, "`receiver_id` = ?"), append(args, *find.ReceiverID)
  41. }
  42. if find.Status != nil {
  43. where, args = append(where, "`status` = ?"), append(args, *find.Status)
  44. }
  45. query := "SELECT `id`, `created_ts`, `sender_id`, `receiver_id`, `status`, `message` FROM `inbox` WHERE " + strings.Join(where, " AND ") + " ORDER BY `created_ts` DESC"
  46. rows, err := d.db.QueryContext(ctx, query, args...)
  47. if err != nil {
  48. return nil, err
  49. }
  50. defer rows.Close()
  51. list := []*store.Inbox{}
  52. for rows.Next() {
  53. inbox := &store.Inbox{}
  54. var messageBytes []byte
  55. if err := rows.Scan(
  56. &inbox.ID,
  57. &inbox.CreatedTs,
  58. &inbox.SenderID,
  59. &inbox.ReceiverID,
  60. &inbox.Status,
  61. &messageBytes,
  62. ); err != nil {
  63. return nil, err
  64. }
  65. message := &storepb.InboxMessage{}
  66. if err := protojsonUnmarshaler.Unmarshal(messageBytes, message); err != nil {
  67. return nil, err
  68. }
  69. inbox.Message = message
  70. list = append(list, inbox)
  71. }
  72. if err := rows.Err(); err != nil {
  73. return nil, err
  74. }
  75. return list, nil
  76. }
  77. func (d *DB) UpdateInbox(ctx context.Context, update *store.UpdateInbox) (*store.Inbox, error) {
  78. set, args := []string{"`status` = ?"}, []any{update.Status.String()}
  79. args = append(args, update.ID)
  80. query := "UPDATE `inbox` SET " + strings.Join(set, ", ") + " WHERE `id` = ? RETURNING `id`, `created_ts`, `sender_id`, `receiver_id`, `status`, `message`"
  81. inbox := &store.Inbox{}
  82. var messageBytes []byte
  83. if err := d.db.QueryRowContext(ctx, query, args...).Scan(
  84. &inbox.ID,
  85. &inbox.CreatedTs,
  86. &inbox.SenderID,
  87. &inbox.ReceiverID,
  88. &inbox.Status,
  89. &messageBytes,
  90. ); err != nil {
  91. return nil, err
  92. }
  93. message := &storepb.InboxMessage{}
  94. if err := protojsonUnmarshaler.Unmarshal(messageBytes, message); err != nil {
  95. return nil, err
  96. }
  97. inbox.Message = message
  98. return inbox, nil
  99. }
  100. func (d *DB) DeleteInbox(ctx context.Context, delete *store.DeleteInbox) error {
  101. result, err := d.db.ExecContext(ctx, "DELETE FROM `inbox` WHERE `id` = ?", delete.ID)
  102. if err != nil {
  103. return err
  104. }
  105. if _, err := result.RowsAffected(); err != nil {
  106. return err
  107. }
  108. return nil
  109. }