@companyhelm/cli 0.0.2
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.
- package/LICENSE +201 -0
- package/README.md +96 -0
- package/RUNTIME_IMAGE_VERSION +1 -0
- package/dist/cli.js +24 -0
- package/dist/commands/agent/index.js +10 -0
- package/dist/commands/agent/list.js +31 -0
- package/dist/commands/agent/register-agent-commands.js +10 -0
- package/dist/commands/index.js +15 -0
- package/dist/commands/register-commands.js +13 -0
- package/dist/commands/root.js +2077 -0
- package/dist/commands/sdk/index.js +12 -0
- package/dist/commands/sdk/list.js +76 -0
- package/dist/commands/sdk/refresh-models.js +18 -0
- package/dist/commands/sdk/register-sdk-commands.js +12 -0
- package/dist/commands/shell.js +88 -0
- package/dist/commands/startup.js +185 -0
- package/dist/commands/thread/docker.js +77 -0
- package/dist/commands/thread/index.js +12 -0
- package/dist/commands/thread/list.js +37 -0
- package/dist/commands/thread/register-thread-commands.js +12 -0
- package/dist/config/local.js +1 -0
- package/dist/config/schema.js +7 -0
- package/dist/config.js +86 -0
- package/dist/generated/codex-app-server/AbsolutePathBuf.js +3 -0
- package/dist/generated/codex-app-server/AddConversationListenerParams.js +3 -0
- package/dist/generated/codex-app-server/AddConversationSubscriptionResponse.js +3 -0
- package/dist/generated/codex-app-server/AgentMessageContent.js +3 -0
- package/dist/generated/codex-app-server/AgentMessageContentDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentMessageDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentMessageEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentMessageItem.js +3 -0
- package/dist/generated/codex-app-server/AgentReasoningDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentReasoningEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentReasoningRawContentDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentReasoningRawContentEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentReasoningSectionBreakEvent.js +3 -0
- package/dist/generated/codex-app-server/AgentStatus.js +3 -0
- package/dist/generated/codex-app-server/ApplyPatchApprovalParams.js +3 -0
- package/dist/generated/codex-app-server/ApplyPatchApprovalRequestEvent.js +3 -0
- package/dist/generated/codex-app-server/ApplyPatchApprovalResponse.js +3 -0
- package/dist/generated/codex-app-server/ArchiveConversationParams.js +3 -0
- package/dist/generated/codex-app-server/ArchiveConversationResponse.js +3 -0
- package/dist/generated/codex-app-server/AskForApproval.js +3 -0
- package/dist/generated/codex-app-server/AuthMode.js +3 -0
- package/dist/generated/codex-app-server/AuthStatusChangeNotification.js +3 -0
- package/dist/generated/codex-app-server/BackgroundEventEvent.js +3 -0
- package/dist/generated/codex-app-server/ByteRange.js +3 -0
- package/dist/generated/codex-app-server/CallToolResult.js +3 -0
- package/dist/generated/codex-app-server/CancelLoginChatGptParams.js +3 -0
- package/dist/generated/codex-app-server/CancelLoginChatGptResponse.js +3 -0
- package/dist/generated/codex-app-server/ClientInfo.js +3 -0
- package/dist/generated/codex-app-server/ClientNotification.js +3 -0
- package/dist/generated/codex-app-server/ClientRequest.js +3 -0
- package/dist/generated/codex-app-server/CodexErrorInfo.js +3 -0
- package/dist/generated/codex-app-server/CollabAgentInteractionBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabAgentInteractionEndEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabAgentSpawnBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabAgentSpawnEndEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabCloseBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabCloseEndEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabResumeBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabResumeEndEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabWaitingBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/CollabWaitingEndEvent.js +3 -0
- package/dist/generated/codex-app-server/CollaborationMode.js +3 -0
- package/dist/generated/codex-app-server/CollaborationModeMask.js +3 -0
- package/dist/generated/codex-app-server/ContentItem.js +3 -0
- package/dist/generated/codex-app-server/ContextCompactedEvent.js +3 -0
- package/dist/generated/codex-app-server/ContextCompactionItem.js +3 -0
- package/dist/generated/codex-app-server/ConversationGitInfo.js +3 -0
- package/dist/generated/codex-app-server/ConversationSummary.js +3 -0
- package/dist/generated/codex-app-server/CreditsSnapshot.js +3 -0
- package/dist/generated/codex-app-server/CustomPrompt.js +3 -0
- package/dist/generated/codex-app-server/DeprecationNoticeEvent.js +3 -0
- package/dist/generated/codex-app-server/DynamicToolCallRequest.js +3 -0
- package/dist/generated/codex-app-server/ElicitationRequestEvent.js +3 -0
- package/dist/generated/codex-app-server/ErrorEvent.js +3 -0
- package/dist/generated/codex-app-server/EventMsg.js +3 -0
- package/dist/generated/codex-app-server/ExecApprovalRequestEvent.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandApprovalParams.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandApprovalResponse.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandEndEvent.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandOutputDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandSource.js +3 -0
- package/dist/generated/codex-app-server/ExecCommandStatus.js +3 -0
- package/dist/generated/codex-app-server/ExecOneOffCommandParams.js +3 -0
- package/dist/generated/codex-app-server/ExecOneOffCommandResponse.js +3 -0
- package/dist/generated/codex-app-server/ExecOutputStream.js +3 -0
- package/dist/generated/codex-app-server/ExecPolicyAmendment.js +3 -0
- package/dist/generated/codex-app-server/ExitedReviewModeEvent.js +3 -0
- package/dist/generated/codex-app-server/FileChange.js +3 -0
- package/dist/generated/codex-app-server/ForcedLoginMethod.js +3 -0
- package/dist/generated/codex-app-server/ForkConversationParams.js +3 -0
- package/dist/generated/codex-app-server/ForkConversationResponse.js +3 -0
- package/dist/generated/codex-app-server/FunctionCallOutputBody.js +3 -0
- package/dist/generated/codex-app-server/FunctionCallOutputContentItem.js +3 -0
- package/dist/generated/codex-app-server/FunctionCallOutputPayload.js +3 -0
- package/dist/generated/codex-app-server/FuzzyFileSearchParams.js +3 -0
- package/dist/generated/codex-app-server/FuzzyFileSearchResponse.js +3 -0
- package/dist/generated/codex-app-server/FuzzyFileSearchResult.js +3 -0
- package/dist/generated/codex-app-server/FuzzyFileSearchSessionCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/FuzzyFileSearchSessionUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/GetAuthStatusParams.js +3 -0
- package/dist/generated/codex-app-server/GetAuthStatusResponse.js +3 -0
- package/dist/generated/codex-app-server/GetConversationSummaryParams.js +3 -0
- package/dist/generated/codex-app-server/GetConversationSummaryResponse.js +3 -0
- package/dist/generated/codex-app-server/GetHistoryEntryResponseEvent.js +3 -0
- package/dist/generated/codex-app-server/GetUserAgentResponse.js +3 -0
- package/dist/generated/codex-app-server/GetUserSavedConfigResponse.js +3 -0
- package/dist/generated/codex-app-server/GhostCommit.js +3 -0
- package/dist/generated/codex-app-server/GitDiffToRemoteParams.js +3 -0
- package/dist/generated/codex-app-server/GitDiffToRemoteResponse.js +3 -0
- package/dist/generated/codex-app-server/GitSha.js +3 -0
- package/dist/generated/codex-app-server/HistoryEntry.js +3 -0
- package/dist/generated/codex-app-server/InitializeCapabilities.js +3 -0
- package/dist/generated/codex-app-server/InitializeParams.js +3 -0
- package/dist/generated/codex-app-server/InitializeResponse.js +3 -0
- package/dist/generated/codex-app-server/InputItem.js +3 -0
- package/dist/generated/codex-app-server/InputModality.js +3 -0
- package/dist/generated/codex-app-server/InterruptConversationParams.js +3 -0
- package/dist/generated/codex-app-server/InterruptConversationResponse.js +3 -0
- package/dist/generated/codex-app-server/ItemCompletedEvent.js +3 -0
- package/dist/generated/codex-app-server/ItemStartedEvent.js +3 -0
- package/dist/generated/codex-app-server/ListConversationsParams.js +3 -0
- package/dist/generated/codex-app-server/ListConversationsResponse.js +3 -0
- package/dist/generated/codex-app-server/ListCustomPromptsResponseEvent.js +3 -0
- package/dist/generated/codex-app-server/ListRemoteSkillsResponseEvent.js +3 -0
- package/dist/generated/codex-app-server/ListSkillsResponseEvent.js +3 -0
- package/dist/generated/codex-app-server/LocalShellAction.js +3 -0
- package/dist/generated/codex-app-server/LocalShellExecAction.js +3 -0
- package/dist/generated/codex-app-server/LocalShellStatus.js +3 -0
- package/dist/generated/codex-app-server/LoginApiKeyParams.js +3 -0
- package/dist/generated/codex-app-server/LoginApiKeyResponse.js +3 -0
- package/dist/generated/codex-app-server/LoginChatGptCompleteNotification.js +3 -0
- package/dist/generated/codex-app-server/LoginChatGptResponse.js +3 -0
- package/dist/generated/codex-app-server/LogoutChatGptResponse.js +3 -0
- package/dist/generated/codex-app-server/McpAuthStatus.js +3 -0
- package/dist/generated/codex-app-server/McpInvocation.js +3 -0
- package/dist/generated/codex-app-server/McpListToolsResponseEvent.js +3 -0
- package/dist/generated/codex-app-server/McpStartupCompleteEvent.js +3 -0
- package/dist/generated/codex-app-server/McpStartupFailure.js +3 -0
- package/dist/generated/codex-app-server/McpStartupStatus.js +3 -0
- package/dist/generated/codex-app-server/McpStartupUpdateEvent.js +3 -0
- package/dist/generated/codex-app-server/McpToolCallBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/McpToolCallEndEvent.js +3 -0
- package/dist/generated/codex-app-server/MessagePhase.js +3 -0
- package/dist/generated/codex-app-server/ModeKind.js +3 -0
- package/dist/generated/codex-app-server/ModelRerouteEvent.js +3 -0
- package/dist/generated/codex-app-server/ModelRerouteReason.js +3 -0
- package/dist/generated/codex-app-server/NetworkAccess.js +3 -0
- package/dist/generated/codex-app-server/NetworkApprovalContext.js +3 -0
- package/dist/generated/codex-app-server/NetworkApprovalProtocol.js +3 -0
- package/dist/generated/codex-app-server/NewConversationParams.js +3 -0
- package/dist/generated/codex-app-server/NewConversationResponse.js +3 -0
- package/dist/generated/codex-app-server/ParsedCommand.js +3 -0
- package/dist/generated/codex-app-server/PatchApplyBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/PatchApplyEndEvent.js +3 -0
- package/dist/generated/codex-app-server/PatchApplyStatus.js +3 -0
- package/dist/generated/codex-app-server/Personality.js +3 -0
- package/dist/generated/codex-app-server/PlanDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/PlanItem.js +3 -0
- package/dist/generated/codex-app-server/PlanItemArg.js +3 -0
- package/dist/generated/codex-app-server/PlanType.js +3 -0
- package/dist/generated/codex-app-server/Profile.js +3 -0
- package/dist/generated/codex-app-server/RateLimitSnapshot.js +3 -0
- package/dist/generated/codex-app-server/RateLimitWindow.js +3 -0
- package/dist/generated/codex-app-server/RawResponseItemEvent.js +3 -0
- package/dist/generated/codex-app-server/ReadOnlyAccess.js +3 -0
- package/dist/generated/codex-app-server/ReasoningContentDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/ReasoningEffort.js +3 -0
- package/dist/generated/codex-app-server/ReasoningItem.js +3 -0
- package/dist/generated/codex-app-server/ReasoningItemContent.js +3 -0
- package/dist/generated/codex-app-server/ReasoningItemReasoningSummary.js +3 -0
- package/dist/generated/codex-app-server/ReasoningRawContentDeltaEvent.js +3 -0
- package/dist/generated/codex-app-server/ReasoningSummary.js +3 -0
- package/dist/generated/codex-app-server/RemoteSkillDownloadedEvent.js +3 -0
- package/dist/generated/codex-app-server/RemoteSkillSummary.js +3 -0
- package/dist/generated/codex-app-server/RemoveConversationListenerParams.js +3 -0
- package/dist/generated/codex-app-server/RemoveConversationSubscriptionResponse.js +3 -0
- package/dist/generated/codex-app-server/RequestId.js +3 -0
- package/dist/generated/codex-app-server/RequestUserInputEvent.js +3 -0
- package/dist/generated/codex-app-server/RequestUserInputQuestion.js +3 -0
- package/dist/generated/codex-app-server/RequestUserInputQuestionOption.js +3 -0
- package/dist/generated/codex-app-server/Resource.js +3 -0
- package/dist/generated/codex-app-server/ResourceTemplate.js +3 -0
- package/dist/generated/codex-app-server/ResponseItem.js +3 -0
- package/dist/generated/codex-app-server/ResumeConversationParams.js +3 -0
- package/dist/generated/codex-app-server/ResumeConversationResponse.js +3 -0
- package/dist/generated/codex-app-server/ReviewCodeLocation.js +3 -0
- package/dist/generated/codex-app-server/ReviewDecision.js +3 -0
- package/dist/generated/codex-app-server/ReviewFinding.js +3 -0
- package/dist/generated/codex-app-server/ReviewLineRange.js +3 -0
- package/dist/generated/codex-app-server/ReviewOutputEvent.js +3 -0
- package/dist/generated/codex-app-server/ReviewRequest.js +3 -0
- package/dist/generated/codex-app-server/ReviewTarget.js +3 -0
- package/dist/generated/codex-app-server/SandboxMode.js +3 -0
- package/dist/generated/codex-app-server/SandboxPolicy.js +3 -0
- package/dist/generated/codex-app-server/SandboxSettings.js +3 -0
- package/dist/generated/codex-app-server/SendUserMessageParams.js +3 -0
- package/dist/generated/codex-app-server/SendUserMessageResponse.js +3 -0
- package/dist/generated/codex-app-server/SendUserTurnParams.js +3 -0
- package/dist/generated/codex-app-server/SendUserTurnResponse.js +3 -0
- package/dist/generated/codex-app-server/ServerNotification.js +3 -0
- package/dist/generated/codex-app-server/ServerRequest.js +3 -0
- package/dist/generated/codex-app-server/SessionConfiguredEvent.js +3 -0
- package/dist/generated/codex-app-server/SessionConfiguredNotification.js +3 -0
- package/dist/generated/codex-app-server/SessionNetworkProxyRuntime.js +3 -0
- package/dist/generated/codex-app-server/SessionSource.js +3 -0
- package/dist/generated/codex-app-server/SetDefaultModelParams.js +3 -0
- package/dist/generated/codex-app-server/SetDefaultModelResponse.js +3 -0
- package/dist/generated/codex-app-server/Settings.js +3 -0
- package/dist/generated/codex-app-server/SkillDependencies.js +3 -0
- package/dist/generated/codex-app-server/SkillErrorInfo.js +3 -0
- package/dist/generated/codex-app-server/SkillInterface.js +3 -0
- package/dist/generated/codex-app-server/SkillMetadata.js +3 -0
- package/dist/generated/codex-app-server/SkillScope.js +3 -0
- package/dist/generated/codex-app-server/SkillToolDependency.js +3 -0
- package/dist/generated/codex-app-server/SkillsListEntry.js +3 -0
- package/dist/generated/codex-app-server/StepStatus.js +3 -0
- package/dist/generated/codex-app-server/StreamErrorEvent.js +3 -0
- package/dist/generated/codex-app-server/SubAgentSource.js +3 -0
- package/dist/generated/codex-app-server/TerminalInteractionEvent.js +3 -0
- package/dist/generated/codex-app-server/TextElement.js +3 -0
- package/dist/generated/codex-app-server/ThreadId.js +3 -0
- package/dist/generated/codex-app-server/ThreadNameUpdatedEvent.js +3 -0
- package/dist/generated/codex-app-server/ThreadRolledBackEvent.js +3 -0
- package/dist/generated/codex-app-server/TokenCountEvent.js +3 -0
- package/dist/generated/codex-app-server/TokenUsage.js +3 -0
- package/dist/generated/codex-app-server/TokenUsageInfo.js +3 -0
- package/dist/generated/codex-app-server/Tool.js +3 -0
- package/dist/generated/codex-app-server/Tools.js +3 -0
- package/dist/generated/codex-app-server/TurnAbortReason.js +3 -0
- package/dist/generated/codex-app-server/TurnAbortedEvent.js +3 -0
- package/dist/generated/codex-app-server/TurnCompleteEvent.js +3 -0
- package/dist/generated/codex-app-server/TurnDiffEvent.js +3 -0
- package/dist/generated/codex-app-server/TurnItem.js +3 -0
- package/dist/generated/codex-app-server/TurnStartedEvent.js +3 -0
- package/dist/generated/codex-app-server/UndoCompletedEvent.js +3 -0
- package/dist/generated/codex-app-server/UndoStartedEvent.js +3 -0
- package/dist/generated/codex-app-server/UpdatePlanArgs.js +3 -0
- package/dist/generated/codex-app-server/UserInfoResponse.js +3 -0
- package/dist/generated/codex-app-server/UserInput.js +3 -0
- package/dist/generated/codex-app-server/UserMessageEvent.js +3 -0
- package/dist/generated/codex-app-server/UserMessageItem.js +3 -0
- package/dist/generated/codex-app-server/UserSavedConfig.js +3 -0
- package/dist/generated/codex-app-server/Verbosity.js +3 -0
- package/dist/generated/codex-app-server/ViewImageToolCallEvent.js +3 -0
- package/dist/generated/codex-app-server/WarningEvent.js +3 -0
- package/dist/generated/codex-app-server/WebSearchAction.js +3 -0
- package/dist/generated/codex-app-server/WebSearchBeginEvent.js +3 -0
- package/dist/generated/codex-app-server/WebSearchEndEvent.js +3 -0
- package/dist/generated/codex-app-server/WebSearchItem.js +3 -0
- package/dist/generated/codex-app-server/WebSearchMode.js +3 -0
- package/dist/generated/codex-app-server/index.js +38 -0
- package/dist/generated/codex-app-server/serde_json/JsonValue.js +3 -0
- package/dist/generated/codex-app-server/v2/Account.js +3 -0
- package/dist/generated/codex-app-server/v2/AccountLoginCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/AccountRateLimitsUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/AccountUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/AgentMessageDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/AnalyticsConfig.js +3 -0
- package/dist/generated/codex-app-server/v2/AppBranding.js +3 -0
- package/dist/generated/codex-app-server/v2/AppDisabledReason.js +3 -0
- package/dist/generated/codex-app-server/v2/AppInfo.js +3 -0
- package/dist/generated/codex-app-server/v2/AppListUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/AppMetadata.js +3 -0
- package/dist/generated/codex-app-server/v2/AppReview.js +3 -0
- package/dist/generated/codex-app-server/v2/AppScreenshot.js +3 -0
- package/dist/generated/codex-app-server/v2/AppsConfig.js +3 -0
- package/dist/generated/codex-app-server/v2/AppsListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/AppsListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/AskForApproval.js +3 -0
- package/dist/generated/codex-app-server/v2/ByteRange.js +3 -0
- package/dist/generated/codex-app-server/v2/CancelLoginAccountParams.js +3 -0
- package/dist/generated/codex-app-server/v2/CancelLoginAccountResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/CancelLoginAccountStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/ChatgptAuthTokensRefreshParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ChatgptAuthTokensRefreshReason.js +3 -0
- package/dist/generated/codex-app-server/v2/ChatgptAuthTokensRefreshResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/CodexErrorInfo.js +3 -0
- package/dist/generated/codex-app-server/v2/CollabAgentState.js +3 -0
- package/dist/generated/codex-app-server/v2/CollabAgentStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/CollabAgentTool.js +3 -0
- package/dist/generated/codex-app-server/v2/CollabAgentToolCallStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandAction.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecParams.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecutionApprovalDecision.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecutionOutputDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecutionRequestApprovalParams.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecutionRequestApprovalResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/CommandExecutionStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/Config.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigBatchWriteParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigEdit.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigLayer.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigLayerMetadata.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigLayerSource.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigReadParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigReadResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigRequirements.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigRequirementsReadResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigValueWriteParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigWarningNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ConfigWriteResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ContextCompactedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/CreditsSnapshot.js +3 -0
- package/dist/generated/codex-app-server/v2/DeprecationNoticeNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/DynamicToolCallOutputContentItem.js +3 -0
- package/dist/generated/codex-app-server/v2/DynamicToolCallParams.js +3 -0
- package/dist/generated/codex-app-server/v2/DynamicToolCallResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/DynamicToolSpec.js +3 -0
- package/dist/generated/codex-app-server/v2/ErrorNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ExecPolicyAmendment.js +3 -0
- package/dist/generated/codex-app-server/v2/ExperimentalFeature.js +3 -0
- package/dist/generated/codex-app-server/v2/ExperimentalFeatureListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ExperimentalFeatureListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ExperimentalFeatureStage.js +3 -0
- package/dist/generated/codex-app-server/v2/FeedbackUploadParams.js +3 -0
- package/dist/generated/codex-app-server/v2/FeedbackUploadResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/FileChangeApprovalDecision.js +3 -0
- package/dist/generated/codex-app-server/v2/FileChangeOutputDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/FileChangeRequestApprovalParams.js +3 -0
- package/dist/generated/codex-app-server/v2/FileChangeRequestApprovalResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/FileUpdateChange.js +3 -0
- package/dist/generated/codex-app-server/v2/GetAccountParams.js +3 -0
- package/dist/generated/codex-app-server/v2/GetAccountRateLimitsResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/GetAccountResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/GitInfo.js +3 -0
- package/dist/generated/codex-app-server/v2/HazelnutScope.js +3 -0
- package/dist/generated/codex-app-server/v2/ItemCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ItemStartedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ListMcpServerStatusParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ListMcpServerStatusResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/LoginAccountParams.js +3 -0
- package/dist/generated/codex-app-server/v2/LoginAccountResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/LogoutAccountResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/McpAuthStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/McpServerOauthLoginCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/McpServerOauthLoginParams.js +3 -0
- package/dist/generated/codex-app-server/v2/McpServerOauthLoginResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/McpServerRefreshResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/McpServerStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/McpToolCallError.js +3 -0
- package/dist/generated/codex-app-server/v2/McpToolCallProgressNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/McpToolCallResult.js +3 -0
- package/dist/generated/codex-app-server/v2/McpToolCallStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/MergeStrategy.js +3 -0
- package/dist/generated/codex-app-server/v2/Model.js +3 -0
- package/dist/generated/codex-app-server/v2/ModelListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ModelListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ModelRerouteReason.js +3 -0
- package/dist/generated/codex-app-server/v2/ModelReroutedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/NetworkAccess.js +3 -0
- package/dist/generated/codex-app-server/v2/NetworkRequirements.js +3 -0
- package/dist/generated/codex-app-server/v2/OverriddenMetadata.js +3 -0
- package/dist/generated/codex-app-server/v2/PatchApplyStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/PatchChangeKind.js +3 -0
- package/dist/generated/codex-app-server/v2/PlanDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ProductSurface.js +3 -0
- package/dist/generated/codex-app-server/v2/ProfileV2.js +3 -0
- package/dist/generated/codex-app-server/v2/RateLimitSnapshot.js +3 -0
- package/dist/generated/codex-app-server/v2/RateLimitWindow.js +3 -0
- package/dist/generated/codex-app-server/v2/RawResponseItemCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ReadOnlyAccess.js +3 -0
- package/dist/generated/codex-app-server/v2/ReasoningEffortOption.js +3 -0
- package/dist/generated/codex-app-server/v2/ReasoningSummaryPartAddedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ReasoningSummaryTextDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ReasoningTextDeltaNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/RemoteSkillSummary.js +3 -0
- package/dist/generated/codex-app-server/v2/ResidencyRequirement.js +3 -0
- package/dist/generated/codex-app-server/v2/ReviewDelivery.js +3 -0
- package/dist/generated/codex-app-server/v2/ReviewStartParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ReviewStartResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ReviewTarget.js +3 -0
- package/dist/generated/codex-app-server/v2/SandboxMode.js +3 -0
- package/dist/generated/codex-app-server/v2/SandboxPolicy.js +3 -0
- package/dist/generated/codex-app-server/v2/SandboxWorkspaceWrite.js +3 -0
- package/dist/generated/codex-app-server/v2/SessionSource.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillDependencies.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillErrorInfo.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillInterface.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillMetadata.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillScope.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillToolDependency.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsConfigWriteParams.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsConfigWriteResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsListEntry.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsListExtraRootsForCwd.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsRemoteReadParams.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsRemoteReadResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsRemoteWriteParams.js +3 -0
- package/dist/generated/codex-app-server/v2/SkillsRemoteWriteResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/TerminalInteractionNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TextElement.js +3 -0
- package/dist/generated/codex-app-server/v2/TextPosition.js +3 -0
- package/dist/generated/codex-app-server/v2/TextRange.js +3 -0
- package/dist/generated/codex-app-server/v2/Thread.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadArchiveParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadArchiveResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadArchivedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadCompactStartParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadCompactStartResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadForkParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadForkResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadItem.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadLoadedListParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadLoadedListResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadNameUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadReadParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadReadResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadResumeParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadResumeResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadRollbackParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadRollbackResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadSetNameParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadSetNameResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadSortKey.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadSourceKind.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadStartParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadStartResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadStartedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadTokenUsage.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadTokenUsageUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadUnarchiveParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadUnarchiveResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ThreadUnarchivedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TokenUsageBreakdown.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolRequestUserInputAnswer.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolRequestUserInputOption.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolRequestUserInputParams.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolRequestUserInputQuestion.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolRequestUserInputResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/ToolsV2.js +3 -0
- package/dist/generated/codex-app-server/v2/Turn.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnCompletedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnDiffUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnError.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnInterruptParams.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnInterruptResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnPlanStep.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnPlanStepStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnPlanUpdatedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnStartParams.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnStartResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnStartedNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnSteerParams.js +3 -0
- package/dist/generated/codex-app-server/v2/TurnSteerResponse.js +3 -0
- package/dist/generated/codex-app-server/v2/UserInput.js +3 -0
- package/dist/generated/codex-app-server/v2/WebSearchAction.js +3 -0
- package/dist/generated/codex-app-server/v2/WindowsWorldWritableWarningNotification.js +3 -0
- package/dist/generated/codex-app-server/v2/WriteStatus.js +3 -0
- package/dist/generated/codex-app-server/v2/index.js +3 -0
- package/dist/model.js +22 -0
- package/dist/schema.js +47 -0
- package/dist/service/app_server.js +427 -0
- package/dist/service/buffered_client_message_sender.js +89 -0
- package/dist/service/companyhelm_api_client.js +337 -0
- package/dist/service/docker/app_server_container.js +268 -0
- package/dist/service/docker/dind.js +114 -0
- package/dist/service/docker/docker_provider.js +1 -0
- package/dist/service/docker/runtime_app_server_exec.js +97 -0
- package/dist/service/docker/runtime_container.js +1 -0
- package/dist/service/docker/runtime_image.js +40 -0
- package/dist/service/host.js +15 -0
- package/dist/service/runtime_bashrc.js +57 -0
- package/dist/service/runtime_shell.js +23 -0
- package/dist/service/sdk/refresh_models.js +83 -0
- package/dist/service/thread_lifecycle.js +673 -0
- package/dist/service/thread_runtime.js +15 -0
- package/dist/service/thread_turn_state.js +46 -0
- package/dist/service/thread_user_message_request_store.js +136 -0
- package/dist/service/workspace_agents.js +82 -0
- package/dist/startup.js +166 -0
- package/dist/state/db.js +63 -0
- package/dist/state/schema.js +51 -0
- package/dist/state/service/app_server.js +392 -0
- package/dist/state/service/buffered_client_message_sender.js +73 -0
- package/dist/state/service/companyhelm_api_client.js +316 -0
- package/dist/state/service/docker/app_server_container.js +165 -0
- package/dist/state/service/docker/dind.js +114 -0
- package/dist/state/service/docker/runtime_app_server_exec.js +95 -0
- package/dist/state/service/host.js +15 -0
- package/dist/state/service/runtime_shell.js +23 -0
- package/dist/state/service/sdk/refresh_models.js +83 -0
- package/dist/state/service/thread_lifecycle.js +327 -0
- package/dist/state/service/thread_runtime.js +11 -0
- package/dist/state/service/thread_turn_state.js +45 -0
- package/dist/state/service/workspace_agents.js +115 -0
- package/dist/utils/async_queue.js +102 -0
- package/dist/utils/logger.js +96 -0
- package/dist/utils/path.js +10 -0
- package/drizzle/0000_nice_stepford_cuckoos.sql +25 -0
- package/drizzle/0001_third_vermin.sql +22 -0
- package/drizzle/0002_kind_sue_storm.sql +1 -0
- package/drizzle/0003_dizzy_micromax.sql +35 -0
- package/drizzle/0004_sloppy_alex_wilder.sql +23 -0
- package/drizzle/0005_open_toro.sql +23 -0
- package/drizzle/0006_fixed_jack_flag.sql +23 -0
- package/drizzle/0007_mute_lord_tyger.sql +1 -0
- package/drizzle/0008_melted_flatman.sql +8 -0
- package/drizzle/0009_powerful_hellcat.sql +1 -0
- package/drizzle/0010_wealthy_dorian_gray.sql +24 -0
- package/drizzle/meta/0000_snapshot.json +174 -0
- package/drizzle/meta/0001_snapshot.json +212 -0
- package/drizzle/meta/0002_snapshot.json +219 -0
- package/drizzle/meta/0003_snapshot.json +240 -0
- package/drizzle/meta/0004_snapshot.json +240 -0
- package/drizzle/meta/0005_snapshot.json +240 -0
- package/drizzle/meta/0006_snapshot.json +240 -0
- package/drizzle/meta/0007_snapshot.json +247 -0
- package/drizzle/meta/0008_snapshot.json +306 -0
- package/drizzle/meta/0009_snapshot.json +313 -0
- package/drizzle/meta/0010_snapshot.json +261 -0
- package/drizzle/meta/_journal.json +83 -0
- package/package.json +49 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ensureThreadRuntimeReady = ensureThreadRuntimeReady;
|
|
4
|
+
const thread_lifecycle_js_1 = require("./thread_lifecycle.js");
|
|
5
|
+
async function ensureThreadRuntimeReady(options) {
|
|
6
|
+
const containerService = options.containerService ?? new thread_lifecycle_js_1.ThreadContainerService();
|
|
7
|
+
if (typeof options.dindContainer === "string" && options.dindContainer.trim().length > 0) {
|
|
8
|
+
await containerService.ensureContainerRunning(options.dindContainer);
|
|
9
|
+
}
|
|
10
|
+
await containerService.ensureContainerRunning(options.runtimeContainer);
|
|
11
|
+
await containerService.ensureRuntimeContainerIdentity(options.runtimeContainer, options.user);
|
|
12
|
+
await containerService.ensureRuntimeContainerBashrc(options.runtimeContainer, options.user);
|
|
13
|
+
await containerService.ensureRuntimeContainerGitConfig(options.runtimeContainer, options.user, options.gitUserName, options.gitUserEmail);
|
|
14
|
+
await containerService.ensureRuntimeContainerTooling(options.runtimeContainer, options.user);
|
|
15
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.loadThreadMessageExecutionState = loadThreadMessageExecutionState;
|
|
4
|
+
exports.updateThreadTurnState = updateThreadTurnState;
|
|
5
|
+
const drizzle_orm_1 = require("drizzle-orm");
|
|
6
|
+
const db_js_1 = require("../state/db.js");
|
|
7
|
+
const schema_js_1 = require("../state/schema.js");
|
|
8
|
+
async function loadThreadMessageExecutionState(stateDbPath, threadId) {
|
|
9
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
10
|
+
try {
|
|
11
|
+
return await db
|
|
12
|
+
.select({
|
|
13
|
+
id: schema_js_1.threads.id,
|
|
14
|
+
workspace: schema_js_1.threads.workspace,
|
|
15
|
+
sdkThreadId: schema_js_1.threads.sdkThreadId,
|
|
16
|
+
model: schema_js_1.threads.model,
|
|
17
|
+
reasoningLevel: schema_js_1.threads.reasoningLevel,
|
|
18
|
+
additionalModelInstructions: schema_js_1.threads.additionalModelInstructions,
|
|
19
|
+
currentSdkTurnId: schema_js_1.threads.currentSdkTurnId,
|
|
20
|
+
isCurrentTurnRunning: schema_js_1.threads.isCurrentTurnRunning,
|
|
21
|
+
runtimeContainer: schema_js_1.threads.runtimeContainer,
|
|
22
|
+
dindContainer: schema_js_1.threads.dindContainer,
|
|
23
|
+
homeDirectory: schema_js_1.threads.homeDirectory,
|
|
24
|
+
uid: schema_js_1.threads.uid,
|
|
25
|
+
gid: schema_js_1.threads.gid,
|
|
26
|
+
})
|
|
27
|
+
.from(schema_js_1.threads)
|
|
28
|
+
.where((0, drizzle_orm_1.eq)(schema_js_1.threads.id, threadId))
|
|
29
|
+
.get();
|
|
30
|
+
}
|
|
31
|
+
finally {
|
|
32
|
+
client.close();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
async function updateThreadTurnState(stateDbPath, threadId, update) {
|
|
36
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
37
|
+
try {
|
|
38
|
+
await db
|
|
39
|
+
.update(schema_js_1.threads)
|
|
40
|
+
.set(update)
|
|
41
|
+
.where((0, drizzle_orm_1.eq)(schema_js_1.threads.id, threadId));
|
|
42
|
+
}
|
|
43
|
+
finally {
|
|
44
|
+
client.close();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.enqueuePendingUserMessageRequestIdForTurn = enqueuePendingUserMessageRequestIdForTurn;
|
|
4
|
+
exports.removePendingUserMessageRequestIdForTurn = removePendingUserMessageRequestIdForTurn;
|
|
5
|
+
exports.assignPendingUserMessageRequestIdForItem = assignPendingUserMessageRequestIdForItem;
|
|
6
|
+
exports.consumePendingUserMessageRequestIdForItem = consumePendingUserMessageRequestIdForItem;
|
|
7
|
+
exports.clearPendingUserMessageRequestIdsForTurn = clearPendingUserMessageRequestIdsForTurn;
|
|
8
|
+
const drizzle_orm_1 = require("drizzle-orm");
|
|
9
|
+
const db_js_1 = require("../state/db.js");
|
|
10
|
+
const schema_js_1 = require("../state/schema.js");
|
|
11
|
+
async function enqueuePendingUserMessageRequestIdForTurn(stateDbPath, threadId, sdkTurnId, requestId) {
|
|
12
|
+
if (!requestId) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
16
|
+
try {
|
|
17
|
+
await db.insert(schema_js_1.threadUserMessageRequestStore).values({
|
|
18
|
+
threadId,
|
|
19
|
+
sdkTurnId,
|
|
20
|
+
requestId,
|
|
21
|
+
sdkItemId: null,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
client.close();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
async function removePendingUserMessageRequestIdForTurn(stateDbPath, threadId, sdkTurnId, requestId) {
|
|
29
|
+
if (!requestId) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
33
|
+
try {
|
|
34
|
+
await db
|
|
35
|
+
.delete(schema_js_1.threadUserMessageRequestStore)
|
|
36
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.requestId, requestId)));
|
|
37
|
+
}
|
|
38
|
+
finally {
|
|
39
|
+
client.close();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async function assignPendingUserMessageRequestIdForItem(stateDbPath, threadId, sdkTurnId, sdkItemId) {
|
|
43
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
44
|
+
try {
|
|
45
|
+
const [existingByItem] = await db
|
|
46
|
+
.select({
|
|
47
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
48
|
+
})
|
|
49
|
+
.from(schema_js_1.threadUserMessageRequestStore)
|
|
50
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkItemId, sdkItemId)))
|
|
51
|
+
.limit(1);
|
|
52
|
+
if (existingByItem) {
|
|
53
|
+
return existingByItem.requestId;
|
|
54
|
+
}
|
|
55
|
+
const [nextPending] = await db
|
|
56
|
+
.select({
|
|
57
|
+
id: schema_js_1.threadUserMessageRequestStore.id,
|
|
58
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
59
|
+
})
|
|
60
|
+
.from(schema_js_1.threadUserMessageRequestStore)
|
|
61
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.isNull)(schema_js_1.threadUserMessageRequestStore.sdkItemId)))
|
|
62
|
+
.orderBy((0, drizzle_orm_1.asc)(schema_js_1.threadUserMessageRequestStore.id))
|
|
63
|
+
.limit(1);
|
|
64
|
+
if (!nextPending) {
|
|
65
|
+
return undefined;
|
|
66
|
+
}
|
|
67
|
+
const [assigned] = await db
|
|
68
|
+
.update(schema_js_1.threadUserMessageRequestStore)
|
|
69
|
+
.set({
|
|
70
|
+
sdkItemId,
|
|
71
|
+
})
|
|
72
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.id, nextPending.id), (0, drizzle_orm_1.isNull)(schema_js_1.threadUserMessageRequestStore.sdkItemId)))
|
|
73
|
+
.returning({
|
|
74
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
75
|
+
});
|
|
76
|
+
if (assigned) {
|
|
77
|
+
return assigned.requestId;
|
|
78
|
+
}
|
|
79
|
+
const [racedAssignment] = await db
|
|
80
|
+
.select({
|
|
81
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
82
|
+
})
|
|
83
|
+
.from(schema_js_1.threadUserMessageRequestStore)
|
|
84
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkItemId, sdkItemId)))
|
|
85
|
+
.limit(1);
|
|
86
|
+
return racedAssignment?.requestId;
|
|
87
|
+
}
|
|
88
|
+
finally {
|
|
89
|
+
client.close();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
async function consumePendingUserMessageRequestIdForItem(stateDbPath, threadId, sdkTurnId, sdkItemId) {
|
|
93
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
94
|
+
try {
|
|
95
|
+
const [existingByItem] = await db
|
|
96
|
+
.select({
|
|
97
|
+
id: schema_js_1.threadUserMessageRequestStore.id,
|
|
98
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
99
|
+
})
|
|
100
|
+
.from(schema_js_1.threadUserMessageRequestStore)
|
|
101
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkItemId, sdkItemId)))
|
|
102
|
+
.limit(1);
|
|
103
|
+
if (existingByItem) {
|
|
104
|
+
await db.delete(schema_js_1.threadUserMessageRequestStore).where((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.id, existingByItem.id));
|
|
105
|
+
return existingByItem.requestId;
|
|
106
|
+
}
|
|
107
|
+
const [nextPending] = await db
|
|
108
|
+
.select({
|
|
109
|
+
id: schema_js_1.threadUserMessageRequestStore.id,
|
|
110
|
+
requestId: schema_js_1.threadUserMessageRequestStore.requestId,
|
|
111
|
+
})
|
|
112
|
+
.from(schema_js_1.threadUserMessageRequestStore)
|
|
113
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId), (0, drizzle_orm_1.isNull)(schema_js_1.threadUserMessageRequestStore.sdkItemId)))
|
|
114
|
+
.orderBy((0, drizzle_orm_1.asc)(schema_js_1.threadUserMessageRequestStore.id))
|
|
115
|
+
.limit(1);
|
|
116
|
+
if (!nextPending) {
|
|
117
|
+
return undefined;
|
|
118
|
+
}
|
|
119
|
+
await db.delete(schema_js_1.threadUserMessageRequestStore).where((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.id, nextPending.id));
|
|
120
|
+
return nextPending.requestId;
|
|
121
|
+
}
|
|
122
|
+
finally {
|
|
123
|
+
client.close();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
async function clearPendingUserMessageRequestIdsForTurn(stateDbPath, threadId, sdkTurnId) {
|
|
127
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
128
|
+
try {
|
|
129
|
+
await db
|
|
130
|
+
.delete(schema_js_1.threadUserMessageRequestStore)
|
|
131
|
+
.where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.threadId, threadId), (0, drizzle_orm_1.eq)(schema_js_1.threadUserMessageRequestStore.sdkTurnId, sdkTurnId)));
|
|
132
|
+
}
|
|
133
|
+
finally {
|
|
134
|
+
client.close();
|
|
135
|
+
}
|
|
136
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.renderRuntimeAgentsMd = renderRuntimeAgentsMd;
|
|
4
|
+
exports.ensureWorkspaceAgentsMd = ensureWorkspaceAgentsMd;
|
|
5
|
+
const node_fs_1 = require("node:fs");
|
|
6
|
+
const node_path_1 = require("node:path");
|
|
7
|
+
const RUNTIME_AGENTS_TEMPLATE_PATH = "templates/runtime_agents.md.j2";
|
|
8
|
+
const DEFAULT_HOME_DIRECTORY = "/home/agent";
|
|
9
|
+
function renderJinjaTemplate(template, context) {
|
|
10
|
+
return template.replace(/{{\s*([a-zA-Z0-9_]+)\s*}}/g, (_match, key) => {
|
|
11
|
+
const value = context[key];
|
|
12
|
+
if (value === undefined) {
|
|
13
|
+
throw new Error(`Missing template value for key '${key}'`);
|
|
14
|
+
}
|
|
15
|
+
return value;
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
function resolveTemplatePath() {
|
|
19
|
+
const distRelativePath = (0, node_path_1.join)(__dirname, "..", RUNTIME_AGENTS_TEMPLATE_PATH);
|
|
20
|
+
if ((0, node_fs_1.existsSync)(distRelativePath)) {
|
|
21
|
+
return distRelativePath;
|
|
22
|
+
}
|
|
23
|
+
const sourceRelativePath = (0, node_path_1.join)(__dirname, "..", "..", "src", RUNTIME_AGENTS_TEMPLATE_PATH);
|
|
24
|
+
if ((0, node_fs_1.existsSync)(sourceRelativePath)) {
|
|
25
|
+
return sourceRelativePath;
|
|
26
|
+
}
|
|
27
|
+
throw new Error(`Runtime AGENTS template was not found at ${distRelativePath} or ${sourceRelativePath}`);
|
|
28
|
+
}
|
|
29
|
+
function extractTopLevelSections(markdown) {
|
|
30
|
+
const sections = [];
|
|
31
|
+
const headingRegex = /^## .+$/gm;
|
|
32
|
+
const matches = [...markdown.matchAll(headingRegex)];
|
|
33
|
+
for (let index = 0; index < matches.length; index += 1) {
|
|
34
|
+
const match = matches[index];
|
|
35
|
+
const marker = match[0].trim();
|
|
36
|
+
const start = match.index ?? 0;
|
|
37
|
+
const end = index + 1 < matches.length ? (matches[index + 1].index ?? markdown.length) : markdown.length;
|
|
38
|
+
const content = markdown.slice(start, end).trimEnd();
|
|
39
|
+
sections.push({ marker, content });
|
|
40
|
+
}
|
|
41
|
+
return sections;
|
|
42
|
+
}
|
|
43
|
+
function renderRuntimeAgentsMd(homeDirectory = DEFAULT_HOME_DIRECTORY) {
|
|
44
|
+
const template = (0, node_fs_1.readFileSync)(resolveTemplatePath(), "utf8");
|
|
45
|
+
return renderJinjaTemplate(template, {
|
|
46
|
+
home_directory: homeDirectory,
|
|
47
|
+
}).trim() + "\n";
|
|
48
|
+
}
|
|
49
|
+
function ensureWorkspaceAgentsMd(workspaceDirectory, homeDirectory = DEFAULT_HOME_DIRECTORY) {
|
|
50
|
+
(0, node_fs_1.mkdirSync)(workspaceDirectory, { recursive: true });
|
|
51
|
+
const agentsPath = (0, node_path_1.join)(workspaceDirectory, "AGENTS.md");
|
|
52
|
+
let existing = "";
|
|
53
|
+
try {
|
|
54
|
+
existing = (0, node_fs_1.readFileSync)(agentsPath, "utf8");
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
existing = "";
|
|
58
|
+
}
|
|
59
|
+
let rendered = "";
|
|
60
|
+
try {
|
|
61
|
+
rendered = renderRuntimeAgentsMd(homeDirectory);
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const templateSections = extractTopLevelSections(rendered);
|
|
67
|
+
const pendingSections = templateSections
|
|
68
|
+
.filter((section) => !existing.includes(section.marker))
|
|
69
|
+
.map((section) => section.content);
|
|
70
|
+
if (pendingSections.length === 0) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const updated = existing.trim()
|
|
74
|
+
? `${existing.trimEnd()}\n\n${pendingSections.join("\n\n")}\n`
|
|
75
|
+
: rendered;
|
|
76
|
+
try {
|
|
77
|
+
(0, node_fs_1.writeFileSync)(agentsPath, updated, "utf8");
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
// Best-effort workspace instruction file.
|
|
81
|
+
}
|
|
82
|
+
}
|
package/dist/startup.js
ADDED
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.startup = startup;
|
|
40
|
+
const node_fs_1 = require("node:fs");
|
|
41
|
+
const node_path_1 = require("node:path");
|
|
42
|
+
const node_child_process_1 = require("node:child_process");
|
|
43
|
+
const p = __importStar(require("@clack/prompts"));
|
|
44
|
+
const figlet_1 = __importDefault(require("figlet"));
|
|
45
|
+
const config_js_1 = require("./config.js");
|
|
46
|
+
const db_js_1 = require("./state/db.js");
|
|
47
|
+
const schema_js_1 = require("./state/schema.js");
|
|
48
|
+
const host_js_1 = require("./service/host.js");
|
|
49
|
+
const path_js_1 = require("./utils/path.js");
|
|
50
|
+
function banner() {
|
|
51
|
+
console.log();
|
|
52
|
+
console.log(figlet_1.default.textSync("CompanyHelm", { font: "Small" }));
|
|
53
|
+
console.log();
|
|
54
|
+
}
|
|
55
|
+
async function dedicatedAuth(cfg, db) {
|
|
56
|
+
const port = cfg.codex.codex_auth_port;
|
|
57
|
+
const socatPort = port + 1; // socat listens on a separate port to avoid conflicting with codex
|
|
58
|
+
const containerName = `companyhelm-codex-auth-${Date.now()}`;
|
|
59
|
+
p.log.info("Starting Codex login inside a container...");
|
|
60
|
+
p.log.info("A browser URL will appear -- open it to complete authentication.");
|
|
61
|
+
const configDir = (0, path_js_1.expandHome)(cfg.config_directory);
|
|
62
|
+
if (!(0, node_fs_1.existsSync)(configDir)) {
|
|
63
|
+
(0, node_fs_1.mkdirSync)(configDir, { recursive: true });
|
|
64
|
+
}
|
|
65
|
+
const destPath = (0, node_path_1.join)(configDir, cfg.codex.codex_auth_file_path);
|
|
66
|
+
// Start codex interactively (full TTY passthrough so user can interact)
|
|
67
|
+
// Host:port → container:socatPort (socat) → container:127.0.0.1:port (codex)
|
|
68
|
+
const child = (0, node_child_process_1.spawn)("docker", [
|
|
69
|
+
"run",
|
|
70
|
+
"-it",
|
|
71
|
+
"--name", containerName,
|
|
72
|
+
"-p", `${port}:${socatPort}`,
|
|
73
|
+
"--entrypoint", "bash",
|
|
74
|
+
cfg.runtime_image,
|
|
75
|
+
"-c",
|
|
76
|
+
`source "$NVM_DIR/nvm.sh"; socat TCP-LISTEN:${socatPort},fork,bind=0.0.0.0,reuseaddr TCP:127.0.0.1:${port} 2>/dev/null & codex`,
|
|
77
|
+
], { stdio: "inherit" });
|
|
78
|
+
// Poll for auth file inside the container — once it exists, login succeeded
|
|
79
|
+
let authCopied = false;
|
|
80
|
+
await new Promise((resolve, reject) => {
|
|
81
|
+
const poll = setInterval(() => {
|
|
82
|
+
// Use sh -c so ~ is expanded by the container's shell
|
|
83
|
+
const check = (0, node_child_process_1.spawnSync)("docker", ["exec", containerName, "sh", "-c", `test -f ${cfg.codex.codex_auth_path}`], { stdio: "ignore" });
|
|
84
|
+
if (check.status === 0) {
|
|
85
|
+
clearInterval(poll);
|
|
86
|
+
// Resolve ~ inside the container to get the absolute path for docker cp
|
|
87
|
+
const resolveResult = (0, node_child_process_1.spawnSync)("docker", ["exec", containerName, "sh", "-c", `echo ${cfg.codex.codex_auth_path}`], { encoding: "utf-8" });
|
|
88
|
+
const containerAuthAbsPath = resolveResult.stdout.trim();
|
|
89
|
+
// Copy auth file from container to host
|
|
90
|
+
const cpResult = (0, node_child_process_1.spawnSync)("docker", ["cp", `${containerName}:${containerAuthAbsPath}`, destPath], { stdio: "ignore" });
|
|
91
|
+
if (cpResult.status !== 0) {
|
|
92
|
+
(0, node_child_process_1.spawnSync)("docker", ["rm", "-f", containerName], { stdio: "ignore" });
|
|
93
|
+
reject(new Error("Failed to extract auth file from container."));
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
// Mark success before killing container to avoid race with exit handler
|
|
97
|
+
authCopied = true;
|
|
98
|
+
(0, node_child_process_1.spawnSync)("docker", ["rm", "-f", containerName], { stdio: "ignore" });
|
|
99
|
+
resolve();
|
|
100
|
+
}
|
|
101
|
+
}, 1000);
|
|
102
|
+
// If codex exits before auth file appeared, user cancelled
|
|
103
|
+
child.on("exit", () => {
|
|
104
|
+
clearInterval(poll);
|
|
105
|
+
if (!authCopied) {
|
|
106
|
+
(0, node_child_process_1.spawnSync)("docker", ["rm", "-f", containerName], { stdio: "ignore" });
|
|
107
|
+
reject(new Error("Codex login failed or was cancelled."));
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
await db.insert(schema_js_1.agentSdks).values({ name: "codex", authentication: "dedicated" });
|
|
112
|
+
p.log.success(`Codex auth saved to ${destPath}`);
|
|
113
|
+
}
|
|
114
|
+
async function startup() {
|
|
115
|
+
banner();
|
|
116
|
+
const cfg = config_js_1.config.parse({});
|
|
117
|
+
const s = p.spinner();
|
|
118
|
+
s.start("Initializing state database");
|
|
119
|
+
const { db } = await (0, db_js_1.initDb)(cfg.state_db_path);
|
|
120
|
+
s.stop("State database ready.");
|
|
121
|
+
// Check if any agent SDK is configured
|
|
122
|
+
const sdks = await db.select().from(schema_js_1.agentSdks).all();
|
|
123
|
+
if (sdks.length > 0) {
|
|
124
|
+
p.log.success(`Agent SDK configured: ${sdks.map((s) => s.name).join(", ")}`);
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
// No SDK configured -- offer auth options
|
|
128
|
+
p.intro("No agent SDK configured. Let's set up Codex authentication.");
|
|
129
|
+
const hostInfo = (0, host_js_1.getHostInfo)(cfg.codex.codex_auth_path);
|
|
130
|
+
const options = [
|
|
131
|
+
{
|
|
132
|
+
value: "dedicated",
|
|
133
|
+
label: "Dedicated",
|
|
134
|
+
hint: "recommended -- runs Codex login inside a container",
|
|
135
|
+
},
|
|
136
|
+
];
|
|
137
|
+
if (hostInfo.codexAuthExists) {
|
|
138
|
+
options.push({
|
|
139
|
+
value: "host",
|
|
140
|
+
label: "Host",
|
|
141
|
+
hint: `reuse existing credentials from ${cfg.codex.codex_auth_path}`,
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
const authMode = await p.select({
|
|
145
|
+
message: "How would you like to authenticate Codex?",
|
|
146
|
+
options,
|
|
147
|
+
});
|
|
148
|
+
if (p.isCancel(authMode)) {
|
|
149
|
+
p.cancel("Setup cancelled.");
|
|
150
|
+
process.exit(0);
|
|
151
|
+
}
|
|
152
|
+
if (authMode === "host") {
|
|
153
|
+
await db.insert(schema_js_1.agentSdks).values({ name: "codex", authentication: "host" });
|
|
154
|
+
p.outro("Codex SDK configured with host authentication.");
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
// Dedicated auth flow
|
|
158
|
+
try {
|
|
159
|
+
await dedicatedAuth(cfg, db);
|
|
160
|
+
p.outro("Codex login successful!");
|
|
161
|
+
}
|
|
162
|
+
catch (err) {
|
|
163
|
+
p.cancel(err.message ?? "Codex login failed or was cancelled.");
|
|
164
|
+
process.exit(1);
|
|
165
|
+
}
|
|
166
|
+
}
|
package/dist/state/db.js
ADDED
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.initDb = initDb;
|
|
37
|
+
const client_1 = require("@libsql/client");
|
|
38
|
+
const libsql_1 = require("drizzle-orm/libsql");
|
|
39
|
+
const migrator_1 = require("drizzle-orm/libsql/migrator");
|
|
40
|
+
const node_fs_1 = require("node:fs");
|
|
41
|
+
const node_path_1 = require("node:path");
|
|
42
|
+
const node_path_2 = require("node:path");
|
|
43
|
+
const schema = __importStar(require("./schema.js"));
|
|
44
|
+
const path_js_1 = require("../utils/path.js");
|
|
45
|
+
async function reconcileLegacyThreadsSchema(client) {
|
|
46
|
+
const pragmaResult = await client.execute("PRAGMA table_info('threads')");
|
|
47
|
+
const columnNames = new Set(pragmaResult.rows.map((row) => String(row.name ?? "")));
|
|
48
|
+
if (columnNames.has("sdk_id") && !columnNames.has("sdk_thread_id")) {
|
|
49
|
+
await client.execute("ALTER TABLE threads RENAME COLUMN sdk_id TO sdk_thread_id");
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
async function initDb(stateDbPath) {
|
|
53
|
+
const resolved = (0, path_js_1.expandHome)(stateDbPath);
|
|
54
|
+
const dir = (0, node_path_1.dirname)(resolved);
|
|
55
|
+
if (!(0, node_fs_1.existsSync)(dir)) {
|
|
56
|
+
(0, node_fs_1.mkdirSync)(dir, { recursive: true });
|
|
57
|
+
}
|
|
58
|
+
const client = (0, client_1.createClient)({ url: `file:${resolved}` });
|
|
59
|
+
const db = (0, libsql_1.drizzle)(client, { schema });
|
|
60
|
+
await (0, migrator_1.migrate)(db, { migrationsFolder: (0, node_path_2.join)(__dirname, "..", "..", "drizzle") });
|
|
61
|
+
await reconcileLegacyThreadsSchema(client);
|
|
62
|
+
return { db, client };
|
|
63
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.threadUserMessageRequestStore = exports.threads = exports.llmModels = exports.agentSdks = void 0;
|
|
4
|
+
const sqlite_core_1 = require("drizzle-orm/sqlite-core");
|
|
5
|
+
// ── agent_sdks ──────────────────────────────────────────────────────────────
|
|
6
|
+
exports.agentSdks = (0, sqlite_core_1.sqliteTable)("agent_sdks", {
|
|
7
|
+
name: (0, sqlite_core_1.text)("name").primaryKey(),
|
|
8
|
+
authentication: (0, sqlite_core_1.text)("authentication", {
|
|
9
|
+
enum: ["unauthenticated", "host", "dedicated", "api-key"],
|
|
10
|
+
}).notNull(),
|
|
11
|
+
});
|
|
12
|
+
// ── llm_models ──────────────────────────────────────────────────────────────
|
|
13
|
+
exports.llmModels = (0, sqlite_core_1.sqliteTable)("llm_models", {
|
|
14
|
+
name: (0, sqlite_core_1.text)("name").primaryKey(),
|
|
15
|
+
sdkName: (0, sqlite_core_1.text)("sdk_name")
|
|
16
|
+
.notNull()
|
|
17
|
+
.references(() => exports.agentSdks.name, { onDelete: "cascade" }),
|
|
18
|
+
reasoningLevels: (0, sqlite_core_1.text)("reasoning_levels", { mode: "json" })
|
|
19
|
+
.$type(),
|
|
20
|
+
});
|
|
21
|
+
// -- threads ──────────────────────────────────────────────────────────────────
|
|
22
|
+
exports.threads = (0, sqlite_core_1.sqliteTable)("threads", {
|
|
23
|
+
id: (0, sqlite_core_1.text)("id").primaryKey(),
|
|
24
|
+
sdkThreadId: (0, sqlite_core_1.text)("sdk_thread_id"),
|
|
25
|
+
cliSecret: (0, sqlite_core_1.text)("cli_secret"),
|
|
26
|
+
model: (0, sqlite_core_1.text)("model").notNull(),
|
|
27
|
+
reasoningLevel: (0, sqlite_core_1.text)("reasoning_level").notNull(),
|
|
28
|
+
additionalModelInstructions: (0, sqlite_core_1.text)("additional_model_instructions"),
|
|
29
|
+
status: (0, sqlite_core_1.text)("status", { enum: ["pending", "ready", "deleting"] }).notNull(),
|
|
30
|
+
currentSdkTurnId: (0, sqlite_core_1.text)("current_sdk_turn_id"),
|
|
31
|
+
isCurrentTurnRunning: (0, sqlite_core_1.integer)("is_current_turn_running", { mode: "boolean" }).notNull(),
|
|
32
|
+
workspace: (0, sqlite_core_1.text)("workspace").notNull(),
|
|
33
|
+
runtimeContainer: (0, sqlite_core_1.text)("runtime_container").notNull(),
|
|
34
|
+
dindContainer: (0, sqlite_core_1.text)("dind_container"),
|
|
35
|
+
// home directory within the container
|
|
36
|
+
homeDirectory: (0, sqlite_core_1.text)("home_directory").notNull(),
|
|
37
|
+
// uid of the user within the container
|
|
38
|
+
uid: (0, sqlite_core_1.integer)("uid").notNull(),
|
|
39
|
+
// gid of the user within the container
|
|
40
|
+
gid: (0, sqlite_core_1.integer)("gid").notNull(),
|
|
41
|
+
});
|
|
42
|
+
// -- thread_user_message_request_store ----------------------------------------
|
|
43
|
+
exports.threadUserMessageRequestStore = (0, sqlite_core_1.sqliteTable)("thread_user_message_request_store", {
|
|
44
|
+
id: (0, sqlite_core_1.integer)("id").primaryKey({ autoIncrement: true }),
|
|
45
|
+
threadId: (0, sqlite_core_1.text)("thread_id")
|
|
46
|
+
.notNull()
|
|
47
|
+
.references(() => exports.threads.id, { onDelete: "cascade" }),
|
|
48
|
+
sdkTurnId: (0, sqlite_core_1.text)("sdk_turn_id").notNull(),
|
|
49
|
+
requestId: (0, sqlite_core_1.text)("request_id").notNull(),
|
|
50
|
+
sdkItemId: (0, sqlite_core_1.text)("sdk_item_id"),
|
|
51
|
+
});
|