@aphexcms/cms-core 0.1.7 → 0.1.8

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 (351) hide show
  1. package/package.json +6 -4
  2. package/src/lib/api/assets.ts +75 -0
  3. package/src/lib/api/client.ts +150 -0
  4. package/src/lib/api/documents.ts +102 -0
  5. package/src/lib/api/index.ts +7 -0
  6. package/src/lib/api/organizations.ts +154 -0
  7. package/src/lib/api/types.ts +34 -0
  8. package/src/lib/auth/auth-errors.ts +23 -0
  9. package/src/lib/auth/auth-hooks.ts +132 -0
  10. package/src/lib/auth/provider.ts +25 -0
  11. package/{dist/client/index.js → src/lib/client/index.ts} +19 -8
  12. package/{dist → src/lib}/components/AdminApp.svelte +4 -5
  13. package/{dist → src/lib}/components/admin/DocumentEditor.svelte +7 -7
  14. package/{dist → src/lib}/components/admin/SchemaField.svelte +1 -1
  15. package/{dist → src/lib}/components/admin/fields/ArrayField.svelte +3 -3
  16. package/{dist → src/lib}/components/admin/fields/BooleanField.svelte +1 -1
  17. package/{dist → src/lib}/components/admin/fields/ImageField.svelte +40 -13
  18. package/{dist → src/lib}/components/admin/fields/NumberField.svelte +1 -1
  19. package/{dist → src/lib}/components/admin/fields/ReferenceField.svelte +2 -2
  20. package/{dist → src/lib}/components/admin/fields/SlugField.svelte +2 -2
  21. package/{dist → src/lib}/components/admin/fields/StringField.svelte +1 -1
  22. package/{dist → src/lib}/components/admin/fields/TextareaField.svelte +1 -1
  23. package/{dist/components/index.js → src/lib/components/index.ts} +5 -1
  24. package/{dist → src/lib}/components/layout/OrganizationSwitcher.svelte +2 -2
  25. package/{dist → src/lib}/components/layout/Sidebar.svelte +1 -1
  26. package/{dist → src/lib}/components/layout/sidebar/AppSidebar.svelte +1 -1
  27. package/{dist → src/lib}/components/layout/sidebar/NavUser.svelte +1 -1
  28. package/src/lib/config.ts +18 -0
  29. package/{dist/db/adapters/index.js → src/lib/db/adapters/index.ts} +0 -1
  30. package/{dist/db/index.js → src/lib/db/index.ts} +2 -1
  31. package/src/lib/db/interfaces/asset.ts +61 -0
  32. package/src/lib/db/interfaces/document.ts +53 -0
  33. package/src/lib/db/interfaces/index.ts +98 -0
  34. package/src/lib/db/interfaces/organization.ts +51 -0
  35. package/src/lib/db/interfaces/schema.ts +13 -0
  36. package/src/lib/db/interfaces/user.ts +16 -0
  37. package/src/lib/db/utils/reference-resolver.ts +119 -0
  38. package/src/lib/define.ts +7 -0
  39. package/{dist/email/index.js → src/lib/email/index.ts} +2 -1
  40. package/src/lib/email/interfaces/email.ts +45 -0
  41. package/src/lib/engine.ts +85 -0
  42. package/src/lib/field-validation/rule.ts +287 -0
  43. package/src/lib/field-validation/utils.ts +91 -0
  44. package/src/lib/hooks.ts +142 -0
  45. package/{dist/index.js → src/lib/index.ts} +2 -1
  46. package/{dist/is-mobile.svelte.js → src/lib/is-mobile.svelte.ts} +5 -3
  47. package/src/lib/routes/assets-by-id.ts +161 -0
  48. package/src/lib/routes/assets-cdn.ts +185 -0
  49. package/src/lib/routes/assets.ts +116 -0
  50. package/src/lib/routes/documents-by-id.ts +188 -0
  51. package/src/lib/routes/documents-publish.ts +211 -0
  52. package/src/lib/routes/documents.ts +172 -0
  53. package/src/lib/routes/index.ts +13 -0
  54. package/src/lib/routes/organizations-by-id.ts +258 -0
  55. package/src/lib/routes/organizations-invitations.ts +183 -0
  56. package/src/lib/routes/organizations-members.ts +301 -0
  57. package/src/lib/routes/organizations-switch.ts +74 -0
  58. package/src/lib/routes/organizations.ts +147 -0
  59. package/src/lib/routes/schemas-by-type.ts +35 -0
  60. package/src/lib/routes/schemas.ts +19 -0
  61. package/src/lib/routes-exports.ts +42 -0
  62. package/src/lib/schema-context.svelte.ts +24 -0
  63. package/src/lib/schema-utils/cleanup.ts +116 -0
  64. package/src/lib/schema-utils/index.ts +4 -0
  65. package/src/lib/schema-utils/utils.ts +47 -0
  66. package/src/lib/schema-utils/validator.ts +58 -0
  67. package/src/lib/server/index.ts +40 -0
  68. package/src/lib/services/asset-service.ts +256 -0
  69. package/src/lib/services/index.ts +6 -0
  70. package/src/lib/storage/adapters/index.ts +2 -0
  71. package/src/lib/storage/adapters/local-storage-adapter.ts +215 -0
  72. package/{dist/storage/index.js → src/lib/storage/index.ts} +4 -2
  73. package/src/lib/storage/interfaces/index.ts +2 -0
  74. package/src/lib/storage/interfaces/storage.ts +114 -0
  75. package/src/lib/storage/providers/storage.ts +83 -0
  76. package/src/lib/types/asset.ts +81 -0
  77. package/src/lib/types/auth.ts +80 -0
  78. package/src/lib/types/config.ts +45 -0
  79. package/src/lib/types/document.ts +38 -0
  80. package/src/lib/types/index.ts +8 -0
  81. package/src/lib/types/organization.ts +119 -0
  82. package/src/lib/types/schemas.ts +151 -0
  83. package/src/lib/types/sidebar.ts +37 -0
  84. package/src/lib/types/user.ts +17 -0
  85. package/src/lib/utils/content-hash.ts +75 -0
  86. package/src/lib/utils/image-url.ts +204 -0
  87. package/src/lib/utils/index.ts +12 -0
  88. package/src/lib/utils/slug.ts +33 -0
  89. package/src/lib/utils.ts +13 -0
  90. package/dist/api/assets.d.ts +0 -48
  91. package/dist/api/assets.d.ts.map +0 -1
  92. package/dist/api/assets.js +0 -52
  93. package/dist/api/client.d.ts +0 -37
  94. package/dist/api/client.d.ts.map +0 -1
  95. package/dist/api/client.js +0 -125
  96. package/dist/api/documents.d.ts +0 -56
  97. package/dist/api/documents.d.ts.map +0 -1
  98. package/dist/api/documents.js +0 -77
  99. package/dist/api/index.d.ts +0 -7
  100. package/dist/api/index.d.ts.map +0 -1
  101. package/dist/api/index.js +0 -5
  102. package/dist/api/organizations.d.ts +0 -101
  103. package/dist/api/organizations.d.ts.map +0 -1
  104. package/dist/api/organizations.js +0 -92
  105. package/dist/api/types.d.ts +0 -23
  106. package/dist/api/types.d.ts.map +0 -1
  107. package/dist/api/types.js +0 -1
  108. package/dist/auth/auth-errors.d.ts +0 -7
  109. package/dist/auth/auth-errors.d.ts.map +0 -1
  110. package/dist/auth/auth-errors.js +0 -13
  111. package/dist/auth/auth-hooks.d.ts +0 -6
  112. package/dist/auth/auth-hooks.d.ts.map +0 -1
  113. package/dist/auth/auth-hooks.js +0 -108
  114. package/dist/auth/provider.d.ts +0 -17
  115. package/dist/auth/provider.d.ts.map +0 -1
  116. package/dist/auth/provider.js +0 -1
  117. package/dist/client/index.d.ts +0 -24
  118. package/dist/client/index.d.ts.map +0 -1
  119. package/dist/components/AdminApp.svelte.d.ts +0 -24
  120. package/dist/components/AdminApp.svelte.d.ts.map +0 -1
  121. package/dist/components/admin/AdminLayout.svelte.d.ts +0 -15
  122. package/dist/components/admin/AdminLayout.svelte.d.ts.map +0 -1
  123. package/dist/components/admin/DocumentEditor.svelte.d.ts +0 -18
  124. package/dist/components/admin/DocumentEditor.svelte.d.ts.map +0 -1
  125. package/dist/components/admin/DocumentTypesList.svelte.d.ts +0 -14
  126. package/dist/components/admin/DocumentTypesList.svelte.d.ts.map +0 -1
  127. package/dist/components/admin/ObjectModal.svelte.d.ts +0 -15
  128. package/dist/components/admin/ObjectModal.svelte.d.ts.map +0 -1
  129. package/dist/components/admin/SchemaField.svelte.d.ts +0 -19
  130. package/dist/components/admin/SchemaField.svelte.d.ts.map +0 -1
  131. package/dist/components/admin/fields/ArrayField.svelte.d.ts +0 -12
  132. package/dist/components/admin/fields/ArrayField.svelte.d.ts.map +0 -1
  133. package/dist/components/admin/fields/BooleanField.svelte.d.ts +0 -13
  134. package/dist/components/admin/fields/BooleanField.svelte.d.ts.map +0 -1
  135. package/dist/components/admin/fields/ImageField.svelte.d.ts +0 -15
  136. package/dist/components/admin/fields/ImageField.svelte.d.ts.map +0 -1
  137. package/dist/components/admin/fields/NumberField.svelte.d.ts +0 -14
  138. package/dist/components/admin/fields/NumberField.svelte.d.ts.map +0 -1
  139. package/dist/components/admin/fields/ReferenceField.svelte.d.ts +0 -12
  140. package/dist/components/admin/fields/ReferenceField.svelte.d.ts.map +0 -1
  141. package/dist/components/admin/fields/SlugField.svelte.d.ts +0 -15
  142. package/dist/components/admin/fields/SlugField.svelte.d.ts.map +0 -1
  143. package/dist/components/admin/fields/StringField.svelte.d.ts +0 -14
  144. package/dist/components/admin/fields/StringField.svelte.d.ts.map +0 -1
  145. package/dist/components/admin/fields/TextareaField.svelte.d.ts +0 -14
  146. package/dist/components/admin/fields/TextareaField.svelte.d.ts.map +0 -1
  147. package/dist/components/fields/index.d.ts +0 -9
  148. package/dist/components/fields/index.d.ts.map +0 -1
  149. package/dist/components/index.d.ts +0 -7
  150. package/dist/components/index.d.ts.map +0 -1
  151. package/dist/components/layout/OrganizationSwitcher.svelte.d.ts +0 -11
  152. package/dist/components/layout/OrganizationSwitcher.svelte.d.ts.map +0 -1
  153. package/dist/components/layout/Sidebar.svelte.d.ts +0 -14
  154. package/dist/components/layout/Sidebar.svelte.d.ts.map +0 -1
  155. package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts +0 -11
  156. package/dist/components/layout/sidebar/AppSidebar.svelte.d.ts.map +0 -1
  157. package/dist/components/layout/sidebar/NavMain.svelte.d.ts +0 -19
  158. package/dist/components/layout/sidebar/NavMain.svelte.d.ts.map +0 -1
  159. package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts +0 -9
  160. package/dist/components/layout/sidebar/NavSecondary.svelte.d.ts.map +0 -1
  161. package/dist/components/layout/sidebar/NavUser.svelte.d.ts +0 -9
  162. package/dist/components/layout/sidebar/NavUser.svelte.d.ts.map +0 -1
  163. package/dist/config.d.ts +0 -3
  164. package/dist/config.d.ts.map +0 -1
  165. package/dist/config.js +0 -15
  166. package/dist/db/adapters/index.d.ts +0 -1
  167. package/dist/db/adapters/index.d.ts.map +0 -1
  168. package/dist/db/index.d.ts +0 -2
  169. package/dist/db/index.d.ts.map +0 -1
  170. package/dist/db/interfaces/asset.d.ts +0 -51
  171. package/dist/db/interfaces/asset.d.ts.map +0 -1
  172. package/dist/db/interfaces/asset.js +0 -1
  173. package/dist/db/interfaces/document.d.ts +0 -36
  174. package/dist/db/interfaces/document.d.ts.map +0 -1
  175. package/dist/db/interfaces/document.js +0 -1
  176. package/dist/db/interfaces/index.d.ts +0 -73
  177. package/dist/db/interfaces/index.d.ts.map +0 -1
  178. package/dist/db/interfaces/index.js +0 -1
  179. package/dist/db/interfaces/organization.d.ts +0 -27
  180. package/dist/db/interfaces/organization.d.ts.map +0 -1
  181. package/dist/db/interfaces/organization.js +0 -1
  182. package/dist/db/interfaces/schema.d.ts +0 -21
  183. package/dist/db/interfaces/schema.d.ts.map +0 -1
  184. package/dist/db/interfaces/schema.js +0 -1
  185. package/dist/db/interfaces/user.d.ts +0 -15
  186. package/dist/db/interfaces/user.d.ts.map +0 -1
  187. package/dist/db/interfaces/user.js +0 -1
  188. package/dist/db/utils/reference-resolver.d.ts +0 -18
  189. package/dist/db/utils/reference-resolver.d.ts.map +0 -1
  190. package/dist/db/utils/reference-resolver.js +0 -80
  191. package/dist/define.d.ts +0 -3
  192. package/dist/define.d.ts.map +0 -1
  193. package/dist/define.js +0 -4
  194. package/dist/email/index.d.ts +0 -2
  195. package/dist/email/index.d.ts.map +0 -1
  196. package/dist/email/interfaces/email.d.ts +0 -42
  197. package/dist/email/interfaces/email.d.ts.map +0 -1
  198. package/dist/email/interfaces/email.js +0 -1
  199. package/dist/engine.d.ts +0 -26
  200. package/dist/engine.d.ts.map +0 -1
  201. package/dist/engine.js +0 -66
  202. package/dist/field-validation/rule.d.ts +0 -51
  203. package/dist/field-validation/rule.d.ts.map +0 -1
  204. package/dist/field-validation/rule.js +0 -221
  205. package/dist/field-validation/utils.d.ts +0 -21
  206. package/dist/field-validation/utils.d.ts.map +0 -1
  207. package/dist/field-validation/utils.js +0 -66
  208. package/dist/hooks.d.ts +0 -23
  209. package/dist/hooks.d.ts.map +0 -1
  210. package/dist/hooks.js +0 -96
  211. package/dist/index.d.ts +0 -2
  212. package/dist/index.d.ts.map +0 -1
  213. package/dist/is-mobile.svelte.d.ts +0 -5
  214. package/dist/is-mobile.svelte.d.ts.map +0 -1
  215. package/dist/routes/assets-by-id.d.ts +0 -5
  216. package/dist/routes/assets-by-id.d.ts.map +0 -1
  217. package/dist/routes/assets-by-id.js +0 -138
  218. package/dist/routes/assets-cdn.d.ts +0 -3
  219. package/dist/routes/assets-cdn.d.ts.map +0 -1
  220. package/dist/routes/assets-cdn.js +0 -155
  221. package/dist/routes/assets.d.ts +0 -4
  222. package/dist/routes/assets.d.ts.map +0 -1
  223. package/dist/routes/assets.js +0 -94
  224. package/dist/routes/documents-by-id.d.ts +0 -5
  225. package/dist/routes/documents-by-id.d.ts.map +0 -1
  226. package/dist/routes/documents-by-id.js +0 -142
  227. package/dist/routes/documents-publish.d.ts +0 -4
  228. package/dist/routes/documents-publish.d.ts.map +0 -1
  229. package/dist/routes/documents-publish.js +0 -151
  230. package/dist/routes/documents.d.ts +0 -4
  231. package/dist/routes/documents.d.ts.map +0 -1
  232. package/dist/routes/documents.js +0 -131
  233. package/dist/routes/index.d.ts +0 -6
  234. package/dist/routes/index.d.ts.map +0 -1
  235. package/dist/routes/index.js +0 -10
  236. package/dist/routes/organizations-by-id.d.ts +0 -5
  237. package/dist/routes/organizations-by-id.d.ts.map +0 -1
  238. package/dist/routes/organizations-by-id.js +0 -187
  239. package/dist/routes/organizations-invitations.d.ts +0 -4
  240. package/dist/routes/organizations-invitations.d.ts.map +0 -1
  241. package/dist/routes/organizations-invitations.js +0 -125
  242. package/dist/routes/organizations-members.d.ts +0 -5
  243. package/dist/routes/organizations-members.d.ts.map +0 -1
  244. package/dist/routes/organizations-members.js +0 -206
  245. package/dist/routes/organizations-switch.d.ts +0 -3
  246. package/dist/routes/organizations-switch.d.ts.map +0 -1
  247. package/dist/routes/organizations-switch.js +0 -53
  248. package/dist/routes/organizations.d.ts +0 -4
  249. package/dist/routes/organizations.d.ts.map +0 -1
  250. package/dist/routes/organizations.js +0 -108
  251. package/dist/routes/schemas-by-type.d.ts +0 -3
  252. package/dist/routes/schemas-by-type.d.ts.map +0 -1
  253. package/dist/routes/schemas-by-type.js +0 -25
  254. package/dist/routes/schemas.d.ts +0 -3
  255. package/dist/routes/schemas.d.ts.map +0 -1
  256. package/dist/routes/schemas.js +0 -11
  257. package/dist/routes-exports.d.ts +0 -14
  258. package/dist/routes-exports.d.ts.map +0 -1
  259. package/dist/routes-exports.js +0 -19
  260. package/dist/schema-context.svelte.d.ts +0 -10
  261. package/dist/schema-context.svelte.d.ts.map +0 -1
  262. package/dist/schema-context.svelte.js +0 -18
  263. package/dist/schema-utils/cleanup.d.ts +0 -21
  264. package/dist/schema-utils/cleanup.d.ts.map +0 -1
  265. package/dist/schema-utils/cleanup.js +0 -80
  266. package/dist/schema-utils/index.d.ts +0 -4
  267. package/dist/schema-utils/index.d.ts.map +0 -1
  268. package/dist/schema-utils/index.js +0 -4
  269. package/dist/schema-utils/utils.d.ts +0 -30
  270. package/dist/schema-utils/utils.d.ts.map +0 -1
  271. package/dist/schema-utils/utils.js +0 -37
  272. package/dist/schema-utils/validator.d.ts +0 -6
  273. package/dist/schema-utils/validator.d.ts.map +0 -1
  274. package/dist/schema-utils/validator.js +0 -45
  275. package/dist/server/index.d.ts +0 -16
  276. package/dist/server/index.d.ts.map +0 -1
  277. package/dist/server/index.js +0 -28
  278. package/dist/services/asset-service.d.ts +0 -86
  279. package/dist/services/asset-service.d.ts.map +0 -1
  280. package/dist/services/asset-service.js +0 -187
  281. package/dist/services/index.d.ts +0 -3
  282. package/dist/services/index.d.ts.map +0 -1
  283. package/dist/services/index.js +0 -4
  284. package/dist/storage/adapters/index.d.ts +0 -2
  285. package/dist/storage/adapters/index.d.ts.map +0 -1
  286. package/dist/storage/adapters/index.js +0 -2
  287. package/dist/storage/adapters/local-storage-adapter.d.ts +0 -54
  288. package/dist/storage/adapters/local-storage-adapter.d.ts.map +0 -1
  289. package/dist/storage/adapters/local-storage-adapter.js +0 -187
  290. package/dist/storage/index.d.ts +0 -3
  291. package/dist/storage/index.d.ts.map +0 -1
  292. package/dist/storage/interfaces/index.d.ts +0 -2
  293. package/dist/storage/interfaces/index.d.ts.map +0 -1
  294. package/dist/storage/interfaces/index.js +0 -2
  295. package/dist/storage/interfaces/storage.d.ts +0 -91
  296. package/dist/storage/interfaces/storage.d.ts.map +0 -1
  297. package/dist/storage/interfaces/storage.js +0 -1
  298. package/dist/storage/providers/storage.d.ts +0 -43
  299. package/dist/storage/providers/storage.d.ts.map +0 -1
  300. package/dist/storage/providers/storage.js +0 -64
  301. package/dist/types/asset.d.ts +0 -73
  302. package/dist/types/asset.d.ts.map +0 -1
  303. package/dist/types/asset.js +0 -2
  304. package/dist/types/auth.d.ts +0 -50
  305. package/dist/types/auth.d.ts.map +0 -1
  306. package/dist/types/auth.js +0 -41
  307. package/dist/types/config.d.ts +0 -47
  308. package/dist/types/config.d.ts.map +0 -1
  309. package/dist/types/config.js +0 -1
  310. package/dist/types/document.d.ts +0 -34
  311. package/dist/types/document.d.ts.map +0 -1
  312. package/dist/types/document.js +0 -1
  313. package/dist/types/index.d.ts +0 -9
  314. package/dist/types/index.d.ts.map +0 -1
  315. package/dist/types/index.js +0 -8
  316. package/dist/types/organization.d.ts +0 -105
  317. package/dist/types/organization.d.ts.map +0 -1
  318. package/dist/types/organization.js +0 -3
  319. package/dist/types/schemas.d.ts +0 -114
  320. package/dist/types/schemas.d.ts.map +0 -1
  321. package/dist/types/schemas.js +0 -1
  322. package/dist/types/sidebar.d.ts +0 -33
  323. package/dist/types/sidebar.d.ts.map +0 -1
  324. package/dist/types/sidebar.js +0 -1
  325. package/dist/types/user.d.ts +0 -14
  326. package/dist/types/user.d.ts.map +0 -1
  327. package/dist/types/user.js +0 -1
  328. package/dist/utils/content-hash.d.ts +0 -22
  329. package/dist/utils/content-hash.d.ts.map +0 -1
  330. package/dist/utils/content-hash.js +0 -67
  331. package/dist/utils/image-url.d.ts +0 -88
  332. package/dist/utils/image-url.d.ts.map +0 -1
  333. package/dist/utils/image-url.js +0 -165
  334. package/dist/utils/index.d.ts +0 -6
  335. package/dist/utils/index.d.ts.map +0 -1
  336. package/dist/utils/index.js +0 -9
  337. package/dist/utils/slug.d.ts +0 -13
  338. package/dist/utils/slug.d.ts.map +0 -1
  339. package/dist/utils/slug.js +0 -30
  340. package/dist/utils.d.ts +0 -13
  341. package/dist/utils.d.ts.map +0 -1
  342. package/dist/utils.js +0 -5
  343. /package/{dist → src/lib}/app.d.ts +0 -0
  344. /package/{dist → src/lib}/auth/MULTI_TENANCY_PLAN.md +0 -0
  345. /package/{dist → src/lib}/components/admin/AdminLayout.svelte +0 -0
  346. /package/{dist → src/lib}/components/admin/DocumentTypesList.svelte +0 -0
  347. /package/{dist → src/lib}/components/admin/ObjectModal.svelte +0 -0
  348. /package/{dist/components/fields/index.js → src/lib/components/fields/index.ts} +0 -0
  349. /package/{dist → src/lib}/components/layout/sidebar/NavMain.svelte +0 -0
  350. /package/{dist → src/lib}/components/layout/sidebar/NavSecondary.svelte +0 -0
  351. /package/{dist → src/lib}/plugins/README.md +0 -0
@@ -1,131 +0,0 @@
1
- // Aphex CMS Document API Handlers
2
- import { json } from '@sveltejs/kit';
3
- import { canWrite } from '../types/auth.js';
4
- // Default values for API
5
- const DEFAULT_API_LIMIT = 20;
6
- const DEFAULT_API_OFFSET = 0;
7
- // GET /api/documents - List documents with filtering
8
- export const GET = async ({ url, locals }) => {
9
- try {
10
- const { databaseAdapter } = locals.aphexCMS;
11
- const auth = locals.auth;
12
- if (!auth) {
13
- return json({
14
- success: false,
15
- error: 'Unauthorized',
16
- message: 'Authentication required'
17
- }, { status: 401 });
18
- }
19
- const docType = url.searchParams.get('docType');
20
- const status = url.searchParams.get('status') || undefined;
21
- const limitParam = url.searchParams.get('limit');
22
- const offsetParam = url.searchParams.get('offset');
23
- const depthParam = url.searchParams.get('depth');
24
- const organizationIdsParam = url.searchParams.get('organizationIds'); // Comma-separated list
25
- // Parse with defaults
26
- const limit = limitParam ? parseInt(limitParam) : DEFAULT_API_LIMIT;
27
- const offset = offsetParam ? parseInt(offsetParam) : DEFAULT_API_OFFSET;
28
- const depth = depthParam ? parseInt(depthParam) : 0;
29
- // Parse organizationIds if provided
30
- const filterOrganizationIds = organizationIdsParam
31
- ? organizationIdsParam
32
- .split(',')
33
- .map((id) => id.trim())
34
- .filter(Boolean)
35
- : undefined;
36
- const filters = {
37
- ...(docType && { type: docType }),
38
- ...(status && { status }),
39
- ...(filterOrganizationIds && { filterOrganizationIds }),
40
- limit: isNaN(limit) ? DEFAULT_API_LIMIT : limit,
41
- offset: isNaN(offset) ? DEFAULT_API_OFFSET : offset,
42
- depth: isNaN(depth) ? 0 : Math.max(0, Math.min(depth, 5)) // Clamp between 0-5 for safety
43
- };
44
- const documents = await databaseAdapter.findManyDoc(auth.organizationId, filters);
45
- return json({
46
- success: true,
47
- data: documents,
48
- meta: {
49
- count: documents.length,
50
- limit: filters.limit,
51
- offset: filters.offset,
52
- filters: {
53
- docType,
54
- status
55
- }
56
- }
57
- });
58
- }
59
- catch (error) {
60
- console.error('Failed to fetch documents:', error);
61
- return json({
62
- success: false,
63
- error: 'Failed to fetch documents',
64
- message: error instanceof Error ? error.message : 'Unknown error'
65
- }, { status: 500 });
66
- }
67
- };
68
- // POST /api/documents - Create new document
69
- export const POST = async ({ request, locals }) => {
70
- try {
71
- const { databaseAdapter } = locals.aphexCMS;
72
- const auth = locals.auth;
73
- if (!auth) {
74
- return json({
75
- success: false,
76
- error: 'Unauthorized',
77
- message: 'Authentication required'
78
- }, { status: 401 });
79
- }
80
- // Check write permissions (viewers are read-only)
81
- if (!canWrite(auth)) {
82
- return json({
83
- success: false,
84
- error: 'Forbidden',
85
- message: 'You do not have permission to create documents. Viewers have read-only access.'
86
- }, { status: 403 });
87
- }
88
- const body = await request.json();
89
- // Validate required fields (support both old and new format)
90
- const documentType = body.type;
91
- const documentData = body.draftData || body.data;
92
- if (!documentType || !documentData) {
93
- return json({
94
- success: false,
95
- error: 'Missing required fields',
96
- message: 'Document type and data are required'
97
- }, { status: 400 });
98
- }
99
- // Validate document type exists
100
- const { cmsEngine } = locals.aphexCMS;
101
- const schema = cmsEngine.getSchemaTypeByName(documentType);
102
- if (!schema) {
103
- return json({
104
- success: false,
105
- error: 'Invalid document type',
106
- message: `Schema type '${documentType}' not found`
107
- }, { status: 400 });
108
- }
109
- // NO VALIDATION FOR DRAFTS - Sanity-style: drafts can have any state
110
- // Validation only happens on publish
111
- // Create document (always starts as draft)
112
- const newDocument = await databaseAdapter.createDocument({
113
- type: documentType,
114
- draftData: documentData,
115
- organizationId: auth.organizationId,
116
- createdBy: auth.type === 'session' ? auth.user.id : undefined
117
- });
118
- return json({
119
- success: true,
120
- data: newDocument
121
- }, { status: 201 });
122
- }
123
- catch (error) {
124
- console.error('Failed to create document:', error);
125
- return json({
126
- success: false,
127
- error: 'Failed to create document',
128
- message: error instanceof Error ? error.message : 'Unknown error'
129
- }, { status: 500 });
130
- }
131
- };
@@ -1,6 +0,0 @@
1
- export * as documents from './documents.js';
2
- export * as documentsById from './documents-by-id.js';
3
- export * as assets from './assets.js';
4
- export * as schemas from './schemas.js';
5
- export * as schemasByType from './schemas-by-type.js';
6
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lib/routes/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,SAAS,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,aAAa,MAAM,sBAAsB,CAAC;AAGtD,OAAO,KAAK,MAAM,MAAM,aAAa,CAAC;AAGtC,OAAO,KAAK,OAAO,MAAM,cAAc,CAAC;AACxC,OAAO,KAAK,aAAa,MAAM,sBAAsB,CAAC"}
@@ -1,10 +0,0 @@
1
- // Aphex CMS API Route Handlers
2
- // These will be imported and re-exported by your app's API routes
3
- // Document management routes
4
- export * as documents from './documents.js';
5
- export * as documentsById from './documents-by-id.js';
6
- // Asset management routes
7
- export * as assets from './assets.js';
8
- // Schema information routes
9
- export * as schemas from './schemas.js';
10
- export * as schemasByType from './schemas-by-type.js';
@@ -1,5 +0,0 @@
1
- import type { RequestHandler } from '@sveltejs/kit';
2
- export declare const GET: RequestHandler;
3
- export declare const PATCH: RequestHandler;
4
- export declare const DELETE: RequestHandler;
5
- //# sourceMappingURL=organizations-by-id.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"organizations-by-id.d.ts","sourceRoot":"","sources":["../../src/lib/routes/organizations-by-id.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,eAAO,MAAM,GAAG,EAAE,cAmEjB,CAAC;AAGF,eAAO,MAAM,KAAK,EAAE,cAgGnB,CAAC;AAGF,eAAO,MAAM,MAAM,EAAE,cAmFpB,CAAC"}
@@ -1,187 +0,0 @@
1
- // Aphex CMS Organization by ID API Handlers
2
- import { json } from '@sveltejs/kit';
3
- // GET /api/organizations/[id] - Get organization by ID
4
- export const GET = async ({ params, locals }) => {
5
- try {
6
- const { databaseAdapter } = locals.aphexCMS;
7
- const auth = locals.auth;
8
- const { id } = params;
9
- if (!auth || auth.type !== 'session') {
10
- return json({
11
- success: false,
12
- error: 'Unauthorized',
13
- message: 'Session authentication required'
14
- }, { status: 401 });
15
- }
16
- if (!id) {
17
- return json({
18
- success: false,
19
- error: 'Missing required field',
20
- message: 'Organization ID is required'
21
- }, { status: 400 });
22
- }
23
- // Check if user is a member of this organization
24
- const membership = await databaseAdapter.findUserMembership(auth.user.id, id);
25
- if (!membership) {
26
- return json({
27
- success: false,
28
- error: 'Forbidden',
29
- message: 'You are not a member of this organization'
30
- }, { status: 403 });
31
- }
32
- const organization = await databaseAdapter.findOrganizationById(id);
33
- if (!organization) {
34
- return json({
35
- success: false,
36
- error: 'Organization not found'
37
- }, { status: 404 });
38
- }
39
- return json({
40
- success: true,
41
- data: organization
42
- });
43
- }
44
- catch (error) {
45
- console.error('Failed to fetch organization:', error);
46
- return json({
47
- success: false,
48
- error: 'Failed to fetch organization',
49
- message: error instanceof Error ? error.message : 'Unknown error'
50
- }, { status: 500 });
51
- }
52
- };
53
- // PATCH /api/organizations/[id] - Update organization
54
- export const PATCH = async ({ params, request, locals }) => {
55
- try {
56
- const { databaseAdapter } = locals.aphexCMS;
57
- const auth = locals.auth;
58
- const { id } = params;
59
- if (!auth || auth.type !== 'session') {
60
- return json({
61
- success: false,
62
- error: 'Unauthorized',
63
- message: 'Session authentication required'
64
- }, { status: 401 });
65
- }
66
- if (!id) {
67
- return json({
68
- success: false,
69
- error: 'Missing required field',
70
- message: 'Organization ID is required'
71
- }, { status: 400 });
72
- }
73
- // Check if user is owner or admin of this organization
74
- const membership = await databaseAdapter.findUserMembership(auth.user.id, id);
75
- if (!membership || (membership.role !== 'owner' && membership.role !== 'admin')) {
76
- return json({
77
- success: false,
78
- error: 'Forbidden',
79
- message: 'Only owners and admins can update organization settings'
80
- }, { status: 403 });
81
- }
82
- const body = await request.json();
83
- // Validate: if slug is being changed, check it's not already taken
84
- if (body.slug) {
85
- const existingOrg = await databaseAdapter.findOrganizationBySlug(body.slug);
86
- if (existingOrg && existingOrg.id !== id) {
87
- return json({
88
- success: false,
89
- error: 'Slug already exists',
90
- message: `Organization with slug '${body.slug}' already exists`
91
- }, { status: 409 });
92
- }
93
- }
94
- // Update organization
95
- const updateData = {};
96
- if (body.name !== undefined)
97
- updateData.name = body.name;
98
- if (body.slug !== undefined)
99
- updateData.slug = body.slug;
100
- if (body.metadata !== undefined)
101
- updateData.metadata = body.metadata;
102
- const updatedOrganization = await databaseAdapter.updateOrganization(id, updateData);
103
- if (!updatedOrganization) {
104
- return json({
105
- success: false,
106
- error: 'Organization not found'
107
- }, { status: 404 });
108
- }
109
- return json({
110
- success: true,
111
- data: updatedOrganization
112
- });
113
- }
114
- catch (error) {
115
- console.error('Failed to update organization:', error);
116
- return json({
117
- success: false,
118
- error: 'Failed to update organization',
119
- message: error instanceof Error ? error.message : 'Unknown error'
120
- }, { status: 500 });
121
- }
122
- };
123
- // DELETE /api/organizations/[id] - Delete an organization
124
- export const DELETE = async ({ params, locals }) => {
125
- try {
126
- const { databaseAdapter } = locals.aphexCMS;
127
- const auth = locals.auth;
128
- const { id } = params;
129
- if (!auth || auth.type !== 'session') {
130
- return json({
131
- success: false,
132
- error: 'Unauthorized',
133
- message: 'Session authentication required'
134
- }, { status: 401 });
135
- }
136
- if (!id) {
137
- return json({
138
- success: false,
139
- error: 'Missing required field',
140
- message: 'Organization ID is required'
141
- }, { status: 400 });
142
- }
143
- // Only owners can delete an organization
144
- const membership = await databaseAdapter.findUserMembership(auth.user.id, id);
145
- if (!membership || membership.role !== 'owner') {
146
- return json({
147
- success: false,
148
- error: 'Forbidden',
149
- message: 'Only owners can delete an organization'
150
- }, { status: 403 });
151
- }
152
- // Get all members of the organization
153
- const members = await databaseAdapter.findOrganizationMembers(id);
154
- // Handle member lifecycle
155
- for (const member of members) {
156
- const userSession = await databaseAdapter.findUserSession(member.userId);
157
- if (userSession?.activeOrganizationId === id) {
158
- const otherOrgs = await databaseAdapter.findUserOrganizations(member.userId);
159
- const remainingOrgs = otherOrgs.filter((org) => org.organization.id !== id);
160
- if (remainingOrgs.length > 0 && remainingOrgs[0]) {
161
- await databaseAdapter.updateUserSession(member.userId, remainingOrgs[0].organization.id);
162
- }
163
- else {
164
- await databaseAdapter.deleteUserSession(member.userId);
165
- }
166
- }
167
- }
168
- // Delete all members from the organization
169
- await databaseAdapter.removeAllMembers(id);
170
- // Delete all invitations for the organization
171
- await databaseAdapter.removeAllInvitations(id);
172
- // Delete the organization
173
- await databaseAdapter.deleteOrganization(id);
174
- return json({
175
- success: true,
176
- message: 'Organization deleted successfully'
177
- });
178
- }
179
- catch (error) {
180
- console.error('Failed to delete organization:', error);
181
- return json({
182
- success: false,
183
- error: 'Failed to delete organization',
184
- message: error instanceof Error ? error.message : 'Unknown error'
185
- }, { status: 500 });
186
- }
187
- };
@@ -1,4 +0,0 @@
1
- import type { RequestHandler } from '@sveltejs/kit';
2
- export declare const POST: RequestHandler;
3
- export declare const DELETE: RequestHandler;
4
- //# sourceMappingURL=organizations-invitations.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"organizations-invitations.d.ts","sourceRoot":"","sources":["../../src/lib/routes/organizations-invitations.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,eAAO,MAAM,IAAI,EAAE,cAyGlB,CAAC;AAGF,eAAO,MAAM,MAAM,EAAE,cAqEpB,CAAC"}
@@ -1,125 +0,0 @@
1
- // Aphex CMS Organization Invitations API Handlers
2
- import { json } from '@sveltejs/kit';
3
- // POST /api/organizations/invitations - Create/send an invitation
4
- export const POST = async ({ request, locals }) => {
5
- try {
6
- const { databaseAdapter } = locals.aphexCMS;
7
- const auth = locals.auth;
8
- if (!auth || auth.type !== 'session') {
9
- return json({
10
- success: false,
11
- error: 'Unauthorized',
12
- message: 'Session authentication required'
13
- }, { status: 401 });
14
- }
15
- // Only owners and admins can invite members
16
- if (auth.organizationRole !== 'owner' && auth.organizationRole !== 'admin') {
17
- return json({
18
- success: false,
19
- error: 'Forbidden',
20
- message: 'Only owners and admins can invite members'
21
- }, { status: 403 });
22
- }
23
- const body = await request.json();
24
- if (!body.email || !body.role) {
25
- return json({
26
- success: false,
27
- error: 'Missing required fields',
28
- message: 'email and role are required'
29
- }, { status: 400 });
30
- }
31
- // Validate role
32
- const validRoles = ['admin', 'editor', 'viewer'];
33
- if (!validRoles.includes(body.role)) {
34
- return json({
35
- success: false,
36
- error: 'Invalid role',
37
- message: 'Role must be one of: admin, editor, viewer'
38
- }, { status: 400 });
39
- }
40
- // Check if there's already a pending invitation for this email
41
- const existingInvitations = await databaseAdapter.findOrganizationInvitations(auth.organizationId);
42
- const pendingInvitation = existingInvitations.find((inv) => inv.email.toLowerCase() === body.email.toLowerCase() && inv.acceptedAt === null);
43
- if (pendingInvitation) {
44
- return json({
45
- success: false,
46
- error: 'Already invited',
47
- message: 'This email has already been invited to the organization'
48
- }, { status: 400 });
49
- }
50
- // Generate a unique invitation token
51
- const token = crypto.randomUUID();
52
- // Create invitation - will auto-join when user signs up
53
- const invitation = await databaseAdapter.createInvitation({
54
- organizationId: auth.organizationId,
55
- email: body.email.toLowerCase(),
56
- role: body.role,
57
- invitedBy: auth.user.id,
58
- token,
59
- expiresAt: new Date(Date.now() + 7 * 24 * 60 * 60 * 1000) // 7 days
60
- });
61
- return json({
62
- success: true,
63
- data: invitation,
64
- message: 'Invitation sent successfully. User will automatically join when they sign up.'
65
- }, { status: 201 });
66
- }
67
- catch (error) {
68
- console.error('Failed to create invitation:', error);
69
- return json({
70
- success: false,
71
- error: 'Failed to create invitation',
72
- message: error instanceof Error ? error.message : 'Unknown error'
73
- }, { status: 500 });
74
- }
75
- };
76
- // DELETE /api/organizations/invitations - Cancel an invitation
77
- export const DELETE = async ({ request, locals }) => {
78
- try {
79
- const { databaseAdapter } = locals.aphexCMS;
80
- const auth = locals.auth;
81
- if (!auth || auth.type !== 'session') {
82
- return json({
83
- success: false,
84
- error: 'Unauthorized',
85
- message: 'Session authentication required'
86
- }, { status: 401 });
87
- }
88
- // Only owners and admins can cancel invitations
89
- if (auth.organizationRole !== 'owner' && auth.organizationRole !== 'admin') {
90
- return json({
91
- success: false,
92
- error: 'Forbidden',
93
- message: 'Only owners and admins can cancel invitations'
94
- }, { status: 403 });
95
- }
96
- const body = await request.json();
97
- if (!body.invitationId) {
98
- return json({
99
- success: false,
100
- error: 'Missing required field',
101
- message: 'invitationId is required'
102
- }, { status: 400 });
103
- }
104
- // Delete the invitation
105
- const deleted = await databaseAdapter.deleteInvitation(body.invitationId);
106
- if (!deleted) {
107
- return json({
108
- success: false,
109
- error: 'Invitation not found'
110
- }, { status: 404 });
111
- }
112
- return json({
113
- success: true,
114
- message: 'Invitation canceled successfully'
115
- });
116
- }
117
- catch (error) {
118
- console.error('Failed to cancel invitation:', error);
119
- return json({
120
- success: false,
121
- error: 'Failed to cancel invitation',
122
- message: error instanceof Error ? error.message : 'Unknown error'
123
- }, { status: 500 });
124
- }
125
- };
@@ -1,5 +0,0 @@
1
- import type { RequestHandler } from '@sveltejs/kit';
2
- export declare const GET: RequestHandler;
3
- export declare const DELETE: RequestHandler;
4
- export declare const PATCH: RequestHandler;
5
- //# sourceMappingURL=organizations-members.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"organizations-members.d.ts","sourceRoot":"","sources":["../../src/lib/routes/organizations-members.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,eAAO,MAAM,GAAG,EAAE,cAkCjB,CAAC;AAGF,eAAO,MAAM,MAAM,EAAE,cAmIpB,CAAC;AAGF,eAAO,MAAM,KAAK,EAAE,cA4HnB,CAAC"}