@shareai-lab/kode 1.0.70 → 1.0.73

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 (278) hide show
  1. package/README.md +342 -75
  2. package/README.zh-CN.md +292 -0
  3. package/cli.js +62 -0
  4. package/package.json +49 -25
  5. package/scripts/postinstall.js +56 -0
  6. package/src/ProjectOnboarding.tsx +198 -0
  7. package/src/Tool.ts +82 -0
  8. package/src/commands/agents.tsx +3401 -0
  9. package/src/commands/approvedTools.ts +53 -0
  10. package/src/commands/bug.tsx +20 -0
  11. package/src/commands/clear.ts +43 -0
  12. package/src/commands/compact.ts +120 -0
  13. package/src/commands/config.tsx +19 -0
  14. package/src/commands/cost.ts +18 -0
  15. package/src/commands/ctx_viz.ts +209 -0
  16. package/src/commands/doctor.ts +24 -0
  17. package/src/commands/help.tsx +19 -0
  18. package/src/commands/init.ts +37 -0
  19. package/src/commands/listen.ts +42 -0
  20. package/src/commands/login.tsx +51 -0
  21. package/src/commands/logout.tsx +40 -0
  22. package/src/commands/mcp.ts +41 -0
  23. package/src/commands/model.tsx +40 -0
  24. package/src/commands/modelstatus.tsx +20 -0
  25. package/src/commands/onboarding.tsx +34 -0
  26. package/src/commands/pr_comments.ts +59 -0
  27. package/src/commands/refreshCommands.ts +54 -0
  28. package/src/commands/release-notes.ts +34 -0
  29. package/src/commands/resume.tsx +31 -0
  30. package/src/commands/review.ts +49 -0
  31. package/src/commands/terminalSetup.ts +221 -0
  32. package/src/commands.ts +139 -0
  33. package/src/components/ApproveApiKey.tsx +93 -0
  34. package/src/components/AsciiLogo.tsx +13 -0
  35. package/src/components/AutoUpdater.tsx +148 -0
  36. package/src/components/Bug.tsx +367 -0
  37. package/src/components/Config.tsx +293 -0
  38. package/src/components/ConsoleOAuthFlow.tsx +327 -0
  39. package/src/components/Cost.tsx +23 -0
  40. package/src/components/CostThresholdDialog.tsx +46 -0
  41. package/src/components/CustomSelect/option-map.ts +42 -0
  42. package/src/components/CustomSelect/select-option.tsx +78 -0
  43. package/src/components/CustomSelect/select.tsx +152 -0
  44. package/src/components/CustomSelect/theme.ts +45 -0
  45. package/src/components/CustomSelect/use-select-state.ts +414 -0
  46. package/src/components/CustomSelect/use-select.ts +35 -0
  47. package/src/components/FallbackToolUseRejectedMessage.tsx +15 -0
  48. package/src/components/FileEditToolUpdatedMessage.tsx +66 -0
  49. package/src/components/Help.tsx +215 -0
  50. package/src/components/HighlightedCode.tsx +33 -0
  51. package/src/components/InvalidConfigDialog.tsx +113 -0
  52. package/src/components/Link.tsx +32 -0
  53. package/src/components/LogSelector.tsx +86 -0
  54. package/src/components/Logo.tsx +145 -0
  55. package/src/components/MCPServerApprovalDialog.tsx +100 -0
  56. package/src/components/MCPServerDialogCopy.tsx +25 -0
  57. package/src/components/MCPServerMultiselectDialog.tsx +109 -0
  58. package/src/components/Message.tsx +221 -0
  59. package/src/components/MessageResponse.tsx +15 -0
  60. package/src/components/MessageSelector.tsx +211 -0
  61. package/src/components/ModeIndicator.tsx +88 -0
  62. package/src/components/ModelConfig.tsx +301 -0
  63. package/src/components/ModelListManager.tsx +227 -0
  64. package/src/components/ModelSelector.tsx +3386 -0
  65. package/src/components/ModelStatusDisplay.tsx +230 -0
  66. package/src/components/Onboarding.tsx +274 -0
  67. package/src/components/PressEnterToContinue.tsx +11 -0
  68. package/src/components/PromptInput.tsx +740 -0
  69. package/src/components/SentryErrorBoundary.ts +33 -0
  70. package/src/components/Spinner.tsx +129 -0
  71. package/src/components/StickerRequestForm.tsx +16 -0
  72. package/src/components/StructuredDiff.tsx +191 -0
  73. package/src/components/TextInput.tsx +259 -0
  74. package/src/components/TodoItem.tsx +11 -0
  75. package/src/components/TokenWarning.tsx +31 -0
  76. package/src/components/ToolUseLoader.tsx +40 -0
  77. package/src/components/TrustDialog.tsx +106 -0
  78. package/src/components/binary-feedback/BinaryFeedback.tsx +63 -0
  79. package/src/components/binary-feedback/BinaryFeedbackOption.tsx +111 -0
  80. package/src/components/binary-feedback/BinaryFeedbackView.tsx +172 -0
  81. package/src/components/binary-feedback/utils.ts +220 -0
  82. package/src/components/messages/AssistantBashOutputMessage.tsx +22 -0
  83. package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +49 -0
  84. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +19 -0
  85. package/src/components/messages/AssistantTextMessage.tsx +144 -0
  86. package/src/components/messages/AssistantThinkingMessage.tsx +40 -0
  87. package/src/components/messages/AssistantToolUseMessage.tsx +133 -0
  88. package/src/components/messages/TaskProgressMessage.tsx +32 -0
  89. package/src/components/messages/TaskToolMessage.tsx +58 -0
  90. package/src/components/messages/UserBashInputMessage.tsx +28 -0
  91. package/src/components/messages/UserCommandMessage.tsx +30 -0
  92. package/src/components/messages/UserKodingInputMessage.tsx +28 -0
  93. package/src/components/messages/UserPromptMessage.tsx +35 -0
  94. package/src/components/messages/UserTextMessage.tsx +39 -0
  95. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +12 -0
  96. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +36 -0
  97. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +31 -0
  98. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +57 -0
  99. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +35 -0
  100. package/src/components/messages/UserToolResultMessage/utils.tsx +56 -0
  101. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +121 -0
  102. package/src/components/permissions/FallbackPermissionRequest.tsx +153 -0
  103. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +182 -0
  104. package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +77 -0
  105. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +164 -0
  106. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +83 -0
  107. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +240 -0
  108. package/src/components/permissions/PermissionRequest.tsx +101 -0
  109. package/src/components/permissions/PermissionRequestTitle.tsx +69 -0
  110. package/src/components/permissions/hooks.ts +44 -0
  111. package/src/components/permissions/toolUseOptions.ts +59 -0
  112. package/src/components/permissions/utils.ts +23 -0
  113. package/src/constants/betas.ts +5 -0
  114. package/src/constants/claude-asterisk-ascii-art.tsx +238 -0
  115. package/src/constants/figures.ts +4 -0
  116. package/src/constants/keys.ts +3 -0
  117. package/src/constants/macros.ts +8 -0
  118. package/src/constants/modelCapabilities.ts +179 -0
  119. package/src/constants/models.ts +1025 -0
  120. package/src/constants/oauth.ts +18 -0
  121. package/src/constants/product.ts +17 -0
  122. package/src/constants/prompts.ts +177 -0
  123. package/src/constants/releaseNotes.ts +7 -0
  124. package/src/context/PermissionContext.tsx +149 -0
  125. package/src/context.ts +278 -0
  126. package/src/cost-tracker.ts +84 -0
  127. package/src/entrypoints/cli.tsx +1518 -0
  128. package/src/entrypoints/mcp.ts +176 -0
  129. package/src/history.ts +25 -0
  130. package/src/hooks/useApiKeyVerification.ts +59 -0
  131. package/src/hooks/useArrowKeyHistory.ts +55 -0
  132. package/src/hooks/useCanUseTool.ts +138 -0
  133. package/src/hooks/useCancelRequest.ts +39 -0
  134. package/src/hooks/useDoublePress.ts +42 -0
  135. package/src/hooks/useExitOnCtrlCD.ts +31 -0
  136. package/src/hooks/useInterval.ts +25 -0
  137. package/src/hooks/useLogMessages.ts +16 -0
  138. package/src/hooks/useLogStartupTime.ts +12 -0
  139. package/src/hooks/useNotifyAfterTimeout.ts +65 -0
  140. package/src/hooks/usePermissionRequestLogging.ts +44 -0
  141. package/src/hooks/useTerminalSize.ts +49 -0
  142. package/src/hooks/useTextInput.ts +318 -0
  143. package/src/hooks/useUnifiedCompletion.ts +1404 -0
  144. package/src/messages.ts +38 -0
  145. package/src/permissions.ts +268 -0
  146. package/src/query.ts +707 -0
  147. package/src/screens/ConfigureNpmPrefix.tsx +197 -0
  148. package/src/screens/Doctor.tsx +219 -0
  149. package/src/screens/LogList.tsx +68 -0
  150. package/src/screens/REPL.tsx +798 -0
  151. package/src/screens/ResumeConversation.tsx +68 -0
  152. package/src/services/adapters/base.ts +38 -0
  153. package/src/services/adapters/chatCompletions.ts +90 -0
  154. package/src/services/adapters/responsesAPI.ts +170 -0
  155. package/src/services/browserMocks.ts +66 -0
  156. package/src/services/claude.ts +2083 -0
  157. package/src/services/customCommands.ts +704 -0
  158. package/src/services/fileFreshness.ts +377 -0
  159. package/src/services/gpt5ConnectionTest.ts +340 -0
  160. package/src/services/mcpClient.ts +564 -0
  161. package/src/services/mcpServerApproval.tsx +50 -0
  162. package/src/services/mentionProcessor.ts +273 -0
  163. package/src/services/modelAdapterFactory.ts +69 -0
  164. package/src/services/notifier.ts +40 -0
  165. package/src/services/oauth.ts +357 -0
  166. package/src/services/openai.ts +1305 -0
  167. package/src/services/responseStateManager.ts +90 -0
  168. package/src/services/sentry.ts +3 -0
  169. package/src/services/statsig.ts +171 -0
  170. package/src/services/statsigStorage.ts +86 -0
  171. package/src/services/systemReminder.ts +507 -0
  172. package/src/services/vcr.ts +161 -0
  173. package/src/test/testAdapters.ts +96 -0
  174. package/src/tools/ArchitectTool/ArchitectTool.tsx +122 -0
  175. package/src/tools/ArchitectTool/prompt.ts +15 -0
  176. package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +569 -0
  177. package/src/tools/BashTool/BashTool.tsx +243 -0
  178. package/src/tools/BashTool/BashToolResultMessage.tsx +38 -0
  179. package/src/tools/BashTool/OutputLine.tsx +49 -0
  180. package/src/tools/BashTool/prompt.ts +174 -0
  181. package/src/tools/BashTool/utils.ts +56 -0
  182. package/src/tools/FileEditTool/FileEditTool.tsx +315 -0
  183. package/src/tools/FileEditTool/prompt.ts +51 -0
  184. package/src/tools/FileEditTool/utils.ts +58 -0
  185. package/src/tools/FileReadTool/FileReadTool.tsx +404 -0
  186. package/src/tools/FileReadTool/prompt.ts +7 -0
  187. package/src/tools/FileWriteTool/FileWriteTool.tsx +297 -0
  188. package/src/tools/FileWriteTool/prompt.ts +10 -0
  189. package/src/tools/GlobTool/GlobTool.tsx +119 -0
  190. package/src/tools/GlobTool/prompt.ts +8 -0
  191. package/src/tools/GrepTool/GrepTool.tsx +147 -0
  192. package/src/tools/GrepTool/prompt.ts +11 -0
  193. package/src/tools/MCPTool/MCPTool.tsx +107 -0
  194. package/src/tools/MCPTool/prompt.ts +3 -0
  195. package/src/tools/MemoryReadTool/MemoryReadTool.tsx +127 -0
  196. package/src/tools/MemoryReadTool/prompt.ts +3 -0
  197. package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +89 -0
  198. package/src/tools/MemoryWriteTool/prompt.ts +3 -0
  199. package/src/tools/MultiEditTool/MultiEditTool.tsx +366 -0
  200. package/src/tools/MultiEditTool/prompt.ts +45 -0
  201. package/src/tools/NotebookEditTool/NotebookEditTool.tsx +298 -0
  202. package/src/tools/NotebookEditTool/prompt.ts +3 -0
  203. package/src/tools/NotebookReadTool/NotebookReadTool.tsx +258 -0
  204. package/src/tools/NotebookReadTool/prompt.ts +3 -0
  205. package/src/tools/StickerRequestTool/StickerRequestTool.tsx +93 -0
  206. package/src/tools/StickerRequestTool/prompt.ts +19 -0
  207. package/src/tools/TaskTool/TaskTool.tsx +466 -0
  208. package/src/tools/TaskTool/constants.ts +1 -0
  209. package/src/tools/TaskTool/prompt.ts +92 -0
  210. package/src/tools/ThinkTool/ThinkTool.tsx +54 -0
  211. package/src/tools/ThinkTool/prompt.ts +12 -0
  212. package/src/tools/TodoWriteTool/TodoWriteTool.tsx +290 -0
  213. package/src/tools/TodoWriteTool/prompt.ts +63 -0
  214. package/src/tools/lsTool/lsTool.tsx +272 -0
  215. package/src/tools/lsTool/prompt.ts +2 -0
  216. package/src/tools.ts +63 -0
  217. package/src/types/PermissionMode.ts +120 -0
  218. package/src/types/RequestContext.ts +72 -0
  219. package/src/types/conversation.ts +51 -0
  220. package/src/types/logs.ts +58 -0
  221. package/src/types/modelCapabilities.ts +64 -0
  222. package/src/types/notebook.ts +87 -0
  223. package/src/utils/Cursor.ts +436 -0
  224. package/src/utils/PersistentShell.ts +373 -0
  225. package/src/utils/advancedFuzzyMatcher.ts +290 -0
  226. package/src/utils/agentLoader.ts +284 -0
  227. package/src/utils/agentStorage.ts +97 -0
  228. package/src/utils/array.ts +3 -0
  229. package/src/utils/ask.tsx +99 -0
  230. package/src/utils/auth.ts +13 -0
  231. package/src/utils/autoCompactCore.ts +223 -0
  232. package/src/utils/autoUpdater.ts +318 -0
  233. package/src/utils/betas.ts +20 -0
  234. package/src/utils/browser.ts +14 -0
  235. package/src/utils/cleanup.ts +72 -0
  236. package/src/utils/commands.ts +261 -0
  237. package/src/utils/commonUnixCommands.ts +161 -0
  238. package/src/utils/config.ts +942 -0
  239. package/src/utils/conversationRecovery.ts +55 -0
  240. package/src/utils/debugLogger.ts +1123 -0
  241. package/src/utils/diff.ts +42 -0
  242. package/src/utils/env.ts +57 -0
  243. package/src/utils/errors.ts +21 -0
  244. package/src/utils/exampleCommands.ts +109 -0
  245. package/src/utils/execFileNoThrow.ts +51 -0
  246. package/src/utils/expertChatStorage.ts +136 -0
  247. package/src/utils/file.ts +402 -0
  248. package/src/utils/fileRecoveryCore.ts +71 -0
  249. package/src/utils/format.tsx +44 -0
  250. package/src/utils/fuzzyMatcher.ts +328 -0
  251. package/src/utils/generators.ts +62 -0
  252. package/src/utils/git.ts +92 -0
  253. package/src/utils/globalLogger.ts +77 -0
  254. package/src/utils/http.ts +10 -0
  255. package/src/utils/imagePaste.ts +38 -0
  256. package/src/utils/json.ts +13 -0
  257. package/src/utils/log.ts +382 -0
  258. package/src/utils/markdown.ts +213 -0
  259. package/src/utils/messageContextManager.ts +289 -0
  260. package/src/utils/messages.tsx +939 -0
  261. package/src/utils/model.ts +836 -0
  262. package/src/utils/permissions/filesystem.ts +118 -0
  263. package/src/utils/responseState.ts +23 -0
  264. package/src/utils/ripgrep.ts +167 -0
  265. package/src/utils/secureFile.ts +559 -0
  266. package/src/utils/sessionState.ts +49 -0
  267. package/src/utils/state.ts +25 -0
  268. package/src/utils/style.ts +29 -0
  269. package/src/utils/terminal.ts +50 -0
  270. package/src/utils/theme.ts +133 -0
  271. package/src/utils/thinking.ts +144 -0
  272. package/src/utils/todoStorage.ts +431 -0
  273. package/src/utils/tokens.ts +43 -0
  274. package/src/utils/toolExecutionController.ts +163 -0
  275. package/src/utils/unaryLogging.ts +26 -0
  276. package/src/utils/user.ts +37 -0
  277. package/src/utils/validate.ts +165 -0
  278. package/cli.mjs +0 -1803
@@ -0,0 +1,68 @@
1
+ import React from 'react'
2
+ import { render } from 'ink'
3
+ import { REPL } from './REPL'
4
+ import { deserializeMessages } from '../utils/conversationRecovery'
5
+ import { LogSelector } from '../components/LogSelector'
6
+ import type { LogOption } from '../types/logs'
7
+ import { logError, getNextAvailableLogForkNumber } from '../utils/log'
8
+ import type { Tool } from '../Tool'
9
+ import { Command } from '../commands'
10
+ import { isDefaultSlowAndCapableModel } from '../utils/model'
11
+
12
+ type Props = {
13
+ commands: Command[]
14
+ context: { unmount?: () => void }
15
+ logs: LogOption[]
16
+ tools: Tool[]
17
+ verbose: boolean | undefined
18
+ }
19
+
20
+ export function ResumeConversation({
21
+ context,
22
+ commands,
23
+ logs,
24
+ tools,
25
+ verbose,
26
+ }: Props): React.ReactNode {
27
+ async function onSelect(index: number) {
28
+ const log = logs[index]
29
+ if (!log) {
30
+ return
31
+ }
32
+
33
+ // Load and deserialize the messages
34
+ try {
35
+ context.unmount?.()
36
+ // Start a new REPL with the loaded messages
37
+ // Increment the fork number by 1 to generate a new transcript
38
+ // Check if using default model before rendering
39
+ const isDefaultModel = await isDefaultSlowAndCapableModel()
40
+
41
+ render(
42
+ <REPL
43
+ messageLogName={log.date}
44
+ initialPrompt=""
45
+ shouldShowPromptInput={true}
46
+ verbose={verbose}
47
+ commands={commands}
48
+ tools={tools}
49
+ initialMessages={deserializeMessages(log.messages, tools)}
50
+ initialForkNumber={getNextAvailableLogForkNumber(
51
+ log.date,
52
+ log.forkNumber ?? 1,
53
+ 0,
54
+ )}
55
+ isDefaultModel={isDefaultModel}
56
+ />,
57
+ {
58
+ exitOnCtrlC: false,
59
+ },
60
+ )
61
+ } catch (e) {
62
+ logError(`Failed to load conversation: ${e}`)
63
+ throw e
64
+ }
65
+ }
66
+
67
+ return <LogSelector logs={logs} onSelect={onSelect} />
68
+ }
@@ -0,0 +1,38 @@
1
+ import { ModelCapabilities, UnifiedRequestParams, UnifiedResponse } from '../../types/modelCapabilities'
2
+ import { ModelProfile } from '../../utils/config'
3
+ import { Tool } from '../../Tool'
4
+
5
+ export abstract class ModelAPIAdapter {
6
+ constructor(
7
+ protected capabilities: ModelCapabilities,
8
+ protected modelProfile: ModelProfile
9
+ ) {}
10
+
11
+ // Subclasses must implement these methods
12
+ abstract createRequest(params: UnifiedRequestParams): any
13
+ abstract parseResponse(response: any): UnifiedResponse
14
+ abstract buildTools(tools: Tool[]): any
15
+
16
+ // Shared utility methods
17
+ protected getMaxTokensParam(): string {
18
+ return this.capabilities.parameters.maxTokensField
19
+ }
20
+
21
+ protected getTemperature(): number {
22
+ if (this.capabilities.parameters.temperatureMode === 'fixed_one') {
23
+ return 1
24
+ }
25
+ if (this.capabilities.parameters.temperatureMode === 'restricted') {
26
+ return Math.min(1, 0.7)
27
+ }
28
+ return 0.7
29
+ }
30
+
31
+ protected shouldIncludeReasoningEffort(): boolean {
32
+ return this.capabilities.parameters.supportsReasoningEffort
33
+ }
34
+
35
+ protected shouldIncludeVerbosity(): boolean {
36
+ return this.capabilities.parameters.supportsVerbosity
37
+ }
38
+ }
@@ -0,0 +1,90 @@
1
+ import { ModelAPIAdapter } from './base'
2
+ import { UnifiedRequestParams, UnifiedResponse } from '../../types/modelCapabilities'
3
+ import { Tool } from '../../Tool'
4
+ import { zodToJsonSchema } from 'zod-to-json-schema'
5
+
6
+ export class ChatCompletionsAdapter extends ModelAPIAdapter {
7
+ createRequest(params: UnifiedRequestParams): any {
8
+ const { messages, systemPrompt, tools, maxTokens, stream } = params
9
+
10
+ // Build complete message list (including system prompts)
11
+ const fullMessages = this.buildMessages(systemPrompt, messages)
12
+
13
+ // Build request
14
+ const request: any = {
15
+ model: this.modelProfile.modelName,
16
+ messages: fullMessages,
17
+ [this.getMaxTokensParam()]: maxTokens,
18
+ temperature: this.getTemperature()
19
+ }
20
+
21
+ // Add tools
22
+ if (tools && tools.length > 0) {
23
+ request.tools = this.buildTools(tools)
24
+ request.tool_choice = 'auto'
25
+ }
26
+
27
+ // Add reasoning effort for GPT-5 via Chat Completions
28
+ if (this.shouldIncludeReasoningEffort() && params.reasoningEffort) {
29
+ request.reasoning_effort = params.reasoningEffort // Chat Completions format
30
+ }
31
+
32
+ // Add verbosity for GPT-5 via Chat Completions
33
+ if (this.shouldIncludeVerbosity() && params.verbosity) {
34
+ request.verbosity = params.verbosity // Chat Completions format
35
+ }
36
+
37
+ // Add streaming options
38
+ if (stream) {
39
+ request.stream = true
40
+ request.stream_options = {
41
+ include_usage: true
42
+ }
43
+ }
44
+
45
+ // O1 model special handling
46
+ if (this.modelProfile.modelName.startsWith('o1')) {
47
+ delete request.temperature // O1 doesn't support temperature
48
+ delete request.stream // O1 doesn't support streaming
49
+ delete request.stream_options
50
+ }
51
+
52
+ return request
53
+ }
54
+
55
+ buildTools(tools: Tool[]): any[] {
56
+ // Chat Completions only supports traditional function calling
57
+ return tools.map(tool => ({
58
+ type: 'function',
59
+ function: {
60
+ name: tool.name,
61
+ description: tool.description || '',
62
+ parameters: tool.inputJSONSchema || zodToJsonSchema(tool.inputSchema)
63
+ }
64
+ }))
65
+ }
66
+
67
+ parseResponse(response: any): UnifiedResponse {
68
+ const choice = response.choices?.[0]
69
+
70
+ return {
71
+ id: response.id || `chatcmpl_${Date.now()}`,
72
+ content: choice?.message?.content || '',
73
+ toolCalls: choice?.message?.tool_calls || [],
74
+ usage: {
75
+ promptTokens: response.usage?.prompt_tokens || 0,
76
+ completionTokens: response.usage?.completion_tokens || 0
77
+ }
78
+ }
79
+ }
80
+
81
+ private buildMessages(systemPrompt: string[], messages: any[]): any[] {
82
+ // Merge system prompts and messages
83
+ const systemMessages = systemPrompt.map(prompt => ({
84
+ role: 'system',
85
+ content: prompt
86
+ }))
87
+
88
+ return [...systemMessages, ...messages]
89
+ }
90
+ }
@@ -0,0 +1,170 @@
1
+ import { ModelAPIAdapter } from './base'
2
+ import { UnifiedRequestParams, UnifiedResponse } from '../../types/modelCapabilities'
3
+ import { Tool } from '../../Tool'
4
+ import { zodToJsonSchema } from 'zod-to-json-schema'
5
+
6
+ export class ResponsesAPIAdapter extends ModelAPIAdapter {
7
+ createRequest(params: UnifiedRequestParams): any {
8
+ const { messages, systemPrompt, tools, maxTokens } = params
9
+
10
+ // Separate system messages and user messages
11
+ const systemMessages = messages.filter(m => m.role === 'system')
12
+ const nonSystemMessages = messages.filter(m => m.role !== 'system')
13
+
14
+ // Build base request
15
+ const request: any = {
16
+ model: this.modelProfile.modelName,
17
+ input: this.convertMessagesToInput(nonSystemMessages),
18
+ instructions: this.buildInstructions(systemPrompt, systemMessages)
19
+ }
20
+
21
+ // Add token limit
22
+ request[this.getMaxTokensParam()] = maxTokens
23
+
24
+ // Add temperature (GPT-5 only supports 1)
25
+ if (this.getTemperature() === 1) {
26
+ request.temperature = 1
27
+ }
28
+
29
+ // Add reasoning control - correct format for Responses API
30
+ if (this.shouldIncludeReasoningEffort()) {
31
+ request.reasoning = {
32
+ effort: params.reasoningEffort || this.modelProfile.reasoningEffort || 'medium'
33
+ }
34
+ }
35
+
36
+ // Add verbosity control - correct format for Responses API
37
+ if (this.shouldIncludeVerbosity()) {
38
+ request.text = {
39
+ verbosity: params.verbosity || 'high' // High verbosity for coding tasks
40
+ }
41
+ }
42
+
43
+ // Add tools
44
+ if (tools && tools.length > 0) {
45
+ request.tools = this.buildTools(tools)
46
+
47
+ // Handle allowed_tools
48
+ if (params.allowedTools && this.capabilities.toolCalling.supportsAllowedTools) {
49
+ request.tool_choice = {
50
+ type: 'allowed_tools',
51
+ mode: 'auto',
52
+ tools: params.allowedTools
53
+ }
54
+ }
55
+ }
56
+
57
+ // Add state management
58
+ if (params.previousResponseId && this.capabilities.stateManagement.supportsPreviousResponseId) {
59
+ request.previous_response_id = params.previousResponseId
60
+ }
61
+
62
+ return request
63
+ }
64
+
65
+ buildTools(tools: Tool[]): any[] {
66
+ // If freeform not supported, use traditional format
67
+ if (!this.capabilities.toolCalling.supportsFreeform) {
68
+ return tools.map(tool => ({
69
+ type: 'function',
70
+ function: {
71
+ name: tool.name,
72
+ description: tool.description || '',
73
+ parameters: tool.inputJSONSchema || zodToJsonSchema(tool.inputSchema)
74
+ }
75
+ }))
76
+ }
77
+
78
+ // Custom tools format (GPT-5 feature)
79
+ return tools.map(tool => {
80
+ const hasSchema = tool.inputJSONSchema || tool.inputSchema
81
+ const isCustom = !hasSchema
82
+
83
+ if (isCustom) {
84
+ // Custom tool format
85
+ return {
86
+ type: 'custom',
87
+ name: tool.name,
88
+ description: tool.description || ''
89
+ }
90
+ } else {
91
+ // Traditional function format
92
+ return {
93
+ type: 'function',
94
+ function: {
95
+ name: tool.name,
96
+ description: tool.description || '',
97
+ parameters: tool.inputJSONSchema || zodToJsonSchema(tool.inputSchema)
98
+ }
99
+ }
100
+ }
101
+ })
102
+ }
103
+
104
+ parseResponse(response: any): UnifiedResponse {
105
+ // Process basic text output
106
+ let content = response.output_text || ''
107
+
108
+ // Process structured output
109
+ if (response.output && Array.isArray(response.output)) {
110
+ const messageItems = response.output.filter(item => item.type === 'message')
111
+ if (messageItems.length > 0) {
112
+ content = messageItems
113
+ .map(item => {
114
+ if (item.content && Array.isArray(item.content)) {
115
+ return item.content
116
+ .filter(c => c.type === 'text')
117
+ .map(c => c.text)
118
+ .join('\n')
119
+ }
120
+ return item.content || ''
121
+ })
122
+ .filter(Boolean)
123
+ .join('\n\n')
124
+ }
125
+ }
126
+
127
+ // Parse tool calls
128
+ const toolCalls = this.parseToolCalls(response)
129
+
130
+ // Build unified response
131
+ return {
132
+ id: response.id || `resp_${Date.now()}`,
133
+ content,
134
+ toolCalls,
135
+ usage: {
136
+ promptTokens: response.usage?.input_tokens || 0,
137
+ completionTokens: response.usage?.output_tokens || 0,
138
+ reasoningTokens: response.usage?.output_tokens_details?.reasoning_tokens
139
+ },
140
+ responseId: response.id // Save for state management
141
+ }
142
+ }
143
+
144
+ private convertMessagesToInput(messages: any[]): any {
145
+ // Convert messages to Responses API input format
146
+ // May need adjustment based on actual API specification
147
+ return messages
148
+ }
149
+
150
+ private buildInstructions(systemPrompt: string[], systemMessages: any[]): string {
151
+ const systemContent = systemMessages.map(m => m.content).join('\n\n')
152
+ const promptContent = systemPrompt.join('\n\n')
153
+ return [systemContent, promptContent].filter(Boolean).join('\n\n')
154
+ }
155
+
156
+ private parseToolCalls(response: any): any[] {
157
+ if (!response.output || !Array.isArray(response.output)) {
158
+ return []
159
+ }
160
+
161
+ return response.output
162
+ .filter(item => item.type === 'tool_call')
163
+ .map(item => ({
164
+ id: item.id || `tool_${Date.now()}`,
165
+ type: 'tool_call',
166
+ name: item.name,
167
+ arguments: item.arguments // Can be text or JSON
168
+ }))
169
+ }
170
+ }
@@ -0,0 +1,66 @@
1
+ // Mock browser APIs needed by @statsig/js-client in Node.js environment
2
+
3
+ // Document mock with visibility state tracking
4
+ const mockDocument = {
5
+ visibilityState: 'visible' as const,
6
+ documentElement: {
7
+ lang: 'en',
8
+ },
9
+ addEventListener: (
10
+ _event: string,
11
+ _handler: EventListenerOrEventListenerObject,
12
+ ) => {
13
+ // Visibility change events are handled through window.document reference
14
+ },
15
+ } as const
16
+
17
+ // Window mock with focus/blur and beforeunload handling
18
+ export const mockWindow = {
19
+ document: mockDocument,
20
+ location: {
21
+ href: 'node://localhost',
22
+ pathname: '/',
23
+ },
24
+ addEventListener: (
25
+ event: string,
26
+ handler: EventListenerOrEventListenerObject,
27
+ ) => {
28
+ if (event === 'beforeunload') {
29
+ // Capture beforeunload handlers and run them on process exit
30
+ process.on('exit', () => {
31
+ if (typeof handler === 'function') {
32
+ handler({} as Event)
33
+ } else {
34
+ handler.handleEvent({} as Event)
35
+ }
36
+ })
37
+ }
38
+ // Other events (focus/blur) are not critically needed in Node.js
39
+ },
40
+ focus: () => {
41
+ // Focus is a no-op in Node.js
42
+ },
43
+ innerHeight: 768,
44
+ innerWidth: 1024,
45
+ } as const
46
+
47
+ // Navigator mock with minimal beacon support
48
+ export const mockNavigator = {
49
+ sendBeacon: (_url: string, _data: string | Blob): boolean => {
50
+ // Beacons are used for analytics - return success but don't actually send
51
+ return true
52
+ },
53
+ userAgent:
54
+ 'Mozilla/5.0 (Node.js) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0',
55
+ language: 'en-US',
56
+ } as const
57
+
58
+ // Only assign mocks if running in Node.js environment
59
+ if (typeof window === 'undefined') {
60
+ // @ts-expect-error: intentionally applying partial mocks for Node.js environment
61
+ global.window = mockWindow
62
+ }
63
+ if (typeof navigator === 'undefined') {
64
+ // @ts-expect-error: intentionally applying partial mocks for Node.js environment
65
+ global.navigator = mockNavigator
66
+ }