@companyhelm/runner 0.0.12 → 0.0.13
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/dist/cli.js +57 -0
- package/dist/commands/global-options.js +20 -0
- package/dist/commands/register-commands.js +15 -0
- package/dist/commands/root.js +2627 -0
- package/dist/commands/runner/common.js +18 -0
- package/dist/commands/runner/register-runner-commands.js +12 -0
- package/dist/commands/runner/start.js +30 -0
- package/dist/commands/runner/stop.js +55 -0
- package/dist/commands/sdk/codex/auth.js +200 -0
- package/dist/commands/sdk/codex/register-codex-sdk-commands.js +12 -0
- package/dist/commands/sdk/codex/use-dedicated-auth.js +18 -0
- package/dist/commands/sdk/codex/use-host-auth.js +19 -0
- package/dist/commands/sdk/list.js +76 -0
- package/dist/commands/sdk/refresh-models.js +25 -0
- package/dist/commands/sdk/register-sdk-commands.js +14 -0
- package/dist/commands/shell.js +90 -0
- package/dist/commands/startup.js +137 -0
- package/dist/commands/status.js +32 -0
- package/dist/commands/thread/docker.js +77 -0
- package/dist/commands/thread/list.js +37 -0
- package/dist/commands/thread/register-thread-commands.js +12 -0
- package/dist/config.js +105 -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/service/app_server.js +441 -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 +319 -0
- package/dist/service/docker/dind.js +114 -0
- package/dist/service/docker/runtime_app_server_exec.js +97 -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 +91 -0
- package/dist/service/thread_lifecycle.js +693 -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/state/daemon_state.js +83 -0
- package/dist/state/db.js +63 -0
- package/dist/state/schema.js +59 -0
- package/dist/templates/app_server_bootstrap.sh.j2 +52 -0
- package/dist/templates/runtime_agents.md.j2 +50 -0
- package/dist/templates/runtime_bashrc.j2 +19 -0
- package/dist/utils/async_queue.js +102 -0
- package/dist/utils/daemon.js +15 -0
- package/dist/utils/logger.js +96 -0
- package/dist/utils/path.js +10 -0
- package/dist/utils/process.js +83 -0
- package/dist/utils/terminal.js +34 -0
- package/package.json +1 -1
|
@@ -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
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RUNNER_DAEMON_STATE_ID = void 0;
|
|
4
|
+
exports.readCurrentDaemonState = readCurrentDaemonState;
|
|
5
|
+
exports.claimCurrentDaemonState = claimCurrentDaemonState;
|
|
6
|
+
exports.clearCurrentDaemonState = clearCurrentDaemonState;
|
|
7
|
+
const drizzle_orm_1 = require("drizzle-orm");
|
|
8
|
+
const db_js_1 = require("./db.js");
|
|
9
|
+
const schema_js_1 = require("./schema.js");
|
|
10
|
+
const process_js_1 = require("../utils/process.js");
|
|
11
|
+
exports.RUNNER_DAEMON_STATE_ID = "runner";
|
|
12
|
+
async function readCurrentDaemonState(stateDbPath) {
|
|
13
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
14
|
+
try {
|
|
15
|
+
const existing = await db.select().from(schema_js_1.daemonState).where((0, drizzle_orm_1.eq)(schema_js_1.daemonState.id, exports.RUNNER_DAEMON_STATE_ID)).all();
|
|
16
|
+
const row = existing[0];
|
|
17
|
+
if (!row) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
return {
|
|
21
|
+
id: row.id,
|
|
22
|
+
pid: row.pid ?? null,
|
|
23
|
+
logPath: row.logPath ?? null,
|
|
24
|
+
startedAt: row.startedAt,
|
|
25
|
+
updatedAt: row.updatedAt,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
finally {
|
|
29
|
+
client.close();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async function claimCurrentDaemonState(stateDbPath, pid, logPath) {
|
|
33
|
+
const now = new Date().toISOString();
|
|
34
|
+
const { client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
35
|
+
try {
|
|
36
|
+
await client.execute("BEGIN IMMEDIATE");
|
|
37
|
+
try {
|
|
38
|
+
const existing = await client.execute({
|
|
39
|
+
sql: "SELECT pid FROM daemon_state WHERE id = ?",
|
|
40
|
+
args: [exports.RUNNER_DAEMON_STATE_ID],
|
|
41
|
+
});
|
|
42
|
+
const row = existing.rows[0];
|
|
43
|
+
const currentPid = typeof row?.pid === "number" ? row.pid : row?.pid == null ? null : Number(row.pid);
|
|
44
|
+
if (currentPid && currentPid !== pid && (0, process_js_1.isProcessRunning)(currentPid)) {
|
|
45
|
+
throw new Error(`Another companyhelm daemon is already running with pid ${currentPid}.`);
|
|
46
|
+
}
|
|
47
|
+
await client.execute({
|
|
48
|
+
sql: "INSERT INTO daemon_state (id, pid, log_path, started_at, updated_at) VALUES (?, ?, ?, ?, ?) " +
|
|
49
|
+
"ON CONFLICT(id) DO UPDATE SET pid = excluded.pid, log_path = excluded.log_path, started_at = excluded.started_at, updated_at = excluded.updated_at",
|
|
50
|
+
args: [exports.RUNNER_DAEMON_STATE_ID, pid, logPath, now, now],
|
|
51
|
+
});
|
|
52
|
+
await client.execute("COMMIT");
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
await client.execute("ROLLBACK");
|
|
56
|
+
throw error;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
finally {
|
|
60
|
+
client.close();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async function clearCurrentDaemonState(stateDbPath, pid) {
|
|
64
|
+
const now = new Date().toISOString();
|
|
65
|
+
const { db, client } = await (0, db_js_1.initDb)(stateDbPath);
|
|
66
|
+
try {
|
|
67
|
+
const existing = await db.select().from(schema_js_1.daemonState).where((0, drizzle_orm_1.eq)(schema_js_1.daemonState.id, exports.RUNNER_DAEMON_STATE_ID)).all();
|
|
68
|
+
const current = existing[0];
|
|
69
|
+
if (!current || current.pid !== pid) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
await db
|
|
73
|
+
.update(schema_js_1.daemonState)
|
|
74
|
+
.set({
|
|
75
|
+
pid: null,
|
|
76
|
+
updatedAt: now,
|
|
77
|
+
})
|
|
78
|
+
.where((0, drizzle_orm_1.eq)(schema_js_1.daemonState.id, exports.RUNNER_DAEMON_STATE_ID));
|
|
79
|
+
}
|
|
80
|
+
finally {
|
|
81
|
+
client.close();
|
|
82
|
+
}
|
|
83
|
+
}
|
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,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.daemonState = 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
|
+
});
|
|
52
|
+
// -- daemon_state ------------------------------------------------------------
|
|
53
|
+
exports.daemonState = (0, sqlite_core_1.sqliteTable)("daemon_state", {
|
|
54
|
+
id: (0, sqlite_core_1.text)("id").primaryKey(),
|
|
55
|
+
pid: (0, sqlite_core_1.integer)("pid"),
|
|
56
|
+
logPath: (0, sqlite_core_1.text)("log_path"),
|
|
57
|
+
startedAt: (0, sqlite_core_1.text)("started_at").notNull(),
|
|
58
|
+
updatedAt: (0, sqlite_core_1.text)("updated_at").notNull(),
|
|
59
|
+
});
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
set -euo pipefail
|
|
2
|
+
|
|
3
|
+
AGENT_USER={{ agent_user }}
|
|
4
|
+
AGENT_HOME={{ agent_home }}
|
|
5
|
+
AGENT_UID={{ agent_uid }}
|
|
6
|
+
AGENT_GID={{ agent_gid }}
|
|
7
|
+
CODEX_AUTH_PATH={{ codex_auth_path }}
|
|
8
|
+
APP_SERVER_COMMAND={{ app_server_command }}
|
|
9
|
+
EXISTING_UID_USER=""
|
|
10
|
+
|
|
11
|
+
if getent passwd "$AGENT_UID" >/dev/null 2>&1; then
|
|
12
|
+
EXISTING_UID_USER="$(getent passwd "$AGENT_UID" | cut -d: -f1)"
|
|
13
|
+
AGENT_USER="$EXISTING_UID_USER"
|
|
14
|
+
fi
|
|
15
|
+
|
|
16
|
+
AGENT_GROUP="$AGENT_USER"
|
|
17
|
+
if getent group "$AGENT_GID" >/dev/null 2>&1; then
|
|
18
|
+
AGENT_GROUP="$(getent group "$AGENT_GID" | cut -d: -f1)"
|
|
19
|
+
elif getent group "$AGENT_USER" >/dev/null 2>&1; then
|
|
20
|
+
groupmod -g "$AGENT_GID" "$AGENT_USER"
|
|
21
|
+
AGENT_GROUP="$AGENT_USER"
|
|
22
|
+
else
|
|
23
|
+
groupadd -g "$AGENT_GID" "$AGENT_USER"
|
|
24
|
+
AGENT_GROUP="$AGENT_USER"
|
|
25
|
+
fi
|
|
26
|
+
|
|
27
|
+
if id -u "$AGENT_USER" >/dev/null 2>&1; then
|
|
28
|
+
usermod -u "$AGENT_UID" -g "$AGENT_GROUP" -d "$AGENT_HOME" -s /bin/bash "$AGENT_USER" || true
|
|
29
|
+
else
|
|
30
|
+
useradd -m -d "$AGENT_HOME" -u "$AGENT_UID" -g "$AGENT_GROUP" -s /bin/bash "$AGENT_USER"
|
|
31
|
+
fi
|
|
32
|
+
|
|
33
|
+
SUDOERS_FILE="/etc/sudoers.d/90-companyhelm-agent"
|
|
34
|
+
if command -v sudo >/dev/null 2>&1; then
|
|
35
|
+
install -d -m 0750 /etc/sudoers.d
|
|
36
|
+
printf '%s\n' "$AGENT_USER ALL=(ALL) NOPASSWD:ALL" > "$SUDOERS_FILE"
|
|
37
|
+
chmod 0440 "$SUDOERS_FILE"
|
|
38
|
+
if command -v visudo >/dev/null 2>&1; then
|
|
39
|
+
visudo -cf "$SUDOERS_FILE" >/dev/null
|
|
40
|
+
fi
|
|
41
|
+
fi
|
|
42
|
+
|
|
43
|
+
mkdir -p "$AGENT_HOME"
|
|
44
|
+
chown "$AGENT_UID:$AGENT_GID" "$AGENT_HOME" || true
|
|
45
|
+
|
|
46
|
+
if [ -n "${CODEX_AUTH_PATH:-}" ]; then
|
|
47
|
+
mkdir -p "$(dirname "$CODEX_AUTH_PATH")"
|
|
48
|
+
chown -R "$AGENT_UID:$AGENT_GID" "$(dirname "$CODEX_AUTH_PATH")" || true
|
|
49
|
+
fi
|
|
50
|
+
|
|
51
|
+
export HOME="$AGENT_HOME"
|
|
52
|
+
exec sudo -n -E -H -u "$AGENT_USER" bash -lc "$APP_SERVER_COMMAND"
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
# Agent Instructions
|
|
2
|
+
|
|
3
|
+
## Workspace Structure
|
|
4
|
+
|
|
5
|
+
- You are running in a thread-specific container and workspace
|
|
6
|
+
- This workspace is not initialized as a Git repository by default. Repositories should live in a subdirectory of the workspace.
|
|
7
|
+
|
|
8
|
+
## Docker
|
|
9
|
+
|
|
10
|
+
Docker is available, the docker host runs in a separate container. The network is shared with container.
|
|
11
|
+
- only the `/workspace` is shared with the docker host
|
|
12
|
+
- `{{home_directory}}/.codex/auth.json` is also shared with the docker host
|
|
13
|
+
- Nested DinD is not supported in this environment because the outer runtime already uses rootless DinD.
|
|
14
|
+
- If you need to use Docker in Docker you can mount the docker socket in the container and use this environment DinD to run containers within containers.
|
|
15
|
+
|
|
16
|
+
## GitHub Installations
|
|
17
|
+
|
|
18
|
+
- Synced GitHub installation credentials are written to `/workspace/.companyhelm/installations.json`.
|
|
19
|
+
- Use `list-installations` to inspect installation IDs, repository scopes, tokens, and expiration timestamps.
|
|
20
|
+
- Use `gh-use-installation <installation-id>` to configure `gh` authentication for a specific installation.
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
# Inspect synced installation credentials
|
|
24
|
+
list-installations
|
|
25
|
+
|
|
26
|
+
# Configure gh to use installation 112331765
|
|
27
|
+
gh-use-installation 112331765
|
|
28
|
+
|
|
29
|
+
# Verify gh is authenticated for github.com
|
|
30
|
+
gh auth status --hostname github.com
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Available CLI Tools
|
|
34
|
+
|
|
35
|
+
- `list-installations`: list synced GitHub installations with repositories, access tokens, and expirations.
|
|
36
|
+
- `gh-use-installation <installation-id>`: configure `gh` authentication for a selected GitHub installation token.
|
|
37
|
+
- `aws`: AWS CLI is pre-installed and available in `PATH`.
|
|
38
|
+
- For scripted PR creation/updates, always use `gh pr create --body-file <path>` and `gh pr edit --body-file <path>` instead of inline `--body` to avoid shell interpolation of markdown backticks.
|
|
39
|
+
- DO NOT INSTALL PLAYWRIGHT IN THE RUNTIME IMAGE. Playwright CLI is already installed and available for browser automation tasks with Chromium pre-installed: `playwright open --browser=chromium ...`
|
|
40
|
+
|
|
41
|
+
## CompanyHelm Agent CLI
|
|
42
|
+
|
|
43
|
+
- `companyhelm-agent` is pre-installed in the runtime image.
|
|
44
|
+
- Thread bootstrap writes `{{home_directory}}/.config/companyhelm-agent-cli/config.json` with:
|
|
45
|
+
- `agent_api_url`: localhost targets are rewritten to `host.docker.internal` (for example `http://host.docker.internal:<port>`) for Docker-to-host access.
|
|
46
|
+
- `token`: sourced from the thread secret.
|
|
47
|
+
- Example commands:
|
|
48
|
+
- `companyhelm-agent task get --task-id <id>`
|
|
49
|
+
- `companyhelm-agent task dependencies --task-id <id>`
|
|
50
|
+
- `companyhelm-agent task update-status --task-id <id> --status <draft|pending|in_progress|completed>`
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# CompanyHelm runtime shell initialization.
|
|
2
|
+
# This file is generated by companyhelm-runner when a thread runtime starts.
|
|
3
|
+
|
|
4
|
+
if [ -z "${NVM_DIR:-}" ] || [ ! -s "$NVM_DIR/nvm.sh" ]; then
|
|
5
|
+
for candidate in "/usr/local/nvm" "$HOME/.nvm" "/opt/nvm" "/root/.nvm"; do
|
|
6
|
+
if [ -s "$candidate/nvm.sh" ]; then
|
|
7
|
+
export NVM_DIR="$candidate"
|
|
8
|
+
break
|
|
9
|
+
fi
|
|
10
|
+
done
|
|
11
|
+
fi
|
|
12
|
+
|
|
13
|
+
if [ -n "${NVM_DIR:-}" ] && [ -s "$NVM_DIR/nvm.sh" ]; then
|
|
14
|
+
. "$NVM_DIR/nvm.sh"
|
|
15
|
+
nvm use --silent default >/dev/null 2>&1 || true
|
|
16
|
+
if [ -s "$NVM_DIR/bash_completion" ]; then
|
|
17
|
+
. "$NVM_DIR/bash_completion"
|
|
18
|
+
fi
|
|
19
|
+
fi
|