nextly 0.0.1 → 0.0.2-alpha.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 (268) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +122 -0
  3. package/dist/_dts-chunks/collections-handler.d-DjgO74Wt.d.ts +20540 -0
  4. package/dist/_dts-chunks/config.d-DNwsDnjs.d.ts +2589 -0
  5. package/dist/_dts-chunks/define-component.d-BUgTHmt3.d.ts +1149 -0
  6. package/dist/_dts-chunks/image-processor.d-OO1PmMrv.d.ts +335 -0
  7. package/dist/_dts-chunks/index.d-axCAzZ7m.d.ts +17842 -0
  8. package/dist/_dts-chunks/media.d-DjDOZo4B.d.ts +117 -0
  9. package/dist/_dts-chunks/on-error.d-CHIKWNxd.d.ts +38 -0
  10. package/dist/_dts-chunks/storage.d-BUhQ2we_.d.ts +404 -0
  11. package/dist/actions/index.d.ts +239 -0
  12. package/dist/actions/index.mjs +281 -0
  13. package/dist/api/auth-state.d.ts +5 -0
  14. package/dist/api/auth-state.mjs +131 -0
  15. package/dist/api/collections-schema-detail.d.ts +56 -0
  16. package/dist/api/collections-schema-detail.mjs +244 -0
  17. package/dist/api/collections-schema-export.d.ts +56 -0
  18. package/dist/api/collections-schema-export.mjs +129 -0
  19. package/dist/api/collections-schema.d.ts +59 -0
  20. package/dist/api/collections-schema.mjs +207 -0
  21. package/dist/api/components-detail.d.ts +50 -0
  22. package/dist/api/components-detail.mjs +132 -0
  23. package/dist/api/components.d.ts +69 -0
  24. package/dist/api/components.mjs +144 -0
  25. package/dist/api/email-providers-default.d.ts +40 -0
  26. package/dist/api/email-providers-default.mjs +75 -0
  27. package/dist/api/email-providers-detail.d.ts +81 -0
  28. package/dist/api/email-providers-detail.mjs +109 -0
  29. package/dist/api/email-providers-test.d.ts +43 -0
  30. package/dist/api/email-providers-test.mjs +114 -0
  31. package/dist/api/email-providers.d.ts +69 -0
  32. package/dist/api/email-providers.mjs +110 -0
  33. package/dist/api/email-send-template.d.ts +41 -0
  34. package/dist/api/email-send-template.mjs +58 -0
  35. package/dist/api/email-send.d.ts +42 -0
  36. package/dist/api/email-send.mjs +58 -0
  37. package/dist/api/email-templates-detail.d.ts +74 -0
  38. package/dist/api/email-templates-detail.mjs +112 -0
  39. package/dist/api/email-templates-layout.d.ts +55 -0
  40. package/dist/api/email-templates-layout.mjs +92 -0
  41. package/dist/api/email-templates-preview.d.ts +48 -0
  42. package/dist/api/email-templates-preview.mjs +93 -0
  43. package/dist/api/email-templates.d.ts +61 -0
  44. package/dist/api/email-templates.mjs +118 -0
  45. package/dist/api/health.d.ts +68 -0
  46. package/dist/api/health.mjs +67 -0
  47. package/dist/api/index.d.ts +54 -0
  48. package/dist/api/index.mjs +16 -0
  49. package/dist/api/media-bulk.d.ts +74 -0
  50. package/dist/api/media-bulk.mjs +196 -0
  51. package/dist/api/media-folders.d.ts +112 -0
  52. package/dist/api/media-folders.mjs +187 -0
  53. package/dist/api/media-handlers.d.ts +102 -0
  54. package/dist/api/media-handlers.mjs +437 -0
  55. package/dist/api/media.d.ts +117 -0
  56. package/dist/api/media.mjs +242 -0
  57. package/dist/api/singles-detail.d.ts +87 -0
  58. package/dist/api/singles-detail.mjs +170 -0
  59. package/dist/api/singles-schema-detail.d.ts +54 -0
  60. package/dist/api/singles-schema-detail.mjs +182 -0
  61. package/dist/api/singles.d.ts +34 -0
  62. package/dist/api/singles.mjs +94 -0
  63. package/dist/api/storage-upload-url.d.ts +48 -0
  64. package/dist/api/storage-upload-url.mjs +202 -0
  65. package/dist/api/uploads.d.ts +109 -0
  66. package/dist/api/uploads.mjs +359 -0
  67. package/dist/auth/index.d.ts +425 -0
  68. package/dist/auth/index.mjs +199 -0
  69. package/dist/boot-apply-PQSYLDIN.mjs +7 -0
  70. package/dist/chunk-2OALJTK6.mjs +489 -0
  71. package/dist/chunk-2Q2SX2CS.mjs +365 -0
  72. package/dist/chunk-2TFX4ND3.mjs +13 -0
  73. package/dist/chunk-2TWPDSYD.mjs +87 -0
  74. package/dist/chunk-2W3DVD7S.mjs +647 -0
  75. package/dist/chunk-2ZFKXPQM.mjs +88 -0
  76. package/dist/chunk-3FA7FKAV.mjs +832 -0
  77. package/dist/chunk-3NZ2KMBL.mjs +58 -0
  78. package/dist/chunk-4MJLT6PZ.mjs +0 -0
  79. package/dist/chunk-56WO4WX7.mjs +0 -0
  80. package/dist/chunk-5APFUGAD.mjs +89 -0
  81. package/dist/chunk-5HMZ644B.mjs +108 -0
  82. package/dist/chunk-67GXH6PR.mjs +32 -0
  83. package/dist/chunk-6JNEPWRW.mjs +14368 -0
  84. package/dist/chunk-6NFHQIJD.mjs +45 -0
  85. package/dist/chunk-7P6ASYW6.mjs +9 -0
  86. package/dist/chunk-A3WPLSDT.mjs +1364 -0
  87. package/dist/chunk-AGJ6F2T3.mjs +144 -0
  88. package/dist/chunk-AK6Z23OX.mjs +1464 -0
  89. package/dist/chunk-APKKRD2G.mjs +102 -0
  90. package/dist/chunk-B2GV2BWH.mjs +73 -0
  91. package/dist/chunk-D5HQBNUB.mjs +74 -0
  92. package/dist/chunk-DNNG377Z.mjs +204 -0
  93. package/dist/chunk-DP3G27G5.mjs +135 -0
  94. package/dist/chunk-DV6WVX2Q.mjs +0 -0
  95. package/dist/chunk-DXGGXIUZ.mjs +57 -0
  96. package/dist/chunk-EGXBZCGC.mjs +943 -0
  97. package/dist/chunk-ERCNLX3V.mjs +176 -0
  98. package/dist/chunk-FQULBZ53.mjs +850 -0
  99. package/dist/chunk-G2AA4QLC.mjs +262 -0
  100. package/dist/chunk-GDBJ5JCU.mjs +488 -0
  101. package/dist/chunk-GJNSJU4S.mjs +19 -0
  102. package/dist/chunk-GZ6DCQKC.mjs +69 -0
  103. package/dist/chunk-H26B4FYG.mjs +167 -0
  104. package/dist/chunk-I4JMR3UR.mjs +21 -0
  105. package/dist/chunk-INV7QKLG.mjs +508 -0
  106. package/dist/chunk-IUDOC7N7.mjs +46 -0
  107. package/dist/chunk-IZWPRDC3.mjs +206 -0
  108. package/dist/chunk-KIMNCZGV.mjs +15 -0
  109. package/dist/chunk-L6HW2DA7.mjs +15 -0
  110. package/dist/chunk-LAZXX4HR.mjs +100 -0
  111. package/dist/chunk-LDKCUMHK.mjs +95 -0
  112. package/dist/chunk-LRXMECUA.mjs +0 -0
  113. package/dist/chunk-M52VMPGA.mjs +119 -0
  114. package/dist/chunk-MGUWEEI6.mjs +160 -0
  115. package/dist/chunk-NRUWQ5Z7.mjs +419 -0
  116. package/dist/chunk-NSEFNNU4.mjs +25360 -0
  117. package/dist/chunk-NTHVDFGO.mjs +138 -0
  118. package/dist/chunk-O3QHXMOX.mjs +3166 -0
  119. package/dist/chunk-P7NH2OSC.mjs +2605 -0
  120. package/dist/chunk-PKMABBB5.mjs +184 -0
  121. package/dist/chunk-PWS6XGJK.mjs +76 -0
  122. package/dist/chunk-R6JJQHFC.mjs +20 -0
  123. package/dist/chunk-RJLLGGPG.mjs +0 -0
  124. package/dist/chunk-SBACDPNX.mjs +689 -0
  125. package/dist/chunk-TO5AFLVQ.mjs +124 -0
  126. package/dist/chunk-TS7GHTG2.mjs +5436 -0
  127. package/dist/chunk-UJ2IMJ4W.mjs +133 -0
  128. package/dist/chunk-UOP63Q54.mjs +102 -0
  129. package/dist/chunk-UUOFWCM6.mjs +78 -0
  130. package/dist/chunk-V4EQTOA4.mjs +893 -0
  131. package/dist/chunk-VJ66NCL4.mjs +193 -0
  132. package/dist/chunk-VQJQHVEV.mjs +29 -0
  133. package/dist/chunk-VTJADRO3.mjs +141 -0
  134. package/dist/chunk-VWF3JO32.mjs +0 -0
  135. package/dist/chunk-W4MGXIRR.mjs +27 -0
  136. package/dist/chunk-W5KKPZT5.mjs +1204 -0
  137. package/dist/chunk-WD34YQ6T.mjs +381 -0
  138. package/dist/chunk-WZBYMYVW.mjs +14 -0
  139. package/dist/chunk-X23WKS3Z.mjs +50 -0
  140. package/dist/chunk-X7TXCYYN.mjs +6496 -0
  141. package/dist/chunk-XGI4EMS3.mjs +140 -0
  142. package/dist/chunk-XZKLBMN6.mjs +1153 -0
  143. package/dist/chunk-YB7INWPY.mjs +0 -0
  144. package/dist/chunk-YV4Y7SDL.mjs +83 -0
  145. package/dist/chunk-YZNBLFIW.mjs +1688 -0
  146. package/dist/chunk-YZZCTONM.mjs +263 -0
  147. package/dist/chunk-ZE6A3FYH.mjs +289 -0
  148. package/dist/cli/nextly.mjs +68 -0
  149. package/dist/cli/utils/index.d.ts +449 -0
  150. package/dist/cli/utils/index.mjs +49 -0
  151. package/dist/component-schema-service-5577KVW6.mjs +11 -0
  152. package/dist/config-loader-23YEMC3Z.mjs +23 -0
  153. package/dist/config.d.ts +44 -0
  154. package/dist/config.mjs +109 -0
  155. package/dist/container-ORGFGYSZ.mjs +9 -0
  156. package/dist/database/index.d.ts +12 -0
  157. package/dist/database/index.mjs +40 -0
  158. package/dist/database/seeders/index.d.ts +93 -0
  159. package/dist/database/seeders/index.mjs +47 -0
  160. package/dist/db-sync-demote-LJGKLB3S.mjs +117 -0
  161. package/dist/db-sync-promote-B26VSYQF.mjs +113 -0
  162. package/dist/dev-reload-broadcaster-B73IQ53V.mjs +25 -0
  163. package/dist/dist-M2NOU37V.mjs +19 -0
  164. package/dist/drizzle-kit-lazy-D2M2PXR2.mjs +13 -0
  165. package/dist/dynamic-collection-schema-service-IEXTPIZ7.mjs +8 -0
  166. package/dist/errors/index.d.ts +159 -0
  167. package/dist/errors/index.mjs +10 -0
  168. package/dist/factory-IWMBKUJM.mjs +15 -0
  169. package/dist/first-run-QIVKWJIF.mjs +63 -0
  170. package/dist/fresh-push-NR67DC3R.mjs +8 -0
  171. package/dist/index.d.ts +4175 -0
  172. package/dist/index.mjs +1336 -0
  173. package/dist/local-plugin-PTET4NAT.mjs +7 -0
  174. package/dist/logger-NU46DXNY.mjs +15 -0
  175. package/dist/logger-YE4TC7ZN.mjs +9 -0
  176. package/dist/migration-journal-EP532Y4L.mjs +139 -0
  177. package/dist/migrations/mysql/0000_eager_sentry.sql +174 -0
  178. package/dist/migrations/mysql/0001_soft_giant_girl.sql +27 -0
  179. package/dist/migrations/mysql/0002_media_table.sql +24 -0
  180. package/dist/migrations/mysql/0003_dynamic_singles.sql +37 -0
  181. package/dist/migrations/mysql/0004_dynamic_components.sql +35 -0
  182. package/dist/migrations/mysql/0005_user_management_tables.sql +92 -0
  183. package/dist/migrations/mysql/0006_api_keys.sql +36 -0
  184. package/dist/migrations/mysql/0007_general_settings.sql +20 -0
  185. package/dist/migrations/mysql/0008_site_settings_logo_url.sql +9 -0
  186. package/dist/migrations/mysql/0009_activity_log.sql +30 -0
  187. package/dist/migrations/mysql/0010_site_settings_sidebar.sql +13 -0
  188. package/dist/migrations/mysql/0011_missing_tables_and_columns.sql +54 -0
  189. package/dist/migrations/mysql/0012_image_sizes_and_focal_point.sql +30 -0
  190. package/dist/migrations/mysql/0012_media_folders.sql +43 -0
  191. package/dist/migrations/mysql/0013_user_brute_force_protection.sql +31 -0
  192. package/dist/migrations/mysql/0014_email_template_attachments.sql +12 -0
  193. package/dist/migrations/mysql/0015_media_uploaded_by_nullable.sql +15 -0
  194. package/dist/migrations/mysql/20260429_000000_000_initial_journal.sql +22 -0
  195. package/dist/migrations/mysql/20260501_000000_journal_batch.sql +17 -0
  196. package/dist/migrations/mysql/20260501_000001_audit_log.sql +24 -0
  197. package/dist/migrations/mysql/20260504_000000_nextly_meta.sql +21 -0
  198. package/dist/migrations/mysql/meta/0000_snapshot.json +1005 -0
  199. package/dist/migrations/mysql/meta/0001_snapshot.json +1099 -0
  200. package/dist/migrations/mysql/meta/_journal.json +41 -0
  201. package/dist/migrations/postgresql/0000_misty_king_bedlam.sql +169 -0
  202. package/dist/migrations/postgresql/0001_perpetual_captain_marvel.sql +8 -0
  203. package/dist/migrations/postgresql/0002_sad_spectrum.sql +16 -0
  204. package/dist/migrations/postgresql/0003_hesitant_ultron.sql +17 -0
  205. package/dist/migrations/postgresql/0004_media_table.sql +24 -0
  206. package/dist/migrations/postgresql/0005_media_folders.sql +36 -0
  207. package/dist/migrations/postgresql/0006_dynamic_collections_update.sql +50 -0
  208. package/dist/migrations/postgresql/0007_dynamic_singles.sql +38 -0
  209. package/dist/migrations/postgresql/0008_dynamic_components.sql +37 -0
  210. package/dist/migrations/postgresql/0009_user_management_tables.sql +95 -0
  211. package/dist/migrations/postgresql/0010_api_keys.sql +34 -0
  212. package/dist/migrations/postgresql/0011_general_settings.sql +20 -0
  213. package/dist/migrations/postgresql/0012_site_settings_logo_url.sql +9 -0
  214. package/dist/migrations/postgresql/0013_activity_log.sql +29 -0
  215. package/dist/migrations/postgresql/0014_image_sizes_and_focal_point.sql +33 -0
  216. package/dist/migrations/postgresql/0014_site_settings_sidebar.sql +13 -0
  217. package/dist/migrations/postgresql/0015_user_brute_force_protection.sql +29 -0
  218. package/dist/migrations/postgresql/0016_email_template_attachments.sql +12 -0
  219. package/dist/migrations/postgresql/0017_media_uploaded_by_nullable.sql +15 -0
  220. package/dist/migrations/postgresql/20260429_000000_000_initial_journal.sql +24 -0
  221. package/dist/migrations/postgresql/20260501_000000_journal_batch.sql +17 -0
  222. package/dist/migrations/postgresql/20260501_000001_audit_log.sql +24 -0
  223. package/dist/migrations/postgresql/20260504_000000_nextly_meta.sql +22 -0
  224. package/dist/migrations/postgresql/meta/0000_snapshot.json +1286 -0
  225. package/dist/migrations/postgresql/meta/0001_snapshot.json +1407 -0
  226. package/dist/migrations/postgresql/meta/0002_snapshot.json +1552 -0
  227. package/dist/migrations/postgresql/meta/0003_snapshot.json +1695 -0
  228. package/dist/migrations/postgresql/meta/0010_snapshot.json +2345 -0
  229. package/dist/migrations/postgresql/meta/_journal.json +90 -0
  230. package/dist/migrations/sqlite/0000_api_keys.sql +34 -0
  231. package/dist/migrations/sqlite/0001_general_settings.sql +20 -0
  232. package/dist/migrations/sqlite/0002_site_settings_logo_url.sql +9 -0
  233. package/dist/migrations/sqlite/0003_activity_log.sql +29 -0
  234. package/dist/migrations/sqlite/0004_image_sizes_and_focal_point.sql +29 -0
  235. package/dist/migrations/sqlite/0004_site_settings_sidebar.sql +11 -0
  236. package/dist/migrations/sqlite/0005_user_brute_force_protection.sql +29 -0
  237. package/dist/migrations/sqlite/0006_email_template_attachments.sql +12 -0
  238. package/dist/migrations/sqlite/0007_media_uploaded_by_nullable.sql +111 -0
  239. package/dist/migrations/sqlite/20260429_000000_000_initial_journal.sql +24 -0
  240. package/dist/migrations/sqlite/20260501_000000_journal_batch.sql +19 -0
  241. package/dist/migrations/sqlite/20260501_000001_audit_log.sql +24 -0
  242. package/dist/migrations/sqlite/20260504_000000_nextly_meta.sql +21 -0
  243. package/dist/migrations/sqlite/20260505_000000_user_management_tables.sql +77 -0
  244. package/dist/next.d.ts +57 -0
  245. package/dist/next.mjs +55 -0
  246. package/dist/observability/index.d.ts +87 -0
  247. package/dist/observability/index.mjs +57 -0
  248. package/dist/permissions-3DZZQZMI.mjs +39 -0
  249. package/dist/pipeline-YOML7SWF.mjs +29 -0
  250. package/dist/preview-ZZTR3QGS.mjs +9 -0
  251. package/dist/program-PW6UB2ZC.mjs +5934 -0
  252. package/dist/reconcile-single-tables-7ENVXJGB.mjs +7 -0
  253. package/dist/register-SF6E6FVU.mjs +49 -0
  254. package/dist/reload-config-HWQ4G5MM.mjs +23 -0
  255. package/dist/resolve-single-table-name-JSOMUB3R.mjs +7 -0
  256. package/dist/routeHandler-UNMMJIBM.mjs +77 -0
  257. package/dist/runtime-schema-generator-NRA6A6Z6.mjs +8 -0
  258. package/dist/runtime.d.ts +120 -0
  259. package/dist/runtime.mjs +73 -0
  260. package/dist/schema-hash-FMMG6VPJ.mjs +13 -0
  261. package/dist/schema-registry-EQ36FZDP.mjs +7 -0
  262. package/dist/scripts/load-env.mjs +42 -0
  263. package/dist/storage/index.d.ts +566 -0
  264. package/dist/storage/index.mjs +45 -0
  265. package/dist/super-admin-G5ZK5F4T.mjs +39 -0
  266. package/dist/system-table-service-WGSRVEGT.mjs +17 -0
  267. package/dist/users-7KELGRYJ.mjs +38 -0
  268. package/package.json +308 -9
@@ -0,0 +1,381 @@
1
+ import {
2
+ DEFAULT_SQL_KEYWORDS_SET,
3
+ RESERVED_SLUGS,
4
+ assertValidCollectionConfig,
5
+ assertValidComponentConfig,
6
+ validateComponentFieldRefShared,
7
+ validateFieldNameShared,
8
+ validateFieldTypeShared,
9
+ validateRelationshipTargetShared,
10
+ validateSelectOptionsShared,
11
+ validateSlugShared
12
+ } from "./chunk-FQULBZ53.mjs";
13
+ import {
14
+ simplePluralize
15
+ } from "./chunk-VTJADRO3.mjs";
16
+
17
+ // src/collections/config/define-collection.ts
18
+ function toTitleCase(str) {
19
+ return str.replace(/[-_]/g, " ").replace(/\b\w/g, (char) => char.toUpperCase());
20
+ }
21
+ function defineCollection(config) {
22
+ assertValidCollectionConfig(config);
23
+ const userFieldNames = new Set(
24
+ config.fields.filter(
25
+ (f) => "name" in f && typeof f.name === "string"
26
+ ).map((f) => f.name)
27
+ );
28
+ const systemFields = [];
29
+ if (!userFieldNames.has("title")) {
30
+ systemFields.push({
31
+ type: "text",
32
+ name: "title",
33
+ label: "Title",
34
+ required: true
35
+ });
36
+ }
37
+ if (!userFieldNames.has("slug")) {
38
+ systemFields.push({
39
+ type: "text",
40
+ name: "slug",
41
+ label: "Slug",
42
+ required: true,
43
+ unique: true
44
+ });
45
+ }
46
+ const fieldsWithSystem = [...systemFields, ...config.fields];
47
+ const singularLabel = config.labels?.singular ?? toTitleCase(config.slug);
48
+ const pluralLabel = config.labels?.plural ?? simplePluralize(singularLabel);
49
+ const normalized = {
50
+ ...config,
51
+ fields: fieldsWithSystem,
52
+ labels: {
53
+ singular: singularLabel,
54
+ plural: pluralLabel
55
+ },
56
+ timestamps: config.timestamps ?? true,
57
+ admin: {
58
+ ...config.admin,
59
+ pagination: {
60
+ defaultLimit: config.admin?.pagination?.defaultLimit ?? 10,
61
+ limits: config.admin?.pagination?.limits ?? [10, 25, 50, 100]
62
+ }
63
+ }
64
+ };
65
+ return normalized;
66
+ }
67
+
68
+ // src/singles/config/validate-single.ts
69
+ var RESERVED_SINGLE_SLUGS = [...RESERVED_SLUGS];
70
+ var RESERVED_SINGLE_SLUGS_SET = new Set(
71
+ RESERVED_SINGLE_SLUGS
72
+ );
73
+ function validateField(field, path, errors, seenNames) {
74
+ if (!field || typeof field !== "object") {
75
+ return;
76
+ }
77
+ const f = field;
78
+ const errsBase = errors;
79
+ if (!validateFieldTypeShared(f.type, path, errsBase)) {
80
+ return;
81
+ }
82
+ const fieldType = f.type;
83
+ validateFieldNameShared(
84
+ f.name,
85
+ path,
86
+ errsBase,
87
+ seenNames,
88
+ DEFAULT_SQL_KEYWORDS_SET
89
+ );
90
+ switch (fieldType) {
91
+ case "select":
92
+ validateSelectOptionsShared(f, path, errsBase, "select");
93
+ break;
94
+ case "radio":
95
+ validateSelectOptionsShared(f, path, errsBase, "radio");
96
+ break;
97
+ case "relationship":
98
+ validateRelationshipTargetShared(f, path, errsBase);
99
+ break;
100
+ case "repeater": {
101
+ const arrayFields = f.fields;
102
+ if (!arrayFields) {
103
+ errors.push({
104
+ path: `${path}.fields`,
105
+ message: "Array field must have a 'fields' array",
106
+ code: "ARRAY_FIELDS_REQUIRED"
107
+ });
108
+ } else if (Array.isArray(arrayFields)) {
109
+ validateFieldsArray(arrayFields, `${path}.fields`, errors);
110
+ }
111
+ break;
112
+ }
113
+ case "group": {
114
+ const groupFields = f.fields;
115
+ if (!groupFields) {
116
+ errors.push({
117
+ path: `${path}.fields`,
118
+ message: "Group field must have a 'fields' array",
119
+ code: "GROUP_FIELDS_REQUIRED"
120
+ });
121
+ } else if (Array.isArray(groupFields)) {
122
+ validateFieldsArray(groupFields, `${path}.fields`, errors);
123
+ }
124
+ break;
125
+ }
126
+ case "component":
127
+ validateComponentFieldRefShared(f, path, errsBase);
128
+ break;
129
+ }
130
+ }
131
+ function validateFieldsArray(fields, basePath, errors) {
132
+ const seenNames = /* @__PURE__ */ new Set();
133
+ fields.forEach((field, index) => {
134
+ const fieldPath = `${basePath}[${index}]`;
135
+ validateField(field, fieldPath, errors, seenNames);
136
+ });
137
+ }
138
+ function validateFields(fields, errors) {
139
+ const path = "fields";
140
+ if (!fields) {
141
+ errors.push({
142
+ path,
143
+ message: "Single fields are required",
144
+ code: "FIELDS_REQUIRED"
145
+ });
146
+ return;
147
+ }
148
+ if (!Array.isArray(fields)) {
149
+ errors.push({
150
+ path,
151
+ message: "Single fields must be an array",
152
+ code: "FIELDS_INVALID_TYPE"
153
+ });
154
+ return;
155
+ }
156
+ validateFieldsArray(fields, path, errors);
157
+ }
158
+ function validateAccess(access, errors) {
159
+ if (!access) {
160
+ return;
161
+ }
162
+ if (typeof access !== "object" || Array.isArray(access)) {
163
+ errors.push({
164
+ path: "access",
165
+ message: "Access control must be an object",
166
+ code: "ACCESS_INVALID_TYPE"
167
+ });
168
+ return;
169
+ }
170
+ const accessObj = access;
171
+ const validAccessKeys = ["read", "update"];
172
+ for (const key of validAccessKeys) {
173
+ const fn = accessObj[key];
174
+ if (fn !== void 0 && typeof fn !== "function") {
175
+ errors.push({
176
+ path: `access.${key}`,
177
+ message: `Access control '${key}' must be a function`,
178
+ code: "ACCESS_FUNCTION_INVALID"
179
+ });
180
+ }
181
+ }
182
+ }
183
+ function validateSingleConfig(config) {
184
+ const errors = [];
185
+ const errsBase = errors;
186
+ validateSlugShared(config.slug, errsBase, {
187
+ entityLabel: "Single",
188
+ reservedSlugsSet: RESERVED_SINGLE_SLUGS_SET,
189
+ sqlKeywordsSet: DEFAULT_SQL_KEYWORDS_SET
190
+ });
191
+ validateFields(config.fields, errors);
192
+ validateAccess(config.access, errors);
193
+ return {
194
+ valid: errors.length === 0,
195
+ errors
196
+ };
197
+ }
198
+ function assertValidSingleConfig(config) {
199
+ const result = validateSingleConfig(config);
200
+ if (!result.valid) {
201
+ const errorMessages = result.errors.map((err) => ` - [${err.code}] ${err.path}: ${err.message}`).join("\n");
202
+ throw new Error(
203
+ `Invalid Single config for '${config.slug || "unknown"}':
204
+ ${errorMessages}`
205
+ );
206
+ }
207
+ }
208
+
209
+ // src/singles/config/define-single.ts
210
+ function toTitleCase2(str) {
211
+ return str.replace(/[-_]/g, " ").replace(/\b\w/g, (char) => char.toUpperCase());
212
+ }
213
+ function defineSingle(config) {
214
+ assertValidSingleConfig(config);
215
+ const userFieldNames = new Set(
216
+ config.fields.filter(
217
+ (f) => "name" in f && typeof f.name === "string"
218
+ ).map((f) => f.name)
219
+ );
220
+ const systemFields = [];
221
+ if (!userFieldNames.has("title")) {
222
+ systemFields.push({
223
+ type: "text",
224
+ name: "title",
225
+ label: "Title",
226
+ required: true
227
+ });
228
+ }
229
+ if (!userFieldNames.has("slug")) {
230
+ systemFields.push({
231
+ type: "text",
232
+ name: "slug",
233
+ label: "Slug",
234
+ required: true,
235
+ unique: true
236
+ });
237
+ }
238
+ const fieldsWithSystem = [...systemFields, ...config.fields];
239
+ const label = {
240
+ singular: config.label?.singular ?? toTitleCase2(config.slug)
241
+ };
242
+ const normalized = {
243
+ ...config,
244
+ fields: fieldsWithSystem,
245
+ label,
246
+ admin: {
247
+ ...config.admin
248
+ }
249
+ };
250
+ return normalized;
251
+ }
252
+
253
+ // src/components/config/define-component.ts
254
+ function toTitleCase3(str) {
255
+ return str.replace(/[-_]/g, " ").replace(/\b\w/g, (char) => char.toUpperCase());
256
+ }
257
+ function defineComponent(config) {
258
+ assertValidComponentConfig(config);
259
+ const label = {
260
+ singular: config.label?.singular ?? toTitleCase3(config.slug)
261
+ };
262
+ const normalized = {
263
+ ...config,
264
+ label,
265
+ admin: {
266
+ ...config.admin
267
+ }
268
+ };
269
+ return normalized;
270
+ }
271
+
272
+ // src/collections/fields/helpers.ts
273
+ var text = (config) => ({
274
+ ...config,
275
+ type: "text"
276
+ });
277
+ var textarea = (config) => ({
278
+ ...config,
279
+ type: "textarea"
280
+ });
281
+ var richText = (config) => ({
282
+ ...config,
283
+ type: "richText"
284
+ });
285
+ var email = (config) => ({
286
+ ...config,
287
+ type: "email"
288
+ });
289
+ var password = (config) => ({
290
+ ...config,
291
+ type: "password"
292
+ });
293
+ var code = (config) => ({
294
+ ...config,
295
+ type: "code"
296
+ });
297
+ var number = (config) => ({
298
+ ...config,
299
+ type: "number"
300
+ });
301
+ var checkbox = (config) => ({
302
+ ...config,
303
+ type: "checkbox"
304
+ });
305
+ var date = (config) => ({
306
+ ...config,
307
+ type: "date"
308
+ });
309
+ var select = (config) => ({
310
+ ...config,
311
+ type: "select"
312
+ });
313
+ var radio = (config) => ({
314
+ ...config,
315
+ type: "radio"
316
+ });
317
+ var upload = (config) => ({
318
+ ...config,
319
+ type: "upload"
320
+ });
321
+ var relationship = (config) => ({
322
+ ...config,
323
+ type: "relationship"
324
+ });
325
+ var array = (config) => ({
326
+ ...config,
327
+ type: "repeater"
328
+ });
329
+ var repeater = (config) => ({
330
+ ...config,
331
+ type: "repeater"
332
+ });
333
+ var group = (config) => ({
334
+ ...config,
335
+ type: "group"
336
+ });
337
+ var json = (config) => ({
338
+ ...config,
339
+ type: "json"
340
+ });
341
+ var component = (config) => ({
342
+ ...config,
343
+ type: "component"
344
+ });
345
+ var chips = (config) => ({
346
+ ...config,
347
+ type: "chips"
348
+ });
349
+ var option = (label, value) => ({
350
+ label,
351
+ value: value ?? label.toLowerCase().replace(/\s+/g, "_")
352
+ });
353
+
354
+ export {
355
+ defineCollection,
356
+ RESERVED_SINGLE_SLUGS,
357
+ validateSingleConfig,
358
+ assertValidSingleConfig,
359
+ defineSingle,
360
+ defineComponent,
361
+ text,
362
+ textarea,
363
+ richText,
364
+ email,
365
+ password,
366
+ code,
367
+ number,
368
+ checkbox,
369
+ date,
370
+ select,
371
+ radio,
372
+ upload,
373
+ relationship,
374
+ array,
375
+ repeater,
376
+ group,
377
+ json,
378
+ component,
379
+ chips,
380
+ option
381
+ };
@@ -0,0 +1,14 @@
1
+ import {
2
+ NextlyError
3
+ } from "./chunk-NRUWQ5Z7.mjs";
4
+
5
+ // src/api/auth-header-only.ts
6
+ function requireAuthHeader(request) {
7
+ if (!request.headers.get("Authorization")) {
8
+ throw NextlyError.authRequired();
9
+ }
10
+ }
11
+
12
+ export {
13
+ requireAuthHeader
14
+ };
@@ -0,0 +1,50 @@
1
+ // src/auth/jwt/claims.ts
2
+ var JWT_INTERNAL_CLAIMS = [
3
+ "iat",
4
+ "exp",
5
+ "jti",
6
+ "sub",
7
+ "nbf",
8
+ "aud",
9
+ "iss"
10
+ ];
11
+ function buildClaims(input) {
12
+ const claims = {
13
+ sub: input.userId,
14
+ email: input.email,
15
+ name: input.name,
16
+ image: input.image,
17
+ roleIds: input.roleIds
18
+ };
19
+ if (input.customFields) {
20
+ for (const [key, value] of Object.entries(input.customFields)) {
21
+ if (!JWT_INTERNAL_CLAIMS.includes(
22
+ key
23
+ ) && !(key in claims)) {
24
+ claims[key] = value;
25
+ }
26
+ }
27
+ }
28
+ return claims;
29
+ }
30
+
31
+ // src/auth/jwt/sign.ts
32
+ import { randomBytes } from "crypto";
33
+ import { SignJWT } from "jose";
34
+ var ALGORITHM = "HS256";
35
+ function secretToKey(secret) {
36
+ return new TextEncoder().encode(secret);
37
+ }
38
+ async function signAccessToken(claims, secret, ttlSeconds = 900) {
39
+ const key = secretToKey(secret);
40
+ const jti = randomBytes(16).toString("hex");
41
+ const jwt = new SignJWT(claims).setProtectedHeader({ alg: ALGORITHM }).setIssuedAt().setExpirationTime(`${ttlSeconds}s`).setJti(jti);
42
+ return jwt.sign(key);
43
+ }
44
+
45
+ export {
46
+ JWT_INTERNAL_CLAIMS,
47
+ buildClaims,
48
+ secretToKey,
49
+ signAccessToken
50
+ };