@promptbook/cli 0.103.0-10 → 0.103.0-100

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 (452) hide show
  1. package/README.md +59 -35
  2. package/apps/agents-server/README.md +3 -0
  3. package/apps/agents-server/TODO.txt +7 -0
  4. package/apps/agents-server/config.ts +128 -0
  5. package/apps/agents-server/next.config.ts +45 -0
  6. package/apps/agents-server/package-lock.json +1163 -0
  7. package/apps/agents-server/package.json +18 -0
  8. package/apps/agents-server/postcss.config.mjs +8 -0
  9. package/apps/agents-server/public/.gitkeep +0 -0
  10. package/apps/agents-server/public/favicon.ico +0 -0
  11. package/apps/agents-server/public/fonts/OpenMoji-black-glyf.woff2 +0 -0
  12. package/apps/agents-server/public/fonts/download-font.js +22 -0
  13. package/apps/agents-server/public/logo-blue-white-256.png +0 -0
  14. package/apps/agents-server/public/sw.js +16 -0
  15. package/apps/agents-server/src/app/AddAgentButton.tsx +41 -0
  16. package/apps/agents-server/src/app/[agentName]/[...rest]/page.tsx +11 -0
  17. package/apps/agents-server/src/app/[agentName]/page.tsx +1 -0
  18. package/apps/agents-server/src/app/actions.ts +51 -0
  19. package/apps/agents-server/src/app/admin/api-tokens/ApiTokensClient.tsx +186 -0
  20. package/apps/agents-server/src/app/admin/api-tokens/page.tsx +13 -0
  21. package/apps/agents-server/src/app/admin/chat-feedback/ChatFeedbackClient.tsx +614 -0
  22. package/apps/agents-server/src/app/admin/chat-feedback/page.tsx +22 -0
  23. package/apps/agents-server/src/app/admin/chat-history/ChatHistoryClient.tsx +634 -0
  24. package/apps/agents-server/src/app/admin/chat-history/page.tsx +21 -0
  25. package/apps/agents-server/src/app/admin/metadata/MetadataClient.tsx +477 -0
  26. package/apps/agents-server/src/app/admin/metadata/page.tsx +13 -0
  27. package/apps/agents-server/src/app/admin/models/page.tsx +22 -0
  28. package/apps/agents-server/src/app/admin/users/[userId]/UserDetailClient.tsx +131 -0
  29. package/apps/agents-server/src/app/admin/users/[userId]/page.tsx +21 -0
  30. package/apps/agents-server/src/app/admin/users/page.tsx +18 -0
  31. package/apps/agents-server/src/app/agents/[agentName]/AgentChatWrapper.tsx +78 -0
  32. package/apps/agents-server/src/app/agents/[agentName]/AgentOptionsMenu.tsx +216 -0
  33. package/apps/agents-server/src/app/agents/[agentName]/AgentProfileChat.tsx +78 -0
  34. package/apps/agents-server/src/app/agents/[agentName]/AgentProfileView.tsx +233 -0
  35. package/apps/agents-server/src/app/agents/[agentName]/AgentQrCode.tsx +55 -0
  36. package/apps/agents-server/src/app/agents/[agentName]/AgentUrlCopy.tsx +40 -0
  37. package/apps/agents-server/src/app/agents/[agentName]/ClearAgentChatFeedbackButton.tsx +63 -0
  38. package/apps/agents-server/src/app/agents/[agentName]/ClearAgentChatHistoryButton.tsx +63 -0
  39. package/apps/agents-server/src/app/agents/[agentName]/CloneAgentButton.tsx +41 -0
  40. package/apps/agents-server/src/app/agents/[agentName]/CopyField.tsx +44 -0
  41. package/apps/agents-server/src/app/agents/[agentName]/InstallPwaButton.tsx +74 -0
  42. package/apps/agents-server/src/app/agents/[agentName]/QrCodeModal.tsx +90 -0
  43. package/apps/agents-server/src/app/agents/[agentName]/ServiceWorkerRegister.tsx +24 -0
  44. package/apps/agents-server/src/app/agents/[agentName]/TODO.txt +1 -0
  45. package/apps/agents-server/src/app/agents/[agentName]/_utils.ts +19 -0
  46. package/apps/agents-server/src/app/agents/[agentName]/agentLinks.tsx +80 -0
  47. package/apps/agents-server/src/app/agents/[agentName]/api/agents/route.ts +67 -0
  48. package/apps/agents-server/src/app/agents/[agentName]/api/book/route.ts +88 -0
  49. package/apps/agents-server/src/app/agents/[agentName]/api/book/test.http +37 -0
  50. package/apps/agents-server/src/app/agents/[agentName]/api/chat/route.ts +174 -0
  51. package/apps/agents-server/src/app/agents/[agentName]/api/feedback/route.ts +54 -0
  52. package/apps/agents-server/src/app/agents/[agentName]/api/mcp/route.ts +203 -0
  53. package/apps/agents-server/src/app/agents/[agentName]/api/modelRequirements/TODO.txt +1 -0
  54. package/apps/agents-server/src/app/agents/[agentName]/api/modelRequirements/route.ts +55 -0
  55. package/apps/agents-server/src/app/agents/[agentName]/api/modelRequirements/systemMessage/route.ts +47 -0
  56. package/apps/agents-server/src/app/agents/[agentName]/api/openai/chat/completions/route.ts +10 -0
  57. package/apps/agents-server/src/app/agents/[agentName]/api/openai/models/route.ts +93 -0
  58. package/apps/agents-server/src/app/agents/[agentName]/api/openai/v1/chat/completions/route.ts +10 -0
  59. package/apps/agents-server/src/app/agents/[agentName]/api/openai/v1/models/route.ts +93 -0
  60. package/apps/agents-server/src/app/agents/[agentName]/api/openrouter/chat/completions/route.ts +10 -0
  61. package/apps/agents-server/src/app/agents/[agentName]/api/profile/route.ts +76 -0
  62. package/apps/agents-server/src/app/agents/[agentName]/api/voice/route.ts +181 -0
  63. package/apps/agents-server/src/app/agents/[agentName]/book/BookEditorWrapper.tsx +139 -0
  64. package/apps/agents-server/src/app/agents/[agentName]/book/page.tsx +35 -0
  65. package/apps/agents-server/src/app/agents/[agentName]/book+chat/AgentBookAndChat.tsx +75 -0
  66. package/apps/agents-server/src/app/agents/[agentName]/book+chat/AgentBookAndChatComponent.tsx.todo +160 -0
  67. package/apps/agents-server/src/app/agents/[agentName]/book+chat/page.tsx +32 -0
  68. package/apps/agents-server/src/app/agents/[agentName]/book+chat/page.tsx.todo +21 -0
  69. package/apps/agents-server/src/app/agents/[agentName]/chat/AgentChatWrapper.tsx +68 -0
  70. package/apps/agents-server/src/app/agents/[agentName]/chat/page.tsx +33 -0
  71. package/apps/agents-server/src/app/agents/[agentName]/generateAgentMetadata.ts +42 -0
  72. package/apps/agents-server/src/app/agents/[agentName]/history/RestoreVersionButton.tsx +46 -0
  73. package/apps/agents-server/src/app/agents/[agentName]/history/actions.ts +12 -0
  74. package/apps/agents-server/src/app/agents/[agentName]/history/page.tsx +62 -0
  75. package/apps/agents-server/src/app/agents/[agentName]/images/icon-256.png/route.tsx +80 -0
  76. package/apps/agents-server/src/app/agents/[agentName]/images/screenshot-fullhd.png/route.tsx +92 -0
  77. package/apps/agents-server/src/app/agents/[agentName]/images/screenshot-phone.png/route.tsx +92 -0
  78. package/apps/agents-server/src/app/agents/[agentName]/integration/SdkCodeTabs.tsx +31 -0
  79. package/apps/agents-server/src/app/agents/[agentName]/integration/page.tsx +302 -0
  80. package/apps/agents-server/src/app/agents/[agentName]/links/page.tsx +182 -0
  81. package/apps/agents-server/src/app/agents/[agentName]/opengraph-image.tsx +102 -0
  82. package/apps/agents-server/src/app/agents/[agentName]/page.tsx +159 -0
  83. package/apps/agents-server/src/app/agents/[agentName]/website-integration/page.tsx +61 -0
  84. package/apps/agents-server/src/app/agents/page.tsx +11 -0
  85. package/apps/agents-server/src/app/api/agents/[agentName]/clone/route.ts +47 -0
  86. package/apps/agents-server/src/app/api/agents/[agentName]/route.ts +19 -0
  87. package/apps/agents-server/src/app/api/agents/route.ts +43 -0
  88. package/apps/agents-server/src/app/api/api-tokens/route.ts +76 -0
  89. package/apps/agents-server/src/app/api/auth/change-password/route.ts +75 -0
  90. package/apps/agents-server/src/app/api/auth/login/route.ts +27 -0
  91. package/apps/agents-server/src/app/api/auth/logout/route.ts +7 -0
  92. package/apps/agents-server/src/app/api/chat/route.ts +32 -0
  93. package/apps/agents-server/src/app/api/chat-feedback/[id]/route.ts +38 -0
  94. package/apps/agents-server/src/app/api/chat-feedback/export/route.ts +55 -0
  95. package/apps/agents-server/src/app/api/chat-feedback/route.ts +157 -0
  96. package/apps/agents-server/src/app/api/chat-history/[id]/route.ts +37 -0
  97. package/apps/agents-server/src/app/api/chat-history/export/route.ts +55 -0
  98. package/apps/agents-server/src/app/api/chat-history/route.ts +147 -0
  99. package/apps/agents-server/src/app/api/chat-streaming/route.ts +48 -0
  100. package/apps/agents-server/src/app/api/embed.js/route.ts +93 -0
  101. package/apps/agents-server/src/app/api/federated-agents/route.ts +17 -0
  102. package/apps/agents-server/src/app/api/long-running-task/route.ts +7 -0
  103. package/apps/agents-server/src/app/api/long-streaming/route.ts +20 -0
  104. package/apps/agents-server/src/app/api/metadata/route.ts +116 -0
  105. package/apps/agents-server/src/app/api/openai/v1/chat/completions/route.ts +6 -0
  106. package/apps/agents-server/src/app/api/openai/v1/models/route.ts +65 -0
  107. package/apps/agents-server/src/app/api/upload/route.ts +83 -0
  108. package/apps/agents-server/src/app/api/users/[username]/route.ts +75 -0
  109. package/apps/agents-server/src/app/api/users/route.ts +71 -0
  110. package/apps/agents-server/src/app/docs/[docId]/page.tsx +43 -0
  111. package/apps/agents-server/src/app/docs/page.tsx +59 -0
  112. package/apps/agents-server/src/app/embed/page.tsx +24 -0
  113. package/apps/agents-server/src/app/globals.css +276 -0
  114. package/apps/agents-server/src/app/layout.tsx +124 -0
  115. package/apps/agents-server/src/app/manifest.ts +109 -0
  116. package/apps/agents-server/src/app/not-found.tsx +5 -0
  117. package/apps/agents-server/src/app/page.tsx +96 -0
  118. package/apps/agents-server/src/app/recycle-bin/RestoreAgentButton.tsx +40 -0
  119. package/apps/agents-server/src/app/recycle-bin/actions.ts +27 -0
  120. package/apps/agents-server/src/app/recycle-bin/page.tsx +58 -0
  121. package/apps/agents-server/src/app/restricted/page.tsx +33 -0
  122. package/apps/agents-server/src/app/test/og-image/README.md +1 -0
  123. package/apps/agents-server/src/app/test/og-image/opengraph-image.tsx +37 -0
  124. package/apps/agents-server/src/app/test/og-image/page.tsx +22 -0
  125. package/apps/agents-server/src/components/Auth/AuthControls.tsx +123 -0
  126. package/apps/agents-server/src/components/ChangePasswordDialog/ChangePasswordDialog.tsx +41 -0
  127. package/apps/agents-server/src/components/ChangePasswordForm/ChangePasswordForm.tsx +159 -0
  128. package/apps/agents-server/src/components/DocumentationContent/DocumentationContent.tsx +87 -0
  129. package/apps/agents-server/src/components/ErrorPage/ErrorPage.tsx +33 -0
  130. package/apps/agents-server/src/components/Footer/Footer.tsx +175 -0
  131. package/apps/agents-server/src/components/ForbiddenPage/ForbiddenPage.tsx +15 -0
  132. package/apps/agents-server/src/components/Header/Header.tsx +593 -0
  133. package/apps/agents-server/src/components/Homepage/AgentCard.tsx +60 -0
  134. package/apps/agents-server/src/components/Homepage/AgentsList.tsx +58 -0
  135. package/apps/agents-server/src/components/Homepage/Card.tsx +18 -0
  136. package/apps/agents-server/src/components/Homepage/ExternalAgentsSection.tsx +21 -0
  137. package/apps/agents-server/src/components/Homepage/ExternalAgentsSectionClient.tsx +183 -0
  138. package/apps/agents-server/src/components/Homepage/ModelCard.tsx +29 -0
  139. package/apps/agents-server/src/components/Homepage/ModelsSection.tsx +75 -0
  140. package/apps/agents-server/src/components/Homepage/Section.tsx +17 -0
  141. package/apps/agents-server/src/components/Homepage/TechInfoCard.tsx +20 -0
  142. package/apps/agents-server/src/components/LayoutWrapper/LayoutWrapper.tsx +53 -0
  143. package/apps/agents-server/src/components/LoginDialog/LoginDialog.tsx +41 -0
  144. package/apps/agents-server/src/components/LoginForm/LoginForm.tsx +109 -0
  145. package/apps/agents-server/src/components/NotFoundPage/NotFoundPage.tsx +17 -0
  146. package/apps/agents-server/src/components/OpenMojiIcon/OpenMojiIcon.tsx +20 -0
  147. package/apps/agents-server/src/components/Portal/Portal.tsx +38 -0
  148. package/apps/agents-server/src/components/PrintButton/PrintButton.tsx +18 -0
  149. package/apps/agents-server/src/components/PrintHeader/PrintHeader.tsx +18 -0
  150. package/apps/agents-server/src/components/UsersList/UsersList.tsx +141 -0
  151. package/apps/agents-server/src/components/UsersList/useUsersAdmin.ts +139 -0
  152. package/apps/agents-server/src/components/VercelDeploymentCard/VercelDeploymentCard.tsx +55 -0
  153. package/apps/agents-server/src/database/$getTableName.ts +18 -0
  154. package/apps/agents-server/src/database/$provideSupabase.ts +29 -0
  155. package/apps/agents-server/src/database/$provideSupabaseForBrowser.ts +41 -0
  156. package/apps/agents-server/src/database/$provideSupabaseForServer.ts +48 -0
  157. package/apps/agents-server/src/database/$provideSupabaseForWorker.ts +43 -0
  158. package/apps/agents-server/src/database/getMetadata.ts +31 -0
  159. package/apps/agents-server/src/database/metadataDefaults.ts +69 -0
  160. package/apps/agents-server/src/database/migrate.ts +131 -0
  161. package/apps/agents-server/src/database/migrations/2025-11-0001-initial-schema.sql +163 -0
  162. package/apps/agents-server/src/database/migrations/2025-11-0002-metadata-table.sql +16 -0
  163. package/apps/agents-server/src/database/migrations/2025-12-0010-llm-cache.sql +12 -0
  164. package/apps/agents-server/src/database/migrations/2025-12-0060-api-tokens.sql +13 -0
  165. package/apps/agents-server/src/database/migrations/2025-12-0070-chat-history-source.sql +2 -0
  166. package/apps/agents-server/src/database/schema.ts +308 -0
  167. package/apps/agents-server/src/deamons/longRunningTask.ts +37 -0
  168. package/apps/agents-server/src/middleware.ts +301 -0
  169. package/apps/agents-server/src/tools/$provideAgentCollectionForServer.ts +54 -0
  170. package/apps/agents-server/src/tools/$provideCdnForServer.ts +24 -0
  171. package/apps/agents-server/src/tools/$provideExecutionToolsForServer.ts +117 -0
  172. package/apps/agents-server/src/tools/$provideOpenAiAssistantExecutionToolsForServer.ts +35 -0
  173. package/apps/agents-server/src/tools/$provideServer.ts +39 -0
  174. package/apps/agents-server/src/utils/auth.ts +33 -0
  175. package/apps/agents-server/src/utils/authenticateUser.ts +42 -0
  176. package/apps/agents-server/src/utils/cache/SupabaseCacheStorage.ts +55 -0
  177. package/apps/agents-server/src/utils/cdn/classes/VercelBlobStorage.ts +63 -0
  178. package/apps/agents-server/src/utils/cdn/interfaces/IFilesStorage.ts +32 -0
  179. package/apps/agents-server/src/utils/cdn/interfaces/IStorage.ts +14 -0
  180. package/apps/agents-server/src/utils/cdn/utils/getUserFileCdnKey.ts +28 -0
  181. package/apps/agents-server/src/utils/cdn/utils/nameToSubfolderPath.ts +9 -0
  182. package/apps/agents-server/src/utils/cdn/utils/nextRequestToNodeRequest.ts +27 -0
  183. package/apps/agents-server/src/utils/chatFeedbackAdmin.ts +96 -0
  184. package/apps/agents-server/src/utils/chatHistoryAdmin.ts +96 -0
  185. package/apps/agents-server/src/utils/convertToCsv.ts +31 -0
  186. package/apps/agents-server/src/utils/getCurrentUser.ts +32 -0
  187. package/apps/agents-server/src/utils/getEffectiveFederatedServers.ts +22 -0
  188. package/apps/agents-server/src/utils/getFederatedAgents.ts +89 -0
  189. package/apps/agents-server/src/utils/getFederatedServersFromMetadata.ts +10 -0
  190. package/apps/agents-server/src/utils/getVisibleCommitmentDefinitions.ts +12 -0
  191. package/apps/agents-server/src/utils/handleChatCompletion.ts +355 -0
  192. package/apps/agents-server/src/utils/isIpAllowed.ts +101 -0
  193. package/apps/agents-server/src/utils/isUserAdmin.ts +31 -0
  194. package/apps/agents-server/src/utils/resolveInheritedAgentSource.ts +100 -0
  195. package/apps/agents-server/src/utils/session.ts +50 -0
  196. package/apps/agents-server/src/utils/validateApiKey.ts +128 -0
  197. package/apps/agents-server/src/utils/validators/validateMimeType.ts +24 -0
  198. package/apps/agents-server/tailwind.config.ts +26 -0
  199. package/apps/agents-server/tsconfig.json +29 -0
  200. package/apps/agents-server/vercel.json +7 -0
  201. package/esm/index.es.js +5114 -383
  202. package/esm/index.es.js.map +1 -1
  203. package/esm/typings/books/index.d.ts +0 -81
  204. package/esm/typings/servers.d.ts +9 -7
  205. package/esm/typings/src/_packages/browser.index.d.ts +6 -0
  206. package/esm/typings/src/_packages/cli.index.d.ts +4 -0
  207. package/esm/typings/src/_packages/components.index.d.ts +20 -8
  208. package/esm/typings/src/_packages/core.index.d.ts +58 -18
  209. package/esm/typings/src/_packages/node.index.d.ts +2 -2
  210. package/esm/typings/src/_packages/remote-server.index.d.ts +2 -0
  211. package/esm/typings/src/_packages/types.index.d.ts +58 -8
  212. package/esm/typings/src/_packages/utils.index.d.ts +6 -0
  213. package/esm/typings/src/_packages/wizard.index.d.ts +4 -0
  214. package/esm/typings/src/book-2.0/agent-source/AgentBasicInformation.d.ts +19 -5
  215. package/esm/typings/src/book-2.0/agent-source/AgentModelRequirements.d.ts +17 -1
  216. package/esm/typings/src/book-2.0/agent-source/AgentSourceParseResult.d.ts +3 -2
  217. package/esm/typings/src/book-2.0/agent-source/computeAgentHash.d.ts +8 -0
  218. package/esm/typings/src/book-2.0/agent-source/createCommitmentRegex.d.ts +3 -3
  219. package/esm/typings/src/book-2.0/agent-source/createDefaultAgentName.d.ts +8 -0
  220. package/esm/typings/src/book-2.0/agent-source/normalizeAgentName.d.ts +9 -0
  221. package/esm/typings/src/book-2.0/agent-source/padBook.d.ts +18 -0
  222. package/esm/typings/src/book-2.0/agent-source/parseAgentSourceWithCommitments.d.ts +1 -1
  223. package/esm/typings/src/book-2.0/agent-source/string_book.d.ts +3 -0
  224. package/esm/typings/src/book-components/AvatarProfile/AvatarProfile/AvatarProfile.d.ts +6 -1
  225. package/esm/typings/src/book-components/BookEditor/BookEditor.d.ts +77 -7
  226. package/esm/typings/src/book-components/BookEditor/BookEditorActionbar.d.ts +14 -0
  227. package/esm/typings/src/book-components/Chat/AgentChat/AgentChat.d.ts +14 -0
  228. package/esm/typings/src/book-components/Chat/AgentChat/AgentChatProps.d.ts +13 -0
  229. package/esm/typings/src/book-components/Chat/Chat/ChatProps.d.ts +10 -0
  230. package/esm/typings/src/book-components/Chat/LlmChat/LlmChatProps.d.ts +5 -0
  231. package/esm/typings/src/book-components/Chat/MarkdownContent/MarkdownContent.d.ts +15 -0
  232. package/esm/typings/src/book-components/Chat/MockedChat/MockedChat.d.ts +5 -0
  233. package/esm/typings/src/book-components/Chat/save/_common/ChatSaveFormatDefinition.d.ts +1 -1
  234. package/esm/typings/src/book-components/Chat/save/html/htmlSaveFormatDefinition.d.ts +1 -0
  235. package/esm/typings/src/book-components/Chat/save/pdf/pdfSaveFormatDefinition.d.ts +4 -0
  236. package/esm/typings/src/book-components/Chat/types/ChatParticipant.d.ts +1 -1
  237. package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgent.d.ts +29 -0
  238. package/esm/typings/src/book-components/Qr/BrandedQrCode.d.ts +18 -0
  239. package/esm/typings/src/book-components/Qr/GenericQrCode.d.ts +10 -0
  240. package/esm/typings/src/book-components/Qr/PromptbookQrCode.d.ts +18 -0
  241. package/esm/typings/src/book-components/Qr/useQrCode.d.ts +15 -0
  242. package/esm/typings/src/book-components/_common/Dropdown/Dropdown.d.ts +15 -0
  243. package/esm/typings/src/book-components/_common/HamburgerMenu/HamburgerMenu.d.ts +12 -0
  244. package/esm/typings/src/book-components/_common/Modal/Modal.d.ts +2 -2
  245. package/esm/typings/src/book-components/_common/Tooltip/Tooltip.d.ts +47 -0
  246. package/esm/typings/src/book-components/icons/AboutIcon.d.ts +9 -0
  247. package/esm/typings/src/book-components/icons/CloseIcon.d.ts +4 -8
  248. package/esm/typings/src/book-components/icons/DownloadIcon.d.ts +9 -0
  249. package/esm/typings/src/book-components/icons/ExitFullscreenIcon.d.ts +7 -0
  250. package/esm/typings/src/book-components/icons/FullscreenIcon.d.ts +7 -0
  251. package/esm/typings/src/book-components/icons/MenuIcon.d.ts +12 -0
  252. package/esm/typings/src/book-components/icons/MicIcon.d.ts +8 -0
  253. package/esm/typings/src/cli/cli-commands/_boilerplate.d.ts +2 -1
  254. package/esm/typings/src/cli/cli-commands/about.d.ts +3 -1
  255. package/esm/typings/src/cli/cli-commands/hello.d.ts +2 -1
  256. package/esm/typings/src/cli/cli-commands/list-models.d.ts +2 -1
  257. package/esm/typings/src/cli/cli-commands/list-scrapers.d.ts +2 -1
  258. package/esm/typings/src/cli/cli-commands/login.d.ts +2 -1
  259. package/esm/typings/src/cli/cli-commands/make.d.ts +2 -1
  260. package/esm/typings/src/cli/cli-commands/prettify.d.ts +2 -1
  261. package/esm/typings/src/cli/cli-commands/run.d.ts +2 -1
  262. package/esm/typings/src/cli/cli-commands/{start-server.d.ts → start-agents-server.d.ts} +3 -2
  263. package/esm/typings/src/cli/cli-commands/start-pipelines-server.d.ts +15 -0
  264. package/esm/typings/src/cli/cli-commands/test-command.d.ts +2 -1
  265. package/esm/typings/src/cli/common/$addGlobalOptionsToCommand.d.ts +2 -1
  266. package/esm/typings/src/collection/agent-collection/AgentCollection.d.ts +12 -0
  267. package/esm/typings/src/collection/agent-collection/constructors/agent-collection-in-supabase/AgentCollectionInSupabase.d.ts +75 -0
  268. package/esm/typings/src/collection/agent-collection/constructors/agent-collection-in-supabase/AgentCollectionInSupabaseOptions.d.ts +10 -0
  269. package/esm/typings/src/collection/agent-collection/constructors/agent-collection-in-supabase/AgentsDatabaseSchema.d.ts +154 -0
  270. package/esm/typings/src/collection/{PipelineCollection.d.ts → pipeline-collection/PipelineCollection.d.ts} +7 -3
  271. package/esm/typings/src/collection/{SimplePipelineCollection.d.ts → pipeline-collection/SimplePipelineCollection.d.ts} +5 -5
  272. package/esm/typings/src/collection/{constructors/createCollectionFromDirectory.d.ts → pipeline-collection/constructors/createPipelineCollectionFromDirectory.d.ts} +8 -11
  273. package/esm/typings/src/collection/pipeline-collection/constructors/createPipelineCollectionFromJson.d.ts +13 -0
  274. package/esm/typings/src/collection/{constructors/createCollectionFromPromise.d.ts → pipeline-collection/constructors/createPipelineCollectionFromPromise.d.ts} +6 -5
  275. package/esm/typings/src/collection/pipeline-collection/constructors/createPipelineCollectionFromPromise.test.d.ts +1 -0
  276. package/esm/typings/src/collection/{constructors/createCollectionFromUrl.d.ts → pipeline-collection/constructors/createPipelineCollectionFromUrl.d.ts} +3 -3
  277. package/esm/typings/src/collection/{constructors/createSubcollection.d.ts → pipeline-collection/constructors/createPipelineSubcollection.d.ts} +3 -3
  278. package/esm/typings/src/collection/pipeline-collection/pipelineCollectionToJson.d.ts +13 -0
  279. package/esm/typings/src/commands/_common/types/CommandParser.d.ts +4 -5
  280. package/esm/typings/src/{book-2.0/commitments → commitments}/ACTION/ACTION.d.ts +5 -1
  281. package/esm/typings/src/commitments/CLOSED/CLOSED.d.ts +35 -0
  282. package/esm/typings/src/commitments/COMPONENT/COMPONENT.d.ts +28 -0
  283. package/esm/typings/src/{book-2.0/commitments → commitments}/DELETE/DELETE.d.ts +5 -1
  284. package/esm/typings/src/{book-2.0/commitments → commitments}/FORMAT/FORMAT.d.ts +5 -1
  285. package/esm/typings/src/commitments/FROM/FROM.d.ts +34 -0
  286. package/esm/typings/src/{book-2.0/commitments → commitments}/GOAL/GOAL.d.ts +5 -1
  287. package/esm/typings/src/{book-2.0/commitments → commitments}/KNOWLEDGE/KNOWLEDGE.d.ts +5 -5
  288. package/esm/typings/src/commitments/LANGUAGE/LANGUAGE.d.ts +35 -0
  289. package/esm/typings/src/{book-2.0/commitments → commitments}/MEMORY/MEMORY.d.ts +5 -1
  290. package/esm/typings/src/commitments/MESSAGE/AgentMessageCommitmentDefinition.d.ts +32 -0
  291. package/esm/typings/src/commitments/MESSAGE/InitialMessageCommitmentDefinition.d.ts +32 -0
  292. package/esm/typings/src/{book-2.0/commitments → commitments}/MESSAGE/MESSAGE.d.ts +5 -1
  293. package/esm/typings/src/commitments/MESSAGE/UserMessageCommitmentDefinition.d.ts +32 -0
  294. package/esm/typings/src/{book-2.0/commitments → commitments}/META/META.d.ts +5 -1
  295. package/esm/typings/src/commitments/META_COLOR/META_COLOR.d.ts +48 -0
  296. package/esm/typings/src/commitments/META_FONT/META_FONT.d.ts +42 -0
  297. package/esm/typings/src/{book-2.0/commitments → commitments}/META_IMAGE/META_IMAGE.d.ts +5 -1
  298. package/esm/typings/src/{book-2.0/commitments → commitments}/META_LINK/META_LINK.d.ts +5 -1
  299. package/esm/typings/src/{book-2.0/commitments → commitments}/MODEL/MODEL.d.ts +5 -1
  300. package/esm/typings/src/{book-2.0/commitments → commitments}/NOTE/NOTE.d.ts +5 -1
  301. package/esm/typings/src/commitments/OPEN/OPEN.d.ts +35 -0
  302. package/esm/typings/src/{book-2.0/commitments → commitments}/PERSONA/PERSONA.d.ts +5 -1
  303. package/esm/typings/src/{book-2.0/commitments → commitments}/RULE/RULE.d.ts +5 -1
  304. package/esm/typings/src/{book-2.0/commitments → commitments}/SAMPLE/SAMPLE.d.ts +5 -1
  305. package/esm/typings/src/{book-2.0/commitments → commitments}/SCENARIO/SCENARIO.d.ts +5 -1
  306. package/esm/typings/src/{book-2.0/commitments → commitments}/STYLE/STYLE.d.ts +5 -1
  307. package/esm/typings/src/commitments/USE/USE.d.ts +53 -0
  308. package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.d.ts +38 -0
  309. package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.test.d.ts +1 -0
  310. package/esm/typings/src/commitments/USE_MCP/USE_MCP.d.ts +37 -0
  311. package/esm/typings/src/commitments/USE_SEARCH_ENGINE/USE_SEARCH_ENGINE.d.ts +38 -0
  312. package/esm/typings/src/{book-2.0/commitments → commitments}/_base/BaseCommitmentDefinition.d.ts +8 -2
  313. package/esm/typings/src/{book-2.0/commitments → commitments}/_base/CommitmentDefinition.d.ts +6 -1
  314. package/esm/typings/src/{book-2.0/commitments → commitments}/_base/NotYetImplementedCommitmentDefinition.d.ts +5 -1
  315. package/esm/typings/src/{book-2.0/commitments → commitments}/_base/createEmptyAgentModelRequirements.d.ts +1 -1
  316. package/esm/typings/src/commitments/index.d.ts +93 -0
  317. package/esm/typings/src/config.d.ts +24 -3
  318. package/esm/typings/src/conversion/validation/validatePipeline.d.ts +2 -0
  319. package/esm/typings/src/errors/0-index.d.ts +6 -0
  320. package/esm/typings/src/errors/DatabaseError.d.ts +12 -0
  321. package/esm/typings/src/errors/NotAllowed.d.ts +9 -0
  322. package/esm/typings/src/errors/WrappedError.d.ts +2 -2
  323. package/esm/typings/src/execution/AvailableModel.d.ts +1 -0
  324. package/esm/typings/src/execution/Executables.d.ts +3 -0
  325. package/esm/typings/src/execution/ExecutionTask.d.ts +12 -3
  326. package/esm/typings/src/execution/ExecutionTools.d.ts +5 -0
  327. package/esm/typings/src/execution/FilesystemTools.d.ts +1 -1
  328. package/esm/typings/src/execution/LlmExecutionTools.d.ts +21 -1
  329. package/esm/typings/src/execution/createPipelineExecutor/10-executePipeline.d.ts +5 -0
  330. package/esm/typings/src/execution/createPipelineExecutor/20-executeTask.d.ts +5 -0
  331. package/esm/typings/src/execution/createPipelineExecutor/30-executeFormatSubvalues.d.ts +5 -0
  332. package/esm/typings/src/execution/createPipelineExecutor/40-executeAttempts.d.ts +5 -0
  333. package/esm/typings/src/execution/utils/usage-constants.d.ts +4 -124
  334. package/esm/typings/src/execution/utils/validatePromptResult.d.ts +2 -0
  335. package/esm/typings/src/high-level-abstractions/_common/HighLevelAbstraction.d.ts +2 -1
  336. package/esm/typings/src/llm-providers/_common/register/$provideLlmToolsForWizardOrCli.d.ts +2 -2
  337. package/esm/typings/src/llm-providers/_common/register/$registeredLlmToolsMessage.d.ts +2 -1
  338. package/esm/typings/src/llm-providers/_common/register/LlmToolsMetadata.d.ts +1 -1
  339. package/esm/typings/src/llm-providers/_common/utils/assertUniqueModels.d.ts +12 -0
  340. package/esm/typings/src/llm-providers/_multiple/getSingleLlmExecutionTools.d.ts +1 -0
  341. package/esm/typings/src/llm-providers/_multiple/joinLlmExecutionTools.d.ts +1 -0
  342. package/esm/typings/src/llm-providers/agent/Agent.d.ts +70 -0
  343. package/esm/typings/src/llm-providers/agent/AgentLlmExecutionTools.d.ts +26 -4
  344. package/esm/typings/src/llm-providers/agent/AgentOptions.d.ts +19 -0
  345. package/esm/typings/src/llm-providers/agent/CreateAgentLlmExecutionToolsOptions.d.ts +17 -0
  346. package/esm/typings/src/llm-providers/agent/RemoteAgent.d.ts +50 -0
  347. package/esm/typings/src/llm-providers/agent/RemoteAgentOptions.d.ts +11 -0
  348. package/esm/typings/src/llm-providers/agent/createAgentLlmExecutionTools.d.ts +1 -19
  349. package/esm/typings/src/llm-providers/anthropic-claude/anthropic-claude-models.d.ts +1 -1
  350. package/esm/typings/src/llm-providers/google/google-models.d.ts +1 -1
  351. package/esm/typings/src/llm-providers/openai/OpenAiAssistantExecutionTools.d.ts +60 -2
  352. package/esm/typings/src/llm-providers/openai/OpenAiAssistantExecutionToolsOptions.d.ts +7 -1
  353. package/esm/typings/src/llm-providers/openai/openai-models.d.ts +1 -1
  354. package/esm/typings/src/llm-providers/openai/openai-models.test.d.ts +4 -0
  355. package/esm/typings/src/other/templates/getTemplatesPipelineCollection.d.ts +1 -1
  356. package/esm/typings/src/pipeline/validatePipelineString.d.ts +2 -0
  357. package/esm/typings/src/playground/permanent/_boilerplate.d.ts +5 -0
  358. package/esm/typings/src/playground/permanent/agent-with-browser-playground.d.ts +5 -0
  359. package/esm/typings/src/prepare/PrepareAndScrapeOptions.d.ts +1 -0
  360. package/esm/typings/src/remote-server/startAgentServer.d.ts +26 -0
  361. package/esm/typings/src/remote-server/startRemoteServer.d.ts +4 -1
  362. package/esm/typings/src/remote-server/types/RemoteServerOptions.d.ts +3 -8
  363. package/esm/typings/src/scrapers/_boilerplate/createBoilerplateScraper.d.ts +1 -12
  364. package/esm/typings/src/scrapers/_boilerplate/register-metadata.d.ts +1 -9
  365. package/esm/typings/src/scrapers/document/createDocumentScraper.d.ts +1 -12
  366. package/esm/typings/src/scrapers/document/register-metadata.d.ts +1 -9
  367. package/esm/typings/src/scrapers/document-legacy/createLegacyDocumentScraper.d.ts +1 -12
  368. package/esm/typings/src/scrapers/document-legacy/register-metadata.d.ts +1 -9
  369. package/esm/typings/src/scrapers/markdown/createMarkdownScraper.d.ts +1 -12
  370. package/esm/typings/src/scrapers/markdown/register-metadata.d.ts +1 -9
  371. package/esm/typings/src/scrapers/markitdown/createMarkitdownScraper.d.ts +1 -12
  372. package/esm/typings/src/scrapers/markitdown/register-metadata.d.ts +1 -9
  373. package/esm/typings/src/scrapers/pdf/createPdfScraper.d.ts +1 -12
  374. package/esm/typings/src/scrapers/pdf/register-metadata.d.ts +1 -9
  375. package/esm/typings/src/scrapers/website/createWebsiteScraper.d.ts +1 -12
  376. package/esm/typings/src/scrapers/website/register-metadata.d.ts +1 -9
  377. package/esm/typings/src/storage/_common/PromptbookStorage.d.ts +1 -0
  378. package/esm/typings/src/storage/env-storage/$EnvStorage.d.ts +2 -1
  379. package/esm/typings/src/transpilers/_common/BookTranspiler.d.ts +33 -0
  380. package/esm/typings/src/transpilers/_common/BookTranspilerOptions.d.ts +18 -0
  381. package/esm/typings/src/transpilers/_common/register/$bookTranspilersRegister.d.ts +15 -0
  382. package/esm/typings/src/transpilers/formatted-book-in-markdown/FormattedBookInMarkdownTranspiler.d.ts +16 -0
  383. package/esm/typings/src/transpilers/formatted-book-in-markdown/register.d.ts +15 -0
  384. package/esm/typings/src/transpilers/openai-sdk/OpenAiSdkTranspiler.d.ts +16 -0
  385. package/esm/typings/src/transpilers/openai-sdk/OpenAiSdkTranspiler.test.d.ts +1 -0
  386. package/esm/typings/src/transpilers/openai-sdk/playground/playground.d.ts +5 -0
  387. package/esm/typings/src/transpilers/openai-sdk/register.d.ts +15 -0
  388. package/esm/typings/src/types/LlmCall.d.ts +20 -0
  389. package/esm/typings/src/types/Updatable.d.ts +19 -0
  390. package/esm/typings/src/types/typeAliases.d.ts +32 -2
  391. package/esm/typings/src/utils/color/$randomColor.d.ts +1 -0
  392. package/esm/typings/src/utils/color/Color.d.ts +15 -0
  393. package/esm/typings/src/utils/color/Color.test.d.ts +1 -0
  394. package/esm/typings/src/utils/color/css-colors.d.ts +1 -0
  395. package/esm/typings/src/utils/color/internal-utils/checkChannelValue.d.ts +0 -3
  396. package/esm/typings/src/utils/color/operators/darken.d.ts +1 -1
  397. package/esm/typings/src/utils/color/operators/grayscale.d.ts +1 -1
  398. package/esm/typings/src/utils/color/operators/lighten.d.ts +1 -1
  399. package/esm/typings/src/utils/color/operators/mixWithColor.d.ts +1 -1
  400. package/esm/typings/src/utils/color/operators/saturate.d.ts +1 -1
  401. package/esm/typings/src/utils/environment/$detectRuntimeEnvironment.d.ts +16 -0
  402. package/esm/typings/src/utils/environment/$getGlobalScope.d.ts +2 -2
  403. package/esm/typings/src/utils/execCommand/$execCommand.d.ts +2 -1
  404. package/esm/typings/src/utils/execCommand/$execCommands.d.ts +2 -1
  405. package/esm/typings/src/utils/files/$induceBookDownload.d.ts +13 -0
  406. package/esm/typings/src/utils/files/$induceFileDownload.d.ts +13 -0
  407. package/esm/typings/src/utils/files/ObjectUrl.d.ts +46 -0
  408. package/esm/typings/src/utils/files/listAllFiles.d.ts +2 -3
  409. package/esm/typings/src/utils/misc/aboutPromptbookInformation.d.ts +27 -0
  410. package/esm/typings/src/utils/misc/computeHash.d.ts +11 -0
  411. package/esm/typings/src/utils/misc/computeHash.test.d.ts +1 -0
  412. package/esm/typings/src/utils/misc/xAboutPromptbookInformation.d.ts +13 -0
  413. package/esm/typings/src/utils/normalization/normalize-to-kebab-case.d.ts +2 -0
  414. package/esm/typings/src/utils/normalization/normalizeMessageText.d.ts +9 -0
  415. package/esm/typings/src/utils/normalization/normalizeMessageText.test.d.ts +1 -0
  416. package/esm/typings/src/utils/normalization/normalizeTo_PascalCase.d.ts +3 -0
  417. package/esm/typings/src/utils/normalization/normalizeTo_camelCase.d.ts +2 -0
  418. package/esm/typings/src/utils/normalization/titleToName.d.ts +2 -0
  419. package/esm/typings/src/utils/organization/$sideEffect.d.ts +2 -2
  420. package/esm/typings/src/utils/organization/$side_effect.d.ts +7 -0
  421. package/esm/typings/src/utils/organization/TODO_USE.d.ts +2 -2
  422. package/esm/typings/src/utils/organization/keepUnused.d.ts +2 -2
  423. package/esm/typings/src/utils/organization/preserve.d.ts +3 -3
  424. package/esm/typings/src/utils/organization/really_any.d.ts +7 -0
  425. package/esm/typings/src/utils/random/$generateBookBoilerplate.d.ts +25 -0
  426. package/esm/typings/src/utils/random/$randomAgentPersona.d.ts +9 -0
  427. package/esm/typings/src/utils/random/$randomFullnameWithColor.d.ts +13 -0
  428. package/esm/typings/src/utils/random/$randomItem.d.ts +9 -0
  429. package/esm/typings/src/utils/random/$randomSeed.d.ts +3 -0
  430. package/esm/typings/src/utils/random/$randomToken.d.ts +2 -0
  431. package/esm/typings/src/utils/serialization/$deepFreeze.d.ts +2 -1
  432. package/esm/typings/src/utils/serialization/asSerializable.d.ts +2 -2
  433. package/esm/typings/src/utils/serialization/serializeToPromptbookJavascript.d.ts +2 -2
  434. package/esm/typings/src/utils/validators/parameterName/validateParameterName.d.ts +2 -0
  435. package/esm/typings/src/version.d.ts +1 -1
  436. package/esm/typings/src/wizard/$getCompiledBook.d.ts +1 -2
  437. package/package.json +15 -15
  438. package/umd/index.umd.js +5089 -356
  439. package/umd/index.umd.js.map +1 -1
  440. package/esm/typings/src/book-2.0/commitments/index.d.ts +0 -60
  441. package/esm/typings/src/book-components/BookEditor/config.d.ts +0 -11
  442. package/esm/typings/src/book-components/Chat/utils/renderMarkdown.d.ts +0 -21
  443. package/esm/typings/src/collection/collectionToJson.d.ts +0 -13
  444. package/esm/typings/src/collection/constructors/createCollectionFromJson.d.ts +0 -13
  445. /package/esm/typings/src/{book-components/Chat/utils/renderMarkdown.test.d.ts → book-2.0/agent-source/computeAgentHash.test.d.ts} +0 -0
  446. /package/esm/typings/src/{collection/constructors/createCollectionFromDirectory.test.d.ts → book-2.0/agent-source/normalizeAgentName.test.d.ts} +0 -0
  447. /package/esm/typings/src/{collection/constructors/createCollectionFromJson.test.d.ts → book-components/Chat/AgentChat/AgentChat.test.d.ts} +0 -0
  448. /package/esm/typings/src/collection/{constructors/createCollectionFromPromise.test.d.ts → pipeline-collection/constructors/createPipelineCollectionFromDirectory.test.d.ts} +0 -0
  449. /package/esm/typings/src/{commands/_common/parseCommand.test.d.ts → collection/pipeline-collection/constructors/createPipelineCollectionFromJson.test.d.ts} +0 -0
  450. /package/esm/typings/src/collection/{collectionToJson.test.d.ts → pipeline-collection/pipelineCollectionToJson.test.d.ts} +0 -0
  451. /package/esm/typings/src/{book-2.0/commitments → commitments}/_base/BookCommitment.d.ts +0 -0
  452. /package/esm/typings/src/{book-2.0/commitments → commitments}/_base/ParsedCommitment.d.ts +0 -0
@@ -0,0 +1,147 @@
1
+ import { NextRequest, NextResponse } from 'next/server';
2
+ import { $getTableName } from '../../../database/$getTableName';
3
+ import { $provideSupabase } from '../../../database/$provideSupabase';
4
+ import { isUserAdmin } from '../../../utils/isUserAdmin';
5
+
6
+ const DEFAULT_PAGE_SIZE = 20;
7
+ const MAX_PAGE_SIZE = 100;
8
+
9
+ type SortField = 'createdAt' | 'agentName' | 'id';
10
+ type SortOrder = 'asc' | 'desc';
11
+
12
+ function parsePositiveInt(value: string | null, fallback: number): number {
13
+ if (!value) return fallback;
14
+ const parsed = parseInt(value, 10);
15
+ if (Number.isNaN(parsed) || parsed <= 0) return fallback;
16
+ return parsed;
17
+ }
18
+
19
+ function parseSortField(value: string | null): SortField {
20
+ if (value === 'agentName' || value === 'id') return value;
21
+ return 'createdAt';
22
+ }
23
+
24
+ function parseSortOrder(value: string | null): SortOrder {
25
+ return value === 'asc' ? 'asc' : 'desc';
26
+ }
27
+
28
+ /**
29
+ * List chat history with filters, search and pagination.
30
+ *
31
+ * Query params:
32
+ * - page: number (1-based)
33
+ * - pageSize: number (items per page)
34
+ * - agentName: filter by agent name
35
+ * - search: free-text search across agentName, url and ip
36
+ * - sortBy: createdAt | agentName | id (default: createdAt)
37
+ * - sortOrder: asc | desc (default: desc)
38
+ */
39
+ export async function GET(request: NextRequest) {
40
+ if (!(await isUserAdmin())) {
41
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
42
+ }
43
+
44
+ try {
45
+ const searchParams = request.nextUrl.searchParams;
46
+
47
+ const page = parsePositiveInt(searchParams.get('page'), 1);
48
+ const pageSize = Math.min(
49
+ MAX_PAGE_SIZE,
50
+ parsePositiveInt(searchParams.get('pageSize'), DEFAULT_PAGE_SIZE),
51
+ );
52
+ const agentName = searchParams.get('agentName');
53
+ const search = searchParams.get('search')?.trim() || '';
54
+ const sortBy = parseSortField(searchParams.get('sortBy'));
55
+ const sortOrder = parseSortOrder(searchParams.get('sortOrder'));
56
+
57
+ const supabase = $provideSupabase();
58
+ const table = await $getTableName('ChatHistory');
59
+
60
+ let query = supabase
61
+ .from(table)
62
+ .select('*', { count: 'exact' });
63
+
64
+ if (agentName) {
65
+ query = query.eq('agentName', agentName);
66
+ }
67
+
68
+ if (search) {
69
+ // Note: We intentionally limit search to simple text columns
70
+ // to keep the query portable and efficient.
71
+ //
72
+ // This searches across:
73
+ // - agentName
74
+ // - url
75
+ // - ip
76
+ const escaped = search.replace(/%/g, '\\%').replace(/_/g, '\\_');
77
+ query = query.or(
78
+ `agentName.ilike.%${escaped}%,url.ilike.%${escaped}%,ip.ilike.%${escaped}%`,
79
+ );
80
+ }
81
+
82
+ query = query.order(sortBy, { ascending: sortOrder === 'asc' });
83
+
84
+ const from = (page - 1) * pageSize;
85
+ const to = from + pageSize - 1;
86
+
87
+ query = query.range(from, to);
88
+
89
+ const { data, error, count } = await query;
90
+
91
+ if (error) {
92
+ console.error('List chat history error:', error);
93
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
94
+ }
95
+
96
+ return NextResponse.json({
97
+ items: data ?? [],
98
+ total: count ?? 0,
99
+ page,
100
+ pageSize,
101
+ sortBy,
102
+ sortOrder,
103
+ });
104
+ } catch (error) {
105
+ console.error('List chat history error:', error);
106
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
107
+ }
108
+ }
109
+
110
+ /**
111
+ * Delete chat history for a specific agent.
112
+ *
113
+ * Query params:
114
+ * - agentName: name of the agent whose history should be removed
115
+ */
116
+ export async function DELETE(request: NextRequest) {
117
+ if (!(await isUserAdmin())) {
118
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
119
+ }
120
+
121
+ const searchParams = request.nextUrl.searchParams;
122
+ const agentName = searchParams.get('agentName');
123
+
124
+ if (!agentName) {
125
+ return NextResponse.json({ error: 'agentName is required' }, { status: 400 });
126
+ }
127
+
128
+ try {
129
+ const supabase = $provideSupabase();
130
+ const table = await $getTableName('ChatHistory');
131
+
132
+ const { error } = await supabase
133
+ .from(table)
134
+ .delete()
135
+ .eq('agentName', agentName);
136
+
137
+ if (error) {
138
+ console.error('Clear chat history error:', error);
139
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
140
+ }
141
+
142
+ return NextResponse.json({ success: true });
143
+ } catch (error) {
144
+ console.error('Clear chat history error:', error);
145
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
146
+ }
147
+ }
@@ -0,0 +1,48 @@
1
+ import { OpenAI } from 'openai';
2
+ import { forTime } from 'waitasecond';
3
+
4
+ export async function GET(request: Request) {
5
+ const { searchParams } = new URL(request.url);
6
+ const message = searchParams.get('message') || 'Hello, who are you?';
7
+
8
+ const openaiClient = new OpenAI({
9
+ apiKey: process.env.OPENAI_API_KEY,
10
+ });
11
+
12
+ // Enable streaming from OpenAI
13
+ const stream = await openaiClient.chat.completions.create({
14
+ model: 'gpt-3.5-turbo',
15
+ messages: [
16
+ { role: 'system', content: 'You are a helpful assistant.' },
17
+ { role: 'user', content: message },
18
+ ],
19
+ stream: true,
20
+ });
21
+
22
+ // Create a ReadableStream to send chunks to the client as they arrive
23
+ const readableStream = new ReadableStream({
24
+ async start(controller) {
25
+ for await (const chunk of stream) {
26
+ // Each chunk contains a delta message
27
+ const content = chunk.choices[0]?.delta?.content;
28
+ if (content) {
29
+ controller.enqueue(new TextEncoder().encode(content));
30
+ }
31
+ }
32
+
33
+ await forTime(100);
34
+ controller.enqueue(new TextEncoder().encode('\n\n[DONE]'));
35
+
36
+ controller.close();
37
+ },
38
+ });
39
+
40
+ return new Response(readableStream, {
41
+ status: 200,
42
+ headers: { 'Content-Type': 'text/markdown' },
43
+ });
44
+ }
45
+
46
+ /**
47
+ * Note: [🐚] This is how streaming is implemented correctly
48
+ */
@@ -0,0 +1,93 @@
1
+ import { NextRequest, NextResponse } from 'next/server';
2
+
3
+ export async function GET(request: NextRequest) {
4
+ const protocol = request.nextUrl.protocol;
5
+ const host = request.nextUrl.host;
6
+ const baseUrl = `${protocol}//${host}`;
7
+
8
+ const script = `
9
+ (function() {
10
+ if (customElements.get('promptbook-agent')) {
11
+ return;
12
+ }
13
+
14
+ class PromptbookAgentElement extends HTMLElement {
15
+ constructor() {
16
+ super();
17
+ this.iframe = null;
18
+ }
19
+
20
+ static get observedAttributes() {
21
+ return ['agent-url'];
22
+ }
23
+
24
+ connectedCallback() {
25
+ this.render();
26
+ window.addEventListener('message', this.handleMessage.bind(this));
27
+ }
28
+
29
+ disconnectedCallback() {
30
+ window.removeEventListener('message', this.handleMessage.bind(this));
31
+ }
32
+
33
+ attributeChangedCallback(name, oldValue, newValue) {
34
+ if (name === 'agent-url' && oldValue !== newValue) {
35
+ this.render();
36
+ }
37
+ }
38
+
39
+ handleMessage(event) {
40
+ if (event.data && event.data.type === 'PROMPTBOOK_AGENT_RESIZE') {
41
+ if (event.data.isOpen) {
42
+ this.iframe.style.width = '450px';
43
+ this.iframe.style.height = '650px';
44
+ this.iframe.style.maxHeight = '90vh';
45
+ this.iframe.style.maxWidth = '90vw';
46
+ this.iframe.style.boxShadow = '0 4px 12px rgba(0,0,0,0.15)';
47
+ this.iframe.style.borderRadius = '12px';
48
+ } else {
49
+ this.iframe.style.width = '60px';
50
+ this.iframe.style.height = '60px';
51
+ this.iframe.style.boxShadow = 'none';
52
+ this.iframe.style.borderRadius = '0';
53
+ }
54
+ }
55
+ }
56
+
57
+ render() {
58
+ const agentUrl = this.getAttribute('agent-url');
59
+ if (!agentUrl) return;
60
+
61
+ if (!this.iframe) {
62
+ this.attachShadow({ mode: 'open' });
63
+ this.iframe = document.createElement('iframe');
64
+ this.iframe.style.border = 'none';
65
+ this.iframe.style.position = 'fixed';
66
+ this.iframe.style.bottom = '20px';
67
+ this.iframe.style.right = '20px';
68
+ this.iframe.style.width = '60px';
69
+ this.iframe.style.height = '60px';
70
+ this.iframe.style.zIndex = '2147483647'; // Max z-index
71
+ this.iframe.style.transition = 'width 0.3s ease, height 0.3s ease';
72
+ this.iframe.style.backgroundColor = 'transparent';
73
+ this.iframe.setAttribute('allow', 'microphone'); // Allow microphone if needed for voice
74
+ this.shadowRoot.appendChild(this.iframe);
75
+ }
76
+
77
+ // Construct embed URL pointing to the Next.js page we created
78
+ const embedUrl = '${baseUrl}/embed?agentUrl=' + encodeURIComponent(agentUrl);
79
+ this.iframe.src = embedUrl;
80
+ }
81
+ }
82
+
83
+ customElements.define('promptbook-agent', PromptbookAgentElement);
84
+ })();
85
+ `;
86
+
87
+ return new NextResponse(script, {
88
+ headers: {
89
+ 'Content-Type': 'application/javascript',
90
+ 'Access-Control-Allow-Origin': '*',
91
+ },
92
+ });
93
+ }
@@ -0,0 +1,17 @@
1
+ import { NextResponse } from 'next/server';
2
+ import { getFederatedServersFromMetadata } from '../../../utils/getFederatedServersFromMetadata';
3
+
4
+ export const dynamic = 'force-dynamic';
5
+
6
+ export async function GET() {
7
+ try {
8
+ const federatedServers = await getFederatedServersFromMetadata();
9
+
10
+ return NextResponse.json({
11
+ federatedServers,
12
+ });
13
+ } catch (error) {
14
+ console.error('Error fetching federated servers:', error);
15
+ return NextResponse.json({ error: 'Failed to fetch federated servers' }, { status: 500 });
16
+ }
17
+ }
@@ -0,0 +1,7 @@
1
+ import { NextResponse } from 'next/server';
2
+ import { getLongRunningTask } from '../../../deamons/longRunningTask';
3
+
4
+ export function GET() {
5
+ const task = getLongRunningTask();
6
+ return NextResponse.json(task);
7
+ }
@@ -0,0 +1,20 @@
1
+ import { forTime } from 'waitasecond';
2
+ import { just } from '../../../../../../src/utils/organization/just';
3
+
4
+ export async function GET() {
5
+ const readableStream = new ReadableStream({
6
+ async start(controller) {
7
+ while (just(true)) {
8
+ await forTime(100);
9
+ controller.enqueue(new TextEncoder().encode('x'));
10
+ }
11
+
12
+ controller.close();
13
+ },
14
+ });
15
+
16
+ return new Response(readableStream, {
17
+ status: 200,
18
+ headers: { 'Content-Type': 'text/plain' },
19
+ });
20
+ }
@@ -0,0 +1,116 @@
1
+ import { $getTableName } from '../../../database/$getTableName';
2
+ import { $provideSupabase } from '../../../database/$provideSupabase';
3
+ import { isUserAdmin } from '../../../utils/isUserAdmin';
4
+ import { NextRequest, NextResponse } from 'next/server';
5
+
6
+ export async function GET(request: NextRequest) {
7
+ if (!(await isUserAdmin())) {
8
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
9
+ }
10
+
11
+ const supabase = $provideSupabase();
12
+ const table = await $getTableName('Metadata');
13
+
14
+ const { data, error } = await supabase.from(table).select('*').order('key');
15
+
16
+ if (error) {
17
+ return NextResponse.json({ error: error.message }, { status: 500 });
18
+ }
19
+
20
+ return NextResponse.json(data);
21
+ }
22
+
23
+ export async function POST(request: NextRequest) {
24
+ if (!(await isUserAdmin())) {
25
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
26
+ }
27
+
28
+ try {
29
+ const body = await request.json();
30
+ const { key, value, note } = body;
31
+
32
+ if (!key || !value) {
33
+ return NextResponse.json({ error: 'Key and value are required' }, { status: 400 });
34
+ }
35
+
36
+ const supabase = $provideSupabase();
37
+ const table = await $getTableName('Metadata');
38
+
39
+ const { data, error } = await supabase
40
+ .from(table)
41
+ .insert({ key, value, note })
42
+ .select()
43
+ .single();
44
+
45
+ if (error) {
46
+ return NextResponse.json({ error: error.message }, { status: 500 });
47
+ }
48
+
49
+ return NextResponse.json(data);
50
+ } catch (e) {
51
+ return NextResponse.json({ error: 'Invalid request body' }, { status: 400 });
52
+ }
53
+ }
54
+
55
+ export async function PUT(request: NextRequest) {
56
+ if (!(await isUserAdmin())) {
57
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
58
+ }
59
+
60
+ try {
61
+ const body = await request.json();
62
+ const { key, value, note } = body;
63
+
64
+ if (!key || !value) {
65
+ return NextResponse.json({ error: 'Key and value are required' }, { status: 400 });
66
+ }
67
+
68
+ const supabase = $provideSupabase();
69
+ const table = await $getTableName('Metadata');
70
+
71
+ // Using upsert if it exists or update if strict
72
+ // Since key is unique, upsert works well, but usually PUT implies update.
73
+ // Let's use update to be safe and explicit about editing existing.
74
+ // Actually, for editing, we identify by ID or Key.
75
+ // Let's use Key as identifier since it is unique.
76
+
77
+ const { data, error } = await supabase
78
+ .from(table)
79
+ .update({ value, note, updatedAt: new Date().toISOString() })
80
+ .eq('key', key)
81
+ .select()
82
+ .single();
83
+
84
+ if (error) {
85
+ return NextResponse.json({ error: error.message }, { status: 500 });
86
+ }
87
+
88
+ return NextResponse.json(data);
89
+ } catch (e) {
90
+ return NextResponse.json({ error: 'Invalid request body' }, { status: 400 });
91
+ }
92
+ }
93
+
94
+ export async function DELETE(request: NextRequest) {
95
+ if (!(await isUserAdmin())) {
96
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
97
+ }
98
+
99
+ const searchParams = request.nextUrl.searchParams;
100
+ const key = searchParams.get('key');
101
+
102
+ if (!key) {
103
+ return NextResponse.json({ error: 'Key is required' }, { status: 400 });
104
+ }
105
+
106
+ const supabase = $provideSupabase();
107
+ const table = await $getTableName('Metadata');
108
+
109
+ const { error } = await supabase.from(table).delete().eq('key', key);
110
+
111
+ if (error) {
112
+ return NextResponse.json({ error: error.message }, { status: 500 });
113
+ }
114
+
115
+ return NextResponse.json({ success: true });
116
+ }
@@ -0,0 +1,6 @@
1
+ import { handleChatCompletion } from '@/src/utils/handleChatCompletion';
2
+ import { NextRequest } from 'next/server';
3
+
4
+ export async function POST(request: NextRequest) {
5
+ return handleChatCompletion(request, {}, 'OpenAI API Chat Completion (Global)');
6
+ }
@@ -0,0 +1,65 @@
1
+ import { $provideAgentCollectionForServer } from '@/src/tools/$provideAgentCollectionForServer';
2
+ import { validateApiKey } from '@/src/utils/validateApiKey';
3
+ import { NextRequest, NextResponse } from 'next/server';
4
+
5
+ /**
6
+ * GET /api/openai/v1/models
7
+ *
8
+ * Lists all available agents as models for the OpenAI-compatible API.
9
+ */
10
+ export async function GET(request: NextRequest) {
11
+ // Validate API key explicitly (in addition to middleware)
12
+ const apiKeyValidation = await validateApiKey(request);
13
+ if (!apiKeyValidation.isValid) {
14
+ return NextResponse.json(
15
+ {
16
+ error: {
17
+ message: apiKeyValidation.error || 'Invalid API key',
18
+ type: 'authentication_error',
19
+ },
20
+ },
21
+ { status: 401 },
22
+ );
23
+ }
24
+
25
+ try {
26
+ const collection = await $provideAgentCollectionForServer();
27
+ const agentNames = await collection.listAgents();
28
+
29
+ const models = agentNames.map((agentName) => ({
30
+ id: agentName,
31
+ object: 'model',
32
+ created: Math.floor(Date.now() / 1000), // We don't have creation date readily available in listAgents
33
+ owned_by: 'promptbook',
34
+ permission: [
35
+ {
36
+ id: `modelperm-${agentName}`,
37
+ object: 'model_permission',
38
+ created: Math.floor(Date.now() / 1000),
39
+ allow_create_engine: false,
40
+ allow_sampling: true,
41
+ allow_logprobs: false,
42
+ allow_search_indices: false,
43
+ allow_view: true,
44
+ allow_fine_tuning: false,
45
+ organization: '*',
46
+ group: null,
47
+ is_blocking: false,
48
+ },
49
+ ],
50
+ root: agentName,
51
+ parent: null,
52
+ }));
53
+
54
+ return NextResponse.json({
55
+ object: 'list',
56
+ data: models,
57
+ });
58
+ } catch (error) {
59
+ console.error('Error in models listing handler:', error);
60
+ return NextResponse.json(
61
+ { error: { message: (error as Error).message || 'Internal Server Error', type: 'server_error' } },
62
+ { status: 500 },
63
+ );
64
+ }
65
+ }
@@ -0,0 +1,83 @@
1
+ import { nextRequestToNodeRequest } from '@/src/utils/cdn/utils/nextRequestToNodeRequest';
2
+ import { TODO_any } from '@promptbook-local/types';
3
+ import { serializeError } from '@promptbook-local/utils';
4
+ import formidable from 'formidable';
5
+ import { readFile } from 'fs/promises';
6
+ import { NextRequest, NextResponse } from 'next/server';
7
+ import { forTime } from 'waitasecond';
8
+ import { assertsError } from '../../../../../../src/errors/assertsError';
9
+ import { string_url } from '../../../../../../src/types/typeAliases';
10
+ import { keepUnused } from '../../../../../../src/utils/organization/keepUnused';
11
+ import { $provideCdnForServer } from '../../../../src/tools/$provideCdnForServer';
12
+ import { getUserFileCdnKey } from '../../../../src/utils/cdn/utils/getUserFileCdnKey';
13
+ import { validateMimeType } from '../../../../src/utils/validators/validateMimeType';
14
+ import { getMetadata } from '../../../database/getMetadata';
15
+
16
+ export async function POST(request: NextRequest) {
17
+ try {
18
+ await forTime(1);
19
+ // await forTime(5000);
20
+
21
+ const nodeRequest = await nextRequestToNodeRequest(request);
22
+ let maxFileSizeMb = Number((await getMetadata('MAX_FILE_UPLOAD_SIZE_MB')) || '50'); // <- TODO: [🌲] To /config.ts
23
+
24
+ if (Number.isNaN(maxFileSizeMb)) {
25
+ maxFileSizeMb = 50; // <- TODO: [🌲] To /config.ts
26
+ }
27
+
28
+ const maxFileSize = maxFileSizeMb * 1024 * 1024;
29
+
30
+ const files = await new Promise<formidable.Files>((resolve, reject) => {
31
+ const form = formidable({ maxFileSize });
32
+ form.parse(nodeRequest as TODO_any, (error, fields, files) => {
33
+ keepUnused(fields);
34
+
35
+ if (error) {
36
+ return reject(error);
37
+ }
38
+ resolve(files);
39
+ });
40
+ });
41
+
42
+ const uploadedFiles = files.file;
43
+
44
+ if (!uploadedFiles || uploadedFiles.length !== 1) {
45
+ return NextResponse.json(
46
+ { message: 'In form data there is not EXACTLY one "file" field' },
47
+ { status: 400 },
48
+ );
49
+ }
50
+
51
+ const uploadedFile = uploadedFiles[0]!;
52
+ const fileBuffer = await readFile(uploadedFile.filepath);
53
+ const cdn = $provideCdnForServer();
54
+ const key = getUserFileCdnKey(fileBuffer, uploadedFile.originalFilename || uploadedFile.newFilename);
55
+
56
+ await cdn.setItem(key, {
57
+ type: validateMimeType(uploadedFile.mimetype),
58
+ data: fileBuffer,
59
+ });
60
+
61
+ const fileUrl = cdn.getItemUrl(key);
62
+
63
+ return NextResponse.json({ fileUrl: fileUrl.href as string_url }, { status: 201 });
64
+ } catch (error) {
65
+ assertsError(error);
66
+
67
+ console.error(error);
68
+
69
+ return new Response(
70
+ JSON.stringify(
71
+ serializeError(error),
72
+ // <- TODO: [🐱‍🚀] Rename `serializeError` to `errorToJson`
73
+ null,
74
+ 4,
75
+ // <- TODO: [🐱‍🚀] Allow to configure pretty print for agent server
76
+ ),
77
+ {
78
+ status: 400, // <- TODO: [🐱‍🚀] Make `errorToHttpStatusCode`
79
+ headers: { 'Content-Type': 'application/json' },
80
+ },
81
+ );
82
+ }
83
+ }
@@ -0,0 +1,75 @@
1
+ import { $getTableName } from '@/src/database/$getTableName';
2
+ import { NextResponse } from 'next/server';
3
+ import { $provideSupabaseForServer } from '../../../../database/$provideSupabaseForServer';
4
+ import { hashPassword } from '../../../../utils/auth';
5
+ import { isUserAdmin } from '../../../../utils/isUserAdmin';
6
+
7
+ export async function PATCH(request: Request, { params }: { params: Promise<{ username: string }> }) {
8
+ if (!(await isUserAdmin())) {
9
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
10
+ }
11
+
12
+ try {
13
+ const { username: usernameParam } = await params;
14
+ const body = await request.json();
15
+ const { password, isAdmin } = body;
16
+
17
+ const updates: { updatedAt: string; passwordHash?: string; isAdmin?: boolean } = {
18
+ updatedAt: new Date().toISOString(),
19
+ };
20
+
21
+ if (password) {
22
+ updates.passwordHash = await hashPassword(password);
23
+ }
24
+
25
+ if (typeof isAdmin === 'boolean') {
26
+ updates.isAdmin = isAdmin;
27
+ }
28
+
29
+ const supabase = $provideSupabaseForServer();
30
+ const { data: updatedUser, error } = await supabase
31
+ .from(await $getTableName('User'))
32
+ .update(updates)
33
+ .eq('username', usernameParam)
34
+ .select('id, username, createdAt, updatedAt, isAdmin')
35
+ .single();
36
+
37
+ if (error) {
38
+ throw error;
39
+ }
40
+
41
+ if (!updatedUser) {
42
+ return NextResponse.json({ error: 'User not found' }, { status: 404 });
43
+ }
44
+
45
+ return NextResponse.json(updatedUser);
46
+ } catch (error) {
47
+ console.error('Update user error:', error);
48
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
49
+ }
50
+ }
51
+
52
+ export async function DELETE(request: Request, { params }: { params: Promise<{ username: string }> }) {
53
+ if (!(await isUserAdmin())) {
54
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
55
+ }
56
+
57
+ try {
58
+ const { username: usernameParam } = await params;
59
+ const supabase = $provideSupabaseForServer();
60
+
61
+ const { error } = await supabase
62
+ .from(await $getTableName('User'))
63
+ .delete()
64
+ .eq('username', usernameParam);
65
+
66
+ if (error) {
67
+ throw error;
68
+ }
69
+
70
+ return NextResponse.json({ success: true });
71
+ } catch (error) {
72
+ console.error('Delete user error:', error);
73
+ return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
74
+ }
75
+ }