@aphexcms/cms-core 0.1.11 → 0.1.13

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 (399) hide show
  1. package/LICENSE +21 -0
  2. package/dist/api/assets.d.ts +48 -0
  3. package/dist/api/assets.d.ts.map +1 -0
  4. package/dist/api/assets.js +52 -0
  5. package/dist/api/client.d.ts +37 -0
  6. package/dist/api/client.d.ts.map +1 -0
  7. package/dist/api/client.js +125 -0
  8. package/dist/api/documents.d.ts +57 -0
  9. package/dist/api/documents.d.ts.map +1 -0
  10. package/dist/api/documents.js +85 -0
  11. package/dist/api/index.d.ts +7 -0
  12. package/dist/api/index.d.ts.map +1 -0
  13. package/dist/api/index.js +5 -0
  14. package/dist/api/organizations.d.ts +101 -0
  15. package/dist/api/organizations.d.ts.map +1 -0
  16. package/dist/api/organizations.js +92 -0
  17. package/dist/api/types.d.ts +45 -0
  18. package/dist/api/types.d.ts.map +1 -0
  19. package/dist/api/types.js +1 -0
  20. package/dist/auth/auth-errors.d.ts +7 -0
  21. package/dist/auth/auth-errors.d.ts.map +1 -0
  22. package/dist/auth/auth-errors.js +13 -0
  23. package/dist/auth/auth-hooks.d.ts +6 -0
  24. package/dist/auth/auth-hooks.d.ts.map +1 -0
  25. package/dist/auth/auth-hooks.js +122 -0
  26. package/dist/auth/provider.d.ts +17 -0
  27. package/dist/auth/provider.d.ts.map +1 -0
  28. package/dist/auth/provider.js +1 -0
  29. package/dist/cli/generate-types.js +218 -0
  30. package/dist/cli/index.js +86 -0
  31. package/dist/client/index.d.ts +24 -0
  32. package/dist/client/index.d.ts.map +1 -0
  33. package/{src/lib/client/index.ts → dist/client/index.js} +7 -18
  34. package/{src/lib → dist}/components/AdminApp.svelte +26 -55
  35. package/dist/components/AdminApp.svelte.d.ts +24 -0
  36. package/dist/components/AdminApp.svelte.d.ts.map +1 -0
  37. package/dist/components/admin/AdminLayout.svelte.d.ts +15 -0
  38. package/dist/components/admin/AdminLayout.svelte.d.ts.map +1 -0
  39. package/{src/lib → dist}/components/admin/DocumentEditor.svelte +60 -14
  40. package/dist/components/admin/DocumentEditor.svelte.d.ts +18 -0
  41. package/dist/components/admin/DocumentEditor.svelte.d.ts.map +1 -0
  42. package/dist/components/admin/DocumentTypesList.svelte.d.ts +14 -0
  43. package/dist/components/admin/DocumentTypesList.svelte.d.ts.map +1 -0
  44. package/dist/components/admin/ObjectModal.svelte.d.ts +15 -0
  45. package/dist/components/admin/ObjectModal.svelte.d.ts.map +1 -0
  46. package/dist/components/admin/SchemaField.svelte.d.ts +19 -0
  47. package/dist/components/admin/SchemaField.svelte.d.ts.map +1 -0
  48. package/dist/components/admin/fields/ArrayField.svelte.d.ts +12 -0
  49. package/dist/components/admin/fields/ArrayField.svelte.d.ts.map +1 -0
  50. package/dist/components/admin/fields/BooleanField.svelte.d.ts +13 -0
  51. package/dist/components/admin/fields/BooleanField.svelte.d.ts.map +1 -0
  52. package/dist/components/admin/fields/ImageField.svelte.d.ts +15 -0
  53. package/dist/components/admin/fields/ImageField.svelte.d.ts.map +1 -0
  54. package/dist/components/admin/fields/NumberField.svelte.d.ts +14 -0
  55. package/dist/components/admin/fields/NumberField.svelte.d.ts.map +1 -0
  56. package/{src/lib → dist}/components/admin/fields/ReferenceField.svelte +2 -3
  57. package/dist/components/admin/fields/ReferenceField.svelte.d.ts +12 -0
  58. package/dist/components/admin/fields/ReferenceField.svelte.d.ts.map +1 -0
  59. package/dist/components/admin/fields/SlugField.svelte.d.ts +15 -0
  60. package/dist/components/admin/fields/SlugField.svelte.d.ts.map +1 -0
  61. package/dist/components/admin/fields/StringField.svelte.d.ts +14 -0
  62. package/dist/components/admin/fields/StringField.svelte.d.ts.map +1 -0
  63. package/dist/components/admin/fields/TextareaField.svelte.d.ts +14 -0
  64. package/dist/components/admin/fields/TextareaField.svelte.d.ts.map +1 -0
  65. package/dist/components/fields/index.d.ts +9 -0
  66. package/dist/components/fields/index.d.ts.map +1 -0
  67. package/dist/components/index.d.ts +7 -0
  68. package/dist/components/index.d.ts.map +1 -0
  69. package/{src/lib/components/index.ts → dist/components/index.js} +1 -5
  70. package/dist/components/layout/OrganizationSwitcher.svelte.d.ts +11 -0
  71. package/dist/components/layout/OrganizationSwitcher.svelte.d.ts.map +1 -0
  72. package/dist/components/layout/Sidebar.svelte.d.ts +14 -0
  73. package/dist/components/layout/Sidebar.svelte.d.ts.map +1 -0
  74. package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts +11 -0
  75. package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts.map +1 -0
  76. package/dist/components/layout/sidebar/NavMain.svelte.d.ts +19 -0
  77. package/dist/components/layout/sidebar/NavMain.svelte.d.ts.map +1 -0
  78. package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts +9 -0
  79. package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts.map +1 -0
  80. package/dist/components/layout/sidebar/NavUser.svelte.d.ts +9 -0
  81. package/dist/components/layout/sidebar/NavUser.svelte.d.ts.map +1 -0
  82. package/dist/config.d.ts +3 -0
  83. package/dist/config.d.ts.map +1 -0
  84. package/dist/config.js +15 -0
  85. package/dist/db/adapters/index.d.ts +1 -0
  86. package/dist/db/adapters/index.d.ts.map +1 -0
  87. package/{src/lib/db/adapters/index.ts → dist/db/adapters/index.js} +1 -0
  88. package/dist/db/index.d.ts +2 -0
  89. package/dist/db/index.d.ts.map +1 -0
  90. package/{src/lib/db/index.ts → dist/db/index.js} +1 -2
  91. package/dist/db/interfaces/asset.d.ts +73 -0
  92. package/dist/db/interfaces/asset.d.ts.map +1 -0
  93. package/dist/db/interfaces/asset.js +1 -0
  94. package/dist/db/interfaces/document.d.ts +61 -0
  95. package/dist/db/interfaces/document.d.ts.map +1 -0
  96. package/dist/db/interfaces/document.js +1 -0
  97. package/dist/db/interfaces/index.d.ts +73 -0
  98. package/dist/db/interfaces/index.d.ts.map +1 -0
  99. package/dist/db/interfaces/index.js +1 -0
  100. package/dist/db/interfaces/organization.d.ts +27 -0
  101. package/dist/db/interfaces/organization.d.ts.map +1 -0
  102. package/dist/db/interfaces/organization.js +1 -0
  103. package/dist/db/interfaces/schema.d.ts +21 -0
  104. package/dist/db/interfaces/schema.d.ts.map +1 -0
  105. package/dist/db/interfaces/schema.js +1 -0
  106. package/dist/db/interfaces/user.d.ts +15 -0
  107. package/dist/db/interfaces/user.d.ts.map +1 -0
  108. package/dist/db/interfaces/user.js +1 -0
  109. package/dist/db/utils/reference-resolver.d.ts +18 -0
  110. package/dist/db/utils/reference-resolver.d.ts.map +1 -0
  111. package/dist/db/utils/reference-resolver.js +80 -0
  112. package/dist/define.d.ts +3 -0
  113. package/dist/define.d.ts.map +1 -0
  114. package/dist/define.js +4 -0
  115. package/dist/email/index.d.ts +2 -0
  116. package/dist/email/index.d.ts.map +1 -0
  117. package/{src/lib/email/index.ts → dist/email/index.js} +1 -2
  118. package/dist/email/interfaces/email.d.ts +42 -0
  119. package/dist/email/interfaces/email.d.ts.map +1 -0
  120. package/dist/email/interfaces/email.js +1 -0
  121. package/dist/engine.d.ts +26 -0
  122. package/dist/engine.d.ts.map +1 -0
  123. package/dist/engine.js +66 -0
  124. package/dist/field-validation/rule.d.ts +51 -0
  125. package/dist/field-validation/rule.d.ts.map +1 -0
  126. package/dist/field-validation/rule.js +221 -0
  127. package/dist/field-validation/utils.d.ts +39 -0
  128. package/dist/field-validation/utils.d.ts.map +1 -0
  129. package/dist/field-validation/utils.js +99 -0
  130. package/dist/hooks.d.ts +25 -0
  131. package/dist/hooks.d.ts.map +1 -0
  132. package/dist/hooks.js +164 -0
  133. package/dist/index.d.ts +2 -0
  134. package/dist/index.d.ts.map +1 -0
  135. package/{src/lib/index.ts → dist/index.js} +1 -2
  136. package/dist/is-mobile.svelte.d.ts +5 -0
  137. package/dist/is-mobile.svelte.d.ts.map +1 -0
  138. package/{src/lib/is-mobile.svelte.ts → dist/is-mobile.svelte.js} +3 -5
  139. package/dist/lib/auth/provider.js +1 -0
  140. package/dist/lib/db/index.js +4 -0
  141. package/dist/lib/db/interfaces/asset.js +1 -0
  142. package/dist/lib/db/interfaces/document.js +1 -0
  143. package/dist/lib/db/interfaces/index.js +1 -0
  144. package/dist/lib/db/interfaces/organization.js +1 -0
  145. package/dist/lib/db/interfaces/schema.js +1 -0
  146. package/dist/lib/db/interfaces/user.js +1 -0
  147. package/dist/lib/email/index.js +4 -0
  148. package/dist/lib/email/interfaces/email.js +1 -0
  149. package/dist/lib/field-validation/rule.js +221 -0
  150. package/dist/lib/field-validation/utils.js +99 -0
  151. package/dist/lib/storage/interfaces/index.js +2 -0
  152. package/dist/lib/storage/interfaces/storage.js +1 -0
  153. package/dist/lib/types/asset.js +2 -0
  154. package/dist/lib/types/auth.js +41 -0
  155. package/dist/lib/types/config.js +1 -0
  156. package/dist/lib/types/document.js +1 -0
  157. package/dist/lib/types/filters.js +5 -0
  158. package/dist/lib/types/index.js +9 -0
  159. package/dist/lib/types/organization.js +3 -0
  160. package/dist/lib/types/schemas.js +1 -0
  161. package/dist/lib/types/sidebar.js +1 -0
  162. package/dist/lib/types/user.js +1 -0
  163. package/dist/local-api/auth-helpers.d.ts +65 -0
  164. package/dist/local-api/auth-helpers.d.ts.map +1 -0
  165. package/dist/local-api/auth-helpers.js +102 -0
  166. package/dist/local-api/collection-api.d.ts +138 -0
  167. package/dist/local-api/collection-api.d.ts.map +1 -0
  168. package/dist/local-api/collection-api.js +276 -0
  169. package/dist/local-api/index.d.ts +108 -0
  170. package/dist/local-api/index.d.ts.map +1 -0
  171. package/dist/local-api/index.js +157 -0
  172. package/dist/local-api/permissions.d.ts +45 -0
  173. package/dist/local-api/permissions.d.ts.map +1 -0
  174. package/dist/local-api/permissions.js +117 -0
  175. package/dist/local-api/types.d.ts +65 -0
  176. package/dist/local-api/types.d.ts.map +1 -0
  177. package/dist/local-api/types.js +4 -0
  178. package/dist/routes/assets-by-id.d.ts +5 -0
  179. package/dist/routes/assets-by-id.d.ts.map +1 -0
  180. package/dist/routes/assets-by-id.js +138 -0
  181. package/dist/routes/assets-cdn.d.ts +3 -0
  182. package/dist/routes/assets-cdn.d.ts.map +1 -0
  183. package/dist/routes/assets-cdn.js +155 -0
  184. package/dist/routes/assets.d.ts +4 -0
  185. package/dist/routes/assets.d.ts.map +1 -0
  186. package/dist/routes/assets.js +94 -0
  187. package/dist/routes/documents-by-id.d.ts +5 -0
  188. package/dist/routes/documents-by-id.d.ts.map +1 -0
  189. package/dist/routes/documents-by-id.js +163 -0
  190. package/dist/routes/documents-publish.d.ts +4 -0
  191. package/dist/routes/documents-publish.d.ts.map +1 -0
  192. package/dist/routes/documents-publish.js +136 -0
  193. package/dist/routes/documents-query.d.ts +24 -0
  194. package/dist/routes/documents-query.d.ts.map +1 -0
  195. package/dist/routes/documents-query.js +95 -0
  196. package/dist/routes/documents.d.ts +4 -0
  197. package/dist/routes/documents.d.ts.map +1 -0
  198. package/dist/routes/documents.js +136 -0
  199. package/dist/routes/index.d.ts +8 -0
  200. package/dist/routes/index.d.ts.map +1 -0
  201. package/dist/routes/index.js +12 -0
  202. package/dist/routes/organizations-by-id.d.ts +5 -0
  203. package/dist/routes/organizations-by-id.d.ts.map +1 -0
  204. package/dist/routes/organizations-by-id.js +187 -0
  205. package/dist/routes/organizations-invitations.d.ts +4 -0
  206. package/dist/routes/organizations-invitations.d.ts.map +1 -0
  207. package/dist/routes/organizations-invitations.js +125 -0
  208. package/dist/routes/organizations-members.d.ts +5 -0
  209. package/dist/routes/organizations-members.d.ts.map +1 -0
  210. package/dist/routes/organizations-members.js +206 -0
  211. package/dist/routes/organizations-switch.d.ts +3 -0
  212. package/dist/routes/organizations-switch.d.ts.map +1 -0
  213. package/dist/routes/organizations-switch.js +53 -0
  214. package/dist/routes/organizations.d.ts +4 -0
  215. package/dist/routes/organizations.d.ts.map +1 -0
  216. package/dist/routes/organizations.js +109 -0
  217. package/dist/routes/schemas-by-type.d.ts +3 -0
  218. package/dist/routes/schemas-by-type.d.ts.map +1 -0
  219. package/dist/routes/schemas-by-type.js +25 -0
  220. package/dist/routes/schemas.d.ts +3 -0
  221. package/dist/routes/schemas.d.ts.map +1 -0
  222. package/dist/routes/schemas.js +11 -0
  223. package/dist/routes-exports.d.ts +14 -0
  224. package/dist/routes-exports.d.ts.map +1 -0
  225. package/dist/routes-exports.js +19 -0
  226. package/dist/schema-context.svelte.d.ts +10 -0
  227. package/dist/schema-context.svelte.d.ts.map +1 -0
  228. package/dist/schema-context.svelte.js +18 -0
  229. package/dist/schema-utils/cleanup.d.ts +21 -0
  230. package/dist/schema-utils/cleanup.d.ts.map +1 -0
  231. package/dist/schema-utils/cleanup.js +80 -0
  232. package/dist/schema-utils/index.d.ts +4 -0
  233. package/dist/schema-utils/index.d.ts.map +1 -0
  234. package/dist/schema-utils/index.js +4 -0
  235. package/dist/schema-utils/utils.d.ts +30 -0
  236. package/dist/schema-utils/utils.d.ts.map +1 -0
  237. package/dist/schema-utils/utils.js +37 -0
  238. package/dist/schema-utils/validator.d.ts +6 -0
  239. package/dist/schema-utils/validator.d.ts.map +1 -0
  240. package/dist/schema-utils/validator.js +45 -0
  241. package/dist/server/index.d.ts +17 -0
  242. package/dist/server/index.d.ts.map +1 -0
  243. package/dist/server/index.js +30 -0
  244. package/dist/services/asset-service.d.ts +86 -0
  245. package/dist/services/asset-service.d.ts.map +1 -0
  246. package/dist/services/asset-service.js +187 -0
  247. package/dist/services/index.d.ts +3 -0
  248. package/dist/services/index.d.ts.map +1 -0
  249. package/dist/services/index.js +4 -0
  250. package/dist/storage/adapters/index.d.ts +2 -0
  251. package/dist/storage/adapters/index.d.ts.map +1 -0
  252. package/dist/storage/adapters/index.js +2 -0
  253. package/dist/storage/adapters/local-storage-adapter.d.ts +54 -0
  254. package/dist/storage/adapters/local-storage-adapter.d.ts.map +1 -0
  255. package/dist/storage/adapters/local-storage-adapter.js +187 -0
  256. package/dist/storage/index.d.ts +3 -0
  257. package/dist/storage/index.d.ts.map +1 -0
  258. package/{src/lib/storage/index.ts → dist/storage/index.js} +2 -4
  259. package/dist/storage/interfaces/index.d.ts +2 -0
  260. package/dist/storage/interfaces/index.d.ts.map +1 -0
  261. package/dist/storage/interfaces/index.js +2 -0
  262. package/dist/storage/interfaces/storage.d.ts +91 -0
  263. package/dist/storage/interfaces/storage.d.ts.map +1 -0
  264. package/dist/storage/interfaces/storage.js +1 -0
  265. package/dist/storage/providers/storage.d.ts +43 -0
  266. package/dist/storage/providers/storage.d.ts.map +1 -0
  267. package/dist/storage/providers/storage.js +64 -0
  268. package/dist/types/asset.d.ts +73 -0
  269. package/dist/types/asset.d.ts.map +1 -0
  270. package/dist/types/asset.js +2 -0
  271. package/dist/types/auth.d.ts +50 -0
  272. package/dist/types/auth.d.ts.map +1 -0
  273. package/dist/types/auth.js +41 -0
  274. package/dist/types/config.d.ts +64 -0
  275. package/dist/types/config.d.ts.map +1 -0
  276. package/dist/types/config.js +1 -0
  277. package/dist/types/document.d.ts +35 -0
  278. package/dist/types/document.d.ts.map +1 -0
  279. package/dist/types/document.js +1 -0
  280. package/dist/types/filters.d.ts +173 -0
  281. package/dist/types/filters.d.ts.map +1 -0
  282. package/dist/types/filters.js +5 -0
  283. package/dist/types/index.d.ts +10 -0
  284. package/dist/types/index.d.ts.map +1 -0
  285. package/dist/types/index.js +9 -0
  286. package/dist/types/organization.d.ts +105 -0
  287. package/dist/types/organization.d.ts.map +1 -0
  288. package/dist/types/organization.js +3 -0
  289. package/dist/types/schemas.d.ts +114 -0
  290. package/dist/types/schemas.d.ts.map +1 -0
  291. package/dist/types/schemas.js +1 -0
  292. package/dist/types/sidebar.d.ts +33 -0
  293. package/dist/types/sidebar.d.ts.map +1 -0
  294. package/dist/types/sidebar.js +1 -0
  295. package/dist/types/user.d.ts +14 -0
  296. package/dist/types/user.d.ts.map +1 -0
  297. package/dist/types/user.js +1 -0
  298. package/dist/utils/content-hash.d.ts +22 -0
  299. package/dist/utils/content-hash.d.ts.map +1 -0
  300. package/dist/utils/content-hash.js +67 -0
  301. package/dist/utils/image-url.d.ts +88 -0
  302. package/dist/utils/image-url.d.ts.map +1 -0
  303. package/dist/utils/image-url.js +165 -0
  304. package/dist/utils/index.d.ts +6 -0
  305. package/dist/utils/index.d.ts.map +1 -0
  306. package/dist/utils/index.js +9 -0
  307. package/dist/utils/slug.d.ts +13 -0
  308. package/dist/utils/slug.d.ts.map +1 -0
  309. package/dist/utils/slug.js +30 -0
  310. package/dist/utils.d.ts +13 -0
  311. package/dist/utils.d.ts.map +1 -0
  312. package/dist/utils.js +5 -0
  313. package/package.json +101 -95
  314. package/src/lib/api/assets.ts +0 -75
  315. package/src/lib/api/client.ts +0 -150
  316. package/src/lib/api/documents.ts +0 -102
  317. package/src/lib/api/index.ts +0 -7
  318. package/src/lib/api/organizations.ts +0 -154
  319. package/src/lib/api/types.ts +0 -34
  320. package/src/lib/auth/auth-errors.ts +0 -23
  321. package/src/lib/auth/auth-hooks.ts +0 -132
  322. package/src/lib/auth/provider.ts +0 -25
  323. package/src/lib/config.ts +0 -18
  324. package/src/lib/db/interfaces/asset.ts +0 -61
  325. package/src/lib/db/interfaces/document.ts +0 -53
  326. package/src/lib/db/interfaces/index.ts +0 -98
  327. package/src/lib/db/interfaces/organization.ts +0 -51
  328. package/src/lib/db/interfaces/schema.ts +0 -13
  329. package/src/lib/db/interfaces/user.ts +0 -16
  330. package/src/lib/db/utils/reference-resolver.ts +0 -119
  331. package/src/lib/define.ts +0 -7
  332. package/src/lib/email/interfaces/email.ts +0 -45
  333. package/src/lib/engine.ts +0 -85
  334. package/src/lib/field-validation/rule.ts +0 -287
  335. package/src/lib/field-validation/utils.ts +0 -91
  336. package/src/lib/hooks.ts +0 -142
  337. package/src/lib/routes/assets-by-id.ts +0 -161
  338. package/src/lib/routes/assets-cdn.ts +0 -185
  339. package/src/lib/routes/assets.ts +0 -116
  340. package/src/lib/routes/documents-by-id.ts +0 -188
  341. package/src/lib/routes/documents-publish.ts +0 -211
  342. package/src/lib/routes/documents.ts +0 -172
  343. package/src/lib/routes/index.ts +0 -13
  344. package/src/lib/routes/organizations-by-id.ts +0 -258
  345. package/src/lib/routes/organizations-invitations.ts +0 -183
  346. package/src/lib/routes/organizations-members.ts +0 -301
  347. package/src/lib/routes/organizations-switch.ts +0 -74
  348. package/src/lib/routes/organizations.ts +0 -147
  349. package/src/lib/routes/schemas-by-type.ts +0 -35
  350. package/src/lib/routes/schemas.ts +0 -19
  351. package/src/lib/routes-exports.ts +0 -42
  352. package/src/lib/schema-context.svelte.ts +0 -24
  353. package/src/lib/schema-utils/cleanup.ts +0 -116
  354. package/src/lib/schema-utils/index.ts +0 -4
  355. package/src/lib/schema-utils/utils.ts +0 -47
  356. package/src/lib/schema-utils/validator.ts +0 -58
  357. package/src/lib/server/index.ts +0 -40
  358. package/src/lib/services/asset-service.ts +0 -256
  359. package/src/lib/services/index.ts +0 -6
  360. package/src/lib/storage/adapters/index.ts +0 -2
  361. package/src/lib/storage/adapters/local-storage-adapter.ts +0 -215
  362. package/src/lib/storage/interfaces/index.ts +0 -2
  363. package/src/lib/storage/interfaces/storage.ts +0 -114
  364. package/src/lib/storage/providers/storage.ts +0 -83
  365. package/src/lib/types/asset.ts +0 -81
  366. package/src/lib/types/auth.ts +0 -80
  367. package/src/lib/types/config.ts +0 -45
  368. package/src/lib/types/document.ts +0 -38
  369. package/src/lib/types/index.ts +0 -8
  370. package/src/lib/types/organization.ts +0 -119
  371. package/src/lib/types/schemas.ts +0 -156
  372. package/src/lib/types/sidebar.ts +0 -37
  373. package/src/lib/types/user.ts +0 -17
  374. package/src/lib/utils/content-hash.ts +0 -75
  375. package/src/lib/utils/image-url.ts +0 -204
  376. package/src/lib/utils/index.ts +0 -12
  377. package/src/lib/utils/slug.ts +0 -33
  378. package/src/lib/utils.ts +0 -13
  379. /package/{src/lib → dist}/app.d.ts +0 -0
  380. /package/{src/lib → dist}/auth/MULTI_TENANCY_PLAN.md +0 -0
  381. /package/{src/lib → dist}/components/admin/AdminLayout.svelte +0 -0
  382. /package/{src/lib → dist}/components/admin/DocumentTypesList.svelte +0 -0
  383. /package/{src/lib → dist}/components/admin/ObjectModal.svelte +0 -0
  384. /package/{src/lib → dist}/components/admin/SchemaField.svelte +0 -0
  385. /package/{src/lib → dist}/components/admin/fields/ArrayField.svelte +0 -0
  386. /package/{src/lib → dist}/components/admin/fields/BooleanField.svelte +0 -0
  387. /package/{src/lib → dist}/components/admin/fields/ImageField.svelte +0 -0
  388. /package/{src/lib → dist}/components/admin/fields/NumberField.svelte +0 -0
  389. /package/{src/lib → dist}/components/admin/fields/SlugField.svelte +0 -0
  390. /package/{src/lib → dist}/components/admin/fields/StringField.svelte +0 -0
  391. /package/{src/lib → dist}/components/admin/fields/TextareaField.svelte +0 -0
  392. /package/{src/lib/components/fields/index.ts → dist/components/fields/index.js} +0 -0
  393. /package/{src/lib → dist}/components/layout/OrganizationSwitcher.svelte +0 -0
  394. /package/{src/lib → dist}/components/layout/Sidebar.svelte +0 -0
  395. /package/{src/lib → dist}/components/layout/sidebar/AppSidebar.svelte +0 -0
  396. /package/{src/lib → dist}/components/layout/sidebar/NavMain.svelte +0 -0
  397. /package/{src/lib → dist}/components/layout/sidebar/NavSecondary.svelte +0 -0
  398. /package/{src/lib → dist}/components/layout/sidebar/NavUser.svelte +0 -0
  399. /package/{src/lib → dist}/plugins/README.md +0 -0
@@ -0,0 +1,65 @@
1
+ import type { Auth } from '../types/auth.js';
2
+ import type { LocalAPIContext } from './types.js';
3
+ /**
4
+ * Convert SvelteKit locals.auth to LocalAPIContext
5
+ *
6
+ * This helper bridges the gap between the authentication system
7
+ * (handled in the app layer and enriched by handleAuthHook) and
8
+ * the LocalAPI's context-based approach.
9
+ *
10
+ * Preserves the full Auth object in context.auth so custom permission
11
+ * logic can access any custom fields added via module augmentation.
12
+ *
13
+ * @param auth - Auth object from locals.auth (already validated by handleAuthHook)
14
+ * @returns LocalAPIContext for use with LocalAPI operations
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * // In a SvelteKit route handler
19
+ * import { authToContext } from '@aphexcms/cms-core/local-api';
20
+ *
21
+ * export const GET: RequestHandler = async ({ locals }) => {
22
+ * const api = locals.aphexCMS.localAPI;
23
+ * const context = authToContext(locals.auth);
24
+ *
25
+ * const pages = await api.collections.page.find(context, {
26
+ * where: { status: { equals: 'published' } }
27
+ * });
28
+ *
29
+ * return json({ data: pages });
30
+ * };
31
+ * ```
32
+ */
33
+ export declare function authToContext(auth: Auth | null | undefined): LocalAPIContext;
34
+ /**
35
+ * Check if auth exists and convert to context
36
+ * Alias for authToContext - more semantic in some contexts
37
+ *
38
+ * @param auth - Auth object from locals.auth
39
+ * @returns LocalAPIContext
40
+ * @throws Error if auth is missing or invalid
41
+ */
42
+ export declare function requireAuth(auth: Auth | null | undefined): LocalAPIContext;
43
+ /**
44
+ * Create a system context for operations that bypass normal permissions
45
+ * Use this for seed scripts, cron jobs, migrations, and other system-level operations
46
+ *
47
+ * @param organizationId - Organization ID for the operation
48
+ * @returns LocalAPIContext with overrideAccess: true
49
+ *
50
+ * @example
51
+ * ```typescript
52
+ * // In a seed script
53
+ * import { systemContext } from '@aphexcms/cms-core/local-api';
54
+ *
55
+ * const api = getLocalAPI();
56
+ * const context = systemContext('org_123');
57
+ *
58
+ * await api.collections.page.create(context, {
59
+ * data: { title: 'Home', slug: 'home' },
60
+ * publish: true
61
+ * });
62
+ * ```
63
+ */
64
+ export declare function systemContext(organizationId: string): LocalAPIContext;
65
+ //# sourceMappingURL=auth-helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-helpers.d.ts","sourceRoot":"","sources":["../../src/lib/local-api/auth-helpers.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,SAAS,GAAG,eAAe,CAiC5E;AAED;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,SAAS,GAAG,eAAe,CAE1E;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,aAAa,CAAC,cAAc,EAAE,MAAM,GAAG,eAAe,CAKrE"}
@@ -0,0 +1,102 @@
1
+ // local-api/auth-helpers.ts
2
+ //
3
+ // Helper utilities to convert between Auth types and LocalAPIContext
4
+ /**
5
+ * Convert SvelteKit locals.auth to LocalAPIContext
6
+ *
7
+ * This helper bridges the gap between the authentication system
8
+ * (handled in the app layer and enriched by handleAuthHook) and
9
+ * the LocalAPI's context-based approach.
10
+ *
11
+ * Preserves the full Auth object in context.auth so custom permission
12
+ * logic can access any custom fields added via module augmentation.
13
+ *
14
+ * @param auth - Auth object from locals.auth (already validated by handleAuthHook)
15
+ * @returns LocalAPIContext for use with LocalAPI operations
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * // In a SvelteKit route handler
20
+ * import { authToContext } from '@aphexcms/cms-core/local-api';
21
+ *
22
+ * export const GET: RequestHandler = async ({ locals }) => {
23
+ * const api = locals.aphexCMS.localAPI;
24
+ * const context = authToContext(locals.auth);
25
+ *
26
+ * const pages = await api.collections.page.find(context, {
27
+ * where: { status: { equals: 'published' } }
28
+ * });
29
+ *
30
+ * return json({ data: pages });
31
+ * };
32
+ * ```
33
+ */
34
+ export function authToContext(auth) {
35
+ if (!auth) {
36
+ throw new Error('Authentication required');
37
+ }
38
+ // For session auth, extract user and organization info
39
+ if (auth.type === 'session') {
40
+ return {
41
+ organizationId: auth.organizationId,
42
+ user: auth.user,
43
+ auth: auth // Preserve full auth for custom permission logic
44
+ };
45
+ }
46
+ // For API key auth, create a synthetic user for permission checking
47
+ // API keys don't have traditional user accounts, but we need user info
48
+ // for the permission system to work correctly
49
+ if (auth.type === 'api_key') {
50
+ return {
51
+ organizationId: auth.organizationId,
52
+ user: {
53
+ id: `apikey:${auth.keyId}`,
54
+ email: `apikey-${auth.name}@system`,
55
+ name: auth.name,
56
+ // Map API key permissions to user roles for permission checking
57
+ role: auth.permissions.includes('write') ? 'editor' : 'viewer'
58
+ },
59
+ auth: auth // Preserve full auth for custom permission logic
60
+ };
61
+ }
62
+ // This should never happen with proper typing, but just in case
63
+ throw new Error('Unknown auth type');
64
+ }
65
+ /**
66
+ * Check if auth exists and convert to context
67
+ * Alias for authToContext - more semantic in some contexts
68
+ *
69
+ * @param auth - Auth object from locals.auth
70
+ * @returns LocalAPIContext
71
+ * @throws Error if auth is missing or invalid
72
+ */
73
+ export function requireAuth(auth) {
74
+ return authToContext(auth);
75
+ }
76
+ /**
77
+ * Create a system context for operations that bypass normal permissions
78
+ * Use this for seed scripts, cron jobs, migrations, and other system-level operations
79
+ *
80
+ * @param organizationId - Organization ID for the operation
81
+ * @returns LocalAPIContext with overrideAccess: true
82
+ *
83
+ * @example
84
+ * ```typescript
85
+ * // In a seed script
86
+ * import { systemContext } from '@aphexcms/cms-core/local-api';
87
+ *
88
+ * const api = getLocalAPI();
89
+ * const context = systemContext('org_123');
90
+ *
91
+ * await api.collections.page.create(context, {
92
+ * data: { title: 'Home', slug: 'home' },
93
+ * publish: true
94
+ * });
95
+ * ```
96
+ */
97
+ export function systemContext(organizationId) {
98
+ return {
99
+ organizationId,
100
+ overrideAccess: true
101
+ };
102
+ }
@@ -0,0 +1,138 @@
1
+ import type { DatabaseAdapter } from '../db/index.js';
2
+ import type { Where, WhereTyped, FindOptions, FindResult } from '../types/filters.js';
3
+ import type { Document } from '../types/document.js';
4
+ import type { LocalAPIContext } from './types.js';
5
+ import type { SchemaType } from '../types/schemas.js';
6
+ import { PermissionChecker } from './permissions.js';
7
+ /**
8
+ * Collection API - provides type-safe operations for a single collection
9
+ * Generic type T represents the document type for this collection
10
+ */
11
+ export declare class CollectionAPI<T = Document> {
12
+ private collectionName;
13
+ private databaseAdapter;
14
+ private _schema;
15
+ private permissions;
16
+ constructor(collectionName: string, databaseAdapter: DatabaseAdapter, _schema: SchemaType, permissions: PermissionChecker);
17
+ /**
18
+ * Get the schema for this collection
19
+ */
20
+ get schema(): SchemaType;
21
+ /**
22
+ * Find multiple documents with advanced filtering and pagination
23
+ *
24
+ * @example
25
+ * ```typescript
26
+ * const result = await api.collections.pages.find(
27
+ * { organizationId: 'org_123', user },
28
+ * {
29
+ * where: {
30
+ * status: { equals: 'published' },
31
+ * 'author.name': { contains: 'John' }
32
+ * },
33
+ * limit: 20,
34
+ * sort: '-publishedAt'
35
+ * }
36
+ * );
37
+ * ```
38
+ */
39
+ find(context: LocalAPIContext, options?: FindOptions<T>): Promise<FindResult<T>>;
40
+ /**
41
+ * Find a single document by ID
42
+ *
43
+ * @example
44
+ * ```typescript
45
+ * const page = await api.collections.pages.findByID(
46
+ * { organizationId: 'org_123', user },
47
+ * 'doc_123',
48
+ * { depth: 1, perspective: 'published' }
49
+ * );
50
+ * ```
51
+ */
52
+ findByID(context: LocalAPIContext, id: string, options?: Partial<FindOptions<T>>): Promise<T | null>;
53
+ /**
54
+ * Count documents matching a where clause
55
+ *
56
+ * @example
57
+ * ```typescript
58
+ * const count = await api.collections.pages.count(
59
+ * { organizationId: 'org_123', user },
60
+ * { where: { status: { equals: 'published' } } }
61
+ * );
62
+ * ```
63
+ */
64
+ count(context: LocalAPIContext, options?: {
65
+ where?: WhereTyped<T> | Where;
66
+ }): Promise<number>;
67
+ /**
68
+ * Create a new document
69
+ *
70
+ * @example
71
+ * ```typescript
72
+ * const page = await api.collections.pages.create(
73
+ * { organizationId: 'org_123', user },
74
+ * {
75
+ * title: 'New Page',
76
+ * slug: 'new-page',
77
+ * content: []
78
+ * }
79
+ * );
80
+ * ```
81
+ */
82
+ create(context: LocalAPIContext, data: Record<string, unknown>, options?: {
83
+ publish?: boolean;
84
+ }): Promise<T>;
85
+ /**
86
+ * Update an existing document
87
+ *
88
+ * @example
89
+ * ```typescript
90
+ * const updated = await api.collections.pages.update(
91
+ * { organizationId: 'org_123', user },
92
+ * 'doc_123',
93
+ * { title: 'Updated Title' },
94
+ * { publish: true }
95
+ * );
96
+ * ```
97
+ */
98
+ update(context: LocalAPIContext, id: string, data: Record<string, unknown>, options?: {
99
+ publish?: boolean;
100
+ }): Promise<T | null>;
101
+ /**
102
+ * Delete a document
103
+ *
104
+ * @example
105
+ * ```typescript
106
+ * const deleted = await api.collections.pages.delete(
107
+ * { organizationId: 'org_123', user },
108
+ * 'doc_123'
109
+ * );
110
+ * ```
111
+ */
112
+ delete(context: LocalAPIContext, id: string): Promise<boolean>;
113
+ /**
114
+ * Publish a document
115
+ *
116
+ * @example
117
+ * ```typescript
118
+ * const published = await api.collections.pages.publish(
119
+ * { organizationId: 'org_123', user },
120
+ * 'doc_123'
121
+ * );
122
+ * ```
123
+ */
124
+ publish(context: LocalAPIContext, id: string): Promise<T | null>;
125
+ /**
126
+ * Unpublish a document
127
+ *
128
+ * @example
129
+ * ```typescript
130
+ * const unpublished = await api.collections.pages.unpublish(
131
+ * { organizationId: 'org_123', user },
132
+ * 'doc_123'
133
+ * );
134
+ * ```
135
+ */
136
+ unpublish(context: LocalAPIContext, id: string): Promise<T | null>;
137
+ }
138
+ //# sourceMappingURL=collection-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collection-api.d.ts","sourceRoot":"","sources":["../../src/lib/local-api/collection-api.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AA6BlD;;;GAGG;AACH,qBAAa,aAAa,CAAC,CAAC,GAAG,QAAQ;IAErC,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,WAAW;gBAHX,cAAc,EAAE,MAAM,EACtB,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,UAAU,EACnB,WAAW,EAAE,iBAAiB;IAMvC;;OAEG;IACH,IAAI,MAAM,IAAI,UAAU,CAEvB;IAED;;;;;;;;;;;;;;;;;OAiBG;IACG,IAAI,CACT,OAAO,EAAE,eAAe,EACxB,OAAO,GAAE,WAAW,CAAC,CAAC,CAAM,GAC1B,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAqBzB;;;;;;;;;;;OAWG;IACG,QAAQ,CACb,OAAO,EAAE,eAAe,EACxB,EAAE,EAAE,MAAM,EACV,OAAO,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAC/B,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAmBpB;;;;;;;;;;OAUG;IACG,KAAK,CACV,OAAO,EAAE,eAAe,EACxB,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,KAAK,CAAA;KAAE,GACzC,OAAO,CAAC,MAAM,CAAC;IAWlB;;;;;;;;;;;;;;OAcG;IACG,MAAM,CACX,OAAO,EAAE,eAAe,EACxB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE,GAC7B,OAAO,CAAC,CAAC,CAAC;IAuCb;;;;;;;;;;;;OAYG;IACG,MAAM,CACX,OAAO,EAAE,eAAe,EACxB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE,GAC7B,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IA6CpB;;;;;;;;;;OAUG;IACG,MAAM,CAAC,OAAO,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAOpE;;;;;;;;;;OAUG;IACG,OAAO,CAAC,OAAO,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAgCtE;;;;;;;;;;OAUG;IACG,SAAS,CAAC,OAAO,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;CAUxE"}
@@ -0,0 +1,276 @@
1
+ // local-api/collection-api.ts
2
+ //
3
+ // Collection API - provides type-safe CRUD operations for a single collection
4
+ import { validateDocumentData } from '../field-validation/utils.js';
5
+ /**
6
+ * Transform a raw database document into a typed document with data extracted
7
+ * based on perspective (draft or published)
8
+ */
9
+ function transformDocument(doc, perspective = 'draft') {
10
+ const data = perspective === 'draft' ? doc.draftData : doc.publishedData;
11
+ // Merge document metadata with the content data
12
+ return {
13
+ id: doc.id,
14
+ ...data,
15
+ // Include metadata fields
16
+ _meta: {
17
+ type: doc.type,
18
+ status: doc.status,
19
+ organizationId: doc.organizationId,
20
+ createdAt: doc.createdAt,
21
+ updatedAt: doc.updatedAt,
22
+ createdBy: doc.createdBy,
23
+ updatedBy: doc.updatedBy,
24
+ publishedAt: doc.publishedAt,
25
+ publishedHash: doc.publishedHash
26
+ }
27
+ };
28
+ }
29
+ /**
30
+ * Collection API - provides type-safe operations for a single collection
31
+ * Generic type T represents the document type for this collection
32
+ */
33
+ export class CollectionAPI {
34
+ collectionName;
35
+ databaseAdapter;
36
+ _schema;
37
+ permissions;
38
+ constructor(collectionName, databaseAdapter, _schema, permissions) {
39
+ this.collectionName = collectionName;
40
+ this.databaseAdapter = databaseAdapter;
41
+ this._schema = _schema;
42
+ this.permissions = permissions;
43
+ // Validate collection exists
44
+ this.permissions.validateCollection(collectionName);
45
+ }
46
+ /**
47
+ * Get the schema for this collection
48
+ */
49
+ get schema() {
50
+ return this._schema;
51
+ }
52
+ /**
53
+ * Find multiple documents with advanced filtering and pagination
54
+ *
55
+ * @example
56
+ * ```typescript
57
+ * const result = await api.collections.pages.find(
58
+ * { organizationId: 'org_123', user },
59
+ * {
60
+ * where: {
61
+ * status: { equals: 'published' },
62
+ * 'author.name': { contains: 'John' }
63
+ * },
64
+ * limit: 20,
65
+ * sort: '-publishedAt'
66
+ * }
67
+ * );
68
+ * ```
69
+ */
70
+ async find(context, options = {}) {
71
+ // Permission check (unless overrideAccess)
72
+ await this.permissions.canRead(context, this.collectionName);
73
+ // Call adapter's advanced find method
74
+ const result = await this.databaseAdapter.findManyDocAdvanced(context.organizationId, this.collectionName, options);
75
+ // Transform documents to extract data based on perspective
76
+ const perspective = options.perspective || 'draft';
77
+ const transformedDocs = result.docs.map((doc) => transformDocument(doc, perspective));
78
+ return {
79
+ ...result,
80
+ docs: transformedDocs
81
+ };
82
+ }
83
+ /**
84
+ * Find a single document by ID
85
+ *
86
+ * @example
87
+ * ```typescript
88
+ * const page = await api.collections.pages.findByID(
89
+ * { organizationId: 'org_123', user },
90
+ * 'doc_123',
91
+ * { depth: 1, perspective: 'published' }
92
+ * );
93
+ * ```
94
+ */
95
+ async findByID(context, id, options) {
96
+ // Permission check (unless overrideAccess)
97
+ await this.permissions.canRead(context, this.collectionName);
98
+ const result = await this.databaseAdapter.findByDocIdAdvanced(context.organizationId, id, options);
99
+ if (!result) {
100
+ return null;
101
+ }
102
+ // Transform document to extract data based on perspective
103
+ const perspective = options?.perspective || 'draft';
104
+ return transformDocument(result, perspective);
105
+ }
106
+ /**
107
+ * Count documents matching a where clause
108
+ *
109
+ * @example
110
+ * ```typescript
111
+ * const count = await api.collections.pages.count(
112
+ * { organizationId: 'org_123', user },
113
+ * { where: { status: { equals: 'published' } } }
114
+ * );
115
+ * ```
116
+ */
117
+ async count(context, options) {
118
+ // Permission check (unless overrideAccess)
119
+ await this.permissions.canRead(context, this.collectionName);
120
+ return this.databaseAdapter.countDocuments(context.organizationId, this.collectionName, options?.where);
121
+ }
122
+ /**
123
+ * Create a new document
124
+ *
125
+ * @example
126
+ * ```typescript
127
+ * const page = await api.collections.pages.create(
128
+ * { organizationId: 'org_123', user },
129
+ * {
130
+ * title: 'New Page',
131
+ * slug: 'new-page',
132
+ * content: []
133
+ * }
134
+ * );
135
+ * ```
136
+ */
137
+ async create(context, data, options) {
138
+ // Permission check (unless overrideAccess)
139
+ await this.permissions.canWrite(context, this.collectionName);
140
+ // Validate data if publishing immediately
141
+ if (options?.publish) {
142
+ await this.permissions.canPublish(context, this.collectionName);
143
+ const validationResult = await validateDocumentData(this._schema, data, data);
144
+ if (!validationResult.isValid) {
145
+ const errorMessage = validationResult.errors
146
+ .map((e) => `${e.field}: ${e.errors.join(', ')}`)
147
+ .join('; ');
148
+ throw new Error(`Cannot publish: validation errors - ${errorMessage}`);
149
+ }
150
+ }
151
+ // Create document with draft data
152
+ const document = await this.databaseAdapter.createDocument({
153
+ organizationId: context.organizationId,
154
+ type: this.collectionName,
155
+ draftData: data,
156
+ createdBy: context.user?.id
157
+ });
158
+ // Publish immediately if requested (validation already done above)
159
+ if (options?.publish) {
160
+ const published = await this.databaseAdapter.publishDoc(context.organizationId, document.id);
161
+ if (published) {
162
+ return transformDocument(published, 'published');
163
+ }
164
+ }
165
+ return transformDocument(document, 'draft');
166
+ }
167
+ /**
168
+ * Update an existing document
169
+ *
170
+ * @example
171
+ * ```typescript
172
+ * const updated = await api.collections.pages.update(
173
+ * { organizationId: 'org_123', user },
174
+ * 'doc_123',
175
+ * { title: 'Updated Title' },
176
+ * { publish: true }
177
+ * );
178
+ * ```
179
+ */
180
+ async update(context, id, data, options) {
181
+ // Permission check (unless overrideAccess)
182
+ await this.permissions.canWrite(context, this.collectionName);
183
+ // Update draft data
184
+ const document = await this.databaseAdapter.updateDocDraft(context.organizationId, id, data, context.user?.id);
185
+ if (!document) {
186
+ return null;
187
+ }
188
+ // Validate and publish immediately if requested
189
+ if (options?.publish) {
190
+ await this.permissions.canPublish(context, this.collectionName);
191
+ // Validate the updated draft data
192
+ const validationResult = await validateDocumentData(this._schema, document.draftData, document.draftData);
193
+ if (!validationResult.isValid) {
194
+ const errorMessage = validationResult.errors
195
+ .map((e) => `${e.field}: ${e.errors.join(', ')}`)
196
+ .join('; ');
197
+ throw new Error(`Cannot publish: validation errors - ${errorMessage}`);
198
+ }
199
+ const published = await this.databaseAdapter.publishDoc(context.organizationId, document.id);
200
+ if (published) {
201
+ return transformDocument(published, 'published');
202
+ }
203
+ }
204
+ return transformDocument(document, 'draft');
205
+ }
206
+ /**
207
+ * Delete a document
208
+ *
209
+ * @example
210
+ * ```typescript
211
+ * const deleted = await api.collections.pages.delete(
212
+ * { organizationId: 'org_123', user },
213
+ * 'doc_123'
214
+ * );
215
+ * ```
216
+ */
217
+ async delete(context, id) {
218
+ // Permission check (unless overrideAccess)
219
+ await this.permissions.canDelete(context, this.collectionName);
220
+ return this.databaseAdapter.deleteDocById(context.organizationId, id);
221
+ }
222
+ /**
223
+ * Publish a document
224
+ *
225
+ * @example
226
+ * ```typescript
227
+ * const published = await api.collections.pages.publish(
228
+ * { organizationId: 'org_123', user },
229
+ * 'doc_123'
230
+ * );
231
+ * ```
232
+ */
233
+ async publish(context, id) {
234
+ // Permission check (unless overrideAccess)
235
+ await this.permissions.canPublish(context, this.collectionName);
236
+ // Get the document to access draft data for validation
237
+ const document = await this.databaseAdapter.findByDocId(context.organizationId, id);
238
+ if (!document || !document.draftData) {
239
+ throw new Error('Document not found or has no draft content to publish');
240
+ }
241
+ // Validate draft data before publishing
242
+ const validationResult = await validateDocumentData(this._schema, document.draftData, document.draftData);
243
+ if (!validationResult.isValid) {
244
+ const errorMessage = validationResult.errors
245
+ .map((e) => `${e.field}: ${e.errors.join(', ')}`)
246
+ .join('; ');
247
+ throw new Error(`Cannot publish: validation errors - ${errorMessage}`);
248
+ }
249
+ // Validation passed - proceed with publish
250
+ const publishedDocument = await this.databaseAdapter.publishDoc(context.organizationId, id);
251
+ if (!publishedDocument) {
252
+ return null;
253
+ }
254
+ return transformDocument(publishedDocument, 'published');
255
+ }
256
+ /**
257
+ * Unpublish a document
258
+ *
259
+ * @example
260
+ * ```typescript
261
+ * const unpublished = await api.collections.pages.unpublish(
262
+ * { organizationId: 'org_123', user },
263
+ * 'doc_123'
264
+ * );
265
+ * ```
266
+ */
267
+ async unpublish(context, id) {
268
+ // Permission check (unless overrideAccess)
269
+ await this.permissions.canPublish(context, this.collectionName);
270
+ const document = await this.databaseAdapter.unpublishDoc(context.organizationId, id);
271
+ if (!document) {
272
+ return null;
273
+ }
274
+ return transformDocument(document, 'draft');
275
+ }
276
+ }
@@ -0,0 +1,108 @@
1
+ import type { CMSConfig } from '../types/config.js';
2
+ import type { DatabaseAdapter } from '../db/index.js';
3
+ import type { SchemaType } from '../types/schemas.js';
4
+ import { CollectionAPI } from './collection-api.js';
5
+ /**
6
+ * Collections map - provides type-safe access to all collections
7
+ * This interface is meant to be augmented by generated types
8
+ */
9
+ export interface Collections {
10
+ [collectionName: string]: CollectionAPI<unknown>;
11
+ }
12
+ /**
13
+ * Local API - provides a unified, type-safe interface for all CMS operations
14
+ *
15
+ * This is the single source of truth for data operations in Aphex CMS.
16
+ * GraphQL and REST APIs should be thin wrappers around this Local API.
17
+ *
18
+ * @example
19
+ * ```typescript
20
+ * // Initialize
21
+ * const api = await getLocalAPI(config);
22
+ *
23
+ * // Query documents
24
+ * const pages = await api.collections.pages.find(
25
+ * { organizationId: 'org_123', user },
26
+ * { where: { status: { equals: 'published' } } }
27
+ * );
28
+ *
29
+ * // Create document
30
+ * const newPage = await api.collections.pages.create(
31
+ * { organizationId: 'org_123', user },
32
+ * { title: 'Hello', slug: 'hello' }
33
+ * );
34
+ *
35
+ * // System operation (bypasses RLS)
36
+ * const allPages = await api.collections.pages.find(
37
+ * { organizationId: 'org_123', overrideAccess: true },
38
+ * { limit: 100 }
39
+ * );
40
+ * ```
41
+ */
42
+ export declare class LocalAPI {
43
+ private config;
44
+ collections: Collections;
45
+ private userAdapter;
46
+ private systemAdapter;
47
+ private permissions;
48
+ private schemas;
49
+ constructor(config: CMSConfig, userAdapter: DatabaseAdapter, systemAdapter?: DatabaseAdapter);
50
+ /**
51
+ * Initialize collection APIs for all document schema types
52
+ */
53
+ private initializeCollections;
54
+ /**
55
+ * Get the appropriate database adapter based on context
56
+ * Uses system adapter if overrideAccess is true, otherwise uses user adapter
57
+ */
58
+ private getAdapter;
59
+ /**
60
+ * Get list of available collection names
61
+ */
62
+ getCollectionNames(): string[];
63
+ /**
64
+ * Check if a collection exists
65
+ */
66
+ hasCollection(name: string): boolean;
67
+ /**
68
+ * Get schema for a collection
69
+ */
70
+ getCollectionSchema(name: string): SchemaType | undefined;
71
+ }
72
+ /**
73
+ * Create and initialize the Local API
74
+ *
75
+ * @param config - CMS configuration
76
+ * @param userAdapter - Standard database adapter (respects RLS)
77
+ * @param systemAdapter - Optional system adapter (bypasses RLS) for system operations
78
+ * @returns LocalAPI instance
79
+ *
80
+ * @example
81
+ * ```typescript
82
+ * // Basic usage (single adapter)
83
+ * const api = createLocalAPI(config, userDb);
84
+ *
85
+ * // With system adapter for RLS bypass
86
+ * const api = createLocalAPI(config, userDb, systemDb);
87
+ * ```
88
+ */
89
+ export declare function createLocalAPI(config: CMSConfig, userAdapter: DatabaseAdapter, systemAdapter?: DatabaseAdapter): LocalAPI;
90
+ /**
91
+ * Get the Local API instance
92
+ * Throws if Local API hasn't been initialized yet
93
+ *
94
+ * @returns LocalAPI instance
95
+ * @throws Error if Local API not initialized
96
+ *
97
+ * @example
98
+ * ```typescript
99
+ * const api = getLocalAPI();
100
+ * const pages = await api.collections.pages.find(...);
101
+ * ```
102
+ */
103
+ export declare function getLocalAPI(): LocalAPI;
104
+ export { CollectionAPI } from './collection-api.js';
105
+ export { PermissionChecker, PermissionError } from './permissions.js';
106
+ export type { LocalAPIContext, CreateOptions, UpdateOptions } from './types.js';
107
+ export { authToContext, requireAuth, systemContext } from './auth-helpers.js';
108
+ //# sourceMappingURL=index.d.ts.map