clawdex-mobile 1.0.0
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/.github/workflows/ci.yml +77 -0
- package/.github/workflows/npm-release.yml +67 -0
- package/AGENTS.md +120 -0
- package/LICENSE +21 -0
- package/README.md +648 -0
- package/STATUS.md +115 -0
- package/apps/mobile/.env.example +7 -0
- package/apps/mobile/App.tsx +589 -0
- package/apps/mobile/app.json +33 -0
- package/apps/mobile/assets/brand/adaptive-icon.png +0 -0
- package/apps/mobile/assets/brand/app-icon.png +0 -0
- package/apps/mobile/assets/brand/favicon.png +0 -0
- package/apps/mobile/assets/brand/mark.png +0 -0
- package/apps/mobile/assets/brand/splash-icon.png +0 -0
- package/apps/mobile/babel.config.js +7 -0
- package/apps/mobile/eslint.config.cjs +28 -0
- package/apps/mobile/index.js +5 -0
- package/apps/mobile/metro.config.js +3 -0
- package/apps/mobile/package.json +55 -0
- package/apps/mobile/src/api/__tests__/chatMapping.test.ts +132 -0
- package/apps/mobile/src/api/__tests__/client.test.ts +872 -0
- package/apps/mobile/src/api/__tests__/ws.test.ts +575 -0
- package/apps/mobile/src/api/chatMapping.ts +591 -0
- package/apps/mobile/src/api/client.ts +1087 -0
- package/apps/mobile/src/api/types.ts +267 -0
- package/apps/mobile/src/api/ws.ts +801 -0
- package/apps/mobile/src/components/ActivityBar.tsx +76 -0
- package/apps/mobile/src/components/ApprovalBanner.tsx +207 -0
- package/apps/mobile/src/components/BrandMark.tsx +43 -0
- package/apps/mobile/src/components/ChatHeader.tsx +106 -0
- package/apps/mobile/src/components/ChatInput.tsx +236 -0
- package/apps/mobile/src/components/ChatMessage.tsx +400 -0
- package/apps/mobile/src/components/StatusLine.tsx +52 -0
- package/apps/mobile/src/components/ToolBlock.tsx +65 -0
- package/apps/mobile/src/components/TypingIndicator.tsx +64 -0
- package/apps/mobile/src/config.ts +75 -0
- package/apps/mobile/src/navigation/DrawerContent.tsx +969 -0
- package/apps/mobile/src/screens/GitScreen.tsx +573 -0
- package/apps/mobile/src/screens/MainScreen.tsx +6905 -0
- package/apps/mobile/src/screens/PrivacyScreen.tsx +196 -0
- package/apps/mobile/src/screens/SettingsScreen.tsx +776 -0
- package/apps/mobile/src/screens/TerminalScreen.tsx +251 -0
- package/apps/mobile/src/screens/TermsScreen.tsx +192 -0
- package/apps/mobile/src/theme.ts +112 -0
- package/apps/mobile/src/types/assets.d.ts +4 -0
- package/apps/mobile/tsconfig.json +33 -0
- package/bin/clawdex.js +72 -0
- package/docs/app-review-notes.md +111 -0
- package/docs/open-source-license-requirements.md +32 -0
- package/docs/plans/2026-02-20-codex-desktop-style-redesign.md +190 -0
- package/docs/plans/2026-02-20-codex-mobile-implementation.md +1630 -0
- package/docs/plans/2026-02-21-codex-ui-redesign-design.md +101 -0
- package/docs/plans/2026-02-21-codex-ui-redesign.md +1229 -0
- package/docs/realtime-streaming-limitations.md +77 -0
- package/package.json +47 -0
- package/scripts/setup-secure-dev.sh +169 -0
- package/scripts/setup-wizard.sh +1302 -0
- package/scripts/start-bridge-secure.sh +38 -0
- package/scripts/start-expo.sh +176 -0
- package/scripts/stop-services.sh +61 -0
- package/scripts/teardown.sh +136 -0
- package/services/mac-bridge/.env.example +10 -0
- package/services/mac-bridge/codex-types/AbsolutePathBuf.ts +14 -0
- package/services/mac-bridge/codex-types/AddConversationListenerParams.ts +6 -0
- package/services/mac-bridge/codex-types/AddConversationSubscriptionResponse.ts +5 -0
- package/services/mac-bridge/codex-types/AgentMessageContent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentMessageContentDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentMessageDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentMessageEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentMessageItem.ts +21 -0
- package/services/mac-bridge/codex-types/AgentReasoningDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentReasoningEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentReasoningRawContentDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentReasoningRawContentEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentReasoningSectionBreakEvent.ts +5 -0
- package/services/mac-bridge/codex-types/AgentStatus.ts +8 -0
- package/services/mac-bridge/codex-types/ApplyPatchApprovalParams.ts +21 -0
- package/services/mac-bridge/codex-types/ApplyPatchApprovalRequestEvent.ts +23 -0
- package/services/mac-bridge/codex-types/ApplyPatchApprovalResponse.ts +6 -0
- package/services/mac-bridge/codex-types/ArchiveConversationParams.ts +6 -0
- package/services/mac-bridge/codex-types/ArchiveConversationResponse.ts +5 -0
- package/services/mac-bridge/codex-types/AskForApproval.ts +9 -0
- package/services/mac-bridge/codex-types/AuthMode.ts +8 -0
- package/services/mac-bridge/codex-types/AuthStatusChangeNotification.ts +9 -0
- package/services/mac-bridge/codex-types/BackgroundEventEvent.ts +5 -0
- package/services/mac-bridge/codex-types/ByteRange.ts +13 -0
- package/services/mac-bridge/codex-types/CallToolResult.ts +9 -0
- package/services/mac-bridge/codex-types/CancelLoginChatGptParams.ts +5 -0
- package/services/mac-bridge/codex-types/CancelLoginChatGptResponse.ts +5 -0
- package/services/mac-bridge/codex-types/ClientInfo.ts +5 -0
- package/services/mac-bridge/codex-types/ClientNotification.ts +5 -0
- package/services/mac-bridge/codex-types/ClientRequest.ts +60 -0
- package/services/mac-bridge/codex-types/CodexErrorInfo.ts +8 -0
- package/services/mac-bridge/codex-types/CollabAgentInteractionBeginEvent.ts +23 -0
- package/services/mac-bridge/codex-types/CollabAgentInteractionEndEvent.ts +28 -0
- package/services/mac-bridge/codex-types/CollabAgentSpawnBeginEvent.ts +19 -0
- package/services/mac-bridge/codex-types/CollabAgentSpawnEndEvent.ts +28 -0
- package/services/mac-bridge/codex-types/CollabCloseBeginEvent.ts +18 -0
- package/services/mac-bridge/codex-types/CollabCloseEndEvent.ts +24 -0
- package/services/mac-bridge/codex-types/CollabResumeBeginEvent.ts +18 -0
- package/services/mac-bridge/codex-types/CollabResumeEndEvent.ts +24 -0
- package/services/mac-bridge/codex-types/CollabWaitingBeginEvent.ts +18 -0
- package/services/mac-bridge/codex-types/CollabWaitingEndEvent.ts +19 -0
- package/services/mac-bridge/codex-types/CollaborationMode.ts +10 -0
- package/services/mac-bridge/codex-types/CollaborationModeMask.ts +11 -0
- package/services/mac-bridge/codex-types/ContentItem.ts +5 -0
- package/services/mac-bridge/codex-types/ContextCompactedEvent.ts +5 -0
- package/services/mac-bridge/codex-types/ContextCompactionItem.ts +5 -0
- package/services/mac-bridge/codex-types/ConversationGitInfo.ts +5 -0
- package/services/mac-bridge/codex-types/ConversationSummary.ts +8 -0
- package/services/mac-bridge/codex-types/CreditsSnapshot.ts +5 -0
- package/services/mac-bridge/codex-types/CustomPrompt.ts +5 -0
- package/services/mac-bridge/codex-types/DeprecationNoticeEvent.ts +13 -0
- package/services/mac-bridge/codex-types/DynamicToolCallRequest.ts +6 -0
- package/services/mac-bridge/codex-types/ElicitationRequestEvent.ts +5 -0
- package/services/mac-bridge/codex-types/ErrorEvent.ts +6 -0
- package/services/mac-bridge/codex-types/EventMsg.ts +78 -0
- package/services/mac-bridge/codex-types/ExecApprovalRequestEvent.ts +44 -0
- package/services/mac-bridge/codex-types/ExecCommandApprovalParams.ts +16 -0
- package/services/mac-bridge/codex-types/ExecCommandApprovalResponse.ts +6 -0
- package/services/mac-bridge/codex-types/ExecCommandBeginEvent.ts +35 -0
- package/services/mac-bridge/codex-types/ExecCommandEndEvent.ts +64 -0
- package/services/mac-bridge/codex-types/ExecCommandOutputDeltaEvent.ts +18 -0
- package/services/mac-bridge/codex-types/ExecCommandSource.ts +5 -0
- package/services/mac-bridge/codex-types/ExecCommandStatus.ts +5 -0
- package/services/mac-bridge/codex-types/ExecOneOffCommandParams.ts +6 -0
- package/services/mac-bridge/codex-types/ExecOneOffCommandResponse.ts +5 -0
- package/services/mac-bridge/codex-types/ExecOutputStream.ts +5 -0
- package/services/mac-bridge/codex-types/ExecPolicyAmendment.ts +12 -0
- package/services/mac-bridge/codex-types/ExitedReviewModeEvent.ts +6 -0
- package/services/mac-bridge/codex-types/FileChange.ts +5 -0
- package/services/mac-bridge/codex-types/ForcedLoginMethod.ts +5 -0
- package/services/mac-bridge/codex-types/ForkConversationParams.ts +7 -0
- package/services/mac-bridge/codex-types/ForkConversationResponse.ts +7 -0
- package/services/mac-bridge/codex-types/FunctionCallOutputBody.ts +6 -0
- package/services/mac-bridge/codex-types/FunctionCallOutputContentItem.ts +9 -0
- package/services/mac-bridge/codex-types/FunctionCallOutputPayload.ts +12 -0
- package/services/mac-bridge/codex-types/FuzzyFileSearchParams.ts +5 -0
- package/services/mac-bridge/codex-types/FuzzyFileSearchResponse.ts +6 -0
- package/services/mac-bridge/codex-types/FuzzyFileSearchResult.ts +8 -0
- package/services/mac-bridge/codex-types/FuzzyFileSearchSessionCompletedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/FuzzyFileSearchSessionUpdatedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/GetAuthStatusParams.ts +5 -0
- package/services/mac-bridge/codex-types/GetAuthStatusResponse.ts +6 -0
- package/services/mac-bridge/codex-types/GetConversationSummaryParams.ts +6 -0
- package/services/mac-bridge/codex-types/GetConversationSummaryResponse.ts +6 -0
- package/services/mac-bridge/codex-types/GetHistoryEntryResponseEvent.ts +10 -0
- package/services/mac-bridge/codex-types/GetUserAgentResponse.ts +5 -0
- package/services/mac-bridge/codex-types/GetUserSavedConfigResponse.ts +6 -0
- package/services/mac-bridge/codex-types/GhostCommit.ts +8 -0
- package/services/mac-bridge/codex-types/GitDiffToRemoteParams.ts +5 -0
- package/services/mac-bridge/codex-types/GitDiffToRemoteResponse.ts +6 -0
- package/services/mac-bridge/codex-types/GitSha.ts +5 -0
- package/services/mac-bridge/codex-types/HistoryEntry.ts +5 -0
- package/services/mac-bridge/codex-types/InitializeCapabilities.ts +17 -0
- package/services/mac-bridge/codex-types/InitializeParams.ts +7 -0
- package/services/mac-bridge/codex-types/InitializeResponse.ts +5 -0
- package/services/mac-bridge/codex-types/InputItem.ts +10 -0
- package/services/mac-bridge/codex-types/InputModality.ts +8 -0
- package/services/mac-bridge/codex-types/InterruptConversationParams.ts +6 -0
- package/services/mac-bridge/codex-types/InterruptConversationResponse.ts +6 -0
- package/services/mac-bridge/codex-types/ItemCompletedEvent.ts +7 -0
- package/services/mac-bridge/codex-types/ItemStartedEvent.ts +7 -0
- package/services/mac-bridge/codex-types/ListConversationsParams.ts +5 -0
- package/services/mac-bridge/codex-types/ListConversationsResponse.ts +6 -0
- package/services/mac-bridge/codex-types/ListCustomPromptsResponseEvent.ts +9 -0
- package/services/mac-bridge/codex-types/ListRemoteSkillsResponseEvent.ts +9 -0
- package/services/mac-bridge/codex-types/ListSkillsResponseEvent.ts +9 -0
- package/services/mac-bridge/codex-types/LocalShellAction.ts +6 -0
- package/services/mac-bridge/codex-types/LocalShellExecAction.ts +5 -0
- package/services/mac-bridge/codex-types/LocalShellStatus.ts +5 -0
- package/services/mac-bridge/codex-types/LoginApiKeyParams.ts +5 -0
- package/services/mac-bridge/codex-types/LoginApiKeyResponse.ts +5 -0
- package/services/mac-bridge/codex-types/LoginChatGptCompleteNotification.ts +8 -0
- package/services/mac-bridge/codex-types/LoginChatGptResponse.ts +5 -0
- package/services/mac-bridge/codex-types/LogoutChatGptResponse.ts +5 -0
- package/services/mac-bridge/codex-types/McpAuthStatus.ts +5 -0
- package/services/mac-bridge/codex-types/McpInvocation.ts +18 -0
- package/services/mac-bridge/codex-types/McpListToolsResponseEvent.ts +25 -0
- package/services/mac-bridge/codex-types/McpStartupCompleteEvent.ts +6 -0
- package/services/mac-bridge/codex-types/McpStartupFailure.ts +5 -0
- package/services/mac-bridge/codex-types/McpStartupStatus.ts +5 -0
- package/services/mac-bridge/codex-types/McpStartupUpdateEvent.ts +14 -0
- package/services/mac-bridge/codex-types/McpToolCallBeginEvent.ts +10 -0
- package/services/mac-bridge/codex-types/McpToolCallEndEvent.ts +15 -0
- package/services/mac-bridge/codex-types/MessagePhase.ts +11 -0
- package/services/mac-bridge/codex-types/ModeKind.ts +8 -0
- package/services/mac-bridge/codex-types/ModelRerouteEvent.ts +6 -0
- package/services/mac-bridge/codex-types/ModelRerouteReason.ts +5 -0
- package/services/mac-bridge/codex-types/NetworkAccess.ts +8 -0
- package/services/mac-bridge/codex-types/NetworkApprovalContext.ts +6 -0
- package/services/mac-bridge/codex-types/NetworkApprovalProtocol.ts +5 -0
- package/services/mac-bridge/codex-types/NewConversationParams.ts +8 -0
- package/services/mac-bridge/codex-types/NewConversationResponse.ts +7 -0
- package/services/mac-bridge/codex-types/ParsedCommand.ts +12 -0
- package/services/mac-bridge/codex-types/PatchApplyBeginEvent.ts +23 -0
- package/services/mac-bridge/codex-types/PatchApplyEndEvent.ts +36 -0
- package/services/mac-bridge/codex-types/PatchApplyStatus.ts +5 -0
- package/services/mac-bridge/codex-types/Personality.ts +5 -0
- package/services/mac-bridge/codex-types/PlanDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/PlanItem.ts +5 -0
- package/services/mac-bridge/codex-types/PlanItemArg.ts +6 -0
- package/services/mac-bridge/codex-types/PlanType.ts +5 -0
- package/services/mac-bridge/codex-types/Profile.ts +9 -0
- package/services/mac-bridge/codex-types/RateLimitSnapshot.ts +8 -0
- package/services/mac-bridge/codex-types/RateLimitWindow.ts +17 -0
- package/services/mac-bridge/codex-types/RawResponseItemEvent.ts +6 -0
- package/services/mac-bridge/codex-types/ReadOnlyAccess.ts +19 -0
- package/services/mac-bridge/codex-types/ReasoningContentDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/ReasoningEffort.ts +8 -0
- package/services/mac-bridge/codex-types/ReasoningItem.ts +5 -0
- package/services/mac-bridge/codex-types/ReasoningItemContent.ts +5 -0
- package/services/mac-bridge/codex-types/ReasoningItemReasoningSummary.ts +5 -0
- package/services/mac-bridge/codex-types/ReasoningRawContentDeltaEvent.ts +5 -0
- package/services/mac-bridge/codex-types/ReasoningSummary.ts +10 -0
- package/services/mac-bridge/codex-types/RemoteSkillDownloadedEvent.ts +8 -0
- package/services/mac-bridge/codex-types/RemoteSkillSummary.ts +5 -0
- package/services/mac-bridge/codex-types/RemoveConversationListenerParams.ts +5 -0
- package/services/mac-bridge/codex-types/RemoveConversationSubscriptionResponse.ts +5 -0
- package/services/mac-bridge/codex-types/RequestId.ts +5 -0
- package/services/mac-bridge/codex-types/RequestUserInputEvent.ts +15 -0
- package/services/mac-bridge/codex-types/RequestUserInputQuestion.ts +6 -0
- package/services/mac-bridge/codex-types/RequestUserInputQuestionOption.ts +5 -0
- package/services/mac-bridge/codex-types/Resource.ts +9 -0
- package/services/mac-bridge/codex-types/ResourceTemplate.ts +9 -0
- package/services/mac-bridge/codex-types/ResponseItem.ts +18 -0
- package/services/mac-bridge/codex-types/ResumeConversationParams.ts +8 -0
- package/services/mac-bridge/codex-types/ResumeConversationResponse.ts +7 -0
- package/services/mac-bridge/codex-types/ReviewCodeLocation.ts +9 -0
- package/services/mac-bridge/codex-types/ReviewDecision.ts +9 -0
- package/services/mac-bridge/codex-types/ReviewFinding.ts +9 -0
- package/services/mac-bridge/codex-types/ReviewLineRange.ts +8 -0
- package/services/mac-bridge/codex-types/ReviewOutputEvent.ts +9 -0
- package/services/mac-bridge/codex-types/ReviewRequest.ts +9 -0
- package/services/mac-bridge/codex-types/ReviewTarget.ts +9 -0
- package/services/mac-bridge/codex-types/SandboxMode.ts +5 -0
- package/services/mac-bridge/codex-types/SandboxPolicy.ts +44 -0
- package/services/mac-bridge/codex-types/SandboxSettings.ts +6 -0
- package/services/mac-bridge/codex-types/SendUserMessageParams.ts +7 -0
- package/services/mac-bridge/codex-types/SendUserMessageResponse.ts +5 -0
- package/services/mac-bridge/codex-types/SendUserTurnParams.ts +16 -0
- package/services/mac-bridge/codex-types/SendUserTurnResponse.ts +5 -0
- package/services/mac-bridge/codex-types/ServerNotification.ts +45 -0
- package/services/mac-bridge/codex-types/ServerRequest.ts +16 -0
- package/services/mac-bridge/codex-types/SessionConfiguredEvent.ts +57 -0
- package/services/mac-bridge/codex-types/SessionConfiguredNotification.ts +8 -0
- package/services/mac-bridge/codex-types/SessionNetworkProxyRuntime.ts +5 -0
- package/services/mac-bridge/codex-types/SessionSource.ts +6 -0
- package/services/mac-bridge/codex-types/SetDefaultModelParams.ts +6 -0
- package/services/mac-bridge/codex-types/SetDefaultModelResponse.ts +5 -0
- package/services/mac-bridge/codex-types/Settings.ts +9 -0
- package/services/mac-bridge/codex-types/SkillDependencies.ts +6 -0
- package/services/mac-bridge/codex-types/SkillErrorInfo.ts +5 -0
- package/services/mac-bridge/codex-types/SkillInterface.ts +5 -0
- package/services/mac-bridge/codex-types/SkillMetadata.ts +12 -0
- package/services/mac-bridge/codex-types/SkillScope.ts +5 -0
- package/services/mac-bridge/codex-types/SkillToolDependency.ts +5 -0
- package/services/mac-bridge/codex-types/SkillsListEntry.ts +7 -0
- package/services/mac-bridge/codex-types/StepStatus.ts +5 -0
- package/services/mac-bridge/codex-types/StreamErrorEvent.ts +12 -0
- package/services/mac-bridge/codex-types/SubAgentSource.ts +6 -0
- package/services/mac-bridge/codex-types/TerminalInteractionEvent.ts +17 -0
- package/services/mac-bridge/codex-types/TextElement.ts +14 -0
- package/services/mac-bridge/codex-types/ThreadId.ts +5 -0
- package/services/mac-bridge/codex-types/ThreadNameUpdatedEvent.ts +6 -0
- package/services/mac-bridge/codex-types/ThreadRolledBackEvent.ts +9 -0
- package/services/mac-bridge/codex-types/TokenCountEvent.ts +7 -0
- package/services/mac-bridge/codex-types/TokenUsage.ts +5 -0
- package/services/mac-bridge/codex-types/TokenUsageInfo.ts +6 -0
- package/services/mac-bridge/codex-types/Tool.ts +9 -0
- package/services/mac-bridge/codex-types/Tools.ts +5 -0
- package/services/mac-bridge/codex-types/TurnAbortReason.ts +5 -0
- package/services/mac-bridge/codex-types/TurnAbortedEvent.ts +6 -0
- package/services/mac-bridge/codex-types/TurnCompleteEvent.ts +5 -0
- package/services/mac-bridge/codex-types/TurnDiffEvent.ts +5 -0
- package/services/mac-bridge/codex-types/TurnItem.ts +11 -0
- package/services/mac-bridge/codex-types/TurnStartedEvent.ts +6 -0
- package/services/mac-bridge/codex-types/UndoCompletedEvent.ts +5 -0
- package/services/mac-bridge/codex-types/UndoStartedEvent.ts +5 -0
- package/services/mac-bridge/codex-types/UpdatePlanArgs.ts +10 -0
- package/services/mac-bridge/codex-types/UserInfoResponse.ts +5 -0
- package/services/mac-bridge/codex-types/UserInput.ts +16 -0
- package/services/mac-bridge/codex-types/UserMessageEvent.ts +22 -0
- package/services/mac-bridge/codex-types/UserMessageItem.ts +6 -0
- package/services/mac-bridge/codex-types/UserSavedConfig.ts +14 -0
- package/services/mac-bridge/codex-types/Verbosity.ts +9 -0
- package/services/mac-bridge/codex-types/ViewImageToolCallEvent.ts +13 -0
- package/services/mac-bridge/codex-types/WarningEvent.ts +5 -0
- package/services/mac-bridge/codex-types/WebSearchAction.ts +5 -0
- package/services/mac-bridge/codex-types/WebSearchBeginEvent.ts +5 -0
- package/services/mac-bridge/codex-types/WebSearchEndEvent.ts +6 -0
- package/services/mac-bridge/codex-types/WebSearchItem.ts +6 -0
- package/services/mac-bridge/codex-types/WebSearchMode.ts +5 -0
- package/services/mac-bridge/codex-types/index.ts +234 -0
- package/services/mac-bridge/codex-types/serde_json/JsonValue.ts +5 -0
- package/services/mac-bridge/codex-types/v2/Account.ts +6 -0
- package/services/mac-bridge/codex-types/v2/AccountLoginCompletedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/AccountRateLimitsUpdatedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/AccountUpdatedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/AgentMessageDeltaNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/AnalyticsConfig.ts +6 -0
- package/services/mac-bridge/codex-types/v2/AppBranding.ts +8 -0
- package/services/mac-bridge/codex-types/v2/AppDisabledReason.ts +5 -0
- package/services/mac-bridge/codex-types/v2/AppInfo.ts +19 -0
- package/services/mac-bridge/codex-types/v2/AppListUpdatedNotification.ts +9 -0
- package/services/mac-bridge/codex-types/v2/AppMetadata.ts +7 -0
- package/services/mac-bridge/codex-types/v2/AppReview.ts +5 -0
- package/services/mac-bridge/codex-types/v2/AppScreenshot.ts +5 -0
- package/services/mac-bridge/codex-types/v2/AppsConfig.ts +6 -0
- package/services/mac-bridge/codex-types/v2/AppsListParams.ts +24 -0
- package/services/mac-bridge/codex-types/v2/AppsListResponse.ts +14 -0
- package/services/mac-bridge/codex-types/v2/AskForApproval.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ByteRange.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CancelLoginAccountParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CancelLoginAccountResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/CancelLoginAccountStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ChatgptAuthTokensRefreshParams.ts +16 -0
- package/services/mac-bridge/codex-types/v2/ChatgptAuthTokensRefreshReason.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ChatgptAuthTokensRefreshResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CodexErrorInfo.ts +11 -0
- package/services/mac-bridge/codex-types/v2/CollabAgentState.ts +6 -0
- package/services/mac-bridge/codex-types/v2/CollabAgentStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CollabAgentTool.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CollabAgentToolCallStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CommandAction.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CommandExecParams.ts +6 -0
- package/services/mac-bridge/codex-types/v2/CommandExecResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CommandExecutionApprovalDecision.ts +6 -0
- package/services/mac-bridge/codex-types/v2/CommandExecutionOutputDeltaNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/CommandExecutionRequestApprovalParams.ts +37 -0
- package/services/mac-bridge/codex-types/v2/CommandExecutionRequestApprovalResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/CommandExecutionStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/Config.ts +17 -0
- package/services/mac-bridge/codex-types/v2/ConfigBatchWriteParams.ts +10 -0
- package/services/mac-bridge/codex-types/v2/ConfigEdit.ts +7 -0
- package/services/mac-bridge/codex-types/v2/ConfigLayer.ts +7 -0
- package/services/mac-bridge/codex-types/v2/ConfigLayerMetadata.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ConfigLayerSource.ts +16 -0
- package/services/mac-bridge/codex-types/v2/ConfigReadParams.ts +11 -0
- package/services/mac-bridge/codex-types/v2/ConfigReadResponse.ts +8 -0
- package/services/mac-bridge/codex-types/v2/ConfigRequirements.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ConfigRequirementsReadResponse.ts +10 -0
- package/services/mac-bridge/codex-types/v2/ConfigValueWriteParams.ts +11 -0
- package/services/mac-bridge/codex-types/v2/ConfigWarningNotification.ts +22 -0
- package/services/mac-bridge/codex-types/v2/ConfigWriteResponse.ts +12 -0
- package/services/mac-bridge/codex-types/v2/ContextCompactedNotification.ts +8 -0
- package/services/mac-bridge/codex-types/v2/CreditsSnapshot.ts +5 -0
- package/services/mac-bridge/codex-types/v2/DeprecationNoticeNotification.ts +13 -0
- package/services/mac-bridge/codex-types/v2/DynamicToolCallOutputContentItem.ts +5 -0
- package/services/mac-bridge/codex-types/v2/DynamicToolCallParams.ts +6 -0
- package/services/mac-bridge/codex-types/v2/DynamicToolCallResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/DynamicToolSpec.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ErrorNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ExecPolicyAmendment.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ExperimentalFeature.ts +37 -0
- package/services/mac-bridge/codex-types/v2/ExperimentalFeatureListParams.ts +13 -0
- package/services/mac-bridge/codex-types/v2/ExperimentalFeatureListResponse.ts +11 -0
- package/services/mac-bridge/codex-types/v2/ExperimentalFeatureStage.ts +5 -0
- package/services/mac-bridge/codex-types/v2/FeedbackUploadParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/FeedbackUploadResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/FileChangeApprovalDecision.ts +5 -0
- package/services/mac-bridge/codex-types/v2/FileChangeOutputDeltaNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/FileChangeRequestApprovalParams.ts +14 -0
- package/services/mac-bridge/codex-types/v2/FileChangeRequestApprovalResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/FileUpdateChange.ts +6 -0
- package/services/mac-bridge/codex-types/v2/GetAccountParams.ts +13 -0
- package/services/mac-bridge/codex-types/v2/GetAccountRateLimitsResponse.ts +14 -0
- package/services/mac-bridge/codex-types/v2/GetAccountResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/GitInfo.ts +5 -0
- package/services/mac-bridge/codex-types/v2/HazelnutScope.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ItemCompletedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ItemStartedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ListMcpServerStatusParams.ts +13 -0
- package/services/mac-bridge/codex-types/v2/ListMcpServerStatusResponse.ts +11 -0
- package/services/mac-bridge/codex-types/v2/LoginAccountParams.ts +21 -0
- package/services/mac-bridge/codex-types/v2/LoginAccountResponse.ts +9 -0
- package/services/mac-bridge/codex-types/v2/LogoutAccountResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpAuthStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpServerOauthLoginCompletedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpServerOauthLoginParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpServerOauthLoginResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpServerRefreshResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpServerStatus.ts +9 -0
- package/services/mac-bridge/codex-types/v2/McpToolCallError.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpToolCallProgressNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/McpToolCallResult.ts +6 -0
- package/services/mac-bridge/codex-types/v2/McpToolCallStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/MergeStrategy.ts +5 -0
- package/services/mac-bridge/codex-types/v2/Model.ts +8 -0
- package/services/mac-bridge/codex-types/v2/ModelListParams.ts +17 -0
- package/services/mac-bridge/codex-types/v2/ModelListResponse.ts +11 -0
- package/services/mac-bridge/codex-types/v2/ModelRerouteReason.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ModelReroutedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/NetworkAccess.ts +5 -0
- package/services/mac-bridge/codex-types/v2/NetworkRequirements.ts +5 -0
- package/services/mac-bridge/codex-types/v2/OverriddenMetadata.ts +7 -0
- package/services/mac-bridge/codex-types/v2/PatchApplyStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/PatchChangeKind.ts +5 -0
- package/services/mac-bridge/codex-types/v2/PlanDeltaNotification.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ProductSurface.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ProfileV2.ts +11 -0
- package/services/mac-bridge/codex-types/v2/RateLimitSnapshot.ts +8 -0
- package/services/mac-bridge/codex-types/v2/RateLimitWindow.ts +5 -0
- package/services/mac-bridge/codex-types/v2/RawResponseItemCompletedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ReadOnlyAccess.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ReasoningEffortOption.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ReasoningSummaryPartAddedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ReasoningSummaryTextDeltaNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ReasoningTextDeltaNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/RemoteSkillSummary.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ResidencyRequirement.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ReviewDelivery.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ReviewStartParams.ts +12 -0
- package/services/mac-bridge/codex-types/v2/ReviewStartResponse.ts +13 -0
- package/services/mac-bridge/codex-types/v2/ReviewTarget.ts +9 -0
- package/services/mac-bridge/codex-types/v2/SandboxMode.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SandboxPolicy.ts +8 -0
- package/services/mac-bridge/codex-types/v2/SandboxWorkspaceWrite.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SessionSource.ts +6 -0
- package/services/mac-bridge/codex-types/v2/SkillDependencies.ts +6 -0
- package/services/mac-bridge/codex-types/v2/SkillErrorInfo.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillInterface.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillMetadata.ts +12 -0
- package/services/mac-bridge/codex-types/v2/SkillScope.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillToolDependency.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillsConfigWriteParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillsConfigWriteResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillsListEntry.ts +7 -0
- package/services/mac-bridge/codex-types/v2/SkillsListExtraRootsForCwd.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillsListParams.ts +18 -0
- package/services/mac-bridge/codex-types/v2/SkillsListResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/SkillsRemoteReadParams.ts +7 -0
- package/services/mac-bridge/codex-types/v2/SkillsRemoteReadResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/SkillsRemoteWriteParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/SkillsRemoteWriteResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TerminalInteractionNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TextElement.ts +14 -0
- package/services/mac-bridge/codex-types/v2/TextPosition.ts +13 -0
- package/services/mac-bridge/codex-types/v2/TextRange.ts +6 -0
- package/services/mac-bridge/codex-types/v2/Thread.ts +51 -0
- package/services/mac-bridge/codex-types/v2/ThreadArchiveParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadArchiveResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadArchivedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadCompactStartParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadCompactStartResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadForkParams.ts +28 -0
- package/services/mac-bridge/codex-types/v2/ThreadForkResponse.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ThreadItem.ts +81 -0
- package/services/mac-bridge/codex-types/v2/ThreadListParams.ts +39 -0
- package/services/mac-bridge/codex-types/v2/ThreadListResponse.ts +11 -0
- package/services/mac-bridge/codex-types/v2/ThreadLoadedListParams.ts +13 -0
- package/services/mac-bridge/codex-types/v2/ThreadLoadedListResponse.ts +14 -0
- package/services/mac-bridge/codex-types/v2/ThreadNameUpdatedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadReadParams.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ThreadReadResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ThreadResumeParams.ts +37 -0
- package/services/mac-bridge/codex-types/v2/ThreadResumeResponse.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ThreadRollbackParams.ts +12 -0
- package/services/mac-bridge/codex-types/v2/ThreadRollbackResponse.ts +14 -0
- package/services/mac-bridge/codex-types/v2/ThreadSetNameParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadSetNameResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadSortKey.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadSourceKind.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadStartParams.ts +17 -0
- package/services/mac-bridge/codex-types/v2/ThreadStartResponse.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ThreadStartedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ThreadTokenUsage.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ThreadTokenUsageUpdatedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ThreadUnarchiveParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ThreadUnarchiveResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/ThreadUnarchivedNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TokenUsageBreakdown.ts +5 -0
- package/services/mac-bridge/codex-types/v2/ToolRequestUserInputAnswer.ts +8 -0
- package/services/mac-bridge/codex-types/v2/ToolRequestUserInputOption.ts +8 -0
- package/services/mac-bridge/codex-types/v2/ToolRequestUserInputParams.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ToolRequestUserInputQuestion.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ToolRequestUserInputResponse.ts +9 -0
- package/services/mac-bridge/codex-types/v2/ToolsV2.ts +5 -0
- package/services/mac-bridge/codex-types/v2/Turn.ts +18 -0
- package/services/mac-bridge/codex-types/v2/TurnCompletedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnDiffUpdatedNotification.ts +9 -0
- package/services/mac-bridge/codex-types/v2/TurnError.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnInterruptParams.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TurnInterruptResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TurnPlanStep.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnPlanStepStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TurnPlanUpdatedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnStartParams.ts +44 -0
- package/services/mac-bridge/codex-types/v2/TurnStartResponse.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnStartedNotification.ts +6 -0
- package/services/mac-bridge/codex-types/v2/TurnStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/TurnSteerParams.ts +11 -0
- package/services/mac-bridge/codex-types/v2/TurnSteerResponse.ts +5 -0
- package/services/mac-bridge/codex-types/v2/UserInput.ts +10 -0
- package/services/mac-bridge/codex-types/v2/WebSearchAction.ts +5 -0
- package/services/mac-bridge/codex-types/v2/WindowsWorldWritableWarningNotification.ts +5 -0
- package/services/mac-bridge/codex-types/v2/WriteStatus.ts +5 -0
- package/services/mac-bridge/codex-types/v2/index.ts +204 -0
- package/services/mac-bridge/eslint.config.cjs +22 -0
- package/services/mac-bridge/package.json +30 -0
- package/services/mac-bridge/schema.ts +0 -0
- package/services/mac-bridge/src/index.ts +18 -0
- package/services/mac-bridge/src/server.ts +426 -0
- package/services/mac-bridge/src/services/__tests__/gitService.test.ts +157 -0
- package/services/mac-bridge/src/services/__tests__/realtimeHub.test.ts +116 -0
- package/services/mac-bridge/src/services/__tests__/terminalService.test.ts +51 -0
- package/services/mac-bridge/src/services/codexAppServerClient.ts +507 -0
- package/services/mac-bridge/src/services/codexCliAdapter.ts +622 -0
- package/services/mac-bridge/src/services/gitService.ts +61 -0
- package/services/mac-bridge/src/services/realtimeHub.ts +25 -0
- package/services/mac-bridge/src/services/terminalService.ts +226 -0
- package/services/mac-bridge/src/types.ts +151 -0
- package/services/mac-bridge/src/utils/__tests__/threadMapping.test.ts +397 -0
- package/services/mac-bridge/src/utils/threadMapping.ts +176 -0
- package/services/mac-bridge/tsconfig.json +16 -0
- package/services/mac-bridge/vitest.config.ts +9 -0
- package/services/rust-bridge/.env.example +11 -0
- package/services/rust-bridge/Cargo.lock +1127 -0
- package/services/rust-bridge/Cargo.toml +14 -0
- package/services/rust-bridge/package.json +13 -0
- package/services/rust-bridge/security_best_practices_report.md +24 -0
- package/services/rust-bridge/src/main.rs +2713 -0
- package/services/rust-bridge/src/services/git.rs +271 -0
- package/services/rust-bridge/src/services/mod.rs +5 -0
- package/services/rust-bridge/src/services/terminal.rs +267 -0
- package/tsconfig.json +4 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
[package]
|
|
2
|
+
name = "codex-rust-bridge"
|
|
3
|
+
version = "0.1.0"
|
|
4
|
+
edition = "2021"
|
|
5
|
+
|
|
6
|
+
[dependencies]
|
|
7
|
+
axum = { version = "0.8", features = ["ws", "http1", "tokio"] }
|
|
8
|
+
base64 = "0.22"
|
|
9
|
+
chrono = { version = "0.4", features = ["clock", "serde"] }
|
|
10
|
+
futures-util = "0.3"
|
|
11
|
+
serde = { version = "1", features = ["derive"] }
|
|
12
|
+
serde_json = "1"
|
|
13
|
+
shlex = "1"
|
|
14
|
+
tokio = { version = "1", features = ["full"] }
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@codex/rust-bridge",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"private": true,
|
|
5
|
+
"scripts": {
|
|
6
|
+
"dev": "cargo run",
|
|
7
|
+
"start": "cargo run --release",
|
|
8
|
+
"build": "cargo build --release",
|
|
9
|
+
"typecheck": "cargo check",
|
|
10
|
+
"lint": "cargo fmt --check",
|
|
11
|
+
"test": "cargo test"
|
|
12
|
+
}
|
|
13
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# Executive Summary
|
|
2
|
+
The bridge exposes powerful RPC surface (terminal execution, git operations, approvals) with minimal automation around authentication, token handling, and child-process resilience. Without tightening the gates, an attacker on the same LAN can run commands or mutate the repository, and outages may go unnoticed. The following findings prioritize these risks and note the lack of tests that would otherwise guard against regressions.
|
|
3
|
+
|
|
4
|
+
## Severity: High
|
|
5
|
+
### HF-1 — Unauthenticated bridge surface with common dev flags
|
|
6
|
+
- **Impact:** When `BRIDGE_ALLOW_INSECURE_NO_AUTH=true` and the host is bound to `0.0.0.0`, any LAN client can connect to `/rpc` and call `bridge/terminal/exec`, `bridge/git/*`, or even forward arbitrary App Server RPCs, effectively running shell commands and mutating the repository as the bridge user. This is a remote code execution and repo integrity risk.
|
|
7
|
+
- **Observation:** `BridgeConfig::from_env` only skips the `BRIDGE_AUTH_TOKEN` requirement when `BRIDGE_ALLOW_INSECURE_NO_AUTH` is true (src/main.rs:51-129). `ws_handler` accepts any socket once `is_authorized` returns true, and that function returns true whenever authentication is disabled (src/main.rs:1125-1144). The powerful operations behind `handle_bridge_method` remain exposed without additional checks (src/main.rs:1307-1405).
|
|
8
|
+
- **Remediation:** Require a token for any non-local binding or refuse to listen on `0.0.0.0` when auth is disabled. Alternatively, keep `BRIDGE_ALLOW_INSECURE_NO_AUTH` but automatically bind to `127.0.0.1` and refuse the flag otherwise, or fail fast if the flag is set without a token plus documented justification. Harden `bridge/terminal/exec` and `bridge/git/*` with explicit policy guards when auth is missing.
|
|
9
|
+
|
|
10
|
+
## Severity: Medium
|
|
11
|
+
### MF-2 — Query-token auth leaks credentials in plaintext URLs
|
|
12
|
+
- **Impact:** `BRIDGE_ALLOW_QUERY_TOKEN_AUTH` accepts the token as a `token` query parameter (src/main.rs:101-129, 1125-1144). Passing secrets in URLs risks leakage through proxy logs, browser history, and any MITM on the local network (the bridge already speaks plain HTTP/TCP). A leaked token allows the exact same RPC surface as a Bearer header, so attackers can replay it.
|
|
13
|
+
- **Observation:** `is_authorized` unconditionally trusts the `token` query value when the flag is true (src/main.rs:101-129). `ws_handler` populates that query into the check every WebSocket upgrade (src/main.rs:1125-1144).
|
|
14
|
+
- **Remediation:** Deprecate `BRIDGE_ALLOW_QUERY_TOKEN_AUTH`; accept only Authorization headers and keep them out of URLs. If the flag is still needed, require TLS + short-lived tokens and actively rotate/log reuse.
|
|
15
|
+
|
|
16
|
+
### MF-3 — App server child death leaves future requests dead and health endpoint blind
|
|
17
|
+
- **Impact:** When the `codex app-server` child exits, the bridge logs the exit, fails outstanding RPCs, and shuts down approval state, but it never restarts the child or marks `/health` as degraded. Forwarded requests still attempt to write to the closed pipe and immediately fail with `-32000`, leaving clients blind and requiring a manual restart, which is a resiliency issue with moderate to high operational impact.
|
|
18
|
+
- **Observation:** `spawn_wait_loop` just logs success/error and clears `pending` state without recovery (src/main.rs:362-403). `forward_request` continues to accept work and only reports failure once `write_json` fails, so the bridge does not short-circuit new requests once the child is gone (src/main.rs:406-439). The existing `/health` handler never observes the child state (src/main.rs:1117-1123).
|
|
19
|
+
- **Remediation:** Monitor the app server child, surface its state through `/health`, and attempt automatic restart/backoff or block forwarded requests (return `ServiceUnavailable`) until recovery. Consider wiring `AppState` with a flag that short-circuits `handle_client_message` whenever the child is not running.
|
|
20
|
+
|
|
21
|
+
### MF-4 — No automated tests for critical security gates or bridge resiliency
|
|
22
|
+
- **Impact:** The bridge’s only source file is `src/main.rs` and `Cargo.toml` defines no `[dev-dependencies]` or test harnesses (Cargo.toml:1-13), so there are no unit or integration tests for `BridgeConfig`, `TerminalService`, or `AppServerBridge`. Any refactor can silently break auth, token parsing, or terminal-command restrictions, and there is no automated guard detecting the regression.
|
|
23
|
+
- **Observation:** `src/main.rs` does not contain any `#[cfg(test)]` modules or `mod tests`, and there is no `tests/` directory in the repo. The mission-critical entry points (`BridgeConfig::from_env`, `TerminalService::execute_shell`, `AppServerBridge::forward_request`) are therefore unverified.
|
|
24
|
+
- **Remediation:** Add tabletop unit tests that cover config parsing (including `BRIDGE_ALLOW_INSECURE_NO_AUTH` vs. `BRIDGE_AUTH_TOKEN`), query token acceptance, terminal command whitelists, and app-server shutdown behavior. Start simple with `#[cfg(test)]` modules shipping assertion scenarios, then expand to integration or smoke tests to exercise `/rpc` and `/health` flows.
|