@effect-app/infra 4.0.0-beta.12 → 4.0.0-beta.120

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 (172) hide show
  1. package/CHANGELOG.md +794 -0
  2. package/dist/CUPS.d.ts +3 -3
  3. package/dist/CUPS.d.ts.map +1 -1
  4. package/dist/CUPS.js +3 -3
  5. package/dist/Emailer/service.d.ts +3 -3
  6. package/dist/Emailer/service.d.ts.map +1 -1
  7. package/dist/Emailer/service.js +3 -3
  8. package/dist/MainFiberSet.d.ts +2 -2
  9. package/dist/MainFiberSet.d.ts.map +1 -1
  10. package/dist/MainFiberSet.js +3 -3
  11. package/dist/Model/Repository/Registry.d.ts +20 -0
  12. package/dist/Model/Repository/Registry.d.ts.map +1 -0
  13. package/dist/Model/Repository/Registry.js +17 -0
  14. package/dist/Model/Repository/internal/internal.d.ts +3 -3
  15. package/dist/Model/Repository/internal/internal.d.ts.map +1 -1
  16. package/dist/Model/Repository/internal/internal.js +22 -16
  17. package/dist/Model/Repository/makeRepo.d.ts +5 -4
  18. package/dist/Model/Repository/makeRepo.d.ts.map +1 -1
  19. package/dist/Model/Repository/makeRepo.js +4 -1
  20. package/dist/Model/Repository/service.d.ts +5 -0
  21. package/dist/Model/Repository/service.d.ts.map +1 -1
  22. package/dist/Model/Repository/validation.d.ts +7 -6
  23. package/dist/Model/Repository/validation.d.ts.map +1 -1
  24. package/dist/Model/Repository.d.ts +1 -0
  25. package/dist/Model/Repository.d.ts.map +1 -1
  26. package/dist/Model/Repository.js +2 -1
  27. package/dist/Model/query/dsl.d.ts +9 -9
  28. package/dist/Model.d.ts +1 -0
  29. package/dist/Model.d.ts.map +1 -1
  30. package/dist/Model.js +2 -1
  31. package/dist/Operations.d.ts +2 -2
  32. package/dist/Operations.d.ts.map +1 -1
  33. package/dist/Operations.js +3 -3
  34. package/dist/OperationsRepo.d.ts +3 -3
  35. package/dist/OperationsRepo.d.ts.map +1 -1
  36. package/dist/OperationsRepo.js +3 -3
  37. package/dist/QueueMaker/SQLQueue.d.ts +2 -4
  38. package/dist/QueueMaker/SQLQueue.d.ts.map +1 -1
  39. package/dist/QueueMaker/SQLQueue.js +8 -6
  40. package/dist/QueueMaker/errors.d.ts +1 -1
  41. package/dist/QueueMaker/errors.d.ts.map +1 -1
  42. package/dist/QueueMaker/memQueue.js +3 -3
  43. package/dist/QueueMaker/sbqueue.js +3 -3
  44. package/dist/RequestContext.d.ts +22 -17
  45. package/dist/RequestContext.d.ts.map +1 -1
  46. package/dist/RequestContext.js +5 -5
  47. package/dist/RequestFiberSet.d.ts +2 -2
  48. package/dist/RequestFiberSet.d.ts.map +1 -1
  49. package/dist/RequestFiberSet.js +5 -5
  50. package/dist/Store/ContextMapContainer.d.ts +19 -3
  51. package/dist/Store/ContextMapContainer.d.ts.map +1 -1
  52. package/dist/Store/ContextMapContainer.js +13 -3
  53. package/dist/Store/Cosmos.d.ts.map +1 -1
  54. package/dist/Store/Cosmos.js +136 -68
  55. package/dist/Store/Disk.d.ts.map +1 -1
  56. package/dist/Store/Disk.js +24 -21
  57. package/dist/Store/Memory.d.ts +2 -2
  58. package/dist/Store/Memory.d.ts.map +1 -1
  59. package/dist/Store/Memory.js +26 -21
  60. package/dist/Store/SQL/Pg.d.ts +4 -0
  61. package/dist/Store/SQL/Pg.d.ts.map +1 -0
  62. package/dist/Store/SQL/Pg.js +191 -0
  63. package/dist/Store/SQL/query.d.ts +38 -0
  64. package/dist/Store/SQL/query.d.ts.map +1 -0
  65. package/dist/Store/SQL/query.js +367 -0
  66. package/dist/Store/SQL.d.ts +20 -0
  67. package/dist/Store/SQL.d.ts.map +1 -0
  68. package/dist/Store/SQL.js +381 -0
  69. package/dist/Store/index.d.ts +4 -1
  70. package/dist/Store/index.d.ts.map +1 -1
  71. package/dist/Store/index.js +15 -3
  72. package/dist/Store/service.d.ts +16 -5
  73. package/dist/Store/service.d.ts.map +1 -1
  74. package/dist/Store/service.js +24 -6
  75. package/dist/adapters/ServiceBus.d.ts +6 -6
  76. package/dist/adapters/ServiceBus.d.ts.map +1 -1
  77. package/dist/adapters/ServiceBus.js +9 -9
  78. package/dist/adapters/cosmos-client.d.ts +2 -2
  79. package/dist/adapters/cosmos-client.d.ts.map +1 -1
  80. package/dist/adapters/cosmos-client.js +3 -3
  81. package/dist/adapters/logger.d.ts.map +1 -1
  82. package/dist/adapters/memQueue.d.ts +2 -2
  83. package/dist/adapters/memQueue.d.ts.map +1 -1
  84. package/dist/adapters/memQueue.js +3 -3
  85. package/dist/adapters/mongo-client.d.ts +2 -2
  86. package/dist/adapters/mongo-client.d.ts.map +1 -1
  87. package/dist/adapters/mongo-client.js +3 -3
  88. package/dist/adapters/redis-client.d.ts +3 -3
  89. package/dist/adapters/redis-client.d.ts.map +1 -1
  90. package/dist/adapters/redis-client.js +3 -3
  91. package/dist/api/ContextProvider.d.ts +6 -6
  92. package/dist/api/ContextProvider.d.ts.map +1 -1
  93. package/dist/api/ContextProvider.js +6 -6
  94. package/dist/api/internal/auth.d.ts +1 -1
  95. package/dist/api/internal/events.d.ts +2 -2
  96. package/dist/api/internal/events.d.ts.map +1 -1
  97. package/dist/api/internal/events.js +11 -7
  98. package/dist/api/layerUtils.d.ts +5 -5
  99. package/dist/api/layerUtils.d.ts.map +1 -1
  100. package/dist/api/layerUtils.js +5 -5
  101. package/dist/api/routing/middleware/RouterMiddleware.d.ts +3 -3
  102. package/dist/api/routing/middleware/RouterMiddleware.d.ts.map +1 -1
  103. package/dist/api/routing/middleware/middleware.d.ts +35 -1
  104. package/dist/api/routing/middleware/middleware.d.ts.map +1 -1
  105. package/dist/api/routing/middleware/middleware.js +39 -1
  106. package/dist/api/routing.d.ts +1 -5
  107. package/dist/api/routing.d.ts.map +1 -1
  108. package/dist/api/routing.js +3 -2
  109. package/dist/api/setupRequest.d.ts +6 -3
  110. package/dist/api/setupRequest.d.ts.map +1 -1
  111. package/dist/api/setupRequest.js +11 -6
  112. package/dist/logger.d.ts.map +1 -1
  113. package/examples/query.ts +30 -26
  114. package/package.json +36 -18
  115. package/src/CUPS.ts +2 -2
  116. package/src/Emailer/service.ts +2 -2
  117. package/src/MainFiberSet.ts +2 -2
  118. package/src/Model/Repository/Registry.ts +33 -0
  119. package/src/Model/Repository/internal/internal.ts +76 -59
  120. package/src/Model/Repository/makeRepo.ts +7 -4
  121. package/src/Model/Repository/service.ts +6 -0
  122. package/src/Model/Repository.ts +1 -0
  123. package/src/Model.ts +1 -0
  124. package/src/Operations.ts +2 -2
  125. package/src/OperationsRepo.ts +2 -2
  126. package/src/QueueMaker/SQLQueue.ts +8 -7
  127. package/src/QueueMaker/memQueue.ts +2 -2
  128. package/src/QueueMaker/sbqueue.ts +2 -2
  129. package/src/RequestContext.ts +4 -4
  130. package/src/RequestFiberSet.ts +4 -4
  131. package/src/Store/ContextMapContainer.ts +41 -2
  132. package/src/Store/Cosmos.ts +350 -255
  133. package/src/Store/Disk.ts +37 -33
  134. package/src/Store/Memory.ts +29 -22
  135. package/src/Store/SQL/Pg.ts +321 -0
  136. package/src/Store/SQL/query.ts +409 -0
  137. package/src/Store/SQL.ts +674 -0
  138. package/src/Store/index.ts +17 -2
  139. package/src/Store/service.ts +31 -7
  140. package/src/adapters/ServiceBus.ts +8 -8
  141. package/src/adapters/cosmos-client.ts +2 -2
  142. package/src/adapters/memQueue.ts +2 -2
  143. package/src/adapters/mongo-client.ts +2 -2
  144. package/src/adapters/redis-client.ts +2 -2
  145. package/src/api/ContextProvider.ts +11 -11
  146. package/src/api/internal/events.ts +14 -9
  147. package/src/api/layerUtils.ts +8 -8
  148. package/src/api/routing/middleware/RouterMiddleware.ts +4 -4
  149. package/src/api/routing/middleware/middleware.ts +43 -0
  150. package/src/api/routing.ts +3 -3
  151. package/src/api/setupRequest.ts +27 -7
  152. package/test/contextProvider.test.ts +11 -11
  153. package/test/controller.test.ts +12 -9
  154. package/test/dist/contextProvider.test.d.ts.map +1 -1
  155. package/test/dist/controller.test.d.ts.map +1 -1
  156. package/test/dist/date-query.test.d.ts.map +1 -0
  157. package/test/dist/fixtures.d.ts +19 -9
  158. package/test/dist/fixtures.d.ts.map +1 -1
  159. package/test/dist/fixtures.js +11 -9
  160. package/test/dist/query.test.d.ts.map +1 -1
  161. package/test/dist/rawQuery.test.d.ts.map +1 -1
  162. package/test/dist/requires.test.d.ts.map +1 -1
  163. package/test/dist/rpc-multi-middleware.test.d.ts.map +1 -1
  164. package/test/dist/sql-store.test.d.ts.map +1 -0
  165. package/test/fixtures.ts +10 -8
  166. package/test/query.test.ts +182 -33
  167. package/test/rawQuery.test.ts +22 -18
  168. package/test/requires.test.ts +6 -5
  169. package/test/rpc-multi-middleware.test.ts +72 -3
  170. package/test/sql-store.test.ts +1064 -0
  171. package/test/validateSample.test.ts +12 -9
  172. package/tsconfig.json +0 -1
@@ -0,0 +1,367 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { Effect } from "effect-app";
3
+ import { assertUnreachable } from "effect-app/utils";
4
+ import { InfraLogger } from "../../logger.js";
5
+ import { isRelationCheck } from "../codeFilter.js";
6
+ export const sqliteDialect = {
7
+ jsonExtract: (path) => `json_extract(data, '$.${path}')`,
8
+ jsonExtractJson: (path) => `CASE json_type(data, '$.${path}') WHEN 'true' THEN 'true' WHEN 'false' THEN 'false' ELSE json_quote(json_extract(data, '$.${path}')) END`,
9
+ placeholder: (_index) => "?",
10
+ jsonArrayContains: (arrPath, val) => `EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value = ${val})`,
11
+ jsonArrayNotContains: (arrPath, val) => `NOT EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value = ${val})`,
12
+ jsonArrayContainsAny: (arrPath, vals) => `EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value IN (${vals.join(", ")}))`,
13
+ jsonArrayNotContainsAny: (arrPath, vals) => `NOT EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value IN (${vals.join(", ")}))`,
14
+ jsonArrayContainsAll: (arrPath, vals) => vals.map((v) => `EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value = ${v})`).join(" AND "),
15
+ jsonArrayNotContainsAll: (arrPath, vals) => `NOT (${vals.map((v) => `EXISTS(SELECT 1 FROM json_each(data, '$.${arrPath}') WHERE value = ${v})`).join(" AND ")})`,
16
+ caseInsensitiveLike: (expr, val) => `LOWER(${expr}) LIKE LOWER(${val})`,
17
+ caseInsensitiveNotLike: (expr, val) => `LOWER(${expr}) NOT LIKE LOWER(${val})`,
18
+ jsonColumnType: "JSON",
19
+ arrayLength: (path) => `json_array_length(data, '$.${path}')`,
20
+ jsonEachFrom: (arrPath, alias) => `json_each(data, '$.${arrPath}') AS ${alias}`,
21
+ jsonExtractElement: (alias, subPath) => `json_extract(${alias}.value, '$.${subPath}')`,
22
+ serializeJsonValue: (v) => v,
23
+ // SQLite stores JSON booleans as integers (0/1) and better-sqlite3 refuses
24
+ // to bind JS booleans, so coerce them to integers for WHERE params.
25
+ serializeScalar: (v) => typeof v === "boolean" ? (v ? 1 : 0) : v
26
+ };
27
+ export const pgDialect = {
28
+ jsonExtract: (path) => {
29
+ const parts = path.split(".");
30
+ if (parts.length === 1)
31
+ return `data->>'${parts[0]}'`;
32
+ const last = parts.pop();
33
+ return `data${parts.map((p) => `->'${p}'`).join("")}->>'${last}'`;
34
+ },
35
+ jsonExtractJson: (path) => {
36
+ const parts = path.split(".");
37
+ if (parts.length === 1)
38
+ return `data->'${parts[0]}'`;
39
+ return `data${parts.map((p) => `->'${p}'`).join("")}`;
40
+ },
41
+ placeholder: (index) => `$${index}`,
42
+ jsonArrayContains: (arrPath, val) => {
43
+ const parts = arrPath.split(".");
44
+ const jsonPath = parts.length === 1
45
+ ? `data->'${parts[0]}'`
46
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
47
+ return `${jsonPath} @> ${val}::jsonb`;
48
+ },
49
+ jsonArrayNotContains: (arrPath, val) => {
50
+ const parts = arrPath.split(".");
51
+ const jsonPath = parts.length === 1
52
+ ? `data->'${parts[0]}'`
53
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
54
+ return `NOT (${jsonPath} @> ${val}::jsonb)`;
55
+ },
56
+ jsonArrayContainsAny: (arrPath, vals) => {
57
+ const parts = arrPath.split(".");
58
+ const jsonPath = parts.length === 1
59
+ ? `data->'${parts[0]}'`
60
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
61
+ return `(${vals.map((v) => `${jsonPath} @> ${v}::jsonb`).join(" OR ")})`;
62
+ },
63
+ jsonArrayNotContainsAny: (arrPath, vals) => {
64
+ const parts = arrPath.split(".");
65
+ const jsonPath = parts.length === 1
66
+ ? `data->'${parts[0]}'`
67
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
68
+ return `NOT (${vals.map((v) => `${jsonPath} @> ${v}::jsonb`).join(" OR ")})`;
69
+ },
70
+ jsonArrayContainsAll: (arrPath, vals) => {
71
+ const parts = arrPath.split(".");
72
+ const jsonPath = parts.length === 1
73
+ ? `data->'${parts[0]}'`
74
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
75
+ return vals.map((v) => `${jsonPath} @> ${v}::jsonb`).join(" AND ");
76
+ },
77
+ jsonArrayNotContainsAll: (arrPath, vals) => {
78
+ const parts = arrPath.split(".");
79
+ const jsonPath = parts.length === 1
80
+ ? `data->'${parts[0]}'`
81
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
82
+ return `NOT (${vals.map((v) => `${jsonPath} @> ${v}::jsonb`).join(" AND ")})`;
83
+ },
84
+ caseInsensitiveLike: (expr, val) => `${expr} ILIKE ${val}`,
85
+ caseInsensitiveNotLike: (expr, val) => `${expr} NOT ILIKE ${val}`,
86
+ jsonColumnType: "JSONB",
87
+ arrayLength: (path) => `jsonb_array_length(data->'${path}')`,
88
+ jsonEachFrom: (arrPath, alias) => {
89
+ const parts = arrPath.split(".");
90
+ const jsonPath = parts.length === 1
91
+ ? `data->'${parts[0]}'`
92
+ : `data${parts.map((p) => `->'${p}'`).join("")}`;
93
+ return `jsonb_array_elements(${jsonPath}) AS ${alias}`;
94
+ },
95
+ jsonExtractElement: (alias, subPath) => {
96
+ const parts = subPath.split(".");
97
+ if (parts.length === 1)
98
+ return `${alias}->>'${parts[0]}'`;
99
+ const last = parts.pop();
100
+ return `${alias}${parts.map((p) => `->'${p}'`).join("")}->>'${last}'`;
101
+ },
102
+ serializeJsonValue: (v) => JSON.stringify(v),
103
+ // PG's ->> operator yields text, so compare booleans as 'true'/'false' text.
104
+ serializeScalar: (v) => typeof v === "boolean" ? (v ? "true" : "false") : v
105
+ };
106
+ export function logQuery(q) {
107
+ return InfraLogger
108
+ .logDebug("sql query")
109
+ .pipe(Effect.annotateLogs({
110
+ query: q.sql,
111
+ parameters: JSON.stringify(q.params, undefined, 2)
112
+ }));
113
+ }
114
+ const dottedToJsonPath = (path) => path
115
+ .split(".")
116
+ .filter((p) => p !== "-1")
117
+ .join(".");
118
+ export function buildWhereSQLQuery(dialect, idKey, filter, tableName, defaultValues, select, order, skip, limit) {
119
+ const params = [];
120
+ let paramIndex = 1;
121
+ const addParam = (value) => {
122
+ params.push(dialect.serializeScalar(value));
123
+ return dialect.placeholder(paramIndex++);
124
+ };
125
+ const fieldExpr = (path, relation) => {
126
+ if (path === idKey || path === "id")
127
+ return "id";
128
+ if (relation && path.includes(".-1.")) {
129
+ const subPath = path.split(".-1.")[1];
130
+ if (subPath.endsWith(".length")) {
131
+ // TODO: array length inside relation element
132
+ return dialect.jsonExtractElement(`_${relation}`, subPath.slice(0, -".length".length));
133
+ }
134
+ return dialect.jsonExtractElement(`_${relation}`, subPath);
135
+ }
136
+ if (path.endsWith(".length")) {
137
+ const arrPath = dottedToJsonPath(path.slice(0, -".length".length));
138
+ return dialect.arrayLength(arrPath);
139
+ }
140
+ const jsonPath = dottedToJsonPath(path);
141
+ const expr = dialect.jsonExtract(jsonPath);
142
+ const topKey = path.split(".")[0];
143
+ if (topKey in defaultValues) {
144
+ return `COALESCE(${expr}, ${addParam(defaultValues[topKey])})`;
145
+ }
146
+ return expr;
147
+ };
148
+ const statement = (x, relation) => {
149
+ const resolvedPath = x.path === idKey ? "id" : x.path;
150
+ const k = fieldExpr(resolvedPath, relation);
151
+ switch (x.op) {
152
+ case "in": {
153
+ const vals = x.value;
154
+ const hasNull = vals.some((v) => v == null);
155
+ const nonNullVals = vals.filter((v) => v != null);
156
+ const parts = [];
157
+ if (nonNullVals.length > 0) {
158
+ const placeholders = nonNullVals.map((v) => addParam(v));
159
+ parts.push(`${k} IN (${placeholders.join(", ")})`);
160
+ }
161
+ if (hasNull)
162
+ parts.push(`${k} IS NULL`);
163
+ return parts.length > 1 ? `(${parts.join(" OR ")})` : parts[0] ?? "1=0";
164
+ }
165
+ case "notIn": {
166
+ const vals = x.value;
167
+ const hasNull = vals.some((v) => v == null);
168
+ const nonNullVals = vals.filter((v) => v != null);
169
+ const parts = [];
170
+ if (nonNullVals.length > 0) {
171
+ const placeholders = nonNullVals.map((v) => addParam(v));
172
+ parts.push(`${k} NOT IN (${placeholders.join(", ")})`);
173
+ }
174
+ if (hasNull)
175
+ parts.push(`${k} IS NOT NULL`);
176
+ return parts.length > 1 ? `(${parts.join(" AND ")})` : parts[0] ?? "1=1";
177
+ }
178
+ case "includes": {
179
+ const arrPath = dottedToJsonPath(resolvedPath);
180
+ const v = addParam(x.value);
181
+ return dialect.jsonArrayContains(arrPath, v);
182
+ }
183
+ case "notIncludes": {
184
+ const arrPath = dottedToJsonPath(resolvedPath);
185
+ const v = addParam(x.value);
186
+ return dialect.jsonArrayNotContains(arrPath, v);
187
+ }
188
+ case "includes-any": {
189
+ const arrPath = dottedToJsonPath(resolvedPath);
190
+ const vals = x.value;
191
+ const placeholders = vals.map((v) => addParam(dialect.serializeJsonValue(v)));
192
+ return dialect.jsonArrayContainsAny(arrPath, placeholders);
193
+ }
194
+ case "notIncludes-any": {
195
+ const arrPath = dottedToJsonPath(resolvedPath);
196
+ const vals = x.value;
197
+ const placeholders = vals.map((v) => addParam(dialect.serializeJsonValue(v)));
198
+ return dialect.jsonArrayNotContainsAny(arrPath, placeholders);
199
+ }
200
+ case "includes-all": {
201
+ const arrPath = dottedToJsonPath(resolvedPath);
202
+ const vals = x.value;
203
+ const placeholders = vals.map((v) => addParam(dialect.serializeJsonValue(v)));
204
+ return dialect.jsonArrayContainsAll(arrPath, placeholders);
205
+ }
206
+ case "notIncludes-all": {
207
+ const arrPath = dottedToJsonPath(resolvedPath);
208
+ const vals = x.value;
209
+ const placeholders = vals.map((v) => addParam(dialect.serializeJsonValue(v)));
210
+ return dialect.jsonArrayNotContainsAll(arrPath, placeholders);
211
+ }
212
+ case "contains": {
213
+ const v = addParam(`%${x.value}%`);
214
+ return dialect.caseInsensitiveLike(k, v);
215
+ }
216
+ case "notContains": {
217
+ const v = addParam(`%${x.value}%`);
218
+ return dialect.caseInsensitiveNotLike(k, v);
219
+ }
220
+ case "startsWith": {
221
+ const v = addParam(`${x.value}%`);
222
+ return dialect.caseInsensitiveLike(k, v);
223
+ }
224
+ case "notStartsWith": {
225
+ const v = addParam(`${x.value}%`);
226
+ return dialect.caseInsensitiveNotLike(k, v);
227
+ }
228
+ case "endsWith": {
229
+ const v = addParam(`%${x.value}`);
230
+ return dialect.caseInsensitiveLike(k, v);
231
+ }
232
+ case "notEndsWith": {
233
+ const v = addParam(`%${x.value}`);
234
+ return dialect.caseInsensitiveNotLike(k, v);
235
+ }
236
+ case "lt": {
237
+ const v = addParam(x.value);
238
+ return `${k} < ${v}`;
239
+ }
240
+ case "lte": {
241
+ const v = addParam(x.value);
242
+ return `${k} <= ${v}`;
243
+ }
244
+ case "gt": {
245
+ const v = addParam(x.value);
246
+ return `${k} > ${v}`;
247
+ }
248
+ case "gte": {
249
+ const v = addParam(x.value);
250
+ return `${k} >= ${v}`;
251
+ }
252
+ case "neq": {
253
+ if (x.value === null)
254
+ return `${k} IS NOT NULL`;
255
+ const v = addParam(x.value);
256
+ return `${k} <> ${v}`;
257
+ }
258
+ case undefined:
259
+ case "eq": {
260
+ if (x.value === null)
261
+ return `${k} IS NULL`;
262
+ const v = addParam(x.value);
263
+ return `${k} = ${v}`;
264
+ }
265
+ default:
266
+ return assertUnreachable(x.op);
267
+ }
268
+ };
269
+ const wrapRelation = (rel, inner, every) => {
270
+ // Optimize tautological/contradictory conditions
271
+ if (every && inner === "1=1")
272
+ return "1=1";
273
+ if (!every && inner === "1=0")
274
+ return "1=0";
275
+ const from = dialect.jsonEachFrom(rel, `_${rel}`);
276
+ // ∀x.P(x) ≡ ¬∃x.¬P(x), i.e. NOT EXISTS(... WHERE NOT P)
277
+ return every
278
+ ? `NOT EXISTS(SELECT 1 FROM ${from} WHERE NOT (${inner}))`
279
+ : `EXISTS(SELECT 1 FROM ${from} WHERE ${inner})`;
280
+ };
281
+ const print = (state, isRelation, every) => {
282
+ let s = "";
283
+ for (const e of state) {
284
+ switch (e.t) {
285
+ case "where":
286
+ s += statement(e, isRelation ?? undefined);
287
+ break;
288
+ case "or":
289
+ s += ` OR ${statement(e, isRelation ?? undefined)}`;
290
+ break;
291
+ case "and":
292
+ s += ` AND ${statement(e, isRelation ?? undefined)}`;
293
+ break;
294
+ case "or-scope": {
295
+ if (!every)
296
+ every = e.relation === "every";
297
+ const rel = isRelationCheck(e.result, isRelation);
298
+ if (rel) {
299
+ s += isRelation
300
+ ? ` OR (${print(e.result, rel, every)})`
301
+ : ` OR ${wrapRelation(rel, print(e.result, rel, every), every)}`;
302
+ }
303
+ else {
304
+ s += ` OR (${print(e.result, null, every)})`;
305
+ }
306
+ break;
307
+ }
308
+ case "and-scope": {
309
+ if (!every)
310
+ every = e.relation === "every";
311
+ const rel = isRelationCheck(e.result, isRelation);
312
+ if (rel) {
313
+ s += isRelation
314
+ ? ` AND (${print(e.result, rel, every)})`
315
+ : ` AND ${wrapRelation(rel, print(e.result, rel, every), every)}`;
316
+ }
317
+ else {
318
+ s += ` AND (${print(e.result, null, every)})`;
319
+ }
320
+ break;
321
+ }
322
+ case "where-scope": {
323
+ if (!every)
324
+ every = e.relation === "every";
325
+ const rel = isRelationCheck(e.result, isRelation);
326
+ if (rel) {
327
+ s += isRelation
328
+ ? `(${print(e.result, rel, every)})`
329
+ : wrapRelation(rel, print(e.result, rel, every), every);
330
+ }
331
+ else {
332
+ s += `(${print(e.result, null, every)})`;
333
+ }
334
+ break;
335
+ }
336
+ }
337
+ }
338
+ return s;
339
+ };
340
+ const getSelectExpr = () => {
341
+ if (!select)
342
+ return "id, _etag, data";
343
+ const fields = select.map((s) => {
344
+ if (typeof s === "string") {
345
+ if (s === idKey || s === "id")
346
+ return `id`;
347
+ if (s === "_etag")
348
+ return `_etag`;
349
+ return `${dialect.jsonExtractJson(s)} AS "${s}"`;
350
+ }
351
+ return `${dialect.jsonExtractJson(s.key)} AS "${s.key}"`;
352
+ });
353
+ return fields.join(", ");
354
+ };
355
+ const whereClause = filter.length
356
+ ? `WHERE ${print([{ t: "where-scope", result: filter, relation: "some" }], null, false)}`
357
+ : "";
358
+ const orderClause = order
359
+ ? `ORDER BY ${order.map((_) => `${fieldExpr(_.key)} ${_.direction}`).join(", ")}`
360
+ : "";
361
+ const limitClause = limit !== undefined || skip !== undefined
362
+ ? `LIMIT ${addParam(limit ?? 999999)} OFFSET ${addParam(skip ?? 0)}`
363
+ : "";
364
+ const sql = `SELECT ${getSelectExpr()} FROM "${tableName}" ${whereClause} ${orderClause} ${limitClause}`.trim();
365
+ return { sql, params };
366
+ }
367
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvU3RvcmUvU1FML3F1ZXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHVEQUF1RDtBQUN2RCxPQUFPLEVBQUUsTUFBTSxFQUE4QixNQUFNLFlBQVksQ0FBQTtBQUMvRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFFN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFBO0FBc0JsRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWU7SUFDdkMsV0FBVyxFQUFFLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyx5QkFBeUIsSUFBSSxJQUFJO0lBQ3hELGVBQWUsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLENBQ3hCLDJCQUEyQixJQUFJLDhGQUE4RixJQUFJLFNBQVM7SUFDNUksV0FBVyxFQUFFLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxHQUFHO0lBQzVCLGlCQUFpQixFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsMkNBQTJDLE9BQU8sb0JBQW9CLEdBQUcsR0FBRztJQUNqSCxvQkFBb0IsRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUNyQywrQ0FBK0MsT0FBTyxvQkFBb0IsR0FBRyxHQUFHO0lBQ2xGLG9CQUFvQixFQUFFLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxFQUFFLENBQ3RDLDJDQUEyQyxPQUFPLHNCQUFzQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO0lBQzdGLHVCQUF1QixFQUFFLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxFQUFFLENBQ3pDLCtDQUErQyxPQUFPLHNCQUFzQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO0lBQ2pHLG9CQUFv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
@@ -0,0 +1,20 @@
1
+ import { Context, Layer } from "effect";
2
+ import { Effect } from "effect-app";
3
+ import { SqlClient } from "effect/unstable/sql";
4
+ import type { FieldValues } from "../Model/filter/types.js";
5
+ import { type PersistenceModelType, type StorageConfig, StoreMaker } from "./service.js";
6
+ export type WithNsTransactionFn = <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>;
7
+ declare const WithNsTransaction_base: Context.ServiceClass<WithNsTransaction, "effect-app/WithNsTransaction", WithNsTransactionFn>;
8
+ export declare class WithNsTransaction extends WithNsTransaction_base {
9
+ }
10
+ /** @internal */
11
+ export declare const parseRow: <Encoded extends FieldValues>(row: {
12
+ id: string;
13
+ _etag: string | null;
14
+ data: string;
15
+ }, idKey: PropertyKey, defaultValues: Partial<Encoded>) => PersistenceModelType<Encoded>;
16
+ export declare function SQLiteStoreLayer(cfg: StorageConfig, options?: {
17
+ makeSqlClientLayer?: (namespace: string) => Layer.Layer<SqlClient.SqlClient>;
18
+ }): Layer.Layer<StoreMaker, never, SqlClient.SqlClient>;
19
+ export {};
20
+ //# sourceMappingURL=SQL.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SQL.d.ts","sourceRoot":"","sources":["../../src/Store/SQL.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAY,MAAM,QAAQ,CAAA;AACjD,OAAO,EAAE,MAAM,EAA8C,MAAM,YAAY,CAAA;AAE/E,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAG/C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AAE3D,OAAO,EAAmB,KAAK,oBAAoB,EAAE,KAAK,aAAa,EAAgC,UAAU,EAAE,MAAM,cAAc,CAAA;AAIvI,MAAM,MAAM,mBAAmB,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;;AAErG,qBAAa,iBACX,SAAQ,sBAAyF;CACjG;AAEF,gBAAgB;AAChB,eAAO,MAAM,QAAQ,GAAI,OAAO,SAAS,WAAW,EAClD,KAAK;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EACvD,OAAO,WAAW,EAClB,eAAe,OAAO,CAAC,OAAO,CAAC,KAC9B,oBAAoB,CAAC,OAAO,CAG9B,CAAA;AAwmBD,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,aAAa,EAClB,OAAO,CAAC,EAAE;IAAE,kBAAkB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,CAAA;CAAE,uDA2B3F"}