memo_organizer.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package postgres
  2. import (
  3. "context"
  4. "fmt"
  5. "strings"
  6. "github.com/usememos/memos/store"
  7. )
  8. func (d *DB) UpsertMemoOrganizer(ctx context.Context, upsert *store.MemoOrganizer) (*store.MemoOrganizer, error) {
  9. pinned := 0
  10. if upsert.Pinned {
  11. pinned = 1
  12. }
  13. stmt := `
  14. INSERT INTO memo_organizer (
  15. memo_id,
  16. user_id,
  17. pinned
  18. )
  19. VALUES (` + placeholders(3) + `)
  20. ON CONFLICT(memo_id, user_id) DO UPDATE
  21. SET pinned = EXCLUDED.pinned`
  22. if _, err := d.db.ExecContext(ctx, stmt, upsert.MemoID, upsert.UserID, pinned); err != nil {
  23. return nil, err
  24. }
  25. return upsert, nil
  26. }
  27. func (d *DB) ListMemoOrganizer(ctx context.Context, find *store.FindMemoOrganizer) ([]*store.MemoOrganizer, error) {
  28. where, args := []string{"1 = 1"}, []any{}
  29. if find.MemoID != 0 {
  30. where, args = append(where, "memo_id = "+placeholder(len(args)+1)), append(args, find.MemoID)
  31. }
  32. if find.UserID != 0 {
  33. where, args = append(where, "user_id = "+placeholder(len(args)+1)), append(args, find.UserID)
  34. }
  35. query := fmt.Sprintf(`
  36. SELECT
  37. memo_id,
  38. user_id,
  39. pinned
  40. FROM memo_organizer
  41. WHERE %s
  42. `, strings.Join(where, " AND "))
  43. rows, err := d.db.QueryContext(ctx, query, args...)
  44. if err != nil {
  45. return nil, err
  46. }
  47. defer rows.Close()
  48. list := []*store.MemoOrganizer{}
  49. for rows.Next() {
  50. memoOrganizer := &store.MemoOrganizer{}
  51. pinned := 0
  52. if err := rows.Scan(
  53. &memoOrganizer.MemoID,
  54. &memoOrganizer.UserID,
  55. &pinned,
  56. ); err != nil {
  57. return nil, err
  58. }
  59. memoOrganizer.Pinned = pinned == 1
  60. list = append(list, memoOrganizer)
  61. }
  62. if err := rows.Err(); err != nil {
  63. return nil, err
  64. }
  65. return list, nil
  66. }
  67. func (d *DB) DeleteMemoOrganizer(ctx context.Context, delete *store.DeleteMemoOrganizer) error {
  68. where, args := []string{}, []any{}
  69. if v := delete.MemoID; v != nil {
  70. where, args = append(where, "memo_id = "+placeholder(len(args)+1)), append(args, *v)
  71. }
  72. if v := delete.UserID; v != nil {
  73. where, args = append(where, "user_id = "+placeholder(len(args)+1)), append(args, *v)
  74. }
  75. stmt := `DELETE FROM memo_organizer WHERE ` + strings.Join(where, " AND ")
  76. if _, err := d.db.ExecContext(ctx, stmt, args...); err != nil {
  77. return err
  78. }
  79. return nil
  80. }