@browserbasehq/orca 3.2.0-preview.3 → 3.2.0-preview.5
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.d.ts +3 -1
- package/dist/cjs/lib/inference.js +2 -2
- package/dist/cjs/lib/inference.js.map +1 -1
- package/dist/cjs/lib/prompt.d.ts +1 -1
- package/dist/cjs/lib/prompt.js +11 -2
- package/dist/cjs/lib/prompt.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/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 +2 -2
- package/dist/cjs/lib/v3/agent/prompts/agentSystemPrompt.js +10 -11
- package/dist/cjs/lib/v3/agent/prompts/agentSystemPrompt.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/act.js +1 -10
- package/dist/cjs/lib/v3/agent/tools/act.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/ariaTree.js +1 -12
- package/dist/cjs/lib/v3/agent/tools/ariaTree.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/braveSearch.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/browserbaseSearch.js.map +1 -1
- 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.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/extract.js +1 -10
- package/dist/cjs/lib/v3/agent/tools/extract.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/fillFormVision.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/fillform.d.ts +0 -1
- package/dist/cjs/lib/v3/agent/tools/fillform.js +8 -20
- package/dist/cjs/lib/v3/agent/tools/fillform.js.map +1 -1
- package/dist/cjs/lib/v3/agent/tools/index.d.ts +2 -2
- package/dist/cjs/lib/v3/agent/tools/index.js +53 -5
- 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/type.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/variables.d.ts +5 -0
- package/dist/cjs/lib/v3/agent/utils/variables.js +9 -0
- package/dist/cjs/lib/v3/agent/utils/variables.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/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 +2 -1
- 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 +112 -78
- 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/llm/aisdk.js +11 -17
- package/dist/cjs/lib/v3/llm/aisdk.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/handlers.d.ts +1 -0
- package/dist/cjs/lib/v3/types/private/handlers.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/api.d.ts +24 -7
- package/dist/cjs/lib/v3/types/public/api.js +41 -14
- package/dist/cjs/lib/v3/types/public/api.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/methods.d.ts +1 -0
- package/dist/cjs/lib/v3/types/public/methods.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/options.d.ts +7 -0
- package/dist/cjs/lib/v3/types/public/options.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/variables.d.ts +7 -0
- package/dist/cjs/lib/v3/types/public/variables.js +22 -0
- package/dist/cjs/lib/v3/types/public/variables.js.map +1 -0
- package/dist/cjs/lib/v3/understudy/cdp.d.ts +3 -12
- package/dist/cjs/lib/v3/understudy/cdp.js +134 -21
- package/dist/cjs/lib/v3/understudy/cdp.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/page.js +28 -18
- package/dist/cjs/lib/v3/understudy/page.js.map +1 -1
- package/dist/cjs/lib/v3/v3.d.ts +12 -2
- package/dist/cjs/lib/v3/v3.js +194 -160
- 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.d.ts +1 -0
- 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/flowLogger.spec.d.ts +1 -0
- 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/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 +113 -3
- 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 +25 -3
- package/dist/cjs/tests/unit/agent-execution-model.test.js.map +1 -1
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.d.ts +1 -0
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.js +23 -0
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.js.map +1 -0
- package/dist/cjs/tests/unit/api-client-observe-variables.test.d.ts +1 -0
- package/dist/cjs/tests/unit/api-client-observe-variables.test.js +86 -0
- package/dist/cjs/tests/unit/api-client-observe-variables.test.js.map +1 -0
- package/dist/cjs/tests/unit/api-variables-schema.test.d.ts +1 -0
- package/dist/cjs/tests/unit/api-variables-schema.test.js +37 -0
- package/dist/cjs/tests/unit/api-variables-schema.test.js.map +1 -0
- 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/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/prompt-observe-variables.test.d.ts +1 -0
- package/dist/cjs/tests/unit/prompt-observe-variables.test.js +19 -0
- package/dist/cjs/tests/unit/prompt-observe-variables.test.js.map +1 -0
- package/dist/cjs/tests/unit/public-api/public-types.test.js.map +1 -1
- package/dist/cjs/tests/unit/timeout-handlers.test.js +50 -0
- package/dist/cjs/tests/unit/timeout-handlers.test.js.map +1 -1
- package/dist/esm/lib/inference.d.ts +3 -1
- package/dist/esm/lib/inference.js +2 -2
- package/dist/esm/lib/inference.js.map +1 -1
- package/dist/esm/lib/prompt.d.ts +1 -1
- package/dist/esm/lib/prompt.js +11 -2
- package/dist/esm/lib/prompt.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/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 +2 -2
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js +10 -11
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/act.js +1 -10
- package/dist/esm/lib/v3/agent/tools/act.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/ariaTree.js +1 -12
- package/dist/esm/lib/v3/agent/tools/ariaTree.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/braveSearch.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/browserbaseSearch.js.map +1 -1
- 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.map +1 -1
- package/dist/esm/lib/v3/agent/tools/extract.js +1 -10
- package/dist/esm/lib/v3/agent/tools/extract.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/fillFormVision.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/fillform.d.ts +0 -1
- package/dist/esm/lib/v3/agent/tools/fillform.js +8 -20
- package/dist/esm/lib/v3/agent/tools/fillform.js.map +1 -1
- package/dist/esm/lib/v3/agent/tools/index.d.ts +2 -2
- package/dist/esm/lib/v3/agent/tools/index.js +53 -5
- 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/type.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/variables.d.ts +5 -0
- package/dist/esm/lib/v3/agent/utils/variables.js +8 -0
- package/dist/esm/lib/v3/agent/utils/variables.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/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 +2 -1
- 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 +112 -78
- 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/llm/aisdk.js +11 -17
- package/dist/esm/lib/v3/llm/aisdk.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/handlers.d.ts +1 -0
- package/dist/esm/lib/v3/types/private/handlers.js.map +1 -1
- package/dist/esm/lib/v3/types/public/api.d.ts +24 -7
- package/dist/esm/lib/v3/types/public/api.js +36 -12
- package/dist/esm/lib/v3/types/public/api.js.map +1 -1
- package/dist/esm/lib/v3/types/public/methods.d.ts +1 -0
- package/dist/esm/lib/v3/types/public/methods.js.map +1 -1
- package/dist/esm/lib/v3/types/public/options.d.ts +7 -0
- package/dist/esm/lib/v3/types/public/options.js.map +1 -1
- package/dist/esm/lib/v3/types/public/variables.d.ts +7 -0
- package/dist/esm/lib/v3/types/public/variables.js +19 -0
- package/dist/esm/lib/v3/types/public/variables.js.map +1 -0
- package/dist/esm/lib/v3/understudy/cdp.d.ts +3 -12
- package/dist/esm/lib/v3/understudy/cdp.js +134 -21
- package/dist/esm/lib/v3/understudy/cdp.js.map +1 -1
- package/dist/esm/lib/v3/understudy/page.js +28 -18
- package/dist/esm/lib/v3/understudy/page.js.map +1 -1
- package/dist/esm/lib/v3/v3.d.ts +12 -2
- package/dist/esm/lib/v3/v3.js +194 -160
- 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/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/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 +113 -3
- 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 +25 -3
- package/dist/esm/tests/unit/agent-execution-model.test.js.map +1 -1
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.d.ts +1 -0
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.js +21 -0
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.js.map +1 -0
- package/dist/esm/tests/unit/api-client-observe-variables.test.d.ts +1 -0
- package/dist/esm/tests/unit/api-client-observe-variables.test.js +84 -0
- package/dist/esm/tests/unit/api-client-observe-variables.test.js.map +1 -0
- package/dist/esm/tests/unit/api-variables-schema.test.d.ts +1 -0
- package/dist/esm/tests/unit/api-variables-schema.test.js +35 -0
- package/dist/esm/tests/unit/api-variables-schema.test.js.map +1 -0
- 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/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/prompt-observe-variables.test.d.ts +1 -0
- package/dist/esm/tests/unit/prompt-observe-variables.test.js +17 -0
- package/dist/esm/tests/unit/prompt-observe-variables.test.js.map +1 -0
- package/dist/esm/tests/unit/public-api/public-types.test.js.map +1 -1
- package/dist/esm/tests/unit/timeout-handlers.test.js +50 -0
- package/dist/esm/tests/unit/timeout-handlers.test.js.map +1 -1
- package/package.json +4 -2
- 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/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
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"flowLogger.js","sourceRoot":"","sources":["../../../../lib/v3/flowLogger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,IAAI,MAAM,MAAM,CAAC;AAIxB,gFAAgF;AAChF,YAAY;AACZ,gFAAgF;AAEhF,MAAM,eAAe,GAAG,GAAG,CAAC;AAE5B,mEAAmE;AACnE,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,EAAE,CAAC;AAE5D,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC;IAC/B,0BAA0B;IAC1B,iCAAiC;IACjC,mCAAmC;IACnC,kCAAkC;IAClC,qBAAqB;IACrB,sBAAsB;IACtB,yBAAyB;IACzB,oCAAoC;IACpC,mCAAmC;IACnC,2BAA2B;IAC3B,0BAA0B;CAC3B,CAAC,CAAC;AAsFH,MAAM,aAAa,GAAG,IAAI,iBAAiB,EAAqB,CAAC;AAEjE,gFAAgF;AAChF,gDAAgD;AAChD,gFAAgF;AAEhF,uCAAuC;AACvC,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAU,EAAE,CACxC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;AAE3C,mEAAmE;AACnE,SAAS,cAAc,CAAC,KAAa;IACnC,OAAO,KAAK,CAAC,OAAO,CAClB,2CAA2C,EAC3C,CAAC,CAAC,EAAE,GAAW,EAAE,EAAU,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAC1E,CAAC;AACJ,CAAC;AAED,wCAAwC;AACxC,SAAS,YAAY,CAAC,KAAa,EAAE,MAAc;IACjD,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC7C,IAAI,SAAS,CAAC,MAAM,IAAI,MAAM;QAAE,OAAO,SAAS,CAAC;IACjD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,CAAC,CAAC;IACrC,OAAO,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;AACvE,CAAC;AAED,SAAS,WAAW,CAAC,KAAc;IACjC,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,IAAI,KAAK,GAAG,CAAC;IACnD,IAAI,KAAK,IAAI,IAAI,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACrE,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,kBAAkB,CAAC;IAC5B,CAAC;AACH,CAAC;AAED,SAAS,UAAU,CAAC,IAA0B;IAC5C,IAAI,IAAI,KAAK,SAAS;QAAE,OAAO,EAAE,CAAC;IAClC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACzC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC;SAC9B,GAAG,CAAC,WAAW,CAAC;SAChB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;SAC3B,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC;AAED,MAAM,OAAO,GAAG,CAAC,EAA6B,EAAU,EAAE,CACxD,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;AAE1B,SAAS,SAAS,CAChB,KAAgC,EAChC,EAA6B,EAC7B,IAAY;IAEZ,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,KAAK,OAAO,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;AAC3E,CAAC;AAED,IAAI,KAAK,GAAG,CAAC,CAAC;AACd,SAAS,eAAe;IACtB,MAAM,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;IACrB,MAAM,GAAG,GAAG,CAAC,CAAS,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC7D,OAAO,GAAG,CAAC,CAAC,WAAW,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;AAClM,CAAC;AAED,MAAM,cAAc,GAClB,sEAAsE,CAAC;AAEzE,SAAS,eAAe,CAAC,OAAkB;IACzC,MAAM,QAAQ,GAAG,CAAC,GAAY,EAAW,EAAE;QACzC,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI;YAAE,OAAO,GAAG,CAAC;QACxD,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;YAAE,OAAO,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACjD,MAAM,MAAM,GAA4B,EAAE,CAAC;QAC3C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YAC/C,MAAM,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACtE,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;IACF,OAAO,QAAQ,CAAC,EAAE,GAAG,OAAO,EAAE,CAA4B,CAAC;AAC7D,CAAC;AAED,qDAAqD;AACrD,SAAS,YAAY,CAAC,GAAW;IAC/B,OAAO,GAAG;SACP,OAAO,CAAC,cAAc,EAAE,IAAI,CAAC;SAC7B,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC;SAC3B,IAAI,EAAE,CAAC;AACZ,CAAC;AAED,gFAAgF;AAChF,oEAAoE;AACpE,gFAAgF;AAEhF,SAAS,aAAa,CAAC,KAAgB;IACrC,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,sFAAsF;IACtF,IAAI,KAAK,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;QACnC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;IAChD,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,eAAe,EAAE,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;IAC7D,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,kBAAkB,EAAE,CAAC;QACjD,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC3D,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;IACjE,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC3D,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/D,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;IACrD,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;QAC3D,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,oCAAoC;IACpC,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAE7D,IAAI,KAAK,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;QACnC,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,OAAO,GAAG,KAAK,KAAK,CAAC,MAAM,IAAI,OAAO,GAAG,CAAC;QAC5C,CAAC;aAAM,IAAI,KAAK,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;YACvC,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;YACxB,MAAM,WAAW,GAAG,CAAC,EAAE,UAAU;gBAC/B,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;gBAClC,CAAC,CAAC,GAAG,CAAC;YACR,MAAM,QAAQ,GAAG,GAAG,CAAC,EAAE,WAAW,IAAI,CAAC,eAAe,CAAC,EAAE,WAAW,IAAI,CAAC,KAAK,CAAC,EAAE,YAAY,IAAI,CAAC,SAAS,CAAC;YAC5G,MAAM,QAAQ,GAAG,GAAG,CAAC,EAAE,SAAS,IAAI,CAAC,WAAW,CAAC;YACjD,OAAO,GAAG,6BAA6B,WAAW,OAAO,QAAQ,MAAM,QAAQ,EAAE,CAAC;QACpF,CAAC;IACH,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,eAAe,EAAE,CAAC;QAC9C,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,OAAO,GAAG,KAAK,KAAK,CAAC,MAAM,IAAI,OAAO,GAAG,CAAC;QAC5C,CAAC;aAAM,IAAI,KAAK,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;YACvC,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,EAAE,UAAU;gBAC3C,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;gBAC9C,CAAC,CAAC,GAAG,CAAC;YACR,OAAO,GAAG,KAAK,KAAK,CAAC,SAAS,IAAI,MAAM,iBAAiB,WAAW,GAAG,CAAC;QAC1E,CAAC;IACH,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,kBAAkB,EAAE,CAAC;QACjD,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,OAAO,GAAG,KAAK,KAAK,CAAC,MAAM,IAAI,OAAO,GAAG,CAAC;QAC5C,CAAC;aAAM,IAAI,KAAK,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;YACvC,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,EAAE,UAAU;gBAC3C,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;gBAC9C,CAAC,CAAC,GAAG,CAAC;YACR,OAAO,GAAG,KAAK,KAAK,CAAC,WAAW,IAAI,QAAQ,iBAAiB,WAAW,GAAG,CAAC;QAC9E,CAAC;IACH,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAChD,OAAO,GAAG,GAAG,IAAI,IAAI,KAAK,CAAC,MAAM,IAAI,OAAO,GAAG,CAAC;IAClD,CAAC;SAAM,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;QACpC,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACjE,OAAO,GAAG,GAAG,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;QAC3C,CAAC;aAAM,IAAI,KAAK,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;YACtC,MAAM,SAAS,GACb,KAAK,CAAC,WAAW,KAAK,SAAS,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,CAAC;YACtE,MAAM,QAAQ,GAAG,SAAS;gBACxB,CAAC,CAAC,KAAK,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,KAAK,CAAC,YAAY,IAAI,CAAC,IAAI;gBAC7D,CAAC,CAAC,EAAE,CAAC;YACP,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACjE,OAAO,GAAG,GAAG,KAAK,CAAC,KAAK,KAAK,QAAQ,GAAG,SAAS,EAAE,CAAC;QACtD,CAAC;IACH,CAAC;IAED,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAE1B,2CAA2C;IAC3C,MAAM,QAAQ,GAAG,GAAG,eAAe,EAAE,IAAI,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,OAAO,EAAE,CAAC;IACtE,MAAM,OAAO,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;IACvC,MAAM,SAAS,GACb,KAAK,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAC/D,OAAO,YAAY,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;AAClD,CAAC;AAED,iEAAiE;AACjE,SAAS,oBAAoB,CAAC,KAAgB;IAC5C,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK;QAAE,OAAO,KAAK,CAAC;IAC3C,IAAI,KAAK,CAAC,MAAM,EAAE,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,QAAQ;QAChE,OAAO,IAAI,CAAC;IACd,OAAO,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAO,CAAC,CAAC;AAC1E,CAAC;AAED,gFAAgF;AAChF,kBAAkB;AAClB,gFAAgF;AAEhF,MAAM,UAAU,GAAG,CAAC,CAAwB,EAAuB,EAAE,CACnE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;AAEtC,SAAS,iBAAiB,CAAC,GAAsB;IAC/C,OAAO,IAAI,QAAQ,CAAC;QAClB,UAAU,EAAE,IAAI;QAChB,KAAK,CAAC,KAAa,EAAE,CAAC,EAAE,EAAE;YACxB,IAAI,GAAG,CAAC,WAAW,IAAI,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzD,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACzC,CAAC;;gBAAM,EAAE,EAAE,CAAC;QACd,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,SAAS,kBAAkB,CACzB,GAAsB,EACtB,QAAuB,EACvB,SAAiD;IAEjD,OAAO,IAAI,QAAQ,CAAC;QAClB,UAAU,EAAE,IAAI;QAChB,KAAK,CAAC,KAAa,EAAE,CAAC,EAAE,EAAE;YACxB,MAAM,MAAM,GAAG,GAAG,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAC1C,IAAI,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;gBAAE,OAAO,EAAE,EAAE,CAAC;YACzD,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAc,CAAC;gBAC7C,IAAI,KAAK,CAAC,QAAQ,KAAK,QAAQ,IAAI,oBAAoB,CAAC,KAAK,CAAC;oBAC5D,OAAO,EAAE,EAAE,CAAC;gBACd,MAAM,IAAI,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;gBAClC,IAAI,IAAI;oBAAE,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;;oBACnC,EAAE,EAAE,CAAC;YACZ,CAAC;YAAC,MAAM,CAAC;gBACP,EAAE,EAAE,CAAC;YACP,CAAC;QACH,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,gFAAgF;AAChF,4CAA4C;AAC5C,gFAAgF;AAEhF;;GAEG;AACH,MAAM,UAAU,YAAY;IAC1B,OAAO,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AACpD,CAAC;AAeD,oFAAoF;AACpF,SAAS,kBAAkB,CACzB,OAAkB,EAClB,MAA2C;IAE3C,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE,CAAC;QAC3B,MAAM,CAAC,GAAG,IAAmB,CAAC;QAC9B,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;YAC3B,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;QAClE,CAAC;QACD,2BAA2B;QAC3B,IAAI,CAAC,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YACjD,MAAM,GAAG,GAAG,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC;YAC7B,IAAI,GAAG,EAAE,UAAU,CAAC,OAAO,CAAC;gBAC1B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iBAC5C,IAAI,CAAC,CAAC,MAAM,EAAE,IAAI;gBACrB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;;gBACtD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,CAAC;aAAM,IAAI,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC;YAC1B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC3D,CAAC;aAAM,IAAI,CAAC,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC;YAC9B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/D,CAAC;QACD,mCAAmC;QACnC,IAAI,CAAC,CAAC,IAAI,KAAK,aAAa,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;YACzD,kBAAkB,CAAC,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;AACH,CAAC;AAED,6CAA6C;AAC7C,SAAS,YAAY,CACnB,IAAwB,EACxB,MAAgB,EAChB,MAAe;IAEf,IAAI,CAAC,IAAI,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IACnD,IAAI,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;IACxB,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,MAAM;QAClC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC;IAC3C,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtB,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzD,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACzD,CAAC;IACD,OAAO,MAAM,IAAI,SAAS,CAAC;AAC7B,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CACpC,QAAmD,EACnD,OAAqD;IAErD,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC;QACpE,IAAI,CAAC,WAAW;YAAE,OAAO,SAAS,CAAC;QAEnC,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,SAA+B;YACrC,MAAM,EAAE,EAAc;SACvB,CAAC;QAEF,IAAI,OAAO,WAAW,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC5C,MAAM,CAAC,IAAI,GAAG,WAAW,CAAC,OAAO,CAAC;QACpC,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9C,kBAAkB,CAAC,WAAW,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,2BAA2B;QAC3B,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;YAChB,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC;QAC7D,CAAC;QAED,IAAI,OAAO,EAAE,SAAS;YAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,OAAO,EAAE,SAAS;YAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,SAAS,QAAQ,CAAC,CAAC;QAEzE,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAClD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CACpC,QAAmB,EACnB,MAAM,GAAG,GAAG;IAEZ,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,QAAQ;aACrB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;YACZ,MAAM,GAAG,GAAG,CAAqC,CAAC;YAClD,OAAO,GAAG,CAAC,IAAI,KAAK,MAAM,IAAI,GAAG,CAAC,IAAI,KAAK,aAAa,CAAC;QAC3D,CAAC,CAAC;aACD,GAAG,EAEO,CAAC;QAEd,IAAI,CAAC,OAAO;YAAE,OAAO,SAAS,CAAC;QAE/B,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,SAA+B;YACrC,MAAM,EAAE,EAAc;SACvB,CAAC;QAEF,IAAI,OAAO,OAAO,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YACxC,MAAM,CAAC,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC;QAChC,CAAC;aAAM,IAAI,OAAO,OAAO,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC5C,MAAM,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QAC7B,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACxC,kBAAkB,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC5C,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAC1C,kBAAkB,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC9C,CAAC;QAED,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC1D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC;AAED,6CAA6C;AAC7C,MAAM,UAAU,wBAAwB,CACtC,MAAe,EACf,MAAM,GAAG,GAAG;IAEZ,IAAI,CAAC;QACH,gCAAgC;QAChC,MAAM,KAAK,GACR,MAAiE;YAChE,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK;YACnC,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAExC,MAAM,OAAO,GAAG,KAAK;aAClB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,CAAC,GAAG,IAKT,CAAC;YACF,IAAI,CAAC,CAAC,IAAI;gBAAE,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACvC,IAAI,CAAC,CAAC,YAAY,EAAE,IAAI;gBAAE,OAAO,MAAM,CAAC,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YAC7D,IAAI,CAAC,CAAC,IAAI,KAAK,UAAU,IAAI,CAAC,CAAC,IAAI;gBAAE,OAAO,YAAY,CAAC,CAAC,IAAI,EAAE,CAAC;YACjE,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC3C,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,CAAC,CAAC;QAEb,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAClC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC;AAED,gFAAgF;AAChF,+BAA+B;AAC/B,gFAAgF;AAEhF,MAAM,OAAO,iBAAiB;IAC5B;;;OAGG;IACH,MAAM,CAAC,IAAI,CAAC,SAAiB,EAAE,SAAqB;QAClD,MAAM,SAAS,GAAG,YAAY,EAAE,CAAC;QACjC,IAAI,CAAC,SAAS;YAAE,OAAO,CAAC,mBAAmB;QAE3C,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;QAE/D,+EAA+E;QAC/E,MAAM,GAAG,GAAsB;YAC7B,MAAM,EAAE,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,8BAA8B;YACjE,OAAO,EAAE;gBACP,WAAW,EAAE,CAAC;gBACd,cAAc,EAAE,CAAC;gBACjB,eAAe,EAAE,CAAC;gBAClB,SAAS,EAAE,CAAC;aACb;YACD,SAAS;YACT,UAAU;YACV,SAAS;YACT,WAAW,EAAE,OAAO,CAAC,OAAO,EAAE;YAC9B,WAAW,EAAE,KAAK;YAClB,4DAA4D;YAC5D,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,IAAI;YACd,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE;gBACX,KAAK,EAAE,IAAI;gBACX,SAAS,EAAE,IAAI;gBACf,UAAU,EAAE,IAAI;gBAChB,GAAG,EAAE,IAAI;gBACT,GAAG,EAAE,IAAI;gBACT,KAAK,EAAE,IAAI;aACZ;SACF,CAAC;QAEF,iDAAiD;QACjD,GAAG,CAAC,WAAW,GAAG,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAE9D,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,SAAS,CAC5B,GAAsB,EACtB,SAAqB;QAErB,IAAI,CAAC;YACH,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAE7D,IAAI,SAAS,EAAE,CAAC;gBACd,MAAM,gBAAgB,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;gBACpD,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;gBAClE,MAAM,EAAE,CAAC,QAAQ,CAAC,SAAS,CACzB,eAAe,EACf,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAC,EACzC,OAAO,CACR,CAAC;YACJ,CAAC;YAED,mCAAmC;YACnC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;YAClE,IAAI,CAAC;gBACH,IAAI,CAAC;oBACH,MAAM,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBACvC,CAAC;gBAAC,MAAM,CAAC;oBACP,0BAA0B;gBAC5B,CAAC;gBACD,MAAM,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;YAC9D,CAAC;YAAC,MAAM,CAAC;gBACP,6DAA6D;YAC/D,CAAC;YAED,sBAAsB;YACtB,MAAM,GAAG,GAAG,GAAG,CAAC,UAAU,CAAC;YAC3B,GAAG,CAAC,WAAW,CAAC,KAAK,GAAG,EAAE,CAAC,iBAAiB,CAC1C,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAClC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YACF,GAAG,CAAC,WAAW,CAAC,SAAS,GAAG,EAAE,CAAC,iBAAiB,CAC9C,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,EACtC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YACF,GAAG,CAAC,WAAW,CAAC,UAAU,GAAG,EAAE,CAAC,iBAAiB,CAC/C,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,uBAAuB,CAAC,EACvC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YACF,GAAG,CAAC,WAAW,CAAC,GAAG,GAAG,EAAE,CAAC,iBAAiB,CACxC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAChC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YACF,GAAG,CAAC,WAAW,CAAC,GAAG,GAAG,EAAE,CAAC,iBAAiB,CACxC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAChC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YACF,GAAG,CAAC,WAAW,CAAC,KAAK,GAAG,EAAE,CAAC,iBAAiB,CAC1C,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,EACtC,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAC;YAEF,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;YAEvB,+DAA+D;YAC/D,MAAM,OAAO,GAAuB;gBAClC,EAAE,MAAM,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE;gBAClC,EAAE,MAAM,EAAE,kBAAkB,CAAC,GAAG,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE;gBACzD,EAAE,MAAM,EAAE,kBAAkB,CAAC,GAAG,EAAE,eAAe,EAAE,WAAW,CAAC,EAAE;gBACjE,EAAE,MAAM,EAAE,kBAAkB,CAAC,GAAG,EAAE,kBAAkB,EAAE,YAAY,CAAC,EAAE;gBACrE,EAAE,MAAM,EAAE,kBAAkB,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE;gBACjD,EAAE,MAAM,EAAE,kBAAkB,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE;aAClD,CAAC;YAEF,4EAA4E;YAC5E,GAAG,CAAC,MAAM,GAAG,IAAI,CACf;gBACE,KAAK,EAAE,MAAM;gBACb,2DAA2D;gBAC3D,KAAK;oBACH,MAAM,KAAK,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;oBACvC,OAAO;wBACL,OAAO,EAAE,MAAM,EAAE;wBACjB,SAAS,EAAE,KAAK,EAAE,SAAS;wBAC3B,MAAM,EAAE,KAAK,EAAE,MAAM;wBACrB,MAAM,EAAE,KAAK,EAAE,MAAM;wBACrB,SAAS,EAAE,KAAK,EAAE,SAAS;wBAC3B,QAAQ,EAAE,KAAK,EAAE,QAAQ;wBACzB,WAAW,EAAE,KAAK,EAAE,WAAW;qBAChC,CAAC;gBACJ,CAAC;aACF,EACD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAC1B,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,gBAAgB;QAClB,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,GAAG,CAAC,WAAW,CAAC;QACtB,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QAC1C,MAAM,OAAO,CAAC,GAAG,CACf,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC;aAC3B,MAAM,CAAC,OAAO,CAAC;aACf,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,OAAO,CAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CACnD,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACpB,CAAC;IAED,MAAM,KAAK,SAAS;QAClB,OAAO,aAAa,CAAC,QAAQ,EAAE,EAAE,SAAS,IAAI,IAAI,CAAC;IACrD,CAAC;IAED,MAAM,KAAK,UAAU;QACnB,OAAO,aAAa,CAAC,QAAQ,EAAE,EAAE,UAAU,IAAI,IAAI,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU;QACf,OAAO,aAAa,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC;IAC1C,CAAC;IAED,8EAA8E;IAC9E,oBAAoB;IACpB,8EAA8E;IAE9E;;OAEG;IACH,MAAM,CAAC,mBAAmB,CAAC,EACzB,UAAU,EACV,IAAI,GAIL;QACC,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QAEjB,sBAAsB;QACtB,GAAG,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC;QACtB,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;QAClB,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;QAEvB,6BAA6B;QAC7B,GAAG,CAAC,OAAO,GAAG;YACZ,aAAa,EAAE,IAAI,CAAC,GAAG,EAAE;YACzB,WAAW,EAAE,CAAC;YACd,cAAc,EAAE,CAAC;YACjB,eAAe,EAAE,CAAC;YAClB,SAAS,EAAE,CAAC;SACb,CAAC;QAEF,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,WAAW;YACrB,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE,IAAI;SACA,CAAC,CAAC;IAClB,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,qBAAqB,CAAC,OAAgC;QAC3D,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,aAAa;YAAE,OAAO;QAE/C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;QAE1D,MAAM,KAAK,GAAuB;YAChC,QAAQ,EAAE,WAAW;YACrB,KAAK,EAAE,WAAW;YAClB,MAAM,EAAE,eAAe;YACvB,OAAO,EAAE;gBACP,UAAU;gBACV,WAAW,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW;gBACpC,WAAW,EAAE,GAAG,CAAC,OAAO,CAAC,cAAc;gBACvC,YAAY,EAAE,GAAG,CAAC,OAAO,CAAC,eAAe;gBACzC,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,SAAS;aACjC;SACF,CAAC;QAEF,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;YACtB,KAAK,CAAC,GAAG,GAAG,0BAA0B,CAAC;QACzC,CAAC;QAED,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEvB,qBAAqB;QACrB,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;QAClB,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;QAClB,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;QACvB,GAAG,CAAC,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC;IACxC,CAAC;IAED,8EAA8E;IAC9E,wBAAwB;IACxB,8EAA8E;IAE9E,MAAM,CAAC,qBAAqB,CAAC,EAC3B,UAAU,EACV,IAAI,EACJ,KAAK,GAKN;QACC,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO,MAAM,EAAE,CAAC;QAE1B,sBAAsB;QACtB,GAAG,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC;QACtB,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;QACpC,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;QACvB,GAAG,CAAC,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,eAAe;YACzB,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE,IAAI;SACA,CAAC,CAAC;QAEhB,OAAO,GAAG,CAAC,MAAM,CAAC;IACpB,CAAC;IAED,MAAM,CAAC,yBAAyB;QAC9B,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM;YAAE,OAAO;QAEhC,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa;YAC1C,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa;YACxC,CAAC,CAAC,CAAC,CAAC;QAEN,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,eAAe;YACzB,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,EAAE,UAAU,EAAE;SACX,CAAC,CAAC;QAEhB,qBAAqB;QACrB,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;QAClB,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;QACvB,GAAG,CAAC,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC;IACxC,CAAC;IAED,8EAA8E;IAC9E,2BAA2B;IAC3B,8EAA8E;IAE9E,MAAM,CAAC,wBAAwB,CAAC,EAC9B,UAAU,EACV,MAAM,EACN,IAAI,GAKL;QACC,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO,MAAM,EAAE,CAAC;QAE1B,wBAAwB;QACxB,GAAG,CAAC,QAAQ,GAAG,MAAM,EAAE,CAAC;QACxB,GAAG,CAAC,WAAW,GAAG,UAAU;aACzB,WAAW,EAAE;aACb,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC;aAC1B,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACxB,GAAG,CAAC,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEzC,MAAM,MAAM,GAA4B,EAAE,CAAC;QAC3C,IAAI,MAAM;YAAE,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;QACnC,IAAI,IAAI;YAAE,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;QAE7B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,kBAAkB;YAC5B,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;SAC/C,CAAC,CAAC;QAEhB,OAAO,GAAG,CAAC,QAAQ,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,4BAA4B;QACjC,MAAM,GAAG,GAAG,aAAa,CAAC,QAAQ,EAAE,CAAC;QACrC,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ;YAAE,OAAO;QAElC,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,eAAe;YAC5C,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,eAAe;YAC1C,CAAC,CAAC,CAAC,CAAC;QAEN,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,kBAAkB;YAC5B,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,EAAE,UAAU,EAAE;SACX,CAAC,CAAC;QAEhB,uBAAuB;QACvB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;QACpB,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;QACvB,GAAG,CAAC,OAAO,CAAC,eAAe,GAAG,SAAS,CAAC;IAC1C,CAAC;IAED,8EAA8E;IAC9E,aAAa;IACb,8EAA8E;IAEtE,MAAM,CAAC,WAAW,CACxB,SAA6B,EAC7B,EACE,MAAM,EACN,MAAM,EACN,QAAQ,GACuD,EACjE,WAAsC;QAEtC,MAAM,GAAG,GAAG,WAAW,IAAI,aAAa,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,IAAI,SAAS,KAAK,MAAM;YAAE,GAAG,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QAClD,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,KAAK;YACf,KAAK,EAAE,SAAS;YAChB,MAAM;YACN,MAAM;YACN,QAAQ;SACI,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,eAAe,CACpB,IAAmE,EACnE,GAA8B;QAE9B,iBAAiB,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,kBAAkB,CACvB,IAAoE,EACpE,GAA8B;QAE9B,iBAAiB,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IACtD,CAAC;IAED,8EAA8E;IAC9E,aAAa;IACb,8EAA8E;IAE9E,MAAM,CAAC,aAAa,CAClB,EACE,SAAS,EACT,KAAK,EACL,MAAM,GAMP,EACD,WAAsC;QAEtC,MAAM,GAAG,GAAG,WAAW,IAAI,aAAa,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,GAAG;YAAE,OAAO;QAEjB,sCAAsC;QACtC,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QAE1B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,KAAK;YACf,KAAK,EAAE,SAAS;YAChB,SAAS;YACT,MAAM,EAAE,aAAa;YACrB,KAAK;YACL,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,cAAc,CACnB,EACE,SAAS,EACT,KAAK,EACL,MAAM,EACN,WAAW,EACX,YAAY,GAQb,EACD,WAAsC;QAEtC,MAAM,GAAG,GAAG,WAAW,IAAI,aAAa,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,GAAG;YAAE,OAAO;QAEjB,gCAAgC;QAChC,GAAG,CAAC,OAAO,CAAC,cAAc,IAAI,WAAW,IAAI,CAAC,CAAC;QAC/C,GAAG,CAAC,OAAO,CAAC,eAAe,IAAI,YAAY,IAAI,CAAC,CAAC;QAEjD,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;YACd,QAAQ,EAAE,KAAK;YACf,KAAK,EAAE,UAAU;YACjB,SAAS;YACT,MAAM,EAAE,cAAc;YACtB,KAAK;YACL,MAAM;YACN,WAAW;YACX,YAAY;SACb,CAAC,CAAC;IACL,CAAC;IAED,8EAA8E;IAC9E,yBAAyB;IACzB,8EAA8E;IAE9E;;;OAGG;IACH,MAAM,CAAC,0BAA0B,CAC/B,OAAe;QAEf,4CAA4C;QAC5C,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO;gBACL,YAAY,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,UAAU,EAAE;aACrD,CAAC;QACJ,CAAC;QAED,OAAO;YACL,YAAY,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE;gBAC7C,MAAM,GAAG,GAAG,iBAAiB,CAAC,UAAU,EAAE,CAAC;gBAC3C,qEAAqE;gBACrE,IAAI,CAAC,GAAG,EAAE,CAAC;oBACT,OAAO,UAAU,EAAE,CAAC;gBACtB,CAAC;gBACD,MAAM,YAAY,GAAG,MAAM,EAAE,CAAC;gBAC9B,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBAExE,sDAAsD;gBACtD,MAAM,QAAQ,GAAG,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAGnC,CAAC;gBACH,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;gBAClE,MAAM,SAAS,GAAG;oBAChB,IAAI,EAAE,SAA+B;oBACrC,MAAM,EAAE,EAAc;iBACvB,CAAC;gBAEF,IAAI,UAAU,GAAG,OAAO,EAAE,IAAI,IAAI,GAAG,CAAC;gBACtC,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,OAAO,OAAO,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;wBACxC,SAAS,CAAC,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC;oBACnC,CAAC;yBAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;wBAC1C,8BAA8B;wBAC9B,MAAM,UAAU,GACd,OAAO,CAAC,OAKT,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,aAAa,CAAC,CAAC;wBACxC,IAAI,UAAU,EAAE,CAAC;4BACf,UAAU,GAAG,gBAAgB,UAAU,CAAC,QAAQ,IAAI,CAAC;4BACrD,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC;4BAC9B,IAAI,GAAG,EAAE,IAAI,KAAK,MAAM,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;gCACtC,SAAS,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;4BAC3D,CAAC;iCAAM,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC;gCACrC,kBAAkB,CAAC,GAAG,CAAC,KAAkB,EAAE,SAAS,CAAC,CAAC;4BACxD,CAAC;wBACH,CAAC;6BAAM,CAAC;4BACN,kBAAkB,CAAC,OAAO,CAAC,OAAoB,EAAE,SAAS,CAAC,CAAC;wBAC9D,CAAC;oBACH,CAAC;gBACH,CAAC;gBAED,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,IAAI,WAAW,CAAC;gBACjD,MAAM,aAAa,GAAG,GAAG,UAAU,KAAK,UAAU,MAAM,SAAS,SAAS,CAAC;gBAE3E,iBAAiB,CAAC,aAAa,CAC7B;oBACE,SAAS,EAAE,YAAY;oBACvB,KAAK,EAAE,OAAO;oBACd,SAAS,EAAE,cAAc;oBACzB,MAAM,EAAE,aAAa;iBACtB,EACD,GAAG,CACJ,CAAC;gBAEF,MAAM,MAAM,GAAG,MAAM,UAAU,EAAE,CAAC;gBAElC,yBAAyB;gBACzB,MAAM,GAAG,GAAG,MAIX,CAAC;gBACF,IAAI,aAAa,GAAG,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;gBACnC,IAAI,CAAC,aAAa,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;oBAClC,IAAI,OAAO,GAAG,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;wBACpC,aAAa,GAAG,GAAG,CAAC,OAAO,CAAC;oBAC9B,CAAC;yBAAM,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;wBACtC,aAAa,GACX,GAAG,CAAC,OAKL;6BACE,GAAG,CACF,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,IAAI;4BACN,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW;gCACrB,CAAC,CAAC,cAAc,CAAC,CAAC,QAAQ,IAAI;gCAC9B,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CACrB;6BACA,IAAI,CAAC,GAAG,CAAC,CAAC;oBACf,CAAC;gBACH,CAAC;gBACD,IAAI,CAAC,aAAa,IAAI,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;oBAC5C,aAAa,GAAG,IAAI,GAAG,CAAC,SAAS,CAAC,MAAM,cAAc,CAAC;gBACzD,CAAC;gBAED,iBAAiB,CAAC,cAAc,CAC9B;oBACE,SAAS,EAAE,YAAY;oBACvB,KAAK,EAAE,OAAO;oBACd,SAAS,EAAE,cAAc;oBACzB,MAAM,EAAE,aAAa,IAAI,SAAS;oBAClC,WAAW,EAAE,MAAM,CAAC,KAAK,EAAE,WAAW;oBACtC,YAAY,EAAE,MAAM,CAAC,KAAK,EAAE,YAAY;iBACzC,EACD,GAAG,CACJ,CAAC;gBAEF,OAAO,MAAM,CAAC;YAChB,CAAC;SACF,CAAC;IACJ,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,UAAU,SAAS,CAAC,UAAkB;IAC1C,OAAO,UACL,cAAiB;QAEjB,iCAAiC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,cAAc,CAAC;QACxB,CAAC;QAED,OAAO,KAAK,WAA0B,GAAG,IAAe;YACtD,iBAAiB,CAAC,wBAAwB,CAAC;gBACzC,UAAU;gBACV,IAAI,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS;aACzC,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAe,CAAC,CAAC;YAC3D,CAAC;oBAAS,CAAC;gBACT,iBAAiB,CAAC,4BAA4B,EAAE,CAAC;YACnD,CAAC;QACH,CAAM,CAAC;IACT,CAAC,CAAC;AACJ,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,gBAAgB,CAAC,UAAkB,EAAE,KAAa;IAChE,OAAO,UACL,cAAiB;QAEjB,iCAAiC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,cAAc,CAAC;QACxB,CAAC;QAED,OAAO,KAAK,WAEV,GAAG,IAAe;YAElB,iBAAiB,CAAC,qBAAqB,CAAC;gBACtC,UAAU;gBACV,IAAI,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS;gBACxC,KAAK;aACN,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAe,CAAC,CAAC;YAC3D,CAAC;oBAAS,CAAC;gBACT,iBAAiB,CAAC,yBAAyB,EAAE,CAAC;YAChD,CAAC;QACH,CAAM,CAAC;IACT,CAAC,CAAC;AACJ,CAAC","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"]}
|