@jsonstudio/rcc 0.89.1960 → 0.89.2195
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/README.md +66 -6
- package/config/file-line-limit-policy.json +21 -0
- package/configsamples/config.json +1 -1
- package/configsamples/config.v1.quickstart.sanitized.json +6 -6
- package/configsamples/provider/iflow/config.v1.json +1 -1
- package/dist/app/config-readers.d.ts +18 -0
- package/dist/app/config-readers.js +95 -0
- package/dist/app/config-readers.js.map +1 -0
- package/dist/app/index.d.ts +9 -0
- package/dist/app/index.js +8 -0
- package/dist/app/index.js.map +1 -0
- package/dist/app/shutdown.d.ts +32 -0
- package/dist/app/shutdown.js +41 -0
- package/dist/app/shutdown.js.map +1 -0
- package/dist/bootstrap/index.d.ts +7 -0
- package/dist/bootstrap/index.js +7 -0
- package/dist/bootstrap/index.js.map +1 -0
- package/dist/bootstrap/log-filter.d.ts +15 -0
- package/dist/bootstrap/log-filter.js +81 -0
- package/dist/bootstrap/log-filter.js.map +1 -0
- package/dist/build-info.js +2 -2
- package/dist/cli/commands/claude.js +6 -5
- package/dist/cli/commands/claude.js.map +1 -1
- package/dist/cli/commands/init/basic.d.ts +1 -7
- package/dist/cli/commands/init/basic.js +0 -79
- package/dist/cli/commands/init/basic.js.map +1 -1
- package/dist/cli/commands/init/prompt-utils.d.ts +7 -0
- package/dist/cli/commands/init/prompt-utils.js +80 -0
- package/dist/cli/commands/init/prompt-utils.js.map +1 -0
- package/dist/cli/commands/init/workflows.js +2 -1
- package/dist/cli/commands/init/workflows.js.map +1 -1
- package/dist/cli/commands/init.js +103 -2
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/launcher/index.d.ts +7 -0
- package/dist/cli/commands/launcher/index.js +7 -0
- package/dist/cli/commands/launcher/index.js.map +1 -0
- package/dist/cli/commands/launcher/types.d.ts +112 -0
- package/dist/cli/commands/launcher/types.js +7 -0
- package/dist/cli/commands/launcher/types.js.map +1 -0
- package/dist/cli/commands/launcher/utils.d.ts +114 -0
- package/dist/cli/commands/launcher/utils.js +378 -0
- package/dist/cli/commands/launcher/utils.js.map +1 -0
- package/dist/cli/commands/launcher-kernel.d.ts +2 -74
- package/dist/cli/commands/launcher-kernel.js +141 -143
- package/dist/cli/commands/launcher-kernel.js.map +1 -1
- package/dist/cli/commands/start-types.d.ts +67 -0
- package/dist/cli/commands/start-types.js +3 -0
- package/dist/cli/commands/start-types.js.map +1 -0
- package/dist/cli/commands/start-utils.d.ts +19 -0
- package/dist/cli/commands/start-utils.js +78 -0
- package/dist/cli/commands/start-utils.js.map +1 -0
- package/dist/cli/commands/start.d.ts +2 -67
- package/dist/cli/commands/start.js +131 -47
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/stop.js +13 -0
- package/dist/cli/commands/stop.js.map +1 -1
- package/dist/cli/commands/tmux-inject.js +1 -1
- package/dist/cli/commands/tmux-inject.js.map +1 -1
- package/dist/cli/config/bundled-default-config.d.ts +18 -0
- package/dist/cli/config/bundled-default-config.js +62 -0
- package/dist/cli/config/bundled-default-config.js.map +1 -0
- package/dist/cli/config/init-config.js +60 -2
- package/dist/cli/config/init-config.js.map +1 -1
- package/dist/cli/config/init-provider-catalog.js +3 -1
- package/dist/cli/config/init-provider-catalog.js.map +1 -1
- package/dist/cli/config/precommand-default-script.d.ts +17 -0
- package/dist/cli/config/precommand-default-script.js +47 -0
- package/dist/cli/config/precommand-default-script.js.map +1 -0
- package/dist/cli.js +2 -0
- package/dist/cli.js.map +1 -1
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js +55 -5
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
- package/dist/commands/oauth.js +28 -4
- package/dist/commands/oauth.js.map +1 -1
- package/dist/commands/quota-daemon.js +12 -0
- package/dist/commands/quota-daemon.js.map +1 -1
- package/dist/configsamples/config.v1.quickstart.sanitized.json +1147 -0
- package/dist/constants/index.d.ts +34 -0
- package/dist/constants/index.js +57 -0
- package/dist/constants/index.js.map +1 -1
- package/dist/docs/daemon-admin-ui.html +268 -11
- package/dist/error-handling/quiet-error-handling-center.js +19 -1
- package/dist/error-handling/quiet-error-handling-center.js.map +1 -1
- package/dist/index.js +233 -30
- package/dist/index.js.map +1 -1
- package/dist/manager/index.js +4 -4
- package/dist/manager/index.js.map +1 -1
- package/dist/manager/modules/quota/antigravity-quota-core.d.ts +26 -0
- package/dist/manager/modules/quota/antigravity-quota-core.js +23 -0
- package/dist/manager/modules/quota/antigravity-quota-core.js.map +1 -0
- package/dist/manager/modules/quota/antigravity-quota-helpers.d.ts +16 -0
- package/dist/manager/modules/quota/antigravity-quota-helpers.js +167 -0
- package/dist/manager/modules/quota/antigravity-quota-helpers.js.map +1 -0
- package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +10 -39
- package/dist/manager/modules/quota/antigravity-quota-manager.js +167 -464
- package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -1
- package/dist/manager/modules/quota/antigravity-quota-persistence.d.ts +20 -0
- package/dist/manager/modules/quota/antigravity-quota-persistence.js +139 -0
- package/dist/manager/modules/quota/antigravity-quota-persistence.js.map +1 -0
- package/dist/manager/modules/quota/antigravity-quota-runtime.d.ts +55 -0
- package/dist/manager/modules/quota/antigravity-quota-runtime.js +174 -0
- package/dist/manager/modules/quota/antigravity-quota-runtime.js.map +1 -0
- package/dist/manager/modules/quota/antigravity-quota-sync.d.ts +46 -0
- package/dist/manager/modules/quota/antigravity-quota-sync.js +162 -0
- package/dist/manager/modules/quota/antigravity-quota-sync.js.map +1 -0
- package/dist/manager/modules/quota/index.d.ts +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.d.ts +13 -0
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js +149 -0
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.events.js +1 -148
- package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -1
- package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -1
- package/dist/manager/modules/quota/quota-adapter.d.ts +111 -0
- package/dist/manager/modules/quota/quota-adapter.js +325 -0
- package/dist/manager/modules/quota/quota-adapter.js.map +1 -0
- package/dist/manager/quota/provider-quota-center.d.ts +10 -0
- package/dist/manager/quota/provider-quota-center.js +15 -2
- package/dist/manager/quota/provider-quota-center.js.map +1 -1
- package/dist/modules/llmswitch/bridge/antigravity-signature.d.ts +28 -0
- package/dist/modules/llmswitch/bridge/antigravity-signature.js +180 -0
- package/dist/modules/llmswitch/bridge/antigravity-signature.js.map +1 -0
- package/dist/modules/llmswitch/bridge/index.d.ts +13 -0
- package/dist/modules/llmswitch/bridge/index.js +14 -0
- package/dist/modules/llmswitch/bridge/index.js.map +1 -0
- package/dist/modules/llmswitch/bridge/module-loader.d.ts +16 -0
- package/dist/modules/llmswitch/bridge/module-loader.js +59 -0
- package/dist/modules/llmswitch/bridge/module-loader.js.map +1 -0
- package/dist/modules/llmswitch/bridge/quota-manager.d.ts +8 -0
- package/dist/modules/llmswitch/bridge/quota-manager.js +37 -0
- package/dist/modules/llmswitch/bridge/quota-manager.js.map +1 -0
- package/dist/modules/llmswitch/bridge/response-converter.d.ts +11 -0
- package/dist/modules/llmswitch/bridge/response-converter.js +68 -0
- package/dist/modules/llmswitch/bridge/response-converter.js.map +1 -0
- package/dist/modules/llmswitch/bridge/routing-integrations.d.ts +12 -0
- package/dist/modules/llmswitch/bridge/routing-integrations.js +56 -0
- package/dist/modules/llmswitch/bridge/routing-integrations.js.map +1 -0
- package/dist/modules/llmswitch/bridge/runtime-integrations.d.ts +34 -0
- package/dist/modules/llmswitch/bridge/runtime-integrations.js +87 -0
- package/dist/modules/llmswitch/bridge/runtime-integrations.js.map +1 -0
- package/dist/modules/llmswitch/bridge/snapshot-recorder.d.ts +13 -0
- package/dist/modules/llmswitch/bridge/snapshot-recorder.js +484 -0
- package/dist/modules/llmswitch/bridge/snapshot-recorder.js.map +1 -0
- package/dist/modules/llmswitch/bridge/state-integrations.d.ts +59 -0
- package/dist/modules/llmswitch/bridge/state-integrations.js +264 -0
- package/dist/modules/llmswitch/bridge/state-integrations.js.map +1 -0
- package/dist/modules/llmswitch/bridge.d.ts +14 -131
- package/dist/modules/llmswitch/bridge.js +14 -834
- package/dist/modules/llmswitch/bridge.js.map +1 -1
- package/dist/modules/pipeline/types/provider-config-types.d.ts +240 -0
- package/dist/modules/pipeline/types/provider-config-types.js +2 -0
- package/dist/modules/pipeline/types/provider-config-types.js.map +1 -0
- package/dist/modules/pipeline/types/provider-types.d.ts +2 -239
- package/dist/modules/pipeline/types/provider-types.js +1 -1
- package/dist/modules/pipeline/types/provider-types.js.map +1 -1
- package/dist/modules/pipeline/utils/debug-logger.js +3 -5
- package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
- package/dist/providers/auth/apikey-auth.d.ts +57 -1
- package/dist/providers/auth/apikey-auth.js +131 -1
- package/dist/providers/auth/apikey-auth.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle/error-detection.d.ts +8 -0
- package/dist/providers/auth/oauth-lifecycle/error-detection.js +71 -0
- package/dist/providers/auth/oauth-lifecycle/error-detection.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle/index.d.ts +10 -0
- package/dist/providers/auth/oauth-lifecycle/index.js +11 -0
- package/dist/providers/auth/oauth-lifecycle/index.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle/path-resolver.d.ts +18 -0
- package/dist/providers/auth/oauth-lifecycle/path-resolver.js +121 -0
- package/dist/providers/auth/oauth-lifecycle/path-resolver.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle/throttle.d.ts +22 -0
- package/dist/providers/auth/oauth-lifecycle/throttle.js +37 -0
- package/dist/providers/auth/oauth-lifecycle/throttle.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle/token-helpers.d.ts +36 -0
- package/dist/providers/auth/oauth-lifecycle/token-helpers.js +127 -0
- package/dist/providers/auth/oauth-lifecycle/token-helpers.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle/token-io.d.ts +14 -0
- package/dist/providers/auth/oauth-lifecycle/token-io.js +151 -0
- package/dist/providers/auth/oauth-lifecycle/token-io.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle.js +70 -446
- package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
- package/dist/providers/auth/oauth-repair-cooldown.js +8 -3
- package/dist/providers/auth/oauth-repair-cooldown.js.map +1 -1
- package/dist/providers/auth/oauth-repair-env.js +5 -3
- package/dist/providers/auth/oauth-repair-env.js.map +1 -1
- package/dist/providers/auth/oauth-token-utils.d.ts +61 -0
- package/dist/providers/auth/oauth-token-utils.js +187 -0
- package/dist/providers/auth/oauth-token-utils.js.map +1 -0
- package/dist/providers/auth/oauth-utils/camoufox-helper.d.ts +21 -0
- package/dist/providers/auth/oauth-utils/camoufox-helper.js +82 -0
- package/dist/providers/auth/oauth-utils/camoufox-helper.js.map +1 -0
- package/dist/providers/auth/oauth-utils/error-extraction.d.ts +17 -0
- package/dist/providers/auth/oauth-utils/error-extraction.js +80 -0
- package/dist/providers/auth/oauth-utils/error-extraction.js.map +1 -0
- package/dist/providers/auth/oauth-utils/index.d.ts +7 -0
- package/dist/providers/auth/oauth-utils/index.js +8 -0
- package/dist/providers/auth/oauth-utils/index.js.map +1 -0
- package/dist/providers/auth/token-refresh/index.d.ts +6 -0
- package/dist/providers/auth/token-refresh/index.js +7 -0
- package/dist/providers/auth/token-refresh/index.js.map +1 -0
- package/dist/providers/auth/token-refresh/token-state.d.ts +17 -0
- package/dist/providers/auth/token-refresh/token-state.js +30 -0
- package/dist/providers/auth/token-refresh/token-state.js.map +1 -0
- package/dist/providers/auth/token-storage/index.d.ts +7 -0
- package/dist/providers/auth/token-storage/index.js +8 -0
- package/dist/providers/auth/token-storage/index.js.map +1 -0
- package/dist/providers/auth/token-storage/token-file-resolver.d.ts +12 -0
- package/dist/providers/auth/token-storage/token-file-resolver.js +117 -0
- package/dist/providers/auth/token-storage/token-file-resolver.js.map +1 -0
- package/dist/providers/auth/token-storage/token-persistence.d.ts +22 -0
- package/dist/providers/auth/token-storage/token-persistence.js +86 -0
- package/dist/providers/auth/token-storage/token-persistence.js.map +1 -0
- package/dist/providers/auth/tokenfile-auth.js +12 -9
- package/dist/providers/auth/tokenfile-auth.js.map +1 -1
- package/dist/providers/core/api/provider-config.d.ts +8 -0
- package/dist/providers/core/config/camoufox-launcher.d.ts +1 -0
- package/dist/providers/core/config/camoufox-launcher.js +40 -9
- package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
- package/dist/providers/core/config/oauth-flows.js +7 -2
- package/dist/providers/core/config/oauth-flows.js.map +1 -1
- package/dist/providers/core/config/provider-debug-hooks.d.ts +0 -12
- package/dist/providers/core/config/provider-debug-hooks.js +16 -56
- package/dist/providers/core/config/provider-debug-hooks.js.map +1 -1
- package/dist/providers/core/config/provider-debug-output-utils.d.ts +38 -0
- package/dist/providers/core/config/provider-debug-output-utils.js +46 -0
- package/dist/providers/core/config/provider-debug-output-utils.js.map +1 -0
- package/dist/providers/core/config/provider-oauth-configs.js +13 -9
- package/dist/providers/core/config/provider-oauth-configs.js.map +1 -1
- package/dist/providers/core/runtime/antigravity-request-type.d.ts +2 -0
- package/dist/providers/core/runtime/antigravity-request-type.js +126 -0
- package/dist/providers/core/runtime/antigravity-request-type.js.map +1 -0
- package/dist/providers/core/runtime/base-provider-runtime-helpers.d.ts +27 -0
- package/dist/providers/core/runtime/base-provider-runtime-helpers.js +105 -0
- package/dist/providers/core/runtime/base-provider-runtime-helpers.js.map +1 -0
- package/dist/providers/core/runtime/base-provider-series-cooldown.d.ts +19 -0
- package/dist/providers/core/runtime/base-provider-series-cooldown.js +363 -0
- package/dist/providers/core/runtime/base-provider-series-cooldown.js.map +1 -0
- package/dist/providers/core/runtime/base-provider.d.ts +4 -35
- package/dist/providers/core/runtime/base-provider.js +20 -501
- package/dist/providers/core/runtime/base-provider.js.map +1 -1
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.d.ts +32 -0
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.js +301 -0
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.js.map +1 -0
- package/dist/providers/core/runtime/deepseek-http-provider.d.ts +0 -3
- package/dist/providers/core/runtime/deepseek-http-provider.js +5 -127
- package/dist/providers/core/runtime/deepseek-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/deepseek-session-pow-helpers.d.ts +21 -0
- package/dist/providers/core/runtime/deepseek-session-pow-helpers.js +99 -0
- package/dist/providers/core/runtime/deepseek-session-pow-helpers.js.map +1 -0
- package/dist/providers/core/runtime/deepseek-session-pow.js +17 -100
- package/dist/providers/core/runtime/deepseek-session-pow.js.map +1 -1
- package/dist/providers/core/runtime/gemini-cli-http-provider.d.ts +0 -15
- package/dist/providers/core/runtime/gemini-cli-http-provider.js +13 -303
- package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/gemini-cli-response-postprocessor.d.ts +9 -0
- package/dist/providers/core/runtime/gemini-cli-response-postprocessor.js +85 -0
- package/dist/providers/core/runtime/gemini-cli-response-postprocessor.js.map +1 -0
- package/dist/providers/core/runtime/gemini-http-provider.js +2 -2
- package/dist/providers/core/runtime/gemini-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/gemini-sse-normalizer.d.ts +25 -0
- package/dist/providers/core/runtime/gemini-sse-normalizer.js +159 -0
- package/dist/providers/core/runtime/gemini-sse-normalizer.js.map +1 -0
- package/dist/providers/core/runtime/http-request-executor.js +1 -48
- package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
- package/dist/providers/core/runtime/http-transport-provider.d.ts +2 -48
- package/dist/providers/core/runtime/http-transport-provider.js +158 -1273
- package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
- package/dist/providers/core/runtime/provider-bootstrap-utils.d.ts +20 -0
- package/dist/providers/core/runtime/provider-bootstrap-utils.js +78 -0
- package/dist/providers/core/runtime/provider-bootstrap-utils.js.map +1 -0
- package/dist/providers/core/runtime/provider-factory-helpers.d.ts +19 -0
- package/dist/providers/core/runtime/provider-factory-helpers.js +203 -0
- package/dist/providers/core/runtime/provider-factory-helpers.js.map +1 -0
- package/dist/providers/core/runtime/provider-factory.d.ts +9 -7
- package/dist/providers/core/runtime/provider-factory.js +57 -214
- package/dist/providers/core/runtime/provider-factory.js.map +1 -1
- package/dist/providers/core/runtime/provider-family-profile-utils.d.ts +23 -0
- package/dist/providers/core/runtime/provider-family-profile-utils.js +57 -0
- package/dist/providers/core/runtime/provider-family-profile-utils.js.map +1 -0
- package/dist/providers/core/runtime/provider-http-executor-utils.d.ts +32 -0
- package/dist/providers/core/runtime/provider-http-executor-utils.js +92 -0
- package/dist/providers/core/runtime/provider-http-executor-utils.js.map +1 -0
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.d.ts +15 -0
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.js +49 -0
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.js.map +1 -0
- package/dist/providers/core/runtime/provider-request-executor-deps-factory.d.ts +29 -0
- package/dist/providers/core/runtime/provider-request-executor-deps-factory.js +41 -0
- package/dist/providers/core/runtime/provider-request-executor-deps-factory.js.map +1 -0
- package/dist/providers/core/runtime/provider-request-header-orchestrator.d.ts +30 -0
- package/dist/providers/core/runtime/provider-request-header-orchestrator.js +91 -0
- package/dist/providers/core/runtime/provider-request-header-orchestrator.js.map +1 -0
- package/dist/providers/core/runtime/provider-request-preprocessor.d.ts +5 -0
- package/dist/providers/core/runtime/provider-request-preprocessor.js +39 -0
- package/dist/providers/core/runtime/provider-request-preprocessor.js.map +1 -0
- package/dist/providers/core/runtime/provider-request-shaping-utils.d.ts +37 -0
- package/dist/providers/core/runtime/provider-request-shaping-utils.js +65 -0
- package/dist/providers/core/runtime/provider-request-shaping-utils.js.map +1 -0
- package/dist/providers/core/runtime/provider-response-postprocessor.d.ts +7 -0
- package/dist/providers/core/runtime/provider-response-postprocessor.js +28 -0
- package/dist/providers/core/runtime/provider-response-postprocessor.js.map +1 -0
- package/dist/providers/core/runtime/provider-runtime-utils.d.ts +16 -0
- package/dist/providers/core/runtime/provider-runtime-utils.js +51 -0
- package/dist/providers/core/runtime/provider-runtime-utils.js.map +1 -0
- package/dist/providers/core/runtime/responses-provider-helpers.d.ts +37 -0
- package/dist/providers/core/runtime/responses-provider-helpers.js +212 -0
- package/dist/providers/core/runtime/responses-provider-helpers.js.map +1 -0
- package/dist/providers/core/runtime/responses-provider.d.ts +0 -10
- package/dist/providers/core/runtime/responses-provider.js +14 -224
- package/dist/providers/core/runtime/responses-provider.js.map +1 -1
- package/dist/providers/core/runtime/runtime-endpoint-resolver.d.ts +21 -0
- package/dist/providers/core/runtime/runtime-endpoint-resolver.js +64 -0
- package/dist/providers/core/runtime/runtime-endpoint-resolver.js.map +1 -0
- package/dist/providers/core/runtime/service-profile-resolver.d.ts +29 -0
- package/dist/providers/core/runtime/service-profile-resolver.js +88 -0
- package/dist/providers/core/runtime/service-profile-resolver.js.map +1 -0
- package/dist/providers/core/runtime/transport/auth-mode-utils.d.ts +13 -0
- package/dist/providers/core/runtime/transport/auth-mode-utils.js +43 -0
- package/dist/providers/core/runtime/transport/auth-mode-utils.js.map +1 -0
- package/dist/providers/core/runtime/transport/auth-provider-factory.d.ts +37 -0
- package/dist/providers/core/runtime/transport/auth-provider-factory.js +131 -0
- package/dist/providers/core/runtime/transport/auth-provider-factory.js.map +1 -0
- package/dist/providers/core/runtime/transport/header-utils.d.ts +15 -0
- package/dist/providers/core/runtime/transport/header-utils.js +85 -0
- package/dist/providers/core/runtime/transport/header-utils.js.map +1 -0
- package/dist/providers/core/runtime/transport/iflow-signer.d.ts +12 -0
- package/dist/providers/core/runtime/transport/iflow-signer.js +63 -0
- package/dist/providers/core/runtime/transport/iflow-signer.js.map +1 -0
- package/dist/providers/core/runtime/transport/index.d.ts +15 -0
- package/dist/providers/core/runtime/transport/index.js +16 -0
- package/dist/providers/core/runtime/transport/index.js.map +1 -0
- package/dist/providers/core/runtime/transport/oauth-header-preflight.d.ts +12 -0
- package/dist/providers/core/runtime/transport/oauth-header-preflight.js +56 -0
- package/dist/providers/core/runtime/transport/oauth-header-preflight.js.map +1 -0
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.d.ts +34 -0
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.js +126 -0
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.js.map +1 -0
- package/dist/providers/core/runtime/transport/provider-payload-utils.d.ts +21 -0
- package/dist/providers/core/runtime/transport/provider-payload-utils.js +88 -0
- package/dist/providers/core/runtime/transport/provider-payload-utils.js.map +1 -0
- package/dist/providers/core/runtime/transport/request-header-builder.d.ts +24 -0
- package/dist/providers/core/runtime/transport/request-header-builder.js +90 -0
- package/dist/providers/core/runtime/transport/request-header-builder.js.map +1 -0
- package/dist/providers/core/runtime/transport/runtime-detector.d.ts +22 -0
- package/dist/providers/core/runtime/transport/runtime-detector.js +63 -0
- package/dist/providers/core/runtime/transport/runtime-detector.js.map +1 -0
- package/dist/providers/core/runtime/transport/session-header-utils.d.ts +8 -0
- package/dist/providers/core/runtime/transport/session-header-utils.js +72 -0
- package/dist/providers/core/runtime/transport/session-header-utils.js.map +1 -0
- package/dist/providers/core/runtime/vision-debug-utils.d.ts +2 -0
- package/dist/providers/core/runtime/vision-debug-utils.js +31 -0
- package/dist/providers/core/runtime/vision-debug-utils.js.map +1 -1
- package/dist/providers/core/strategies/oauth-auth-code-flow.d.ts +13 -0
- package/dist/providers/core/strategies/oauth-auth-code-flow.js +272 -55
- package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
- package/dist/providers/core/utils/snapshot-writer-buffer.d.ts +13 -0
- package/dist/providers/core/utils/snapshot-writer-buffer.js +39 -0
- package/dist/providers/core/utils/snapshot-writer-buffer.js.map +1 -0
- package/dist/providers/core/utils/snapshot-writer.js +75 -54
- package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
- package/dist/providers/profile/families/antigravity-profile.js +2 -10
- package/dist/providers/profile/families/antigravity-profile.js.map +1 -1
- package/dist/providers/profile/families/deepseek-profile.d.ts +2 -0
- package/dist/providers/profile/families/deepseek-profile.js +110 -0
- package/dist/providers/profile/families/deepseek-profile.js.map +1 -0
- package/dist/providers/profile/families/iflow-profile.js +89 -10
- package/dist/providers/profile/families/iflow-profile.js.map +1 -1
- package/dist/providers/profile/provider-profile-loader.d.ts +5 -0
- package/dist/providers/profile/provider-profile-loader.js +35 -0
- package/dist/providers/profile/provider-profile-loader.js.map +1 -1
- package/dist/providers/profile/provider-profile.d.ts +16 -1
- package/dist/runtime/runtime-flags.js +1 -1
- package/dist/runtime/runtime-flags.js.map +1 -1
- package/dist/runtime/wasm-runtime/index.d.ts +56 -0
- package/dist/runtime/wasm-runtime/index.js +69 -0
- package/dist/runtime/wasm-runtime/index.js.map +1 -0
- package/dist/scripts/camoufox/launch-auth.mjs +158 -10
- package/dist/server/handlers/handler-response-utils.d.ts +13 -0
- package/dist/server/handlers/handler-response-utils.js +427 -0
- package/dist/server/handlers/handler-response-utils.js.map +1 -0
- package/dist/server/handlers/handler-utils.d.ts +2 -11
- package/dist/server/handlers/handler-utils.js +21 -421
- package/dist/server/handlers/handler-utils.js.map +1 -1
- package/dist/server/runtime/http-server/clock-client-reaper.d.ts +23 -0
- package/dist/server/runtime/http-server/clock-client-reaper.js +159 -0
- package/dist/server/runtime/http-server/clock-client-reaper.js.map +1 -0
- package/dist/server/runtime/http-server/clock-client-registry-utils.d.ts +87 -0
- package/dist/server/runtime/http-server/clock-client-registry-utils.js +276 -0
- package/dist/server/runtime/http-server/clock-client-registry-utils.js.map +1 -0
- package/dist/server/runtime/http-server/clock-client-registry.d.ts +5 -50
- package/dist/server/runtime/http-server/clock-client-registry.js +74 -320
- package/dist/server/runtime/http-server/clock-client-registry.js.map +1 -1
- package/dist/server/runtime/http-server/clock-client-route-utils.d.ts +12 -0
- package/dist/server/runtime/http-server/clock-client-route-utils.js +210 -0
- package/dist/server/runtime/http-server/clock-client-route-utils.js.map +1 -0
- package/dist/server/runtime/http-server/clock-client-routes.js +27 -201
- package/dist/server/runtime/http-server/clock-client-routes.js.map +1 -1
- package/dist/server/runtime/http-server/clock-daemon-log-throttle.d.ts +12 -0
- package/dist/server/runtime/http-server/clock-daemon-log-throttle.js +56 -0
- package/dist/server/runtime/http-server/clock-daemon-log-throttle.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/control-handler.js +143 -14
- package/dist/server/runtime/http-server/daemon-admin/control-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.d.ts +19 -0
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js +107 -0
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +2 -104
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.d.ts +28 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js +298 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.d.ts +22 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.js +211 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +25 -454
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +81 -32
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.d.ts +22 -0
- package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.js +70 -0
- package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.js.map +1 -0
- package/dist/server/runtime/http-server/executor/antigravity-detector.d.ts +34 -0
- package/dist/server/runtime/http-server/executor/antigravity-detector.js +118 -0
- package/dist/server/runtime/http-server/executor/antigravity-detector.js.map +1 -0
- package/dist/server/runtime/http-server/executor/env-config.d.ts +13 -0
- package/dist/server/runtime/http-server/executor/env-config.js +20 -0
- package/dist/server/runtime/http-server/executor/env-config.js.map +1 -0
- package/dist/server/runtime/http-server/executor/index.d.ts +11 -0
- package/dist/server/runtime/http-server/executor/index.js +18 -0
- package/dist/server/runtime/http-server/executor/index.js.map +1 -0
- package/dist/server/runtime/http-server/executor/provider-request-context.d.ts +20 -0
- package/dist/server/runtime/http-server/executor/provider-request-context.js +38 -0
- package/dist/server/runtime/http-server/executor/provider-request-context.js.map +1 -0
- package/dist/server/runtime/http-server/executor/provider-response-converter.d.ts +23 -0
- package/dist/server/runtime/http-server/executor/provider-response-converter.js +337 -0
- package/dist/server/runtime/http-server/executor/provider-response-converter.js.map +1 -0
- package/dist/server/runtime/http-server/executor/provider-response-utils.d.ts +8 -0
- package/dist/server/runtime/http-server/executor/provider-response-utils.js +93 -0
- package/dist/server/runtime/http-server/executor/provider-response-utils.js.map +1 -0
- package/dist/server/runtime/http-server/executor/provider-runtime-resolver.d.ts +23 -0
- package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js +85 -0
- package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js.map +1 -0
- package/dist/server/runtime/http-server/executor/request-executor-core-utils.d.ts +7 -0
- package/dist/server/runtime/http-server/executor/request-executor-core-utils.js +39 -0
- package/dist/server/runtime/http-server/executor/request-executor-core-utils.js.map +1 -0
- package/dist/server/runtime/http-server/executor/request-retry-helpers.d.ts +16 -0
- package/dist/server/runtime/http-server/executor/request-retry-helpers.js +218 -0
- package/dist/server/runtime/http-server/executor/request-retry-helpers.js.map +1 -0
- package/dist/server/runtime/http-server/executor/retry-engine.d.ts +21 -0
- package/dist/server/runtime/http-server/executor/retry-engine.js +73 -0
- package/dist/server/runtime/http-server/executor/retry-engine.js.map +1 -0
- package/dist/server/runtime/http-server/executor/sse-error-handler.d.ts +14 -0
- package/dist/server/runtime/http-server/executor/sse-error-handler.js +127 -0
- package/dist/server/runtime/http-server/executor/sse-error-handler.js.map +1 -0
- package/dist/server/runtime/http-server/executor/usage-aggregator.d.ts +39 -0
- package/dist/server/runtime/http-server/executor/usage-aggregator.js +177 -0
- package/dist/server/runtime/http-server/executor/usage-aggregator.js.map +1 -0
- package/dist/server/runtime/http-server/executor/usage-logger.d.ts +7 -0
- package/dist/server/runtime/http-server/executor/usage-logger.js +13 -0
- package/dist/server/runtime/http-server/executor/usage-logger.js.map +1 -0
- package/dist/server/runtime/http-server/executor/utils.d.ts +21 -0
- package/dist/server/runtime/http-server/executor/utils.js +62 -0
- package/dist/server/runtime/http-server/executor/utils.js.map +1 -0
- package/dist/server/runtime/http-server/executor-metadata.js +83 -2
- package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
- package/dist/server/runtime/http-server/executor-response.js +17 -9
- package/dist/server/runtime/http-server/executor-response.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-bootstrap.d.ts +31 -0
- package/dist/server/runtime/http-server/http-server-bootstrap.js +367 -0
- package/dist/server/runtime/http-server/http-server-bootstrap.js.map +1 -0
- package/dist/server/runtime/http-server/http-server-clock-daemon.d.ts +5 -0
- package/dist/server/runtime/http-server/http-server-clock-daemon.js +242 -0
- package/dist/server/runtime/http-server/http-server-clock-daemon.js.map +1 -0
- package/dist/server/runtime/http-server/http-server-legacy-pipeline.d.ts +2 -0
- package/dist/server/runtime/http-server/http-server-legacy-pipeline.js +65 -0
- package/dist/server/runtime/http-server/http-server-legacy-pipeline.js.map +1 -0
- package/dist/server/runtime/http-server/http-server-lifecycle.d.ts +27 -0
- package/dist/server/runtime/http-server/http-server-lifecycle.js +285 -0
- package/dist/server/runtime/http-server/http-server-lifecycle.js.map +1 -0
- package/dist/server/runtime/http-server/http-server-runtime-providers.d.ts +10 -0
- package/dist/server/runtime/http-server/http-server-runtime-providers.js +415 -0
- package/dist/server/runtime/http-server/http-server-runtime-providers.js.map +1 -0
- package/dist/server/runtime/http-server/http-server-runtime-setup.d.ts +2 -0
- package/dist/server/runtime/http-server/http-server-runtime-setup.js +93 -0
- package/dist/server/runtime/http-server/http-server-runtime-setup.js.map +1 -0
- package/dist/server/runtime/http-server/index.d.ts +4 -46
- package/dist/server/runtime/http-server/index.js +98 -2577
- package/dist/server/runtime/http-server/index.js.map +1 -1
- package/dist/server/runtime/http-server/request-executor.d.ts +8 -21
- package/dist/server/runtime/http-server/request-executor.js +94 -956
- package/dist/server/runtime/http-server/request-executor.js.map +1 -1
- package/dist/server/runtime/http-server/routes.js +2 -2
- package/dist/server/runtime/http-server/routes.js.map +1 -1
- package/dist/server/runtime/http-server/servertool-admin-state.d.ts +42 -0
- package/dist/server/runtime/http-server/servertool-admin-state.js +210 -0
- package/dist/server/runtime/http-server/servertool-admin-state.js.map +1 -0
- package/dist/server/runtime/http-server/stats-manager-internals.d.ts +96 -0
- package/dist/server/runtime/http-server/stats-manager-internals.js +311 -0
- package/dist/server/runtime/http-server/stats-manager-internals.js.map +1 -0
- package/dist/server/runtime/http-server/stats-manager-table.d.ts +6 -0
- package/dist/server/runtime/http-server/stats-manager-table.js +135 -0
- package/dist/server/runtime/http-server/stats-manager-table.js.map +1 -0
- package/dist/server/runtime/http-server/stats-manager.d.ts +0 -23
- package/dist/server/runtime/http-server/stats-manager.js +95 -483
- package/dist/server/runtime/http-server/stats-manager.js.map +1 -1
- package/dist/server/utils/client-connection-state.js +61 -0
- package/dist/server/utils/client-connection-state.js.map +1 -1
- package/dist/server/utils/request-id-manager.d.ts +6 -0
- package/dist/server/utils/request-id-manager.js +105 -15
- package/dist/server/utils/request-id-manager.js.map +1 -1
- package/dist/server/utils/stage-logger.js +14 -4
- package/dist/server/utils/stage-logger.js.map +1 -1
- package/dist/server-lifecycle/index.d.ts +6 -0
- package/dist/server-lifecycle/index.js +7 -0
- package/dist/server-lifecycle/index.js.map +1 -0
- package/dist/server-lifecycle/port-utils.d.ts +18 -0
- package/dist/server-lifecycle/port-utils.js +204 -0
- package/dist/server-lifecycle/port-utils.js.map +1 -0
- package/dist/sharedmodule/process-snapshot.d.ts +26 -0
- package/dist/sharedmodule/process-snapshot.js +141 -0
- package/dist/sharedmodule/process-snapshot.js.map +1 -0
- package/dist/token-daemon/index.js +10 -3
- package/dist/token-daemon/index.js.map +1 -1
- package/dist/token-daemon/token-daemon.js +9 -11
- package/dist/token-daemon/token-daemon.js.map +1 -1
- package/dist/token-daemon/token-utils.d.ts +1 -1
- package/dist/token-daemon/token-utils.js +19 -3
- package/dist/token-daemon/token-utils.js.map +1 -1
- package/dist/tools/semantic-replay-snapshot-loader.d.ts +4 -0
- package/dist/tools/semantic-replay-snapshot-loader.js +396 -0
- package/dist/tools/semantic-replay-snapshot-loader.js.map +1 -0
- package/dist/tools/semantic-replay.js +2 -393
- package/dist/tools/semantic-replay.js.map +1 -1
- package/dist/utils/daemon-stop-intent.d.ts +17 -0
- package/dist/utils/daemon-stop-intent.js +104 -0
- package/dist/utils/daemon-stop-intent.js.map +1 -0
- package/dist/utils/key-429-tracker.js +6 -5
- package/dist/utils/key-429-tracker.js.map +1 -1
- package/dist/utils/pipeline-health-manager.js +7 -6
- package/dist/utils/pipeline-health-manager.js.map +1 -1
- package/dist/utils/process-lifecycle-logger.js +45 -1
- package/dist/utils/process-lifecycle-logger.js.map +1 -1
- package/dist/utils/runtime-exit-forensics.d.ts +2 -2
- package/dist/utils/runtime-exit-forensics.js +10 -5
- package/dist/utils/runtime-exit-forensics.js.map +1 -1
- package/dist/utils/snapshot-writer.js +3 -3
- package/dist/utils/snapshot-writer.js.map +1 -1
- package/docs/QUOTA_MANAGER_V3.md +3 -0
- package/docs/VIRTUAL_ROUTER_PRIORITY_AND_HEALTH.md +114 -0
- package/docs/daemon-admin-ui.html +268 -11
- package/docs/file-line-limit-gate.md +30 -0
- package/docs/refactoring/host-164.3-responsibility-migration.md +62 -0
- package/docs/release-iflow-400-gate.md +58 -0
- package/docs/replay-evidence-iflow-400.txt +33 -0
- package/docs/stop-message-auto.md +4 -3
- package/package.json +4 -3
- package/scripts/auth-iflow-manual.mjs +13 -23
- package/scripts/camoufox/launch-auth.mjs +158 -10
- package/scripts/ci/check-file-line-limit.mjs +149 -0
- package/scripts/copy-compat-assets.mjs +26 -0
- package/scripts/copy-modules-config.mjs +18 -0
- package/scripts/tests/ci-jest.mjs +4 -0
- package/scripts/verify-codex-error-samples.mjs +27 -6
|
@@ -1,78 +1,6 @@
|
|
|
1
|
-
import fs from 'node:fs';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { spawnSync } from 'node:child_process';
|
|
4
|
-
import type { ChildProcess, SpawnOptions } from 'node:child_process';
|
|
5
1
|
import type { Command } from 'commander';
|
|
6
|
-
type
|
|
7
|
-
|
|
8
|
-
succeed(text?: string): void;
|
|
9
|
-
fail(text?: string): void;
|
|
10
|
-
warn(text?: string): void;
|
|
11
|
-
info(text?: string): void;
|
|
12
|
-
stop(): void;
|
|
13
|
-
text: string;
|
|
14
|
-
};
|
|
15
|
-
type LoggerLike = {
|
|
16
|
-
info: (msg: string) => void;
|
|
17
|
-
warning: (msg: string) => void;
|
|
18
|
-
success: (msg: string) => void;
|
|
19
|
-
error: (msg: string) => void;
|
|
20
|
-
};
|
|
21
|
-
export type LauncherCommandContext = {
|
|
22
|
-
isDevPackage: boolean;
|
|
23
|
-
isWindows: boolean;
|
|
24
|
-
defaultDevPort: number;
|
|
25
|
-
nodeBin: string;
|
|
26
|
-
createSpinner: (text: string) => Promise<Spinner>;
|
|
27
|
-
logger: LoggerLike;
|
|
28
|
-
env: NodeJS.ProcessEnv;
|
|
29
|
-
rawArgv: string[];
|
|
30
|
-
fsImpl?: typeof fs;
|
|
31
|
-
pathImpl?: typeof path;
|
|
32
|
-
homedir: () => string;
|
|
33
|
-
cwd?: () => string;
|
|
34
|
-
sleep: (ms: number) => Promise<void>;
|
|
35
|
-
fetch: typeof fetch;
|
|
36
|
-
spawn: (command: string, args: string[], options: SpawnOptions) => ChildProcess;
|
|
37
|
-
spawnSyncImpl?: typeof spawnSync;
|
|
38
|
-
getModulesConfigPath: () => string;
|
|
39
|
-
resolveServerEntryPath: () => string;
|
|
40
|
-
waitForever: () => Promise<void>;
|
|
41
|
-
onSignal?: (signal: NodeJS.Signals, cb: () => void) => void;
|
|
42
|
-
exit: (code: number) => never;
|
|
43
|
-
};
|
|
44
|
-
type LauncherCommandOptions = {
|
|
45
|
-
port?: string;
|
|
46
|
-
host: string;
|
|
47
|
-
url?: string;
|
|
48
|
-
config?: string;
|
|
49
|
-
apikey?: string;
|
|
50
|
-
cwd?: string;
|
|
51
|
-
model?: string;
|
|
52
|
-
profile?: string;
|
|
53
|
-
ensureServer?: boolean;
|
|
54
|
-
[key: string]: unknown;
|
|
55
|
-
};
|
|
56
|
-
type LauncherSpec = {
|
|
57
|
-
commandName: string;
|
|
58
|
-
displayName: string;
|
|
59
|
-
description: string;
|
|
60
|
-
binaryOptionFlags: string;
|
|
61
|
-
binaryOptionName: string;
|
|
62
|
-
binaryOptionDescription: string;
|
|
63
|
-
binaryDefault: string;
|
|
64
|
-
binaryEnvKey?: string;
|
|
65
|
-
extraKnownOptions: string[];
|
|
66
|
-
withModelOption?: boolean;
|
|
67
|
-
withProfileOption?: boolean;
|
|
68
|
-
buildArgs: (options: LauncherCommandOptions) => string[];
|
|
69
|
-
buildEnv: (args: {
|
|
70
|
-
env: NodeJS.ProcessEnv;
|
|
71
|
-
baseUrl: string;
|
|
72
|
-
configuredApiKey: string | null;
|
|
73
|
-
cwd: string;
|
|
74
|
-
}) => NodeJS.ProcessEnv;
|
|
75
|
-
};
|
|
2
|
+
import type { LauncherCommandContext, LauncherSpec } from './launcher/types.js';
|
|
3
|
+
export type { Spinner, LoggerLike, LauncherCommandContext, LauncherCommandOptions, LauncherSpec, ResolvedServerConnection, ClockClientService, ManagedTmuxSession, TmuxSelfHealPolicy } from './launcher/types.js';
|
|
76
4
|
declare function normalizeOpenAiBaseUrl(baseUrl: string): string;
|
|
77
5
|
export declare function createLauncherCommand(program: Command, ctx: LauncherCommandContext, spec: LauncherSpec): void;
|
|
78
6
|
export { normalizeOpenAiBaseUrl };
|
|
@@ -6,118 +6,7 @@ import crypto from 'node:crypto';
|
|
|
6
6
|
import { LOCAL_HOSTS } from '../../constants/index.js';
|
|
7
7
|
import { encodeClockClientApiKey } from '../../utils/clock-client-token.js';
|
|
8
8
|
import { logProcessLifecycle } from '../../utils/process-lifecycle-logger.js';
|
|
9
|
-
|
|
10
|
-
const raw = String(options.command || '').trim();
|
|
11
|
-
if (!raw) {
|
|
12
|
-
return '';
|
|
13
|
-
}
|
|
14
|
-
if (raw.includes('/') || raw.includes('\\')) {
|
|
15
|
-
return raw;
|
|
16
|
-
}
|
|
17
|
-
const candidates = [];
|
|
18
|
-
try {
|
|
19
|
-
candidates.push(options.pathImpl.join('/opt/homebrew/bin', raw));
|
|
20
|
-
}
|
|
21
|
-
catch {
|
|
22
|
-
// ignore
|
|
23
|
-
}
|
|
24
|
-
try {
|
|
25
|
-
candidates.push(options.pathImpl.join('/usr/local/bin', raw));
|
|
26
|
-
}
|
|
27
|
-
catch {
|
|
28
|
-
// ignore
|
|
29
|
-
}
|
|
30
|
-
try {
|
|
31
|
-
candidates.push(options.pathImpl.join(options.homedir(), '.local', 'bin', raw));
|
|
32
|
-
}
|
|
33
|
-
catch {
|
|
34
|
-
// ignore
|
|
35
|
-
}
|
|
36
|
-
for (const candidate of candidates) {
|
|
37
|
-
try {
|
|
38
|
-
if (candidate && options.fsImpl.existsSync(candidate)) {
|
|
39
|
-
return candidate;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
catch {
|
|
43
|
-
// ignore
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
return raw;
|
|
47
|
-
}
|
|
48
|
-
function parseServerUrl(raw) {
|
|
49
|
-
const trimmed = String(raw || '').trim();
|
|
50
|
-
if (!trimmed) {
|
|
51
|
-
throw new Error('--url is empty');
|
|
52
|
-
}
|
|
53
|
-
let parsed;
|
|
54
|
-
try {
|
|
55
|
-
parsed = new URL(trimmed);
|
|
56
|
-
}
|
|
57
|
-
catch {
|
|
58
|
-
parsed = new URL(`http://${trimmed}`);
|
|
59
|
-
}
|
|
60
|
-
const protocol = parsed.protocol === 'https:' ? 'https' : 'http';
|
|
61
|
-
const host = parsed.hostname;
|
|
62
|
-
const hasExplicitPort = Boolean(parsed.port && parsed.port.trim());
|
|
63
|
-
const port = hasExplicitPort ? Number(parsed.port) : null;
|
|
64
|
-
const rawPath = typeof parsed.pathname === 'string' ? parsed.pathname : '';
|
|
65
|
-
const basePath = rawPath && rawPath !== '/' ? rawPath.replace(/\/+$/, '') : '';
|
|
66
|
-
return { protocol, host, port: Number.isFinite(port) ? port : null, basePath };
|
|
67
|
-
}
|
|
68
|
-
function readConfigApiKey(fsImpl, configPath) {
|
|
69
|
-
try {
|
|
70
|
-
if (!configPath || !fsImpl.existsSync(configPath)) {
|
|
71
|
-
return null;
|
|
72
|
-
}
|
|
73
|
-
const txt = fsImpl.readFileSync(configPath, 'utf8');
|
|
74
|
-
const cfg = JSON.parse(txt);
|
|
75
|
-
const direct = cfg?.httpserver?.apikey ?? cfg?.modules?.httpserver?.config?.apikey ?? cfg?.server?.apikey;
|
|
76
|
-
const value = typeof direct === 'string' ? direct.trim() : '';
|
|
77
|
-
return value ? value : null;
|
|
78
|
-
}
|
|
79
|
-
catch {
|
|
80
|
-
return null;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
function normalizeConnectHost(host) {
|
|
84
|
-
const value = String(host || '').toLowerCase();
|
|
85
|
-
if (value === '0.0.0.0') {
|
|
86
|
-
return '0.0.0.0';
|
|
87
|
-
}
|
|
88
|
-
if (value === '::' || value === '::1' || value === 'localhost') {
|
|
89
|
-
return '0.0.0.0';
|
|
90
|
-
}
|
|
91
|
-
return host || '0.0.0.0';
|
|
92
|
-
}
|
|
93
|
-
function toIntegerPort(value) {
|
|
94
|
-
if (typeof value === 'number' && Number.isFinite(value) && value > 0) {
|
|
95
|
-
return Math.floor(value);
|
|
96
|
-
}
|
|
97
|
-
if (typeof value === 'string' && value.trim()) {
|
|
98
|
-
const parsed = Number(value.trim());
|
|
99
|
-
if (Number.isFinite(parsed) && parsed > 0) {
|
|
100
|
-
return Math.floor(parsed);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
return null;
|
|
104
|
-
}
|
|
105
|
-
function tryReadConfigHostPort(fsImpl, configPath) {
|
|
106
|
-
if (!configPath || !fsImpl.existsSync(configPath)) {
|
|
107
|
-
return { host: null, port: null };
|
|
108
|
-
}
|
|
109
|
-
try {
|
|
110
|
-
const configContent = fsImpl.readFileSync(configPath, 'utf8');
|
|
111
|
-
const config = JSON.parse(configContent);
|
|
112
|
-
const port = toIntegerPort(config?.httpserver?.port ?? config?.server?.port ?? config?.port);
|
|
113
|
-
const hostRaw = config?.httpserver?.host ?? config?.server?.host ?? config?.host;
|
|
114
|
-
const host = typeof hostRaw === 'string' && hostRaw.trim() ? hostRaw.trim() : null;
|
|
115
|
-
return { host, port };
|
|
116
|
-
}
|
|
117
|
-
catch {
|
|
118
|
-
return { host: null, port: null };
|
|
119
|
-
}
|
|
120
|
-
}
|
|
9
|
+
import { resolveBinary, parseServerUrl, resolveTmuxSelfHealPolicy, readConfigApiKey, normalizeConnectHost, toIntegerPort, tryReadConfigHostPort, resolveIntFromEnv } from './launcher/utils.js';
|
|
121
10
|
function resolveServerConnection(ctx, fsImpl, pathImpl, options) {
|
|
122
11
|
let configPath = typeof options.config === 'string' && options.config.trim() ? options.config.trim() : '';
|
|
123
12
|
if (!configPath) {
|
|
@@ -392,17 +281,24 @@ async function ensureServerReady(ctx, fsImpl, pathImpl, spinner, options, resolv
|
|
|
392
281
|
}
|
|
393
282
|
function resolveWorkingDirectory(ctx, fsImpl, pathImpl, requested) {
|
|
394
283
|
const getCwd = ctx.cwd ?? (() => process.cwd());
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
const resolved = pathImpl.resolve(
|
|
398
|
-
if (fsImpl.existsSync(resolved)) {
|
|
399
|
-
|
|
284
|
+
const normalizeRequested = typeof requested === 'string' ? requested.trim() : '';
|
|
285
|
+
if (normalizeRequested) {
|
|
286
|
+
const resolved = pathImpl.resolve(normalizeRequested);
|
|
287
|
+
if (!fsImpl.existsSync(resolved)) {
|
|
288
|
+
throw new Error(`Invalid --cwd: path does not exist: ${resolved}`);
|
|
400
289
|
}
|
|
290
|
+
const stats = fsImpl.statSync(resolved);
|
|
291
|
+
if (!stats || typeof stats.isDirectory !== 'function' || !stats.isDirectory()) {
|
|
292
|
+
throw new Error(`Invalid --cwd: path is not a directory: ${resolved}`);
|
|
293
|
+
}
|
|
294
|
+
return resolved;
|
|
295
|
+
}
|
|
296
|
+
try {
|
|
297
|
+
return pathImpl.resolve(getCwd());
|
|
401
298
|
}
|
|
402
299
|
catch {
|
|
403
300
|
return getCwd();
|
|
404
301
|
}
|
|
405
|
-
return getCwd();
|
|
406
302
|
}
|
|
407
303
|
function isTmuxAvailable(spawnSyncImpl = spawnSync) {
|
|
408
304
|
try {
|
|
@@ -466,16 +362,25 @@ function buildShellCommand(tokens) {
|
|
|
466
362
|
return tokens.map((token) => shellQuote(token)).join(' ');
|
|
467
363
|
}
|
|
468
364
|
function collectChangedEnv(baseEnv, nextEnv) {
|
|
469
|
-
const
|
|
365
|
+
const set = [];
|
|
366
|
+
const unset = [];
|
|
470
367
|
for (const [key, value] of Object.entries(nextEnv)) {
|
|
471
368
|
if (typeof value !== 'string') {
|
|
472
369
|
continue;
|
|
473
370
|
}
|
|
474
371
|
if (baseEnv[key] !== value) {
|
|
475
|
-
|
|
372
|
+
set.push([key, value]);
|
|
476
373
|
}
|
|
477
374
|
}
|
|
478
|
-
|
|
375
|
+
for (const [key, value] of Object.entries(baseEnv)) {
|
|
376
|
+
if (typeof value !== 'string') {
|
|
377
|
+
continue;
|
|
378
|
+
}
|
|
379
|
+
if (typeof nextEnv[key] === 'undefined') {
|
|
380
|
+
unset.push(key);
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
return { set, unset };
|
|
479
384
|
}
|
|
480
385
|
function sendTmuxSubmitKey(spawnSyncImpl, tmuxTarget, clientType) {
|
|
481
386
|
const type = String(clientType || '').trim().toLowerCase();
|
|
@@ -497,6 +402,20 @@ function sendTmuxSubmitKey(spawnSyncImpl, tmuxTarget, clientType) {
|
|
|
497
402
|
lastError = error instanceof Error ? error.message : String(error ?? `tmux send-keys ${submitKey} failed`);
|
|
498
403
|
}
|
|
499
404
|
}
|
|
405
|
+
for (const fallback of ['\r', '\n']) {
|
|
406
|
+
try {
|
|
407
|
+
const literal = spawnSyncImpl('tmux', ['send-keys', '-t', tmuxTarget, '-l', '--', fallback], { encoding: 'utf8' });
|
|
408
|
+
if (literal.status === 0) {
|
|
409
|
+
return { ok: true };
|
|
410
|
+
}
|
|
411
|
+
lastError =
|
|
412
|
+
String(literal.stderr || literal.stdout || 'tmux send-keys literal newline failed').trim()
|
|
413
|
+
|| 'tmux send-keys literal newline failed';
|
|
414
|
+
}
|
|
415
|
+
catch (error) {
|
|
416
|
+
lastError = error instanceof Error ? error.message : String(error ?? 'tmux send-keys literal newline failed');
|
|
417
|
+
}
|
|
418
|
+
}
|
|
500
419
|
return { ok: false, error: lastError || 'tmux send-keys submit failed' };
|
|
501
420
|
}
|
|
502
421
|
function isReusableIdlePaneCommand(command) {
|
|
@@ -634,18 +553,58 @@ function createManagedTmuxSession(args) {
|
|
|
634
553
|
};
|
|
635
554
|
}
|
|
636
555
|
function launchCommandInTmuxPane(args) {
|
|
637
|
-
const { spawnSyncImpl, tmuxTarget, cwd, command, commandArgs, envOverrides,
|
|
638
|
-
const envTokens =
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
556
|
+
const { spawnSyncImpl, tmuxTarget, cwd, command, commandName, commandArgs, envOverrides, selfHealPolicy } = args;
|
|
557
|
+
const envTokens = [
|
|
558
|
+
...envOverrides.unset.flatMap((key) => ['-u', key]),
|
|
559
|
+
...envOverrides.set.map(([key, value]) => `${key}=${value}`)
|
|
560
|
+
];
|
|
561
|
+
const baseCommand = buildShellCommand(['env', ...envTokens, command, ...commandArgs]);
|
|
562
|
+
// Keep the managed tmux session alive when the client process exits.
|
|
563
|
+
// Session cleanup is handled by managed heartbeat/reaper logic, not by inline shell self-kill.
|
|
564
|
+
const shellCommand = (() => {
|
|
565
|
+
if (!selfHealPolicy.enabled || selfHealPolicy.maxRetries <= 0) {
|
|
566
|
+
return `cd -- ${shellQuote(cwd)} && ${baseCommand}`;
|
|
567
|
+
}
|
|
568
|
+
const safeCommandName = shellQuote(commandName || command || 'client');
|
|
569
|
+
const loopBody = [
|
|
570
|
+
`${baseCommand}`,
|
|
571
|
+
'__rcc_exit=$?',
|
|
572
|
+
'if [ "$__rcc_exit" -eq 0 ] || [ "$__rcc_exit" -eq 130 ] || [ "$__rcc_exit" -eq 143 ]; then exit "$__rcc_exit"; fi',
|
|
573
|
+
'if [ "$__rcc_try" -ge "$__rcc_max" ]; then exit "$__rcc_exit"; fi',
|
|
574
|
+
'__rcc_try=$((__rcc_try + 1))',
|
|
575
|
+
`echo "[routecodex][self-heal] ${safeCommandName} exited with code $__rcc_exit; retry $__rcc_try/$__rcc_max in $__rcc_delay s" >&2`,
|
|
576
|
+
'sleep "$__rcc_delay"'
|
|
577
|
+
].join('; ');
|
|
578
|
+
return [
|
|
579
|
+
`cd -- ${shellQuote(cwd)} || exit 1`,
|
|
580
|
+
'__rcc_try=0',
|
|
581
|
+
`__rcc_max=${selfHealPolicy.maxRetries}`,
|
|
582
|
+
`__rcc_delay=${selfHealPolicy.retryDelaySec}`,
|
|
583
|
+
`while true; do ${loopBody}; done`
|
|
584
|
+
].join('; ');
|
|
585
|
+
})();
|
|
586
|
+
try {
|
|
587
|
+
// Prefer respawn-pane for deterministic execution in managed sessions.
|
|
588
|
+
// This avoids flaky "typed but not submitted" behavior from send-keys on some terminals.
|
|
589
|
+
const respawn = spawnSyncImpl('tmux', ['respawn-pane', '-k', '-t', tmuxTarget, shellCommand], { encoding: 'utf8' });
|
|
590
|
+
if (respawn.status === 0) {
|
|
591
|
+
return true;
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
catch {
|
|
595
|
+
// fallback to send-keys injection
|
|
596
|
+
}
|
|
643
597
|
try {
|
|
598
|
+
// Best-effort exit copy-mode before injecting and submitting shell command.
|
|
599
|
+
spawnSyncImpl('tmux', ['send-keys', '-t', tmuxTarget, '-X', 'cancel'], { encoding: 'utf8' });
|
|
600
|
+
// Reset any stale partially-typed command in reusable panes before injecting.
|
|
601
|
+
// This prevents duplicated/concatenated command lines when previous launches failed to submit.
|
|
602
|
+
spawnSyncImpl('tmux', ['send-keys', '-t', tmuxTarget, 'C-u'], { encoding: 'utf8' });
|
|
644
603
|
const literal = spawnSyncImpl('tmux', ['send-keys', '-t', tmuxTarget, '-l', '--', shellCommand], { encoding: 'utf8' });
|
|
645
604
|
if (literal.status !== 0) {
|
|
646
605
|
return false;
|
|
647
606
|
}
|
|
648
|
-
const submit = sendTmuxSubmitKey(spawnSyncImpl, tmuxTarget);
|
|
607
|
+
const submit = sendTmuxSubmitKey(spawnSyncImpl, tmuxTarget, commandName);
|
|
649
608
|
return submit.ok;
|
|
650
609
|
}
|
|
651
610
|
catch {
|
|
@@ -681,7 +640,7 @@ function sendJson(res, status, payload) {
|
|
|
681
640
|
res.end(body);
|
|
682
641
|
}
|
|
683
642
|
async function startClockClientService(args) {
|
|
684
|
-
const { ctx, resolved, tmuxTarget, spawnSyncImpl, clientType, managedTmuxSession, getManagedProcessState } = args;
|
|
643
|
+
const { ctx, resolved, workdir, tmuxTarget, spawnSyncImpl, clientType, managedTmuxSession, getManagedProcessState } = args;
|
|
685
644
|
const daemonId = (() => {
|
|
686
645
|
try {
|
|
687
646
|
return `clockd_${crypto.randomUUID()}`;
|
|
@@ -782,31 +741,67 @@ async function startClockClientService(args) {
|
|
|
782
741
|
headers: { 'content-type': 'application/json' },
|
|
783
742
|
body: JSON.stringify(payload)
|
|
784
743
|
});
|
|
785
|
-
return response.ok;
|
|
744
|
+
return { ok: response.ok, status: response.status };
|
|
786
745
|
}
|
|
787
746
|
catch {
|
|
788
|
-
return false;
|
|
747
|
+
return { ok: false, status: 0 };
|
|
748
|
+
}
|
|
749
|
+
};
|
|
750
|
+
const reRegisterBackoffMs = resolveIntFromEnv(ctx.env.ROUTECODEX_CLOCK_CLIENT_REREGISTER_BACKOFF_MS ?? ctx.env.RCC_CLOCK_CLIENT_REREGISTER_BACKOFF_MS, 1500, 200, 60_000);
|
|
751
|
+
let registerInFlight = null;
|
|
752
|
+
let lastRegisterAttemptAtMs = 0;
|
|
753
|
+
const registerDaemon = async () => {
|
|
754
|
+
if (registerInFlight) {
|
|
755
|
+
return await registerInFlight;
|
|
756
|
+
}
|
|
757
|
+
registerInFlight = (async () => {
|
|
758
|
+
lastRegisterAttemptAtMs = Date.now();
|
|
759
|
+
const result = await post('/daemon/clock-client/register', {
|
|
760
|
+
daemonId,
|
|
761
|
+
tmuxSessionId,
|
|
762
|
+
sessionId: tmuxSessionId,
|
|
763
|
+
workdir,
|
|
764
|
+
clientType,
|
|
765
|
+
...(normalizedTmuxTarget ? { tmuxTarget: normalizedTmuxTarget } : {}),
|
|
766
|
+
managedTmuxSession,
|
|
767
|
+
callbackUrl,
|
|
768
|
+
...normalizeManagedProcessPayload()
|
|
769
|
+
});
|
|
770
|
+
return result.ok;
|
|
771
|
+
})();
|
|
772
|
+
try {
|
|
773
|
+
return await registerInFlight;
|
|
774
|
+
}
|
|
775
|
+
finally {
|
|
776
|
+
registerInFlight = null;
|
|
789
777
|
}
|
|
790
778
|
};
|
|
791
779
|
const syncHeartbeat = async () => {
|
|
792
|
-
|
|
780
|
+
const heartbeat = await post('/daemon/clock-client/heartbeat', {
|
|
793
781
|
daemonId,
|
|
794
782
|
tmuxSessionId,
|
|
795
783
|
sessionId: tmuxSessionId,
|
|
784
|
+
workdir,
|
|
796
785
|
managedTmuxSession,
|
|
797
786
|
...normalizeManagedProcessPayload()
|
|
798
787
|
});
|
|
788
|
+
if (heartbeat.ok) {
|
|
789
|
+
return true;
|
|
790
|
+
}
|
|
791
|
+
const shouldReRegister = heartbeat.status === 404
|
|
792
|
+
|| heartbeat.status === 410
|
|
793
|
+
|| heartbeat.status === 0
|
|
794
|
+
|| heartbeat.status >= 500;
|
|
795
|
+
if (!shouldReRegister) {
|
|
796
|
+
return false;
|
|
797
|
+
}
|
|
798
|
+
const allowImmediateReRegister = heartbeat.status === 404 || heartbeat.status === 410;
|
|
799
|
+
if (!allowImmediateReRegister && Date.now() - lastRegisterAttemptAtMs < reRegisterBackoffMs) {
|
|
800
|
+
return false;
|
|
801
|
+
}
|
|
802
|
+
return await registerDaemon();
|
|
799
803
|
};
|
|
800
|
-
const registered = await
|
|
801
|
-
daemonId,
|
|
802
|
-
tmuxSessionId,
|
|
803
|
-
sessionId: tmuxSessionId,
|
|
804
|
-
clientType,
|
|
805
|
-
...(normalizedTmuxTarget ? { tmuxTarget: normalizedTmuxTarget } : {}),
|
|
806
|
-
managedTmuxSession,
|
|
807
|
-
callbackUrl,
|
|
808
|
-
...normalizeManagedProcessPayload()
|
|
809
|
-
});
|
|
804
|
+
const registered = await registerDaemon();
|
|
810
805
|
if (!registered) {
|
|
811
806
|
if (server) {
|
|
812
807
|
try {
|
|
@@ -923,6 +918,7 @@ export function createLauncherCommand(program, ctx, spec) {
|
|
|
923
918
|
const baseUrl = `${resolved.protocol}://${resolved.connectHost}${resolved.portPart}${resolved.basePath}`;
|
|
924
919
|
const currentCwd = resolveWorkingDirectory(ctx, fsImpl, pathImpl, options.cwd);
|
|
925
920
|
const spawnSyncImpl = ctx.spawnSyncImpl ?? spawnSync;
|
|
921
|
+
const tmuxSelfHealPolicy = resolveTmuxSelfHealPolicy(ctx.env);
|
|
926
922
|
const toolArgs = spec.buildArgs(options);
|
|
927
923
|
const knownOptions = new Set([
|
|
928
924
|
'--port',
|
|
@@ -1016,6 +1012,7 @@ export function createLauncherCommand(program, ctx, spec) {
|
|
|
1016
1012
|
const clockClientService = await startClockClientService({
|
|
1017
1013
|
ctx,
|
|
1018
1014
|
resolved,
|
|
1015
|
+
workdir: currentCwd,
|
|
1019
1016
|
tmuxTarget,
|
|
1020
1017
|
spawnSyncImpl,
|
|
1021
1018
|
clientType: spec.commandName,
|
|
@@ -1071,9 +1068,10 @@ export function createLauncherCommand(program, ctx, spec) {
|
|
|
1071
1068
|
tmuxTarget: managedTmuxSession.tmuxTarget,
|
|
1072
1069
|
cwd: currentCwd,
|
|
1073
1070
|
command: resolvedBinary,
|
|
1071
|
+
commandName: spec.commandName,
|
|
1074
1072
|
commandArgs: toolArgs,
|
|
1075
1073
|
envOverrides,
|
|
1076
|
-
|
|
1074
|
+
selfHealPolicy: tmuxSelfHealPolicy
|
|
1077
1075
|
});
|
|
1078
1076
|
if (!launched) {
|
|
1079
1077
|
managedTmuxSession.stop();
|