@peers-app/peers-sdk 0.1.4

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 (234) hide show
  1. package/README.md +1 -0
  2. package/dist/context/data-context.d.ts +31 -0
  3. package/dist/context/data-context.js +56 -0
  4. package/dist/context/index.d.ts +3 -0
  5. package/dist/context/index.js +19 -0
  6. package/dist/context/user-context-singleton.d.ts +11 -0
  7. package/dist/context/user-context-singleton.js +121 -0
  8. package/dist/context/user-context.d.ts +55 -0
  9. package/dist/context/user-context.js +205 -0
  10. package/dist/data/assistants.d.ts +68 -0
  11. package/dist/data/assistants.js +64 -0
  12. package/dist/data/change-tracking.d.ts +219 -0
  13. package/dist/data/change-tracking.js +119 -0
  14. package/dist/data/channels.d.ts +29 -0
  15. package/dist/data/channels.js +25 -0
  16. package/dist/data/data-locks.d.ts +37 -0
  17. package/dist/data/data-locks.js +180 -0
  18. package/dist/data/data-locks.test.d.ts +1 -0
  19. package/dist/data/data-locks.test.js +456 -0
  20. package/dist/data/device-sync-info.d.ts +19 -0
  21. package/dist/data/device-sync-info.js +24 -0
  22. package/dist/data/devices.d.ts +51 -0
  23. package/dist/data/devices.js +36 -0
  24. package/dist/data/embeddings.d.ts +47 -0
  25. package/dist/data/embeddings.js +36 -0
  26. package/dist/data/files/file-read-stream.d.ts +27 -0
  27. package/dist/data/files/file-read-stream.js +195 -0
  28. package/dist/data/files/file-write-stream.d.ts +20 -0
  29. package/dist/data/files/file-write-stream.js +113 -0
  30. package/dist/data/files/file.types.d.ts +47 -0
  31. package/dist/data/files/file.types.js +55 -0
  32. package/dist/data/files/files.d.ts +28 -0
  33. package/dist/data/files/files.js +127 -0
  34. package/dist/data/files/files.test.d.ts +1 -0
  35. package/dist/data/files/files.test.js +728 -0
  36. package/dist/data/files/index.d.ts +4 -0
  37. package/dist/data/files/index.js +23 -0
  38. package/dist/data/group-member-roles.d.ts +9 -0
  39. package/dist/data/group-member-roles.js +25 -0
  40. package/dist/data/group-members.d.ts +39 -0
  41. package/dist/data/group-members.js +68 -0
  42. package/dist/data/group-members.test.d.ts +1 -0
  43. package/dist/data/group-members.test.js +287 -0
  44. package/dist/data/group-permissions.d.ts +8 -0
  45. package/dist/data/group-permissions.js +73 -0
  46. package/dist/data/group-share.d.ts +50 -0
  47. package/dist/data/group-share.js +196 -0
  48. package/dist/data/groups.d.ts +50 -0
  49. package/dist/data/groups.js +73 -0
  50. package/dist/data/groups.test.d.ts +1 -0
  51. package/dist/data/groups.test.js +153 -0
  52. package/dist/data/index.d.ts +31 -0
  53. package/dist/data/index.js +47 -0
  54. package/dist/data/knowledge/knowledge-frames.d.ts +34 -0
  55. package/dist/data/knowledge/knowledge-frames.js +34 -0
  56. package/dist/data/knowledge/knowledge-links.d.ts +30 -0
  57. package/dist/data/knowledge/knowledge-links.js +25 -0
  58. package/dist/data/knowledge/knowledge-values.d.ts +35 -0
  59. package/dist/data/knowledge/knowledge-values.js +35 -0
  60. package/dist/data/knowledge/peer-types.d.ts +112 -0
  61. package/dist/data/knowledge/peer-types.js +27 -0
  62. package/dist/data/knowledge/predicates.d.ts +34 -0
  63. package/dist/data/knowledge/predicates.js +27 -0
  64. package/dist/data/messages.d.ts +57 -0
  65. package/dist/data/messages.js +97 -0
  66. package/dist/data/orm/client-proxy.data-source.d.ts +27 -0
  67. package/dist/data/orm/client-proxy.data-source.js +65 -0
  68. package/dist/data/orm/cursor.d.ts +25 -0
  69. package/dist/data/orm/cursor.js +47 -0
  70. package/dist/data/orm/cursor.test.d.ts +1 -0
  71. package/dist/data/orm/cursor.test.js +315 -0
  72. package/dist/data/orm/data-query.d.ts +96 -0
  73. package/dist/data/orm/data-query.js +208 -0
  74. package/dist/data/orm/data-query.mongo.d.ts +17 -0
  75. package/dist/data/orm/data-query.mongo.js +267 -0
  76. package/dist/data/orm/data-query.mongo.test.d.ts +1 -0
  77. package/dist/data/orm/data-query.mongo.test.js +398 -0
  78. package/dist/data/orm/data-query.sqlite.d.ts +14 -0
  79. package/dist/data/orm/data-query.sqlite.js +297 -0
  80. package/dist/data/orm/data-query.sqlite.test.d.ts +1 -0
  81. package/dist/data/orm/data-query.sqlite.test.js +377 -0
  82. package/dist/data/orm/data-query.test.d.ts +1 -0
  83. package/dist/data/orm/data-query.test.js +553 -0
  84. package/dist/data/orm/decorators.d.ts +6 -0
  85. package/dist/data/orm/decorators.js +21 -0
  86. package/dist/data/orm/dependency-injection.test.d.ts +1 -0
  87. package/dist/data/orm/dependency-injection.test.js +171 -0
  88. package/dist/data/orm/doc.d.ts +26 -0
  89. package/dist/data/orm/doc.js +124 -0
  90. package/dist/data/orm/event-registry.d.ts +24 -0
  91. package/dist/data/orm/event-registry.js +40 -0
  92. package/dist/data/orm/event-registry.test.d.ts +1 -0
  93. package/dist/data/orm/event-registry.test.js +44 -0
  94. package/dist/data/orm/factory.d.ts +8 -0
  95. package/dist/data/orm/factory.js +147 -0
  96. package/dist/data/orm/index.d.ts +16 -0
  97. package/dist/data/orm/index.js +32 -0
  98. package/dist/data/orm/multi-cursors.d.ts +11 -0
  99. package/dist/data/orm/multi-cursors.js +146 -0
  100. package/dist/data/orm/multi-cursors.test.d.ts +1 -0
  101. package/dist/data/orm/multi-cursors.test.js +455 -0
  102. package/dist/data/orm/sql-db.d.ts +6 -0
  103. package/dist/data/orm/sql-db.js +2 -0
  104. package/dist/data/orm/sql.data-source.d.ts +38 -0
  105. package/dist/data/orm/sql.data-source.js +379 -0
  106. package/dist/data/orm/sql.data-source.test.d.ts +1 -0
  107. package/dist/data/orm/sql.data-source.test.js +406 -0
  108. package/dist/data/orm/subscribable.data-source.d.ts +25 -0
  109. package/dist/data/orm/subscribable.data-source.js +72 -0
  110. package/dist/data/orm/table-container-events.test.d.ts +1 -0
  111. package/dist/data/orm/table-container-events.test.js +93 -0
  112. package/dist/data/orm/table-container.d.ts +39 -0
  113. package/dist/data/orm/table-container.js +96 -0
  114. package/dist/data/orm/table-definitions.system.d.ts +9 -0
  115. package/dist/data/orm/table-definitions.system.js +29 -0
  116. package/dist/data/orm/table-definitions.type.d.ts +19 -0
  117. package/dist/data/orm/table-definitions.type.js +2 -0
  118. package/dist/data/orm/table-dependencies.d.ts +32 -0
  119. package/dist/data/orm/table-dependencies.js +2 -0
  120. package/dist/data/orm/table.d.ts +42 -0
  121. package/dist/data/orm/table.event-source.test.d.ts +1 -0
  122. package/dist/data/orm/table.event-source.test.js +341 -0
  123. package/dist/data/orm/table.js +244 -0
  124. package/dist/data/orm/types.d.ts +20 -0
  125. package/dist/data/orm/types.js +115 -0
  126. package/dist/data/orm/types.test.d.ts +1 -0
  127. package/dist/data/orm/types.test.js +71 -0
  128. package/dist/data/package-permissions.d.ts +7 -0
  129. package/dist/data/package-permissions.js +18 -0
  130. package/dist/data/packages.d.ts +92 -0
  131. package/dist/data/packages.js +90 -0
  132. package/dist/data/peer-events/peer-event-handlers.d.ts +21 -0
  133. package/dist/data/peer-events/peer-event-handlers.js +28 -0
  134. package/dist/data/peer-events/peer-event-types.d.ts +119 -0
  135. package/dist/data/peer-events/peer-event-types.js +29 -0
  136. package/dist/data/peer-events/peer-events.d.ts +41 -0
  137. package/dist/data/peer-events/peer-events.js +102 -0
  138. package/dist/data/persistent-vars.d.ts +87 -0
  139. package/dist/data/persistent-vars.js +230 -0
  140. package/dist/data/tool-tests.d.ts +37 -0
  141. package/dist/data/tool-tests.js +27 -0
  142. package/dist/data/tools.d.ts +358 -0
  143. package/dist/data/tools.js +48 -0
  144. package/dist/data/user-permissions.d.ts +15 -0
  145. package/dist/data/user-permissions.js +39 -0
  146. package/dist/data/user-permissions.test.d.ts +1 -0
  147. package/dist/data/user-permissions.test.js +252 -0
  148. package/dist/data/users.d.ts +38 -0
  149. package/dist/data/users.js +73 -0
  150. package/dist/data/workflow-logs.d.ts +106 -0
  151. package/dist/data/workflow-logs.js +67 -0
  152. package/dist/data/workflow-runs.d.ts +103 -0
  153. package/dist/data/workflow-runs.js +313 -0
  154. package/dist/data/workflows.d.ts +16 -0
  155. package/dist/data/workflows.js +21 -0
  156. package/dist/device/connection.d.ts +41 -0
  157. package/dist/device/connection.js +249 -0
  158. package/dist/device/connection.test.d.ts +1 -0
  159. package/dist/device/connection.test.js +292 -0
  160. package/dist/device/device-election.d.ts +36 -0
  161. package/dist/device/device-election.js +137 -0
  162. package/dist/device/device.d.ts +22 -0
  163. package/dist/device/device.js +110 -0
  164. package/dist/device/device.test.d.ts +1 -0
  165. package/dist/device/device.test.js +203 -0
  166. package/dist/device/get-trust-level.d.ts +3 -0
  167. package/dist/device/get-trust-level.js +87 -0
  168. package/dist/device/socket.type.d.ts +20 -0
  169. package/dist/device/socket.type.js +15 -0
  170. package/dist/device/streamed-socket.d.ts +27 -0
  171. package/dist/device/streamed-socket.js +154 -0
  172. package/dist/device/streamed-socket.test.d.ts +1 -0
  173. package/dist/device/streamed-socket.test.js +44 -0
  174. package/dist/events.d.ts +35 -0
  175. package/dist/events.js +128 -0
  176. package/dist/index.d.ts +33 -0
  177. package/dist/index.js +50 -0
  178. package/dist/keys.d.ts +51 -0
  179. package/dist/keys.js +234 -0
  180. package/dist/keys.test.d.ts +1 -0
  181. package/dist/keys.test.js +215 -0
  182. package/dist/mentions.d.ts +9 -0
  183. package/dist/mentions.js +46 -0
  184. package/dist/observable.d.ts +19 -0
  185. package/dist/observable.js +112 -0
  186. package/dist/observable.test.d.ts +1 -0
  187. package/dist/observable.test.js +183 -0
  188. package/dist/package-loader/get-require.d.ts +10 -0
  189. package/dist/package-loader/get-require.js +31 -0
  190. package/dist/package-loader/index.d.ts +1 -0
  191. package/dist/package-loader/index.js +17 -0
  192. package/dist/package-loader/package-loader.d.ts +16 -0
  193. package/dist/package-loader/package-loader.js +102 -0
  194. package/dist/peers-ui/peers-ui.d.ts +15 -0
  195. package/dist/peers-ui/peers-ui.js +23 -0
  196. package/dist/peers-ui/peers-ui.types.d.ts +35 -0
  197. package/dist/peers-ui/peers-ui.types.js +3 -0
  198. package/dist/rpc-types.d.ts +45 -0
  199. package/dist/rpc-types.js +47 -0
  200. package/dist/serial-json.d.ts +5 -0
  201. package/dist/serial-json.js +186 -0
  202. package/dist/serial-json.test.d.ts +1 -0
  203. package/dist/serial-json.test.js +86 -0
  204. package/dist/system-ids.d.ts +6 -0
  205. package/dist/system-ids.js +10 -0
  206. package/dist/tools/index.d.ts +1 -0
  207. package/dist/tools/index.js +17 -0
  208. package/dist/tools/tools-factory.d.ts +5 -0
  209. package/dist/tools/tools-factory.js +34 -0
  210. package/dist/types/app-nav.d.ts +18 -0
  211. package/dist/types/app-nav.js +10 -0
  212. package/dist/types/assistant-runner-args.d.ts +9 -0
  213. package/dist/types/assistant-runner-args.js +2 -0
  214. package/dist/types/field-type.d.ts +37 -0
  215. package/dist/types/field-type.js +26 -0
  216. package/dist/types/peer-device.d.ts +40 -0
  217. package/dist/types/peer-device.js +14 -0
  218. package/dist/types/peers-package.d.ts +23 -0
  219. package/dist/types/peers-package.js +2 -0
  220. package/dist/types/workflow-logger.d.ts +2 -0
  221. package/dist/types/workflow-logger.js +2 -0
  222. package/dist/types/workflow-run-context.d.ts +12 -0
  223. package/dist/types/workflow-run-context.js +2 -0
  224. package/dist/types/workflow.d.ts +72 -0
  225. package/dist/types/workflow.js +24 -0
  226. package/dist/types/zod-types.d.ts +7 -0
  227. package/dist/types/zod-types.js +12 -0
  228. package/dist/users.query.d.ts +13 -0
  229. package/dist/users.query.js +134 -0
  230. package/dist/utils.d.ts +39 -0
  231. package/dist/utils.js +240 -0
  232. package/dist/utils.test.d.ts +1 -0
  233. package/dist/utils.test.js +140 -0
  234. package/package.json +50 -0
@@ -0,0 +1,553 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const data_query_1 = require("./data-query");
4
+ const data_query_sqlite_1 = require("./data-query.sqlite");
5
+ const factory_1 = require("./factory");
6
+ describe('dataFilterToSqlWhere (SQLite)', () => {
7
+ it('should return "1=1" when filter is empty', () => {
8
+ const filter = {};
9
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
10
+ expect(result).toBe('(1=1)');
11
+ });
12
+ it('should return correct SQL WHERE clause for single field filter', () => {
13
+ const filter = { name: 'John' };
14
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
15
+ expect(result).toBe(`("name" = 'John')`);
16
+ });
17
+ it('should return correct SQL WHERE clause for multiple field filter', () => {
18
+ const filter = { name: 'John', age: 30 };
19
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
20
+ expect(result).toBe(`("name" = 'John' AND "age" = 30)`);
21
+ });
22
+ it('should return correct SQL WHERE clause for $in filter', () => {
23
+ const filter = { name: { $in: ['John', 'Jane'] } };
24
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
25
+ expect(result).toBe(`("name" IN ('John', 'Jane'))`);
26
+ });
27
+ it('should handle null and undefined values correctly', () => {
28
+ const filter = { name: null, age: undefined };
29
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
30
+ expect(result).toBe(`("name" IS NULL AND "age" IS NULL)`);
31
+ });
32
+ it('should escape single quotes in strings', () => {
33
+ const filter = { name: "John's" };
34
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
35
+ expect(result).toBe(`("name" = 'John''s')`);
36
+ });
37
+ it('should escape multiple single quotes in strings', () => {
38
+ const filter = { name: "It's John''s" };
39
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
40
+ expect(result).toBe(`("name" = 'It''s John''''s')`);
41
+ });
42
+ it('should escape single quotes in strings when doing $matchText', () => {
43
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)({ name: { $matchWords: "It's John's" } });
44
+ expect(result).toBe(`("name" LIKE '%It''s%' AND "name" LIKE '%John''s%')`);
45
+ });
46
+ it('should escape and preserver sequences of single quotes when doing $matchText', () => {
47
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)({ name: { $matchWords: "It''s John''s" } });
48
+ expect(result).toBe(`("name" LIKE '%It''''s%' AND "name" LIKE '%John''''s%')`);
49
+ });
50
+ it('should convert top level arrays into OR statements', () => {
51
+ const filter = [
52
+ { name: 'John' },
53
+ { age: 32 },
54
+ ];
55
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
56
+ expect(result).toBe(`(("name" = 'John') OR ("age" = 32))`);
57
+ });
58
+ it('should convert top level arrays into OR statements', () => {
59
+ const filter = [
60
+ { name: 'John' },
61
+ { age: 32, airport: { $in: ['LAX', 'PSP'] } },
62
+ ];
63
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
64
+ expect(result).toBe(`(("name" = 'John') OR ("age" = 32 AND "airport" IN ('LAX', 'PSP')))`);
65
+ });
66
+ it('should convert $nin to NOT IN', () => {
67
+ const filter = { age: { $nin: [29, 'lol'] } };
68
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
69
+ expect(result).toBe(`("age" NOT IN (29, 'lol'))`);
70
+ });
71
+ it('should convert $gte to ">="', () => {
72
+ const filter = { age: { $gte: 12 } };
73
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
74
+ expect(result).toBe(`("age" >= 12)`);
75
+ });
76
+ it('should convert $gt to >', () => {
77
+ const filter = [{ age: { $gt: 12 } }];
78
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
79
+ expect(result).toBe(`(("age" > 12))`);
80
+ });
81
+ it('should convert $ne to "<> OR IS NULL"', () => {
82
+ const filter = [{ age: { $ne: 12 } }];
83
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
84
+ expect(result).toBe(`((("age" <> 12 OR "age" IS NULL)))`);
85
+ });
86
+ it('should escape single quotes for $ne', () => {
87
+ const filter = [{ name: { $ne: "O'Hara" } }];
88
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
89
+ expect(result).toBe(`((("name" <> 'O''Hara' OR "name" IS NULL)))`);
90
+ });
91
+ it('should escape sequences single quotes for $ne', () => {
92
+ const filter = [{ name: { $ne: "O''Hara" } }];
93
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
94
+ expect(result).toBe(`((("name" <> 'O''''Hara' OR "name" IS NULL)))`);
95
+ });
96
+ it('should convert $exists to IS or IS NOT NULL', () => {
97
+ const filter = [
98
+ { age: { $exists: true } },
99
+ { age: { $exists: false } },
100
+ ];
101
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
102
+ expect(result).toBe(`(("age" IS NOT NULL) OR ("age" IS NULL))`);
103
+ });
104
+ it('should convert $lt, $lte, $ne correctly', () => {
105
+ const filter = [
106
+ { age: { $lt: 10 } },
107
+ { age: { $lte: 10 } },
108
+ { age: { $ne: 10 } },
109
+ ];
110
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
111
+ expect(result).toBe(`(("age" < 10) OR ("age" <= 10) OR (("age" <> 10 OR "age" IS NULL)))`);
112
+ });
113
+ it('should convert $matchWords to a LIKE for each word', () => {
114
+ const filter = { name: { $matchWords: 'John Doe' } };
115
+ const result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
116
+ expect(result).toBe(`("name" LIKE '%John%' AND "name" LIKE '%Doe%')`);
117
+ });
118
+ it('should generate AND clause for $and directive', () => {
119
+ let filter = { $and: [{ age: 32 }, { name: 'John' }] };
120
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
121
+ expect(result).toBe(`((("age" = 32) AND ("name" = 'John')))`);
122
+ filter = {
123
+ name: { $ne: 'John M. Doe' },
124
+ $and: [
125
+ { age: { $gte: 30 } },
126
+ { age: { $lte: 32 } },
127
+ { name: { $matchWords: 'John Doe' } }
128
+ ]
129
+ };
130
+ result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
131
+ expect(result).toBe(`(("name" <> 'John M. Doe' OR "name" IS NULL) AND (("age" >= 30) AND ("age" <= 32) AND ("name" LIKE '%John%' AND "name" LIKE '%Doe%')))`);
132
+ });
133
+ it('should allow indicating columns with $ prefix', () => {
134
+ let filter = { id: { $gte: '$col1' } };
135
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
136
+ expect(result).toBe(`("id" >= "col1")`);
137
+ });
138
+ it('should allow escaping $prefix with backslash', () => {
139
+ let filter = { id: { $gte: '\\$col1' } };
140
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
141
+ expect(result).toBe(`("id" >= '$col1')`);
142
+ });
143
+ it('should leave backslash prefix if not followed by $', () => {
144
+ let filter = { id: { $gte: '\\col1' } };
145
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
146
+ expect(result).toBe(`("id" >= '\\col1')`);
147
+ });
148
+ it('should generate substr clause for $substr directive on right hand side', () => {
149
+ let filter = { id: { $gte: { $substr: ['$col1', 2, 4] } } };
150
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
151
+ expect(result).toBe(`("id" >= (substr("col1", 2, 4)))`);
152
+ });
153
+ it('should generate substr clauses for $substr directive on left hand side', () => {
154
+ let filter = { $expr: [{ $substr: ['$id1', -1, 1] }, { $eq: 'a' }] };
155
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
156
+ expect(result).toBe(`((substr("id1", -1, 1)) = 'a')`);
157
+ });
158
+ it('should generate substr clauses for $substr directive on left and right hand side', () => {
159
+ let filter = { $expr: [{ $substr: ['$id1', -1, 1] }, { $gte: { $substr: ['$col1', 2, 4] } }] };
160
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
161
+ expect(result).toBe(`((substr("id1", -1, 1)) >= (substr("col1", 2, 4)))`);
162
+ });
163
+ it('should generate substr clause for $substr directive and correctly escape single quotes in string', () => {
164
+ let filter = { id: { $gte: { $substr: [`$id`, -1, 1] } } };
165
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
166
+ expect(result).toBe(`("id" >= (substr("id", -1, 1)))`);
167
+ });
168
+ it('should generate substr clause for $expr directive and correctly escape single quotes in string', () => {
169
+ let filter = { $expr: [{ $substr: [`I'm a string`, -1, 1] }, { $gte: 'a' }] };
170
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
171
+ expect(result).toBe(`((substr('I''m a string', -1, 1)) >= 'a')`);
172
+ });
173
+ it('should generate substr clause for $expr directive and correctly escape double quotes in identifiers', () => {
174
+ let filter = { $expr: [{ $substr: ['$weird"col"name', -1, 1] }, { $gte: 'a' }] };
175
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
176
+ expect(result).toBe(`((substr("weird""col""name", -1, 1)) >= 'a')`);
177
+ });
178
+ it('should handle empty $or arrays without generating empty parentheses', () => {
179
+ let filter = { $or: [] };
180
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
181
+ expect(result).toBe('((1=1))');
182
+ });
183
+ it('should handle $or arrays with filters that resolve to (1=1)', () => {
184
+ let filter = { $or: [{}] };
185
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
186
+ expect(result).toBe('(((1=1)))');
187
+ });
188
+ it('should handle empty $and arrays without generating empty parentheses', () => {
189
+ let filter = { $and: [] };
190
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
191
+ expect(result).toBe('((1=1))');
192
+ });
193
+ it('should handle $and arrays with filters that resolve to (1=1)', () => {
194
+ let filter = { $and: [{}] };
195
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
196
+ expect(result).toBe('(((1=1)))');
197
+ });
198
+ it('should handle mixed $or and $and with empty conditions', () => {
199
+ let filter = {
200
+ $and: [
201
+ { name: 'John' },
202
+ { $or: [] }
203
+ ]
204
+ };
205
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
206
+ expect(result).toBe(`((("name" = 'John') AND ((1=1))))`);
207
+ });
208
+ it('should throw error for direct array usage', () => {
209
+ let filter = { name: ['John', 'Jane'] };
210
+ expect(() => (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter)).toThrow('Invalid filter: Arrays are not allowed as direct field values. Use $in instead: { name: { $in: [\'John\', \'Jane\'] } }');
211
+ });
212
+ it('should handle $in operator correctly', () => {
213
+ let filter = { name: { $in: ['John', 'Jane', 'Bob'] } };
214
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
215
+ expect(result).toBe(`("name" IN ('John', 'Jane', 'Bob'))`);
216
+ });
217
+ it('should throw error for $in with non-array value', () => {
218
+ let filter = { name: { $in: 'John' } };
219
+ expect(() => (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter)).toThrow('$in value must be an array');
220
+ });
221
+ });
222
+ describe('filterToSkipPastValue', () => {
223
+ it('should a filter limited to results after the next item', () => {
224
+ const sortBy = ['id'];
225
+ let filter = { id: { $gte: '$col1' } };
226
+ filter = (0, data_query_1.filterToSkipPastValue)(filter, sortBy, { id: 10 });
227
+ expect(filter).toEqual({
228
+ $and: [
229
+ { id: { $gte: '$col1' } },
230
+ {
231
+ $or: [
232
+ { id: { $gt: 10 } },
233
+ ]
234
+ }
235
+ ]
236
+ });
237
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
238
+ expect(result).toBe(`((("id" >= "col1") AND ((("id" > 10)))))`);
239
+ });
240
+ it('should a work with descending sorts', () => {
241
+ const sortBy = ['-id'];
242
+ let filter = { id: { $gte: '$col1' } };
243
+ filter = (0, data_query_1.filterToSkipPastValue)(filter, sortBy, { id: 10 });
244
+ expect(filter).toEqual({
245
+ $and: [
246
+ { id: { $gte: '$col1' } },
247
+ {
248
+ $or: [
249
+ { id: { $lt: 10 } },
250
+ ]
251
+ }
252
+ ]
253
+ });
254
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
255
+ expect(result).toBe(`((("id" >= "col1") AND ((("id" < 10)))))`);
256
+ });
257
+ it('should work with multiple sorts', () => {
258
+ const sortBy = ['name', '-id', 'age'];
259
+ let filter = { id: { $gte: '$col1' } };
260
+ filter = (0, data_query_1.filterToSkipPastValue)(filter, sortBy, { id: 10, name: 'test', age: 30 });
261
+ expect(filter).toEqual({
262
+ $and: [
263
+ { id: { $gte: '$col1' } },
264
+ {
265
+ $or: [
266
+ { name: { $gt: 'test' } },
267
+ { name: { $eq: 'test' }, id: { $lt: 10 } },
268
+ { name: { $eq: 'test' }, id: { $eq: 10 }, age: { $gt: 30 } },
269
+ ]
270
+ }
271
+ ]
272
+ });
273
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
274
+ expect(result).toBe(`((("id" >= "col1") AND ((("name" > 'test') OR ("id" < 10 AND "name" = 'test') OR ("age" > 30 AND "id" = 10 AND "name" = 'test')))))`);
275
+ });
276
+ it('should correctly handle null values', () => {
277
+ const sortBy = ['name', '-id', 'age'];
278
+ let filter = { id: { $gte: '$col1' } };
279
+ filter = (0, data_query_1.filterToSkipPastValue)(filter, sortBy, { id: 10 });
280
+ expect(filter).toEqual({
281
+ $and: [
282
+ { id: { $gte: '$col1' } },
283
+ {
284
+ $or: [
285
+ { name: { $exists: true } },
286
+ { name: { $exists: false }, id: { $lt: 10 } },
287
+ { name: { $exists: false }, id: { $eq: 10 }, age: { $exists: true } },
288
+ ]
289
+ }
290
+ ]
291
+ });
292
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
293
+ expect(result).toBe(`((("id" >= "col1") AND ((("name" IS NOT NULL) OR ("id" < 10 AND "name" IS NULL) OR ("age" IS NOT NULL AND "id" = 10 AND "name" IS NULL)))))`);
294
+ });
295
+ it('should handle empty filter', () => {
296
+ const sortBy = ['name', '-id', 'age'];
297
+ let filter = {};
298
+ filter = (0, data_query_1.filterToSkipPastValue)(filter, sortBy, { id: 10 });
299
+ expect(filter).toEqual({
300
+ $and: [
301
+ {},
302
+ {
303
+ $or: [
304
+ { name: { $exists: true } },
305
+ { name: { $exists: false }, id: { $lt: 10 } },
306
+ { name: { $exists: false }, id: { $eq: 10 }, age: { $exists: true } },
307
+ ]
308
+ }
309
+ ]
310
+ });
311
+ let result = (0, data_query_sqlite_1.dataFilterToSqlWhere)(filter);
312
+ expect(result).toBe(`(((1=1) AND (((\"name\" IS NOT NULL) OR (\"id\" < 10 AND \"name\" IS NULL) OR (\"age\" IS NOT NULL AND \"id\" = 10 AND \"name\" IS NULL)))))`);
313
+ });
314
+ });
315
+ const aryTable = (0, factory_1.arrayAsTable)([
316
+ { id: 1, name: 'John', age: 30 },
317
+ { id: 2, name: 'Jane', age: 32 },
318
+ { id: 3, name: 'Joe', age: 29 },
319
+ { id: 4, name: 'Jeb', age: 50 },
320
+ { id: 5, name: 'Joey', age: 31 },
321
+ ], {
322
+ name: 'People',
323
+ });
324
+ describe('DataQuery', () => {
325
+ describe('cursor', () => {
326
+ const query = new data_query_1.DataQuery(aryTable);
327
+ query.pageSize = 2;
328
+ it('should allow async iteration via `for await`', async () => {
329
+ let results = [];
330
+ for await (const item of query.cursor()) {
331
+ results.push(item.id);
332
+ }
333
+ expect(results).toEqual([1, 2, 3, 4, 5]);
334
+ });
335
+ it('should allow async iteration via `while await next`', async () => {
336
+ let results = [];
337
+ const cursor = query.cursor();
338
+ while (await cursor.next()) {
339
+ results.push(cursor.value?.id);
340
+ }
341
+ expect(results).toEqual([1, 2, 3, 4, 5]);
342
+ });
343
+ });
344
+ });
345
+ describe('dataQueryToSqliteQuery', () => {
346
+ const aryTable = (0, factory_1.arrayAsTable)([
347
+ { id: 1, name: 'John', age: 30 },
348
+ { id: 2, name: 'Jane', age: 32 },
349
+ { id: 3, name: 'Joe', age: 29 },
350
+ ], {
351
+ name: 'People',
352
+ });
353
+ function fmtSql(sql) {
354
+ return sql.replace(/ /g, '').trim();
355
+ }
356
+ let query = new data_query_1.DataQuery(aryTable);
357
+ beforeEach(() => {
358
+ query = new data_query_1.DataQuery(aryTable);
359
+ });
360
+ it('should return correct SQL query for empty query', () => {
361
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
362
+ expect(sql).toBe(fmtSql(`
363
+ SELECT
364
+ *
365
+ FROM "People"
366
+ WHERE (1=1)
367
+ ORDER BY 1
368
+ `));
369
+ });
370
+ it('should generate single clause for single field filter', () => {
371
+ query.filter = { age: 30 };
372
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
373
+ expect(sql).toBe(fmtSql(`
374
+ SELECT
375
+ *
376
+ FROM "People"
377
+ WHERE ("age" = 30)
378
+ ORDER BY 1
379
+ `));
380
+ });
381
+ it('should generate AND clause for multi-field filter', () => {
382
+ query.filter = { age: 30, name: 'John' };
383
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
384
+ expect(sql).toBe(fmtSql(`
385
+ SELECT
386
+ *
387
+ FROM "People"
388
+ WHERE ("age" = 30 AND "name" = 'John')
389
+ ORDER BY 1
390
+ `));
391
+ });
392
+ it('should generate OR LIKE clauses for all fields for text search', () => {
393
+ query.filter = {};
394
+ query.textSearch = 'John';
395
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
396
+ expect(sql).toBe(fmtSql(`
397
+ SELECT
398
+ *
399
+ FROM "People"
400
+ WHERE (("id" LIKE '%John%' OR "name" LIKE '%John%' OR "age" LIKE '%John%'))
401
+ ORDER BY 1
402
+ `));
403
+ });
404
+ it('should handle empty filter and text search with only spaces', () => {
405
+ query.filter = {};
406
+ query.textSearch = ' ';
407
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
408
+ expect(sql).toBe(fmtSql(`
409
+ SELECT
410
+ *
411
+ FROM "People"
412
+ WHERE (1=1)
413
+ ORDER BY 1
414
+ `));
415
+ });
416
+ it('should handle filter and text search with only spaces', () => {
417
+ query.filter = { age: 30 };
418
+ query.textSearch = ' ';
419
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
420
+ expect(sql).toBe(fmtSql(`
421
+ SELECT
422
+ *
423
+ FROM "People"
424
+ WHERE ("age" = 30)
425
+ ORDER BY 1
426
+ `));
427
+ });
428
+ it('should generate OR LIKE clauses for all fields for text search for each word given', () => {
429
+ query.filter = {};
430
+ query.textSearch = 'John Smith';
431
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
432
+ expect(sql).toBe(fmtSql(`
433
+ SELECT
434
+ *
435
+ FROM "People"
436
+ WHERE (("id" LIKE '%John%' OR "name" LIKE '%John%' OR "age" LIKE '%John%') AND ("id" LIKE '%Smith%' OR "name" LIKE '%Smith%' OR "age" LIKE '%Smith%'))
437
+ ORDER BY 1
438
+ `));
439
+ });
440
+ it('should generate OR LIKE clauses for all fields for exact text when specified', () => {
441
+ query.filter = {};
442
+ query.textSearch = 'John Smith';
443
+ query.textSearchExact = true;
444
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
445
+ expect(sql).toBe(fmtSql(`
446
+ SELECT
447
+ *
448
+ FROM "People"
449
+ WHERE ("id" LIKE '%John Smith%' OR "name" LIKE '%John Smith%' OR "age" LIKE '%John Smith%')
450
+ ORDER BY 1
451
+ `));
452
+ });
453
+ it('should generate OR clause for $or directive', () => {
454
+ query.filter = { $or: [{ age: 32 }, { name: 'John' }] };
455
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
456
+ expect(sql).toBe(fmtSql(`
457
+ SELECT
458
+ *
459
+ FROM "People"
460
+ WHERE ((("age" = 32) OR ("name" = 'John')))
461
+ ORDER BY 1
462
+ `));
463
+ query.filter = { $or: [{ age: 30, name: 'John' }, { age: 32, name: 'Jane' }], id: { $in: [1, 2, 3] }, name: { $ne: 'Joe' } };
464
+ sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
465
+ expect(sql).toBe(fmtSql(`
466
+ SELECT
467
+ *
468
+ FROM "People"
469
+ WHERE ((("age" = 30 AND "name" = 'John') OR ("age" = 32 AND "name" = 'Jane')) AND "id" IN (1, 2, 3) AND ("name" <> 'Joe' OR "name" IS NULL))
470
+ ORDER BY 1
471
+ `));
472
+ });
473
+ it('should generate AND clause for $and directive', () => {
474
+ query.filter = { $and: [{ age: 32 }, { name: 'John' }] };
475
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
476
+ expect(sql).toBe(fmtSql(`
477
+ SELECT
478
+ *
479
+ FROM "People"
480
+ WHERE ((("age" = 32) AND ("name" = 'John')))
481
+ ORDER BY 1
482
+ `));
483
+ query.filter = { $and: [{ age: 30, name: 'John' }, { age: 32, name: 'Jane' }], id: { $in: [1, 2, 3] }, name: { $ne: 'Joe' } };
484
+ sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
485
+ expect(sql).toBe(fmtSql(`
486
+ SELECT
487
+ *
488
+ FROM "People"
489
+ WHERE ((("age" = 30 AND "name" = 'John') AND ("age" = 32 AND "name" = 'Jane')) AND "id" IN (1, 2, 3) AND ("name" <> 'Joe' OR "name" IS NULL))
490
+ ORDER BY 1
491
+ `));
492
+ });
493
+ it('should combine filter and textSearch with AND', () => {
494
+ query.filter = ({ age: 30 });
495
+ query.textSearch = ('John');
496
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
497
+ expect(sql).toBe(fmtSql(`
498
+ SELECT
499
+ *
500
+ FROM "People"
501
+ WHERE (("age" = 30)) AND ((("id" LIKE '%John%' OR "name" LIKE '%John%' OR "age" LIKE '%John%')))
502
+ ORDER BY 1
503
+ `));
504
+ });
505
+ it('should respond correctly to pageSize changing', () => {
506
+ query.filter = ({});
507
+ query.textSearch = ('');
508
+ query.pageSize = (10);
509
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
510
+ expect(sql).toBe(fmtSql(`
511
+ SELECT
512
+ *
513
+ FROM "People"
514
+ WHERE (1=1)
515
+ ORDER BY 1
516
+ LIMIT 10
517
+ OFFSET 0
518
+ `));
519
+ });
520
+ it('should calculate LIMIT and OFFSET from page and pageSize', () => {
521
+ query.filter = ({});
522
+ query.textSearch = ('');
523
+ query.pageSize = (10);
524
+ query.page = (10);
525
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
526
+ expect(sql).toBe(fmtSql(`
527
+ SELECT
528
+ *
529
+ FROM "People"
530
+ WHERE (1=1)
531
+ ORDER BY 1
532
+ LIMIT 10
533
+ OFFSET 90
534
+ `));
535
+ });
536
+ it('should calculate LIMIT and OFFSET from page and pageSize', () => {
537
+ query.filter = ({});
538
+ query.textSearch = ('');
539
+ query.pageSize = (10);
540
+ query.page = (10);
541
+ query.sortBy = (['name', '-age']);
542
+ let sql = (0, data_query_sqlite_1.dataQueryToSqliteQuery)(query);
543
+ expect(sql).toBe(fmtSql(`
544
+ SELECT
545
+ *
546
+ FROM "People"
547
+ WHERE (1=1)
548
+ ORDER BY "name" ASC, "age" DESC
549
+ LIMIT 10
550
+ OFFSET 90
551
+ `));
552
+ });
553
+ });
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Decorator that marks a table method as server-side only.
3
+ * When used on the client side, these methods will be automatically proxied
4
+ * to the server via rpcServerCalls.tableMethodCall.
5
+ */
6
+ export declare function ProxyClientCalls(): (target: any, context: any) => any;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProxyClientCalls = ProxyClientCalls;
4
+ /**
5
+ * Decorator that marks a table method as server-side only.
6
+ * When used on the client side, these methods will be automatically proxied
7
+ * to the server via rpcServerCalls.tableMethodCall.
8
+ */
9
+ function ProxyClientCalls() {
10
+ return function (target, context) {
11
+ if (context.kind === 'method' && typeof window !== 'undefined') {
12
+ const methodName = context.name;
13
+ return function (...args) {
14
+ // Lazy import to avoid circular dependencies
15
+ const { rpcServerCalls } = require("../..");
16
+ return rpcServerCalls.tableMethodCall(this.dataContextId, this.tableName, methodName, ...args);
17
+ };
18
+ }
19
+ return target;
20
+ };
21
+ }
@@ -0,0 +1 @@
1
+ export {};