@btst/stack 2.4.0 → 2.5.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 (136) hide show
  1. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.cjs +33 -47
  2. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.mjs +33 -47
  3. package/dist/packages/stack/src/plugins/ai-chat/client/plugin.cjs +14 -21
  4. package/dist/packages/stack/src/plugins/ai-chat/client/plugin.mjs +15 -22
  5. package/dist/packages/stack/src/plugins/blog/api/plugin.cjs +28 -45
  6. package/dist/packages/stack/src/plugins/blog/api/plugin.mjs +22 -39
  7. package/dist/packages/stack/src/plugins/blog/client/plugin.cjs +23 -27
  8. package/dist/packages/stack/src/plugins/blog/client/plugin.mjs +24 -28
  9. package/dist/packages/stack/src/plugins/cms/api/plugin.cjs +14 -17
  10. package/dist/packages/stack/src/plugins/cms/api/plugin.mjs +14 -17
  11. package/dist/packages/stack/src/plugins/cms/client/plugin.cjs +11 -15
  12. package/dist/packages/stack/src/plugins/cms/client/plugin.mjs +12 -16
  13. package/dist/packages/stack/src/plugins/form-builder/api/plugin.cjs +58 -62
  14. package/dist/packages/stack/src/plugins/form-builder/api/plugin.mjs +58 -62
  15. package/dist/packages/stack/src/plugins/form-builder/client/plugin.cjs +12 -12
  16. package/dist/packages/stack/src/plugins/form-builder/client/plugin.mjs +13 -13
  17. package/dist/packages/stack/src/plugins/kanban/api/plugin.cjs +86 -117
  18. package/dist/packages/stack/src/plugins/kanban/api/plugin.mjs +83 -114
  19. package/dist/packages/stack/src/plugins/kanban/client/plugin.cjs +22 -29
  20. package/dist/packages/stack/src/plugins/kanban/client/plugin.mjs +23 -30
  21. package/dist/packages/stack/src/plugins/ui-builder/client/plugin.cjs +8 -8
  22. package/dist/packages/stack/src/plugins/ui-builder/client/plugin.mjs +9 -9
  23. package/dist/packages/stack/src/plugins/utils.cjs +42 -0
  24. package/dist/packages/stack/src/plugins/utils.mjs +41 -1
  25. package/dist/plugins/ai-chat/api/index.d.cts +1 -1
  26. package/dist/plugins/ai-chat/api/index.d.mts +1 -1
  27. package/dist/plugins/ai-chat/api/index.d.ts +1 -1
  28. package/dist/plugins/ai-chat/client/hooks/index.d.cts +1 -1
  29. package/dist/plugins/ai-chat/client/hooks/index.d.mts +1 -1
  30. package/dist/plugins/ai-chat/client/hooks/index.d.ts +1 -1
  31. package/dist/plugins/ai-chat/client/index.d.cts +8 -8
  32. package/dist/plugins/ai-chat/client/index.d.mts +8 -8
  33. package/dist/plugins/ai-chat/client/index.d.ts +8 -8
  34. package/dist/plugins/ai-chat/query-keys.d.cts +1 -1
  35. package/dist/plugins/ai-chat/query-keys.d.mts +1 -1
  36. package/dist/plugins/ai-chat/query-keys.d.ts +1 -1
  37. package/dist/plugins/blog/api/index.d.cts +1 -1
  38. package/dist/plugins/blog/api/index.d.mts +1 -1
  39. package/dist/plugins/blog/api/index.d.ts +1 -1
  40. package/dist/plugins/blog/client/index.d.cts +12 -12
  41. package/dist/plugins/blog/client/index.d.mts +12 -12
  42. package/dist/plugins/blog/client/index.d.ts +12 -12
  43. package/dist/plugins/blog/query-keys.d.cts +1 -1
  44. package/dist/plugins/blog/query-keys.d.mts +1 -1
  45. package/dist/plugins/blog/query-keys.d.ts +1 -1
  46. package/dist/plugins/client/index.cjs +1 -0
  47. package/dist/plugins/client/index.d.cts +8 -1
  48. package/dist/plugins/client/index.d.mts +8 -1
  49. package/dist/plugins/client/index.d.ts +8 -1
  50. package/dist/plugins/client/index.mjs +1 -1
  51. package/dist/plugins/cms/api/index.d.cts +2 -2
  52. package/dist/plugins/cms/api/index.d.mts +2 -2
  53. package/dist/plugins/cms/api/index.d.ts +2 -2
  54. package/dist/plugins/cms/client/hooks/index.d.cts +1 -1
  55. package/dist/plugins/cms/client/hooks/index.d.mts +1 -1
  56. package/dist/plugins/cms/client/hooks/index.d.ts +1 -1
  57. package/dist/plugins/cms/client/index.d.cts +6 -6
  58. package/dist/plugins/cms/client/index.d.mts +6 -6
  59. package/dist/plugins/cms/client/index.d.ts +6 -6
  60. package/dist/plugins/cms/query-keys.d.cts +2 -2
  61. package/dist/plugins/cms/query-keys.d.mts +2 -2
  62. package/dist/plugins/cms/query-keys.d.ts +2 -2
  63. package/dist/plugins/form-builder/api/index.d.cts +2 -2
  64. package/dist/plugins/form-builder/api/index.d.mts +2 -2
  65. package/dist/plugins/form-builder/api/index.d.ts +2 -2
  66. package/dist/plugins/form-builder/client/components/index.d.cts +1 -1
  67. package/dist/plugins/form-builder/client/components/index.d.mts +1 -1
  68. package/dist/plugins/form-builder/client/components/index.d.ts +1 -1
  69. package/dist/plugins/form-builder/client/hooks/index.d.cts +1 -1
  70. package/dist/plugins/form-builder/client/hooks/index.d.mts +1 -1
  71. package/dist/plugins/form-builder/client/hooks/index.d.ts +1 -1
  72. package/dist/plugins/form-builder/client/index.d.cts +6 -6
  73. package/dist/plugins/form-builder/client/index.d.mts +6 -6
  74. package/dist/plugins/form-builder/client/index.d.ts +6 -6
  75. package/dist/plugins/form-builder/query-keys.d.cts +2 -2
  76. package/dist/plugins/form-builder/query-keys.d.mts +2 -2
  77. package/dist/plugins/form-builder/query-keys.d.ts +2 -2
  78. package/dist/plugins/kanban/api/index.d.cts +1 -1
  79. package/dist/plugins/kanban/api/index.d.mts +1 -1
  80. package/dist/plugins/kanban/api/index.d.ts +1 -1
  81. package/dist/plugins/kanban/client/index.d.cts +12 -12
  82. package/dist/plugins/kanban/client/index.d.mts +12 -12
  83. package/dist/plugins/kanban/client/index.d.ts +12 -12
  84. package/dist/plugins/kanban/query-keys.d.cts +1 -1
  85. package/dist/plugins/kanban/query-keys.d.mts +1 -1
  86. package/dist/plugins/kanban/query-keys.d.ts +1 -1
  87. package/dist/plugins/ui-builder/client/hooks/index.d.cts +1 -1
  88. package/dist/plugins/ui-builder/client/hooks/index.d.mts +1 -1
  89. package/dist/plugins/ui-builder/client/hooks/index.d.ts +1 -1
  90. package/dist/plugins/ui-builder/client/index.d.cts +3 -3
  91. package/dist/plugins/ui-builder/client/index.d.mts +3 -3
  92. package/dist/plugins/ui-builder/client/index.d.ts +3 -3
  93. package/dist/plugins/ui-builder/index.d.cts +2 -2
  94. package/dist/plugins/ui-builder/index.d.mts +2 -2
  95. package/dist/plugins/ui-builder/index.d.ts +2 -2
  96. package/dist/shared/{stack.C-WUPMT6.d.cts → stack.B2xZTSiO.d.cts} +4 -4
  97. package/dist/shared/{stack.CczspVn2.d.mts → stack.B58oHdqm.d.mts} +1 -1
  98. package/dist/shared/{stack.CVDTkMoO.d.mts → stack.B8QD11QU.d.cts} +7 -7
  99. package/dist/shared/{stack.CVDTkMoO.d.cts → stack.B8QD11QU.d.mts} +7 -7
  100. package/dist/shared/{stack.CVDTkMoO.d.ts → stack.B8QD11QU.d.ts} +7 -7
  101. package/dist/shared/{stack.Kq2-QzOC.d.ts → stack.BDVEpue1.d.ts} +2 -2
  102. package/dist/shared/{stack.B7ONvlD_.d.mts → stack.BTvbxZvw.d.cts} +2 -2
  103. package/dist/shared/{stack.DdI5W6MB.d.mts → stack.BozPgbrZ.d.cts} +19 -19
  104. package/dist/shared/{stack.DdI5W6MB.d.cts → stack.BozPgbrZ.d.mts} +19 -19
  105. package/dist/shared/{stack.DdI5W6MB.d.ts → stack.BozPgbrZ.d.ts} +19 -19
  106. package/dist/shared/{stack.BUkC2EsZ.d.cts → stack.C9Mg2Q46.d.cts} +1 -1
  107. package/dist/shared/{stack.BEn34wW6.d.ts → stack.CTDVxbrA.d.ts} +12 -12
  108. package/dist/shared/{stack.C-Ptrz8s.d.ts → stack.Cj_zKww4.d.ts} +4 -4
  109. package/dist/shared/{stack.BepFXT3w.d.mts → stack.CxaFNQCV.d.mts} +25 -25
  110. package/dist/shared/{stack.DWoCZff7.d.cts → stack.D-b5zbPm.d.cts} +12 -12
  111. package/dist/shared/{stack.kcdnD4gA.d.cts → stack.DTtmJPQO.d.mts} +2 -2
  112. package/dist/shared/{stack.CL8ts1Mu.d.ts → stack.DXnclTG7.d.ts} +8 -8
  113. package/dist/shared/{stack.heOA9gzA.d.cts → stack.DaZM10cp.d.cts} +8 -8
  114. package/dist/shared/{stack.DTDxgFj8.d.mts → stack.FVWf2JhZ.d.mts} +12 -12
  115. package/dist/shared/{stack.Dk5r4W1F.d.mts → stack.cfCkioTe.d.mts} +8 -8
  116. package/dist/shared/{stack.6fUOjLs9.d.mts → stack.dH7u-TJH.d.mts} +4 -4
  117. package/dist/shared/{stack.CgWzG5jH.d.ts → stack.j75TpKh2.d.ts} +25 -25
  118. package/dist/shared/{stack.D3GB6wKv.d.cts → stack.n1_i1p2B.d.cts} +25 -25
  119. package/dist/shared/{stack.DASmUVjX.d.ts → stack.sO33ZDhK.d.ts} +1 -1
  120. package/package.json +1 -1
  121. package/src/plugins/ai-chat/api/plugin.ts +48 -63
  122. package/src/plugins/ai-chat/client/plugin.tsx +23 -31
  123. package/src/plugins/blog/api/plugin.ts +31 -47
  124. package/src/plugins/blog/client/plugin.tsx +36 -39
  125. package/src/plugins/client/index.ts +5 -1
  126. package/src/plugins/cms/api/plugin.ts +14 -17
  127. package/src/plugins/cms/client/plugin.tsx +18 -21
  128. package/src/plugins/cms/types.ts +7 -7
  129. package/src/plugins/form-builder/api/plugin.ts +64 -64
  130. package/src/plugins/form-builder/client/plugin.tsx +19 -18
  131. package/src/plugins/form-builder/types.ts +19 -24
  132. package/src/plugins/kanban/api/plugin.ts +111 -136
  133. package/src/plugins/kanban/client/plugin.tsx +35 -41
  134. package/src/plugins/ui-builder/client/plugin.tsx +11 -10
  135. package/src/plugins/ui-builder/types.ts +4 -4
  136. package/src/plugins/utils.ts +92 -1
@@ -7,12 +7,12 @@ import { QueryClient } from '@tanstack/react-query';
7
7
 
8
8
  declare const createBoardSchema: z.ZodObject<{
9
9
  description: z.ZodOptional<z.ZodString>;
10
+ name: z.ZodString;
10
11
  slug: z.ZodOptional<z.ZodString>;
11
12
  ownerId: z.ZodOptional<z.ZodString>;
12
13
  organizationId: z.ZodOptional<z.ZodString>;
13
14
  createdAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
14
15
  updatedAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
15
- name: z.ZodString;
16
16
  }, z.core.$strip>;
17
17
  declare const updateBoardSchema: z.ZodObject<{
18
18
  createdAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
@@ -189,25 +189,25 @@ interface KanbanApiContext<TBody = unknown, TParams = unknown, TQuery = unknown>
189
189
  */
190
190
  interface KanbanBackendHooks {
191
191
  /**
192
- * Called before listing boards. Return false to deny access.
192
+ * Called before listing boards. Throw an error to deny access.
193
193
  */
194
- onBeforeListBoards?: (filter: z.infer<typeof BoardListQuerySchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
194
+ onBeforeListBoards?: (filter: z.infer<typeof BoardListQuerySchema>, context: KanbanApiContext) => Promise<void> | void;
195
195
  /**
196
- * Called before creating a board. Return false to deny access.
196
+ * Called before creating a board. Throw an error to deny access.
197
197
  */
198
- onBeforeCreateBoard?: (data: z.infer<typeof createBoardSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
198
+ onBeforeCreateBoard?: (data: z.infer<typeof createBoardSchema>, context: KanbanApiContext) => Promise<void> | void;
199
199
  /**
200
- * Called before reading a single board. Return false to deny access.
200
+ * Called before reading a single board. Throw an error to deny access.
201
201
  */
202
- onBeforeReadBoard?: (boardId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
202
+ onBeforeReadBoard?: (boardId: string, context: KanbanApiContext) => Promise<void> | void;
203
203
  /**
204
- * Called before updating a board. Return false to deny access.
204
+ * Called before updating a board. Throw an error to deny access.
205
205
  */
206
- onBeforeUpdateBoard?: (boardId: string, data: z.infer<typeof updateBoardSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
206
+ onBeforeUpdateBoard?: (boardId: string, data: z.infer<typeof updateBoardSchema>, context: KanbanApiContext) => Promise<void> | void;
207
207
  /**
208
- * Called before deleting a board. Return false to deny access.
208
+ * Called before deleting a board. Throw an error to deny access.
209
209
  */
210
- onBeforeDeleteBoard?: (boardId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
210
+ onBeforeDeleteBoard?: (boardId: string, context: KanbanApiContext) => Promise<void> | void;
211
211
  /**
212
212
  * Called after boards are listed successfully.
213
213
  * Receives the items array (same shape as `board[]`) for consistency
@@ -251,17 +251,17 @@ interface KanbanBackendHooks {
251
251
  */
252
252
  onDeleteBoardError?: (error: Error, context: KanbanApiContext) => Promise<void> | void;
253
253
  /**
254
- * Called before creating a column. Return false to deny access.
254
+ * Called before creating a column. Throw an error to deny access.
255
255
  */
256
- onBeforeCreateColumn?: (data: z.infer<typeof createColumnSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
256
+ onBeforeCreateColumn?: (data: z.infer<typeof createColumnSchema>, context: KanbanApiContext) => Promise<void> | void;
257
257
  /**
258
- * Called before updating a column. Return false to deny access.
258
+ * Called before updating a column. Throw an error to deny access.
259
259
  */
260
- onBeforeUpdateColumn?: (columnId: string, data: z.infer<typeof updateColumnSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
260
+ onBeforeUpdateColumn?: (columnId: string, data: z.infer<typeof updateColumnSchema>, context: KanbanApiContext) => Promise<void> | void;
261
261
  /**
262
- * Called before deleting a column. Return false to deny access.
262
+ * Called before deleting a column. Throw an error to deny access.
263
263
  */
264
- onBeforeDeleteColumn?: (columnId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
264
+ onBeforeDeleteColumn?: (columnId: string, context: KanbanApiContext) => Promise<void> | void;
265
265
  /**
266
266
  * Called after a column is created successfully
267
267
  */
@@ -275,17 +275,17 @@ interface KanbanBackendHooks {
275
275
  */
276
276
  onColumnDeleted?: (columnId: string, context: KanbanApiContext) => Promise<void> | void;
277
277
  /**
278
- * Called before creating a task. Return false to deny access.
278
+ * Called before creating a task. Throw an error to deny access.
279
279
  */
280
- onBeforeCreateTask?: (data: z.infer<typeof createTaskSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
280
+ onBeforeCreateTask?: (data: z.infer<typeof createTaskSchema>, context: KanbanApiContext) => Promise<void> | void;
281
281
  /**
282
- * Called before updating a task. Return false to deny access.
282
+ * Called before updating a task. Throw an error to deny access.
283
283
  */
284
- onBeforeUpdateTask?: (taskId: string, data: z.infer<typeof updateTaskSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
284
+ onBeforeUpdateTask?: (taskId: string, data: z.infer<typeof updateTaskSchema>, context: KanbanApiContext) => Promise<void> | void;
285
285
  /**
286
- * Called before deleting a task. Return false to deny access.
286
+ * Called before deleting a task. Throw an error to deny access.
287
287
  */
288
- onBeforeDeleteTask?: (taskId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
288
+ onBeforeDeleteTask?: (taskId: string, context: KanbanApiContext) => Promise<void> | void;
289
289
  /**
290
290
  * Called after a task is created successfully
291
291
  */
@@ -323,12 +323,12 @@ declare const kanbanBackendPlugin: (hooks?: KanbanBackendHooks) => _btst_stack_p
323
323
  method: "POST";
324
324
  body: z.ZodObject<{
325
325
  description: z.ZodOptional<z.ZodString>;
326
+ name: z.ZodString;
326
327
  slug: z.ZodOptional<z.ZodString>;
327
328
  ownerId: z.ZodOptional<z.ZodString>;
328
329
  organizationId: z.ZodOptional<z.ZodString>;
329
330
  createdAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
330
331
  updatedAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
331
- name: z.ZodString;
332
332
  }, z.core.$strip>;
333
333
  }, {
334
334
  columns: ColumnWithTasks[];
@@ -345,12 +345,12 @@ declare const kanbanBackendPlugin: (hooks?: KanbanBackendHooks) => _btst_stack_p
345
345
  method: "PUT";
346
346
  body: z.ZodObject<{
347
347
  description: z.ZodOptional<z.ZodOptional<z.ZodString>>;
348
+ name: z.ZodOptional<z.ZodString>;
348
349
  slug: z.ZodOptional<z.ZodString>;
349
350
  ownerId: z.ZodOptional<z.ZodOptional<z.ZodString>>;
350
351
  organizationId: z.ZodOptional<z.ZodOptional<z.ZodString>>;
351
352
  createdAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
352
353
  updatedAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
353
- name: z.ZodOptional<z.ZodString>;
354
354
  }, z.core.$strip>;
355
355
  }, Board>;
356
356
  readonly deleteBoard: better_call.StrictEndpoint<"/boards/:id", {
@@ -24,49 +24,49 @@ interface ChatApiContext<TBody = any, TParams = any, TQuery = any> {
24
24
  */
25
25
  interface AiChatBackendHooks {
26
26
  /**
27
- * Called before processing a chat message. Return false to deny access.
27
+ * Called before processing a chat message. Throw an error to deny access.
28
28
  * @param messages - Array of messages being sent
29
29
  * @param context - Request context with headers, etc.
30
30
  */
31
31
  onBeforeChat?: (messages: Array<{
32
32
  role: string;
33
33
  content: string;
34
- }>, context: ChatApiContext) => Promise<boolean> | boolean;
34
+ }>, context: ChatApiContext) => Promise<void> | void;
35
35
  /**
36
- * Called before listing conversations. Return false to deny access.
36
+ * Called before listing conversations. Throw an error to deny access.
37
37
  * @param context - Request context with headers, etc.
38
38
  */
39
- onBeforeListConversations?: (context: ChatApiContext) => Promise<boolean> | boolean;
39
+ onBeforeListConversations?: (context: ChatApiContext) => Promise<void> | void;
40
40
  /**
41
- * Called before getting a single conversation. Return false to deny access.
41
+ * Called before getting a single conversation. Throw an error to deny access.
42
42
  * @param conversationId - ID of the conversation being accessed
43
43
  * @param context - Request context with headers, etc.
44
44
  */
45
- onBeforeGetConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
45
+ onBeforeGetConversation?: (conversationId: string, context: ChatApiContext) => Promise<void> | void;
46
46
  /**
47
- * Called before creating a conversation. Return false to deny access.
47
+ * Called before creating a conversation. Throw an error to deny access.
48
48
  * @param data - Conversation data being created
49
49
  * @param context - Request context with headers, etc.
50
50
  */
51
51
  onBeforeCreateConversation?: (data: {
52
52
  id?: string;
53
53
  title?: string;
54
- }, context: ChatApiContext) => Promise<boolean> | boolean;
54
+ }, context: ChatApiContext) => Promise<void> | void;
55
55
  /**
56
- * Called before updating a conversation. Return false to deny access.
56
+ * Called before updating a conversation. Throw an error to deny access.
57
57
  * @param conversationId - ID of the conversation being updated
58
58
  * @param data - Updated conversation data
59
59
  * @param context - Request context with headers, etc.
60
60
  */
61
61
  onBeforeUpdateConversation?: (conversationId: string, data: {
62
62
  title?: string;
63
- }, context: ChatApiContext) => Promise<boolean> | boolean;
63
+ }, context: ChatApiContext) => Promise<void> | void;
64
64
  /**
65
- * Called before deleting a conversation. Return false to deny access.
65
+ * Called before deleting a conversation. Throw an error to deny access.
66
66
  * @param conversationId - ID of the conversation being deleted
67
67
  * @param context - Request context with headers, etc.
68
68
  */
69
- onBeforeDeleteConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
69
+ onBeforeDeleteConversation?: (conversationId: string, context: ChatApiContext) => Promise<void> | void;
70
70
  /**
71
71
  * Called after the structural routeName/allowlist validation, with the list
72
72
  * of tool names that passed. Return a filtered subset to further restrict
@@ -1,6 +1,6 @@
1
1
  import * as _btst_stack_plugins_api from '@btst/stack/plugins/api';
2
2
  import * as better_call from 'better-call';
3
- import { S as SerializedForm, b as SerializedFormSubmissionWithData, F as Form, d as FormSubmission, a as SerializedFormSubmission, e as FormSubmissionWithForm, f as FormBuilderBackendConfig } from './stack.DdI5W6MB.cjs';
3
+ import { S as SerializedForm, b as SerializedFormSubmissionWithData, F as Form, d as FormSubmission, a as SerializedFormSubmission, e as FormSubmissionWithForm, f as FormBuilderBackendConfig } from './stack.BozPgbrZ.mjs';
4
4
  import { z } from 'zod';
5
5
  import { Adapter } from '@btst/db';
6
6
  import { QueryClient } from '@tanstack/react-query';
@@ -191,8 +191,8 @@ declare const formBuilderBackendPlugin: (config?: FormBuilderBackendConfig) => _
191
191
  };
192
192
  submittedAt: string;
193
193
  id: string;
194
- data: string;
195
194
  formId: string;
195
+ data: string;
196
196
  submittedBy?: string | undefined;
197
197
  ipAddress?: string | undefined;
198
198
  userAgent?: string | undefined;
@@ -113,30 +113,30 @@ interface BlogApiContext<TBody = any, TParams = any, TQuery = any> {
113
113
  */
114
114
  interface BlogBackendHooks {
115
115
  /**
116
- * Called before listing posts. Return false to deny access.
116
+ * Called before listing posts. Throw an error to deny access.
117
117
  * @param filter - Query parameters for filtering posts
118
118
  * @param context - Request context with headers, etc.
119
119
  */
120
- onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<boolean> | boolean;
120
+ onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<void> | void;
121
121
  /**
122
- * Called before creating a post. Return false to deny access.
122
+ * Called before creating a post. Throw an error to deny access.
123
123
  * @param data - Post data being created
124
124
  * @param context - Request context with headers, etc.
125
125
  */
126
- onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
126
+ onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<void> | void;
127
127
  /**
128
- * Called before updating a post. Return false to deny access.
128
+ * Called before updating a post. Throw an error to deny access.
129
129
  * @param postId - ID of the post being updated
130
130
  * @param data - Updated post data
131
131
  * @param context - Request context with headers, etc.
132
132
  */
133
- onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
133
+ onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<void> | void;
134
134
  /**
135
- * Called before deleting a post. Return false to deny access.
135
+ * Called before deleting a post. Throw an error to deny access.
136
136
  * @param postId - ID of the post being deleted
137
137
  * @param context - Request context with headers, etc.
138
138
  */
139
- onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<boolean> | boolean;
139
+ onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<void> | void;
140
140
  /**
141
141
  * Called after posts are read successfully
142
142
  * @param posts - The list of posts returned by the query
@@ -113,30 +113,30 @@ interface BlogApiContext<TBody = any, TParams = any, TQuery = any> {
113
113
  */
114
114
  interface BlogBackendHooks {
115
115
  /**
116
- * Called before listing posts. Return false to deny access.
116
+ * Called before listing posts. Throw an error to deny access.
117
117
  * @param filter - Query parameters for filtering posts
118
118
  * @param context - Request context with headers, etc.
119
119
  */
120
- onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<boolean> | boolean;
120
+ onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<void> | void;
121
121
  /**
122
- * Called before creating a post. Return false to deny access.
122
+ * Called before creating a post. Throw an error to deny access.
123
123
  * @param data - Post data being created
124
124
  * @param context - Request context with headers, etc.
125
125
  */
126
- onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
126
+ onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<void> | void;
127
127
  /**
128
- * Called before updating a post. Return false to deny access.
128
+ * Called before updating a post. Throw an error to deny access.
129
129
  * @param postId - ID of the post being updated
130
130
  * @param data - Updated post data
131
131
  * @param context - Request context with headers, etc.
132
132
  */
133
- onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
133
+ onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<void> | void;
134
134
  /**
135
- * Called before deleting a post. Return false to deny access.
135
+ * Called before deleting a post. Throw an error to deny access.
136
136
  * @param postId - ID of the post being deleted
137
137
  * @param context - Request context with headers, etc.
138
138
  */
139
- onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<boolean> | boolean;
139
+ onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<void> | void;
140
140
  /**
141
141
  * Called after posts are read successfully
142
142
  * @param posts - The list of posts returned by the query
@@ -24,49 +24,49 @@ interface ChatApiContext<TBody = any, TParams = any, TQuery = any> {
24
24
  */
25
25
  interface AiChatBackendHooks {
26
26
  /**
27
- * Called before processing a chat message. Return false to deny access.
27
+ * Called before processing a chat message. Throw an error to deny access.
28
28
  * @param messages - Array of messages being sent
29
29
  * @param context - Request context with headers, etc.
30
30
  */
31
31
  onBeforeChat?: (messages: Array<{
32
32
  role: string;
33
33
  content: string;
34
- }>, context: ChatApiContext) => Promise<boolean> | boolean;
34
+ }>, context: ChatApiContext) => Promise<void> | void;
35
35
  /**
36
- * Called before listing conversations. Return false to deny access.
36
+ * Called before listing conversations. Throw an error to deny access.
37
37
  * @param context - Request context with headers, etc.
38
38
  */
39
- onBeforeListConversations?: (context: ChatApiContext) => Promise<boolean> | boolean;
39
+ onBeforeListConversations?: (context: ChatApiContext) => Promise<void> | void;
40
40
  /**
41
- * Called before getting a single conversation. Return false to deny access.
41
+ * Called before getting a single conversation. Throw an error to deny access.
42
42
  * @param conversationId - ID of the conversation being accessed
43
43
  * @param context - Request context with headers, etc.
44
44
  */
45
- onBeforeGetConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
45
+ onBeforeGetConversation?: (conversationId: string, context: ChatApiContext) => Promise<void> | void;
46
46
  /**
47
- * Called before creating a conversation. Return false to deny access.
47
+ * Called before creating a conversation. Throw an error to deny access.
48
48
  * @param data - Conversation data being created
49
49
  * @param context - Request context with headers, etc.
50
50
  */
51
51
  onBeforeCreateConversation?: (data: {
52
52
  id?: string;
53
53
  title?: string;
54
- }, context: ChatApiContext) => Promise<boolean> | boolean;
54
+ }, context: ChatApiContext) => Promise<void> | void;
55
55
  /**
56
- * Called before updating a conversation. Return false to deny access.
56
+ * Called before updating a conversation. Throw an error to deny access.
57
57
  * @param conversationId - ID of the conversation being updated
58
58
  * @param data - Updated conversation data
59
59
  * @param context - Request context with headers, etc.
60
60
  */
61
61
  onBeforeUpdateConversation?: (conversationId: string, data: {
62
62
  title?: string;
63
- }, context: ChatApiContext) => Promise<boolean> | boolean;
63
+ }, context: ChatApiContext) => Promise<void> | void;
64
64
  /**
65
- * Called before deleting a conversation. Return false to deny access.
65
+ * Called before deleting a conversation. Throw an error to deny access.
66
66
  * @param conversationId - ID of the conversation being deleted
67
67
  * @param context - Request context with headers, etc.
68
68
  */
69
- onBeforeDeleteConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
69
+ onBeforeDeleteConversation?: (conversationId: string, context: ChatApiContext) => Promise<void> | void;
70
70
  /**
71
71
  * Called after the structural routeName/allowlist validation, with the list
72
72
  * of tool names that passed. Return a filtered subset to further restrict
@@ -113,30 +113,30 @@ interface BlogApiContext<TBody = any, TParams = any, TQuery = any> {
113
113
  */
114
114
  interface BlogBackendHooks {
115
115
  /**
116
- * Called before listing posts. Return false to deny access.
116
+ * Called before listing posts. Throw an error to deny access.
117
117
  * @param filter - Query parameters for filtering posts
118
118
  * @param context - Request context with headers, etc.
119
119
  */
120
- onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<boolean> | boolean;
120
+ onBeforeListPosts?: (filter: z.infer<typeof PostListQuerySchema>, context: BlogApiContext) => Promise<void> | void;
121
121
  /**
122
- * Called before creating a post. Return false to deny access.
122
+ * Called before creating a post. Throw an error to deny access.
123
123
  * @param data - Post data being created
124
124
  * @param context - Request context with headers, etc.
125
125
  */
126
- onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
126
+ onBeforeCreatePost?: (data: z.infer<typeof createPostSchema>, context: BlogApiContext) => Promise<void> | void;
127
127
  /**
128
- * Called before updating a post. Return false to deny access.
128
+ * Called before updating a post. Throw an error to deny access.
129
129
  * @param postId - ID of the post being updated
130
130
  * @param data - Updated post data
131
131
  * @param context - Request context with headers, etc.
132
132
  */
133
- onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<boolean> | boolean;
133
+ onBeforeUpdatePost?: (postId: string, data: z.infer<typeof updatePostSchema>, context: BlogApiContext) => Promise<void> | void;
134
134
  /**
135
- * Called before deleting a post. Return false to deny access.
135
+ * Called before deleting a post. Throw an error to deny access.
136
136
  * @param postId - ID of the post being deleted
137
137
  * @param context - Request context with headers, etc.
138
138
  */
139
- onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<boolean> | boolean;
139
+ onBeforeDeletePost?: (postId: string, context: BlogApiContext) => Promise<void> | void;
140
140
  /**
141
141
  * Called after posts are read successfully
142
142
  * @param posts - The list of posts returned by the query
@@ -83,21 +83,21 @@ interface LoaderContext {
83
83
  */
84
84
  interface UIBuilderClientHooks {
85
85
  /**
86
- * Called before loading the page list. Return false to cancel loading.
86
+ * Called before loading the page list. Throw an error to cancel loading.
87
87
  * @param context - Loader context with path, params, etc.
88
88
  */
89
- beforeLoadPageList?: (context: LoaderContext) => Promise<boolean> | boolean;
89
+ beforeLoadPageList?: (context: LoaderContext) => Promise<void> | void;
90
90
  /**
91
91
  * Called after the page list is loaded.
92
92
  * @param context - Loader context
93
93
  */
94
94
  afterLoadPageList?: (context: LoaderContext) => Promise<void> | void;
95
95
  /**
96
- * Called before loading the page builder. Return false to cancel loading.
96
+ * Called before loading the page builder. Throw an error to cancel loading.
97
97
  * @param pageId - The page ID (undefined for new pages)
98
98
  * @param context - Loader context
99
99
  */
100
- beforeLoadPageBuilder?: (pageId: string | undefined, context: LoaderContext) => Promise<boolean> | boolean;
100
+ beforeLoadPageBuilder?: (pageId: string | undefined, context: LoaderContext) => Promise<void> | void;
101
101
  /**
102
102
  * Called after the page builder is loaded.
103
103
  * @param pageId - The page ID (undefined for new pages)
@@ -7,12 +7,12 @@ import { QueryClient } from '@tanstack/react-query';
7
7
 
8
8
  declare const createBoardSchema: z.ZodObject<{
9
9
  description: z.ZodOptional<z.ZodString>;
10
+ name: z.ZodString;
10
11
  slug: z.ZodOptional<z.ZodString>;
11
12
  ownerId: z.ZodOptional<z.ZodString>;
12
13
  organizationId: z.ZodOptional<z.ZodString>;
13
14
  createdAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
14
15
  updatedAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
15
- name: z.ZodString;
16
16
  }, z.core.$strip>;
17
17
  declare const updateBoardSchema: z.ZodObject<{
18
18
  createdAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
@@ -189,25 +189,25 @@ interface KanbanApiContext<TBody = unknown, TParams = unknown, TQuery = unknown>
189
189
  */
190
190
  interface KanbanBackendHooks {
191
191
  /**
192
- * Called before listing boards. Return false to deny access.
192
+ * Called before listing boards. Throw an error to deny access.
193
193
  */
194
- onBeforeListBoards?: (filter: z.infer<typeof BoardListQuerySchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
194
+ onBeforeListBoards?: (filter: z.infer<typeof BoardListQuerySchema>, context: KanbanApiContext) => Promise<void> | void;
195
195
  /**
196
- * Called before creating a board. Return false to deny access.
196
+ * Called before creating a board. Throw an error to deny access.
197
197
  */
198
- onBeforeCreateBoard?: (data: z.infer<typeof createBoardSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
198
+ onBeforeCreateBoard?: (data: z.infer<typeof createBoardSchema>, context: KanbanApiContext) => Promise<void> | void;
199
199
  /**
200
- * Called before reading a single board. Return false to deny access.
200
+ * Called before reading a single board. Throw an error to deny access.
201
201
  */
202
- onBeforeReadBoard?: (boardId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
202
+ onBeforeReadBoard?: (boardId: string, context: KanbanApiContext) => Promise<void> | void;
203
203
  /**
204
- * Called before updating a board. Return false to deny access.
204
+ * Called before updating a board. Throw an error to deny access.
205
205
  */
206
- onBeforeUpdateBoard?: (boardId: string, data: z.infer<typeof updateBoardSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
206
+ onBeforeUpdateBoard?: (boardId: string, data: z.infer<typeof updateBoardSchema>, context: KanbanApiContext) => Promise<void> | void;
207
207
  /**
208
- * Called before deleting a board. Return false to deny access.
208
+ * Called before deleting a board. Throw an error to deny access.
209
209
  */
210
- onBeforeDeleteBoard?: (boardId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
210
+ onBeforeDeleteBoard?: (boardId: string, context: KanbanApiContext) => Promise<void> | void;
211
211
  /**
212
212
  * Called after boards are listed successfully.
213
213
  * Receives the items array (same shape as `board[]`) for consistency
@@ -251,17 +251,17 @@ interface KanbanBackendHooks {
251
251
  */
252
252
  onDeleteBoardError?: (error: Error, context: KanbanApiContext) => Promise<void> | void;
253
253
  /**
254
- * Called before creating a column. Return false to deny access.
254
+ * Called before creating a column. Throw an error to deny access.
255
255
  */
256
- onBeforeCreateColumn?: (data: z.infer<typeof createColumnSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
256
+ onBeforeCreateColumn?: (data: z.infer<typeof createColumnSchema>, context: KanbanApiContext) => Promise<void> | void;
257
257
  /**
258
- * Called before updating a column. Return false to deny access.
258
+ * Called before updating a column. Throw an error to deny access.
259
259
  */
260
- onBeforeUpdateColumn?: (columnId: string, data: z.infer<typeof updateColumnSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
260
+ onBeforeUpdateColumn?: (columnId: string, data: z.infer<typeof updateColumnSchema>, context: KanbanApiContext) => Promise<void> | void;
261
261
  /**
262
- * Called before deleting a column. Return false to deny access.
262
+ * Called before deleting a column. Throw an error to deny access.
263
263
  */
264
- onBeforeDeleteColumn?: (columnId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
264
+ onBeforeDeleteColumn?: (columnId: string, context: KanbanApiContext) => Promise<void> | void;
265
265
  /**
266
266
  * Called after a column is created successfully
267
267
  */
@@ -275,17 +275,17 @@ interface KanbanBackendHooks {
275
275
  */
276
276
  onColumnDeleted?: (columnId: string, context: KanbanApiContext) => Promise<void> | void;
277
277
  /**
278
- * Called before creating a task. Return false to deny access.
278
+ * Called before creating a task. Throw an error to deny access.
279
279
  */
280
- onBeforeCreateTask?: (data: z.infer<typeof createTaskSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
280
+ onBeforeCreateTask?: (data: z.infer<typeof createTaskSchema>, context: KanbanApiContext) => Promise<void> | void;
281
281
  /**
282
- * Called before updating a task. Return false to deny access.
282
+ * Called before updating a task. Throw an error to deny access.
283
283
  */
284
- onBeforeUpdateTask?: (taskId: string, data: z.infer<typeof updateTaskSchema>, context: KanbanApiContext) => Promise<boolean> | boolean;
284
+ onBeforeUpdateTask?: (taskId: string, data: z.infer<typeof updateTaskSchema>, context: KanbanApiContext) => Promise<void> | void;
285
285
  /**
286
- * Called before deleting a task. Return false to deny access.
286
+ * Called before deleting a task. Throw an error to deny access.
287
287
  */
288
- onBeforeDeleteTask?: (taskId: string, context: KanbanApiContext) => Promise<boolean> | boolean;
288
+ onBeforeDeleteTask?: (taskId: string, context: KanbanApiContext) => Promise<void> | void;
289
289
  /**
290
290
  * Called after a task is created successfully
291
291
  */
@@ -323,12 +323,12 @@ declare const kanbanBackendPlugin: (hooks?: KanbanBackendHooks) => _btst_stack_p
323
323
  method: "POST";
324
324
  body: z.ZodObject<{
325
325
  description: z.ZodOptional<z.ZodString>;
326
+ name: z.ZodString;
326
327
  slug: z.ZodOptional<z.ZodString>;
327
328
  ownerId: z.ZodOptional<z.ZodString>;
328
329
  organizationId: z.ZodOptional<z.ZodString>;
329
330
  createdAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
330
331
  updatedAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
331
- name: z.ZodString;
332
332
  }, z.core.$strip>;
333
333
  }, {
334
334
  columns: ColumnWithTasks[];
@@ -345,12 +345,12 @@ declare const kanbanBackendPlugin: (hooks?: KanbanBackendHooks) => _btst_stack_p
345
345
  method: "PUT";
346
346
  body: z.ZodObject<{
347
347
  description: z.ZodOptional<z.ZodOptional<z.ZodString>>;
348
+ name: z.ZodOptional<z.ZodString>;
348
349
  slug: z.ZodOptional<z.ZodString>;
349
350
  ownerId: z.ZodOptional<z.ZodOptional<z.ZodString>>;
350
351
  organizationId: z.ZodOptional<z.ZodOptional<z.ZodString>>;
351
352
  createdAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
352
353
  updatedAt: z.ZodOptional<z.ZodOptional<z.ZodCoercedDate<unknown>>>;
353
- name: z.ZodOptional<z.ZodString>;
354
354
  }, z.core.$strip>;
355
355
  }, Board>;
356
356
  readonly deleteBoard: better_call.StrictEndpoint<"/boards/:id", {