@browserbasehq/orca 3.1.0-patch.4 → 3.2.0-middleware.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/lib/inference.js +1 -4
- package/dist/cjs/lib/inference.js.map +1 -1
- package/dist/cjs/lib/utils.d.ts +1 -0
- package/dist/cjs/lib/utils.js +4 -0
- package/dist/cjs/lib/utils.js.map +1 -1
- package/dist/cjs/lib/v3/agent/AgentClient.d.ts +8 -0
- package/dist/cjs/lib/v3/agent/AgentClient.js +13 -0
- package/dist/cjs/lib/v3/agent/AgentClient.js.map +1 -1
- package/dist/cjs/lib/v3/agent/AgentProvider.js +0 -1
- package/dist/cjs/lib/v3/agent/AgentProvider.js.map +1 -1
- package/dist/cjs/lib/v3/agent/AnthropicCUAClient.js +6 -7
- package/dist/cjs/lib/v3/agent/AnthropicCUAClient.js.map +1 -1
- package/dist/cjs/lib/v3/agent/GoogleCUAClient.js +6 -7
- package/dist/cjs/lib/v3/agent/GoogleCUAClient.js.map +1 -1
- package/dist/cjs/lib/v3/agent/MicrosoftCUAClient.js +1 -0
- package/dist/cjs/lib/v3/agent/MicrosoftCUAClient.js.map +1 -1
- package/dist/cjs/lib/v3/agent/OpenAICUAClient.d.ts +4 -4
- package/dist/cjs/lib/v3/agent/OpenAICUAClient.js +67 -8
- package/dist/cjs/lib/v3/agent/OpenAICUAClient.js.map +1 -1
- package/dist/cjs/lib/v3/agent/prompts/agentSystemPrompt.d.ts +4 -2
- package/dist/cjs/lib/v3/agent/prompts/agentSystemPrompt.js +7 -7
- package/dist/cjs/lib/v3/agent/prompts/agentSystemPrompt.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/act.d.ts +1 -1
- package/dist/cjs/lib/v3/agent/tools/act.js +11 -4
- package/dist/cjs/lib/v3/agent/tools/act.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/ariaTree.d.ts +8 -1
- package/dist/cjs/lib/v3/agent/tools/ariaTree.js +49 -22
- package/dist/cjs/lib/v3/agent/tools/ariaTree.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/{search.js → braveSearch.js} +1 -1
- package/dist/cjs/lib/v3/agent/tools/braveSearch.js.map +1 -0
- package/dist/cjs/lib/v3/agent/tools/browserbaseSearch.d.ts +13 -0
- package/dist/cjs/lib/v3/agent/tools/browserbaseSearch.js +70 -0
- package/dist/cjs/lib/v3/agent/tools/browserbaseSearch.js.map +1 -0
- package/dist/cjs/lib/v3/agent/tools/click.js +23 -31
- package/dist/cjs/lib/v3/agent/tools/click.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/clickAndHold.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/dragAndDrop.js +22 -30
- package/dist/cjs/lib/v3/agent/tools/dragAndDrop.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/extract.d.ts +2 -2
- package/dist/cjs/lib/v3/agent/tools/extract.js +7 -3
- package/dist/cjs/lib/v3/agent/tools/extract.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/fillFormVision.js +30 -30
- package/dist/cjs/lib/v3/agent/tools/fillFormVision.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/fillform.d.ts +7 -2
- package/dist/cjs/lib/v3/agent/tools/fillform.js +56 -45
- package/dist/cjs/lib/v3/agent/tools/fillform.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/index.d.ts +19 -3
- package/dist/cjs/lib/v3/agent/tools/index.js +63 -11
- package/dist/cjs/lib/v3/agent/tools/index.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/keys.d.ts +1 -1
- package/dist/cjs/lib/v3/agent/tools/keys.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/screenshot.d.ts +8 -0
- package/dist/cjs/lib/v3/agent/tools/screenshot.js +32 -15
- package/dist/cjs/lib/v3/agent/tools/screenshot.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/scroll.js +12 -0
- package/dist/cjs/lib/v3/agent/tools/scroll.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/type.js +23 -31
- package/dist/cjs/lib/v3/agent/tools/type.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/wait.js +6 -0
- package/dist/cjs/lib/v3/agent/tools/wait.js.map +1 -1
- package/dist/cjs/lib/v3/agent/utils/captchaSolver.d.ts +76 -0
- package/dist/cjs/lib/v3/agent/utils/captchaSolver.js +175 -0
- package/dist/cjs/lib/v3/agent/utils/captchaSolver.js.map +1 -0
- package/dist/cjs/lib/v3/agent/utils/handleDoneToolCall.js +4 -0
- package/dist/cjs/lib/v3/agent/utils/handleDoneToolCall.js.map +1 -1
- package/dist/cjs/lib/v3/api.d.ts +2 -2
- package/dist/cjs/lib/v3/api.js +1 -1
- package/dist/cjs/lib/v3/api.js.map +1 -1
- package/dist/cjs/lib/v3/cache/ActCache.d.ts +0 -1
- package/dist/cjs/lib/v3/cache/ActCache.js +2 -18
- package/dist/cjs/lib/v3/cache/ActCache.js.map +1 -1
- package/dist/cjs/lib/v3/flowlogger/EventEmitter.d.ts +7 -0
- package/dist/cjs/lib/v3/flowlogger/EventEmitter.js +30 -0
- package/dist/cjs/lib/v3/flowlogger/EventEmitter.js.map +1 -0
- package/dist/cjs/lib/v3/flowlogger/EventSink.d.ts +44 -0
- package/dist/cjs/lib/v3/flowlogger/EventSink.js +217 -0
- package/dist/cjs/lib/v3/flowlogger/EventSink.js.map +1 -0
- package/dist/cjs/lib/v3/flowlogger/EventStore.d.ts +26 -0
- package/dist/cjs/lib/v3/flowlogger/EventStore.js +135 -0
- package/dist/cjs/lib/v3/flowlogger/EventStore.js.map +1 -0
- package/dist/cjs/lib/v3/flowlogger/FlowLogger.d.ts +99 -0
- package/dist/cjs/lib/v3/flowlogger/FlowLogger.js +591 -0
- package/dist/cjs/lib/v3/flowlogger/FlowLogger.js.map +1 -0
- package/dist/cjs/lib/v3/flowlogger/prettify.d.ts +6 -0
- package/dist/cjs/lib/v3/flowlogger/prettify.js +395 -0
- package/dist/cjs/lib/v3/flowlogger/prettify.js.map +1 -0
- package/dist/cjs/lib/v3/handlers/actHandler.js +1 -2
- package/dist/cjs/lib/v3/handlers/actHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/extractHandler.js +2 -2
- package/dist/cjs/lib/v3/handlers/extractHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/handlerUtils/actHandlerUtils.js +43 -57
- package/dist/cjs/lib/v3/handlers/handlerUtils/actHandlerUtils.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/observeHandler.js +1 -2
- package/dist/cjs/lib/v3/handlers/observeHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/v3AgentHandler.d.ts +2 -5
- package/dist/cjs/lib/v3/handlers/v3AgentHandler.js +130 -91
- package/dist/cjs/lib/v3/handlers/v3AgentHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/v3CuaAgentHandler.d.ts +5 -0
- package/dist/cjs/lib/v3/handlers/v3CuaAgentHandler.js +134 -14
- package/dist/cjs/lib/v3/handlers/v3CuaAgentHandler.js.map +1 -1
- package/dist/cjs/lib/v3/index.d.ts +2 -1
- package/dist/cjs/lib/v3/launch/browserbase.d.ts +1 -1
- package/dist/cjs/lib/v3/launch/browserbase.js +4 -9
- package/dist/cjs/lib/v3/launch/browserbase.js.map +1 -1
- package/dist/cjs/lib/v3/llm/LLMProvider.d.ts +5 -2
- package/dist/cjs/lib/v3/llm/LLMProvider.js +13 -11
- package/dist/cjs/lib/v3/llm/LLMProvider.js.map +1 -1
- package/dist/cjs/lib/v3/llm/aisdk.js +11 -17
- package/dist/cjs/lib/v3/llm/aisdk.js.map +1 -1
- package/dist/cjs/lib/v3/runtimePaths.js +2 -1
- package/dist/cjs/lib/v3/runtimePaths.js.map +1 -1
- package/dist/cjs/lib/v3/shutdown/supervisor.js +2 -2
- package/dist/cjs/lib/v3/shutdown/supervisor.js.map +1 -1
- package/dist/cjs/lib/v3/timeoutConfig.d.ts +1 -1
- package/dist/cjs/lib/v3/timeoutConfig.js +5 -0
- package/dist/cjs/lib/v3/timeoutConfig.js.map +1 -1
- package/dist/cjs/lib/v3/types/private/cache.d.ts +0 -1
- package/dist/cjs/lib/v3/types/private/cache.js.map +1 -1
- package/dist/cjs/lib/v3/types/private/shutdown.d.ts +1 -1
- package/dist/cjs/lib/v3/types/private/shutdown.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/agent.d.ts +28 -3
- package/dist/cjs/lib/v3/types/public/agent.js +0 -1
- package/dist/cjs/lib/v3/types/public/agent.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/api.d.ts +7 -0
- package/dist/cjs/lib/v3/types/public/api.js +9 -0
- package/dist/cjs/lib/v3/types/public/api.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/model.d.ts +12 -3
- package/dist/cjs/lib/v3/types/public/model.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/options.d.ts +8 -0
- package/dist/cjs/lib/v3/types/public/options.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/cdp.d.ts +8 -13
- package/dist/cjs/lib/v3/understudy/cdp.js +180 -20
- package/dist/cjs/lib/v3/understudy/cdp.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/context.d.ts +1 -0
- package/dist/cjs/lib/v3/understudy/context.js +142 -60
- package/dist/cjs/lib/v3/understudy/context.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/frame.js +23 -6
- package/dist/cjs/lib/v3/understudy/frame.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/page.d.ts +13 -0
- package/dist/cjs/lib/v3/understudy/page.js +84 -21
- package/dist/cjs/lib/v3/understudy/page.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/screenshotUtils.d.ts +0 -1
- package/dist/cjs/lib/v3/understudy/screenshotUtils.js +0 -18
- package/dist/cjs/lib/v3/understudy/screenshotUtils.js.map +1 -1
- package/dist/cjs/lib/v3/v3.d.ts +26 -3
- package/dist/cjs/lib/v3/v3.js +242 -180
- package/dist/cjs/lib/v3/v3.js.map +1 -1
- package/dist/cjs/lib/version.d.ts +1 -1
- package/dist/cjs/lib/version.js +1 -1
- package/dist/cjs/lib/version.js.map +1 -1
- package/dist/cjs/tests/integration/agent-captcha-autosolve.spec.js +56 -0
- package/dist/cjs/tests/integration/agent-captcha-autosolve.spec.js.map +1 -0
- package/dist/cjs/tests/integration/agent-hybrid-mode.spec.js +6 -6
- package/dist/cjs/tests/integration/agent-hybrid-mode.spec.js.map +1 -1
- package/dist/cjs/tests/integration/cdp-session-detached.spec.js +1 -1
- package/dist/cjs/tests/integration/cdp-session-detached.spec.js.map +1 -1
- package/dist/cjs/tests/integration/context-addInitScript.spec.js +104 -11
- package/dist/cjs/tests/integration/context-addInitScript.spec.js.map +1 -1
- package/dist/cjs/tests/integration/flowLogger.spec.js +714 -0
- package/dist/cjs/tests/integration/flowLogger.spec.js.map +1 -0
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.d.ts +1 -0
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.js +219 -0
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.js.map +1 -0
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.d.ts +1 -0
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.js +85 -0
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.js.map +1 -0
- package/dist/cjs/tests/integration/page-screenshot.spec.js +1 -1
- package/dist/cjs/tests/integration/page-screenshot.spec.js.map +1 -1
- package/dist/cjs/tests/integration/testUtils.d.ts +33 -0
- package/dist/cjs/tests/integration/testUtils.js +144 -0
- package/dist/cjs/tests/integration/testUtils.js.map +1 -1
- package/dist/cjs/tests/integration/timeouts.spec.js +278 -0
- package/dist/cjs/tests/integration/timeouts.spec.js.map +1 -1
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.d.ts +1 -0
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.js +285 -0
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.js.map +1 -0
- package/dist/cjs/tests/unit/agent-execution-model.test.js +1 -1
- package/dist/cjs/tests/unit/agent-execution-model.test.js.map +1 -1
- package/dist/cjs/tests/unit/browserbase-session-accessors.test.js +20 -0
- package/dist/cjs/tests/unit/browserbase-session-accessors.test.js.map +1 -1
- package/dist/cjs/tests/unit/captcha-solver.test.d.ts +1 -0
- package/dist/cjs/tests/unit/captcha-solver.test.js +154 -0
- package/dist/cjs/tests/unit/captcha-solver.test.js.map +1 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.d.ts +1 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.js +95 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.js.map +1 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.d.ts +1 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.js +43 -0
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.js.map +1 -0
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.d.ts +1 -0
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.js +250 -0
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.js.map +1 -0
- package/dist/cjs/tests/unit/llm-middleware.test.d.ts +1 -0
- package/dist/cjs/tests/unit/llm-middleware.test.js +495 -0
- package/dist/cjs/tests/unit/llm-middleware.test.js.map +1 -0
- package/dist/cjs/tests/unit/model-deprecation.test.js +5 -8
- package/dist/cjs/tests/unit/model-deprecation.test.js.map +1 -1
- package/dist/cjs/tests/unit/openai-cua-client.test.d.ts +1 -0
- package/dist/cjs/tests/unit/openai-cua-client.test.js +71 -0
- package/dist/cjs/tests/unit/openai-cua-client.test.js.map +1 -0
- package/dist/cjs/tests/unit/page-extra-http-headers.test.d.ts +1 -0
- package/dist/cjs/tests/unit/page-extra-http-headers.test.js +92 -0
- package/dist/cjs/tests/unit/page-extra-http-headers.test.js.map +1 -0
- package/dist/cjs/tests/unit/public-api/llm-and-agents.test.js +13 -1
- package/dist/cjs/tests/unit/public-api/llm-and-agents.test.js.map +1 -1
- package/dist/cjs/tests/unit/public-api/public-types.test.js.map +1 -1
- package/dist/esm/lib/inference.js +1 -4
- package/dist/esm/lib/inference.js.map +1 -1
- package/dist/esm/lib/utils.d.ts +1 -0
- package/dist/esm/lib/utils.js +3 -0
- package/dist/esm/lib/utils.js.map +1 -1
- package/dist/esm/lib/v3/agent/AgentClient.d.ts +8 -0
- package/dist/esm/lib/v3/agent/AgentClient.js +13 -0
- package/dist/esm/lib/v3/agent/AgentClient.js.map +1 -1
- package/dist/esm/lib/v3/agent/AgentProvider.js +0 -1
- package/dist/esm/lib/v3/agent/AgentProvider.js.map +1 -1
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js +6 -7
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js.map +1 -1
- package/dist/esm/lib/v3/agent/GoogleCUAClient.js +6 -7
- package/dist/esm/lib/v3/agent/GoogleCUAClient.js.map +1 -1
- package/dist/esm/lib/v3/agent/MicrosoftCUAClient.js +1 -0
- package/dist/esm/lib/v3/agent/MicrosoftCUAClient.js.map +1 -1
- package/dist/esm/lib/v3/agent/OpenAICUAClient.d.ts +4 -4
- package/dist/esm/lib/v3/agent/OpenAICUAClient.js +67 -8
- package/dist/esm/lib/v3/agent/OpenAICUAClient.js.map +1 -1
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.d.ts +4 -2
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js +7 -7
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/act.d.ts +1 -1
- package/dist/esm/lib/v3/agent/tools/act.js +11 -4
- package/dist/esm/lib/v3/agent/tools/act.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/ariaTree.d.ts +8 -1
- package/dist/esm/lib/v3/agent/tools/ariaTree.js +49 -22
- package/dist/esm/lib/v3/agent/tools/ariaTree.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/{search.js → braveSearch.js} +1 -1
- package/dist/esm/lib/v3/agent/tools/braveSearch.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/browserbaseSearch.d.ts +13 -0
- package/dist/esm/lib/v3/agent/tools/browserbaseSearch.js +66 -0
- package/dist/esm/lib/v3/agent/tools/browserbaseSearch.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/click.js +23 -31
- package/dist/esm/lib/v3/agent/tools/click.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/clickAndHold.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/dragAndDrop.js +22 -30
- package/dist/esm/lib/v3/agent/tools/dragAndDrop.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/extract.d.ts +2 -2
- package/dist/esm/lib/v3/agent/tools/extract.js +7 -3
- package/dist/esm/lib/v3/agent/tools/extract.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/fillFormVision.js +30 -30
- package/dist/esm/lib/v3/agent/tools/fillFormVision.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/fillform.d.ts +7 -2
- package/dist/esm/lib/v3/agent/tools/fillform.js +56 -45
- package/dist/esm/lib/v3/agent/tools/fillform.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/index.d.ts +19 -3
- package/dist/esm/lib/v3/agent/tools/index.js +63 -11
- package/dist/esm/lib/v3/agent/tools/index.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/keys.d.ts +1 -1
- package/dist/esm/lib/v3/agent/tools/keys.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/screenshot.d.ts +8 -0
- package/dist/esm/lib/v3/agent/tools/screenshot.js +32 -15
- package/dist/esm/lib/v3/agent/tools/screenshot.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/scroll.js +12 -0
- package/dist/esm/lib/v3/agent/tools/scroll.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/type.js +23 -31
- package/dist/esm/lib/v3/agent/tools/type.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/wait.js +6 -0
- package/dist/esm/lib/v3/agent/tools/wait.js.map +1 -1
- package/dist/esm/lib/v3/agent/utils/captchaSolver.d.ts +76 -0
- package/dist/esm/lib/v3/agent/utils/captchaSolver.js +171 -0
- package/dist/esm/lib/v3/agent/utils/captchaSolver.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/handleDoneToolCall.js +4 -0
- package/dist/esm/lib/v3/agent/utils/handleDoneToolCall.js.map +1 -1
- package/dist/esm/lib/v3/api.d.ts +2 -2
- package/dist/esm/lib/v3/api.js +1 -1
- package/dist/esm/lib/v3/api.js.map +1 -1
- package/dist/esm/lib/v3/cache/ActCache.d.ts +0 -1
- package/dist/esm/lib/v3/cache/ActCache.js +2 -18
- package/dist/esm/lib/v3/cache/ActCache.js.map +1 -1
- package/dist/esm/lib/v3/flowlogger/EventEmitter.d.ts +7 -0
- package/dist/esm/lib/v3/flowlogger/EventEmitter.js +26 -0
- package/dist/esm/lib/v3/flowlogger/EventEmitter.js.map +1 -0
- package/dist/esm/lib/v3/flowlogger/EventSink.d.ts +44 -0
- package/dist/esm/lib/v3/flowlogger/EventSink.js +206 -0
- package/dist/esm/lib/v3/flowlogger/EventSink.js.map +1 -0
- package/dist/esm/lib/v3/flowlogger/EventStore.d.ts +26 -0
- package/dist/esm/lib/v3/flowlogger/EventStore.js +127 -0
- package/dist/esm/lib/v3/flowlogger/EventStore.js.map +1 -0
- package/dist/esm/lib/v3/flowlogger/FlowLogger.d.ts +99 -0
- package/dist/esm/lib/v3/flowlogger/FlowLogger.js +583 -0
- package/dist/esm/lib/v3/flowlogger/FlowLogger.js.map +1 -0
- package/dist/esm/lib/v3/flowlogger/prettify.d.ts +6 -0
- package/dist/esm/lib/v3/flowlogger/prettify.js +389 -0
- package/dist/esm/lib/v3/flowlogger/prettify.js.map +1 -0
- package/dist/esm/lib/v3/handlers/actHandler.js +1 -2
- package/dist/esm/lib/v3/handlers/actHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/extractHandler.js +2 -2
- package/dist/esm/lib/v3/handlers/extractHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/handlerUtils/actHandlerUtils.js +43 -57
- package/dist/esm/lib/v3/handlers/handlerUtils/actHandlerUtils.js.map +1 -1
- package/dist/esm/lib/v3/handlers/observeHandler.js +1 -2
- package/dist/esm/lib/v3/handlers/observeHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/v3AgentHandler.d.ts +2 -5
- package/dist/esm/lib/v3/handlers/v3AgentHandler.js +131 -92
- package/dist/esm/lib/v3/handlers/v3AgentHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.d.ts +5 -0
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js +134 -14
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js.map +1 -1
- package/dist/esm/lib/v3/index.d.ts +2 -1
- package/dist/esm/lib/v3/launch/browserbase.d.ts +1 -1
- package/dist/esm/lib/v3/launch/browserbase.js +4 -9
- package/dist/esm/lib/v3/launch/browserbase.js.map +1 -1
- package/dist/esm/lib/v3/llm/LLMProvider.d.ts +5 -2
- package/dist/esm/lib/v3/llm/LLMProvider.js +14 -12
- package/dist/esm/lib/v3/llm/LLMProvider.js.map +1 -1
- package/dist/esm/lib/v3/llm/aisdk.js +11 -17
- package/dist/esm/lib/v3/llm/aisdk.js.map +1 -1
- package/dist/esm/lib/v3/runtimePaths.js +2 -1
- package/dist/esm/lib/v3/runtimePaths.js.map +1 -1
- package/dist/esm/lib/v3/shutdown/supervisor.js +2 -2
- package/dist/esm/lib/v3/shutdown/supervisor.js.map +1 -1
- package/dist/esm/lib/v3/timeoutConfig.d.ts +1 -1
- package/dist/esm/lib/v3/timeoutConfig.js +5 -0
- package/dist/esm/lib/v3/timeoutConfig.js.map +1 -1
- package/dist/esm/lib/v3/types/private/cache.d.ts +0 -1
- package/dist/esm/lib/v3/types/private/cache.js.map +1 -1
- package/dist/esm/lib/v3/types/private/shutdown.d.ts +1 -1
- package/dist/esm/lib/v3/types/private/shutdown.js.map +1 -1
- package/dist/esm/lib/v3/types/public/agent.d.ts +28 -3
- package/dist/esm/lib/v3/types/public/agent.js +0 -1
- package/dist/esm/lib/v3/types/public/agent.js.map +1 -1
- package/dist/esm/lib/v3/types/public/api.d.ts +7 -0
- package/dist/esm/lib/v3/types/public/api.js +9 -0
- package/dist/esm/lib/v3/types/public/api.js.map +1 -1
- package/dist/esm/lib/v3/types/public/model.d.ts +12 -3
- package/dist/esm/lib/v3/types/public/model.js.map +1 -1
- package/dist/esm/lib/v3/types/public/options.d.ts +8 -0
- package/dist/esm/lib/v3/types/public/options.js.map +1 -1
- package/dist/esm/lib/v3/understudy/cdp.d.ts +8 -13
- package/dist/esm/lib/v3/understudy/cdp.js +181 -21
- package/dist/esm/lib/v3/understudy/cdp.js.map +1 -1
- package/dist/esm/lib/v3/understudy/context.d.ts +1 -0
- package/dist/esm/lib/v3/understudy/context.js +142 -60
- package/dist/esm/lib/v3/understudy/context.js.map +1 -1
- package/dist/esm/lib/v3/understudy/frame.js +23 -6
- package/dist/esm/lib/v3/understudy/frame.js.map +1 -1
- package/dist/esm/lib/v3/understudy/page.d.ts +13 -0
- package/dist/esm/lib/v3/understudy/page.js +86 -23
- package/dist/esm/lib/v3/understudy/page.js.map +1 -1
- package/dist/esm/lib/v3/understudy/screenshotUtils.d.ts +0 -1
- package/dist/esm/lib/v3/understudy/screenshotUtils.js +0 -17
- package/dist/esm/lib/v3/understudy/screenshotUtils.js.map +1 -1
- package/dist/esm/lib/v3/v3.d.ts +26 -3
- package/dist/esm/lib/v3/v3.js +242 -181
- package/dist/esm/lib/v3/v3.js.map +1 -1
- package/dist/esm/lib/version.d.ts +1 -1
- package/dist/esm/lib/version.js +1 -1
- package/dist/esm/lib/version.js.map +1 -1
- package/dist/esm/tests/integration/agent-captcha-autosolve.spec.d.ts +1 -0
- package/dist/esm/tests/integration/agent-captcha-autosolve.spec.js +54 -0
- package/dist/esm/tests/integration/agent-captcha-autosolve.spec.js.map +1 -0
- package/dist/esm/tests/integration/agent-hybrid-mode.spec.js +6 -6
- package/dist/esm/tests/integration/agent-hybrid-mode.spec.js.map +1 -1
- package/dist/esm/tests/integration/cdp-session-detached.spec.js +1 -1
- package/dist/esm/tests/integration/cdp-session-detached.spec.js.map +1 -1
- package/dist/esm/tests/integration/context-addInitScript.spec.js +104 -11
- package/dist/esm/tests/integration/context-addInitScript.spec.js.map +1 -1
- package/dist/esm/tests/integration/flowLogger.spec.d.ts +1 -0
- package/dist/esm/tests/integration/flowLogger.spec.js +712 -0
- package/dist/esm/tests/integration/flowLogger.spec.js.map +1 -0
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.d.ts +1 -0
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.js +217 -0
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.js.map +1 -0
- package/dist/esm/tests/integration/page-extra-http-headers.spec.d.ts +1 -0
- package/dist/esm/tests/integration/page-extra-http-headers.spec.js +83 -0
- package/dist/esm/tests/integration/page-extra-http-headers.spec.js.map +1 -0
- package/dist/esm/tests/integration/page-screenshot.spec.js +1 -1
- package/dist/esm/tests/integration/page-screenshot.spec.js.map +1 -1
- package/dist/esm/tests/integration/testUtils.d.ts +33 -0
- package/dist/esm/tests/integration/testUtils.js +138 -0
- package/dist/esm/tests/integration/testUtils.js.map +1 -1
- package/dist/esm/tests/integration/timeouts.spec.js +278 -0
- package/dist/esm/tests/integration/timeouts.spec.js.map +1 -1
- package/dist/esm/tests/unit/agent-captcha-hooks.test.d.ts +1 -0
- package/dist/esm/tests/unit/agent-captcha-hooks.test.js +283 -0
- package/dist/esm/tests/unit/agent-captcha-hooks.test.js.map +1 -0
- package/dist/esm/tests/unit/agent-execution-model.test.js +1 -1
- package/dist/esm/tests/unit/agent-execution-model.test.js.map +1 -1
- package/dist/esm/tests/unit/browserbase-session-accessors.test.js +20 -0
- package/dist/esm/tests/unit/browserbase-session-accessors.test.js.map +1 -1
- package/dist/esm/tests/unit/captcha-solver.test.d.ts +1 -0
- package/dist/esm/tests/unit/captcha-solver.test.js +152 -0
- package/dist/esm/tests/unit/captcha-solver.test.js.map +1 -0
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.d.ts +1 -0
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.js +93 -0
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.js.map +1 -0
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.d.ts +1 -0
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.js +41 -0
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.js.map +1 -0
- package/dist/esm/tests/unit/flowlogger-eventstore.test.d.ts +1 -0
- package/dist/esm/tests/unit/flowlogger-eventstore.test.js +248 -0
- package/dist/esm/tests/unit/flowlogger-eventstore.test.js.map +1 -0
- package/dist/esm/tests/unit/llm-middleware.test.d.ts +1 -0
- package/dist/esm/tests/unit/llm-middleware.test.js +460 -0
- package/dist/esm/tests/unit/llm-middleware.test.js.map +1 -0
- package/dist/esm/tests/unit/model-deprecation.test.js +5 -8
- package/dist/esm/tests/unit/model-deprecation.test.js.map +1 -1
- package/dist/esm/tests/unit/openai-cua-client.test.d.ts +1 -0
- package/dist/esm/tests/unit/openai-cua-client.test.js +69 -0
- package/dist/esm/tests/unit/openai-cua-client.test.js.map +1 -0
- package/dist/esm/tests/unit/page-extra-http-headers.test.d.ts +1 -0
- package/dist/esm/tests/unit/page-extra-http-headers.test.js +90 -0
- package/dist/esm/tests/unit/page-extra-http-headers.test.js.map +1 -0
- package/dist/esm/tests/unit/public-api/llm-and-agents.test.js +13 -1
- package/dist/esm/tests/unit/public-api/llm-and-agents.test.js.map +1 -1
- package/dist/esm/tests/unit/public-api/public-types.test.js.map +1 -1
- package/package.json +5 -3
- package/dist/cjs/lib/v3/agent/tools/search.js.map +0 -1
- package/dist/cjs/lib/v3/flowLogger.d.ts +0 -139
- package/dist/cjs/lib/v3/flowLogger.js +0 -881
- package/dist/cjs/lib/v3/flowLogger.js.map +0 -1
- package/dist/cjs/tests/unit/rerender-missing-shadows.test.js +0 -209
- package/dist/cjs/tests/unit/rerender-missing-shadows.test.js.map +0 -1
- package/dist/esm/lib/v3/agent/tools/search.js.map +0 -1
- package/dist/esm/lib/v3/flowLogger.d.ts +0 -139
- package/dist/esm/lib/v3/flowLogger.js +0 -868
- package/dist/esm/lib/v3/flowLogger.js.map +0 -1
- package/dist/esm/tests/unit/rerender-missing-shadows.test.js +0 -207
- package/dist/esm/tests/unit/rerender-missing-shadows.test.js.map +0 -1
- /package/dist/cjs/lib/v3/agent/tools/{search.d.ts → braveSearch.d.ts} +0 -0
- /package/dist/cjs/tests/{unit/rerender-missing-shadows.test.d.ts → integration/agent-captcha-autosolve.spec.d.ts} +0 -0
- /package/dist/{esm/tests/unit/rerender-missing-shadows.test.d.ts → cjs/tests/integration/flowLogger.spec.d.ts} +0 -0
- /package/dist/esm/lib/v3/agent/tools/{search.d.ts → braveSearch.d.ts} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"flowLogger.js","sourceRoot":"","sources":["../../../../lib/v3/flowLogger.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncLocalStorage } from \"node:async_hooks\";\nimport fs from \"node:fs\";\nimport { Writable } from \"node:stream\";\nimport { v7 as uuidv7 } from \"uuid\";\nimport path from \"node:path\";\nimport pino from \"pino\";\nimport type { LanguageModelMiddleware } from \"ai\";\nimport type { V3Options } from \"./types/public/index.js\";\n\n// =============================================================================\n// Constants\n// =============================================================================\n\nconst MAX_LINE_LENGTH = 160;\n\n// Flow logging config dir - empty string disables logging entirely\nconst CONFIG_DIR = process.env.BROWSERBASE_CONFIG_DIR || \"\";\n\nconst NOISY_CDP_EVENTS = new Set([\n \"Target.targetInfoChanged\",\n \"Runtime.executionContextCreated\",\n \"Runtime.executionContextDestroyed\",\n \"Runtime.executionContextsCleared\",\n \"Page.lifecycleEvent\",\n \"Network.dataReceived\",\n \"Network.loadingFinished\",\n \"Network.requestWillBeSentExtraInfo\",\n \"Network.responseReceivedExtraInfo\",\n \"Network.requestWillBeSent\",\n \"Network.responseReceived\",\n]);\n\n// =============================================================================\n// Types\n// =============================================================================\n\ntype EventCategory =\n | \"AgentTask\"\n | \"StagehandStep\"\n | \"UnderstudyAction\"\n | \"CDP\"\n | \"LLM\";\n\ninterface FlowEvent {\n // Core identifiers (set via mixin from child logger bindings)\n eventId: string;\n sessionId: string;\n taskId?: string | null;\n stepId?: string | null;\n stepLabel?: string | null;\n actionId?: string | null;\n actionLabel?: string | null;\n\n // Event classification\n category: EventCategory;\n event: \"started\" | \"completed\" | \"call\" | \"message\" | \"request\" | \"response\";\n method?: string;\n msg?: string;\n\n // Event-specific payload (not truncated)\n params?: unknown;\n targetId?: string | null;\n\n // LLM event fields (for individual LLM request/response events only)\n requestId?: string; // Correlation ID linking LLM request to response\n model?: string;\n prompt?: unknown;\n output?: unknown;\n inputTokens?: number; // Tokens for THIS specific LLM call\n outputTokens?: number; // Tokens for THIS specific LLM call\n\n // Aggregate metrics (for completion events only - task/step/action)\n metrics?: {\n durationMs?: number;\n llmRequests?: number; // Total LLM calls in this span\n inputTokens?: number; // Total input tokens across all LLM calls\n outputTokens?: number; // Total output tokens across all LLM calls\n cdpEvents?: number; // Total CDP events in this span\n };\n}\n\ninterface FlowLoggerMetrics {\n taskStartTime?: number;\n stepStartTime?: number;\n actionStartTime?: number;\n llmRequests: number;\n llmInputTokens: number;\n llmOutputTokens: number;\n cdpEvents: number;\n}\n\nexport interface FlowLoggerContext {\n logger: pino.Logger;\n metrics: FlowLoggerMetrics;\n sessionId: string;\n sessionDir: string;\n configDir: string;\n initPromise: Promise<void>;\n initialized: boolean;\n // Current span context (mutable, injected via mixin)\n taskId: string | null;\n stepId: string | null;\n stepLabel: string | null;\n actionId: string | null;\n actionLabel: string | null;\n // File handles for pretty streams\n fileStreams: {\n agent: fs.WriteStream | null;\n stagehand: fs.WriteStream | null;\n understudy: fs.WriteStream | null;\n cdp: fs.WriteStream | null;\n llm: fs.WriteStream | null;\n jsonl: fs.WriteStream | null;\n };\n}\n\nconst loggerContext = new AsyncLocalStorage<FlowLoggerContext>();\n\n// =============================================================================\n// Formatting Utilities (used by pretty streams)\n// =============================================================================\n\n/** Calculate base64 data size in KB */\nconst dataToKb = (data: string): string =>\n ((data.length * 0.75) / 1024).toFixed(1);\n\n/** Truncate CDP IDs: frameId:363F03EB...EF8 → frameId:363F…5EF8 */\nfunction truncateCdpIds(value: string): string {\n return value.replace(\n /([iI]d:?\"?)([0-9A-F]{32})(?=\"?[,})\\s]|$)/g,\n (_, pre: string, id: string) => `${pre}${id.slice(0, 4)}…${id.slice(-4)}`,\n );\n}\n\n/** Truncate line showing start...end */\nfunction truncateLine(value: string, maxLen: number): string {\n const collapsed = value.replace(/\\s+/g, \" \");\n if (collapsed.length <= maxLen) return collapsed;\n const endLen = Math.floor(maxLen * 0.3);\n const startLen = maxLen - endLen - 1;\n return `${collapsed.slice(0, startLen)}…${collapsed.slice(-endLen)}`;\n}\n\nfunction formatValue(value: unknown): string {\n if (typeof value === \"string\") return `'${value}'`;\n if (value == null || typeof value !== \"object\") return String(value);\n try {\n return JSON.stringify(value);\n } catch {\n return \"[unserializable]\";\n }\n}\n\nfunction formatArgs(args?: unknown | unknown[]): string {\n if (args === undefined) return \"\";\n return (Array.isArray(args) ? args : [args])\n .filter((e) => e !== undefined)\n .map(formatValue)\n .filter((e) => e.length > 0)\n .join(\", \");\n}\n\nconst shortId = (id: string | null | undefined): string =>\n id ? id.slice(-4) : \"-\";\n\nfunction formatTag(\n label: string | null | undefined,\n id: string | null | undefined,\n icon: string,\n): string {\n return id ? `[${icon} #${shortId(id)}${label ? \" \" + label : \"\"}]` : \"⤑\";\n}\n\nlet nonce = 0;\nfunction formatTimestamp(): string {\n const d = new Date();\n const pad = (n: number, w = 2) => String(n).padStart(w, \"0\");\n return `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())} ${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}.${pad(d.getMilliseconds(), 3)}${pad(nonce++ % 100)}`;\n}\n\nconst SENSITIVE_KEYS =\n /apikey|api_key|key|secret|token|password|passwd|pwd|credential|auth/i;\n\nfunction sanitizeOptions(options: V3Options): Record<string, unknown> {\n const sanitize = (obj: unknown): unknown => {\n if (typeof obj !== \"object\" || obj === null) return obj;\n if (Array.isArray(obj)) return obj.map(sanitize);\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n result[key] = SENSITIVE_KEYS.test(key) ? \"******\" : sanitize(value);\n }\n return result;\n };\n return sanitize({ ...options }) as Record<string, unknown>;\n}\n\n/** Remove unescaped quotes for cleaner log output */\nfunction removeQuotes(str: string): string {\n return str\n .replace(/([^\\\\])[\"']/g, \"$1\")\n .replace(/^[\"']|[\"']$/g, \"\")\n .trim();\n}\n\n// =============================================================================\n// Pretty Formatting (converts FlowEvent to human-readable log line)\n// =============================================================================\n\nfunction prettifyEvent(event: FlowEvent): string | null {\n const parts: string[] = [];\n\n // Build context tags - always add parent span tags (formatTag returns ⤑ for null IDs)\n if (event.category === \"AgentTask\") {\n parts.push(formatTag(\"\", event.taskId, \"🅰\"));\n } else if (event.category === \"StagehandStep\") {\n parts.push(formatTag(\"\", event.taskId, \"🅰\"));\n parts.push(formatTag(event.stepLabel, event.stepId, \"🆂\"));\n } else if (event.category === \"UnderstudyAction\") {\n parts.push(formatTag(\"\", event.taskId, \"🅰\"));\n parts.push(formatTag(event.stepLabel, event.stepId, \"🆂\"));\n parts.push(formatTag(event.actionLabel, event.actionId, \"🆄\"));\n } else if (event.category === \"CDP\") {\n parts.push(formatTag(\"\", event.taskId, \"🅰\"));\n parts.push(formatTag(event.stepLabel, event.stepId, \"🆂\"));\n parts.push(formatTag(event.actionLabel, event.actionId, \"🆄\"));\n parts.push(formatTag(\"CDP\", event.targetId, \"🅲\"));\n } else if (event.category === \"LLM\") {\n parts.push(formatTag(\"\", event.taskId, \"🅰\"));\n parts.push(formatTag(event.stepLabel, event.stepId, \"🆂\"));\n parts.push(formatTag(\"LLM\", event.requestId, \"🧠\"));\n }\n\n // Build details based on event type\n let details = \"\";\n const argsStr = event.params ? formatArgs(event.params) : \"\";\n\n if (event.category === \"AgentTask\") {\n if (event.event === \"started\") {\n details = `▷ ${event.method}(${argsStr})`;\n } else if (event.event === \"completed\") {\n const m = event.metrics;\n const durationSec = m?.durationMs\n ? (m.durationMs / 1000).toFixed(1)\n : \"?\";\n const llmStats = `${m?.llmRequests ?? 0} LLM calls ꜛ${m?.inputTokens ?? 0} ꜜ${m?.outputTokens ?? 0} tokens`;\n const cdpStats = `${m?.cdpEvents ?? 0} CDP msgs`;\n details = `✓ Agent.execute() DONE in ${durationSec}s | ${llmStats} | ${cdpStats}`;\n }\n } else if (event.category === \"StagehandStep\") {\n if (event.event === \"started\") {\n details = `▷ ${event.method}(${argsStr})`;\n } else if (event.event === \"completed\") {\n const durationSec = event.metrics?.durationMs\n ? (event.metrics.durationMs / 1000).toFixed(2)\n : \"?\";\n details = `✓ ${event.stepLabel || \"STEP\"} completed in ${durationSec}s`;\n }\n } else if (event.category === \"UnderstudyAction\") {\n if (event.event === \"started\") {\n details = `▷ ${event.method}(${argsStr})`;\n } else if (event.event === \"completed\") {\n const durationSec = event.metrics?.durationMs\n ? (event.metrics.durationMs / 1000).toFixed(2)\n : \"?\";\n details = `✓ ${event.actionLabel || \"ACTION\"} completed in ${durationSec}s`;\n }\n } else if (event.category === \"CDP\") {\n const icon = event.event === \"call\" ? \"⏵\" : \"⏴\";\n details = `${icon} ${event.method}(${argsStr})`;\n } else if (event.category === \"LLM\") {\n if (event.event === \"request\") {\n const promptStr = event.prompt ? \" \" + String(event.prompt) : \"\";\n details = `${event.model} ⏴${promptStr}`;\n } else if (event.event === \"response\") {\n const hasTokens =\n event.inputTokens !== undefined || event.outputTokens !== undefined;\n const tokenStr = hasTokens\n ? ` ꜛ${event.inputTokens ?? 0} ꜜ${event.outputTokens ?? 0} |`\n : \"\";\n const outputStr = event.output ? \" \" + String(event.output) : \"\";\n details = `${event.model} ↳${tokenStr}${outputStr}`;\n }\n }\n\n if (!details) return null;\n\n // Assemble line and apply final truncation\n const fullLine = `${formatTimestamp()} ${parts.join(\" \")} ${details}`;\n const cleaned = removeQuotes(fullLine);\n const processed =\n event.category === \"CDP\" ? truncateCdpIds(cleaned) : cleaned;\n return truncateLine(processed, MAX_LINE_LENGTH);\n}\n\n/** Check if a CDP event should be filtered from pretty output */\nfunction shouldFilterCdpEvent(event: FlowEvent): boolean {\n if (event.category !== \"CDP\") return false;\n if (event.method?.endsWith(\".enable\") || event.method === \"enable\")\n return true;\n return event.event === \"message\" && NOISY_CDP_EVENTS.has(event.method!);\n}\n\n// =============================================================================\n// Stream Creation\n// =============================================================================\n\nconst isWritable = (s: fs.WriteStream | null): s is fs.WriteStream =>\n !!(s && !s.destroyed && s.writable);\n\nfunction createJsonlStream(ctx: FlowLoggerContext): Writable {\n return new Writable({\n objectMode: true,\n write(chunk: string, _, cb) {\n if (ctx.initialized && isWritable(ctx.fileStreams.jsonl)) {\n ctx.fileStreams.jsonl.write(chunk, cb);\n } else cb();\n },\n });\n}\n\nfunction createPrettyStream(\n ctx: FlowLoggerContext,\n category: EventCategory,\n streamKey: keyof FlowLoggerContext[\"fileStreams\"],\n): Writable {\n return new Writable({\n objectMode: true,\n write(chunk: string, _, cb) {\n const stream = ctx.fileStreams[streamKey];\n if (!ctx.initialized || !isWritable(stream)) return cb();\n try {\n const event = JSON.parse(chunk) as FlowEvent;\n if (event.category !== category || shouldFilterCdpEvent(event))\n return cb();\n const line = prettifyEvent(event);\n if (line) stream.write(line + \"\\n\", cb);\n else cb();\n } catch {\n cb();\n }\n },\n });\n}\n\n// =============================================================================\n// Public Helpers (used by external callers)\n// =============================================================================\n\n/**\n * Get the config directory. Returns empty string if logging is disabled.\n */\nexport function getConfigDir(): string {\n return CONFIG_DIR ? path.resolve(CONFIG_DIR) : \"\";\n}\n\n// =============================================================================\n// Prompt Preview Helpers\n// =============================================================================\n\ntype ContentPart = {\n type?: string;\n text?: string;\n content?: unknown[];\n source?: { data?: string };\n image_url?: { url?: string };\n inlineData?: { data?: string };\n};\n\n/** Extract text and image info from a content array (handles nested tool_result) */\nfunction extractFromContent(\n content: unknown[],\n result: { text?: string; extras: string[] },\n): void {\n for (const part of content) {\n const p = part as ContentPart;\n // Text\n if (!result.text && p.text) {\n result.text = p.type === \"text\" || !p.type ? p.text : undefined;\n }\n // Images - various formats\n if (p.type === \"image\" || p.type === \"image_url\") {\n const url = p.image_url?.url;\n if (url?.startsWith(\"data:\"))\n result.extras.push(`${dataToKb(url)}kb image`);\n else if (p.source?.data)\n result.extras.push(`${dataToKb(p.source.data)}kb image`);\n else result.extras.push(\"image\");\n } else if (p.source?.data) {\n result.extras.push(`${dataToKb(p.source.data)}kb image`);\n } else if (p.inlineData?.data) {\n result.extras.push(`${dataToKb(p.inlineData.data)}kb image`);\n }\n // Recurse into tool_result content\n if (p.type === \"tool_result\" && Array.isArray(p.content)) {\n extractFromContent(p.content, result);\n }\n }\n}\n\n/** Build final preview string with extras */\nfunction buildPreview(\n text: string | undefined,\n extras: string[],\n maxLen?: number,\n): string | undefined {\n if (!text && extras.length === 0) return undefined;\n let result = text || \"\";\n if (maxLen && result.length > maxLen)\n result = result.slice(0, maxLen) + \"...\";\n if (extras.length > 0) {\n const extrasStr = extras.map((e) => `+{${e}}`).join(\" \");\n result = result ? `${result} ${extrasStr}` : extrasStr;\n }\n return result || undefined;\n}\n\n/**\n * Format a prompt preview from LLM messages for logging.\n * Returns format like: \"some text... +{5.8kb image} +{schema} +{12 tools}\"\n */\nexport function formatLlmPromptPreview(\n messages: Array<{ role: string; content: unknown }>,\n options?: { toolCount?: number; hasSchema?: boolean },\n): string | undefined {\n try {\n const lastUserMsg = messages.filter((m) => m.role === \"user\").pop();\n if (!lastUserMsg) return undefined;\n\n const result = {\n text: undefined as string | undefined,\n extras: [] as string[],\n };\n\n if (typeof lastUserMsg.content === \"string\") {\n result.text = lastUserMsg.content;\n } else if (Array.isArray(lastUserMsg.content)) {\n extractFromContent(lastUserMsg.content, result);\n } else {\n return undefined;\n }\n\n // Clean instruction prefix\n if (result.text) {\n result.text = result.text.replace(/^[Ii]nstruction: /, \"\");\n }\n\n if (options?.hasSchema) result.extras.push(\"schema\");\n if (options?.toolCount) result.extras.push(`${options.toolCount} tools`);\n\n return buildPreview(result.text, result.extras);\n } catch {\n return undefined;\n }\n}\n\n/**\n * Extract a text preview from CUA-style messages.\n * Accepts various message formats (Anthropic, OpenAI, Google).\n */\nexport function formatCuaPromptPreview(\n messages: unknown[],\n maxLen = 100,\n): string | undefined {\n try {\n const lastMsg = messages\n .filter((m) => {\n const msg = m as { role?: string; type?: string };\n return msg.role === \"user\" || msg.type === \"tool_result\";\n })\n .pop() as\n | { content?: unknown; parts?: unknown[]; text?: string }\n | undefined;\n\n if (!lastMsg) return undefined;\n\n const result = {\n text: undefined as string | undefined,\n extras: [] as string[],\n };\n\n if (typeof lastMsg.content === \"string\") {\n result.text = lastMsg.content;\n } else if (typeof lastMsg.text === \"string\") {\n result.text = lastMsg.text;\n } else if (Array.isArray(lastMsg.parts)) {\n extractFromContent(lastMsg.parts, result);\n } else if (Array.isArray(lastMsg.content)) {\n extractFromContent(lastMsg.content, result);\n }\n\n return buildPreview(result.text, result.extras, maxLen);\n } catch {\n return undefined;\n }\n}\n\n/** Format CUA response output for logging */\nexport function formatCuaResponsePreview(\n output: unknown,\n maxLen = 100,\n): string {\n try {\n // Handle Google format or array\n const items: unknown[] =\n (output as { candidates?: [{ content?: { parts?: unknown[] } }] })\n ?.candidates?.[0]?.content?.parts ??\n (Array.isArray(output) ? output : []);\n\n const preview = items\n .map((item) => {\n const i = item as {\n type?: string;\n text?: string;\n name?: string;\n functionCall?: { name?: string };\n };\n if (i.text) return i.text.slice(0, 50);\n if (i.functionCall?.name) return `fn:${i.functionCall.name}`;\n if (i.type === \"tool_use\" && i.name) return `tool_use:${i.name}`;\n return i.type ? `[${i.type}]` : \"[item]\";\n })\n .join(\" \");\n\n return preview.slice(0, maxLen);\n } catch {\n return \"[error]\";\n }\n}\n\n// =============================================================================\n// SessionFileLogger - Main API\n// =============================================================================\n\nexport class SessionFileLogger {\n /**\n * Initialize a new logging context. Call this at the start of a session.\n * If BROWSERBASE_CONFIG_DIR is not set, logging is disabled.\n */\n static init(sessionId: string, v3Options?: V3Options): void {\n const configDir = getConfigDir();\n if (!configDir) return; // Logging disabled\n\n const sessionDir = path.join(configDir, \"sessions\", sessionId);\n\n // Create context with placeholder logger (will be replaced after streams init)\n const ctx: FlowLoggerContext = {\n logger: pino({ level: \"silent\" }), // Placeholder, replaced below\n metrics: {\n llmRequests: 0,\n llmInputTokens: 0,\n llmOutputTokens: 0,\n cdpEvents: 0,\n },\n sessionId,\n sessionDir,\n configDir,\n initPromise: Promise.resolve(),\n initialized: false,\n // Span context - mutable, injected into every log via mixin\n taskId: null,\n stepId: null,\n stepLabel: null,\n actionId: null,\n actionLabel: null,\n fileStreams: {\n agent: null,\n stagehand: null,\n understudy: null,\n cdp: null,\n llm: null,\n jsonl: null,\n },\n };\n\n // Store init promise for awaiting in log methods\n ctx.initPromise = SessionFileLogger.initAsync(ctx, v3Options);\n\n loggerContext.enterWith(ctx);\n }\n\n private static async initAsync(\n ctx: FlowLoggerContext,\n v3Options?: V3Options,\n ): Promise<void> {\n try {\n await fs.promises.mkdir(ctx.sessionDir, { recursive: true });\n\n if (v3Options) {\n const sanitizedOptions = sanitizeOptions(v3Options);\n const sessionJsonPath = path.join(ctx.sessionDir, \"session.json\");\n await fs.promises.writeFile(\n sessionJsonPath,\n JSON.stringify(sanitizedOptions, null, 2),\n \"utf-8\",\n );\n }\n\n // Create symlink to latest session\n const latestLink = path.join(ctx.configDir, \"sessions\", \"latest\");\n try {\n try {\n await fs.promises.unlink(latestLink);\n } catch {\n // Ignore if doesn't exist\n }\n await fs.promises.symlink(ctx.sessionId, latestLink, \"dir\");\n } catch {\n // Symlink creation can fail on Windows or due to permissions\n }\n\n // Create file streams\n const dir = ctx.sessionDir;\n ctx.fileStreams.agent = fs.createWriteStream(\n path.join(dir, \"agent_events.log\"),\n { flags: \"a\" },\n );\n ctx.fileStreams.stagehand = fs.createWriteStream(\n path.join(dir, \"stagehand_events.log\"),\n { flags: \"a\" },\n );\n ctx.fileStreams.understudy = fs.createWriteStream(\n path.join(dir, \"understudy_events.log\"),\n { flags: \"a\" },\n );\n ctx.fileStreams.cdp = fs.createWriteStream(\n path.join(dir, \"cdp_events.log\"),\n { flags: \"a\" },\n );\n ctx.fileStreams.llm = fs.createWriteStream(\n path.join(dir, \"llm_events.log\"),\n { flags: \"a\" },\n );\n ctx.fileStreams.jsonl = fs.createWriteStream(\n path.join(dir, \"session_events.jsonl\"),\n { flags: \"a\" },\n );\n\n ctx.initialized = true;\n\n // Create pino multistream: JSONL + pretty streams per category\n const streams: pino.StreamEntry[] = [\n { stream: createJsonlStream(ctx) },\n { stream: createPrettyStream(ctx, \"AgentTask\", \"agent\") },\n { stream: createPrettyStream(ctx, \"StagehandStep\", \"stagehand\") },\n { stream: createPrettyStream(ctx, \"UnderstudyAction\", \"understudy\") },\n { stream: createPrettyStream(ctx, \"CDP\", \"cdp\") },\n { stream: createPrettyStream(ctx, \"LLM\", \"llm\") },\n ];\n\n // Create logger with mixin that injects span context from AsyncLocalStorage\n ctx.logger = pino(\n {\n level: \"info\",\n // Mixin adds eventId and current span context to every log\n mixin() {\n const store = loggerContext.getStore();\n return {\n eventId: uuidv7(),\n sessionId: store?.sessionId,\n taskId: store?.taskId,\n stepId: store?.stepId,\n stepLabel: store?.stepLabel,\n actionId: store?.actionId,\n actionLabel: store?.actionLabel,\n };\n },\n },\n pino.multistream(streams),\n );\n } catch {\n // Fail silently\n }\n }\n\n static async close(): Promise<void> {\n const ctx = loggerContext.getStore();\n if (!ctx) return;\n await ctx.initPromise;\n SessionFileLogger.logAgentTaskCompleted();\n await Promise.all(\n Object.values(ctx.fileStreams)\n .filter(Boolean)\n .map((s) => new Promise<void>((r) => s!.end(r))),\n ).catch(() => {});\n }\n\n static get sessionId(): string | null {\n return loggerContext.getStore()?.sessionId ?? null;\n }\n\n static get sessionDir(): string | null {\n return loggerContext.getStore()?.sessionDir ?? null;\n }\n\n /**\n * Get the current logger context object.\n */\n static getContext(): FlowLoggerContext | null {\n return loggerContext.getStore() ?? null;\n }\n\n // ===========================================================================\n // Agent Task Events\n // ===========================================================================\n\n /**\n * Start a new task and log it.\n */\n static logAgentTaskStarted({\n invocation,\n args,\n }: {\n invocation: string;\n args?: unknown | unknown[];\n }): void {\n const ctx = loggerContext.getStore();\n if (!ctx) return;\n\n // Set up task context\n ctx.taskId = uuidv7();\n ctx.stepId = null;\n ctx.stepLabel = null;\n ctx.actionId = null;\n ctx.actionLabel = null;\n\n // Reset metrics for new task\n ctx.metrics = {\n taskStartTime: Date.now(),\n llmRequests: 0,\n llmInputTokens: 0,\n llmOutputTokens: 0,\n cdpEvents: 0,\n };\n\n ctx.logger.info({\n category: \"AgentTask\",\n event: \"started\",\n method: invocation,\n params: args,\n } as FlowEvent);\n }\n\n /**\n * Log task completion with metrics summary.\n */\n static logAgentTaskCompleted(options?: { cacheHit?: boolean }): void {\n const ctx = loggerContext.getStore();\n if (!ctx || !ctx.metrics.taskStartTime) return;\n\n const durationMs = Date.now() - ctx.metrics.taskStartTime;\n\n const event: Partial<FlowEvent> = {\n category: \"AgentTask\",\n event: \"completed\",\n method: \"Agent.execute\",\n metrics: {\n durationMs,\n llmRequests: ctx.metrics.llmRequests,\n inputTokens: ctx.metrics.llmInputTokens,\n outputTokens: ctx.metrics.llmOutputTokens,\n cdpEvents: ctx.metrics.cdpEvents,\n },\n };\n\n if (options?.cacheHit) {\n event.msg = \"CACHE HIT, NO LLM NEEDED\";\n }\n\n ctx.logger.info(event);\n\n // Clear task context\n ctx.taskId = null;\n ctx.stepId = null;\n ctx.stepLabel = null;\n ctx.actionId = null;\n ctx.actionLabel = null;\n ctx.metrics.taskStartTime = undefined;\n }\n\n // ===========================================================================\n // Stagehand Step Events\n // ===========================================================================\n\n static logStagehandStepEvent({\n invocation,\n args,\n label,\n }: {\n invocation: string;\n args?: unknown | unknown[];\n label: string;\n }): string {\n const ctx = loggerContext.getStore();\n if (!ctx) return uuidv7();\n\n // Set up step context\n ctx.stepId = uuidv7();\n ctx.stepLabel = label.toUpperCase();\n ctx.actionId = null;\n ctx.actionLabel = null;\n ctx.metrics.stepStartTime = Date.now();\n\n ctx.logger.info({\n category: \"StagehandStep\",\n event: \"started\",\n method: invocation,\n params: args,\n } as FlowEvent);\n\n return ctx.stepId;\n }\n\n static logStagehandStepCompleted(): void {\n const ctx = loggerContext.getStore();\n if (!ctx || !ctx.stepId) return;\n\n const durationMs = ctx.metrics.stepStartTime\n ? Date.now() - ctx.metrics.stepStartTime\n : 0;\n\n ctx.logger.info({\n category: \"StagehandStep\",\n event: \"completed\",\n metrics: { durationMs },\n } as FlowEvent);\n\n // Clear step context\n ctx.stepId = null;\n ctx.stepLabel = null;\n ctx.actionId = null;\n ctx.actionLabel = null;\n ctx.metrics.stepStartTime = undefined;\n }\n\n // ===========================================================================\n // Understudy Action Events\n // ===========================================================================\n\n static logUnderstudyActionEvent({\n actionType,\n target,\n args,\n }: {\n actionType: string;\n target?: string;\n args?: unknown | unknown[];\n }): string {\n const ctx = loggerContext.getStore();\n if (!ctx) return uuidv7();\n\n // Set up action context\n ctx.actionId = uuidv7();\n ctx.actionLabel = actionType\n .toUpperCase()\n .replace(\"UNDERSTUDY.\", \"\")\n .replace(\"PAGE.\", \"\");\n ctx.metrics.actionStartTime = Date.now();\n\n const params: Record<string, unknown> = {};\n if (target) params.target = target;\n if (args) params.args = args;\n\n ctx.logger.info({\n category: \"UnderstudyAction\",\n event: \"started\",\n method: actionType,\n params: Object.keys(params).length > 0 ? params : undefined,\n } as FlowEvent);\n\n return ctx.actionId;\n }\n\n static logUnderstudyActionCompleted(): void {\n const ctx = loggerContext.getStore();\n if (!ctx || !ctx.actionId) return;\n\n const durationMs = ctx.metrics.actionStartTime\n ? Date.now() - ctx.metrics.actionStartTime\n : 0;\n\n ctx.logger.info({\n category: \"UnderstudyAction\",\n event: \"completed\",\n metrics: { durationMs },\n } as FlowEvent);\n\n // Clear action context\n ctx.actionId = null;\n ctx.actionLabel = null;\n ctx.metrics.actionStartTime = undefined;\n }\n\n // ===========================================================================\n // CDP Events\n // ===========================================================================\n\n private static logCdpEvent(\n eventType: \"call\" | \"message\",\n {\n method,\n params,\n targetId,\n }: { method: string; params?: unknown; targetId?: string | null },\n explicitCtx?: FlowLoggerContext | null,\n ): void {\n const ctx = explicitCtx ?? loggerContext.getStore();\n if (!ctx) return;\n if (eventType === \"call\") ctx.metrics.cdpEvents++;\n ctx.logger.info({\n category: \"CDP\",\n event: eventType,\n method,\n params,\n targetId,\n } as FlowEvent);\n }\n\n static logCdpCallEvent(\n data: { method: string; params?: object; targetId?: string | null },\n ctx?: FlowLoggerContext | null,\n ): void {\n SessionFileLogger.logCdpEvent(\"call\", data, ctx);\n }\n\n static logCdpMessageEvent(\n data: { method: string; params?: unknown; targetId?: string | null },\n ctx?: FlowLoggerContext | null,\n ): void {\n SessionFileLogger.logCdpEvent(\"message\", data, ctx);\n }\n\n // ===========================================================================\n // LLM Events\n // ===========================================================================\n\n static logLlmRequest(\n {\n requestId,\n model,\n prompt,\n }: {\n requestId: string;\n model: string;\n operation: string;\n prompt?: string;\n },\n explicitCtx?: FlowLoggerContext | null,\n ): void {\n const ctx = explicitCtx ?? loggerContext.getStore();\n if (!ctx) return;\n\n // Track LLM requests for task metrics\n ctx.metrics.llmRequests++;\n\n ctx.logger.info({\n category: \"LLM\",\n event: \"request\",\n requestId,\n method: \"LLM.request\",\n model,\n prompt,\n });\n }\n\n static logLlmResponse(\n {\n requestId,\n model,\n output,\n inputTokens,\n outputTokens,\n }: {\n requestId: string;\n model: string;\n operation: string;\n output?: string;\n inputTokens?: number;\n outputTokens?: number;\n },\n explicitCtx?: FlowLoggerContext | null,\n ): void {\n const ctx = explicitCtx ?? loggerContext.getStore();\n if (!ctx) return;\n\n // Track tokens for task metrics\n ctx.metrics.llmInputTokens += inputTokens ?? 0;\n ctx.metrics.llmOutputTokens += outputTokens ?? 0;\n\n ctx.logger.info({\n category: \"LLM\",\n event: \"response\",\n requestId,\n method: \"LLM.response\",\n model,\n output,\n inputTokens,\n outputTokens,\n });\n }\n\n // ===========================================================================\n // LLM Logging Middleware\n // ===========================================================================\n\n /**\n * Create middleware for wrapping language models with LLM call logging.\n * Returns a no-op middleware when logging is disabled.\n */\n static createLlmLoggingMiddleware(\n modelId: string,\n ): Pick<LanguageModelMiddleware, \"wrapGenerate\"> {\n // No-op middleware when logging is disabled\n if (!CONFIG_DIR) {\n return {\n wrapGenerate: async ({ doGenerate }) => doGenerate(),\n };\n }\n\n return {\n wrapGenerate: async ({ doGenerate, params }) => {\n const ctx = SessionFileLogger.getContext();\n // Skip logging overhead if no context (shouldn't happen but be safe)\n if (!ctx) {\n return doGenerate();\n }\n const llmRequestId = uuidv7();\n const toolCount = Array.isArray(params.tools) ? params.tools.length : 0;\n\n // Extract prompt preview from last non-system message\n const messages = (params.prompt ?? []) as Array<{\n role?: string;\n content?: unknown;\n }>;\n const lastMsg = messages.filter((m) => m.role !== \"system\").pop();\n const extracted = {\n text: undefined as string | undefined,\n extras: [] as string[],\n };\n\n let rolePrefix = lastMsg?.role ?? \"?\";\n if (lastMsg) {\n if (typeof lastMsg.content === \"string\") {\n extracted.text = lastMsg.content;\n } else if (Array.isArray(lastMsg.content)) {\n // Check for tool-result first\n const toolResult = (\n lastMsg.content as Array<{\n type?: string;\n toolName?: string;\n output?: { type?: string; value?: unknown };\n }>\n ).find((p) => p.type === \"tool-result\");\n if (toolResult) {\n rolePrefix = `tool result: ${toolResult.toolName}()`;\n const out = toolResult.output;\n if (out?.type === \"json\" && out.value) {\n extracted.text = JSON.stringify(out.value).slice(0, 150);\n } else if (Array.isArray(out?.value)) {\n extractFromContent(out.value as unknown[], extracted);\n }\n } else {\n extractFromContent(lastMsg.content as unknown[], extracted);\n }\n }\n }\n\n const promptText = extracted.text || \"(no text)\";\n const promptPreview = `${rolePrefix}: ${promptText} +{${toolCount} tools}`;\n\n SessionFileLogger.logLlmRequest(\n {\n requestId: llmRequestId,\n model: modelId,\n operation: \"generateText\",\n prompt: promptPreview,\n },\n ctx,\n );\n\n const result = await doGenerate();\n\n // Extract output preview\n const res = result as {\n text?: string;\n content?: unknown;\n toolCalls?: unknown[];\n };\n let outputPreview = res.text || \"\";\n if (!outputPreview && res.content) {\n if (typeof res.content === \"string\") {\n outputPreview = res.content;\n } else if (Array.isArray(res.content)) {\n outputPreview = (\n res.content as Array<{\n type?: string;\n text?: string;\n toolName?: string;\n }>\n )\n .map(\n (c) =>\n c.text ||\n (c.type === \"tool-call\"\n ? `tool call: ${c.toolName}()`\n : `[${c.type}]`),\n )\n .join(\" \");\n }\n }\n if (!outputPreview && res.toolCalls?.length) {\n outputPreview = `[${res.toolCalls.length} tool calls]`;\n }\n\n SessionFileLogger.logLlmResponse(\n {\n requestId: llmRequestId,\n model: modelId,\n operation: \"generateText\",\n output: outputPreview || \"[empty]\",\n inputTokens: result.usage?.inputTokens,\n outputTokens: result.usage?.outputTokens,\n },\n ctx,\n );\n\n return result;\n },\n };\n }\n}\n\n/**\n * Method decorator for logging understudy actions with automatic start/complete.\n * Logs all arguments automatically. No-op when CONFIG_DIR is empty.\n */\nexport function logAction(actionType: string) {\n return function <T extends (...args: never[]) => Promise<unknown>>(\n originalMethod: T,\n ): T {\n // No-op when logging is disabled\n if (!CONFIG_DIR) {\n return originalMethod;\n }\n\n return async function (this: unknown, ...args: unknown[]) {\n SessionFileLogger.logUnderstudyActionEvent({\n actionType,\n args: args.length > 0 ? args : undefined,\n });\n\n try {\n return await originalMethod.apply(this, args as never[]);\n } finally {\n SessionFileLogger.logUnderstudyActionCompleted();\n }\n } as T;\n };\n}\n\n/**\n * Method decorator for logging Stagehand step events (act, extract, observe).\n * Only adds logging - does NOT wrap with withInstanceLogContext (caller handles that).\n * No-op when CONFIG_DIR is empty.\n */\nexport function logStagehandStep(invocation: string, label: string) {\n return function <T extends (...args: never[]) => Promise<unknown>>(\n originalMethod: T,\n ): T {\n // No-op when logging is disabled\n if (!CONFIG_DIR) {\n return originalMethod;\n }\n\n return async function (\n this: unknown,\n ...args: unknown[]\n ): Promise<unknown> {\n SessionFileLogger.logStagehandStepEvent({\n invocation,\n args: args.length > 0 ? args : undefined,\n label,\n });\n\n try {\n return await originalMethod.apply(this, args as never[]);\n } finally {\n SessionFileLogger.logStagehandStepCompleted();\n }\n } as T;\n };\n}\n"]}
|
|
@@ -1,209 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const jsdom_1 = require("jsdom");
|
|
4
|
-
const vitest_1 = require("vitest");
|
|
5
|
-
const rerenderMissingShadows_runtime_js_1 = require("../../lib/v3/dom/rerenderMissingShadows.runtime.js");
|
|
6
|
-
const globalRef = globalThis;
|
|
7
|
-
const originalGlobals = {
|
|
8
|
-
window: globalRef.window,
|
|
9
|
-
document: globalRef.document,
|
|
10
|
-
Node: globalRef.Node,
|
|
11
|
-
NodeFilter: globalRef.NodeFilter,
|
|
12
|
-
Element: globalRef.Element,
|
|
13
|
-
HTMLElement: globalRef.HTMLElement,
|
|
14
|
-
Document: globalRef.Document,
|
|
15
|
-
DocumentFragment: globalRef.DocumentFragment,
|
|
16
|
-
ShadowRoot: globalRef.ShadowRoot,
|
|
17
|
-
customElements: globalRef.customElements,
|
|
18
|
-
};
|
|
19
|
-
let dom;
|
|
20
|
-
const installDomGlobals = () => {
|
|
21
|
-
const win = dom.window;
|
|
22
|
-
globalRef.window = win;
|
|
23
|
-
globalRef.document = win.document;
|
|
24
|
-
globalRef.Node = win.Node;
|
|
25
|
-
globalRef.NodeFilter = win.NodeFilter;
|
|
26
|
-
globalRef.Element = win.Element;
|
|
27
|
-
globalRef.HTMLElement = win.HTMLElement;
|
|
28
|
-
globalRef.Document = win.Document;
|
|
29
|
-
globalRef.DocumentFragment =
|
|
30
|
-
win.DocumentFragment;
|
|
31
|
-
globalRef.ShadowRoot = win.ShadowRoot;
|
|
32
|
-
globalRef.customElements =
|
|
33
|
-
win.customElements;
|
|
34
|
-
};
|
|
35
|
-
const restoreDomGlobals = () => {
|
|
36
|
-
for (const [key, value] of Object.entries(originalGlobals)) {
|
|
37
|
-
if (value === undefined) {
|
|
38
|
-
delete globalRef[key];
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
globalRef[key] = value;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
/**
|
|
46
|
-
* Helper: set up a fake piercer on `window.__stagehandV3__` backed by a WeakMap.
|
|
47
|
-
* Returns the WeakMap so tests can inspect tracked roots.
|
|
48
|
-
*/
|
|
49
|
-
function installFakePiercer() {
|
|
50
|
-
const closedRoots = new WeakMap();
|
|
51
|
-
const win = globalRef.window;
|
|
52
|
-
win.__stagehandV3__ = {
|
|
53
|
-
getClosedRoot: (el) => closedRoots.get(el) ?? null,
|
|
54
|
-
stats: false,
|
|
55
|
-
};
|
|
56
|
-
return closedRoots;
|
|
57
|
-
}
|
|
58
|
-
(0, vitest_1.describe)("rerenderMissingShadowHosts", () => {
|
|
59
|
-
(0, vitest_1.beforeAll)(() => {
|
|
60
|
-
dom = new jsdom_1.JSDOM("<!doctype html><html><body></body></html>");
|
|
61
|
-
installDomGlobals();
|
|
62
|
-
});
|
|
63
|
-
(0, vitest_1.afterAll)(() => {
|
|
64
|
-
dom.window.close();
|
|
65
|
-
restoreDomGlobals();
|
|
66
|
-
});
|
|
67
|
-
(0, vitest_1.beforeEach)(() => {
|
|
68
|
-
document.body.innerHTML = "";
|
|
69
|
-
// Clean up any stale custom element registrations by recreating the DOM
|
|
70
|
-
// (JSDOM doesn't support undefining custom elements, but we can use unique tag names per test)
|
|
71
|
-
});
|
|
72
|
-
(0, vitest_1.it)("re-renders a custom element with closed shadow so piercer can track it", () => {
|
|
73
|
-
const closedRoots = installFakePiercer();
|
|
74
|
-
const tag = "test-closed-a";
|
|
75
|
-
let constructorCalled = 0;
|
|
76
|
-
customElements.define(tag, class extends HTMLElement {
|
|
77
|
-
constructor() {
|
|
78
|
-
super();
|
|
79
|
-
constructorCalled++;
|
|
80
|
-
const root = this.attachShadow({ mode: "closed" });
|
|
81
|
-
root.innerHTML = "<span>shadow</span>";
|
|
82
|
-
// Simulate piercer intercepting attachShadow
|
|
83
|
-
closedRoots.set(this, root);
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
// Manually insert via innerHTML so the constructor fires once for the original
|
|
87
|
-
document.body.innerHTML = `<${tag}></${tag}>`;
|
|
88
|
-
const original = document.querySelector(tag);
|
|
89
|
-
// The original was created by innerHTML which does call the constructor in JSDOM
|
|
90
|
-
const callsBefore = constructorCalled;
|
|
91
|
-
// Remove the tracked root to simulate "created before piercer was installed"
|
|
92
|
-
closedRoots.delete(original);
|
|
93
|
-
(0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)();
|
|
94
|
-
const fresh = document.querySelector(tag);
|
|
95
|
-
// Constructor was called again for the fresh element
|
|
96
|
-
(0, vitest_1.expect)(constructorCalled).toBe(callsBefore + 1);
|
|
97
|
-
// Piercer now tracks the new element's closed root
|
|
98
|
-
(0, vitest_1.expect)(closedRoots.has(fresh)).toBe(true);
|
|
99
|
-
});
|
|
100
|
-
(0, vitest_1.it)("skips elements that already have an open shadow root", () => {
|
|
101
|
-
installFakePiercer();
|
|
102
|
-
const tag = "test-open-b";
|
|
103
|
-
customElements.define(tag, class extends HTMLElement {
|
|
104
|
-
constructor() {
|
|
105
|
-
super();
|
|
106
|
-
this.attachShadow({ mode: "open" });
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
document.body.innerHTML = `<${tag}></${tag}>`;
|
|
110
|
-
const original = document.querySelector(tag);
|
|
111
|
-
(0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)();
|
|
112
|
-
// Element should NOT have been replaced
|
|
113
|
-
(0, vitest_1.expect)(document.querySelector(tag)).toBe(original);
|
|
114
|
-
});
|
|
115
|
-
(0, vitest_1.it)("skips elements whose closed root is already tracked by piercer", () => {
|
|
116
|
-
const closedRoots = installFakePiercer();
|
|
117
|
-
const tag = "test-tracked-c";
|
|
118
|
-
customElements.define(tag, class extends HTMLElement {
|
|
119
|
-
constructor() {
|
|
120
|
-
super();
|
|
121
|
-
const root = this.attachShadow({ mode: "closed" });
|
|
122
|
-
closedRoots.set(this, root);
|
|
123
|
-
}
|
|
124
|
-
});
|
|
125
|
-
document.body.innerHTML = `<${tag}></${tag}>`;
|
|
126
|
-
const original = document.querySelector(tag);
|
|
127
|
-
(0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)();
|
|
128
|
-
// Element should NOT have been replaced since piercer already knows about it
|
|
129
|
-
(0, vitest_1.expect)(document.querySelector(tag)).toBe(original);
|
|
130
|
-
});
|
|
131
|
-
(0, vitest_1.it)("transfers attributes to the fresh element", () => {
|
|
132
|
-
const closedRoots = installFakePiercer();
|
|
133
|
-
const tag = "test-attrs-d";
|
|
134
|
-
customElements.define(tag, class extends HTMLElement {
|
|
135
|
-
constructor() {
|
|
136
|
-
super();
|
|
137
|
-
const root = this.attachShadow({ mode: "closed" });
|
|
138
|
-
closedRoots.set(this, root);
|
|
139
|
-
}
|
|
140
|
-
});
|
|
141
|
-
document.body.innerHTML = `<${tag} id="myid" class="foo bar" data-x="123"></${tag}>`;
|
|
142
|
-
const original = document.querySelector(tag);
|
|
143
|
-
// Remove tracking to force re-render
|
|
144
|
-
closedRoots.delete(original);
|
|
145
|
-
(0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)();
|
|
146
|
-
const fresh = document.querySelector(tag);
|
|
147
|
-
(0, vitest_1.expect)(fresh).not.toBe(original);
|
|
148
|
-
(0, vitest_1.expect)(fresh.getAttribute("id")).toBe("myid");
|
|
149
|
-
(0, vitest_1.expect)(fresh.getAttribute("class")).toBe("foo bar");
|
|
150
|
-
(0, vitest_1.expect)(fresh.getAttribute("data-x")).toBe("123");
|
|
151
|
-
});
|
|
152
|
-
(0, vitest_1.it)("moves light DOM children to the fresh element", () => {
|
|
153
|
-
const closedRoots = installFakePiercer();
|
|
154
|
-
const tag = "test-children-e";
|
|
155
|
-
customElements.define(tag, class extends HTMLElement {
|
|
156
|
-
constructor() {
|
|
157
|
-
super();
|
|
158
|
-
const root = this.attachShadow({ mode: "closed" });
|
|
159
|
-
root.innerHTML = "<slot></slot>";
|
|
160
|
-
closedRoots.set(this, root);
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
document.body.innerHTML = `<${tag}><span class="child1">A</span><span class="child2">B</span></${tag}>`;
|
|
164
|
-
const original = document.querySelector(tag);
|
|
165
|
-
const child1 = original.querySelector(".child1");
|
|
166
|
-
const child2 = original.querySelector(".child2");
|
|
167
|
-
// Remove tracking to force re-render
|
|
168
|
-
closedRoots.delete(original);
|
|
169
|
-
(0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)();
|
|
170
|
-
const fresh = document.querySelector(tag);
|
|
171
|
-
(0, vitest_1.expect)(fresh).not.toBe(original);
|
|
172
|
-
// Children should have been moved (same DOM nodes, not cloned)
|
|
173
|
-
(0, vitest_1.expect)(fresh.querySelector(".child1")).toBe(child1);
|
|
174
|
-
(0, vitest_1.expect)(fresh.querySelector(".child2")).toBe(child2);
|
|
175
|
-
(0, vitest_1.expect)(fresh.children.length).toBe(2);
|
|
176
|
-
});
|
|
177
|
-
(0, vitest_1.it)("skips elements whose constructor throws without breaking the rest", () => {
|
|
178
|
-
const closedRoots = installFakePiercer();
|
|
179
|
-
const tagBad = "test-throws-f";
|
|
180
|
-
const tagGood = "test-good-f";
|
|
181
|
-
let badCreated = false;
|
|
182
|
-
customElements.define(tagBad, class extends HTMLElement {
|
|
183
|
-
constructor() {
|
|
184
|
-
super();
|
|
185
|
-
if (badCreated) {
|
|
186
|
-
throw new Error("constructor boom");
|
|
187
|
-
}
|
|
188
|
-
badCreated = true;
|
|
189
|
-
}
|
|
190
|
-
});
|
|
191
|
-
customElements.define(tagGood, class extends HTMLElement {
|
|
192
|
-
constructor() {
|
|
193
|
-
super();
|
|
194
|
-
const root = this.attachShadow({ mode: "closed" });
|
|
195
|
-
closedRoots.set(this, root);
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
document.body.innerHTML = `<${tagBad}></${tagBad}><${tagGood}></${tagGood}>`;
|
|
199
|
-
// Remove tracking from the good element so it needs re-render
|
|
200
|
-
const goodOriginal = document.querySelector(tagGood);
|
|
201
|
-
closedRoots.delete(goodOriginal);
|
|
202
|
-
// Should not throw even though tagBad's constructor will throw on re-create
|
|
203
|
-
(0, vitest_1.expect)(() => (0, rerenderMissingShadows_runtime_js_1.rerenderMissingShadowHosts)()).not.toThrow();
|
|
204
|
-
// The good element should have been re-rendered successfully
|
|
205
|
-
const freshGood = document.querySelector(tagGood);
|
|
206
|
-
(0, vitest_1.expect)(closedRoots.has(freshGood)).toBe(true);
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
//# sourceMappingURL=rerender-missing-shadows.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rerender-missing-shadows.test.js","sourceRoot":"","sources":["../../../../tests/unit/rerender-missing-shadows.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { JSDOM } from \"jsdom\";\nimport { afterAll, beforeAll, beforeEach, describe, expect, it } from \"vitest\";\nimport { rerenderMissingShadowHosts } from \"../../lib/v3/dom/rerenderMissingShadows.runtime.js\";\n\ntype DomGlobals = {\n window: Window & typeof globalThis;\n document: Document;\n Node: typeof Node;\n NodeFilter: typeof NodeFilter;\n Element: typeof Element;\n HTMLElement: typeof HTMLElement;\n Document: typeof Document;\n DocumentFragment: typeof DocumentFragment;\n ShadowRoot: typeof ShadowRoot;\n customElements: CustomElementRegistry;\n};\n\nconst globalRef = globalThis as typeof globalThis & Partial<DomGlobals>;\nconst originalGlobals: Partial<DomGlobals> = {\n window: globalRef.window,\n document: globalRef.document,\n Node: globalRef.Node,\n NodeFilter: globalRef.NodeFilter,\n Element: globalRef.Element,\n HTMLElement: globalRef.HTMLElement,\n Document: globalRef.Document,\n DocumentFragment: globalRef.DocumentFragment,\n ShadowRoot: globalRef.ShadowRoot,\n customElements: globalRef.customElements,\n};\n\nlet dom: JSDOM;\n\nconst installDomGlobals = () => {\n const win = dom.window;\n globalRef.window = win as unknown as Window & typeof globalThis;\n globalRef.document = win.document;\n globalRef.Node = win.Node as unknown as typeof Node;\n globalRef.NodeFilter = win.NodeFilter as unknown as typeof NodeFilter;\n globalRef.Element = win.Element as unknown as typeof Element;\n globalRef.HTMLElement = win.HTMLElement as unknown as typeof HTMLElement;\n globalRef.Document = win.Document as unknown as typeof Document;\n globalRef.DocumentFragment =\n win.DocumentFragment as unknown as typeof DocumentFragment;\n globalRef.ShadowRoot = win.ShadowRoot as unknown as typeof ShadowRoot;\n globalRef.customElements =\n win.customElements as unknown as CustomElementRegistry;\n};\n\nconst restoreDomGlobals = () => {\n for (const [key, value] of Object.entries(originalGlobals)) {\n if (value === undefined) {\n delete (globalRef as Record<string, unknown>)[key];\n } else {\n (globalRef as Record<string, unknown>)[key] = value;\n }\n }\n};\n\n/**\n * Helper: set up a fake piercer on `window.__stagehandV3__` backed by a WeakMap.\n * Returns the WeakMap so tests can inspect tracked roots.\n */\nfunction installFakePiercer(): WeakMap<Element, ShadowRoot> {\n const closedRoots = new WeakMap<Element, ShadowRoot>();\n const win = globalRef.window as unknown as Record<string, unknown>;\n win.__stagehandV3__ = {\n getClosedRoot: (el: Element) => closedRoots.get(el) ?? null,\n stats: false,\n };\n return closedRoots;\n}\n\ndescribe(\"rerenderMissingShadowHosts\", () => {\n beforeAll(() => {\n dom = new JSDOM(\"<!doctype html><html><body></body></html>\");\n installDomGlobals();\n });\n\n afterAll(() => {\n dom.window.close();\n restoreDomGlobals();\n });\n\n beforeEach(() => {\n document.body.innerHTML = \"\";\n // Clean up any stale custom element registrations by recreating the DOM\n // (JSDOM doesn't support undefining custom elements, but we can use unique tag names per test)\n });\n\n it(\"re-renders a custom element with closed shadow so piercer can track it\", () => {\n const closedRoots = installFakePiercer();\n const tag = \"test-closed-a\";\n let constructorCalled = 0;\n\n customElements.define(\n tag,\n class extends HTMLElement {\n constructor() {\n super();\n constructorCalled++;\n const root = this.attachShadow({ mode: \"closed\" });\n root.innerHTML = \"<span>shadow</span>\";\n // Simulate piercer intercepting attachShadow\n closedRoots.set(this, root);\n }\n },\n );\n\n // Manually insert via innerHTML so the constructor fires once for the original\n document.body.innerHTML = `<${tag}></${tag}>`;\n const original = document.querySelector(tag)!;\n // The original was created by innerHTML which does call the constructor in JSDOM\n const callsBefore = constructorCalled;\n\n // Remove the tracked root to simulate \"created before piercer was installed\"\n closedRoots.delete(original);\n\n rerenderMissingShadowHosts();\n\n const fresh = document.querySelector(tag)!;\n // Constructor was called again for the fresh element\n expect(constructorCalled).toBe(callsBefore + 1);\n // Piercer now tracks the new element's closed root\n expect(closedRoots.has(fresh)).toBe(true);\n });\n\n it(\"skips elements that already have an open shadow root\", () => {\n installFakePiercer();\n const tag = \"test-open-b\";\n\n customElements.define(\n tag,\n class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: \"open\" });\n }\n },\n );\n\n document.body.innerHTML = `<${tag}></${tag}>`;\n const original = document.querySelector(tag)!;\n\n rerenderMissingShadowHosts();\n\n // Element should NOT have been replaced\n expect(document.querySelector(tag)).toBe(original);\n });\n\n it(\"skips elements whose closed root is already tracked by piercer\", () => {\n const closedRoots = installFakePiercer();\n const tag = \"test-tracked-c\";\n\n customElements.define(\n tag,\n class extends HTMLElement {\n constructor() {\n super();\n const root = this.attachShadow({ mode: \"closed\" });\n closedRoots.set(this, root);\n }\n },\n );\n\n document.body.innerHTML = `<${tag}></${tag}>`;\n const original = document.querySelector(tag)!;\n\n rerenderMissingShadowHosts();\n\n // Element should NOT have been replaced since piercer already knows about it\n expect(document.querySelector(tag)).toBe(original);\n });\n\n it(\"transfers attributes to the fresh element\", () => {\n const closedRoots = installFakePiercer();\n const tag = \"test-attrs-d\";\n\n customElements.define(\n tag,\n class extends HTMLElement {\n constructor() {\n super();\n const root = this.attachShadow({ mode: \"closed\" });\n closedRoots.set(this, root);\n }\n },\n );\n\n document.body.innerHTML = `<${tag} id=\"myid\" class=\"foo bar\" data-x=\"123\"></${tag}>`;\n const original = document.querySelector(tag)!;\n // Remove tracking to force re-render\n closedRoots.delete(original);\n\n rerenderMissingShadowHosts();\n\n const fresh = document.querySelector(tag)!;\n expect(fresh).not.toBe(original);\n expect(fresh.getAttribute(\"id\")).toBe(\"myid\");\n expect(fresh.getAttribute(\"class\")).toBe(\"foo bar\");\n expect(fresh.getAttribute(\"data-x\")).toBe(\"123\");\n });\n\n it(\"moves light DOM children to the fresh element\", () => {\n const closedRoots = installFakePiercer();\n const tag = \"test-children-e\";\n\n customElements.define(\n tag,\n class extends HTMLElement {\n constructor() {\n super();\n const root = this.attachShadow({ mode: \"closed\" });\n root.innerHTML = \"<slot></slot>\";\n closedRoots.set(this, root);\n }\n },\n );\n\n document.body.innerHTML = `<${tag}><span class=\"child1\">A</span><span class=\"child2\">B</span></${tag}>`;\n const original = document.querySelector(tag)!;\n const child1 = original.querySelector(\".child1\")!;\n const child2 = original.querySelector(\".child2\")!;\n // Remove tracking to force re-render\n closedRoots.delete(original);\n\n rerenderMissingShadowHosts();\n\n const fresh = document.querySelector(tag)!;\n expect(fresh).not.toBe(original);\n // Children should have been moved (same DOM nodes, not cloned)\n expect(fresh.querySelector(\".child1\")).toBe(child1);\n expect(fresh.querySelector(\".child2\")).toBe(child2);\n expect(fresh.children.length).toBe(2);\n });\n\n it(\"skips elements whose constructor throws without breaking the rest\", () => {\n const closedRoots = installFakePiercer();\n const tagBad = \"test-throws-f\";\n const tagGood = \"test-good-f\";\n let badCreated = false;\n\n customElements.define(\n tagBad,\n class extends HTMLElement {\n constructor() {\n super();\n if (badCreated) {\n throw new Error(\"constructor boom\");\n }\n badCreated = true;\n }\n },\n );\n\n customElements.define(\n tagGood,\n class extends HTMLElement {\n constructor() {\n super();\n const root = this.attachShadow({ mode: \"closed\" });\n closedRoots.set(this, root);\n }\n },\n );\n\n document.body.innerHTML = `<${tagBad}></${tagBad}><${tagGood}></${tagGood}>`;\n // Remove tracking from the good element so it needs re-render\n const goodOriginal = document.querySelector(tagGood)!;\n closedRoots.delete(goodOriginal);\n\n // Should not throw even though tagBad's constructor will throw on re-create\n expect(() => rerenderMissingShadowHosts()).not.toThrow();\n\n // The good element should have been re-rendered successfully\n const freshGood = document.querySelector(tagGood)!;\n expect(closedRoots.has(freshGood)).toBe(true);\n });\n});\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../../../../../lib/v3/agent/tools/search.ts"],"names":[],"mappings":"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","sourcesContent":["import { tool } from \"ai\";\nimport { z } from \"zod\";\nimport type { V3 } from \"../../v3.js\";\n\nexport interface BraveSearchResult {\n title: string;\n url: string;\n description?: string;\n}\n\ninterface SearchResponse {\n data?: {\n results: BraveSearchResult[];\n };\n error?: string;\n}\n\ninterface BraveWebResult {\n title?: string;\n url?: string;\n description?: string;\n age?: string;\n meta_url?: {\n favicon?: string;\n };\n}\n\ninterface BraveApiResponse {\n web?: {\n results?: BraveWebResult[];\n };\n}\n\nasync function performBraveSearch(query: string): Promise<SearchResponse> {\n try {\n const encodedQuery = encodeURIComponent(query);\n const response = await fetch(\n `https://api.search.brave.com/res/v1/web/search?q=${encodedQuery}`,\n {\n method: \"GET\",\n headers: {\n Accept: \"application/json\",\n \"Accept-Encoding\": \"gzip\",\n \"X-Subscription-Token\": process.env.BRAVE_API_KEY!,\n },\n },\n );\n\n if (!response.ok) {\n return {\n error: `Brave API error: ${response.status} ${response.statusText}`,\n data: { results: [] },\n };\n }\n\n const data = (await response.json()) as BraveApiResponse;\n const results: BraveSearchResult[] = [];\n\n if (data?.web?.results && Array.isArray(data.web.results)) {\n for (const item of data.web.results.slice(0, 5)) {\n if (item.title && item.url) {\n results.push({\n title: item.title,\n url: item.url,\n description: item.description,\n });\n }\n }\n }\n\n return { data: { results } };\n } catch (error) {\n console.error(\"Search error\", error);\n return {\n error: `Error performing search: ${(error as Error).message}`,\n data: { results: [] },\n };\n }\n}\n\nexport const searchTool = (v3: V3) =>\n tool({\n description:\n \"Perform a web search and returns results. Use this tool when you need information from the web or when you are unsure of the exact URL you want to navigate to. This can be used to find the ideal entry point, resulting in a task that is easier to complete due to starting further in the process.\",\n inputSchema: z.object({\n query: z.string().describe(\"The search query to look for on the web\"),\n }),\n execute: async ({ query }) => {\n v3.logger({\n category: \"agent\",\n message: `Agent calling tool: search`,\n level: 1,\n auxiliary: {\n arguments: {\n value: JSON.stringify({ query }),\n type: \"object\",\n },\n },\n });\n\n const result = await performBraveSearch(query);\n\n v3.recordAgentReplayStep({\n type: \"search\",\n instruction: query,\n playwrightArguments: { query },\n message:\n result.error ?? `Found ${result.data?.results.length ?? 0} results`,\n });\n\n return {\n ...result,\n timestamp: Date.now(),\n };\n },\n });\n"]}
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import pino from "pino";
|
|
3
|
-
import type { LanguageModelMiddleware } from "ai";
|
|
4
|
-
import type { V3Options } from "./types/public/index.js";
|
|
5
|
-
interface FlowLoggerMetrics {
|
|
6
|
-
taskStartTime?: number;
|
|
7
|
-
stepStartTime?: number;
|
|
8
|
-
actionStartTime?: number;
|
|
9
|
-
llmRequests: number;
|
|
10
|
-
llmInputTokens: number;
|
|
11
|
-
llmOutputTokens: number;
|
|
12
|
-
cdpEvents: number;
|
|
13
|
-
}
|
|
14
|
-
export interface FlowLoggerContext {
|
|
15
|
-
logger: pino.Logger;
|
|
16
|
-
metrics: FlowLoggerMetrics;
|
|
17
|
-
sessionId: string;
|
|
18
|
-
sessionDir: string;
|
|
19
|
-
configDir: string;
|
|
20
|
-
initPromise: Promise<void>;
|
|
21
|
-
initialized: boolean;
|
|
22
|
-
taskId: string | null;
|
|
23
|
-
stepId: string | null;
|
|
24
|
-
stepLabel: string | null;
|
|
25
|
-
actionId: string | null;
|
|
26
|
-
actionLabel: string | null;
|
|
27
|
-
fileStreams: {
|
|
28
|
-
agent: fs.WriteStream | null;
|
|
29
|
-
stagehand: fs.WriteStream | null;
|
|
30
|
-
understudy: fs.WriteStream | null;
|
|
31
|
-
cdp: fs.WriteStream | null;
|
|
32
|
-
llm: fs.WriteStream | null;
|
|
33
|
-
jsonl: fs.WriteStream | null;
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Get the config directory. Returns empty string if logging is disabled.
|
|
38
|
-
*/
|
|
39
|
-
export declare function getConfigDir(): string;
|
|
40
|
-
/**
|
|
41
|
-
* Format a prompt preview from LLM messages for logging.
|
|
42
|
-
* Returns format like: "some text... +{5.8kb image} +{schema} +{12 tools}"
|
|
43
|
-
*/
|
|
44
|
-
export declare function formatLlmPromptPreview(messages: Array<{
|
|
45
|
-
role: string;
|
|
46
|
-
content: unknown;
|
|
47
|
-
}>, options?: {
|
|
48
|
-
toolCount?: number;
|
|
49
|
-
hasSchema?: boolean;
|
|
50
|
-
}): string | undefined;
|
|
51
|
-
/**
|
|
52
|
-
* Extract a text preview from CUA-style messages.
|
|
53
|
-
* Accepts various message formats (Anthropic, OpenAI, Google).
|
|
54
|
-
*/
|
|
55
|
-
export declare function formatCuaPromptPreview(messages: unknown[], maxLen?: number): string | undefined;
|
|
56
|
-
/** Format CUA response output for logging */
|
|
57
|
-
export declare function formatCuaResponsePreview(output: unknown, maxLen?: number): string;
|
|
58
|
-
export declare class SessionFileLogger {
|
|
59
|
-
/**
|
|
60
|
-
* Initialize a new logging context. Call this at the start of a session.
|
|
61
|
-
* If BROWSERBASE_CONFIG_DIR is not set, logging is disabled.
|
|
62
|
-
*/
|
|
63
|
-
static init(sessionId: string, v3Options?: V3Options): void;
|
|
64
|
-
private static initAsync;
|
|
65
|
-
static close(): Promise<void>;
|
|
66
|
-
static get sessionId(): string | null;
|
|
67
|
-
static get sessionDir(): string | null;
|
|
68
|
-
/**
|
|
69
|
-
* Get the current logger context object.
|
|
70
|
-
*/
|
|
71
|
-
static getContext(): FlowLoggerContext | null;
|
|
72
|
-
/**
|
|
73
|
-
* Start a new task and log it.
|
|
74
|
-
*/
|
|
75
|
-
static logAgentTaskStarted({ invocation, args, }: {
|
|
76
|
-
invocation: string;
|
|
77
|
-
args?: unknown | unknown[];
|
|
78
|
-
}): void;
|
|
79
|
-
/**
|
|
80
|
-
* Log task completion with metrics summary.
|
|
81
|
-
*/
|
|
82
|
-
static logAgentTaskCompleted(options?: {
|
|
83
|
-
cacheHit?: boolean;
|
|
84
|
-
}): void;
|
|
85
|
-
static logStagehandStepEvent({ invocation, args, label, }: {
|
|
86
|
-
invocation: string;
|
|
87
|
-
args?: unknown | unknown[];
|
|
88
|
-
label: string;
|
|
89
|
-
}): string;
|
|
90
|
-
static logStagehandStepCompleted(): void;
|
|
91
|
-
static logUnderstudyActionEvent({ actionType, target, args, }: {
|
|
92
|
-
actionType: string;
|
|
93
|
-
target?: string;
|
|
94
|
-
args?: unknown | unknown[];
|
|
95
|
-
}): string;
|
|
96
|
-
static logUnderstudyActionCompleted(): void;
|
|
97
|
-
private static logCdpEvent;
|
|
98
|
-
static logCdpCallEvent(data: {
|
|
99
|
-
method: string;
|
|
100
|
-
params?: object;
|
|
101
|
-
targetId?: string | null;
|
|
102
|
-
}, ctx?: FlowLoggerContext | null): void;
|
|
103
|
-
static logCdpMessageEvent(data: {
|
|
104
|
-
method: string;
|
|
105
|
-
params?: unknown;
|
|
106
|
-
targetId?: string | null;
|
|
107
|
-
}, ctx?: FlowLoggerContext | null): void;
|
|
108
|
-
static logLlmRequest({ requestId, model, prompt, }: {
|
|
109
|
-
requestId: string;
|
|
110
|
-
model: string;
|
|
111
|
-
operation: string;
|
|
112
|
-
prompt?: string;
|
|
113
|
-
}, explicitCtx?: FlowLoggerContext | null): void;
|
|
114
|
-
static logLlmResponse({ requestId, model, output, inputTokens, outputTokens, }: {
|
|
115
|
-
requestId: string;
|
|
116
|
-
model: string;
|
|
117
|
-
operation: string;
|
|
118
|
-
output?: string;
|
|
119
|
-
inputTokens?: number;
|
|
120
|
-
outputTokens?: number;
|
|
121
|
-
}, explicitCtx?: FlowLoggerContext | null): void;
|
|
122
|
-
/**
|
|
123
|
-
* Create middleware for wrapping language models with LLM call logging.
|
|
124
|
-
* Returns a no-op middleware when logging is disabled.
|
|
125
|
-
*/
|
|
126
|
-
static createLlmLoggingMiddleware(modelId: string): Pick<LanguageModelMiddleware, "wrapGenerate">;
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Method decorator for logging understudy actions with automatic start/complete.
|
|
130
|
-
* Logs all arguments automatically. No-op when CONFIG_DIR is empty.
|
|
131
|
-
*/
|
|
132
|
-
export declare function logAction(actionType: string): <T extends (...args: never[]) => Promise<unknown>>(originalMethod: T) => T;
|
|
133
|
-
/**
|
|
134
|
-
* Method decorator for logging Stagehand step events (act, extract, observe).
|
|
135
|
-
* Only adds logging - does NOT wrap with withInstanceLogContext (caller handles that).
|
|
136
|
-
* No-op when CONFIG_DIR is empty.
|
|
137
|
-
*/
|
|
138
|
-
export declare function logStagehandStep(invocation: string, label: string): <T extends (...args: never[]) => Promise<unknown>>(originalMethod: T) => T;
|
|
139
|
-
export {};
|