@nextsparkjs/core 0.1.0-beta.82 → 0.1.0-beta.83

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 (374) hide show
  1. package/dist/components/entities/wrappers/EntityDetailWrapper.d.ts.map +1 -1
  2. package/dist/components/entities/wrappers/EntityDetailWrapper.js +11 -39
  3. package/dist/hooks/useEntityQuery.d.ts.map +1 -1
  4. package/dist/hooks/useEntityQuery.js +21 -3
  5. package/dist/lib/theme/get-default-theme-mode.d.ts +11 -0
  6. package/dist/lib/theme/get-default-theme-mode.d.ts.map +1 -1
  7. package/dist/lib/theme/get-default-theme-mode.js +42 -25
  8. package/dist/styles/classes.json +1 -1
  9. package/dist/types/theme.d.ts +2 -0
  10. package/dist/types/theme.d.ts.map +1 -1
  11. package/package.json +16 -16
  12. package/scripts/build/docs-registry.mjs +0 -0
  13. package/scripts/create-theme.mjs +0 -0
  14. package/scripts/deploy/release-version.mjs +0 -0
  15. package/scripts/deploy/vercel-deploy.mjs +0 -0
  16. package/scripts/dev/watch-plugins.mjs +0 -0
  17. package/scripts/maintenance/update-core.mjs +0 -0
  18. package/scripts/setup/npm-postinstall.mjs +0 -0
  19. package/scripts/setup/setup-claude.mjs +0 -0
  20. package/scripts/validation/check-imports.sh +0 -0
  21. package/dist/templates/app/(auth)/forgot-password/page.tsx +0 -216
  22. package/dist/templates/app/(auth)/layout.tsx +0 -51
  23. package/dist/templates/app/(auth)/login/page.tsx +0 -21
  24. package/dist/templates/app/(auth)/reset-password/page.tsx +0 -212
  25. package/dist/templates/app/(auth)/signup/page.tsx +0 -21
  26. package/dist/templates/app/(auth)/verify-email/page.tsx +0 -190
  27. package/dist/templates/app/(public)/[...slug]/page.tsx +0 -378
  28. package/dist/templates/app/(public)/docs/[section]/[page]/page.tsx +0 -90
  29. package/dist/templates/app/(public)/docs/layout.tsx +0 -25
  30. package/dist/templates/app/(public)/docs/page.tsx +0 -81
  31. package/dist/templates/app/(public)/layout.tsx +0 -41
  32. package/dist/templates/app/(public)/page.tsx +0 -19
  33. package/dist/templates/app/403/page.tsx +0 -89
  34. package/dist/templates/app/api/auth/[...all]/route.ts +0 -78
  35. package/dist/templates/app/api/cron/billing/lifecycle/route.ts +0 -98
  36. package/dist/templates/app/api/csp-report/route.ts +0 -175
  37. package/dist/templates/app/api/devtools/config/entities/route.ts +0 -108
  38. package/dist/templates/app/api/devtools/config/theme/route.ts +0 -66
  39. package/dist/templates/app/api/devtools/tests/[...path]/route.ts +0 -130
  40. package/dist/templates/app/api/devtools/tests/route.ts +0 -134
  41. package/dist/templates/app/api/health/route.ts +0 -29
  42. package/dist/templates/app/api/internal/user-metadata/route.ts +0 -36
  43. package/dist/templates/app/api/superadmin/subscriptions/route.ts +0 -310
  44. package/dist/templates/app/api/superadmin/teams/[teamId]/route.ts +0 -286
  45. package/dist/templates/app/api/superadmin/teams/route.ts +0 -188
  46. package/dist/templates/app/api/superadmin/users/[userId]/route.ts +0 -540
  47. package/dist/templates/app/api/superadmin/users/route.ts +0 -323
  48. package/dist/templates/app/api/user/delete-account/route.ts +0 -55
  49. package/dist/templates/app/api/user/plan-flags/route.ts +0 -283
  50. package/dist/templates/app/api/user/profile/route.ts +0 -133
  51. package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +0 -210
  52. package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +0 -331
  53. package/dist/templates/app/api/v1/[entity]/[id]/route.ts +0 -35
  54. package/dist/templates/app/api/v1/[entity]/docs.md +0 -369
  55. package/dist/templates/app/api/v1/[entity]/presets.ts +0 -194
  56. package/dist/templates/app/api/v1/[entity]/route.ts +0 -31
  57. package/dist/templates/app/api/v1/api-keys/[id]/route.ts +0 -303
  58. package/dist/templates/app/api/v1/api-keys/docs.md +0 -101
  59. package/dist/templates/app/api/v1/api-keys/presets.ts +0 -31
  60. package/dist/templates/app/api/v1/api-keys/route.ts +0 -250
  61. package/dist/templates/app/api/v1/auth/docs.md +0 -184
  62. package/dist/templates/app/api/v1/auth/presets.ts +0 -44
  63. package/dist/templates/app/api/v1/auth/signup-with-invite/route.ts +0 -227
  64. package/dist/templates/app/api/v1/billing/cancel/route.ts +0 -206
  65. package/dist/templates/app/api/v1/billing/change-plan/route.ts +0 -97
  66. package/dist/templates/app/api/v1/billing/check-action/route.ts +0 -81
  67. package/dist/templates/app/api/v1/billing/checkout/route.ts +0 -124
  68. package/dist/templates/app/api/v1/billing/docs.md +0 -209
  69. package/dist/templates/app/api/v1/billing/plans/route.ts +0 -85
  70. package/dist/templates/app/api/v1/billing/portal/route.ts +0 -90
  71. package/dist/templates/app/api/v1/billing/presets.ts +0 -121
  72. package/dist/templates/app/api/v1/billing/webhooks/stripe/route.ts +0 -428
  73. package/dist/templates/app/api/v1/blocks/[slug]/route.ts +0 -29
  74. package/dist/templates/app/api/v1/blocks/docs.md +0 -173
  75. package/dist/templates/app/api/v1/blocks/presets.ts +0 -121
  76. package/dist/templates/app/api/v1/blocks/route.ts +0 -45
  77. package/dist/templates/app/api/v1/blocks/validate/route.ts +0 -45
  78. package/dist/templates/app/api/v1/cron/docs.md +0 -116
  79. package/dist/templates/app/api/v1/cron/presets.ts +0 -26
  80. package/dist/templates/app/api/v1/cron/process/route.ts +0 -108
  81. package/dist/templates/app/api/v1/devtools/blocks/route.ts +0 -82
  82. package/dist/templates/app/api/v1/devtools/docs/route.ts +0 -150
  83. package/dist/templates/app/api/v1/devtools/docs.md +0 -204
  84. package/dist/templates/app/api/v1/devtools/features/route.ts +0 -61
  85. package/dist/templates/app/api/v1/devtools/flows/route.ts +0 -61
  86. package/dist/templates/app/api/v1/devtools/presets.ts +0 -113
  87. package/dist/templates/app/api/v1/devtools/scheduled-actions/route.ts +0 -120
  88. package/dist/templates/app/api/v1/devtools/testing/route.ts +0 -82
  89. package/dist/templates/app/api/v1/media/docs.md +0 -117
  90. package/dist/templates/app/api/v1/media/presets.ts +0 -24
  91. package/dist/templates/app/api/v1/media/upload/route.ts +0 -150
  92. package/dist/templates/app/api/v1/patterns/[id]/usages/route.ts +0 -116
  93. package/dist/templates/app/api/v1/plugin/[...path]/route.ts +0 -373
  94. package/dist/templates/app/api/v1/plugin/docs.md +0 -79
  95. package/dist/templates/app/api/v1/plugin/presets.ts +0 -21
  96. package/dist/templates/app/api/v1/plugin/route.ts +0 -96
  97. package/dist/templates/app/api/v1/post-categories/[id]/route.ts +0 -255
  98. package/dist/templates/app/api/v1/post-categories/docs.md +0 -134
  99. package/dist/templates/app/api/v1/post-categories/presets.ts +0 -78
  100. package/dist/templates/app/api/v1/post-categories/route.ts +0 -119
  101. package/dist/templates/app/api/v1/team-invitations/[token]/accept/route.ts +0 -179
  102. package/dist/templates/app/api/v1/team-invitations/[token]/decline/route.ts +0 -120
  103. package/dist/templates/app/api/v1/team-invitations/[token]/route.ts +0 -89
  104. package/dist/templates/app/api/v1/team-invitations/docs.md +0 -88
  105. package/dist/templates/app/api/v1/team-invitations/presets.ts +0 -43
  106. package/dist/templates/app/api/v1/team-invitations/route.ts +0 -114
  107. package/dist/templates/app/api/v1/teams/[teamId]/invitations/route.ts +0 -171
  108. package/dist/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +0 -105
  109. package/dist/templates/app/api/v1/teams/[teamId]/invoices/route.ts +0 -125
  110. package/dist/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +0 -263
  111. package/dist/templates/app/api/v1/teams/[teamId]/members/route.ts +0 -358
  112. package/dist/templates/app/api/v1/teams/[teamId]/route.ts +0 -322
  113. package/dist/templates/app/api/v1/teams/[teamId]/subscription/route.ts +0 -50
  114. package/dist/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +0 -91
  115. package/dist/templates/app/api/v1/teams/docs.md +0 -320
  116. package/dist/templates/app/api/v1/teams/presets.ts +0 -178
  117. package/dist/templates/app/api/v1/teams/route.ts +0 -293
  118. package/dist/templates/app/api/v1/teams/switch/route.ts +0 -88
  119. package/dist/templates/app/api/v1/theme/[...path]/route.ts +0 -361
  120. package/dist/templates/app/api/v1/theme/docs.md +0 -74
  121. package/dist/templates/app/api/v1/theme/presets.ts +0 -21
  122. package/dist/templates/app/api/v1/theme/route.ts +0 -96
  123. package/dist/templates/app/api/v1/users/[id]/meta/[key]/route.ts +0 -363
  124. package/dist/templates/app/api/v1/users/[id]/route.ts +0 -302
  125. package/dist/templates/app/api/v1/users/docs.md +0 -93
  126. package/dist/templates/app/api/v1/users/presets.ts +0 -59
  127. package/dist/templates/app/api/v1/users/route.ts +0 -197
  128. package/dist/templates/app/dashboard/(main)/[entity]/[id]/edit/page.tsx +0 -117
  129. package/dist/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +0 -103
  130. package/dist/templates/app/dashboard/(main)/[entity]/create/page.tsx +0 -95
  131. package/dist/templates/app/dashboard/(main)/[entity]/error.tsx +0 -51
  132. package/dist/templates/app/dashboard/(main)/[entity]/layout.tsx +0 -113
  133. package/dist/templates/app/dashboard/(main)/[entity]/loading.tsx +0 -61
  134. package/dist/templates/app/dashboard/(main)/[entity]/page.tsx +0 -90
  135. package/dist/templates/app/dashboard/(main)/layout.tsx +0 -98
  136. package/dist/templates/app/dashboard/(main)/loading.tsx +0 -5
  137. package/dist/templates/app/dashboard/(main)/page.tsx +0 -201
  138. package/dist/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +0 -114
  139. package/dist/templates/app/dashboard/(main)/patterns/[id]/page.tsx +0 -20
  140. package/dist/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +0 -171
  141. package/dist/templates/app/dashboard/(main)/patterns/create/page.tsx +0 -86
  142. package/dist/templates/app/dashboard/(main)/patterns/page.tsx +0 -444
  143. package/dist/templates/app/dashboard/features/analytics/page.tsx +0 -35
  144. package/dist/templates/app/dashboard/features/automation/page.tsx +0 -35
  145. package/dist/templates/app/dashboard/features/layout.tsx +0 -13
  146. package/dist/templates/app/dashboard/features/loading.tsx +0 -5
  147. package/dist/templates/app/dashboard/features/webhooks/page.tsx +0 -35
  148. package/dist/templates/app/dashboard/layout.tsx +0 -86
  149. package/dist/templates/app/dashboard/permission-denied/page.tsx +0 -29
  150. package/dist/templates/app/dashboard/settings/api-keys/loading.tsx +0 -5
  151. package/dist/templates/app/dashboard/settings/api-keys/page.tsx +0 -513
  152. package/dist/templates/app/dashboard/settings/billing/loading.tsx +0 -5
  153. package/dist/templates/app/dashboard/settings/billing/page.tsx +0 -284
  154. package/dist/templates/app/dashboard/settings/invoices/[invoiceNumber]/page.tsx +0 -222
  155. package/dist/templates/app/dashboard/settings/invoices/loading.tsx +0 -5
  156. package/dist/templates/app/dashboard/settings/invoices/page.tsx +0 -82
  157. package/dist/templates/app/dashboard/settings/layout.tsx +0 -151
  158. package/dist/templates/app/dashboard/settings/loading.tsx +0 -5
  159. package/dist/templates/app/dashboard/settings/notifications/loading.tsx +0 -5
  160. package/dist/templates/app/dashboard/settings/notifications/page.tsx +0 -462
  161. package/dist/templates/app/dashboard/settings/page.tsx +0 -92
  162. package/dist/templates/app/dashboard/settings/password/loading.tsx +0 -5
  163. package/dist/templates/app/dashboard/settings/password/page.tsx +0 -306
  164. package/dist/templates/app/dashboard/settings/plans/loading.tsx +0 -5
  165. package/dist/templates/app/dashboard/settings/plans/page.tsx +0 -40
  166. package/dist/templates/app/dashboard/settings/profile/loading.tsx +0 -5
  167. package/dist/templates/app/dashboard/settings/profile/page.tsx +0 -686
  168. package/dist/templates/app/dashboard/settings/security/loading.tsx +0 -5
  169. package/dist/templates/app/dashboard/settings/security/page.tsx +0 -505
  170. package/dist/templates/app/dashboard/settings/teams/loading.tsx +0 -5
  171. package/dist/templates/app/dashboard/settings/teams/page.tsx +0 -272
  172. package/dist/templates/app/dashboard/settings/teams/permissions/page.tsx +0 -92
  173. package/dist/templates/app/devtools/blocks/[slug]/page.tsx +0 -39
  174. package/dist/templates/app/devtools/blocks/page.tsx +0 -31
  175. package/dist/templates/app/devtools/config/page.tsx +0 -31
  176. package/dist/templates/app/devtools/features/page.tsx +0 -31
  177. package/dist/templates/app/devtools/flows/page.tsx +0 -31
  178. package/dist/templates/app/devtools/layout.tsx +0 -58
  179. package/dist/templates/app/devtools/page.tsx +0 -121
  180. package/dist/templates/app/devtools/scheduled-actions/page.tsx +0 -157
  181. package/dist/templates/app/devtools/style/page.tsx +0 -330
  182. package/dist/templates/app/devtools/tags/page.tsx +0 -31
  183. package/dist/templates/app/devtools/tests/[[...path]]/page.tsx +0 -47
  184. package/dist/templates/app/favicon.ico +0 -0
  185. package/dist/templates/app/globals.css +0 -12
  186. package/dist/templates/app/layout.tsx +0 -96
  187. package/dist/templates/app/public/page.tsx +0 -30
  188. package/dist/templates/app/superadmin/docs/[section]/[page]/page.tsx +0 -92
  189. package/dist/templates/app/superadmin/docs/page.tsx +0 -75
  190. package/dist/templates/app/superadmin/layout.tsx +0 -67
  191. package/dist/templates/app/superadmin/page.tsx +0 -149
  192. package/dist/templates/app/superadmin/subscriptions/page.tsx +0 -655
  193. package/dist/templates/app/superadmin/team-roles/page.tsx +0 -493
  194. package/dist/templates/app/superadmin/teams/[teamId]/page.tsx +0 -687
  195. package/dist/templates/app/superadmin/teams/page.tsx +0 -302
  196. package/dist/templates/app/superadmin/users/[userId]/page.tsx +0 -548
  197. package/dist/templates/app/superadmin/users/page.tsx +0 -528
  198. package/templates/app/(auth)/forgot-password/page.tsx +0 -216
  199. package/templates/app/(auth)/layout.tsx +0 -51
  200. package/templates/app/(auth)/login/page.tsx +0 -21
  201. package/templates/app/(auth)/reset-password/page.tsx +0 -212
  202. package/templates/app/(auth)/signup/page.tsx +0 -21
  203. package/templates/app/(auth)/verify-email/page.tsx +0 -190
  204. package/templates/app/(public)/[...slug]/page.tsx +0 -378
  205. package/templates/app/(public)/docs/[section]/[page]/page.tsx +0 -90
  206. package/templates/app/(public)/docs/layout.tsx +0 -25
  207. package/templates/app/(public)/docs/page.tsx +0 -81
  208. package/templates/app/(public)/layout.tsx +0 -41
  209. package/templates/app/(public)/page.tsx +0 -19
  210. package/templates/app/403/page.tsx +0 -89
  211. package/templates/app/api/auth/[...all]/route.ts +0 -78
  212. package/templates/app/api/cron/billing/lifecycle/route.ts +0 -98
  213. package/templates/app/api/csp-report/route.ts +0 -175
  214. package/templates/app/api/devtools/config/entities/route.ts +0 -108
  215. package/templates/app/api/devtools/config/theme/route.ts +0 -66
  216. package/templates/app/api/devtools/tests/[...path]/route.ts +0 -130
  217. package/templates/app/api/devtools/tests/route.ts +0 -134
  218. package/templates/app/api/health/route.ts +0 -29
  219. package/templates/app/api/internal/user-metadata/route.ts +0 -36
  220. package/templates/app/api/superadmin/subscriptions/route.ts +0 -310
  221. package/templates/app/api/superadmin/teams/[teamId]/route.ts +0 -286
  222. package/templates/app/api/superadmin/teams/route.ts +0 -188
  223. package/templates/app/api/superadmin/users/[userId]/route.ts +0 -540
  224. package/templates/app/api/superadmin/users/route.ts +0 -323
  225. package/templates/app/api/user/delete-account/route.ts +0 -55
  226. package/templates/app/api/user/plan-flags/route.ts +0 -283
  227. package/templates/app/api/user/profile/route.ts +0 -133
  228. package/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +0 -210
  229. package/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +0 -331
  230. package/templates/app/api/v1/[entity]/[id]/route.ts +0 -35
  231. package/templates/app/api/v1/[entity]/docs.md +0 -369
  232. package/templates/app/api/v1/[entity]/presets.ts +0 -194
  233. package/templates/app/api/v1/[entity]/route.ts +0 -31
  234. package/templates/app/api/v1/api-keys/[id]/route.ts +0 -303
  235. package/templates/app/api/v1/api-keys/docs.md +0 -101
  236. package/templates/app/api/v1/api-keys/presets.ts +0 -31
  237. package/templates/app/api/v1/api-keys/route.ts +0 -250
  238. package/templates/app/api/v1/auth/docs.md +0 -184
  239. package/templates/app/api/v1/auth/presets.ts +0 -44
  240. package/templates/app/api/v1/auth/signup-with-invite/route.ts +0 -227
  241. package/templates/app/api/v1/billing/cancel/route.ts +0 -206
  242. package/templates/app/api/v1/billing/change-plan/route.ts +0 -97
  243. package/templates/app/api/v1/billing/check-action/route.ts +0 -81
  244. package/templates/app/api/v1/billing/checkout/route.ts +0 -124
  245. package/templates/app/api/v1/billing/docs.md +0 -209
  246. package/templates/app/api/v1/billing/plans/route.ts +0 -85
  247. package/templates/app/api/v1/billing/portal/route.ts +0 -90
  248. package/templates/app/api/v1/billing/presets.ts +0 -121
  249. package/templates/app/api/v1/billing/webhooks/stripe/route.ts +0 -428
  250. package/templates/app/api/v1/blocks/[slug]/route.ts +0 -29
  251. package/templates/app/api/v1/blocks/docs.md +0 -173
  252. package/templates/app/api/v1/blocks/presets.ts +0 -121
  253. package/templates/app/api/v1/blocks/route.ts +0 -45
  254. package/templates/app/api/v1/blocks/validate/route.ts +0 -45
  255. package/templates/app/api/v1/cron/docs.md +0 -116
  256. package/templates/app/api/v1/cron/presets.ts +0 -26
  257. package/templates/app/api/v1/cron/process/route.ts +0 -108
  258. package/templates/app/api/v1/devtools/blocks/route.ts +0 -82
  259. package/templates/app/api/v1/devtools/docs/route.ts +0 -150
  260. package/templates/app/api/v1/devtools/docs.md +0 -204
  261. package/templates/app/api/v1/devtools/features/route.ts +0 -61
  262. package/templates/app/api/v1/devtools/flows/route.ts +0 -61
  263. package/templates/app/api/v1/devtools/presets.ts +0 -113
  264. package/templates/app/api/v1/devtools/scheduled-actions/route.ts +0 -120
  265. package/templates/app/api/v1/devtools/testing/route.ts +0 -82
  266. package/templates/app/api/v1/media/docs.md +0 -117
  267. package/templates/app/api/v1/media/presets.ts +0 -24
  268. package/templates/app/api/v1/media/upload/route.ts +0 -150
  269. package/templates/app/api/v1/patterns/[id]/usages/route.ts +0 -116
  270. package/templates/app/api/v1/plugin/[...path]/route.ts +0 -373
  271. package/templates/app/api/v1/plugin/docs.md +0 -79
  272. package/templates/app/api/v1/plugin/presets.ts +0 -21
  273. package/templates/app/api/v1/plugin/route.ts +0 -96
  274. package/templates/app/api/v1/post-categories/[id]/route.ts +0 -255
  275. package/templates/app/api/v1/post-categories/docs.md +0 -134
  276. package/templates/app/api/v1/post-categories/presets.ts +0 -78
  277. package/templates/app/api/v1/post-categories/route.ts +0 -119
  278. package/templates/app/api/v1/team-invitations/[token]/accept/route.ts +0 -179
  279. package/templates/app/api/v1/team-invitations/[token]/decline/route.ts +0 -120
  280. package/templates/app/api/v1/team-invitations/[token]/route.ts +0 -89
  281. package/templates/app/api/v1/team-invitations/docs.md +0 -88
  282. package/templates/app/api/v1/team-invitations/presets.ts +0 -43
  283. package/templates/app/api/v1/team-invitations/route.ts +0 -114
  284. package/templates/app/api/v1/teams/[teamId]/invitations/route.ts +0 -171
  285. package/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +0 -105
  286. package/templates/app/api/v1/teams/[teamId]/invoices/route.ts +0 -125
  287. package/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +0 -263
  288. package/templates/app/api/v1/teams/[teamId]/members/route.ts +0 -358
  289. package/templates/app/api/v1/teams/[teamId]/route.ts +0 -322
  290. package/templates/app/api/v1/teams/[teamId]/subscription/route.ts +0 -50
  291. package/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +0 -91
  292. package/templates/app/api/v1/teams/docs.md +0 -320
  293. package/templates/app/api/v1/teams/presets.ts +0 -178
  294. package/templates/app/api/v1/teams/route.ts +0 -293
  295. package/templates/app/api/v1/teams/switch/route.ts +0 -88
  296. package/templates/app/api/v1/theme/[...path]/route.ts +0 -361
  297. package/templates/app/api/v1/theme/docs.md +0 -74
  298. package/templates/app/api/v1/theme/presets.ts +0 -21
  299. package/templates/app/api/v1/theme/route.ts +0 -96
  300. package/templates/app/api/v1/users/[id]/meta/[key]/route.ts +0 -363
  301. package/templates/app/api/v1/users/[id]/route.ts +0 -302
  302. package/templates/app/api/v1/users/docs.md +0 -93
  303. package/templates/app/api/v1/users/presets.ts +0 -59
  304. package/templates/app/api/v1/users/route.ts +0 -197
  305. package/templates/app/dashboard/(main)/[entity]/[id]/edit/page.tsx +0 -117
  306. package/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +0 -103
  307. package/templates/app/dashboard/(main)/[entity]/create/page.tsx +0 -95
  308. package/templates/app/dashboard/(main)/[entity]/error.tsx +0 -51
  309. package/templates/app/dashboard/(main)/[entity]/layout.tsx +0 -113
  310. package/templates/app/dashboard/(main)/[entity]/loading.tsx +0 -61
  311. package/templates/app/dashboard/(main)/[entity]/page.tsx +0 -90
  312. package/templates/app/dashboard/(main)/layout.tsx +0 -98
  313. package/templates/app/dashboard/(main)/loading.tsx +0 -5
  314. package/templates/app/dashboard/(main)/page.tsx +0 -201
  315. package/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +0 -114
  316. package/templates/app/dashboard/(main)/patterns/[id]/page.tsx +0 -20
  317. package/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +0 -171
  318. package/templates/app/dashboard/(main)/patterns/create/page.tsx +0 -86
  319. package/templates/app/dashboard/(main)/patterns/page.tsx +0 -444
  320. package/templates/app/dashboard/features/analytics/page.tsx +0 -35
  321. package/templates/app/dashboard/features/automation/page.tsx +0 -35
  322. package/templates/app/dashboard/features/layout.tsx +0 -13
  323. package/templates/app/dashboard/features/loading.tsx +0 -5
  324. package/templates/app/dashboard/features/webhooks/page.tsx +0 -35
  325. package/templates/app/dashboard/layout.tsx +0 -86
  326. package/templates/app/dashboard/permission-denied/page.tsx +0 -29
  327. package/templates/app/dashboard/settings/api-keys/loading.tsx +0 -5
  328. package/templates/app/dashboard/settings/api-keys/page.tsx +0 -513
  329. package/templates/app/dashboard/settings/billing/loading.tsx +0 -5
  330. package/templates/app/dashboard/settings/billing/page.tsx +0 -284
  331. package/templates/app/dashboard/settings/invoices/[invoiceNumber]/page.tsx +0 -222
  332. package/templates/app/dashboard/settings/invoices/loading.tsx +0 -5
  333. package/templates/app/dashboard/settings/invoices/page.tsx +0 -82
  334. package/templates/app/dashboard/settings/layout.tsx +0 -151
  335. package/templates/app/dashboard/settings/loading.tsx +0 -5
  336. package/templates/app/dashboard/settings/notifications/loading.tsx +0 -5
  337. package/templates/app/dashboard/settings/notifications/page.tsx +0 -462
  338. package/templates/app/dashboard/settings/page.tsx +0 -92
  339. package/templates/app/dashboard/settings/password/loading.tsx +0 -5
  340. package/templates/app/dashboard/settings/password/page.tsx +0 -306
  341. package/templates/app/dashboard/settings/plans/loading.tsx +0 -5
  342. package/templates/app/dashboard/settings/plans/page.tsx +0 -40
  343. package/templates/app/dashboard/settings/profile/loading.tsx +0 -5
  344. package/templates/app/dashboard/settings/profile/page.tsx +0 -686
  345. package/templates/app/dashboard/settings/security/loading.tsx +0 -5
  346. package/templates/app/dashboard/settings/security/page.tsx +0 -505
  347. package/templates/app/dashboard/settings/teams/loading.tsx +0 -5
  348. package/templates/app/dashboard/settings/teams/page.tsx +0 -272
  349. package/templates/app/dashboard/settings/teams/permissions/page.tsx +0 -92
  350. package/templates/app/devtools/blocks/[slug]/page.tsx +0 -39
  351. package/templates/app/devtools/blocks/page.tsx +0 -31
  352. package/templates/app/devtools/config/page.tsx +0 -31
  353. package/templates/app/devtools/features/page.tsx +0 -31
  354. package/templates/app/devtools/flows/page.tsx +0 -31
  355. package/templates/app/devtools/layout.tsx +0 -58
  356. package/templates/app/devtools/page.tsx +0 -121
  357. package/templates/app/devtools/scheduled-actions/page.tsx +0 -157
  358. package/templates/app/devtools/style/page.tsx +0 -330
  359. package/templates/app/devtools/tags/page.tsx +0 -31
  360. package/templates/app/devtools/tests/[[...path]]/page.tsx +0 -47
  361. package/templates/app/favicon.ico +0 -0
  362. package/templates/app/globals.css +0 -12
  363. package/templates/app/layout.tsx +0 -96
  364. package/templates/app/public/page.tsx +0 -30
  365. package/templates/app/superadmin/docs/[section]/[page]/page.tsx +0 -92
  366. package/templates/app/superadmin/docs/page.tsx +0 -75
  367. package/templates/app/superadmin/layout.tsx +0 -67
  368. package/templates/app/superadmin/page.tsx +0 -149
  369. package/templates/app/superadmin/subscriptions/page.tsx +0 -655
  370. package/templates/app/superadmin/team-roles/page.tsx +0 -493
  371. package/templates/app/superadmin/teams/[teamId]/page.tsx +0 -687
  372. package/templates/app/superadmin/teams/page.tsx +0 -302
  373. package/templates/app/superadmin/users/[userId]/page.tsx +0 -548
  374. package/templates/app/superadmin/users/page.tsx +0 -528
@@ -1,323 +0,0 @@
1
- import { NextRequest, NextResponse } from 'next/server';
2
- import { auth } from '@nextsparkjs/core/lib/auth';
3
- import { queryWithRLS } from '@nextsparkjs/core/lib/db';
4
- import type { User } from '@nextsparkjs/core/types/user.types';
5
-
6
- /**
7
- * GET /api/superadmin/users
8
- *
9
- * Retrieves users with pagination, search, and filters.
10
- * Only accessible by superadmin or developer users.
11
- *
12
- * Query params:
13
- * - search: Filter by name or email
14
- * - role: Filter by role (member, superadmin, etc.)
15
- * - status: Filter by email verification status (verified, unverified)
16
- * - tab: Which tab to paginate (users, superadmins, all)
17
- * - page: Page number (default: 1)
18
- * - limit: Items per page (default: 20)
19
- *
20
- * Returns:
21
- * - regularUsers: Array of users excluding superadmins
22
- * - superadmins: Array of superadmin users
23
- * - counts: Object with user counts
24
- * - pagination: Pagination info for the active tab
25
- */
26
- export async function GET(request: NextRequest) {
27
- try {
28
- // Get the current session using Better Auth
29
- const session = await auth.api.getSession({
30
- headers: request.headers
31
- });
32
-
33
- // Check if user is authenticated
34
- if (!session?.user) {
35
- return NextResponse.json(
36
- { error: 'Unauthorized - No session found' },
37
- { status: 401 }
38
- );
39
- }
40
-
41
- // Check if user is superadmin or developer
42
- if (session.user.role !== 'superadmin' && session.user.role !== 'developer') {
43
- return NextResponse.json(
44
- { error: 'Forbidden - Superadmin or developer access required' },
45
- { status: 403 }
46
- );
47
- }
48
-
49
- // Parse query params
50
- const searchParams = request.nextUrl.searchParams;
51
- const search = searchParams.get('search') || '';
52
- const roleFilter = searchParams.get('role') || '';
53
- const statusFilter = searchParams.get('status') || '';
54
- const tab = searchParams.get('tab') || 'users'; // users, superadmins, all
55
- const page = Math.max(1, parseInt(searchParams.get('page') || '1'));
56
- const limit = Math.min(100, Math.max(1, parseInt(searchParams.get('limit') || '20')));
57
- const offset = (page - 1) * limit;
58
-
59
- // Build WHERE conditions
60
- const buildWhereClause = (isSuperadmin: boolean) => {
61
- const conditions: string[] = [];
62
- const params: (string | boolean)[] = [];
63
- let paramIndex = 1;
64
-
65
- // Role filter for regular users vs superadmins
66
- if (isSuperadmin) {
67
- conditions.push(`role = $${paramIndex}`);
68
- params.push('superadmin');
69
- paramIndex++;
70
- } else {
71
- conditions.push(`role != $${paramIndex}`);
72
- params.push('superadmin');
73
- paramIndex++;
74
-
75
- // Additional role filter for regular users
76
- if (roleFilter && roleFilter !== 'superadmin') {
77
- conditions.push(`role = $${paramIndex}`);
78
- params.push(roleFilter);
79
- paramIndex++;
80
- }
81
- }
82
-
83
- // Search filter
84
- if (search) {
85
- conditions.push(`(
86
- "firstName" ILIKE $${paramIndex} OR
87
- "lastName" ILIKE $${paramIndex} OR
88
- email ILIKE $${paramIndex} OR
89
- CONCAT("firstName", ' ', "lastName") ILIKE $${paramIndex}
90
- )`);
91
- params.push(`%${search}%`);
92
- paramIndex++;
93
- }
94
-
95
- // Status filter
96
- if (statusFilter === 'verified') {
97
- conditions.push(`"emailVerified" = $${paramIndex}`);
98
- params.push(true);
99
- paramIndex++;
100
- } else if (statusFilter === 'unverified') {
101
- conditions.push(`("emailVerified" = $${paramIndex} OR "emailVerified" IS NULL)`);
102
- params.push(false);
103
- paramIndex++;
104
- }
105
-
106
- return {
107
- whereClause: conditions.length > 0 ? `WHERE ${conditions.join(' AND ')}` : '',
108
- params
109
- };
110
- };
111
-
112
- // Build queries for regular users
113
- const regularWhere = buildWhereClause(false);
114
- const regularUsersQuery = `
115
- SELECT
116
- id,
117
- "firstName",
118
- "lastName",
119
- email,
120
- role,
121
- "emailVerified",
122
- "createdAt",
123
- "updatedAt"
124
- FROM "users"
125
- ${regularWhere.whereClause}
126
- ORDER BY "createdAt" DESC
127
- ${tab === 'users' ? `LIMIT ${limit} OFFSET ${offset}` : ''}
128
- `;
129
-
130
- const regularCountQuery = `
131
- SELECT COUNT(*)::int as total
132
- FROM "users"
133
- ${regularWhere.whereClause}
134
- `;
135
-
136
- // Build queries for superadmins
137
- const superadminWhere = buildWhereClause(true);
138
- const superadminsQuery = `
139
- SELECT
140
- id,
141
- "firstName",
142
- "lastName",
143
- email,
144
- role,
145
- "emailVerified",
146
- "createdAt",
147
- "updatedAt"
148
- FROM "users"
149
- ${superadminWhere.whereClause}
150
- ORDER BY "createdAt" DESC
151
- ${tab === 'superadmins' ? `LIMIT ${limit} OFFSET ${offset}` : ''}
152
- `;
153
-
154
- const superadminCountQuery = `
155
- SELECT COUNT(*)::int as total
156
- FROM "users"
157
- ${superadminWhere.whereClause}
158
- `;
159
-
160
- // Query for status distribution (all users)
161
- const statusDistributionQuery = `
162
- SELECT
163
- CASE WHEN "emailVerified" = true THEN 'verified' ELSE 'unverified' END as status,
164
- COUNT(*)::int as count
165
- FROM "users"
166
- GROUP BY "emailVerified"
167
- `;
168
-
169
- // Query for team role distribution
170
- const teamRoleDistributionQuery = `
171
- SELECT
172
- role,
173
- COUNT(*)::int as count
174
- FROM "team_members"
175
- GROUP BY role
176
- `;
177
-
178
- // Query for teams count
179
- const teamsCountQuery = `
180
- SELECT COUNT(*)::int as total
181
- FROM "teams"
182
- `;
183
-
184
- // Execute all queries in parallel
185
- const [
186
- regularUsers,
187
- regularCount,
188
- superadmins,
189
- superadminCount,
190
- statusDistribution,
191
- teamRoleDistribution,
192
- teamsCount
193
- ] = await Promise.all([
194
- queryWithRLS(regularUsersQuery, regularWhere.params, session.user.id) as Promise<User[]>,
195
- queryWithRLS(regularCountQuery, regularWhere.params, session.user.id) as Promise<{ total: number }[]>,
196
- queryWithRLS(superadminsQuery, superadminWhere.params, session.user.id) as Promise<User[]>,
197
- queryWithRLS(superadminCountQuery, superadminWhere.params, session.user.id) as Promise<{ total: number }[]>,
198
- queryWithRLS(statusDistributionQuery, [], session.user.id) as Promise<{ status: string; count: number }[]>,
199
- queryWithRLS(teamRoleDistributionQuery, [], session.user.id) as Promise<{ role: string; count: number }[]>,
200
- queryWithRLS(teamsCountQuery, [], session.user.id) as Promise<{ total: number }[]>
201
- ]);
202
-
203
- const regularTotal = regularCount[0]?.total || 0;
204
- const superadminTotal = superadminCount[0]?.total || 0;
205
-
206
- // Calculate counts by role
207
- const roleCounts = regularUsers.reduce((acc: Record<string, number>, user: User) => {
208
- acc[user.role] = (acc[user.role] || 0) + 1;
209
- return acc;
210
- }, {});
211
-
212
- // Build status distribution object
213
- const statusDist: Record<string, number> = { verified: 0, unverified: 0 };
214
- statusDistribution.forEach(({ status, count }) => {
215
- statusDist[status] = count;
216
- });
217
-
218
- // Build team role distribution object
219
- const teamRoleDist: Record<string, number> = { owner: 0, admin: 0, member: 0, viewer: 0 };
220
- teamRoleDistribution.forEach(({ role, count }) => {
221
- teamRoleDist[role] = count;
222
- });
223
-
224
- // Determine pagination based on active tab
225
- let paginationTotal = 0;
226
- if (tab === 'users') {
227
- paginationTotal = regularTotal;
228
- } else if (tab === 'superadmins') {
229
- paginationTotal = superadminTotal;
230
- } else {
231
- paginationTotal = regularTotal + superadminTotal;
232
- }
233
- const totalPages = Math.ceil(paginationTotal / limit);
234
-
235
- // Format user data
236
- const formatUser = (user: User) => ({
237
- id: user.id,
238
- firstName: user.firstName || '',
239
- lastName: user.lastName || '',
240
- email: user.email,
241
- role: user.role,
242
- emailVerified: user.emailVerified,
243
- createdAt: user.createdAt,
244
- updatedAt: user.updatedAt,
245
- fullName: [user.firstName, user.lastName].filter(Boolean).join(' ') || user.email
246
- });
247
-
248
- // Prepare response data
249
- const responseData = {
250
- regularUsers: regularUsers.map(formatUser),
251
- superadmins: superadmins.map(formatUser),
252
- counts: {
253
- total: regularTotal + superadminTotal,
254
- regularUsers: regularTotal,
255
- superadmins: superadminTotal,
256
- teams: teamsCount[0]?.total || 0,
257
- byRole: {
258
- ...roleCounts,
259
- superadmin: superadminTotal
260
- },
261
- statusDistribution: statusDist,
262
- teamRoleDistribution: teamRoleDist
263
- },
264
- pagination: {
265
- page,
266
- limit,
267
- total: paginationTotal,
268
- totalPages,
269
- hasMore: page < totalPages
270
- },
271
- filters: {
272
- search,
273
- role: roleFilter,
274
- status: statusFilter,
275
- tab
276
- },
277
- metadata: {
278
- requestedBy: session.user.id,
279
- requestedAt: new Date().toISOString(),
280
- source: 'superadmin-api'
281
- }
282
- };
283
-
284
- return NextResponse.json(responseData);
285
-
286
- } catch (error) {
287
- console.error('Error fetching users data:', error);
288
-
289
- return NextResponse.json(
290
- {
291
- error: 'Internal server error',
292
- message: 'Failed to retrieve users data'
293
- },
294
- { status: 500 }
295
- );
296
- }
297
- }
298
-
299
- /**
300
- * POST /api/superadmin/users
301
- *
302
- * Future endpoint for user management actions (create, update roles, etc.)
303
- * Currently returns not implemented.
304
- */
305
- export async function POST() {
306
- return NextResponse.json(
307
- { error: 'Not implemented yet' },
308
- { status: 501 }
309
- );
310
- }
311
-
312
- /**
313
- * PUT /api/superadmin/users
314
- *
315
- * Future endpoint for bulk user operations
316
- * Currently returns not implemented.
317
- */
318
- export async function PUT() {
319
- return NextResponse.json(
320
- { error: 'Not implemented yet' },
321
- { status: 501 }
322
- );
323
- }
@@ -1,55 +0,0 @@
1
- import { NextRequest, NextResponse } from "next/server";
2
- import { auth } from "@nextsparkjs/core/lib/auth";
3
- import { mutateWithRLS } from "@nextsparkjs/core/lib/db";
4
-
5
- export async function DELETE(req: NextRequest) {
6
- try {
7
- // Get session from Better Auth
8
- const session = await auth.api.getSession({
9
- headers: req.headers,
10
- });
11
-
12
- if (!session?.user) {
13
- return NextResponse.json({ error: "Unauthorized" }, { status: 401 });
14
- }
15
-
16
- const userId = session.user.id;
17
-
18
- try {
19
- // Sign out the user first (while the user still exists)
20
- try {
21
- await auth.api.signOut({
22
- headers: req.headers,
23
- });
24
- } catch (signOutError) {
25
- console.warn("Sign out failed (user may already be signed out):", signOutError);
26
- }
27
-
28
- // Delete user account and all associated data
29
- // RLS policies will ensure only the user's own data is deleted
30
- await mutateWithRLS(
31
- 'DELETE FROM "users" WHERE id = $1',
32
- [userId],
33
- userId
34
- );
35
-
36
- return NextResponse.json({
37
- message: "Account deleted successfully"
38
- });
39
-
40
- } catch (dbError) {
41
- console.error("Failed to delete user account:", dbError);
42
- return NextResponse.json(
43
- { error: "Failed to delete account" },
44
- { status: 500 }
45
- );
46
- }
47
-
48
- } catch (error) {
49
- console.error("Delete account error:", error);
50
- return NextResponse.json(
51
- { error: "Internal server error" },
52
- { status: 500 }
53
- );
54
- }
55
- }
@@ -1,283 +0,0 @@
1
- /**
2
- * User Plan & Flags API Route
3
- *
4
- * Handles fetching and updating user plan and flags data
5
- * for the entity system permission integration.
6
- */
7
-
8
- import { NextRequest, NextResponse } from 'next/server'
9
- import { auth } from '@nextsparkjs/core/lib/auth'
10
- import { getUserPlanAndFlags, updateUserPlan, updateUserFlags } from '@nextsparkjs/core/lib/user-data'
11
- import { z } from 'zod'
12
- import type { UserRole } from '@nextsparkjs/core/types/user.types'
13
-
14
- // Validation schemas
15
- const planFlagsQuerySchema = z.object({
16
- userId: z.string().optional()
17
- })
18
-
19
- const planFlagsUpdateSchema = z.object({
20
- userId: z.string(),
21
- plan: z.enum(['free', 'starter', 'premium']).optional(),
22
- flags: z.array(z.enum(['beta_tester', 'early_adopter', 'limited_access', 'vip', 'restricted', 'experimental'])).optional()
23
- })
24
-
25
- /**
26
- * GET /api/user/plan-flags
27
- * Fetch user plan and flags data
28
- */
29
- export async function GET(request: NextRequest) {
30
- try {
31
- // Get session
32
- const session = await auth.api.getSession({
33
- headers: request.headers,
34
- })
35
-
36
- if (!session) {
37
- return NextResponse.json(
38
- { error: 'Authentication required' },
39
- { status: 401 }
40
- )
41
- }
42
-
43
- const { searchParams } = new URL(request.url)
44
- const validation = planFlagsQuerySchema.safeParse({
45
- userId: searchParams.get('userId')
46
- })
47
-
48
- if (!validation.success) {
49
- return NextResponse.json(
50
- {
51
- error: 'Invalid parameters',
52
- details: validation.error.flatten().fieldErrors
53
- },
54
- { status: 400 }
55
- )
56
- }
57
-
58
- const { userId } = validation.data
59
- const targetUserId = userId || session.user.id
60
-
61
- // Security check: users can only access their own data unless admin
62
- const userRole = session.user.role as UserRole
63
- if (targetUserId !== session.user.id && !['admin', 'superadmin'].includes(userRole)) {
64
- return NextResponse.json(
65
- { error: 'Permission denied' },
66
- { status: 403 }
67
- )
68
- }
69
-
70
- // Get user plan and flags
71
- const planData = await getUserPlanAndFlags(targetUserId)
72
-
73
- return NextResponse.json({
74
- userId: targetUserId,
75
- plan: planData.plan,
76
- flags: planData.flags,
77
- cached: planData.cached
78
- })
79
-
80
- } catch (error) {
81
- console.error('GET user plan-flags error:', error)
82
- return NextResponse.json(
83
- { error: 'Internal server error' },
84
- { status: 500 }
85
- )
86
- }
87
- }
88
-
89
- /**
90
- * PATCH /api/user/plan-flags
91
- * Update user plan and/or flags
92
- */
93
- export async function PATCH(request: NextRequest) {
94
- try {
95
- // Get session
96
- const session = await auth.api.getSession({
97
- headers: request.headers,
98
- })
99
-
100
- if (!session) {
101
- return NextResponse.json(
102
- { error: 'Authentication required' },
103
- { status: 401 }
104
- )
105
- }
106
-
107
- const body = await request.json()
108
- const validation = planFlagsUpdateSchema.safeParse(body)
109
-
110
- if (!validation.success) {
111
- return NextResponse.json(
112
- {
113
- error: 'Invalid request body',
114
- details: validation.error.flatten().fieldErrors
115
- },
116
- { status: 400 }
117
- )
118
- }
119
-
120
- const { userId, plan, flags } = validation.data
121
- const userRole = session.user.role as UserRole
122
-
123
- // Security check: users can only update their own data unless admin
124
- if (userId !== session.user.id && !['admin', 'superadmin'].includes(userRole)) {
125
- return NextResponse.json(
126
- { error: 'Permission denied' },
127
- { status: 403 }
128
- )
129
- }
130
-
131
- // Additional security: only admins can update other users' data
132
- if (userId !== session.user.id && !['admin', 'superadmin'].includes(userRole)) {
133
- return NextResponse.json(
134
- { error: 'Only admins can update other users data' },
135
- { status: 403 }
136
- )
137
- }
138
-
139
- const results: { plan?: boolean; flags?: boolean } = {}
140
-
141
- // Update plan if provided
142
- if (plan) {
143
- const planSuccess = await updateUserPlan(userId, plan)
144
- if (!planSuccess) {
145
- return NextResponse.json(
146
- { error: 'Failed to update user plan' },
147
- { status: 500 }
148
- )
149
- }
150
- results.plan = true
151
- }
152
-
153
- // Update flags if provided
154
- if (flags) {
155
- const flagsSuccess = await updateUserFlags(userId, flags)
156
- if (!flagsSuccess) {
157
- return NextResponse.json(
158
- { error: 'Failed to update user flags' },
159
- { status: 500 }
160
- )
161
- }
162
- results.flags = true
163
- }
164
-
165
- // Get updated data
166
- const updatedData = await getUserPlanAndFlags(userId)
167
-
168
- return NextResponse.json({
169
- success: true,
170
- updated: results,
171
- userId,
172
- plan: updatedData.plan,
173
- flags: updatedData.flags
174
- })
175
-
176
- } catch (error) {
177
- console.error('PATCH user plan-flags error:', error)
178
- return NextResponse.json(
179
- { error: 'Internal server error' },
180
- { status: 500 }
181
- )
182
- }
183
- }
184
-
185
- /**
186
- * POST /api/user/plan-flags/bulk
187
- * Bulk update user plans and flags (admin only)
188
- */
189
- export async function POST(request: NextRequest) {
190
- try {
191
- // Get session
192
- const session = await auth.api.getSession({
193
- headers: request.headers,
194
- })
195
-
196
- if (!session) {
197
- return NextResponse.json(
198
- { error: 'Authentication required' },
199
- { status: 401 }
200
- )
201
- }
202
-
203
- const userRole = session.user.role as UserRole
204
-
205
- // Only admins can perform bulk operations
206
- if (!['admin', 'superadmin'].includes(userRole)) {
207
- return NextResponse.json(
208
- { error: 'Admin access required for bulk operations' },
209
- { status: 403 }
210
- )
211
- }
212
-
213
- const body = await request.json()
214
- const bulkSchema = z.object({
215
- updates: z.array(z.object({
216
- userId: z.string(),
217
- plan: z.enum(['free', 'starter', 'premium']).optional(),
218
- flags: z.array(z.enum(['beta_tester', 'early_adopter', 'limited_access', 'vip', 'restricted', 'experimental'])).optional()
219
- })).max(100) // Limit bulk operations
220
- })
221
-
222
- const validation = bulkSchema.safeParse(body)
223
-
224
- if (!validation.success) {
225
- return NextResponse.json(
226
- {
227
- error: 'Invalid bulk request',
228
- details: validation.error.flatten().fieldErrors
229
- },
230
- { status: 400 }
231
- )
232
- }
233
-
234
- const { updates } = validation.data
235
- const results = []
236
-
237
- // Process each update
238
- for (const update of updates) {
239
- try {
240
- const updateResult: { userId: string; plan?: boolean; flags?: boolean } = {
241
- userId: update.userId
242
- }
243
-
244
- if (update.plan) {
245
- updateResult.plan = await updateUserPlan(update.userId, update.plan)
246
- }
247
-
248
- if (update.flags) {
249
- updateResult.flags = await updateUserFlags(update.userId, update.flags)
250
- }
251
-
252
- results.push({
253
- ...updateResult,
254
- success: true
255
- })
256
- } catch (error) {
257
- results.push({
258
- userId: update.userId,
259
- success: false,
260
- error: error instanceof Error ? error.message : 'Unknown error'
261
- })
262
- }
263
- }
264
-
265
- const successCount = results.filter(r => r.success).length
266
- const failureCount = results.length - successCount
267
-
268
- return NextResponse.json({
269
- success: failureCount === 0,
270
- processed: results.length,
271
- succeeded: successCount,
272
- failed: failureCount,
273
- results
274
- })
275
-
276
- } catch (error) {
277
- console.error('POST bulk user plan-flags error:', error)
278
- return NextResponse.json(
279
- { error: 'Internal server error' },
280
- { status: 500 }
281
- )
282
- }
283
- }