applesauce-core 1.0.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (194) hide show
  1. package/README.md +7 -13
  2. package/dist/event-store/{database.d.ts → event-set.d.ts} +35 -20
  3. package/dist/event-store/{database.js → event-set.js} +91 -60
  4. package/dist/event-store/event-store.d.ts +64 -25
  5. package/dist/event-store/event-store.js +163 -206
  6. package/dist/event-store/index.d.ts +1 -1
  7. package/dist/event-store/index.js +1 -1
  8. package/dist/event-store/interface.d.ts +71 -13
  9. package/dist/helpers/app-handlers.d.ts +23 -0
  10. package/dist/helpers/app-handlers.js +68 -0
  11. package/dist/helpers/article.d.ts +9 -0
  12. package/dist/helpers/article.js +21 -0
  13. package/dist/helpers/blossom.d.ts +2 -0
  14. package/dist/helpers/blossom.js +18 -0
  15. package/dist/helpers/bolt11.d.ts +1 -0
  16. package/dist/helpers/bolt11.js +2 -0
  17. package/dist/helpers/bookmarks.js +1 -2
  18. package/dist/helpers/emoji.d.ts +10 -2
  19. package/dist/helpers/emoji.js +21 -3
  20. package/dist/helpers/encrypted-content-cache.d.ts +15 -0
  21. package/dist/helpers/encrypted-content-cache.js +125 -0
  22. package/dist/helpers/encrypted-content.d.ts +48 -0
  23. package/dist/helpers/encrypted-content.js +65 -0
  24. package/dist/helpers/encryption.d.ts +5 -0
  25. package/dist/helpers/encryption.js +10 -0
  26. package/dist/helpers/event.d.ts +4 -1
  27. package/dist/helpers/event.js +13 -3
  28. package/dist/helpers/expiration.d.ts +6 -0
  29. package/dist/helpers/expiration.js +16 -0
  30. package/dist/helpers/filter.d.ts +1 -3
  31. package/dist/helpers/filter.js +1 -3
  32. package/dist/helpers/gift-wraps.d.ts +17 -5
  33. package/dist/helpers/gift-wraps.js +65 -27
  34. package/dist/helpers/groups.d.ts +5 -0
  35. package/dist/helpers/groups.js +12 -2
  36. package/dist/helpers/hidden-content.d.ts +27 -32
  37. package/dist/helpers/hidden-content.js +35 -65
  38. package/dist/helpers/hidden-tags.d.ts +23 -4
  39. package/dist/helpers/hidden-tags.js +39 -4
  40. package/dist/helpers/index.d.ts +11 -1
  41. package/dist/helpers/index.js +11 -1
  42. package/dist/helpers/legacy-messages.d.ts +21 -0
  43. package/dist/helpers/legacy-messages.js +39 -0
  44. package/dist/helpers/lists.d.ts +1 -1
  45. package/dist/helpers/lists.js +2 -2
  46. package/dist/helpers/messages.d.ts +11 -0
  47. package/dist/helpers/messages.js +19 -0
  48. package/dist/helpers/mutes.js +1 -1
  49. package/dist/helpers/pointers.d.ts +33 -9
  50. package/dist/helpers/pointers.js +80 -44
  51. package/dist/helpers/profile.d.ts +10 -2
  52. package/dist/helpers/profile.js +33 -4
  53. package/dist/helpers/reactions.d.ts +8 -0
  54. package/dist/helpers/reactions.js +56 -0
  55. package/dist/helpers/reports.d.ts +28 -0
  56. package/dist/helpers/reports.js +38 -0
  57. package/dist/helpers/share.d.ts +10 -1
  58. package/dist/helpers/share.js +22 -8
  59. package/dist/helpers/url.d.ts +4 -0
  60. package/dist/helpers/url.js +20 -0
  61. package/dist/helpers/user-status.js +2 -1
  62. package/dist/helpers/wrapped-messages.d.ts +23 -0
  63. package/dist/helpers/wrapped-messages.js +38 -0
  64. package/dist/helpers/zap.d.ts +8 -5
  65. package/dist/helpers/zap.js +11 -6
  66. package/dist/index.d.ts +2 -2
  67. package/dist/index.js +2 -2
  68. package/dist/models/blossom.d.ts +3 -0
  69. package/dist/models/blossom.js +8 -0
  70. package/dist/models/bookmarks.d.ts +8 -0
  71. package/dist/{queries → models}/bookmarks.js +9 -9
  72. package/dist/models/channels.d.ts +11 -0
  73. package/dist/{queries → models}/channels.js +9 -9
  74. package/dist/models/comments.d.ts +4 -0
  75. package/dist/models/comments.js +11 -0
  76. package/dist/models/common.d.ts +16 -0
  77. package/dist/models/common.js +176 -0
  78. package/dist/models/contacts.d.ts +8 -0
  79. package/dist/{queries → models}/contacts.js +10 -10
  80. package/dist/models/encrypted-content.d.ts +4 -0
  81. package/dist/models/encrypted-content.js +11 -0
  82. package/dist/models/gift-wrap.d.ts +7 -0
  83. package/dist/models/gift-wrap.js +20 -0
  84. package/dist/{queries → models}/index.d.ts +6 -2
  85. package/dist/{queries → models}/index.js +6 -2
  86. package/dist/models/legacy-messages.d.ts +8 -0
  87. package/dist/models/legacy-messages.js +29 -0
  88. package/dist/models/mailboxes.d.ts +6 -0
  89. package/dist/{queries → models}/mailboxes.js +2 -2
  90. package/dist/models/mutes.d.ts +8 -0
  91. package/dist/{queries → models}/mutes.js +9 -9
  92. package/dist/models/pins.d.ts +4 -0
  93. package/dist/{queries → models}/pins.js +3 -3
  94. package/dist/models/profile.d.ts +4 -0
  95. package/dist/models/profile.js +14 -0
  96. package/dist/models/reactions.d.ts +4 -0
  97. package/dist/{queries → models}/reactions.js +2 -2
  98. package/dist/models/relays.d.ts +27 -0
  99. package/dist/{queries → models}/relays.js +13 -13
  100. package/dist/{queries → models}/thread.d.ts +6 -5
  101. package/dist/{queries → models}/thread.js +4 -3
  102. package/dist/models/user-status.d.ts +11 -0
  103. package/dist/{queries → models}/user-status.js +5 -5
  104. package/dist/models/wrapped-messages.d.ts +25 -0
  105. package/dist/models/wrapped-messages.js +61 -0
  106. package/dist/models/zaps.d.ts +9 -0
  107. package/dist/{queries → models}/zaps.js +11 -3
  108. package/dist/observable/claim-events.d.ts +3 -3
  109. package/dist/observable/claim-events.js +4 -4
  110. package/dist/observable/claim-latest.d.ts +3 -3
  111. package/dist/observable/claim-latest.js +4 -4
  112. package/dist/observable/index.d.ts +5 -1
  113. package/dist/observable/index.js +6 -1
  114. package/dist/observable/map-events-timeline.d.ts +7 -0
  115. package/dist/observable/map-events-timeline.js +9 -0
  116. package/dist/observable/map-events-to-store.d.ts +5 -0
  117. package/dist/observable/map-events-to-store.js +12 -0
  118. package/dist/observable/simple-timeout.d.ts +1 -0
  119. package/dist/observable/simple-timeout.js +1 -0
  120. package/dist/observable/watch-event-updates.d.ts +7 -0
  121. package/dist/observable/watch-event-updates.js +25 -0
  122. package/package.json +11 -16
  123. package/dist/__tests__/fixtures.d.ts +0 -8
  124. package/dist/__tests__/fixtures.js +0 -20
  125. package/dist/event-store/__tests__/event-store.test.d.ts +0 -1
  126. package/dist/event-store/__tests__/event-store.test.js +0 -354
  127. package/dist/helpers/__tests__/blossom.test.d.ts +0 -1
  128. package/dist/helpers/__tests__/blossom.test.js +0 -13
  129. package/dist/helpers/__tests__/bookmarks.test.d.ts +0 -1
  130. package/dist/helpers/__tests__/bookmarks.test.js +0 -88
  131. package/dist/helpers/__tests__/comment.test.d.ts +0 -1
  132. package/dist/helpers/__tests__/comment.test.js +0 -249
  133. package/dist/helpers/__tests__/contacts.test.d.ts +0 -1
  134. package/dist/helpers/__tests__/contacts.test.js +0 -34
  135. package/dist/helpers/__tests__/emoji.test.d.ts +0 -1
  136. package/dist/helpers/__tests__/emoji.test.js +0 -15
  137. package/dist/helpers/__tests__/event.test.d.ts +0 -1
  138. package/dist/helpers/__tests__/event.test.js +0 -36
  139. package/dist/helpers/__tests__/events.test.d.ts +0 -1
  140. package/dist/helpers/__tests__/events.test.js +0 -32
  141. package/dist/helpers/__tests__/file-metadata.test.d.ts +0 -1
  142. package/dist/helpers/__tests__/file-metadata.test.js +0 -103
  143. package/dist/helpers/__tests__/hidden-tags.test.d.ts +0 -1
  144. package/dist/helpers/__tests__/hidden-tags.test.js +0 -29
  145. package/dist/helpers/__tests__/mailboxes.test.d.ts +0 -1
  146. package/dist/helpers/__tests__/mailboxes.test.js +0 -81
  147. package/dist/helpers/__tests__/mutes.test.d.ts +0 -1
  148. package/dist/helpers/__tests__/mutes.test.js +0 -55
  149. package/dist/helpers/__tests__/nip-19.test.d.ts +0 -1
  150. package/dist/helpers/__tests__/nip-19.test.js +0 -42
  151. package/dist/helpers/__tests__/relays.test.d.ts +0 -1
  152. package/dist/helpers/__tests__/relays.test.js +0 -21
  153. package/dist/helpers/__tests__/tags.test.d.ts +0 -1
  154. package/dist/helpers/__tests__/tags.test.js +0 -24
  155. package/dist/helpers/__tests__/threading.test.d.ts +0 -1
  156. package/dist/helpers/__tests__/threading.test.js +0 -41
  157. package/dist/helpers/direct-messages.d.ts +0 -4
  158. package/dist/helpers/direct-messages.js +0 -5
  159. package/dist/helpers/nip-19.d.ts +0 -18
  160. package/dist/helpers/nip-19.js +0 -56
  161. package/dist/observable/__tests__/claim-events.test.d.ts +0 -1
  162. package/dist/observable/__tests__/claim-events.test.js +0 -23
  163. package/dist/observable/__tests__/claim-latest.test.d.ts +0 -1
  164. package/dist/observable/__tests__/claim-latest.test.js +0 -37
  165. package/dist/observable/__tests__/listen-latest-updates.test.d.ts +0 -1
  166. package/dist/observable/__tests__/listen-latest-updates.test.js +0 -55
  167. package/dist/observable/__tests__/simple-timeout.test.d.ts +0 -1
  168. package/dist/observable/__tests__/simple-timeout.test.js +0 -34
  169. package/dist/observable/listen-latest-updates.d.ts +0 -5
  170. package/dist/observable/listen-latest-updates.js +0 -12
  171. package/dist/queries/blossom.d.ts +0 -2
  172. package/dist/queries/blossom.js +0 -5
  173. package/dist/queries/bookmarks.d.ts +0 -8
  174. package/dist/queries/channels.d.ts +0 -11
  175. package/dist/queries/comments.d.ts +0 -4
  176. package/dist/queries/comments.js +0 -11
  177. package/dist/queries/contacts.d.ts +0 -8
  178. package/dist/queries/mailboxes.d.ts +0 -6
  179. package/dist/queries/mutes.d.ts +0 -8
  180. package/dist/queries/pins.d.ts +0 -4
  181. package/dist/queries/profile.d.ts +0 -4
  182. package/dist/queries/profile.js +0 -7
  183. package/dist/queries/reactions.d.ts +0 -4
  184. package/dist/queries/relays.d.ts +0 -27
  185. package/dist/queries/simple.d.ts +0 -16
  186. package/dist/queries/simple.js +0 -21
  187. package/dist/queries/user-status.d.ts +0 -11
  188. package/dist/queries/zaps.d.ts +0 -5
  189. package/dist/query-store/__tests__/query-store.test.d.ts +0 -1
  190. package/dist/query-store/__tests__/query-store.test.js +0 -63
  191. package/dist/query-store/index.d.ts +0 -1
  192. package/dist/query-store/index.js +0 -1
  193. package/dist/query-store/query-store.d.ts +0 -54
  194. package/dist/query-store/query-store.js +0 -102
@@ -1,249 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { getCommentAddressPointer, getCommentEventPointer, getCommentExternalPointer, getCommentReplyPointer, getCommentRootPointer, } from "../comment.js";
3
- import { FakeUser } from "../../__tests__/fixtures.js";
4
- const user = new FakeUser();
5
- describe("getCommentRootPointer", () => {
6
- it("should throw if event is not a comment", () => {
7
- expect(() => {
8
- getCommentRootPointer(user.note("testing"));
9
- }).toThrow("Event is not a comment");
10
- });
11
- });
12
- describe("getCommentReplyPointer", () => {
13
- it("should throw if event is not a comment", () => {
14
- expect(() => {
15
- getCommentReplyPointer(user.note("testing"));
16
- }).toThrow("Event is not a comment");
17
- });
18
- });
19
- describe("getCommentEventPointer", () => {
20
- it("should get pubkey from P tag when root=true", () => {
21
- const tags = [
22
- ["E", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f"],
23
- ["K", "1621"],
24
- ["P", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
25
- ["k", "1621"],
26
- ["p", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
27
- ["e", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f"],
28
- ];
29
- expect(getCommentEventPointer(tags, true)).toEqual({
30
- type: "event",
31
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
32
- kind: 1621,
33
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
34
- relay: undefined,
35
- });
36
- });
37
- it("should default to pubkey in E tag when root pubkey do not match", () => {
38
- const tags = [
39
- [
40
- "E",
41
- "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
42
- "",
43
- "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
44
- ],
45
- ["K", "1621"],
46
- ["P", "bad-pubkey"],
47
- ];
48
- expect(getCommentEventPointer(tags, true)).toEqual({
49
- type: "event",
50
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
51
- kind: 1621,
52
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
53
- relay: undefined,
54
- });
55
- });
56
- it("should get pubkey from E tag", () => {
57
- const tags = [
58
- [
59
- "E",
60
- "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
61
- "",
62
- "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
63
- ],
64
- ["K", "1621"],
65
- ];
66
- expect(getCommentEventPointer(tags, true)).toEqual({
67
- type: "event",
68
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
69
- kind: 1621,
70
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
71
- relay: undefined,
72
- });
73
- });
74
- it("should get relay from E tag", () => {
75
- const tags = [
76
- ["E", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f", "wss://relay.io/"],
77
- ["K", "1621"],
78
- ["P", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
79
- ];
80
- expect(getCommentEventPointer(tags, true)).toEqual({
81
- type: "event",
82
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
83
- kind: 1621,
84
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
85
- relay: "wss://relay.io/",
86
- });
87
- });
88
- it("should throw if K tag is missing", () => {
89
- const tags = [
90
- ["E", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f", "wss://relay.io/"],
91
- ["P", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
92
- ];
93
- expect(() => {
94
- getCommentEventPointer(tags, true);
95
- }).toThrow("Missing kind tag");
96
- });
97
- it("should return null if missing E tag", () => {
98
- const tags = [
99
- ["K", "1621"],
100
- ["P", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
101
- ];
102
- expect(getCommentEventPointer(tags, true)).toBe(null);
103
- expect(getCommentEventPointer(tags)).toBe(null);
104
- });
105
- });
106
- describe("getCommentAddressPointer", () => {
107
- it("should get event id from E tag", () => {
108
- // root
109
- expect(getCommentAddressPointer([
110
- ["A", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
111
- ["E", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f"],
112
- ["K", "30000"],
113
- ], true)).toEqual({
114
- type: "address",
115
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
116
- kind: 30000,
117
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
118
- identifier: "list",
119
- });
120
- // reply
121
- expect(getCommentAddressPointer([
122
- ["a", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
123
- ["e", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f"],
124
- ["k", "30000"],
125
- ])).toEqual({
126
- type: "address",
127
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
128
- kind: 30000,
129
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
130
- identifier: "list",
131
- });
132
- });
133
- it("should get relay from A tag", () => {
134
- // root
135
- expect(getCommentAddressPointer([
136
- ["A", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list", "wss://relay.io/"],
137
- ["K", "30000"],
138
- ], true)).toEqual({
139
- type: "address",
140
- kind: 30000,
141
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
142
- identifier: "list",
143
- relay: "wss://relay.io/",
144
- });
145
- // reply
146
- expect(getCommentAddressPointer([
147
- ["a", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list", "wss://relay.io/"],
148
- ["k", "30000"],
149
- ])).toEqual({
150
- type: "address",
151
- kind: 30000,
152
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
153
- identifier: "list",
154
- relay: "wss://relay.io/",
155
- });
156
- });
157
- it("should get relay from E tag", () => {
158
- // root
159
- expect(getCommentAddressPointer([
160
- ["A", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
161
- ["E", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f", "wss://relay.io/"],
162
- ["K", "30000"],
163
- ], true)).toEqual({
164
- type: "address",
165
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
166
- kind: 30000,
167
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
168
- identifier: "list",
169
- relay: "wss://relay.io/",
170
- });
171
- // reply
172
- expect(getCommentAddressPointer([
173
- ["a", "30000:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
174
- ["e", "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f", "wss://relay.io/"],
175
- ["k", "30000"],
176
- ])).toEqual({
177
- type: "address",
178
- id: "86c0b95589b016ffb703bfc080d49e54106e74e2d683295119c3453e494dbe6f",
179
- kind: 30000,
180
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
181
- identifier: "list",
182
- relay: "wss://relay.io/",
183
- });
184
- });
185
- it("should return A tag kind over K tag", () => {
186
- // root
187
- expect(getCommentAddressPointer([
188
- ["A", "30010:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
189
- ["K", "30000"],
190
- ], true)).toEqual({
191
- type: "address",
192
- kind: 30010,
193
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
194
- identifier: "list",
195
- });
196
- // reply
197
- expect(getCommentAddressPointer([
198
- ["a", "30010:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"],
199
- ["k", "30000"],
200
- ])).toEqual({
201
- type: "address",
202
- kind: 30010,
203
- pubkey: "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10",
204
- identifier: "list",
205
- });
206
- });
207
- it("should throw if missing K tag", () => {
208
- // root
209
- expect(() => getCommentAddressPointer([["A", "30010:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"]], true)).toThrow("Missing kind tag");
210
- // reply
211
- expect(() => getCommentAddressPointer([["a", "30010:e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10:list"]])).toThrow("Missing kind tag");
212
- });
213
- it("should return null if missing A tag", () => {
214
- const tags = [
215
- ["K", "1621"],
216
- ["P", "e4336cd525df79fa4d3af364fd9600d4b10dce4215aa4c33ed77ea0842344b10"],
217
- ];
218
- expect(getCommentEventPointer(tags, true)).toBe(null);
219
- expect(getCommentEventPointer(tags)).toBe(null);
220
- });
221
- });
222
- describe("getCommentExternalPointer", () => {
223
- it("should get kind prefix from I tag", () => {
224
- // root
225
- expect(getCommentExternalPointer([
226
- ["I", "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f"],
227
- ["K", "podcast:item:guid"],
228
- ], true)).toEqual({
229
- type: "external",
230
- identifier: "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f",
231
- kind: "podcast:item:guid",
232
- });
233
- // reply
234
- expect(getCommentExternalPointer([
235
- ["i", "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f"],
236
- ["k", "podcast:item:guid"],
237
- ])).toEqual({
238
- type: "external",
239
- identifier: "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f",
240
- kind: "podcast:item:guid",
241
- });
242
- });
243
- it("should throw if missing K tag", () => {
244
- // root
245
- expect(() => getCommentExternalPointer([["I", "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f"]], true)).toThrow("Missing kind tag");
246
- // reply
247
- expect(() => getCommentExternalPointer([["i", "podcast:item:guid:d98d189b-dc7b-45b1-8720-d4b98690f31f"]])).toThrow("Missing kind tag");
248
- });
249
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,34 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { mergeContacts } from "../contacts.js";
3
- describe("mergeContacts", () => {
4
- it("should merge contacts and remove duplicates", () => {
5
- // Create some test profile pointers
6
- const pointer1 = { pubkey: "pubkey1", relays: ["relay1"] };
7
- const pointer2 = { pubkey: "pubkey2" }; // No relays
8
- const pointer3 = { pubkey: "pubkey3", relays: ["relay3"] };
9
- const pointer4 = { pubkey: "pubkey1" }; // Duplicate pubkey without relays
10
- // Test merging arrays of pointers
11
- const result1 = mergeContacts([pointer1, pointer2], [pointer3, pointer4]);
12
- // Should have 3 unique pubkeys
13
- expect(result1.length).toBe(3);
14
- // Check that the duplicate was handled correctly (last one should win)
15
- const pubkey1Entry = result1.find((p) => p.pubkey === "pubkey1");
16
- expect(pubkey1Entry).toBeDefined();
17
- expect(pubkey1Entry?.relays).toBeUndefined();
18
- // Test with undefined values
19
- const result2 = mergeContacts([pointer1], undefined, [pointer2, undefined]);
20
- expect(result2.length).toBe(2);
21
- // Test with single pointers
22
- const result3 = mergeContacts(pointer1, pointer2, pointer1);
23
- expect(result3.length).toBe(2);
24
- // Test with empty arrays
25
- const result4 = mergeContacts([], [pointer1], []);
26
- expect(result4.length).toBe(1);
27
- // Test with pointers that have and don't have relays
28
- const pointer5 = { pubkey: "pubkey5", relays: ["relay5"] };
29
- const pointer6 = { pubkey: "pubkey5" }; // Same pubkey without relays
30
- const result5 = mergeContacts([pointer5], [pointer6]);
31
- expect(result5.length).toBe(1);
32
- expect(result5[0].relays).toBeUndefined();
33
- });
34
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,15 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { getEmojiTag } from "../emoji.js";
3
- import { FakeUser } from "../../__tests__/fixtures.js";
4
- const user = new FakeUser();
5
- describe("getEmojiTag", () => {
6
- it("Should find emoji tag", () => {
7
- expect(getEmojiTag(user.note("hello :custom:", { tags: [["emoji", "custom", "https://cdn.example.com/reaction1.png"]] }), "custom")).toEqual(["emoji", "custom", "https://cdn.example.com/reaction1.png"]);
8
- });
9
- it("Should custom leading and trailing :", () => {
10
- expect(getEmojiTag(user.note("hello :custom:", { tags: [["emoji", "custom", "https://cdn.example.com/reaction1.png"]] }), ":custom:")).toEqual(["emoji", "custom", "https://cdn.example.com/reaction1.png"]);
11
- });
12
- it("Should convert to lowercase", () => {
13
- expect(getEmojiTag(user.note("hello :custom:", { tags: [["emoji", "custom", "https://cdn.example.com/reaction1.png"]] }), "CustoM")).toEqual(["emoji", "custom", "https://cdn.example.com/reaction1.png"]);
14
- });
15
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,36 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { EventIndexableTagsSymbol, getIndexableTags, getTagValue } from "../event.js";
3
- const event = {
4
- content: "",
5
- created_at: 1732889913,
6
- id: "2d53511f321cc82dd13eedfb597c9fe834d12d271c10d8068e9d8cfb8f58d1b4",
7
- kind: 30000,
8
- pubkey: "266815e0c9210dfa324c6cba3573b14bee49da4209a9456f9484e5106cd408a5",
9
- sig: "e6a442487ef44a8a00ec1e0a852e547991fcd5cbf19aa1a4219fa65d6f41022675e0745207649f4b16fe9a6c5c7c3693dc3e13966ffa5b2891634867c874cf22",
10
- tags: [
11
- ["d", "qRxLhBbTfRlxsvKSu0iUl"],
12
- ["title", "Musicians"],
13
- ["client", "noStrudel", "31990:266815e0c9210dfa324c6cba3573b14bee49da4209a9456f9484e5106cd408a5:1686066542546"],
14
- ["p", "2842e34860c59dfacd5df48ba7a65065e6760d08c35f779553d83c2c2310b493"],
15
- ["p", "28ca019b78b494c25a9da2d645975a8501c7e99b11302e5cbe748ee593fcb2cc"],
16
- ["p", "f46192b8b9be1b43fc30ea27c7cb16210aede17252b3aa9692fbb3f2ba153199"],
17
- ],
18
- };
19
- describe("getIndexableTags", () => {
20
- it("should return a set of indexable tags for event", () => {
21
- expect(Array.from(getIndexableTags(event))).toEqual(expect.arrayContaining([
22
- "p:2842e34860c59dfacd5df48ba7a65065e6760d08c35f779553d83c2c2310b493",
23
- "p:28ca019b78b494c25a9da2d645975a8501c7e99b11302e5cbe748ee593fcb2cc",
24
- "p:f46192b8b9be1b43fc30ea27c7cb16210aede17252b3aa9692fbb3f2ba153199",
25
- ]));
26
- });
27
- it("should cache value on EventIndexableTagsSymbol", () => {
28
- getIndexableTags(event);
29
- expect(Reflect.has(event, EventIndexableTagsSymbol)).toBe(true);
30
- });
31
- });
32
- describe("getTagValue", () => {
33
- it("should return value of tag if present", () => {
34
- expect(getTagValue(event, "title")).toBe("Musicians");
35
- });
36
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,32 +0,0 @@
1
- import { kinds } from "nostr-tools";
2
- import { describe, expect, it } from "vitest";
3
- import { FakeUser } from "../../__tests__/fixtures.js";
4
- import { getReplaceableAddress } from "../event.js";
5
- const user = new FakeUser();
6
- describe("getReplaceableAddress", () => {
7
- it("should throw an error for non-replaceable events", () => {
8
- const normalEvent = user.note("Hello world");
9
- expect(() => {
10
- getReplaceableAddress(normalEvent);
11
- }).toThrow("Event is not replaceable or addressable");
12
- });
13
- it("should return the correct address for replaceable events", () => {
14
- const replaceableEvent = user.event({
15
- kind: kinds.Metadata,
16
- content: JSON.stringify({ name: "Test User" }),
17
- tags: [],
18
- });
19
- const expectedAddress = `${kinds.Metadata}:${user.pubkey}:`;
20
- expect(getReplaceableAddress(replaceableEvent)).toBe(expectedAddress);
21
- });
22
- it("should include the identifier for addressable events", () => {
23
- const identifier = "test-profile";
24
- const addressableEvent = user.event({
25
- kind: 30000, // Parameterized replaceable event
26
- content: "Test content",
27
- tags: [["d", identifier]],
28
- });
29
- const expectedAddress = `30000:${user.pubkey}:${identifier}`;
30
- expect(getReplaceableAddress(addressableEvent)).toBe(expectedAddress);
31
- });
32
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,103 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { getFileMetadataFromImetaTag, parseFileMetadataTags } from "../file-metadata.js";
3
- describe("file metadata helpers", () => {
4
- describe("parseFileMetadataTags", () => {
5
- it("should parse a simple 1060 event", () => {
6
- const tags = [
7
- ["url", "https://image.nostr.build/30696696e57a2732d4e9f1b15ff4d4d4eaa64b759df6876863f436ff5d736eae.gif"],
8
- ["ox", "30696696e57a2732d4e9f1b15ff4d4d4eaa64b759df6876863f436ff5d736eae"],
9
- ["fallback", "https://media.tenor.com/wpvrkjn192gAAAAC/daenerys-targaryen.gif"],
10
- ["x", "77fcf42b2b720babcdbe686eff67273d8a68862d74a2672db672bc48439a3ea5"],
11
- ["m", "image/gif"],
12
- ["dim", "360x306"],
13
- ["bh", "L38zleNL00~W^kRj0L-p0KM_^kx]"],
14
- ["blurhash", "L38zleNL00~W^kRj0L-p0KM_^kx]"],
15
- [
16
- "thumb",
17
- "https://image.nostr.build/thumb/30696696e57a2732d4e9f1b15ff4d4d4eaa64b759df6876863f436ff5d736eae.gif",
18
- ],
19
- ["t", "gifbuddy"],
20
- ["summary", "Khaleesi call dragons Daenerys Targaryen"],
21
- ["alt", "a woman with blonde hair and a brooch on her shoulder"],
22
- [
23
- "thumb",
24
- "https://media.tenor.com/wpvrkjn192gAAAAx/daenerys-targaryen.webp",
25
- "5d92423664fc15874b1d26c70a05a541ec09b5c438bf157977a87c8e64b31463",
26
- ],
27
- [
28
- "image",
29
- "https://media.tenor.com/wpvrkjn192gAAAAe/daenerys-targaryen.png",
30
- "5d92423664fc15874b1d26c70a05a541ec09b5c438bf157977a87c8e64b31463",
31
- ],
32
- ];
33
- expect(parseFileMetadataTags(tags)).toEqual({
34
- url: "https://image.nostr.build/30696696e57a2732d4e9f1b15ff4d4d4eaa64b759df6876863f436ff5d736eae.gif",
35
- type: "image/gif",
36
- dimensions: "360x306",
37
- blurhash: "L38zleNL00~W^kRj0L-p0KM_^kx]",
38
- sha256: "77fcf42b2b720babcdbe686eff67273d8a68862d74a2672db672bc48439a3ea5",
39
- originalSha256: "30696696e57a2732d4e9f1b15ff4d4d4eaa64b759df6876863f436ff5d736eae",
40
- thumbnail: "https://media.tenor.com/wpvrkjn192gAAAAx/daenerys-targaryen.webp",
41
- image: "https://media.tenor.com/wpvrkjn192gAAAAe/daenerys-targaryen.png",
42
- summary: "Khaleesi call dragons Daenerys Targaryen",
43
- fallback: ["https://media.tenor.com/wpvrkjn192gAAAAC/daenerys-targaryen.gif"],
44
- alt: "a woman with blonde hair and a brooch on her shoulder",
45
- });
46
- });
47
- });
48
- describe("getFileMetadataFromImetaTag", () => {
49
- it("should parse simple imeta tag", () => {
50
- expect(getFileMetadataFromImetaTag([
51
- "imeta",
52
- "url https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
53
- "x 3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
54
- "dim 1024x1024",
55
- "m image/jpeg",
56
- "blurhash ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
57
- ])).toEqual({
58
- url: "https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
59
- sha256: "3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
60
- dimensions: "1024x1024",
61
- type: "image/jpeg",
62
- blurhash: "ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
63
- });
64
- });
65
- it("should parse thumbnail url", () => {
66
- expect(getFileMetadataFromImetaTag([
67
- "imeta",
68
- "url https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
69
- "x 3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
70
- "dim 1024x1024",
71
- "m image/jpeg",
72
- "blurhash ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
73
- "thumb https://exmaple.com/thumb.jpg",
74
- ])).toEqual({
75
- url: "https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
76
- sha256: "3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
77
- dimensions: "1024x1024",
78
- type: "image/jpeg",
79
- blurhash: "ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
80
- thumbnail: "https://exmaple.com/thumb.jpg",
81
- });
82
- });
83
- it("should parse multiple fallback urls", () => {
84
- expect(getFileMetadataFromImetaTag([
85
- "imeta",
86
- "url https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
87
- "x 3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
88
- "dim 1024x1024",
89
- "m image/jpeg",
90
- "blurhash ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
91
- "fallback https://exmaple.com/image2.jpg",
92
- "fallback https://exmaple.com/image3.jpg",
93
- ])).toEqual({
94
- url: "https://blossom.primal.net/3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c.jpg",
95
- sha256: "3f4dbf2797ac4e90b00bcfe2728e5c8367ed909c48230ac454cc325f1993646c",
96
- dimensions: "1024x1024",
97
- type: "image/jpeg",
98
- blurhash: "ggH{Aws:RPWBRjaeay?^ozV@aeRjaej[$gt7kCofWVofkCrrofxuofa|ozbHx]s:tRofaet7ay",
99
- fallback: ["https://exmaple.com/image2.jpg", "https://exmaple.com/image3.jpg"],
100
- });
101
- });
102
- });
103
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,29 +0,0 @@
1
- import { describe, beforeEach, it, expect } from "vitest";
2
- import { finalizeEvent, generateSecretKey, getPublicKey, kinds, nip04 } from "nostr-tools";
3
- import { getHiddenTags, unlockHiddenTags } from "../hidden-tags.js";
4
- import { unixNow } from "../time.js";
5
- const key = generateSecretKey();
6
- const pubkey = getPublicKey(key);
7
- const signer = {
8
- nip04: {
9
- encrypt: (pubkey, plaintext) => nip04.encrypt(key, pubkey, plaintext),
10
- decrypt: (pubkey, ciphertext) => nip04.decrypt(key, pubkey, ciphertext),
11
- },
12
- };
13
- describe("Private Lists", () => {
14
- describe("unlockHiddenTags", () => {
15
- let list;
16
- beforeEach(async () => {
17
- list = finalizeEvent({
18
- kind: kinds.Mutelist,
19
- created_at: unixNow(),
20
- content: await nip04.encrypt(key, pubkey, JSON.stringify([["p", "npub1ye5ptcxfyyxl5vjvdjar2ua3f0hynkjzpx552mu5snj3qmx5pzjscpknpr"]])),
21
- tags: [],
22
- }, key);
23
- });
24
- it("should unlock hidden tags", async () => {
25
- await unlockHiddenTags(list, signer);
26
- expect(getHiddenTags(list)).toEqual(expect.arrayContaining([["p", "npub1ye5ptcxfyyxl5vjvdjar2ua3f0hynkjzpx552mu5snj3qmx5pzjscpknpr"]]));
27
- });
28
- });
29
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,81 +0,0 @@
1
- import { describe, test, expect } from "vitest";
2
- import { getInboxes, getOutboxes } from "../mailboxes.js";
3
- const emptyEvent = {
4
- kind: 10002,
5
- content: "",
6
- tags: [],
7
- created_at: 0,
8
- sig: "",
9
- id: "",
10
- pubkey: "",
11
- };
12
- describe("Mailboxes", () => {
13
- describe("getInboxes", () => {
14
- test("should transform urls", () => {
15
- expect(Array.from(getInboxes({
16
- ...emptyEvent,
17
- tags: [["r", "wss://inbox.com"]],
18
- }))).toEqual(expect.arrayContaining(["wss://inbox.com/"]));
19
- });
20
- test("should remove bad urls", () => {
21
- expect(Array.from(getInboxes({
22
- ...emptyEvent,
23
- tags: [["r", "bad://inbox.com"]],
24
- }))).toHaveLength(0);
25
- expect(Array.from(getInboxes({
26
- ...emptyEvent,
27
- tags: [["r", "something that is not a url"]],
28
- }))).toHaveLength(0);
29
- expect(Array.from(getInboxes({
30
- ...emptyEvent,
31
- tags: [["r", "wss://inbox.com,wss://inbox.org"]],
32
- }))).toHaveLength(0);
33
- });
34
- test("without marker", () => {
35
- expect(Array.from(getInboxes({
36
- ...emptyEvent,
37
- tags: [["r", "wss://inbox.com/"]],
38
- }))).toEqual(expect.arrayContaining(["wss://inbox.com/"]));
39
- });
40
- test("with marker", () => {
41
- expect(Array.from(getInboxes({
42
- ...emptyEvent,
43
- tags: [["r", "wss://inbox.com/", "read"]],
44
- }))).toEqual(expect.arrayContaining(["wss://inbox.com/"]));
45
- });
46
- });
47
- describe("getOutboxes", () => {
48
- test("should transform urls", () => {
49
- expect(Array.from(getOutboxes({
50
- ...emptyEvent,
51
- tags: [["r", "wss://outbox.com"]],
52
- }))).toEqual(expect.arrayContaining(["wss://outbox.com/"]));
53
- });
54
- test("should remove bad urls", () => {
55
- expect(Array.from(getOutboxes({
56
- ...emptyEvent,
57
- tags: [["r", "bad://inbox.com"]],
58
- }))).toHaveLength(0);
59
- expect(Array.from(getOutboxes({
60
- ...emptyEvent,
61
- tags: [["r", "something that is not a url"]],
62
- }))).toHaveLength(0);
63
- expect(Array.from(getOutboxes({
64
- ...emptyEvent,
65
- tags: [["r", "wss://outbox.com,wss://inbox.org"]],
66
- }))).toHaveLength(0);
67
- });
68
- test("without marker", () => {
69
- expect(Array.from(getOutboxes({
70
- ...emptyEvent,
71
- tags: [["r", "wss://outbox.com/"]],
72
- }))).toEqual(expect.arrayContaining(["wss://outbox.com/"]));
73
- });
74
- test("with marker", () => {
75
- expect(Array.from(getOutboxes({
76
- ...emptyEvent,
77
- tags: [["r", "wss://outbox.com/", "write"]],
78
- }))).toEqual(expect.arrayContaining(["wss://outbox.com/"]));
79
- });
80
- });
81
- });
@@ -1 +0,0 @@
1
- export {};