@revealui/db 0.2.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (226) hide show
  1. package/README.md +0 -4
  2. package/dist/audit-store.d.ts.map +1 -1
  3. package/dist/audit-store.js +1 -1
  4. package/dist/audit-store.js.map +1 -1
  5. package/dist/cleanup/cross-db-cleanup.d.ts +63 -0
  6. package/dist/cleanup/cross-db-cleanup.d.ts.map +1 -0
  7. package/dist/cleanup/cross-db-cleanup.js +150 -0
  8. package/dist/cleanup/cross-db-cleanup.js.map +1 -0
  9. package/dist/cleanup/index.d.ts +10 -0
  10. package/dist/cleanup/index.d.ts.map +1 -0
  11. package/dist/cleanup/index.js +10 -0
  12. package/dist/cleanup/index.js.map +1 -0
  13. package/dist/cleanup/stale-tokens.d.ts +37 -0
  14. package/dist/cleanup/stale-tokens.d.ts.map +1 -0
  15. package/dist/cleanup/stale-tokens.js +113 -0
  16. package/dist/cleanup/stale-tokens.js.map +1 -0
  17. package/dist/client/index.d.ts +13 -0
  18. package/dist/client/index.d.ts.map +1 -1
  19. package/dist/client/index.js +46 -7
  20. package/dist/client/index.js.map +1 -1
  21. package/dist/client/types.d.ts.map +1 -1
  22. package/dist/crypto.d.ts.map +1 -1
  23. package/dist/crypto.js +6 -0
  24. package/dist/crypto.js.map +1 -1
  25. package/dist/index.d.ts +2 -1
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +4 -2
  28. package/dist/index.js.map +1 -1
  29. package/dist/log-transport.d.ts.map +1 -1
  30. package/dist/log-transport.js +3 -1
  31. package/dist/log-transport.js.map +1 -1
  32. package/dist/pool.d.ts +1 -4
  33. package/dist/pool.d.ts.map +1 -1
  34. package/dist/pool.js +29 -13
  35. package/dist/pool.js.map +1 -1
  36. package/dist/queries/boards.d.ts +13 -1
  37. package/dist/queries/boards.d.ts.map +1 -1
  38. package/dist/queries/boards.js +5 -2
  39. package/dist/queries/boards.js.map +1 -1
  40. package/dist/queries/code-provenance.d.ts +2 -0
  41. package/dist/queries/code-provenance.d.ts.map +1 -1
  42. package/dist/queries/code-provenance.js +8 -2
  43. package/dist/queries/code-provenance.js.map +1 -1
  44. package/dist/queries/media.d.ts +84 -0
  45. package/dist/queries/media.d.ts.map +1 -0
  46. package/dist/queries/media.js +47 -0
  47. package/dist/queries/media.js.map +1 -0
  48. package/dist/queries/optimized-queries.js +1 -1
  49. package/dist/queries/optimized-queries.js.map +1 -1
  50. package/dist/queries/pages.d.ts +119 -0
  51. package/dist/queries/pages.d.ts.map +1 -0
  52. package/dist/queries/pages.js +61 -0
  53. package/dist/queries/pages.js.map +1 -0
  54. package/dist/queries/posts.d.ts +107 -0
  55. package/dist/queries/posts.d.ts.map +1 -0
  56. package/dist/queries/posts.js +55 -0
  57. package/dist/queries/posts.js.map +1 -0
  58. package/dist/queries/sites.d.ts +127 -0
  59. package/dist/queries/sites.d.ts.map +1 -0
  60. package/dist/queries/sites.js +83 -0
  61. package/dist/queries/sites.js.map +1 -0
  62. package/dist/queries/ticket-comments.d.ts +9 -1
  63. package/dist/queries/ticket-comments.d.ts.map +1 -1
  64. package/dist/queries/ticket-comments.js +4 -0
  65. package/dist/queries/ticket-comments.js.map +1 -1
  66. package/dist/queries/ticket-labels.d.ts +10 -0
  67. package/dist/queries/ticket-labels.d.ts.map +1 -1
  68. package/dist/queries/ticket-labels.js +4 -0
  69. package/dist/queries/ticket-labels.js.map +1 -1
  70. package/dist/queries/tickets.d.ts +1 -1
  71. package/dist/queries/tickets.d.ts.map +1 -1
  72. package/dist/queries/tickets.js +4 -7
  73. package/dist/queries/tickets.js.map +1 -1
  74. package/dist/queries/users.d.ts +109 -0
  75. package/dist/queries/users.d.ts.map +1 -0
  76. package/dist/queries/users.js +44 -0
  77. package/dist/queries/users.js.map +1 -0
  78. package/dist/schema/accounts.d.ts +962 -0
  79. package/dist/schema/accounts.d.ts.map +1 -0
  80. package/dist/schema/accounts.js +115 -0
  81. package/dist/schema/accounts.js.map +1 -0
  82. package/dist/schema/agents.d.ts +167 -3
  83. package/dist/schema/agents.d.ts.map +1 -1
  84. package/dist/schema/agents.js +58 -7
  85. package/dist/schema/agents.js.map +1 -1
  86. package/dist/schema/api-keys.d.ts +17 -0
  87. package/dist/schema/api-keys.d.ts.map +1 -1
  88. package/dist/schema/api-keys.js +3 -0
  89. package/dist/schema/api-keys.js.map +1 -1
  90. package/dist/schema/app-logs.d.ts.map +1 -1
  91. package/dist/schema/app-logs.js.map +1 -1
  92. package/dist/schema/audit-log.d.ts.map +1 -1
  93. package/dist/schema/audit-log.js.map +1 -1
  94. package/dist/schema/cms.d.ts +68 -0
  95. package/dist/schema/cms.d.ts.map +1 -1
  96. package/dist/schema/cms.js +18 -4
  97. package/dist/schema/cms.js.map +1 -1
  98. package/dist/schema/code-provenance.d.ts.map +1 -1
  99. package/dist/schema/code-provenance.js.map +1 -1
  100. package/dist/schema/collab-edits.d.ts.map +1 -1
  101. package/dist/schema/collab-edits.js +2 -2
  102. package/dist/schema/collab-edits.js.map +1 -1
  103. package/dist/schema/coordination.d.ts +967 -0
  104. package/dist/schema/coordination.d.ts.map +1 -0
  105. package/dist/schema/coordination.js +109 -0
  106. package/dist/schema/coordination.js.map +1 -0
  107. package/dist/schema/crdt-operations.d.ts.map +1 -1
  108. package/dist/schema/crdt-operations.js.map +1 -1
  109. package/dist/schema/error-events.d.ts.map +1 -1
  110. package/dist/schema/error-events.js.map +1 -1
  111. package/dist/schema/gdpr.d.ts +529 -0
  112. package/dist/schema/gdpr.d.ts.map +1 -0
  113. package/dist/schema/gdpr.js +93 -0
  114. package/dist/schema/gdpr.js.map +1 -0
  115. package/dist/schema/index.d.ts +41 -1
  116. package/dist/schema/index.d.ts.map +1 -1
  117. package/dist/schema/index.js +82 -0
  118. package/dist/schema/index.js.map +1 -1
  119. package/dist/schema/jobs.d.ts +242 -0
  120. package/dist/schema/jobs.d.ts.map +1 -0
  121. package/dist/schema/jobs.js +48 -0
  122. package/dist/schema/jobs.js.map +1 -0
  123. package/dist/schema/licenses.d.ts +51 -0
  124. package/dist/schema/licenses.d.ts.map +1 -1
  125. package/dist/schema/licenses.js +12 -3
  126. package/dist/schema/licenses.js.map +1 -1
  127. package/dist/schema/magic-links.d.ts +136 -0
  128. package/dist/schema/magic-links.d.ts.map +1 -0
  129. package/dist/schema/magic-links.js +32 -0
  130. package/dist/schema/magic-links.js.map +1 -0
  131. package/dist/schema/marketplace.d.ts +496 -0
  132. package/dist/schema/marketplace.d.ts.map +1 -0
  133. package/dist/schema/marketplace.js +110 -0
  134. package/dist/schema/marketplace.js.map +1 -0
  135. package/dist/schema/node-ids.d.ts.map +1 -1
  136. package/dist/schema/node-ids.js.map +1 -1
  137. package/dist/schema/oauth-accounts.d.ts +205 -0
  138. package/dist/schema/oauth-accounts.d.ts.map +1 -0
  139. package/dist/schema/oauth-accounts.js +35 -0
  140. package/dist/schema/oauth-accounts.js.map +1 -0
  141. package/dist/schema/pages.d.ts +34 -0
  142. package/dist/schema/pages.d.ts.map +1 -1
  143. package/dist/schema/pages.js +14 -4
  144. package/dist/schema/pages.js.map +1 -1
  145. package/dist/schema/passkeys.d.ts +208 -0
  146. package/dist/schema/passkeys.d.ts.map +1 -0
  147. package/dist/schema/passkeys.js +47 -0
  148. package/dist/schema/passkeys.js.map +1 -0
  149. package/dist/schema/password-reset-tokens.d.ts.map +1 -1
  150. package/dist/schema/password-reset-tokens.js +5 -2
  151. package/dist/schema/password-reset-tokens.js.map +1 -1
  152. package/dist/schema/rag.d.ts +566 -0
  153. package/dist/schema/rag.d.ts.map +1 -0
  154. package/dist/schema/rag.js +85 -0
  155. package/dist/schema/rag.js.map +1 -0
  156. package/dist/schema/rate-limits.d.ts.map +1 -1
  157. package/dist/schema/rate-limits.js +5 -2
  158. package/dist/schema/rate-limits.js.map +1 -1
  159. package/dist/schema/rest.d.ts +11 -2
  160. package/dist/schema/rest.d.ts.map +1 -1
  161. package/dist/schema/rest.js +11 -2
  162. package/dist/schema/rest.js.map +1 -1
  163. package/dist/schema/sites.d.ts +34 -0
  164. package/dist/schema/sites.d.ts.map +1 -1
  165. package/dist/schema/sites.js +15 -3
  166. package/dist/schema/sites.js.map +1 -1
  167. package/dist/schema/tenants.d.ts +188 -0
  168. package/dist/schema/tenants.d.ts.map +1 -0
  169. package/dist/schema/tenants.js +15 -0
  170. package/dist/schema/tenants.js.map +1 -0
  171. package/dist/schema/tickets.d.ts.map +1 -1
  172. package/dist/schema/tickets.js +17 -5
  173. package/dist/schema/tickets.js.map +1 -1
  174. package/dist/schema/users.d.ts +259 -0
  175. package/dist/schema/users.d.ts.map +1 -1
  176. package/dist/schema/users.js +39 -3
  177. package/dist/schema/users.js.map +1 -1
  178. package/dist/schema/vector.d.ts +1 -0
  179. package/dist/schema/vector.d.ts.map +1 -1
  180. package/dist/schema/vector.js +2 -0
  181. package/dist/schema/vector.js.map +1 -1
  182. package/dist/schema/waitlist.d.ts.map +1 -1
  183. package/dist/schema/waitlist.js.map +1 -1
  184. package/dist/schema/webhook-events.d.ts +68 -0
  185. package/dist/schema/webhook-events.d.ts.map +1 -0
  186. package/dist/schema/webhook-events.js +17 -0
  187. package/dist/schema/webhook-events.js.map +1 -0
  188. package/dist/schema/yjs-documents.d.ts.map +1 -1
  189. package/dist/schema/yjs-documents.js.map +1 -1
  190. package/dist/scripts/cleanup-expired.d.ts +12 -0
  191. package/dist/scripts/cleanup-expired.d.ts.map +1 -0
  192. package/dist/scripts/cleanup-expired.js +50 -0
  193. package/dist/scripts/cleanup-expired.js.map +1 -0
  194. package/dist/security-audit-storage.d.ts +54 -0
  195. package/dist/security-audit-storage.d.ts.map +1 -0
  196. package/dist/security-audit-storage.js +100 -0
  197. package/dist/security-audit-storage.js.map +1 -0
  198. package/dist/types/database.d.ts +381 -2
  199. package/dist/types/database.d.ts.map +1 -1
  200. package/dist/types/database.js +78 -1
  201. package/dist/types/database.js.map +1 -1
  202. package/dist/types/discover.d.ts +2 -2
  203. package/dist/types/discover.d.ts.map +1 -1
  204. package/dist/types/discover.js +16 -16
  205. package/dist/types/discover.js.map +1 -1
  206. package/dist/types/extract-relationships.d.ts.map +1 -1
  207. package/dist/types/extract-relationships.js.map +1 -1
  208. package/dist/types/generate-contracts.js.map +1 -1
  209. package/dist/types/generate-zod-schemas.js.map +1 -1
  210. package/dist/types/generate.js.map +1 -1
  211. package/dist/types/index.d.ts.map +1 -1
  212. package/dist/types/introspect.d.ts.map +1 -1
  213. package/dist/types/introspect.js +0 -1
  214. package/dist/types/introspect.js.map +1 -1
  215. package/dist/types/stripe-schema.d.ts.map +1 -1
  216. package/dist/types/stripe-schema.js +7 -2
  217. package/dist/types/stripe-schema.js.map +1 -1
  218. package/dist/utils/soft-delete.d.ts +45 -0
  219. package/dist/utils/soft-delete.d.ts.map +1 -0
  220. package/dist/utils/soft-delete.js +45 -0
  221. package/dist/utils/soft-delete.js.map +1 -0
  222. package/dist/validation/cross-db.d.ts +60 -0
  223. package/dist/validation/cross-db.d.ts.map +1 -0
  224. package/dist/validation/cross-db.js +146 -0
  225. package/dist/validation/cross-db.js.map +1 -0
  226. package/package.json +45 -6
@@ -1 +1 @@
1
- {"version":3,"file":"optimized-queries.js","sourceRoot":"","sources":["../../src/queries/optimized-queries.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,oBAAoB;AACpB;;;;;GAKG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAE9C,uEAAuE;AACvE,yEAAyE;AACzE,2EAA2E;AAE3E,+FAA+F;AAC/F,MAAM,YAAY,GAAG,CAAI,KAAa,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AACrE,MAAM,WAAW,GAAG,CAAI,IAAY,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AACnE,MAAM,SAAS,GAAG,CAAI,IAAY,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AAEjE,yBAAyB;AACzB,MAAM,EAAE,GAAG,SAAS,EAAE,CAAA;AAEtB,+EAA+E;AAC/E,wBAAwB;AACxB,+EAA+E;AAE/E;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,6BAA6B;IAC7B,MAAM,KAAK,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,uCAAuC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAA;IAEpF,mDAAmD;IACnD,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;QAC9B,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mCAAmC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;QACpF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC9B,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAA;AACnB,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B;IAChD,OAAO,YAAY,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;;;;;;KAmBb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB;IAC7C,OAAO,SAAS,CACd,OAAO,EACP,EAAE,MAAM,EAAE,WAAW,EAAE,EACvB,GAAG,EAAE,CAAC,4BAA4B,EAAE,EACpC,GAAG,CACJ,CAAA;AACH,CAAC;AAED,+EAA+E;AAC/E,0BAA0B;AAC1B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,IAAY,EAAE,OAAe;IACzE,MAAM,MAAM,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,OAAO,CAAA;IAEnC,MAAM,KAAK,GAAG;;;;;GAKb,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;IACvD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,MAAe,EAAE,UAAkB,EAAE;IACjF,OAAO,YAAY,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,KAAK,GAAG,MAAM;YAClB,CAAC,CAAC;;;;;;;;SAQC;YACH,CAAC,CAAC;;;;;SAKC,CAAA;QAEL,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;QACrD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAE5C,OAAO;YACL,KAAK,EAAE,MAAM,CAAC,IAAI;YAClB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;SAC3F,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,2BAA2B;AAC3B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc;IAClC,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/D,MAAM,cAAc,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,uDAAuD,CAAC,CAAA;IAC9F,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAA;IAEtF,OAAO;QACL,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;QAC/B,SAAS,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;QACvC,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;KAChC,CAAA;AACH,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,OAAO,YAAY,CAAC,cAAc,EAAE,KAAK,IAAI,EAAE;QAC7C,MAAM,KAAK,GAAG;;;;;;KAMb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACvB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,gBAAgB;AAChB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAa;IACjD,MAAM,KAAK,GAAG,EAAE,CAAA;IAChB,KAAK,MAAM,EAAE,IAAI,GAAG,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mCAAmC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;QACxE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,GAAa;IACxD,OAAO,YAAY,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,KAAK,GAAG,wCAAwC,CAAA;QACtD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,uBAAuB;AACvB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,OAAO,YAAY,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmCb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,KAAa;IACjD,MAAM,GAAG,GAAG;;;;GAIX,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAA;IAClD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,KAAa;IACtD,OAAO,YAAY,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,GAAG,GAAG;;;;;;;;;;;;;KAaX,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,OAKtC;IACC,OAAO,YAAY,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,UAAU,GAAa,EAAE,CAAA;QAC/B,MAAM,MAAM,GAAc,EAAE,CAAA;QAC5B,IAAI,UAAU,GAAG,CAAC,CAAA;QAElB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,UAAU,CAAC,IAAI,CAAC,aAAa,UAAU,EAAE,CAAC,CAAA;YAC1C,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;YAC3B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,UAAU,CAAC,IAAI,CAAC,gBAAgB,UAAU,EAAE,CAAC,CAAA;YAC7C,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;YAC7B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,UAAU,CAAC,IAAI,CAAC,oBAAoB,UAAU,EAAE,CAAC,CAAA;YACjD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;YAC7B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,UAAU,CAAC,IAAI,CAAC,oBAAoB,UAAU,EAAE,CAAC,CAAA;YACjD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;YAC3B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;QAEpF,MAAM,KAAK,GAAG;;QAEV,WAAW;;;KAGd,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAC5C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,qBAAqB;AACrB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,+BAA+B;IACnD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;GAcb,CAAA;IAED,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB;IACpC,MAAM,EAAE,CAAC,KAAK,CAAC,sDAAsD,CAAC,CAAA;AACxE,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,QAAc,EAAE,MAAY;IACnE,MAAM,KAAK,GAAG;;;;GAIb,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAA;IACxD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED,+EAA+E;AAC/E,8BAA8B;AAC9B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB;IAC1C,OAAO,YAAY,CAAC,wBAAwB,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;KAcb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC"}
1
+ {"version":3,"file":"optimized-queries.js","sourceRoot":"","sources":["../../src/queries/optimized-queries.ts"],"names":[],"mappings":"AAAA,oBAAoB;AACpB,cAAc;AACd;;;;;GAKG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAE9C,uEAAuE;AACvE,yEAAyE;AACzE,2EAA2E;AAE3E,+FAA+F;AAC/F,MAAM,YAAY,GAAG,CAAI,KAAa,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AACrE,MAAM,WAAW,GAAG,CAAI,IAAY,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AACnE,MAAM,SAAS,GAAG,CAAI,IAAY,EAAE,EAAoB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAA;AAEjE,yBAAyB;AACzB,MAAM,EAAE,GAAG,SAAS,EAAE,CAAA;AAEtB,+EAA+E;AAC/E,wBAAwB;AACxB,+EAA+E;AAE/E;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,6BAA6B;IAC7B,MAAM,KAAK,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,uCAAuC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAA;IAEpF,mDAAmD;IACnD,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;QAC9B,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mCAAmC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;QACpF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC9B,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAA;AACnB,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B;IAChD,OAAO,YAAY,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;;;;;;KAmBb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB;IAC7C,OAAO,SAAS,CACd,OAAO,EACP,EAAE,MAAM,EAAE,WAAW,EAAE,EACvB,GAAG,EAAE,CAAC,4BAA4B,EAAE,EACpC,GAAG,CACJ,CAAA;AACH,CAAC;AAED,+EAA+E;AAC/E,0BAA0B;AAC1B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,IAAY,EAAE,OAAe;IACzE,MAAM,MAAM,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,OAAO,CAAA;IAEnC,MAAM,KAAK,GAAG;;;;;GAKb,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;IACvD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,MAAe,EAAE,UAAkB,EAAE;IACjF,OAAO,YAAY,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,KAAK,GAAG,MAAM;YAClB,CAAC,CAAC;;;;;;;;SAQC;YACH,CAAC,CAAC;;;;;SAKC,CAAA;QAEL,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;QACrD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAE5C,OAAO;YACL,KAAK,EAAE,MAAM,CAAC,IAAI;YAClB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;SAC3F,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,2BAA2B;AAC3B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc;IAClC,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/D,MAAM,cAAc,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,uDAAuD,CAAC,CAAA;IAC9F,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAA;IAEtF,OAAO;QACL,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;QAC/B,SAAS,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;QACvC,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;KAChC,CAAA;AACH,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,OAAO,YAAY,CAAC,cAAc,EAAE,KAAK,IAAI,EAAE;QAC7C,MAAM,KAAK,GAAG;;;;;;KAMb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACvB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,gBAAgB;AAChB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAa;IACjD,MAAM,KAAK,GAAG,EAAE,CAAA;IAChB,KAAK,MAAM,EAAE,IAAI,GAAG,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,mCAAmC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;QACxE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,GAAa;IACxD,OAAO,YAAY,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,KAAK,GAAG,wCAAwC,CAAA;QACtD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,uBAAuB;AACvB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB;IACzC,OAAO,YAAY,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmCb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,KAAa;IACjD,MAAM,GAAG,GAAG;;;;GAIX,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAA;IAClD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,KAAa;IACtD,OAAO,YAAY,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,GAAG,GAAG;;;;;;;;;;;;;KAaX,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,OAKtC;IACC,OAAO,YAAY,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,UAAU,GAAa,EAAE,CAAA;QAC/B,MAAM,MAAM,GAAc,EAAE,CAAA;QAC5B,IAAI,UAAU,GAAG,CAAC,CAAA;QAElB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,UAAU,CAAC,IAAI,CAAC,aAAa,UAAU,EAAE,CAAC,CAAA;YAC1C,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;YAC3B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,UAAU,CAAC,IAAI,CAAC,gBAAgB,UAAU,EAAE,CAAC,CAAA;YAC7C,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;YAC7B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,UAAU,CAAC,IAAI,CAAC,oBAAoB,UAAU,EAAE,CAAC,CAAA;YACjD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;YAC7B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,UAAU,CAAC,IAAI,CAAC,oBAAoB,UAAU,EAAE,CAAC,CAAA;YACjD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;YAC3B,UAAU,EAAE,CAAA;QACd,CAAC;QAED,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;QAEpF,MAAM,KAAK,GAAG;;QAEV,WAAW;;;KAGd,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAC5C,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,+EAA+E;AAC/E,qBAAqB;AACrB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,+BAA+B;IACnD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;GAcb,CAAA;IAED,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB;IACpC,MAAM,EAAE,CAAC,KAAK,CAAC,sDAAsD,CAAC,CAAA;AACxE,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,QAAc,EAAE,MAAY;IACnE,MAAM,KAAK,GAAG;;;;GAIb,CAAA;IAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAA;IACxD,OAAO,MAAM,CAAC,IAAI,CAAA;AACpB,CAAC;AAED,+EAA+E;AAC/E,8BAA8B;AAC9B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB;IAC1C,OAAO,YAAY,CAAC,wBAAwB,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,KAAK,GAAG;;;;;;;;;;;;;;KAcb,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpC,OAAO,MAAM,CAAC,IAAI,CAAA;IACpB,CAAC,CAAC,CAAA;AACJ,CAAC"}
@@ -0,0 +1,119 @@
1
+ /**
2
+ * Page database queries
3
+ */
4
+ import type { DatabaseClient } from '../client/types.js';
5
+ import { pages } from '../schema/pages.js';
6
+ export declare function getPagesBySite(db: DatabaseClient, siteId: string, options?: {
7
+ status?: string;
8
+ }): Promise<{
9
+ id: string;
10
+ schemaVersion: string;
11
+ version: number;
12
+ siteId: string;
13
+ parentId: string | null;
14
+ templateId: string | null;
15
+ title: string;
16
+ slug: string;
17
+ path: string;
18
+ status: string;
19
+ blocks: unknown[] | null;
20
+ seo: unknown;
21
+ blockCount: number | null;
22
+ wordCount: number | null;
23
+ lock: unknown;
24
+ scheduledAt: Date | null;
25
+ createdAt: Date;
26
+ updatedAt: Date;
27
+ publishedAt: Date | null;
28
+ deletedAt: Date | null;
29
+ }[]>;
30
+ export declare function getPageById(db: DatabaseClient, id: string): Promise<{
31
+ id: string;
32
+ schemaVersion: string;
33
+ version: number;
34
+ siteId: string;
35
+ parentId: string | null;
36
+ templateId: string | null;
37
+ title: string;
38
+ slug: string;
39
+ path: string;
40
+ status: string;
41
+ blocks: unknown[] | null;
42
+ seo: unknown;
43
+ blockCount: number | null;
44
+ wordCount: number | null;
45
+ lock: unknown;
46
+ scheduledAt: Date | null;
47
+ createdAt: Date;
48
+ updatedAt: Date;
49
+ publishedAt: Date | null;
50
+ deletedAt: Date | null;
51
+ } | null>;
52
+ export declare function getPageByPath(db: DatabaseClient, siteId: string, path: string): Promise<{
53
+ id: string;
54
+ schemaVersion: string;
55
+ version: number;
56
+ siteId: string;
57
+ parentId: string | null;
58
+ templateId: string | null;
59
+ title: string;
60
+ slug: string;
61
+ path: string;
62
+ status: string;
63
+ blocks: unknown[] | null;
64
+ seo: unknown;
65
+ blockCount: number | null;
66
+ wordCount: number | null;
67
+ lock: unknown;
68
+ scheduledAt: Date | null;
69
+ createdAt: Date;
70
+ updatedAt: Date;
71
+ publishedAt: Date | null;
72
+ deletedAt: Date | null;
73
+ } | null>;
74
+ export declare function createPage(db: DatabaseClient, data: typeof pages.$inferInsert): Promise<{
75
+ id: string;
76
+ schemaVersion: string;
77
+ status: string;
78
+ createdAt: Date;
79
+ updatedAt: Date;
80
+ deletedAt: Date | null;
81
+ slug: string;
82
+ version: number;
83
+ publishedAt: Date | null;
84
+ siteId: string;
85
+ title: string;
86
+ parentId: string | null;
87
+ templateId: string | null;
88
+ path: string;
89
+ blocks: unknown[] | null;
90
+ seo: unknown;
91
+ blockCount: number | null;
92
+ wordCount: number | null;
93
+ lock: unknown;
94
+ scheduledAt: Date | null;
95
+ } | null>;
96
+ export declare function updatePage(db: DatabaseClient, id: string, data: Partial<typeof pages.$inferInsert>): Promise<{
97
+ id: string;
98
+ schemaVersion: string;
99
+ version: number;
100
+ siteId: string;
101
+ parentId: string | null;
102
+ templateId: string | null;
103
+ title: string;
104
+ slug: string;
105
+ path: string;
106
+ status: string;
107
+ blocks: unknown[] | null;
108
+ seo: unknown;
109
+ blockCount: number | null;
110
+ wordCount: number | null;
111
+ lock: unknown;
112
+ scheduledAt: Date | null;
113
+ createdAt: Date;
114
+ updatedAt: Date;
115
+ publishedAt: Date | null;
116
+ deletedAt: Date | null;
117
+ } | null>;
118
+ export declare function deletePage(db: DatabaseClient, id: string): Promise<void>;
119
+ //# sourceMappingURL=pages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pages.d.ts","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAG3C,wBAAsB,cAAc,CAClC,EAAE,EAAE,cAAc,EAClB,MAAM,EAAE,MAAM,EACd,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;;;;KAalC;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;UAO/D;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;UAOnF;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;UAMnF;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,KAAK,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;UAQzC;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAQ9D"}
@@ -0,0 +1,61 @@
1
+ /**
2
+ * Page database queries
3
+ */
4
+ import { and, asc, eq, isNull } from 'drizzle-orm';
5
+ import { pages } from '../schema/pages.js';
6
+ import { decrementPageCount, incrementPageCount } from './sites.js';
7
+ export async function getPagesBySite(db, siteId, options = {}) {
8
+ const { status } = options;
9
+ const conditions = [
10
+ eq(pages.siteId, siteId),
11
+ isNull(pages.deletedAt),
12
+ ...(status ? [eq(pages.status, status)] : []),
13
+ ];
14
+ return db
15
+ .select()
16
+ .from(pages)
17
+ .where(and(...conditions))
18
+ .orderBy(asc(pages.path));
19
+ }
20
+ export async function getPageById(db, id) {
21
+ const result = await db
22
+ .select()
23
+ .from(pages)
24
+ .where(and(eq(pages.id, id), isNull(pages.deletedAt)))
25
+ .limit(1);
26
+ return result[0] ?? null;
27
+ }
28
+ export async function getPageByPath(db, siteId, path) {
29
+ const result = await db
30
+ .select()
31
+ .from(pages)
32
+ .where(and(eq(pages.siteId, siteId), eq(pages.path, path), isNull(pages.deletedAt)))
33
+ .limit(1);
34
+ return result[0] ?? null;
35
+ }
36
+ export async function createPage(db, data) {
37
+ const result = await db.insert(pages).values(data).returning();
38
+ if (result[0]) {
39
+ await incrementPageCount(db, data.siteId);
40
+ }
41
+ return result[0] ?? null;
42
+ }
43
+ export async function updatePage(db, id, data) {
44
+ const result = await db
45
+ .update(pages)
46
+ .set({ ...data, updatedAt: new Date() })
47
+ .where(eq(pages.id, id))
48
+ .returning();
49
+ return result[0] ?? null;
50
+ }
51
+ export async function deletePage(db, id) {
52
+ const page = await getPageById(db, id);
53
+ if (!page)
54
+ return;
55
+ await db
56
+ .update(pages)
57
+ .set({ deletedAt: new Date(), updatedAt: new Date() })
58
+ .where(and(eq(pages.id, id), isNull(pages.deletedAt)));
59
+ await decrementPageCount(db, page.siteId);
60
+ }
61
+ //# sourceMappingURL=pages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pages.js","sourceRoot":"","sources":["../../src/queries/pages.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,107 @@
1
+ /**
2
+ * Post database queries
3
+ */
4
+ import type { DatabaseClient } from '../client/types.js';
5
+ import { posts } from '../schema/cms.js';
6
+ export declare function getAllPosts(db: DatabaseClient, options?: {
7
+ status?: string;
8
+ authorId?: string;
9
+ limit?: number;
10
+ offset?: number;
11
+ }): Promise<{
12
+ id: string;
13
+ schemaVersion: string;
14
+ version: number;
15
+ title: string;
16
+ slug: string;
17
+ excerpt: string | null;
18
+ content: unknown;
19
+ featuredImageId: string | null;
20
+ authorId: string | null;
21
+ status: string;
22
+ published: boolean | null;
23
+ meta: unknown;
24
+ categories: string[] | null;
25
+ createdAt: Date;
26
+ updatedAt: Date;
27
+ publishedAt: Date | null;
28
+ deletedAt: Date | null;
29
+ }[]>;
30
+ export declare function getPostById(db: DatabaseClient, id: string): Promise<{
31
+ id: string;
32
+ schemaVersion: string;
33
+ version: number;
34
+ title: string;
35
+ slug: string;
36
+ excerpt: string | null;
37
+ content: unknown;
38
+ featuredImageId: string | null;
39
+ authorId: string | null;
40
+ status: string;
41
+ published: boolean | null;
42
+ meta: unknown;
43
+ categories: string[] | null;
44
+ createdAt: Date;
45
+ updatedAt: Date;
46
+ publishedAt: Date | null;
47
+ deletedAt: Date | null;
48
+ } | null>;
49
+ export declare function getPostBySlug(db: DatabaseClient, slug: string): Promise<{
50
+ id: string;
51
+ schemaVersion: string;
52
+ version: number;
53
+ title: string;
54
+ slug: string;
55
+ excerpt: string | null;
56
+ content: unknown;
57
+ featuredImageId: string | null;
58
+ authorId: string | null;
59
+ status: string;
60
+ published: boolean | null;
61
+ meta: unknown;
62
+ categories: string[] | null;
63
+ createdAt: Date;
64
+ updatedAt: Date;
65
+ publishedAt: Date | null;
66
+ deletedAt: Date | null;
67
+ } | null>;
68
+ export declare function createPost(db: DatabaseClient, data: typeof posts.$inferInsert): Promise<{
69
+ id: string;
70
+ schemaVersion: string;
71
+ status: string;
72
+ createdAt: Date;
73
+ updatedAt: Date;
74
+ deletedAt: Date | null;
75
+ slug: string;
76
+ version: number;
77
+ publishedAt: Date | null;
78
+ content: unknown;
79
+ title: string;
80
+ excerpt: string | null;
81
+ featuredImageId: string | null;
82
+ authorId: string | null;
83
+ published: boolean | null;
84
+ meta: unknown;
85
+ categories: string[] | null;
86
+ } | null>;
87
+ export declare function updatePost(db: DatabaseClient, id: string, data: Partial<typeof posts.$inferInsert>): Promise<{
88
+ id: string;
89
+ schemaVersion: string;
90
+ version: number;
91
+ title: string;
92
+ slug: string;
93
+ excerpt: string | null;
94
+ content: unknown;
95
+ featuredImageId: string | null;
96
+ authorId: string | null;
97
+ status: string;
98
+ published: boolean | null;
99
+ meta: unknown;
100
+ categories: string[] | null;
101
+ createdAt: Date;
102
+ updatedAt: Date;
103
+ publishedAt: Date | null;
104
+ deletedAt: Date | null;
105
+ } | null>;
106
+ export declare function deletePost(db: DatabaseClient, id: string): Promise<void>;
107
+ //# sourceMappingURL=posts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"posts.d.ts","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,wBAAsB,WAAW,CAC/B,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAO;;;;;;;;;;;;;;;;;;KAetF;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;UAO/D;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;;UAOnE;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;UAGnF;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,KAAK,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;;UAQzC;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAK9D"}
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Post database queries
3
+ */
4
+ import { and, desc, eq, isNull } from 'drizzle-orm';
5
+ import { posts } from '../schema/cms.js';
6
+ export async function getAllPosts(db, options = {}) {
7
+ const { status, authorId, limit = 20, offset = 0 } = options;
8
+ const conditions = [
9
+ isNull(posts.deletedAt),
10
+ ...(status ? [eq(posts.status, status)] : []),
11
+ ...(authorId ? [eq(posts.authorId, authorId)] : []),
12
+ ];
13
+ return db
14
+ .select()
15
+ .from(posts)
16
+ .where(and(...conditions))
17
+ .orderBy(desc(posts.createdAt))
18
+ .limit(limit)
19
+ .offset(offset);
20
+ }
21
+ export async function getPostById(db, id) {
22
+ const result = await db
23
+ .select()
24
+ .from(posts)
25
+ .where(and(eq(posts.id, id), isNull(posts.deletedAt)))
26
+ .limit(1);
27
+ return result[0] ?? null;
28
+ }
29
+ export async function getPostBySlug(db, slug) {
30
+ const result = await db
31
+ .select()
32
+ .from(posts)
33
+ .where(and(eq(posts.slug, slug), isNull(posts.deletedAt)))
34
+ .limit(1);
35
+ return result[0] ?? null;
36
+ }
37
+ export async function createPost(db, data) {
38
+ const result = await db.insert(posts).values(data).returning();
39
+ return result[0] ?? null;
40
+ }
41
+ export async function updatePost(db, id, data) {
42
+ const result = await db
43
+ .update(posts)
44
+ .set({ ...data, updatedAt: new Date() })
45
+ .where(eq(posts.id, id))
46
+ .returning();
47
+ return result[0] ?? null;
48
+ }
49
+ export async function deletePost(db, id) {
50
+ await db
51
+ .update(posts)
52
+ .set({ deletedAt: new Date(), updatedAt: new Date() })
53
+ .where(and(eq(posts.id, id), isNull(posts.deletedAt)));
54
+ }
55
+ //# sourceMappingURL=posts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"posts.js","sourceRoot":"","sources":["../../src/queries/posts.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,EAAkB,EAClB,UAAmF,EAAE;IAErF,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,GAAG,EAAE,EAAE,MAAM,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC;IAC7D,MAAM,UAAU,GAAG;QACjB,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC;QACvB,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7C,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;KACpD,CAAC;IACF,OAAO,EAAE;SACN,MAAM,EAAE;SACR,IAAI,CAAC,KAAK,CAAC;SACX,KAAK,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;SACzB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;SAC9B,KAAK,CAAC,KAAK,CAAC;SACZ,MAAM,CAAC,MAAM,CAAC,CAAC;AACpB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,EAAkB,EAAE,EAAU;IAC9D,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,EAAE;SACR,IAAI,CAAC,KAAK,CAAC;SACX,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;SACrD,KAAK,CAAC,CAAC,CAAC,CAAC;IACZ,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAAkB,EAAE,IAAY;IAClE,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,EAAE;SACR,IAAI,CAAC,KAAK,CAAC;SACX,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;SACzD,KAAK,CAAC,CAAC,CAAC,CAAC;IACZ,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,EAAkB,EAAE,IAA+B;IAClF,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;IAC/D,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,EAAkB,EAClB,EAAU,EACV,IAAwC;IAExC,MAAM,MAAM,GAAG,MAAM,EAAE;SACpB,MAAM,CAAC,KAAK,CAAC;SACb,GAAG,CAAC,EAAE,GAAG,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SACvC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;SACvB,SAAS,EAAE,CAAC;IACf,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,EAAkB,EAAE,EAAU;IAC7D,MAAM,EAAE;SACL,MAAM,CAAC,KAAK,CAAC;SACb,GAAG,CAAC,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SACrD,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,127 @@
1
+ /**
2
+ * Site database queries
3
+ */
4
+ import type { DatabaseClient } from '../client/types.js';
5
+ import { sites } from '../schema/sites.js';
6
+ export declare function getAllSites(db: DatabaseClient, options?: {
7
+ ownerId?: string;
8
+ status?: string;
9
+ limit?: number;
10
+ offset?: number;
11
+ includeDeleted?: boolean;
12
+ }): Promise<{
13
+ id: string;
14
+ schemaVersion: string;
15
+ version: number;
16
+ ownerId: string;
17
+ name: string;
18
+ slug: string;
19
+ description: string | null;
20
+ status: string;
21
+ theme: unknown;
22
+ settings: unknown;
23
+ pageCount: number | null;
24
+ favicon: string | null;
25
+ createdAt: Date;
26
+ updatedAt: Date;
27
+ publishedAt: Date | null;
28
+ deletedAt: Date | null;
29
+ }[]>;
30
+ export declare function getSiteById(db: DatabaseClient, id: string): Promise<{
31
+ id: string;
32
+ schemaVersion: string;
33
+ version: number;
34
+ ownerId: string;
35
+ name: string;
36
+ slug: string;
37
+ description: string | null;
38
+ status: string;
39
+ theme: unknown;
40
+ settings: unknown;
41
+ pageCount: number | null;
42
+ favicon: string | null;
43
+ createdAt: Date;
44
+ updatedAt: Date;
45
+ publishedAt: Date | null;
46
+ deletedAt: Date | null;
47
+ } | null>;
48
+ export declare function getSiteBySlug(db: DatabaseClient, slug: string): Promise<{
49
+ id: string;
50
+ schemaVersion: string;
51
+ version: number;
52
+ ownerId: string;
53
+ name: string;
54
+ slug: string;
55
+ description: string | null;
56
+ status: string;
57
+ theme: unknown;
58
+ settings: unknown;
59
+ pageCount: number | null;
60
+ favicon: string | null;
61
+ createdAt: Date;
62
+ updatedAt: Date;
63
+ publishedAt: Date | null;
64
+ deletedAt: Date | null;
65
+ } | null>;
66
+ export declare function createSite(db: DatabaseClient, data: typeof sites.$inferInsert): Promise<{
67
+ id: string;
68
+ name: string;
69
+ schemaVersion: string;
70
+ status: string;
71
+ createdAt: Date;
72
+ updatedAt: Date;
73
+ deletedAt: Date | null;
74
+ slug: string;
75
+ version: number;
76
+ ownerId: string;
77
+ description: string | null;
78
+ theme: unknown;
79
+ settings: unknown;
80
+ pageCount: number | null;
81
+ favicon: string | null;
82
+ publishedAt: Date | null;
83
+ } | null>;
84
+ export declare function updateSite(db: DatabaseClient, id: string, data: Partial<typeof sites.$inferInsert>): Promise<{
85
+ id: string;
86
+ schemaVersion: string;
87
+ version: number;
88
+ ownerId: string;
89
+ name: string;
90
+ slug: string;
91
+ description: string | null;
92
+ status: string;
93
+ theme: unknown;
94
+ settings: unknown;
95
+ pageCount: number | null;
96
+ favicon: string | null;
97
+ createdAt: Date;
98
+ updatedAt: Date;
99
+ publishedAt: Date | null;
100
+ deletedAt: Date | null;
101
+ } | null>;
102
+ /** Soft-delete: sets deletedAt timestamp instead of removing the row */
103
+ export declare function deleteSite(db: DatabaseClient, id: string): Promise<void>;
104
+ /** Restore a soft-deleted site */
105
+ export declare function restoreSite(db: DatabaseClient, id: string): Promise<{
106
+ id: string;
107
+ schemaVersion: string;
108
+ version: number;
109
+ ownerId: string;
110
+ name: string;
111
+ slug: string;
112
+ description: string | null;
113
+ status: string;
114
+ theme: unknown;
115
+ settings: unknown;
116
+ pageCount: number | null;
117
+ favicon: string | null;
118
+ createdAt: Date;
119
+ updatedAt: Date;
120
+ publishedAt: Date | null;
121
+ deletedAt: Date | null;
122
+ } | null>;
123
+ /** Permanently remove a soft-deleted site (admin cleanup) */
124
+ export declare function purgeSite(db: DatabaseClient, id: string): Promise<void>;
125
+ export declare function incrementPageCount(db: DatabaseClient, siteId: string): Promise<void>;
126
+ export declare function decrementPageCount(db: DatabaseClient, siteId: string): Promise<void>;
127
+ //# sourceMappingURL=sites.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sites.d.ts","sourceRoot":"","sources":["../../src/queries/sites.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAK3C,wBAAsB,WAAW,CAC/B,EAAE,EAAE,cAAc,EAClB,OAAO,GAAE;IACP,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,OAAO,CAAC;CACrB;;;;;;;;;;;;;;;;;KAeP;AAED,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;UAO/D;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM;;;;;;;;;;;;;;;;;UAOnE;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,OAAO,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;UAGnF;AAED,wBAAsB,UAAU,CAC9B,EAAE,EAAE,cAAc,EAClB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,OAAO,CAAC,OAAO,KAAK,CAAC,YAAY,CAAC;;;;;;;;;;;;;;;;;UAQzC;AAED,wEAAwE;AACxE,wBAAsB,UAAU,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAK9D;AAED,kCAAkC;AAClC,wBAAsB,WAAW,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;UAO/D;AAED,6DAA6D;AAC7D,wBAAsB,SAAS,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAE7D;AAED,wBAAsB,kBAAkB,CAAC,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAK1F;AAED,wBAAsB,kBAAkB,CAAC,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAK1F"}
@@ -0,0 +1,83 @@
1
+ /**
2
+ * Site database queries
3
+ */
4
+ import { and, desc, eq, isNull, sql } from 'drizzle-orm';
5
+ import { sites } from '../schema/sites.js';
6
+ /** Condition that excludes soft-deleted sites */
7
+ const notDeleted = isNull(sites.deletedAt);
8
+ export async function getAllSites(db, options = {}) {
9
+ const { ownerId, status, limit = 20, offset = 0, includeDeleted = false } = options;
10
+ const conditions = [
11
+ ...(includeDeleted ? [] : [notDeleted]),
12
+ ...(ownerId ? [eq(sites.ownerId, ownerId)] : []),
13
+ ...(status ? [eq(sites.status, status)] : []),
14
+ ];
15
+ return db
16
+ .select()
17
+ .from(sites)
18
+ .where(conditions.length > 0 ? and(...conditions) : undefined)
19
+ .orderBy(desc(sites.createdAt))
20
+ .limit(limit)
21
+ .offset(offset);
22
+ }
23
+ export async function getSiteById(db, id) {
24
+ const result = await db
25
+ .select()
26
+ .from(sites)
27
+ .where(and(eq(sites.id, id), notDeleted))
28
+ .limit(1);
29
+ return result[0] ?? null;
30
+ }
31
+ export async function getSiteBySlug(db, slug) {
32
+ const result = await db
33
+ .select()
34
+ .from(sites)
35
+ .where(and(eq(sites.slug, slug), notDeleted))
36
+ .limit(1);
37
+ return result[0] ?? null;
38
+ }
39
+ export async function createSite(db, data) {
40
+ const result = await db.insert(sites).values(data).returning();
41
+ return result[0] ?? null;
42
+ }
43
+ export async function updateSite(db, id, data) {
44
+ const result = await db
45
+ .update(sites)
46
+ .set({ ...data, updatedAt: new Date() })
47
+ .where(and(eq(sites.id, id), notDeleted))
48
+ .returning();
49
+ return result[0] ?? null;
50
+ }
51
+ /** Soft-delete: sets deletedAt timestamp instead of removing the row */
52
+ export async function deleteSite(db, id) {
53
+ await db
54
+ .update(sites)
55
+ .set({ deletedAt: new Date(), updatedAt: new Date() })
56
+ .where(and(eq(sites.id, id), notDeleted));
57
+ }
58
+ /** Restore a soft-deleted site */
59
+ export async function restoreSite(db, id) {
60
+ const result = await db
61
+ .update(sites)
62
+ .set({ deletedAt: null, updatedAt: new Date() })
63
+ .where(eq(sites.id, id))
64
+ .returning();
65
+ return result[0] ?? null;
66
+ }
67
+ /** Permanently remove a soft-deleted site (admin cleanup) */
68
+ export async function purgeSite(db, id) {
69
+ await db.delete(sites).where(eq(sites.id, id));
70
+ }
71
+ export async function incrementPageCount(db, siteId) {
72
+ await db
73
+ .update(sites)
74
+ .set({ pageCount: sql `COALESCE(${sites.pageCount}, 0) + 1` })
75
+ .where(eq(sites.id, siteId));
76
+ }
77
+ export async function decrementPageCount(db, siteId) {
78
+ await db
79
+ .update(sites)
80
+ .set({ pageCount: sql `GREATEST(COALESCE(${sites.pageCount}, 0) - 1, 0)` })
81
+ .where(eq(sites.id, siteId));
82
+ }
83
+ //# sourceMappingURL=sites.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sites.js","sourceRoot":"","sources":["../../src/queries/sites.ts"],"names":[],"mappings":"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"}
@@ -2,6 +2,14 @@
2
2
  * Ticket comment database queries
3
3
  */
4
4
  import type { DatabaseClient } from '../client/types.js';
5
+ export declare function getCommentById(db: DatabaseClient, id: string): Promise<{
6
+ id: string;
7
+ ticketId: string;
8
+ authorId: string | null;
9
+ body: unknown;
10
+ createdAt: Date;
11
+ updatedAt: Date;
12
+ } | null>;
5
13
  export declare function getCommentsByTicket(db: DatabaseClient, ticketId: string): Promise<{
6
14
  id: string;
7
15
  ticketId: string;
@@ -20,8 +28,8 @@ export declare function createComment(db: DatabaseClient, data: {
20
28
  createdAt: Date;
21
29
  updatedAt: Date;
22
30
  authorId: string | null;
23
- ticketId: string;
24
31
  body: unknown;
32
+ ticketId: string;
25
33
  } | undefined>;
26
34
  export declare function updateComment(db: DatabaseClient, id: string, data: {
27
35
  body: unknown;
@@ -1 +1 @@
1
- {"version":3,"file":"ticket-comments.d.ts","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAA;AAGxD,wBAAsB,mBAAmB,CAAC,EAAE,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM;;;;;;;KAM7E;AAED,wBAAsB,aAAa,CACjC,EAAE,EAAE,cAAc,EAClB,IAAI,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;eAczE;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;UAQ1F;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAoBjE"}
1
+ {"version":3,"file":"ticket-comments.d.ts","sourceRoot":"","sources":["../../src/queries/ticket-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGzD,wBAAsB,cAAc,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM;;;;;;;UAGlE;AAED,wBAAsB,mBAAmB,CAAC,EAAE,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM;;;;;;;KAM7E;AAED,wBAAsB,aAAa,CACjC,EAAE,EAAE,cAAc,EAClB,IAAI,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;eAczE;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE;;;;;;;UAQ1F;AAED,wBAAsB,aAAa,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,MAAM,iBAoBjE"}
@@ -3,6 +3,10 @@
3
3
  */
4
4
  import { eq, sql } from 'drizzle-orm';
5
5
  import { ticketComments, tickets } from '../schema/tickets.js';
6
+ export async function getCommentById(db, id) {
7
+ const result = await db.select().from(ticketComments).where(eq(ticketComments.id, id)).limit(1);
8
+ return result[0] ?? null;
9
+ }
6
10
  export async function getCommentsByTicket(db, ticketId) {
7
11
  return db
8
12
  .select()