@promptbook/cli 0.104.0-1 → 0.104.0-3

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 (128) hide show
  1. package/apps/agents-server/next.config.ts +2 -2
  2. package/apps/agents-server/package.json +7 -3
  3. package/apps/agents-server/public/fonts/OpenMoji-color-cbdt.woff2 +0 -0
  4. package/apps/agents-server/public/swagger.json +115 -0
  5. package/apps/agents-server/scripts/generate-reserved-paths/generate-reserved-paths.ts +54 -0
  6. package/apps/agents-server/scripts/generate-reserved-paths/tsconfig.json +19 -0
  7. package/apps/agents-server/src/app/AddAgentButton.tsx +3 -3
  8. package/apps/agents-server/src/app/actions.ts +17 -5
  9. package/apps/agents-server/src/app/admin/chat-feedback/ChatFeedbackClient.tsx +221 -274
  10. package/apps/agents-server/src/app/admin/chat-history/ChatHistoryClient.tsx +94 -137
  11. package/apps/agents-server/src/app/admin/metadata/MetadataClient.tsx +23 -19
  12. package/apps/agents-server/src/app/agents/[agentName]/AgentChatWrapper.tsx +15 -1
  13. package/apps/agents-server/src/app/agents/[agentName]/AgentOptionsMenu.tsx +51 -9
  14. package/apps/agents-server/src/app/agents/[agentName]/AgentProfileChat.tsx +47 -4
  15. package/apps/agents-server/src/app/agents/[agentName]/AgentProfileWrapper.tsx +2 -0
  16. package/apps/agents-server/src/app/agents/[agentName]/_utils.ts +18 -0
  17. package/apps/agents-server/src/app/agents/[agentName]/agentLinks.tsx +8 -8
  18. package/apps/agents-server/src/app/agents/[agentName]/api/agents/route.ts +17 -26
  19. package/apps/agents-server/src/app/agents/[agentName]/api/chat/route.ts +20 -0
  20. package/apps/agents-server/src/app/agents/[agentName]/api/mcp/route.ts +6 -11
  21. package/apps/agents-server/src/app/agents/[agentName]/api/profile/route.ts +1 -1
  22. package/apps/agents-server/src/app/agents/[agentName]/api/voice/route.ts +5 -2
  23. package/apps/agents-server/src/app/agents/[agentName]/book/BookEditorWrapper.tsx +20 -16
  24. package/apps/agents-server/src/app/agents/[agentName]/book/page.tsx +15 -2
  25. package/apps/agents-server/src/app/agents/[agentName]/book+chat/page.tsx +15 -2
  26. package/apps/agents-server/src/app/agents/[agentName]/chat/page.tsx +12 -0
  27. package/apps/agents-server/src/app/agents/[agentName]/code/api/route.ts +68 -0
  28. package/apps/agents-server/src/app/agents/[agentName]/code/page.tsx +214 -0
  29. package/apps/agents-server/src/app/agents/[agentName]/generateAgentMetadata.ts +5 -0
  30. package/apps/agents-server/src/app/agents/[agentName]/history/actions.ts +2 -2
  31. package/apps/agents-server/src/app/agents/[agentName]/integration/page.tsx +1 -1
  32. package/apps/agents-server/src/app/agents/[agentName]/links/page.tsx +2 -2
  33. package/apps/agents-server/src/app/agents/[agentName]/page.tsx +12 -6
  34. package/apps/agents-server/src/app/agents/[agentName]/system-message/page.tsx +87 -0
  35. package/apps/agents-server/src/app/api/admin-email/route.ts +12 -0
  36. package/apps/agents-server/src/app/api/agents/[agentName]/clone/route.ts +10 -12
  37. package/apps/agents-server/src/app/api/agents/[agentName]/restore/route.ts +19 -0
  38. package/apps/agents-server/src/app/api/agents/[agentName]/route.ts +41 -0
  39. package/apps/agents-server/src/app/api/agents/route.ts +28 -3
  40. package/apps/agents-server/src/app/api/api-tokens/route.ts +6 -7
  41. package/apps/agents-server/src/app/api/docs/book.md/route.ts +61 -0
  42. package/apps/agents-server/src/app/api/federated-agents/route.ts +12 -0
  43. package/apps/agents-server/src/app/api/images/[filename]/route.ts +107 -0
  44. package/apps/agents-server/src/app/api/metadata/route.ts +5 -6
  45. package/apps/agents-server/src/app/api/upload/route.ts +128 -45
  46. package/apps/agents-server/src/app/docs/[docId]/page.tsx +2 -3
  47. package/apps/agents-server/src/app/docs/page.tsx +12 -12
  48. package/apps/agents-server/src/app/globals.css +140 -33
  49. package/apps/agents-server/src/app/layout.tsx +27 -22
  50. package/apps/agents-server/src/app/page.tsx +50 -4
  51. package/apps/agents-server/src/app/recycle-bin/actions.ts +20 -14
  52. package/apps/agents-server/src/app/recycle-bin/page.tsx +25 -41
  53. package/apps/agents-server/src/app/sitemap.xml/route.ts +6 -3
  54. package/apps/agents-server/src/app/swagger/page.tsx +14 -0
  55. package/apps/agents-server/src/components/AgentProfile/AgentProfile.tsx +9 -98
  56. package/apps/agents-server/src/components/AgentProfile/QrCodeModal.tsx +0 -1
  57. package/apps/agents-server/src/components/AgentProfile/useAgentBackground.ts +97 -0
  58. package/apps/agents-server/src/components/Auth/AuthControls.tsx +5 -4
  59. package/apps/agents-server/src/components/DeletedAgentBanner.tsx +26 -0
  60. package/apps/agents-server/src/components/DocsToolbar/DocsToolbar.tsx +38 -0
  61. package/apps/agents-server/src/components/DocumentationContent/DocumentationContent.tsx +11 -9
  62. package/apps/agents-server/src/components/Footer/Footer.tsx +5 -5
  63. package/apps/agents-server/src/components/ForgottenPasswordDialog/ForgottenPasswordDialog.tsx +61 -0
  64. package/apps/agents-server/src/components/Header/Header.tsx +106 -40
  65. package/apps/agents-server/src/components/Homepage/AgentCard.tsx +104 -20
  66. package/apps/agents-server/src/components/Homepage/AgentsList.tsx +72 -12
  67. package/apps/agents-server/src/components/Homepage/DeletedAgentsList.tsx +50 -0
  68. package/apps/agents-server/src/components/LayoutWrapper/LayoutWrapper.tsx +3 -2
  69. package/apps/agents-server/src/components/LoginForm/LoginForm.tsx +50 -1
  70. package/apps/agents-server/src/components/NotFoundPage/NotFoundPage.tsx +7 -2
  71. package/apps/agents-server/src/components/OpenMojiIcon/OpenMojiIcon.tsx +16 -7
  72. package/apps/agents-server/src/components/PrintHeader/PrintHeader.tsx +4 -4
  73. package/apps/agents-server/src/components/RegisterUserDialog/RegisterUserDialog.tsx +61 -0
  74. package/apps/agents-server/src/components/_utils/headlessParam.tsx +7 -3
  75. package/apps/agents-server/src/database/metadataDefaults.ts +19 -1
  76. package/apps/agents-server/src/database/migrations/2025-12-0240-agent-public-id.sql +3 -0
  77. package/apps/agents-server/src/database/migrations/2025-12-0360-agent-deleted-at.sql +1 -0
  78. package/apps/agents-server/src/database/migrations/2025-12-0370-image-table.sql +19 -0
  79. package/apps/agents-server/src/database/migrations/2025-12-0380-agent-visibility.sql +1 -0
  80. package/apps/agents-server/src/database/migrations/2025-12-0390-upload-tracking.sql +20 -0
  81. package/apps/agents-server/src/database/migrations/2025-12-0401-file-upload-status.sql +13 -0
  82. package/apps/agents-server/src/database/migrations/2025-12-0640-openai-assistant-cache.sql +12 -0
  83. package/apps/agents-server/src/database/schema.ts +109 -0
  84. package/apps/agents-server/src/generated/reservedPaths.ts +32 -0
  85. package/apps/agents-server/src/middleware.ts +19 -23
  86. package/apps/agents-server/src/tools/$provideCdnForServer.ts +6 -1
  87. package/apps/agents-server/src/utils/auth.ts +117 -17
  88. package/apps/agents-server/src/utils/cdn/classes/TrackedFilesStorage.ts +57 -0
  89. package/apps/agents-server/src/utils/cdn/classes/VercelBlobStorage.ts +4 -0
  90. package/apps/agents-server/src/utils/cdn/interfaces/IFilesStorage.ts +18 -0
  91. package/apps/agents-server/src/utils/getUserIdFromRequest.ts +35 -0
  92. package/apps/agents-server/src/utils/handleChatCompletion.ts +65 -5
  93. package/apps/agents-server/src/utils/normalization/filenameToPrompt.ts +21 -0
  94. package/apps/agents-server/src/utils/validateApiKey.ts +7 -11
  95. package/esm/index.es.js +194 -34
  96. package/esm/index.es.js.map +1 -1
  97. package/esm/typings/src/_packages/types.index.d.ts +8 -2
  98. package/esm/typings/src/book-2.0/agent-source/AgentBasicInformation.d.ts +6 -1
  99. package/esm/typings/src/book-components/Chat/Chat/ChatMessageItem.d.ts +5 -1
  100. package/esm/typings/src/book-components/Chat/Chat/ChatProps.d.ts +5 -0
  101. package/esm/typings/src/book-components/Chat/CodeBlock/CodeBlock.d.ts +13 -0
  102. package/esm/typings/src/book-components/Chat/MarkdownContent/MarkdownContent.d.ts +1 -0
  103. package/esm/typings/src/book-components/Chat/types/ChatMessage.d.ts +7 -11
  104. package/esm/typings/src/book-components/_common/Dropdown/Dropdown.d.ts +2 -2
  105. package/esm/typings/src/book-components/_common/MenuHoisting/MenuHoistingContext.d.ts +56 -0
  106. package/esm/typings/src/collection/agent-collection/constructors/agent-collection-in-supabase/AgentCollectionInSupabase.d.ts +13 -7
  107. package/esm/typings/src/collection/agent-collection/constructors/agent-collection-in-supabase/AgentsDatabaseSchema.d.ts +6 -0
  108. package/esm/typings/src/commitments/DICTIONARY/DICTIONARY.d.ts +46 -0
  109. package/esm/typings/src/commitments/index.d.ts +2 -1
  110. package/esm/typings/src/llm-providers/ollama/OllamaExecutionTools.d.ts +1 -1
  111. package/esm/typings/src/llm-providers/openai/createOpenAiCompatibleExecutionTools.d.ts +1 -1
  112. package/esm/typings/src/types/Message.d.ts +49 -0
  113. package/esm/typings/src/types/typeAliases.d.ts +12 -0
  114. package/esm/typings/src/utils/environment/$detectRuntimeEnvironment.d.ts +4 -4
  115. package/esm/typings/src/utils/environment/$isRunningInBrowser.d.ts +1 -1
  116. package/esm/typings/src/utils/environment/$isRunningInJest.d.ts +1 -1
  117. package/esm/typings/src/utils/environment/$isRunningInNode.d.ts +1 -1
  118. package/esm/typings/src/utils/environment/$isRunningInWebWorker.d.ts +1 -1
  119. package/esm/typings/src/utils/markdown/extractAllBlocksFromMarkdown.d.ts +2 -2
  120. package/esm/typings/src/utils/markdown/extractOneBlockFromMarkdown.d.ts +2 -2
  121. package/esm/typings/src/utils/random/$randomBase58.d.ts +12 -0
  122. package/esm/typings/src/version.d.ts +1 -1
  123. package/package.json +1 -1
  124. package/umd/index.umd.js +200 -40
  125. package/umd/index.umd.js.map +1 -1
  126. package/apps/agents-server/package-lock.json +0 -27
  127. package/apps/agents-server/public/fonts/download-font.js +0 -22
  128. package/apps/agents-server/src/components/PrintButton/PrintButton.tsx +0 -18
@@ -2,8 +2,8 @@ import type { NextConfig } from 'next';
2
2
  import path from 'path';
3
3
 
4
4
  const nextConfig: NextConfig = {
5
- output: 'standalone',
6
- // <- TODO: [🐱‍🚀][🧠] How to propperly build Next.js app
5
+ // output: 'standalone',
6
+ // <- TODO: [🐱‍🚀][🧠] How to propperly build Next.js app, for both Vercel and Doceker?
7
7
 
8
8
  experimental: {
9
9
  externalDir: true,
@@ -1,12 +1,16 @@
1
1
  {
2
2
  "name": "promptbook-agents-server",
3
3
  "scripts": {
4
- "migrate-database": "npx tsx src/database/migrate.ts",
4
+ "migrate-database": "npx tsx ./src/database/migrate.ts",
5
+ "generate-reserved-paths": "ts-node ./scripts/generate-reserved-paths/generate-reserved-paths.ts",
6
+ "prebuild": "npm run generate-reserved-paths",
7
+ "predev": "npm run generate-reserved-paths",
5
8
  "dev": "(npx kill-port 4440 || true) && next dev -p 4440",
6
- "test-build": "npm run build",
9
+ "test": "npm run lint && npm run test-build",
10
+ "test-build": "(npx kill-port 4440 || true) && next build",
7
11
  "build": "(npx kill-port 4440 || true) && next build",
8
12
  "start": "next start -p 4440",
9
- "lint": "next lint",
13
+ "lint": "next lint --max-warnings=0",
10
14
  "postinstall": "cd ../../ && npm ci"
11
15
  }
12
16
  }
@@ -0,0 +1,115 @@
1
+ {
2
+ "openapi": "3.0.0",
3
+ "info": {
4
+ "title": "Agents Server API",
5
+ "version": "1.0.0",
6
+ "description": "API documentation for the Agents Server"
7
+ },
8
+ "servers": [
9
+ {
10
+ "url": "/",
11
+ "description": "Current Server"
12
+ }
13
+ ],
14
+ "paths": {
15
+ "/api/agents": {
16
+ "get": {
17
+ "summary": "List all agents",
18
+ "tags": ["Agents"],
19
+ "responses": {
20
+ "200": {
21
+ "description": "A list of agents",
22
+ "content": {
23
+ "application/json": {
24
+ "schema": {
25
+ "type": "array",
26
+ "items": {
27
+ "type": "object",
28
+ "properties": {
29
+ "name": { "type": "string" },
30
+ "title": { "type": "string" },
31
+ "description": { "type": "string" }
32
+ }
33
+ }
34
+ }
35
+ }
36
+ }
37
+ }
38
+ }
39
+ }
40
+ },
41
+ "/api/chat": {
42
+ "post": {
43
+ "summary": "Chat with an agent",
44
+ "tags": ["Chat"],
45
+ "requestBody": {
46
+ "required": true,
47
+ "content": {
48
+ "application/json": {
49
+ "schema": {
50
+ "type": "object",
51
+ "properties": {
52
+ "agentName": { "type": "string" },
53
+ "message": { "type": "string" }
54
+ }
55
+ }
56
+ }
57
+ }
58
+ },
59
+ "responses": {
60
+ "200": {
61
+ "description": "Chat response"
62
+ }
63
+ }
64
+ }
65
+ },
66
+ "/api/agents/{agentName}": {
67
+ "get": {
68
+ "summary": "Get agent details",
69
+ "tags": ["Agents"],
70
+ "parameters": [
71
+ {
72
+ "name": "agentName",
73
+ "in": "path",
74
+ "required": true,
75
+ "schema": {
76
+ "type": "string"
77
+ }
78
+ }
79
+ ],
80
+ "responses": {
81
+ "200": {
82
+ "description": "Agent details"
83
+ }
84
+ }
85
+ }
86
+ },
87
+ "/api/upload": {
88
+ "post": {
89
+ "summary": "Upload a file",
90
+ "tags": ["Upload"],
91
+ "requestBody": {
92
+ "content": {
93
+ "multipart/form-data": {
94
+ "schema": {
95
+ "type": "object",
96
+ "properties": {
97
+ "file": {
98
+ "type": "string",
99
+ "format": "binary"
100
+ }
101
+ }
102
+ }
103
+ }
104
+ }
105
+ },
106
+ "responses": {
107
+ "200": {
108
+ "description": "File uploaded"
109
+ }
110
+ }
111
+ }
112
+ }
113
+ },
114
+ "--0": "<- TODO: !!!! Generate this file dynamically from the codebase of the Agents server app"
115
+ }
@@ -0,0 +1,54 @@
1
+ import fs from 'fs';
2
+ import path from 'path';
3
+ import { GENERATOR_WARNING } from '../../../../src/config';
4
+
5
+ const appDir = path.join(__dirname, '..', '..', 'src', 'app');
6
+ const publicDir = path.join(__dirname, '..', '..', 'public');
7
+ const outputFile = path.join(__dirname, '..', '..', 'src', 'generated', 'reservedPaths.ts');
8
+
9
+ // Read the app directory
10
+ const appEntries = fs.readdirSync(appDir, { withFileTypes: true });
11
+
12
+ // Filter to get only directories (excluding dynamic routes like [agentName])
13
+ const reservedPaths = appEntries
14
+ .filter((entry) => entry.isDirectory())
15
+ .map((entry) => entry.name)
16
+ .filter((name) => !name.startsWith('[') && !name.endsWith(']'));
17
+
18
+ // Read the public directory (files and folders)
19
+ const publicEntries = fs.readdirSync(publicDir, { withFileTypes: true });
20
+ const publicPaths = publicEntries.map((entry) => entry.name).filter((name) => !name.startsWith('.'));
21
+
22
+ // Add additional paths that are not in app or public but should be reserved
23
+ const additionalPaths = [
24
+ '_next', // Next.js internal paths
25
+ 'manifest.webmanifest', // PWA manifest
26
+ ];
27
+
28
+ const allReservedPaths = [...new Set([...reservedPaths, ...publicPaths, ...additionalPaths])].sort();
29
+
30
+ // Generate the TypeScript file
31
+ const content = `/**
32
+ * Reserved paths that should not be treated as agent names.
33
+ * This file is auto-generated by scripts/generate-reserved-paths.js
34
+ *
35
+ * ${GENERATOR_WARNING}
36
+ *
37
+ * @see /apps/agents-server/src/app - source directory for routes
38
+ * @see /apps/agents-server/public - source directory for static files
39
+ * @see /apps/agents-server/src/middleware.ts - where this is used
40
+ */
41
+ export const RESERVED_PATHS: readonly string[] = ${JSON.stringify(allReservedPaths, null, 4)} as const;
42
+ `;
43
+
44
+ // Ensure the generated directory exists
45
+ const generatedDir = path.dirname(outputFile);
46
+ if (!fs.existsSync(generatedDir)) {
47
+ fs.mkdirSync(generatedDir, { recursive: true });
48
+ }
49
+
50
+ // Write the file
51
+ fs.writeFileSync(outputFile, content, 'utf-8');
52
+
53
+ console.log(`Generated ${outputFile} with ${allReservedPaths.length} reserved paths:`);
54
+ console.log(allReservedPaths.join(', '));
@@ -0,0 +1,19 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "commonjs",
5
+ "downlevelIteration": true,
6
+ "allowJs": true,
7
+ "moduleResolution": "node",
8
+ "forceConsistentCasingInFileNames": true,
9
+ "noImplicitReturns": true,
10
+ "noImplicitThis": true,
11
+ "noImplicitAny": true,
12
+ "strictNullChecks": true,
13
+ "experimentalDecorators": true,
14
+ "noUnusedLocals": false,
15
+ "resolveJsonModule": true,
16
+ "esModuleInterop": true
17
+ },
18
+ "exclude": ["node_modules"]
19
+ }
@@ -11,10 +11,10 @@ export function AddAgentButton() {
11
11
 
12
12
  const handleAddAgent = async () => {
13
13
  setIsLoading(true);
14
- const agentName = await $createAgentAction();
14
+ const { /*agentName,*/ permanentId } = await $createAgentAction();
15
15
  // TODO: Add proper error handling and UI feedback
16
- if (agentName) {
17
- router.push(`/agents/${agentName}`);
16
+ if (permanentId) {
17
+ router.push(`/agents/${permanentId}`);
18
18
  } else {
19
19
  router.refresh();
20
20
  setIsLoading(false);
@@ -1,16 +1,16 @@
1
1
  'use server';
2
2
 
3
3
  import { $generateBookBoilerplate } from '@promptbook-local/core';
4
- import { string_agent_name } from '@promptbook-local/types';
4
+ import { string_agent_name, string_book } from '@promptbook-local/types';
5
5
  import { revalidatePath } from 'next/cache';
6
- import { cookies } from 'next/headers';
6
+ import { string_agent_permanent_id } from '../../../../src/types/typeAliases';
7
7
  import { getMetadata } from '../database/getMetadata';
8
8
  import { $provideAgentCollectionForServer } from '../tools/$provideAgentCollectionForServer';
9
9
  import { authenticateUser } from '../utils/authenticateUser';
10
10
  import { isUserAdmin } from '../utils/isUserAdmin';
11
11
  import { clearSession, setSession } from '../utils/session';
12
12
 
13
- export async function $createAgentAction(): Promise<string_agent_name> {
13
+ export async function $createAgentAction(): Promise<{ agentName: string_agent_name; permanentId: string_agent_permanent_id }> {
14
14
  // TODO: [👹] Check permissions here
15
15
  if (!(await isUserAdmin())) {
16
16
  throw new Error('You are not authorized to create agents');
@@ -20,9 +20,21 @@ export async function $createAgentAction(): Promise<string_agent_name> {
20
20
  const namePool = (await getMetadata('NAME_POOL')) || 'ENGLISH';
21
21
  const agentSource = $generateBookBoilerplate({ namePool });
22
22
 
23
- const { agentName } = await collection.createAgent(agentSource);
23
+ const { agentName, permanentId } = await collection.createAgent(agentSource);
24
24
 
25
- return agentName;
25
+ return { agentName, permanentId };
26
+ }
27
+
28
+ export async function $createAgentFromBookAction(bookContent: string_book): Promise<{ agentName: string_agent_name; permanentId: string_agent_permanent_id }> {
29
+ // TODO: [👹] Check permissions here
30
+ if (!(await isUserAdmin())) {
31
+ throw new Error('You are not authorized to create agents');
32
+ }
33
+
34
+ const collection = await $provideAgentCollectionForServer();
35
+ const { agentName, permanentId } = await collection.createAgent(bookContent);
36
+
37
+ return { agentName, permanentId };
26
38
  }
27
39
 
28
40
  export async function loginAction(formData: FormData) {