joist-core 2.1.0 → 2.2.0-next.10

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 (217) hide show
  1. package/build/BaseEntity.js +1 -1
  2. package/build/BaseEntity.js.map +1 -1
  3. package/build/ConditionBuilder.d.ts +1 -22
  4. package/build/ConditionBuilder.d.ts.map +1 -1
  5. package/build/ConditionBuilder.js +6 -72
  6. package/build/ConditionBuilder.js.map +1 -1
  7. package/build/EntityFilter.d.ts +4 -2
  8. package/build/EntityFilter.d.ts.map +1 -1
  9. package/build/EntityGraphQLFilter.d.ts +2 -0
  10. package/build/EntityGraphQLFilter.d.ts.map +1 -1
  11. package/build/EntityGraphQLFilter.js.map +1 -1
  12. package/build/EntityManager.d.ts +27 -39
  13. package/build/EntityManager.d.ts.map +1 -1
  14. package/build/EntityManager.js +243 -122
  15. package/build/EntityManager.js.map +1 -1
  16. package/build/EntityMetadata.d.ts +19 -1
  17. package/build/EntityMetadata.d.ts.map +1 -1
  18. package/build/EntityMetadata.js.map +1 -1
  19. package/build/IndexManager.d.ts +2 -2
  20. package/build/IndexManager.d.ts.map +1 -1
  21. package/build/IndexManager.js +22 -16
  22. package/build/IndexManager.js.map +1 -1
  23. package/build/InstanceData.d.ts +21 -3
  24. package/build/InstanceData.d.ts.map +1 -1
  25. package/build/InstanceData.js +70 -10
  26. package/build/InstanceData.js.map +1 -1
  27. package/build/IsLoadedCache.d.ts +1 -1
  28. package/build/IsLoadedCache.d.ts.map +1 -1
  29. package/build/IsLoadedCache.js +37 -26
  30. package/build/IsLoadedCache.js.map +1 -1
  31. package/build/JoinRows.d.ts +1 -1
  32. package/build/JoinRows.js +6 -1
  33. package/build/JoinRows.js.map +1 -1
  34. package/build/PluginManager.d.ts +12 -0
  35. package/build/PluginManager.d.ts.map +1 -1
  36. package/build/PluginManager.js +18 -2
  37. package/build/PluginManager.js.map +1 -1
  38. package/build/QueryParser.collectionJoins.d.ts +27 -0
  39. package/build/QueryParser.collectionJoins.d.ts.map +1 -0
  40. package/build/QueryParser.collectionJoins.js +466 -0
  41. package/build/QueryParser.collectionJoins.js.map +1 -0
  42. package/build/QueryParser.collectionJoins.test.d.ts +2 -0
  43. package/build/QueryParser.collectionJoins.test.d.ts.map +1 -0
  44. package/build/QueryParser.collectionJoins.test.js +772 -0
  45. package/build/QueryParser.collectionJoins.test.js.map +1 -0
  46. package/build/QueryParser.d.ts +71 -11
  47. package/build/QueryParser.d.ts.map +1 -1
  48. package/build/QueryParser.js +39 -33
  49. package/build/QueryParser.js.map +1 -1
  50. package/build/QueryParser.pruning.d.ts +4 -2
  51. package/build/QueryParser.pruning.d.ts.map +1 -1
  52. package/build/QueryParser.pruning.js +87 -10
  53. package/build/QueryParser.pruning.js.map +1 -1
  54. package/build/QueryParser.pruning.test.d.ts +2 -0
  55. package/build/QueryParser.pruning.test.d.ts.map +1 -0
  56. package/build/QueryParser.pruning.test.js +106 -0
  57. package/build/QueryParser.pruning.test.js.map +1 -0
  58. package/build/QueryVisitor.d.ts.map +1 -1
  59. package/build/QueryVisitor.js +22 -0
  60. package/build/QueryVisitor.js.map +1 -1
  61. package/build/ReactionsManager.d.ts +2 -1
  62. package/build/ReactionsManager.d.ts.map +1 -1
  63. package/build/ReactionsManager.js +55 -51
  64. package/build/ReactionsManager.js.map +1 -1
  65. package/build/batchloaders/BatchLoader.d.ts.map +1 -1
  66. package/build/batchloaders/BatchLoader.js +9 -1
  67. package/build/batchloaders/BatchLoader.js.map +1 -1
  68. package/build/batchloaders/manyToManyBatchLoader.js +3 -1
  69. package/build/batchloaders/manyToManyBatchLoader.js.map +1 -1
  70. package/build/batchloaders/populateBatchLoader.d.ts.map +1 -1
  71. package/build/batchloaders/populateBatchLoader.js +2 -1
  72. package/build/batchloaders/populateBatchLoader.js.map +1 -1
  73. package/build/batchloaders/recursiveM2mBatchLoader.d.ts.map +1 -1
  74. package/build/batchloaders/recursiveM2mBatchLoader.js +3 -1
  75. package/build/batchloaders/recursiveM2mBatchLoader.js.map +1 -1
  76. package/build/changes.d.ts.map +1 -1
  77. package/build/changes.js +1 -4
  78. package/build/changes.js.map +1 -1
  79. package/build/config.d.ts.map +1 -1
  80. package/build/config.js +18 -10
  81. package/build/config.js.map +1 -1
  82. package/build/configure.d.ts +3 -3
  83. package/build/configure.d.ts.map +1 -1
  84. package/build/configure.js +66 -2
  85. package/build/configure.js.map +1 -1
  86. package/build/dataloaders/fastWhereFilterHash.d.ts +15 -0
  87. package/build/dataloaders/fastWhereFilterHash.d.ts.map +1 -0
  88. package/build/dataloaders/fastWhereFilterHash.js +164 -0
  89. package/build/dataloaders/fastWhereFilterHash.js.map +1 -0
  90. package/build/dataloaders/fastWhereFilterHash.test.d.ts +2 -0
  91. package/build/dataloaders/fastWhereFilterHash.test.d.ts.map +1 -0
  92. package/build/dataloaders/fastWhereFilterHash.test.js +59 -0
  93. package/build/dataloaders/fastWhereFilterHash.test.js.map +1 -0
  94. package/build/dataloaders/findCountDataLoader.d.ts +1 -2
  95. package/build/dataloaders/findCountDataLoader.d.ts.map +1 -1
  96. package/build/dataloaders/findCountDataLoader.js +16 -13
  97. package/build/dataloaders/findCountDataLoader.js.map +1 -1
  98. package/build/dataloaders/findDataLoader.d.ts +7 -3
  99. package/build/dataloaders/findDataLoader.d.ts.map +1 -1
  100. package/build/dataloaders/findDataLoader.js +105 -91
  101. package/build/dataloaders/findDataLoader.js.map +1 -1
  102. package/build/dataloaders/findIdsDataLoader.d.ts +1 -2
  103. package/build/dataloaders/findIdsDataLoader.d.ts.map +1 -1
  104. package/build/dataloaders/findIdsDataLoader.js +16 -15
  105. package/build/dataloaders/findIdsDataLoader.js.map +1 -1
  106. package/build/dataloaders/findOrCreateDataLoader.d.ts.map +1 -1
  107. package/build/dataloaders/findOrCreateDataLoader.js +7 -2
  108. package/build/dataloaders/findOrCreateDataLoader.js.map +1 -1
  109. package/build/dataloaders/findPaginatedDataLoader.d.ts +7 -0
  110. package/build/dataloaders/findPaginatedDataLoader.d.ts.map +1 -0
  111. package/build/dataloaders/findPaginatedDataLoader.js +79 -0
  112. package/build/dataloaders/findPaginatedDataLoader.js.map +1 -0
  113. package/build/defaults.d.ts.map +1 -1
  114. package/build/defaults.js +49 -42
  115. package/build/defaults.js.map +1 -1
  116. package/build/drivers/EntityWriter.js +13 -7
  117. package/build/drivers/EntityWriter.js.map +1 -1
  118. package/build/drivers/buildRawQuery.d.ts +6 -4
  119. package/build/drivers/buildRawQuery.d.ts.map +1 -1
  120. package/build/drivers/buildRawQuery.js +11 -6
  121. package/build/drivers/buildRawQuery.js.map +1 -1
  122. package/build/drivers/buildUtils.d.ts +7 -2
  123. package/build/drivers/buildUtils.d.ts.map +1 -1
  124. package/build/drivers/buildUtils.js +14 -5
  125. package/build/drivers/buildUtils.js.map +1 -1
  126. package/build/fields.d.ts.map +1 -1
  127. package/build/fields.js +31 -12
  128. package/build/fields.js.map +1 -1
  129. package/build/index.d.ts +2 -1
  130. package/build/index.d.ts.map +1 -1
  131. package/build/index.js +7 -5
  132. package/build/index.js.map +1 -1
  133. package/build/json.d.ts +3 -3
  134. package/build/json.d.ts.map +1 -1
  135. package/build/json.js +4 -4
  136. package/build/json.js.map +1 -1
  137. package/build/keys.d.ts.map +1 -1
  138. package/build/keys.js +8 -6
  139. package/build/keys.js.map +1 -1
  140. package/build/loadHints.d.ts +13 -4
  141. package/build/loadHints.d.ts.map +1 -1
  142. package/build/loadHints.js +63 -9
  143. package/build/loadHints.js.map +1 -1
  144. package/build/loadLens.d.ts +11 -0
  145. package/build/loadLens.d.ts.map +1 -1
  146. package/build/loadLens.js +25 -8
  147. package/build/loadLens.js.map +1 -1
  148. package/build/normalizeHints.d.ts +7 -0
  149. package/build/normalizeHints.d.ts.map +1 -1
  150. package/build/normalizeHints.js +40 -2
  151. package/build/normalizeHints.js.map +1 -1
  152. package/build/preloading/JsonAggregatePreloader.js +6 -2
  153. package/build/preloading/JsonAggregatePreloader.js.map +1 -1
  154. package/build/reactiveHints.d.ts +24 -7
  155. package/build/reactiveHints.d.ts.map +1 -1
  156. package/build/reactiveHints.js +45 -28
  157. package/build/reactiveHints.js.map +1 -1
  158. package/build/relations/AbstractRelationImpl.d.ts +7 -2
  159. package/build/relations/AbstractRelationImpl.d.ts.map +1 -1
  160. package/build/relations/AbstractRelationImpl.js.map +1 -1
  161. package/build/relations/AsyncProperty.d.ts +36 -0
  162. package/build/relations/AsyncProperty.d.ts.map +1 -0
  163. package/build/relations/AsyncProperty.js +80 -0
  164. package/build/relations/AsyncProperty.js.map +1 -0
  165. package/build/relations/{ReactiveQueryField.d.ts → AsyncReactiveField.d.ts} +10 -10
  166. package/build/relations/AsyncReactiveField.d.ts.map +1 -0
  167. package/build/relations/{ReactiveQueryField.js → AsyncReactiveField.js} +19 -19
  168. package/build/relations/{ReactiveQueryField.js.map → AsyncReactiveField.js.map} +1 -1
  169. package/build/relations/ReactiveField.d.ts +7 -9
  170. package/build/relations/ReactiveField.d.ts.map +1 -1
  171. package/build/relations/ReactiveField.js +5 -10
  172. package/build/relations/ReactiveField.js.map +1 -1
  173. package/build/relations/ReactiveGetter.d.ts +5 -5
  174. package/build/relations/ReactiveGetter.d.ts.map +1 -1
  175. package/build/relations/ReactiveGetter.js +3 -3
  176. package/build/relations/ReactiveGetter.js.map +1 -1
  177. package/build/relations/ReactiveReference.d.ts +2 -2
  178. package/build/relations/ReactiveReference.d.ts.map +1 -1
  179. package/build/relations/ReactiveReference.js +100 -36
  180. package/build/relations/ReactiveReference.js.map +1 -1
  181. package/build/relations/hasOneThrough.d.ts.map +1 -1
  182. package/build/relations/hasOneThrough.js +6 -4
  183. package/build/relations/hasOneThrough.js.map +1 -1
  184. package/build/relations/{hasAsyncProperty.d.ts → hasProperty.d.ts} +12 -12
  185. package/build/relations/hasProperty.d.ts.map +1 -0
  186. package/build/relations/{hasAsyncProperty.js → hasProperty.js} +20 -20
  187. package/build/relations/hasProperty.js.map +1 -0
  188. package/build/relations/index.d.ts +3 -2
  189. package/build/relations/index.d.ts.map +1 -1
  190. package/build/relations/index.js +16 -11
  191. package/build/relations/index.js.map +1 -1
  192. package/build/resurrection.d.ts +10 -0
  193. package/build/resurrection.d.ts.map +1 -0
  194. package/build/resurrection.js +93 -0
  195. package/build/resurrection.js.map +1 -0
  196. package/build/rules.js +3 -3
  197. package/build/trusted.d.ts +1 -1
  198. package/build/trusted.d.ts.map +1 -1
  199. package/build/trusted.js +1 -1
  200. package/build/trusted.js.map +1 -1
  201. package/build/upsert.d.ts.map +1 -1
  202. package/build/upsert.js +26 -10
  203. package/build/upsert.js.map +1 -1
  204. package/build/utils.d.ts +2 -0
  205. package/build/utils.d.ts.map +1 -1
  206. package/build/utils.js +12 -0
  207. package/build/utils.js.map +1 -1
  208. package/build/withLoaded.js +5 -5
  209. package/build/withLoaded.js.map +1 -1
  210. package/package.json +10 -12
  211. package/build/caches.d.ts +0 -6
  212. package/build/caches.d.ts.map +0 -1
  213. package/build/caches.js +0 -42
  214. package/build/caches.js.map +0 -1
  215. package/build/relations/ReactiveQueryField.d.ts.map +0 -1
  216. package/build/relations/hasAsyncProperty.d.ts.map +0 -1
  217. package/build/relations/hasAsyncProperty.js.map +0 -1
@@ -0,0 +1,466 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.optimizeCollectionJoins = optimizeCollectionJoins;
4
+ const QueryParser_1 = require("./QueryParser");
5
+ const QueryParser_pruning_1 = require("./QueryParser.pruning");
6
+ const utils_1 = require("./utils");
7
+ /**
8
+ * Rewrites eligible logical collection LEFT JOINs into EXISTS after plugins have mutated the AST.
9
+ *
10
+ * QueryParser intentionally leaves collection filters as ordinary joins so `beforeFind` plugins see
11
+ * stabler/simpler input than "sometimes JOINs / sometimes EXISTS".
12
+ *
13
+ * This pass runs after plugins and before SQL rendering:
14
+ *
15
+ * 1. `rewriteCollectionJoins` finds top-level collection joins and moves conditions that reference only
16
+ * that subtree into a correlated EXISTS subquery. I.e. `{ books: { title: "b1" } }` becomes
17
+ * `EXISTS (SELECT 1 FROM books b WHERE a.id = b.author_id AND b.title = 'b1')`.
18
+ * 2. The same helper recurses into the generated subquery, so nested collections become nested EXISTS clauses.
19
+ * I.e. `{ books: { reviews: { rating: 5 } } }` becomes EXISTS(books WHERE EXISTS(reviews)).
20
+ * 3. Conditions that cannot be safely moved stay as LEFT JOINs. I.e. `OR(b.title = 'x', a.first_name = 'x')`
21
+ * needs both aliases in one SQL scope, so `b` remains a join instead of becoming an EXISTS.
22
+ * 4. Remaining fanout LEFT JOIN roots are rejected unless `allowMultipleLeftJoins` is set,
23
+ * because they can produce cross-product row explosions.
24
+ * 5. Finally, `maybeAddIdNotNulls` and `pruneUnusedJoins` clean up the joins that remain.
25
+ */
26
+ function optimizeCollectionJoins(query, opts = {}) {
27
+ const { allowMultipleLeftJoins = false, optimizeJoinsToExists = true, pruneJoins = true, keepAliases = [] } = opts;
28
+ for (const table of query.tables) {
29
+ // I.e. batched find/count queries wrap the real query in a LATERAL subquery; optimize that inner query too,
30
+ // but let the outer query decide final pruning so it can keep the lateral alias itself.
31
+ if (table.join === "lateral")
32
+ optimizeCollectionJoins(table.query, { ...opts, pruneJoins: false });
33
+ }
34
+ if (optimizeJoinsToExists)
35
+ rewriteCollectionJoins(query, keepAliases);
36
+ // I.e. collection LEFT JOINs now fall into three buckets:
37
+ // 1. local real filters, like `{ books: { title: "b1" } }`, were rewritten to EXISTS above;
38
+ // 2. no local real filters, like `{ books: {}, comments: {} }`, are safe because pruning will remove them;
39
+ // 3. blocked real filters, like cross-scope ORs, must stay as LEFT JOINs and can multiply rows.
40
+ // Only the third bucket should trip the fanout guard.
41
+ const fanoutLeftJoinAliases = getCollectionRoots(query)
42
+ .filter((root) => conditionBlocksExistsRewrite(query.condition, root.aliases))
43
+ .map((root) => root.table.alias);
44
+ if (optimizeJoinsToExists && !allowMultipleLeftJoins && fanoutLeftJoinAliases.length > 1) {
45
+ throw new Error(`em.find would issue multiple LEFT JOINs across collection relations (${fanoutLeftJoinAliases.join(", ")}); pass allowMultipleLeftJoins: true if this fanout is intentional`);
46
+ }
47
+ if (query.tables.some((t) => t.join === "outer")) {
48
+ // I.e. preserve legacy LEFT JOIN null semantics for any joins that could not become EXISTS.
49
+ (0, QueryParser_1.maybeAddIdNotNulls)(query);
50
+ }
51
+ if (pruneJoins) {
52
+ // I.e. remove logical collection joins that were replaced by EXISTS and any joins only needed before plugin edits.
53
+ (0, QueryParser_pruning_1.pruneUnusedJoins)(query, keepAliases);
54
+ }
55
+ }
56
+ /**
57
+ * Rewrites root-level collection join subtrees into EXISTS when their conditions are locally scoped.
58
+ *
59
+ * I.e. for `authors a -> books b -> book_reviews br`, `b` is the collection root and `br` is part of its subtree.
60
+ */
61
+ function rewriteCollectionJoins(query, keepAliases = []) {
62
+ const roots = getCollectionRoots(query);
63
+ if (query.condition)
64
+ rewriteSiblingOrExpression(query, query.condition, roots, keepAliases);
65
+ for (const root of roots) {
66
+ if (queryReferencesAliasesOutsideConditions(query, root.aliases, keepAliases))
67
+ continue;
68
+ if (conditionHasCrossScopeReference(query.condition, root.aliases))
69
+ continue;
70
+ // I.e. move `b.title = 'x'` and `(br.rating = 5 OR br.rating = 4)`, but not `b.title = 'x' OR a.first_name = 'x'`.
71
+ const moved = query.condition ? removeLocallyScopedConditions(query.condition, root.aliases) : [];
72
+ if (moved.length === 0)
73
+ continue;
74
+ const exists = createExistsCondition(query, root, moved);
75
+ if (!exists) {
76
+ addConditions(query, moved);
77
+ continue;
78
+ }
79
+ addConditions(query, [exists]);
80
+ // I.e. after adding EXISTS, remove `books b` and its children from the outer FROM list.
81
+ query.tables = query.tables.filter((t) => !root.aliases.has(t.alias));
82
+ }
83
+ removeEmptyExpressions(query.condition);
84
+ }
85
+ /** Rewrites eligible sibling collection ORs while preserving outer/mixed-scope ORs as joins. */
86
+ function rewriteSiblingOrExpression(query, condition, roots, keepAliases) {
87
+ if (condition.kind !== "exp")
88
+ return;
89
+ if (condition.op === "or" && rewriteSiblingOrExpressionChildren(query, condition, roots, keepAliases))
90
+ return;
91
+ if (condition.op === "and") {
92
+ for (const child of condition.conditions)
93
+ rewriteSiblingOrExpression(query, child, roots, keepAliases);
94
+ }
95
+ }
96
+ /** Returns true when OR branches that are scoped to collection subtrees became EXISTS conditions. */
97
+ function rewriteSiblingOrExpressionChildren(query, exp, roots, keepAliases) {
98
+ const matches = [];
99
+ const usedAliases = new Set();
100
+ const usedRoots = new Set();
101
+ let hasAntiJoinBranch = false;
102
+ for (const condition of exp.conditions) {
103
+ if (!isRealCondition(condition))
104
+ return false;
105
+ const match = roots.find((root) => conditionReferencesOnlyAliases(condition, root.aliases));
106
+ if (!match) {
107
+ const found = conditionAliases(condition);
108
+ // I.e. `a.first_name = 'x'` can stay in the OR while `b.title = 'x'` becomes EXISTS, but
109
+ // `a.first_name = 'x' AND b.title = 'x'` must stay joined because one branch spans both scopes.
110
+ if (roots.some((root) => hasAnyAlias(found, root.aliases)))
111
+ return false;
112
+ continue;
113
+ }
114
+ matches.push({ collectionRoot: match, condition });
115
+ usedRoots.add(match.table.alias);
116
+ hasAntiJoinBranch ||= isCollectionAntiJoin(condition, match);
117
+ for (const alias of match.aliases)
118
+ usedAliases.add(alias);
119
+ }
120
+ if (matches.length === 0)
121
+ return false;
122
+ // I.e. rewrite true sibling collection ORs like `b.id IS NOT NULL OR c.id IS NOT NULL`, and same-root
123
+ // anti-join ORs like `b.id IS NULL OR br.rating = 5` that need `b.id IS NULL` to become `NOT EXISTS`.
124
+ // skip positive-only single-root ORs, i.e. ORs with no `b.id IS NULL` anti-join branch like
125
+ // `b.title = 'x' OR br.rating = 5`; mixed ordinary/collection ORs like `a.first_name = 'x' OR b.title = 'x'`
126
+ // are safe because only the collection branch is replaced. Aliases are also filtered elsewhere like
127
+ // `b.order = 1 AND (b.title = 'x' OR c.text = 'x')`, and aliases that must stay projected/sorted like
128
+ // `SELECT b.title` or `ORDER BY b.title`.
129
+ if ((matches.length === exp.conditions.length && usedRoots.size < 2 && !hasAntiJoinBranch) ||
130
+ conditionReferencesAliasesOutside(query.condition, exp, usedAliases) ||
131
+ queryReferencesAliasesOutsideConditions(query, usedAliases, keepAliases)) {
132
+ return false;
133
+ }
134
+ const existsConditions = new Map();
135
+ for (const match of matches) {
136
+ const exists = createExistsCondition(query, match.collectionRoot, [match.condition]);
137
+ if (!exists)
138
+ return false;
139
+ existsConditions.set(match.condition, exists);
140
+ }
141
+ exp.conditions = exp.conditions.map((condition) => existsConditions.get(condition) ?? condition);
142
+ // I.e. leave the collection joins in place for now; pruning removes them after all rewrites.
143
+ return true;
144
+ }
145
+ /** Creates an EXISTS/NOT EXISTS condition for moved collection filters, or undefined when a LEFT JOIN must stay. */
146
+ function createExistsCondition(query, collectionRoot, moved) {
147
+ const root = collectionRoot.table;
148
+ const hasOnlyAntiJoin = moved.length === 1 && isCollectionAntiJoin(moved[0], collectionRoot);
149
+ if (!hasOnlyAntiJoin && !moved.some(isRealCondition)) {
150
+ // I.e. only soft-delete/STI conditions moved; don't create an EXISTS that changes nothing.
151
+ return undefined;
152
+ }
153
+ if (!hasOnlyAntiJoin && moved.some((c) => conditionContainsCollectionAntiJoin(c, collectionRoot))) {
154
+ // I.e. `b.id IS NULL OR br.rating = 5` is not a pure anti-join; leave it as a LEFT JOIN for SQL semantics.
155
+ return undefined;
156
+ }
157
+ // I.e. `rpm` may correlate through `_pp_version.id = rpm.ready_plan_version_id`, so pruning must keep
158
+ // `_pp_version` even when the collection metadata's parent alias is only `pp`.
159
+ const correlationAliases = joinDependencies(root);
160
+ const correlation = {
161
+ kind: "raw",
162
+ aliases: [root.alias, ...correlationAliases],
163
+ condition: `${root.col1} = ${root.col2}`,
164
+ bindings: [],
165
+ pruneable: false,
166
+ };
167
+ // I.e. a pure `b.id IS NULL` anti-join becomes `NOT EXISTS (SELECT 1 FROM books b WHERE a.id = b.author_id)`.
168
+ const conditions = hasOnlyAntiJoin ? [correlation] : [correlation, ...moved];
169
+ const subquery = {
170
+ selects: ["1"],
171
+ tables: query.tables
172
+ .filter((t) => (hasOnlyAntiJoin ? t.alias === root.alias : collectionRoot.aliases.has(t.alias)))
173
+ .map((t) => {
174
+ // I.e. the collection root becomes the subquery's FROM table; children remain joins off that root.
175
+ if (t.alias === root.alias)
176
+ return { join: "primary", alias: t.alias, table: t.table };
177
+ // I.e. preserve nullable paths like `LEFT JOIN p ... LEFT JOIN sp ... WHERE p.id = 1 OR sp.id = 1`; forcing
178
+ // children to INNER JOIN would require every optional branch to exist before the OR can match any branch.
179
+ if (t.join === "outer")
180
+ return { ...t, distinct: false };
181
+ return t;
182
+ }),
183
+ condition: { kind: "exp", op: "and", conditions },
184
+ orderBys: [],
185
+ };
186
+ // I.e. nested `books.reviews` first creates an EXISTS for books, then this recursive call creates EXISTS for reviews.
187
+ rewriteCollectionJoins(subquery);
188
+ return {
189
+ kind: "exists",
190
+ negate: hasOnlyAntiJoin,
191
+ subquery,
192
+ outerAliases: correlationAliases,
193
+ };
194
+ }
195
+ /** Appends conditions to the top-level expression, creating an AND wrapper when needed. */
196
+ function addConditions(query, conditions) {
197
+ query.condition ??= { kind: "exp", op: "and", conditions: [] };
198
+ query.condition.conditions.push(...conditions);
199
+ }
200
+ /** Returns top-level collection roots with their full join subtrees. */
201
+ function getCollectionRoots(query) {
202
+ return getTopLevelCollectionRoots(query).map((table) => {
203
+ const aliases = collectJoinSubtreeAliases(query, table.alias);
204
+ return {
205
+ table,
206
+ aliases,
207
+ joinTables: query.tables.filter((t) => isJoinTable(t) && aliases.has(t.alias)),
208
+ };
209
+ });
210
+ }
211
+ /** Returns top-level collection roots, i.e. `books b` but not nested `book_reviews br`. */
212
+ function getTopLevelCollectionRoots(query) {
213
+ // I.e. if `books b` is nested under another collection root, the parent pass should absorb it; don't rewrite it here.
214
+ const joinTables = query.tables.filter(isJoinTable);
215
+ const collectionAliases = new Set(joinTables.flatMap((t) => (t.collection ? [t.alias] : [])));
216
+ return joinTables.filter((t) => t.collection?.rootAlias === t.alias && !collectionAliases.has(t.collection.parentAlias));
217
+ }
218
+ /** Returns true if a remaining real condition prevents this subtree from becoming EXISTS, i.e. a cross-scope OR. */
219
+ function conditionBlocksExistsRewrite(condition, aliases) {
220
+ if (!condition || !isRealCondition(condition))
221
+ return false;
222
+ if (condition.kind === "exp" && condition.op === "and") {
223
+ return condition.conditions.some((c) => conditionBlocksExistsRewrite(c, aliases));
224
+ }
225
+ return conditionReferencesAnyAlias(condition, aliases);
226
+ }
227
+ /** Collects a collection root and all joins that depend on it, i.e. `b -> br -> c`. */
228
+ function collectJoinSubtreeAliases(query, rootAlias) {
229
+ const aliases = new Set([rootAlias]);
230
+ let changed = true;
231
+ while (changed) {
232
+ changed = false;
233
+ for (const table of query.tables) {
234
+ if (!isJoinTable(table))
235
+ continue;
236
+ // I.e. `book_reviews br ON b.id = br.book_id` depends on `b`, so `br` belongs in the `b` subtree.
237
+ if (!aliases.has(table.alias) && joinReferencesAnyAlias(table, aliases)) {
238
+ aliases.add(table.alias);
239
+ changed = true;
240
+ }
241
+ }
242
+ }
243
+ return aliases;
244
+ }
245
+ /**
246
+ * Removes AND-safe conditions whose aliases all live inside one collection subtree.
247
+ *
248
+ * I.e. in `a.age = 1 AND b.title = 'x'`, only `b.title = 'x'` moves. In `b.title = 'x' OR br.rating = 5`,
249
+ * the whole OR moves only if every alias is inside the same subtree.
250
+ */
251
+ function removeLocallyScopedConditions(exp, aliases) {
252
+ if (exp.op === "or") {
253
+ // I.e. OR cannot be split across scopes; either move the whole OR into the EXISTS, or leave it outside.
254
+ if (!conditionReferencesOnlyAliases(exp, aliases))
255
+ return [];
256
+ const moved = { ...exp, conditions: [...exp.conditions] };
257
+ exp.conditions = [];
258
+ return [moved];
259
+ }
260
+ const moved = [];
261
+ for (let i = exp.conditions.length - 1; i >= 0; i--) {
262
+ const condition = exp.conditions[i];
263
+ if (condition.kind === "exp" && condition.op === "and") {
264
+ // I.e. flatten nested AND movement so `a AND (b AND br)` can still move `b` and `br` into the EXISTS.
265
+ moved.push(...removeLocallyScopedConditions(condition, aliases));
266
+ if (condition.conditions.length === 0)
267
+ exp.conditions.splice(i, 1);
268
+ }
269
+ else if (conditionReferencesOnlyAliases(condition, aliases)) {
270
+ // I.e. move `b.title = 'x'` out of the parent AND and into the collection EXISTS.
271
+ moved.unshift(condition);
272
+ exp.conditions.splice(i, 1);
273
+ }
274
+ }
275
+ return moved;
276
+ }
277
+ /** Returns true when a condition references at least one alias and all aliases are in `aliases`, i.e. only `b`/`br`. */
278
+ function conditionReferencesOnlyAliases(condition, aliases) {
279
+ const found = conditionAliases(condition);
280
+ return found.size > 0 && [...found].every((alias) => aliases.has(alias));
281
+ }
282
+ /** Returns true when `aliases` are referenced by a real condition other than the targeted OR expression. */
283
+ function conditionReferencesAliasesOutside(condition, target, aliases) {
284
+ if (!condition || condition === target || !isRealCondition(condition))
285
+ return false;
286
+ if (condition.kind === "exp") {
287
+ return condition.conditions.some((child) => conditionReferencesAliasesOutside(child, target, aliases));
288
+ }
289
+ return conditionReferencesAnyAlias(condition, aliases);
290
+ }
291
+ /** Returns true when selected/ordered aliases would force these joins to remain in the outer query. */
292
+ function queryReferencesAliasesOutsideConditions(query, aliases, keepAliases) {
293
+ const requiredAliases = queryRequiredAliasesOutsideConditions(query, keepAliases);
294
+ // I.e. if `array_agg(br.rating)` requires `br`, then `b` is required too because `br` joins through `b`; don't
295
+ // move `b` under EXISTS just because the select references only its child alias directly.
296
+ return hasAnyAlias(requiredAliases, aliases);
297
+ }
298
+ /**
299
+ * Returns aliases needed by SELECT/GROUP/ORDER plus their join dependencies.
300
+ *
301
+ * I.e. `array_agg(br.rating)` requires `br`, and then `br` requires `b` because it joins through `b`.
302
+ */
303
+ function queryRequiredAliasesOutsideConditions(query, keepAliases) {
304
+ const required = new Set();
305
+ for (const alias of keepAliases)
306
+ required.add(alias);
307
+ for (const orderBy of query.orderBys)
308
+ required.add(orderBy.alias);
309
+ for (const groupBy of query.groupBys ?? []) {
310
+ if ("expression" in groupBy) {
311
+ addSelectAliases(query, required, groupBy.expression);
312
+ }
313
+ else {
314
+ required.add(groupBy.alias);
315
+ }
316
+ }
317
+ for (const select of query.selects) {
318
+ if (typeof select === "string") {
319
+ addSelectAliases(query, required, select);
320
+ }
321
+ else if ("aliases" in select) {
322
+ for (const alias of select.aliases)
323
+ required.add(alias);
324
+ addSelectAliases(query, required, select.sql);
325
+ }
326
+ }
327
+ const todo = [...required];
328
+ while (todo.length > 0) {
329
+ const alias = todo.pop();
330
+ const table = query.tables.find((t) => t.alias === alias);
331
+ if (!table || !isJoinTable(table))
332
+ continue;
333
+ for (const dependency of joinDependencies(table)) {
334
+ if (!required.has(dependency)) {
335
+ required.add(dependency);
336
+ todo.push(dependency);
337
+ }
338
+ }
339
+ }
340
+ return required;
341
+ }
342
+ /** Adds aliases referenced by raw select SQL, i.e. `array_agg(br.rating)` requires `br`. */
343
+ function addSelectAliases(query, required, select) {
344
+ for (const table of query.tables) {
345
+ if ((0, QueryParser_pruning_1.selectReferencesAlias)(select, table.alias))
346
+ required.add(table.alias);
347
+ }
348
+ }
349
+ /** Returns the aliases needed to evaluate a join's ON clause, excluding the joined alias itself. */
350
+ function joinDependencies(table) {
351
+ return [(0, QueryParser_1.parseAlias)(table.col1), (0, QueryParser_1.parseAlias)(table.col2)].filter((alias) => alias !== table.alias);
352
+ }
353
+ /** Returns true when a condition references this subtree and another scope, i.e. `b.title = 'x' OR c.text = 'x'`. */
354
+ function conditionHasCrossScopeReference(condition, aliases) {
355
+ if (!condition || !isRealCondition(condition))
356
+ return false;
357
+ if (condition.kind === "exp" && condition.op === "and") {
358
+ return condition.conditions.some((child) => conditionHasCrossScopeReference(child, aliases));
359
+ }
360
+ const found = conditionAliases(condition);
361
+ return hasAnyAlias(found, aliases) && ![...found].every((alias) => aliases.has(alias));
362
+ }
363
+ /** Returns true when a condition references any alias in `aliases`, i.e. `b` in `b.title = c.text`. */
364
+ function conditionReferencesAnyAlias(condition, aliases) {
365
+ return hasAnyAlias(conditionAliases(condition), aliases);
366
+ }
367
+ /** Returns true when `table` is an ordinary SQL join. */
368
+ function isJoinTable(table) {
369
+ return table.join === "inner" || table.join === "outer";
370
+ }
371
+ /** Returns true when a join's ON clause references any alias in `aliases`. */
372
+ function joinReferencesAnyAlias(table, aliases) {
373
+ return joinDependencies(table).some((alias) => aliases.has(alias));
374
+ }
375
+ /** Returns true when two alias sets overlap. */
376
+ function hasAnyAlias(found, aliases) {
377
+ return [...found].some((alias) => aliases.has(alias));
378
+ }
379
+ /** Returns true for collection anti-joins, i.e. `b.id IS NULL` or m2m target `t.id IS NULL` for root `att`. */
380
+ function isCollectionAntiJoin(condition, root) {
381
+ return collectionAntiJoinAliases(root).some((alias) => isAliasIdNull(condition, alias));
382
+ }
383
+ /** Returns aliases whose `id IS NULL` means the collection root has no matching row. */
384
+ function collectionAntiJoinAliases(root) {
385
+ return [...root.aliases].filter((alias) => {
386
+ if (alias === root.table.alias)
387
+ return true;
388
+ const table = rootTable(root, alias);
389
+ // I.e. for m2m `authors -> authors_to_tags att -> tags t`, `t.id IS NULL` means no tag membership.
390
+ return table?.collection?.rootAlias === root.table.alias;
391
+ });
392
+ }
393
+ /** Returns a join table from a collection subtree by alias. */
394
+ function rootTable(root, alias) {
395
+ return root.joinTables.find((table) => table.alias === alias);
396
+ }
397
+ /** Returns true for `alias.id IS NULL`, i.e. the parse shape for `{ books: { id: null } }`. */
398
+ function isAliasIdNull(condition, alias) {
399
+ return (condition.kind === "column" &&
400
+ condition.alias === alias &&
401
+ condition.column === "id" &&
402
+ condition.cond.kind === "is-null");
403
+ }
404
+ /** Returns true when a condition tree contains a collection anti-join branch inside an OR. */
405
+ function conditionContainsCollectionAntiJoin(condition, root) {
406
+ if (isCollectionAntiJoin(condition, root))
407
+ return true;
408
+ if (condition.kind === "exp")
409
+ return condition.conditions.some((c) => conditionContainsCollectionAntiJoin(c, root));
410
+ return false;
411
+ }
412
+ /** Removes empty expression wrappers left behind by condition movement, i.e. `AND []` after all children moved. */
413
+ function removeEmptyExpressions(exp) {
414
+ if (!exp)
415
+ return;
416
+ for (let i = exp.conditions.length - 1; i >= 0; i--) {
417
+ const condition = exp.conditions[i];
418
+ if (condition.kind === "exp") {
419
+ removeEmptyExpressions(condition);
420
+ if (condition.conditions.length === 0)
421
+ exp.conditions.splice(i, 1);
422
+ }
423
+ }
424
+ }
425
+ /** Returns true if a condition must be preserved to maintain query semantics, i.e. user filters vs soft-delete filters. */
426
+ function isRealCondition(condition) {
427
+ if (condition.kind === "column" || condition.kind === "raw") {
428
+ return !condition.pruneable;
429
+ }
430
+ else if (condition.kind === "exists") {
431
+ return true;
432
+ }
433
+ else if (condition.kind === "exp") {
434
+ return condition.conditions.some(isRealCondition);
435
+ }
436
+ else {
437
+ (0, utils_1.assertNever)(condition);
438
+ }
439
+ }
440
+ /** Returns all aliases referenced by a condition, i.e. `b` and `a` in an OR. */
441
+ function conditionAliases(condition) {
442
+ const aliases = new Set();
443
+ collectAllAliases(condition, aliases);
444
+ return aliases;
445
+ }
446
+ /** Collects all aliases referenced by a condition, including inside nested expressions, i.e. `b` and `a` in an OR. */
447
+ function collectAllAliases(cond, out) {
448
+ if (cond.kind === "column") {
449
+ out.add(cond.alias);
450
+ }
451
+ else if (cond.kind === "raw") {
452
+ for (const a of cond.aliases)
453
+ out.add(a);
454
+ }
455
+ else if (cond.kind === "exp") {
456
+ for (const c of cond.conditions)
457
+ collectAllAliases(c, out);
458
+ }
459
+ else if (cond.kind === "exists") {
460
+ // I.e. an EXISTS subquery is already a scoped unit; outer movement decisions should not inspect its internals.
461
+ }
462
+ else {
463
+ (0, utils_1.assertNever)(cond);
464
+ }
465
+ }
466
+ //# sourceMappingURL=QueryParser.collectionJoins.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryParser.collectionJoins.js","sourceRoot":"","sources":["../src/QueryParser.collectionJoins.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=QueryParser.collectionJoins.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryParser.collectionJoins.test.d.ts","sourceRoot":"","sources":["../src/QueryParser.collectionJoins.test.ts"],"names":[],"mappings":""}