@probelabs/visor 0.1.183-ee → 0.1.184-ee
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/agent-protocol/task-live-update-slack.d.ts +24 -0
- package/dist/agent-protocol/task-live-update-slack.d.ts.map +1 -0
- package/dist/agent-protocol/task-live-update-teams.d.ts +25 -0
- package/dist/agent-protocol/task-live-update-teams.d.ts.map +1 -0
- package/dist/agent-protocol/task-live-update-telegram.d.ts +25 -0
- package/dist/agent-protocol/task-live-update-telegram.d.ts.map +1 -0
- package/dist/agent-protocol/task-live-updates.d.ts +102 -0
- package/dist/agent-protocol/task-live-updates.d.ts.map +1 -0
- package/dist/agent-protocol/task-progress-tool.d.ts.map +1 -1
- package/dist/agent-protocol/task-trace-resolution.d.ts +11 -0
- package/dist/agent-protocol/task-trace-resolution.d.ts.map +1 -0
- package/dist/agent-protocol/trace-serializer.d.ts.map +1 -1
- package/dist/agent-protocol/track-execution.d.ts +8 -0
- package/dist/agent-protocol/track-execution.d.ts.map +1 -1
- package/dist/cli-main.d.ts.map +1 -1
- package/dist/cli.d.ts.map +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/frontends/slack-frontend.d.ts +2 -0
- package/dist/frontends/slack-frontend.d.ts.map +1 -1
- package/dist/frontends/teams-frontend.d.ts.map +1 -1
- package/dist/frontends/telegram-frontend.d.ts.map +1 -1
- package/dist/generated/config-schema.d.ts +110 -6
- package/dist/generated/config-schema.d.ts.map +1 -1
- package/dist/index.js +2239 -261
- package/dist/logger.d.ts +4 -1
- package/dist/logger.d.ts.map +1 -1
- package/dist/mcp-job-manager.d.ts +70 -0
- package/dist/mcp-job-manager.d.ts.map +1 -0
- package/dist/mcp-server.d.ts +6 -0
- package/dist/mcp-server.d.ts.map +1 -1
- package/dist/runners/mcp-server-runner.d.ts +4 -0
- package/dist/runners/mcp-server-runner.d.ts.map +1 -1
- package/dist/runners/runner-factory.d.ts.map +1 -1
- package/dist/sdk/{a2a-frontend-5YDHFQXD.mjs → a2a-frontend-OI4OVSKC.mjs} +4 -4
- package/dist/sdk/check-provider-registry-RITJW67U.mjs +32 -0
- package/dist/sdk/check-provider-registry-ZZ6N4GDP.mjs +32 -0
- package/dist/sdk/{chunk-4BN2XI4X.mjs → chunk-4HIWZA6M.mjs} +2 -2
- package/dist/sdk/{chunk-RI4ONH5X.mjs → chunk-4MHHELVZ.mjs} +2 -2
- package/dist/sdk/{chunk-J27D43HS.mjs → chunk-4ZLYHSN4.mjs} +2 -2
- package/dist/sdk/{chunk-ZPYODGYA.mjs → chunk-6E625R3C.mjs} +19 -4
- package/dist/sdk/chunk-6E625R3C.mjs.map +1 -0
- package/dist/sdk/{chunk-GA2TYKSR.mjs → chunk-7XKHFRPN.mjs} +4 -4
- package/dist/sdk/{chunk-6C3R6E42.mjs → chunk-IY5PQ5EN.mjs} +30 -6
- package/dist/sdk/chunk-IY5PQ5EN.mjs.map +1 -0
- package/dist/sdk/{chunk-MFXPJUUE.mjs → chunk-PUHU6UY6.mjs} +4 -3
- package/dist/sdk/chunk-PUHU6UY6.mjs.map +1 -0
- package/dist/sdk/{chunk-XOAEKFKB.mjs → chunk-QLT42TX7.mjs} +2 -2
- package/dist/sdk/chunk-SRU5TFNY.mjs +620 -0
- package/dist/sdk/chunk-SRU5TFNY.mjs.map +1 -0
- package/dist/sdk/{chunk-P2K4VOMU.mjs → chunk-TSX3YS3F.mjs} +3 -3
- package/dist/sdk/{chunk-WKLJ57WF.mjs → chunk-UM7LGO2P.mjs} +6 -6
- package/dist/sdk/{chunk-7VTZDC2X.mjs → chunk-VPPBOKBQ.mjs} +2 -2
- package/dist/sdk/chunk-WZQMTD7W.mjs +33 -0
- package/dist/sdk/chunk-WZQMTD7W.mjs.map +1 -0
- package/dist/sdk/{chunk-ZOF5QT6U.mjs → chunk-YBXNG75V.mjs} +118 -10
- package/dist/sdk/chunk-YBXNG75V.mjs.map +1 -0
- package/dist/sdk/{chunk-UXB4XWEE.mjs → chunk-YYFSAAD6.mjs} +53 -51
- package/dist/sdk/chunk-YYFSAAD6.mjs.map +1 -0
- package/dist/sdk/{chunk-RHKPFJLG.mjs → chunk-ZNKL6ESZ.mjs} +2 -2
- package/dist/sdk/{chunk-IDL3AA3G.mjs → chunk-ZYDRR6PZ.mjs} +1150 -403
- package/dist/sdk/chunk-ZYDRR6PZ.mjs.map +1 -0
- package/dist/sdk/{command-executor-YNJOS77A.mjs → command-executor-LHUW77GR.mjs} +3 -3
- package/dist/sdk/{config-PCP6O6Y6.mjs → config-TVU5RWR5.mjs} +3 -3
- package/dist/sdk/{dist-3UGGEZB3.mjs → dist-PN5UHL6A.mjs} +429 -429
- package/dist/sdk/dist-PN5UHL6A.mjs.map +1 -0
- package/dist/sdk/{email-frontend-WSNADJPI.mjs → email-frontend-ECHQCFTR.mjs} +2 -2
- package/dist/sdk/{failure-condition-evaluator-IRFKTYZD.mjs → failure-condition-evaluator-USY3ISVA.mjs} +6 -6
- package/dist/sdk/{github-auth-BJQBLK2V.mjs → github-auth-UO4DMNCC.mjs} +2 -2
- package/dist/sdk/{github-frontend-DECYOBRN.mjs → github-frontend-2T5PWYD5.mjs} +6 -6
- package/dist/sdk/{host-CFM2ASDI.mjs → host-OJSMCLKK.mjs} +6 -6
- package/dist/sdk/{host-T4LNVU2H.mjs → host-RM6UJEPP.mjs} +7 -7
- package/dist/sdk/{knex-store-OEWSZEBY.mjs → knex-store-KCMFAMH5.mjs} +2 -2
- package/dist/sdk/{liquid-extensions-E3AKRX7P.mjs → liquid-extensions-KZIRR4OY.mjs} +4 -4
- package/dist/sdk/{loader-WRGI244P.mjs → loader-35YWX5UQ.mjs} +4 -4
- package/dist/sdk/{memory-store-OHUIXCWJ.mjs → memory-store-3JONK7AF.mjs} +3 -3
- package/dist/sdk/{opa-policy-engine-IVMCGVNA.mjs → opa-policy-engine-FY5D45YS.mjs} +2 -2
- package/dist/sdk/{prompt-state-LN57DQF3.mjs → prompt-state-VVJMONT3.mjs} +3 -3
- package/dist/sdk/{renderer-schema-BT2IXMLW.mjs → renderer-schema-JZRRU5CW.mjs} +2 -2
- package/dist/sdk/{routing-H2PQ57OA.mjs → routing-NNQQSLWA.mjs} +8 -8
- package/dist/sdk/{schedule-tool-2DPNSU63.mjs → schedule-tool-ADZ2ON4I.mjs} +15 -14
- package/dist/sdk/schedule-tool-EMNF3FPQ.mjs +38 -0
- package/dist/sdk/{schedule-tool-handler-NBEO46RV.mjs → schedule-tool-handler-3R3IC6VA.mjs} +15 -14
- package/dist/sdk/{schedule-tool-handler-KLHE2SOW.mjs → schedule-tool-handler-F76ZD2WU.mjs} +17 -16
- package/dist/sdk/sdk.d.mts +40 -0
- package/dist/sdk/sdk.d.ts +40 -0
- package/dist/sdk/sdk.js +1154 -176
- package/dist/sdk/sdk.js.map +1 -1
- package/dist/sdk/sdk.mjs +14 -13
- package/dist/sdk/sdk.mjs.map +1 -1
- package/dist/sdk/{slack-frontend-DF5VL4OF.mjs → slack-frontend-K3TPGERM.mjs} +65 -9
- package/dist/sdk/slack-frontend-K3TPGERM.mjs.map +1 -0
- package/dist/sdk/{task-evaluator-OVMG7S56.mjs → task-evaluator-H3BXC7SE.mjs} +3 -3
- package/dist/sdk/{teams-frontend-DNW5GZP3.mjs → teams-frontend-6RRW533K.mjs} +54 -1
- package/dist/sdk/teams-frontend-6RRW533K.mjs.map +1 -0
- package/dist/sdk/{telegram-frontend-GA7OLADB.mjs → telegram-frontend-5UA77YAT.mjs} +48 -1
- package/dist/sdk/telegram-frontend-5UA77YAT.mjs.map +1 -0
- package/dist/sdk/{trace-helpers-26ZCAE2V.mjs → trace-helpers-OMF4C24T.mjs} +3 -3
- package/dist/sdk/{trace-serializer-KKBJHM7J.mjs → trace-serializer-EBHTHZYT.mjs} +3 -3
- package/dist/sdk/track-execution-3CHMGEPH.mjs +249 -0
- package/dist/sdk/track-execution-3CHMGEPH.mjs.map +1 -0
- package/dist/sdk/{utcp-check-provider-WI3QZ3W6.mjs → utcp-check-provider-Q4PD5EP2.mjs} +5 -5
- package/dist/sdk/workflow-check-provider-TC2G33WF.mjs +32 -0
- package/dist/sdk/workflow-check-provider-U4UXZ5YS.mjs +32 -0
- package/dist/sdk/{workflow-registry-YCZ3FCJC.mjs → workflow-registry-K56UTX36.mjs} +3 -3
- package/dist/slack/client.d.ts +14 -0
- package/dist/slack/client.d.ts.map +1 -1
- package/dist/slack/socket-runner.d.ts.map +1 -1
- package/dist/teams/client.d.ts +16 -0
- package/dist/teams/client.d.ts.map +1 -1
- package/dist/teams/webhook-runner.d.ts.map +1 -1
- package/dist/telegram/client.d.ts +17 -0
- package/dist/telegram/client.d.ts.map +1 -1
- package/dist/telegram/polling-runner.d.ts.map +1 -1
- package/dist/types/cli.d.ts +2 -0
- package/dist/types/cli.d.ts.map +1 -1
- package/dist/types/config.d.ts +40 -0
- package/dist/types/config.d.ts.map +1 -1
- package/package.json +4 -3
- package/dist/generated/config-schema.json +0 -4027
- package/dist/sdk/a2a-frontend-6LWBIPMS.mjs +0 -1734
- package/dist/sdk/a2a-frontend-6LWBIPMS.mjs.map +0 -1
- package/dist/sdk/check-provider-registry-WSEVHJEV.mjs +0 -31
- package/dist/sdk/check-provider-registry-YRADEEQY.mjs +0 -31
- package/dist/sdk/chunk-34QX63WK.mjs +0 -244
- package/dist/sdk/chunk-34QX63WK.mjs.map +0 -1
- package/dist/sdk/chunk-54KOAC4W.mjs +0 -665
- package/dist/sdk/chunk-6C3R6E42.mjs.map +0 -1
- package/dist/sdk/chunk-7W5QCO4Y.mjs +0 -5943
- package/dist/sdk/chunk-7W5QCO4Y.mjs.map +0 -1
- package/dist/sdk/chunk-7XRSCOKE.mjs +0 -825
- package/dist/sdk/chunk-FT3I25QV.mjs +0 -251
- package/dist/sdk/chunk-FT3I25QV.mjs.map +0 -1
- package/dist/sdk/chunk-G7GSN3SK.mjs +0 -390
- package/dist/sdk/chunk-G7GSN3SK.mjs.map +0 -1
- package/dist/sdk/chunk-IDL3AA3G.mjs.map +0 -1
- package/dist/sdk/chunk-J27D43HS.mjs.map +0 -1
- package/dist/sdk/chunk-MEB2TTIE.mjs +0 -157
- package/dist/sdk/chunk-MEB2TTIE.mjs.map +0 -1
- package/dist/sdk/chunk-MFXPJUUE.mjs.map +0 -1
- package/dist/sdk/chunk-NPSLGKXB.mjs +0 -1502
- package/dist/sdk/chunk-P2K4VOMU.mjs.map +0 -1
- package/dist/sdk/chunk-PQWZ6NFL.mjs +0 -459
- package/dist/sdk/chunk-PQWZ6NFL.mjs.map +0 -1
- package/dist/sdk/chunk-S5FSRHMY.mjs +0 -139
- package/dist/sdk/chunk-S5FSRHMY.mjs.map +0 -1
- package/dist/sdk/chunk-TFUQ2D5L.mjs +0 -307
- package/dist/sdk/chunk-TFUQ2D5L.mjs.map +0 -1
- package/dist/sdk/chunk-UCMJJ3IM.mjs +0 -227
- package/dist/sdk/chunk-UCMJJ3IM.mjs.map +0 -1
- package/dist/sdk/chunk-UFHOIB3R.mjs +0 -482
- package/dist/sdk/chunk-UFHOIB3R.mjs.map +0 -1
- package/dist/sdk/chunk-UXB4XWEE.mjs.map +0 -1
- package/dist/sdk/chunk-V45TITKX.mjs +0 -739
- package/dist/sdk/chunk-V45TITKX.mjs.map +0 -1
- package/dist/sdk/chunk-WKLJ57WF.mjs.map +0 -1
- package/dist/sdk/chunk-ZOF5QT6U.mjs.map +0 -1
- package/dist/sdk/chunk-ZPYODGYA.mjs.map +0 -1
- package/dist/sdk/command-executor-3AHGIYQG.mjs +0 -14
- package/dist/sdk/config-JE4HKTWW.mjs +0 -16
- package/dist/sdk/dist-3UGGEZB3.mjs.map +0 -1
- package/dist/sdk/failure-condition-evaluator-H3PBFBYT.mjs +0 -18
- package/dist/sdk/github-auth-27SZGPEC.mjs +0 -196
- package/dist/sdk/github-auth-BJQBLK2V.mjs.map +0 -1
- package/dist/sdk/github-frontend-TZRBOQCN.mjs +0 -1394
- package/dist/sdk/github-frontend-TZRBOQCN.mjs.map +0 -1
- package/dist/sdk/lazy-otel-5NH4ZJJM.mjs +0 -24
- package/dist/sdk/liquid-extensions-P6KDYILF.mjs +0 -25
- package/dist/sdk/memory-store-K5N7MC7U.mjs +0 -12
- package/dist/sdk/metrics-JTOG2HNO.mjs +0 -41
- package/dist/sdk/prompt-state-YPICX7PI.mjs +0 -16
- package/dist/sdk/renderer-schema-KOIH75RZ.mjs +0 -51
- package/dist/sdk/renderer-schema-KOIH75RZ.mjs.map +0 -1
- package/dist/sdk/routing-JMZ7HDCC.mjs +0 -26
- package/dist/sdk/schedule-tool-4M45RK3E.mjs +0 -37
- package/dist/sdk/schedule-tool-4M45RK3E.mjs.map +0 -1
- package/dist/sdk/schedule-tool-handler-KLHE2SOW.mjs.map +0 -1
- package/dist/sdk/schedule-tool-handler-NBEO46RV.mjs.map +0 -1
- package/dist/sdk/slack-frontend-BPWXNIHE.mjs +0 -929
- package/dist/sdk/slack-frontend-BPWXNIHE.mjs.map +0 -1
- package/dist/sdk/slack-frontend-DF5VL4OF.mjs.map +0 -1
- package/dist/sdk/task-evaluator-GQYDOSGT.mjs +0 -1392
- package/dist/sdk/task-evaluator-GQYDOSGT.mjs.map +0 -1
- package/dist/sdk/teams-frontend-DNW5GZP3.mjs.map +0 -1
- package/dist/sdk/telegram-frontend-GA7OLADB.mjs.map +0 -1
- package/dist/sdk/trace-helpers-26ZCAE2V.mjs.map +0 -1
- package/dist/sdk/trace-helpers-XV5GAX5L.mjs +0 -29
- package/dist/sdk/trace-helpers-XV5GAX5L.mjs.map +0 -1
- package/dist/sdk/trace-serializer-KKBJHM7J.mjs.map +0 -1
- package/dist/sdk/track-execution-3EC24C2X.mjs +0 -163
- package/dist/sdk/track-execution-3EC24C2X.mjs.map +0 -1
- package/dist/sdk/track-execution-66RLL6QT.mjs +0 -143
- package/dist/sdk/track-execution-66RLL6QT.mjs.map +0 -1
- package/dist/sdk/utcp-check-provider-JLIYF5HH.mjs +0 -16
- package/dist/sdk/utcp-check-provider-JLIYF5HH.mjs.map +0 -1
- package/dist/sdk/utcp-check-provider-WI3QZ3W6.mjs.map +0 -1
- package/dist/sdk/workflow-check-provider-X2UREEH7.mjs +0 -31
- package/dist/sdk/workflow-check-provider-X2UREEH7.mjs.map +0 -1
- package/dist/sdk/workflow-check-provider-YXALZNAQ.mjs +0 -31
- package/dist/sdk/workflow-check-provider-YXALZNAQ.mjs.map +0 -1
- package/dist/sdk/workflow-registry-X2IPY35M.mjs +0 -12
- package/dist/sdk/workflow-registry-X2IPY35M.mjs.map +0 -1
- package/dist/sdk/workflow-registry-YCZ3FCJC.mjs.map +0 -1
- /package/dist/sdk/{a2a-frontend-5YDHFQXD.mjs.map → a2a-frontend-OI4OVSKC.mjs.map} +0 -0
- /package/dist/sdk/{check-provider-registry-WSEVHJEV.mjs.map → check-provider-registry-RITJW67U.mjs.map} +0 -0
- /package/dist/sdk/{check-provider-registry-YRADEEQY.mjs.map → check-provider-registry-ZZ6N4GDP.mjs.map} +0 -0
- /package/dist/sdk/{chunk-4BN2XI4X.mjs.map → chunk-4HIWZA6M.mjs.map} +0 -0
- /package/dist/sdk/{chunk-RI4ONH5X.mjs.map → chunk-4MHHELVZ.mjs.map} +0 -0
- /package/dist/sdk/{chunk-54KOAC4W.mjs.map → chunk-4ZLYHSN4.mjs.map} +0 -0
- /package/dist/sdk/{chunk-GA2TYKSR.mjs.map → chunk-7XKHFRPN.mjs.map} +0 -0
- /package/dist/sdk/{chunk-XOAEKFKB.mjs.map → chunk-QLT42TX7.mjs.map} +0 -0
- /package/dist/sdk/{chunk-7XRSCOKE.mjs.map → chunk-TSX3YS3F.mjs.map} +0 -0
- /package/dist/sdk/{chunk-NPSLGKXB.mjs.map → chunk-UM7LGO2P.mjs.map} +0 -0
- /package/dist/sdk/{chunk-7VTZDC2X.mjs.map → chunk-VPPBOKBQ.mjs.map} +0 -0
- /package/dist/sdk/{chunk-RHKPFJLG.mjs.map → chunk-ZNKL6ESZ.mjs.map} +0 -0
- /package/dist/sdk/{command-executor-3AHGIYQG.mjs.map → command-executor-LHUW77GR.mjs.map} +0 -0
- /package/dist/sdk/{command-executor-YNJOS77A.mjs.map → config-TVU5RWR5.mjs.map} +0 -0
- /package/dist/sdk/{email-frontend-WSNADJPI.mjs.map → email-frontend-ECHQCFTR.mjs.map} +0 -0
- /package/dist/sdk/{config-JE4HKTWW.mjs.map → failure-condition-evaluator-USY3ISVA.mjs.map} +0 -0
- /package/dist/sdk/{github-auth-27SZGPEC.mjs.map → github-auth-UO4DMNCC.mjs.map} +0 -0
- /package/dist/sdk/{github-frontend-DECYOBRN.mjs.map → github-frontend-2T5PWYD5.mjs.map} +0 -0
- /package/dist/sdk/{host-CFM2ASDI.mjs.map → host-OJSMCLKK.mjs.map} +0 -0
- /package/dist/sdk/{host-T4LNVU2H.mjs.map → host-RM6UJEPP.mjs.map} +0 -0
- /package/dist/sdk/{knex-store-OEWSZEBY.mjs.map → knex-store-KCMFAMH5.mjs.map} +0 -0
- /package/dist/sdk/{config-PCP6O6Y6.mjs.map → liquid-extensions-KZIRR4OY.mjs.map} +0 -0
- /package/dist/sdk/{loader-WRGI244P.mjs.map → loader-35YWX5UQ.mjs.map} +0 -0
- /package/dist/sdk/{failure-condition-evaluator-H3PBFBYT.mjs.map → memory-store-3JONK7AF.mjs.map} +0 -0
- /package/dist/sdk/{opa-policy-engine-IVMCGVNA.mjs.map → opa-policy-engine-FY5D45YS.mjs.map} +0 -0
- /package/dist/sdk/{failure-condition-evaluator-IRFKTYZD.mjs.map → prompt-state-VVJMONT3.mjs.map} +0 -0
- /package/dist/sdk/{renderer-schema-BT2IXMLW.mjs.map → renderer-schema-JZRRU5CW.mjs.map} +0 -0
- /package/dist/sdk/{lazy-otel-5NH4ZJJM.mjs.map → routing-NNQQSLWA.mjs.map} +0 -0
- /package/dist/sdk/{liquid-extensions-E3AKRX7P.mjs.map → schedule-tool-ADZ2ON4I.mjs.map} +0 -0
- /package/dist/sdk/{liquid-extensions-P6KDYILF.mjs.map → schedule-tool-EMNF3FPQ.mjs.map} +0 -0
- /package/dist/sdk/{memory-store-K5N7MC7U.mjs.map → schedule-tool-handler-3R3IC6VA.mjs.map} +0 -0
- /package/dist/sdk/{memory-store-OHUIXCWJ.mjs.map → schedule-tool-handler-F76ZD2WU.mjs.map} +0 -0
- /package/dist/sdk/{task-evaluator-OVMG7S56.mjs.map → task-evaluator-H3BXC7SE.mjs.map} +0 -0
- /package/dist/sdk/{metrics-JTOG2HNO.mjs.map → trace-helpers-OMF4C24T.mjs.map} +0 -0
- /package/dist/sdk/{prompt-state-LN57DQF3.mjs.map → trace-serializer-EBHTHZYT.mjs.map} +0 -0
- /package/dist/sdk/{prompt-state-YPICX7PI.mjs.map → utcp-check-provider-Q4PD5EP2.mjs.map} +0 -0
- /package/dist/sdk/{routing-H2PQ57OA.mjs.map → workflow-check-provider-TC2G33WF.mjs.map} +0 -0
- /package/dist/sdk/{routing-JMZ7HDCC.mjs.map → workflow-check-provider-U4UXZ5YS.mjs.map} +0 -0
- /package/dist/sdk/{schedule-tool-2DPNSU63.mjs.map → workflow-registry-K56UTX36.mjs.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/agent-protocol/task-live-updates.ts"],"sourcesContent":["import crypto from 'crypto';\nimport { logger } from '../logger';\nimport type { TaskLiveUpdatesConfig } from '../types/config';\nimport { fetchTraceSpans, serializeTraceForPrompt } from './trace-serializer';\n\nexport const DEFAULT_TASK_LIVE_UPDATE_INTERVAL_SECONDS = 10;\nexport const DEFAULT_TASK_LIVE_UPDATE_MAX_TRACE_CHARS = 12_000;\nexport const DEFAULT_TASK_LIVE_UPDATE_FIRST_UPDATE_DELAY_SECONDS = 10;\nexport const DEFAULT_TASK_LIVE_UPDATE_METADATA_REFRESH_SECONDS = 5;\nexport const DEFAULT_TASK_LIVE_UPDATE_STALL_FALLBACK_SECONDS = 60;\nexport const DEFAULT_TASK_LIVE_UPDATE_MODEL = 'gemini-3.1-flash-lite-preview';\nconst DEFAULT_TASK_LIVE_UPDATE_STALL_NOTICE =\n '_No new meaningful progress is visible yet. Some steps can stay quiet for up to 5 minutes before there is new news._';\n\nexport const DEFAULT_TASK_LIVE_UPDATE_PROMPT = `You are generating a short live progress update for a user while an AI task is still running.\n\nThis is NOT the final answer.\nDo NOT answer the user's original request.\nDo NOT write the final solution.\nDo NOT explain the topic in full.\nDo NOT provide a root cause, recommendation, summary of findings, or conclusion.\nEven if you think you already know the answer, do NOT give it here.\n\nYou will receive:\n- the user's original request\n- the previous progress update, if any\n- timing metadata for this run\n- the latest execution trace snapshot\n\nYour job is to produce a concise status update that tells the user only:\n- the overall progress so far\n- the last meaningful action that finished\n- what the agent is doing right now\n- what it is likely waiting on, if anything\n\nRules:\n- This is a STATUS UPDATE, not the final answer\n- Never answer the user's request directly\n- Never switch into explanation mode\n- Never write a complete answer, even partially\n- Keep it short: exactly 4 short bullet points\n- Use the exact bullet labels below\n- Do NOT generate timing metadata lines\n- Do NOT generate task_id lines\n- Timing metadata is provided only so you understand task pace and recency\n- The system will append timing and task metadata separately\n- Prefer concrete progress over generic wording\n- Mention the most recent completed action before the current action\n- Do not claim completion unless the task is actually done\n- Do not mention internal implementation details unless they help explain the current work\n- Avoid repeating the previous update verbatim\n- Do not use code fences\n- Plain markdown text only\n\nRequired output format:\n- Progress: <very short overall progress statement, not a final answer>\n- Last done: <most recent completed action>\n- Now: <current action in progress>\n- Waiting on: <tool, search, model, user input, or \"nothing blocking right now\">\n\nTrace interpretation rules:\n- Translate internal trace phases into user-meaningful progress, do not just repeat raw span names\n- If the trace shows routing or classify work, describe that as understanding the request and choosing the right path\n- If the trace shows setup-projects, build-config, or loading context, describe that as preparing the workspace or gathering context\n- If the trace shows search, extract, code-explorer, or file inspection, describe that as investigating the codebase\n- If the trace shows engineer work, edits, tests, PR creation, or command execution, describe that as implementing or verifying changes\n- If the trace shows completion prompts, final answer generation, summarization, final validation, or output rendering, describe that as validating findings and preparing the final response\n- If the trace shows waiting on a long AI request, delegate, tool call, or sandboxed child task, describe that as waiting for analysis or validation to finish\n\nIf you are tempted to answer the user's question, stop and convert that into:\n- what was learned so far\n- what was just completed\n- what is still being checked\n\nBad update example:\n- \"API rate limiting works by...\"\n\nGood update example:\n- \"Progress: identified the gateway components involved in rate limiting\"\n- \"Last done: found the middleware files and session manager entry points\"\n- \"Now: tracing the enforcement path through the gateway\"\n- \"Waiting on: search results for the limiter implementation details\"`;\n\nexport interface TaskLiveUpdateSink {\n readonly kind: string;\n start(): Promise<{ ref?: Record<string, unknown> } | null>;\n update(text: string): Promise<{ ref?: Record<string, unknown> } | null>;\n complete(text: string): Promise<{ ref?: Record<string, unknown> } | null>;\n fail(text: string): Promise<{ ref?: Record<string, unknown> } | null>;\n}\n\nexport interface TaskLiveUpdateDeps {\n summarizeProgress?: (input: TaskProgressSummaryInput) => Promise<string | null>;\n serializeTrace?: (\n traceRef: string,\n maxChars: number,\n traceId?: string\n ) => Promise<string | undefined>;\n extractSkillMetadata?: (\n traceRef: string,\n traceId?: string\n ) => Promise<TaskLiveUpdateSkillMetadata | undefined>;\n}\n\nexport interface TaskProgressSummaryInput {\n requestText: string;\n previousUpdate?: string;\n traceSnapshot: string;\n config: RequiredTaskLiveUpdatesConfig;\n startedAt: Date;\n now: Date;\n elapsedSeconds: number;\n previousUpdateAt?: Date;\n secondsSincePreviousUpdate?: number;\n}\n\ninterface ProgressTimingMetadata {\n elapsedSeconds: number;\n previousUpdateAt?: Date;\n secondsSincePreviousUpdate?: number;\n activatedSkills?: string[];\n}\n\ninterface TaskLiveUpdateSkillMetadata {\n activatedSkills?: string[];\n}\n\nexport interface TaskLiveUpdateContext {\n taskId: string;\n requestText: string;\n traceRef?: string;\n traceId?: string;\n includeTraceId?: boolean;\n resolveTraceState?: () => { traceRef?: string; traceId?: string };\n sink: TaskLiveUpdateSink;\n config: RequiredTaskLiveUpdatesConfig;\n onPostedRef?: (ref: Record<string, unknown>) => void;\n appendHistory?: (text: string, stage: 'started' | 'progress' | 'completed' | 'failed') => void;\n}\n\nexport interface RequiredTaskLiveUpdatesConfig {\n enabled: boolean;\n intervalSeconds: number;\n model: string;\n provider?: string;\n prompt: string;\n initialMessage: string;\n maxTraceChars: number;\n}\n\nexport function resolveTaskLiveUpdatesConfig(\n config?: boolean | TaskLiveUpdatesConfig | null\n): RequiredTaskLiveUpdatesConfig | null {\n if (!config) return null;\n if (config === true) {\n return {\n enabled: true,\n intervalSeconds: DEFAULT_TASK_LIVE_UPDATE_INTERVAL_SECONDS,\n model: DEFAULT_TASK_LIVE_UPDATE_MODEL,\n prompt: DEFAULT_TASK_LIVE_UPDATE_PROMPT,\n initialMessage: '',\n maxTraceChars: DEFAULT_TASK_LIVE_UPDATE_MAX_TRACE_CHARS,\n };\n }\n\n if (config.enabled === false) return null;\n\n return {\n enabled: true,\n intervalSeconds: Math.max(\n 1,\n Math.floor(config.interval_seconds || DEFAULT_TASK_LIVE_UPDATE_INTERVAL_SECONDS)\n ),\n model: config.model || DEFAULT_TASK_LIVE_UPDATE_MODEL,\n provider: config.provider,\n prompt: config.prompt || DEFAULT_TASK_LIVE_UPDATE_PROMPT,\n initialMessage: config.initial_message || '',\n maxTraceChars: Math.max(\n 1000,\n Math.floor(config.max_trace_chars || DEFAULT_TASK_LIVE_UPDATE_MAX_TRACE_CHARS)\n ),\n };\n}\n\nexport function isFrontendLiveUpdatesEnabled(\n config: boolean | TaskLiveUpdatesConfig | null | undefined,\n frontend: 'slack' | 'telegram' | 'teams' | 'whatsapp'\n): boolean {\n if (!config) return false;\n if (config === true) return true;\n if (config.enabled === false) return false;\n const frontendCfg = config.frontends?.[frontend];\n if (frontendCfg?.enabled === false) return false;\n return true;\n}\n\nexport class TaskLiveUpdateManager {\n private readonly deps: Required<TaskLiveUpdateDeps>;\n private timer?: ReturnType<typeof setInterval>;\n private firstTickTimer?: ReturnType<typeof setTimeout>;\n private metadataRefreshTimer?: ReturnType<typeof setInterval>;\n private running = false;\n private started = false;\n private completed = false;\n private readonly startedAt = new Date();\n private lastUpdateText?: string;\n private lastUpdateAt?: Date;\n private lastTraceSnapshot?: string;\n private lastPostedMessage?: string;\n private lastStallFallbackAt?: Date;\n private lastUpdateKind: 'semantic' | 'stall' = 'semantic';\n private lastSkillMetadata?: TaskLiveUpdateSkillMetadata;\n\n constructor(\n private readonly ctx: TaskLiveUpdateContext,\n deps?: TaskLiveUpdateDeps\n ) {\n this.deps = {\n summarizeProgress: deps?.summarizeProgress || summarizeTaskProgress,\n serializeTrace: deps?.serializeTrace || defaultSerializeTrace,\n extractSkillMetadata: deps?.extractSkillMetadata || extractTraceSkillMetadata,\n };\n }\n\n async start(): Promise<void> {\n if (this.started) return;\n this.started = true;\n try {\n const started = await this.ctx.sink.start();\n this.recordSinkRef(started);\n logger.info(\n `[TaskLiveUpdates] Started for task ${this.ctx.taskId}; first update in ${DEFAULT_TASK_LIVE_UPDATE_FIRST_UPDATE_DELAY_SECONDS}s, interval=${this.ctx.config.intervalSeconds}s, provider=${this.ctx.config.provider || 'default'}, model=${this.ctx.config.model}`\n );\n } catch (err) {\n logger.warn(\n `[TaskLiveUpdates] Failed to initialize live updates for task ${this.ctx.taskId}: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n }\n\n this.firstTickTimer = setTimeout(() => {\n void this.runFirstTick();\n }, DEFAULT_TASK_LIVE_UPDATE_FIRST_UPDATE_DELAY_SECONDS * 1000);\n if (typeof (this.firstTickTimer as any)?.unref === 'function') {\n (this.firstTickTimer as any).unref();\n }\n }\n\n async complete(finalText: string): Promise<void> {\n if (this.completed) return;\n this.completed = true;\n this.stop();\n try {\n logger.info(`[TaskLiveUpdates] Publishing final success update for task ${this.ctx.taskId}`);\n const result = await this.ctx.sink.complete(this.decorateText(finalText));\n this.recordSinkRef(result);\n this.ctx.appendHistory?.(finalText, 'completed');\n } catch (err) {\n logger.warn(\n `[TaskLiveUpdates] Failed to publish final update for task ${this.ctx.taskId}: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n }\n }\n\n async fail(finalText: string): Promise<void> {\n if (this.completed) return;\n this.completed = true;\n this.stop();\n try {\n logger.info(`[TaskLiveUpdates] Publishing final failure update for task ${this.ctx.taskId}`);\n const result = await this.ctx.sink.fail(this.decorateText(finalText));\n this.recordSinkRef(result);\n this.ctx.appendHistory?.(finalText, 'failed');\n } catch (err) {\n logger.warn(\n `[TaskLiveUpdates] Failed to publish failure update for task ${this.ctx.taskId}: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n }\n }\n\n stop(): void {\n if (this.firstTickTimer) {\n clearTimeout(this.firstTickTimer);\n this.firstTickTimer = undefined;\n }\n if (this.timer) {\n clearInterval(this.timer);\n this.timer = undefined;\n }\n if (this.metadataRefreshTimer) {\n clearInterval(this.metadataRefreshTimer);\n this.metadataRefreshTimer = undefined;\n }\n }\n\n async tick(): Promise<void> {\n if (this.completed || this.running) return;\n const traceState = this.getTraceState();\n if (!traceState.traceRef && !traceState.traceId) {\n logger.debug(\n `[TaskLiveUpdates] Skipping tick for task ${this.ctx.taskId}: no trace reference available yet`\n );\n return;\n }\n this.running = true;\n try {\n const traceRef = traceState.traceRef || traceState.traceId!;\n const traceSnapshot = await this.deps.serializeTrace(\n traceRef,\n this.ctx.config.maxTraceChars,\n traceState.traceId\n );\n if (this.completed) {\n logger.debug(\n `[TaskLiveUpdates] Aborting in-flight tick for task ${this.ctx.taskId}: task already completed`\n );\n return;\n }\n if (!traceSnapshot || traceSnapshot === '(no trace data available)') {\n logger.debug(\n `[TaskLiveUpdates] Skipping tick for task ${this.ctx.taskId}: no trace data available yet (traceRef=${traceRef})`\n );\n return;\n }\n if (traceSnapshot === this.lastTraceSnapshot) {\n await this.maybePublishStallFallback(traceSnapshot, traceState.traceId);\n logger.debug(\n `[TaskLiveUpdates] Skipping tick for task ${this.ctx.taskId}: trace snapshot unchanged`\n );\n return;\n }\n\n const summary = await this.deps.summarizeProgress({\n requestText: this.ctx.requestText,\n previousUpdate: this.lastUpdateText,\n traceSnapshot,\n config: this.ctx.config,\n startedAt: this.startedAt,\n now: new Date(),\n elapsedSeconds: Math.max(0, Math.floor((Date.now() - this.startedAt.getTime()) / 1000)),\n previousUpdateAt: this.lastUpdateAt,\n secondsSincePreviousUpdate: this.lastUpdateAt\n ? Math.max(0, Math.floor((Date.now() - this.lastUpdateAt.getTime()) / 1000))\n : undefined,\n });\n if (this.completed) {\n logger.debug(\n `[TaskLiveUpdates] Aborting in-flight tick for task ${this.ctx.taskId}: task already completed after summarization`\n );\n return;\n }\n const cleaned = summary?.trim();\n if (!cleaned || cleaned === this.lastUpdateText) {\n await this.maybePublishStallFallback(traceSnapshot, traceState.traceId);\n logger.debug(\n `[TaskLiveUpdates] Skipping tick for task ${this.ctx.taskId}: summary empty or unchanged`\n );\n this.lastTraceSnapshot = traceSnapshot;\n return;\n }\n\n logger.info(\n `[TaskLiveUpdates] Publishing progress update for task ${this.ctx.taskId}: ${cleaned.slice(0, 160)}`\n );\n this.lastSkillMetadata = await this.deps.extractSkillMetadata(traceRef, traceState.traceId);\n this.lastUpdateKind = 'semantic';\n const message = this.decorateProgressText(\n cleaned,\n {\n elapsedSeconds: Math.max(0, Math.floor((Date.now() - this.startedAt.getTime()) / 1000)),\n previousUpdateAt: this.lastUpdateAt,\n secondsSincePreviousUpdate: this.lastUpdateAt\n ? Math.max(0, Math.floor((Date.now() - this.lastUpdateAt.getTime()) / 1000))\n : undefined,\n activatedSkills: this.lastSkillMetadata?.activatedSkills,\n },\n traceState.traceId\n );\n const result = await this.ctx.sink.update(message);\n this.recordSinkRef(result);\n this.ctx.appendHistory?.(cleaned, 'progress');\n this.lastUpdateText = cleaned;\n this.lastUpdateAt = new Date();\n this.lastTraceSnapshot = traceSnapshot;\n this.lastPostedMessage = message;\n this.lastStallFallbackAt = undefined;\n } catch (err) {\n logger.warn(\n `[TaskLiveUpdates] Progress update failed for task ${this.ctx.taskId}: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n } finally {\n this.running = false;\n }\n }\n\n private async runFirstTick(): Promise<void> {\n if (this.completed) return;\n logger.debug(`[TaskLiveUpdates] Running first scheduled tick for task ${this.ctx.taskId}`);\n await this.tick();\n if (this.completed) return;\n this.timer = setInterval(() => {\n void this.tick();\n }, this.ctx.config.intervalSeconds * 1000);\n if (typeof (this.timer as any)?.unref === 'function') {\n (this.timer as any).unref();\n }\n this.metadataRefreshTimer = setInterval(() => {\n void this.refreshProgressMetadata();\n }, DEFAULT_TASK_LIVE_UPDATE_METADATA_REFRESH_SECONDS * 1000);\n if (typeof (this.metadataRefreshTimer as any)?.unref === 'function') {\n (this.metadataRefreshTimer as any).unref();\n }\n }\n\n private recordSinkRef(result: { ref?: Record<string, unknown> } | null | undefined): void {\n if (result?.ref) this.ctx.onPostedRef?.(result.ref);\n }\n\n private getTraceState(): { traceRef?: string; traceId?: string } {\n const resolved = this.ctx.resolveTraceState?.();\n return {\n traceRef: resolved?.traceRef || this.ctx.traceRef,\n traceId: resolved?.traceId || this.ctx.traceId,\n };\n }\n\n private decorateText(text: string, _traceId?: string): string {\n if (!this.ctx.includeTraceId) return text;\n if (text.includes(`task_id: ${this.ctx.taskId}`)) return text;\n return `${text}\\n\\n\\`task_id: ${this.ctx.taskId}\\``;\n }\n\n private decorateProgressText(\n text: string,\n timing: ProgressTimingMetadata,\n traceId?: string\n ): string {\n const normalized = normalizeProgressSummary(text);\n const blocks = [\n '*Live Update*',\n '_Current task is still running. This message updates in place until the final answer is ready._',\n this.lastUpdateKind === 'stall' ? DEFAULT_TASK_LIVE_UPDATE_STALL_NOTICE : '',\n normalized,\n formatProgressMetadata(timing),\n ].filter(Boolean);\n return this.decorateText(blocks.join('\\n\\n'), traceId);\n }\n\n private async refreshProgressMetadata(): Promise<void> {\n if (this.completed || this.running || !this.lastUpdateText) return;\n const traceState = this.getTraceState();\n const message = this.decorateProgressText(\n this.lastUpdateText,\n {\n elapsedSeconds: Math.max(0, Math.floor((Date.now() - this.startedAt.getTime()) / 1000)),\n previousUpdateAt: this.lastUpdateAt,\n secondsSincePreviousUpdate: this.lastUpdateAt\n ? Math.max(0, Math.floor((Date.now() - this.lastUpdateAt.getTime()) / 1000))\n : undefined,\n activatedSkills: this.lastSkillMetadata?.activatedSkills,\n },\n traceState.traceId\n );\n if (!message || message === this.lastPostedMessage) return;\n if (this.completed) return;\n try {\n logger.debug(\n `[TaskLiveUpdates] Refreshing metadata-only live update for task ${this.ctx.taskId}`\n );\n const result = await this.ctx.sink.update(message);\n this.recordSinkRef(result);\n this.lastPostedMessage = message;\n } catch (err) {\n logger.warn(\n `[TaskLiveUpdates] Metadata refresh failed for task ${this.ctx.taskId}: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n }\n }\n\n private async maybePublishStallFallback(traceSnapshot: string, traceId?: string): Promise<void> {\n if (this.completed) return;\n const now = new Date();\n if (\n this.lastStallFallbackAt &&\n now.getTime() - this.lastStallFallbackAt.getTime() <\n DEFAULT_TASK_LIVE_UPDATE_STALL_FALLBACK_SECONDS * 1000\n ) {\n return;\n }\n if (\n this.lastUpdateAt &&\n now.getTime() - this.lastUpdateAt.getTime() <\n DEFAULT_TASK_LIVE_UPDATE_STALL_FALLBACK_SECONDS * 1000\n ) {\n return;\n }\n this.lastSkillMetadata = await this.deps.extractSkillMetadata(\n this.getTraceState().traceRef || traceId || '',\n traceId\n );\n\n const fallback = buildStallFallbackSummary(traceSnapshot, this.lastUpdateText);\n const baseText = this.lastUpdateText || fallback;\n if (!baseText) return;\n\n logger.info(\n `[TaskLiveUpdates] Publishing stall notice for task ${this.ctx.taskId}: ${baseText.slice(0, 160)}`\n );\n this.lastUpdateKind = 'stall';\n if (this.completed) return;\n const message = this.decorateProgressText(\n baseText,\n {\n elapsedSeconds: Math.max(0, Math.floor((Date.now() - this.startedAt.getTime()) / 1000)),\n previousUpdateAt: this.lastUpdateAt,\n secondsSincePreviousUpdate: this.lastUpdateAt\n ? Math.max(0, Math.floor((Date.now() - this.lastUpdateAt.getTime()) / 1000))\n : undefined,\n activatedSkills: this.lastSkillMetadata?.activatedSkills,\n },\n traceId\n );\n if (message === this.lastPostedMessage) {\n this.lastStallFallbackAt = now;\n return;\n }\n const result = await this.ctx.sink.update(message);\n this.recordSinkRef(result);\n if (!this.lastUpdateText) {\n this.ctx.appendHistory?.(baseText, 'progress');\n this.lastUpdateText = baseText;\n this.lastUpdateAt = now;\n }\n this.lastPostedMessage = message;\n this.lastStallFallbackAt = now;\n }\n}\n\nasync function defaultSerializeTrace(\n traceRef: string,\n maxChars: number,\n traceId?: string\n): Promise<string | undefined> {\n logger.debug(\n `[TaskLiveUpdates] Serializing trace for progress update (traceRef=${traceRef}, traceId=${traceId || '-'}, sink=${process.env.VISOR_TELEMETRY_SINK || 'auto'})`\n );\n return serializeTraceForPrompt(traceRef, maxChars, undefined, undefined, traceId);\n}\n\nexport async function summarizeTaskProgress(\n input: TaskProgressSummaryInput\n): Promise<string | null> {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const { ProbeAgent } = require('@probelabs/probe');\n\n const agentOptions: Record<string, unknown> = {\n sessionId: `visor-task-progress-${Date.now()}-${crypto.randomUUID().slice(0, 8)}`,\n systemPrompt: input.config.prompt,\n maxIterations: 1,\n disableTools: true,\n };\n if (input.config.model) agentOptions.model = input.config.model;\n if (input.config.provider) agentOptions.provider = input.config.provider;\n\n const agent = new ProbeAgent(agentOptions);\n if (typeof agent.initialize === 'function') {\n await agent.initialize();\n }\n\n const userPrompt = [\n `<user_request>\\n${input.requestText}\\n</user_request>`,\n input.previousUpdate\n ? `<previous_update>\\n${input.previousUpdate}\\n</previous_update>`\n : '<previous_update>(none)</previous_update>',\n `<timing>\\nstarted_at: ${input.startedAt.toISOString()}\\nnow: ${input.now.toISOString()}\\nelapsed: ${formatDuration(input.elapsedSeconds)}\\nlast_update_at: ${input.previousUpdateAt ? input.previousUpdateAt.toISOString() : '(none)'}\\ntime_since_last_update: ${\n input.previousUpdateAt ? formatDuration(input.secondsSincePreviousUpdate || 0) : '(none)'\n }\\n</timing>`,\n `<execution_trace>\\n${input.traceSnapshot}\\n</execution_trace>`,\n ].join('\\n\\n');\n\n const response = await agent.answer(userPrompt);\n const cleaned = response\n .replace(/^```(?:markdown|md|text)?\\s*\\n?/i, '')\n .replace(/\\n?```\\s*$/m, '')\n .trim();\n return cleaned || null;\n}\n\nfunction formatDuration(totalSeconds: number): string {\n const seconds = Math.max(0, Math.floor(totalSeconds));\n const hours = Math.floor(seconds / 3600);\n const minutes = Math.floor((seconds % 3600) / 60);\n const remainingSeconds = seconds % 60;\n const parts: string[] = [];\n if (hours > 0) parts.push(`${hours}h`);\n if (minutes > 0) parts.push(`${minutes}m`);\n if (remainingSeconds > 0 || parts.length === 0) parts.push(`${remainingSeconds}s`);\n return parts.join(' ');\n}\n\nfunction normalizeProgressSummary(text: string): string {\n const wantedLabels = ['Progress', 'Last done', 'Now', 'Waiting on'];\n const lines = text\n .split(/\\r?\\n/)\n .map(line => line.trim())\n .filter(Boolean);\n\n const matched = new Map<string, string>();\n for (const line of lines) {\n const match = line.match(/^-?\\s*(Progress|Last done|Now|Waiting on|Timing)\\s*:\\s*(.+)$/i);\n if (!match) continue;\n const label = match[1].toLowerCase();\n if (label === 'timing') continue;\n const canonical = wantedLabels.find(item => item.toLowerCase() === label);\n if (canonical && !matched.has(canonical)) {\n matched.set(canonical, match[2].trim());\n }\n }\n\n if (matched.size === wantedLabels.length) {\n return wantedLabels.map(label => `- ${label}: ${matched.get(label)}`).join('\\n');\n }\n\n const withoutTiming = lines.filter(line => !/^-?\\s*(Timing|Metadata|Trace)\\s*:/i.test(line));\n return withoutTiming.join('\\n');\n}\n\nfunction formatProgressMetadata(timing: ProgressTimingMetadata): string {\n const parts = [`elapsed ${formatDuration(timing.elapsedSeconds)}`];\n if (timing.previousUpdateAt) {\n parts.push(`previous update ${formatDuration(timing.secondsSincePreviousUpdate || 0)} ago`);\n parts.push(`at ${timing.previousUpdateAt.toISOString()}`);\n } else {\n parts.push('first live update');\n }\n if (timing.activatedSkills && timing.activatedSkills.length > 0) {\n parts.push(`activated skills ${formatSkillList(timing.activatedSkills)}`);\n }\n return `_Metadata: ${parts.join(' | ')}_`;\n}\n\nfunction formatSkillList(skills: string[]): string {\n const normalized = dedupeStrings(skills);\n if (normalized.length <= 4) return normalized.join(', ');\n return `${normalized.slice(0, 4).join(', ')} +${normalized.length - 4} more`;\n}\n\nfunction dedupeStrings(values: string[] | undefined): string[] {\n if (!Array.isArray(values)) return [];\n return [...new Set(values.map(value => String(value || '').trim()).filter(Boolean))];\n}\n\nasync function extractTraceSkillMetadata(\n traceRef: string,\n traceId?: string\n): Promise<TaskLiveUpdateSkillMetadata | undefined> {\n if (!traceRef && !traceId) return undefined;\n try {\n const spans = await fetchTraceSpans(traceId || traceRef);\n if (!spans.length) return undefined;\n\n const routeIntentSpan = spans.find(\n span => span.attributes['visor.check.id'] === 'route-intent'\n );\n const buildConfigSpan = spans.find(\n span => span.attributes['visor.check.id'] === 'build-config'\n );\n const classifySpan = spans.find(span => span.attributes['visor.check.id'] === 'classify');\n\n const routeIntentOutput = parseJsonAttribute(routeIntentSpan?.attributes['visor.check.output']);\n const classifyOutput = parseJsonAttribute(classifySpan?.attributes['visor.check.output']);\n const buildConfigOutput = parseJsonAttribute(buildConfigSpan?.attributes['visor.check.output']);\n\n const activatedSkills = dedupeStrings(\n Array.isArray(buildConfigOutput?.activated_skills)\n ? buildConfigOutput.activated_skills\n : undefined\n );\n\n const fallbackActivatedSkills = dedupeStrings(\n (Array.isArray(routeIntentOutput?.skills) ? routeIntentOutput.skills : undefined) ||\n (Array.isArray(classifyOutput?.skills) ? classifyOutput.skills : undefined)\n );\n\n const finalActivatedSkills =\n activatedSkills.length > 0 ? activatedSkills : fallbackActivatedSkills;\n if (!finalActivatedSkills.length) return undefined;\n return { activatedSkills: finalActivatedSkills };\n } catch (err) {\n logger.debug(\n `[TaskLiveUpdates] Failed to extract skill metadata from trace: ${\n err instanceof Error ? err.message : String(err)\n }`\n );\n return undefined;\n }\n}\n\nfunction parseJsonAttribute(value: unknown): Record<string, any> | undefined {\n if (typeof value !== 'string' || !value.trim()) return undefined;\n try {\n const parsed = JSON.parse(value);\n return parsed && typeof parsed === 'object' ? parsed : undefined;\n } catch {\n return undefined;\n }\n}\n\nfunction buildStallFallbackSummary(traceSnapshot: string, previousUpdate?: string): string {\n const lastDone =\n extractProgressField(previousUpdate, 'Last done') ||\n 'continuing from the last completed analysis step';\n\n const lower = traceSnapshot.toLowerCase();\n let now = 'waiting for the current analysis step to finish';\n let waitingOn = 'the current analysis step to complete';\n\n if (\n lower.includes('search.delegate') ||\n lower.includes('tool: search') ||\n lower.includes('search(')\n ) {\n now = 'running or waiting on the current code search step';\n waitingOn = 'search results and downstream analysis to finish';\n } else if (lower.includes('extract(') || lower.includes('tool: extract')) {\n now = 'extracting the relevant code or documentation context';\n waitingOn = 'the extract step to finish and be interpreted';\n } else if (lower.includes('engineer-task') || lower.includes('engineer')) {\n now = 'waiting on the current implementation or validation step';\n waitingOn = 'the engineer workflow to finish the current step';\n } else if (\n lower.includes('ai.request') ||\n lower.includes('gemini') ||\n lower.includes('claude') ||\n lower.includes('openai')\n ) {\n now = 'waiting on the current model analysis step';\n waitingOn = 'the active model response to finish';\n } else if (lower.includes('bash(') || lower.includes('go test') || lower.includes('npm test')) {\n now = 'running or waiting on command-based validation';\n waitingOn = 'the current command or test run to finish';\n } else if (lower.includes('setup-projects') || lower.includes('build-config')) {\n now = 'preparing the workspace and loading the required context';\n waitingOn = 'workspace setup and context loading to finish';\n }\n\n return [\n '- Progress: still working through the same step; no new completed action yet',\n `- Last done: ${lastDone}`,\n `- Now: ${now}`,\n `- Waiting on: ${waitingOn}`,\n ].join('\\n');\n}\n\nfunction extractProgressField(text: string | undefined, label: string): string | undefined {\n if (!text) return undefined;\n const match = text.match(new RegExp(`(?:^|\\\\n)-?\\\\s*${escapeRegExp(label)}\\\\s*:\\\\s*(.+)$`, 'im'));\n return match?.[1]?.trim() || undefined;\n}\n\nfunction escapeRegExp(value: string): string {\n return value.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n"],"mappings":"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","names":[]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
createExtendedLiquid,
|
|
3
3
|
init_liquid_extensions
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-4HIWZA6M.mjs";
|
|
5
5
|
import {
|
|
6
6
|
compileAndRun,
|
|
7
7
|
createSecureSandbox,
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
import {
|
|
11
11
|
init_logger,
|
|
12
12
|
logger
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-6E625R3C.mjs";
|
|
14
14
|
import {
|
|
15
15
|
__esm,
|
|
16
16
|
__export,
|
|
@@ -822,4 +822,4 @@ export {
|
|
|
822
822
|
UtcpCheckProvider,
|
|
823
823
|
init_utcp_check_provider
|
|
824
824
|
};
|
|
825
|
-
//# sourceMappingURL=chunk-
|
|
825
|
+
//# sourceMappingURL=chunk-TSX3YS3F.mjs.map
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import {
|
|
2
2
|
FailureConditionEvaluator,
|
|
3
3
|
init_failure_condition_evaluator
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-7XKHFRPN.mjs";
|
|
5
5
|
import {
|
|
6
6
|
addEvent,
|
|
7
7
|
init_trace_helpers
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-QLT42TX7.mjs";
|
|
9
9
|
import {
|
|
10
10
|
createExtendedLiquid,
|
|
11
11
|
init_liquid_extensions
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-4HIWZA6M.mjs";
|
|
13
13
|
import {
|
|
14
14
|
compileAndRun,
|
|
15
15
|
createSecureSandbox,
|
|
@@ -18,11 +18,11 @@ import {
|
|
|
18
18
|
import {
|
|
19
19
|
MemoryStore,
|
|
20
20
|
init_memory_store
|
|
21
|
-
} from "./chunk-
|
|
21
|
+
} from "./chunk-4MHHELVZ.mjs";
|
|
22
22
|
import {
|
|
23
23
|
init_logger,
|
|
24
24
|
logger
|
|
25
|
-
} from "./chunk-
|
|
25
|
+
} from "./chunk-6E625R3C.mjs";
|
|
26
26
|
import {
|
|
27
27
|
__esm,
|
|
28
28
|
__export,
|
|
@@ -1499,4 +1499,4 @@ export {
|
|
|
1499
1499
|
evaluateTransitions,
|
|
1500
1500
|
init_routing
|
|
1501
1501
|
};
|
|
1502
|
-
//# sourceMappingURL=chunk-
|
|
1502
|
+
//# sourceMappingURL=chunk-UM7LGO2P.mjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
init_logger,
|
|
3
3
|
logger
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-6E625R3C.mjs";
|
|
5
5
|
import {
|
|
6
6
|
__esm
|
|
7
7
|
} from "./chunk-J7LXIPZS.mjs";
|
|
@@ -154,4 +154,4 @@ export {
|
|
|
154
154
|
resetPromptStateManager,
|
|
155
155
|
init_prompt_state
|
|
156
156
|
};
|
|
157
|
-
//# sourceMappingURL=chunk-
|
|
157
|
+
//# sourceMappingURL=chunk-VPPBOKBQ.mjs.map
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import {
|
|
2
|
+
__esm
|
|
3
|
+
} from "./chunk-J7LXIPZS.mjs";
|
|
4
|
+
|
|
5
|
+
// src/agent-protocol/task-trace-resolution.ts
|
|
6
|
+
async function resolveTaskTraceReference(metadata) {
|
|
7
|
+
const traceFile = metadata?.trace_file;
|
|
8
|
+
let traceId = metadata?.trace_id;
|
|
9
|
+
if (!traceId && traceFile) {
|
|
10
|
+
try {
|
|
11
|
+
const { readTraceIdFromFile } = await import("./trace-serializer-EBHTHZYT.mjs");
|
|
12
|
+
traceId = await readTraceIdFromFile(traceFile) || void 0;
|
|
13
|
+
} catch {
|
|
14
|
+
traceId = void 0;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
return {
|
|
18
|
+
traceId,
|
|
19
|
+
traceFile,
|
|
20
|
+
primaryRef: traceId || traceFile || void 0
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
var init_task_trace_resolution = __esm({
|
|
24
|
+
"src/agent-protocol/task-trace-resolution.ts"() {
|
|
25
|
+
"use strict";
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
export {
|
|
30
|
+
resolveTaskTraceReference,
|
|
31
|
+
init_task_trace_resolution
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=chunk-WZQMTD7W.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/agent-protocol/task-trace-resolution.ts"],"sourcesContent":["export interface TaskTraceMetadata {\n trace_id?: string;\n trace_file?: string;\n}\n\nexport interface ResolvedTaskTrace {\n traceId?: string;\n traceFile?: string;\n primaryRef?: string;\n}\n\nexport async function resolveTaskTraceReference(\n metadata?: TaskTraceMetadata | null\n): Promise<ResolvedTaskTrace> {\n const traceFile = metadata?.trace_file;\n let traceId = metadata?.trace_id;\n\n if (!traceId && traceFile) {\n try {\n const { readTraceIdFromFile } = await import('./trace-serializer');\n traceId = (await readTraceIdFromFile(traceFile)) || undefined;\n } catch {\n traceId = undefined;\n }\n }\n\n return {\n traceId,\n traceFile,\n primaryRef: traceId || traceFile || undefined,\n };\n}\n"],"mappings":";;;;;AAWA,eAAsB,0BACpB,UAC4B;AAC5B,QAAM,YAAY,UAAU;AAC5B,MAAI,UAAU,UAAU;AAExB,MAAI,CAAC,WAAW,WAAW;AACzB,QAAI;AACF,YAAM,EAAE,oBAAoB,IAAI,MAAM,OAAO,iCAAoB;AACjE,gBAAW,MAAM,oBAAoB,SAAS,KAAM;AAAA,IACtD,QAAQ;AACN,gBAAU;AAAA,IACZ;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,YAAY,WAAW,aAAa;AAAA,EACtC;AACF;AA/BA;AAAA;AAAA;AAAA;AAAA;","names":[]}
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
import {
|
|
11
11
|
init_logger,
|
|
12
12
|
logger
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-6E625R3C.mjs";
|
|
14
14
|
import {
|
|
15
15
|
__esm,
|
|
16
16
|
__export,
|
|
@@ -655,6 +655,17 @@ var init_config_schema = __esm({
|
|
|
655
655
|
}
|
|
656
656
|
],
|
|
657
657
|
description: "Automatically evaluate completed tasks using an LLM judge. Requires task_tracking to be enabled. Runs asynchronously after task completion. Set to `true` for defaults, or provide an object to configure."
|
|
658
|
+
},
|
|
659
|
+
task_live_updates: {
|
|
660
|
+
anyOf: [
|
|
661
|
+
{
|
|
662
|
+
type: "boolean"
|
|
663
|
+
},
|
|
664
|
+
{
|
|
665
|
+
$ref: "#/definitions/TaskLiveUpdatesConfig"
|
|
666
|
+
}
|
|
667
|
+
],
|
|
668
|
+
description: "Live progress updates for long-running tracked tasks on supported frontends."
|
|
658
669
|
}
|
|
659
670
|
},
|
|
660
671
|
required: ["version"],
|
|
@@ -1527,7 +1538,7 @@ var init_config_schema = __esm({
|
|
|
1527
1538
|
description: "Arguments/inputs for the workflow"
|
|
1528
1539
|
},
|
|
1529
1540
|
overrides: {
|
|
1530
|
-
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
1541
|
+
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422%3E%3E",
|
|
1531
1542
|
description: "Override specific step configurations in the workflow"
|
|
1532
1543
|
},
|
|
1533
1544
|
output_mapping: {
|
|
@@ -1543,7 +1554,7 @@ var init_config_schema = __esm({
|
|
|
1543
1554
|
description: "Config file path - alternative to workflow ID (loads a Visor config file as workflow)"
|
|
1544
1555
|
},
|
|
1545
1556
|
workflow_overrides: {
|
|
1546
|
-
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
1557
|
+
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422%3E%3E",
|
|
1547
1558
|
description: "Alias for overrides - workflow step overrides (backward compatibility)"
|
|
1548
1559
|
},
|
|
1549
1560
|
ref: {
|
|
@@ -2271,7 +2282,7 @@ var init_config_schema = __esm({
|
|
|
2271
2282
|
description: "Custom output name (defaults to workflow name)"
|
|
2272
2283
|
},
|
|
2273
2284
|
overrides: {
|
|
2274
|
-
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
2285
|
+
$ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422%3E%3E",
|
|
2275
2286
|
description: "Step overrides"
|
|
2276
2287
|
},
|
|
2277
2288
|
output_mapping: {
|
|
@@ -2286,13 +2297,13 @@ var init_config_schema = __esm({
|
|
|
2286
2297
|
"^x-": {}
|
|
2287
2298
|
}
|
|
2288
2299
|
},
|
|
2289
|
-
"Record<string,Partial<interface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
2300
|
+
"Record<string,Partial<interface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422>>": {
|
|
2290
2301
|
type: "object",
|
|
2291
2302
|
additionalProperties: {
|
|
2292
|
-
$ref: "#/definitions/Partial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
2303
|
+
$ref: "#/definitions/Partial%3Cinterface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422%3E"
|
|
2293
2304
|
}
|
|
2294
2305
|
},
|
|
2295
|
-
"Partial<interface-src_types_config.ts-15521-30601-src_types_config.ts-0-
|
|
2306
|
+
"Partial<interface-src_types_config.ts-15521-30601-src_types_config.ts-0-62422>": {
|
|
2296
2307
|
type: "object",
|
|
2297
2308
|
additionalProperties: false
|
|
2298
2309
|
},
|
|
@@ -4224,6 +4235,102 @@ var init_config_schema = __esm({
|
|
|
4224
4235
|
patternProperties: {
|
|
4225
4236
|
"^x-": {}
|
|
4226
4237
|
}
|
|
4238
|
+
},
|
|
4239
|
+
TaskLiveUpdatesConfig: {
|
|
4240
|
+
type: "object",
|
|
4241
|
+
properties: {
|
|
4242
|
+
enabled: {
|
|
4243
|
+
type: "boolean",
|
|
4244
|
+
description: "Enable live task progress updates (default: true when config object is present)"
|
|
4245
|
+
},
|
|
4246
|
+
interval_seconds: {
|
|
4247
|
+
type: "number",
|
|
4248
|
+
description: "Update interval in seconds (default: 10)"
|
|
4249
|
+
},
|
|
4250
|
+
model: {
|
|
4251
|
+
type: "string",
|
|
4252
|
+
description: "LLM model to use for progress summarization"
|
|
4253
|
+
},
|
|
4254
|
+
provider: {
|
|
4255
|
+
type: "string",
|
|
4256
|
+
description: "AI provider to use for progress summarization"
|
|
4257
|
+
},
|
|
4258
|
+
prompt: {
|
|
4259
|
+
type: "string",
|
|
4260
|
+
description: "Custom system prompt for the progress summarizer"
|
|
4261
|
+
},
|
|
4262
|
+
initial_message: {
|
|
4263
|
+
type: "string",
|
|
4264
|
+
description: "Immediate placeholder text posted before the first summary is generated"
|
|
4265
|
+
},
|
|
4266
|
+
max_trace_chars: {
|
|
4267
|
+
type: "number",
|
|
4268
|
+
description: "Maximum serialized trace characters passed into the summarizer (default: 12000)"
|
|
4269
|
+
},
|
|
4270
|
+
frontends: {
|
|
4271
|
+
type: "object",
|
|
4272
|
+
properties: {
|
|
4273
|
+
slack: {
|
|
4274
|
+
type: "object",
|
|
4275
|
+
properties: {
|
|
4276
|
+
enabled: {
|
|
4277
|
+
type: "boolean"
|
|
4278
|
+
}
|
|
4279
|
+
},
|
|
4280
|
+
additionalProperties: false,
|
|
4281
|
+
patternProperties: {
|
|
4282
|
+
"^x-": {}
|
|
4283
|
+
}
|
|
4284
|
+
},
|
|
4285
|
+
telegram: {
|
|
4286
|
+
type: "object",
|
|
4287
|
+
properties: {
|
|
4288
|
+
enabled: {
|
|
4289
|
+
type: "boolean"
|
|
4290
|
+
}
|
|
4291
|
+
},
|
|
4292
|
+
additionalProperties: false,
|
|
4293
|
+
patternProperties: {
|
|
4294
|
+
"^x-": {}
|
|
4295
|
+
}
|
|
4296
|
+
},
|
|
4297
|
+
teams: {
|
|
4298
|
+
type: "object",
|
|
4299
|
+
properties: {
|
|
4300
|
+
enabled: {
|
|
4301
|
+
type: "boolean"
|
|
4302
|
+
}
|
|
4303
|
+
},
|
|
4304
|
+
additionalProperties: false,
|
|
4305
|
+
patternProperties: {
|
|
4306
|
+
"^x-": {}
|
|
4307
|
+
}
|
|
4308
|
+
},
|
|
4309
|
+
whatsapp: {
|
|
4310
|
+
type: "object",
|
|
4311
|
+
properties: {
|
|
4312
|
+
enabled: {
|
|
4313
|
+
type: "boolean"
|
|
4314
|
+
}
|
|
4315
|
+
},
|
|
4316
|
+
additionalProperties: false,
|
|
4317
|
+
patternProperties: {
|
|
4318
|
+
"^x-": {}
|
|
4319
|
+
}
|
|
4320
|
+
}
|
|
4321
|
+
},
|
|
4322
|
+
additionalProperties: false,
|
|
4323
|
+
description: "Per-frontend enablement overrides",
|
|
4324
|
+
patternProperties: {
|
|
4325
|
+
"^x-": {}
|
|
4326
|
+
}
|
|
4327
|
+
}
|
|
4328
|
+
},
|
|
4329
|
+
additionalProperties: false,
|
|
4330
|
+
description: 'Live task progress updates for supported interactive frontends.\n\nWhen enabled, Visor posts a "working on it" placeholder and periodically updates the same message using a cheap internal LLM summary of the current execution trace. The final answer replaces that same message.',
|
|
4331
|
+
patternProperties: {
|
|
4332
|
+
"^x-": {}
|
|
4333
|
+
}
|
|
4227
4334
|
}
|
|
4228
4335
|
}
|
|
4229
4336
|
};
|
|
@@ -4595,7 +4702,7 @@ var init_config = __esm({
|
|
|
4595
4702
|
* When a workflow YAML is run standalone, register the workflow and use its tests as checks
|
|
4596
4703
|
*/
|
|
4597
4704
|
async convertWorkflowToConfig(workflowData, basePath) {
|
|
4598
|
-
const { WorkflowRegistry } = await import("./workflow-registry-
|
|
4705
|
+
const { WorkflowRegistry } = await import("./workflow-registry-K56UTX36.mjs");
|
|
4599
4706
|
const registry = WorkflowRegistry.getInstance();
|
|
4600
4707
|
const workflowId = workflowData.id;
|
|
4601
4708
|
logger.info(`Detected standalone workflow file: ${workflowId}`);
|
|
@@ -4681,7 +4788,7 @@ ${errors}`);
|
|
|
4681
4788
|
if (!config.imports || config.imports.length === 0) {
|
|
4682
4789
|
return;
|
|
4683
4790
|
}
|
|
4684
|
-
const { WorkflowRegistry } = await import("./workflow-registry-
|
|
4791
|
+
const { WorkflowRegistry } = await import("./workflow-registry-K56UTX36.mjs");
|
|
4685
4792
|
const registry = WorkflowRegistry.getInstance();
|
|
4686
4793
|
for (const source of config.imports) {
|
|
4687
4794
|
const results = await registry.import(source, { basePath, validate: true, override: true });
|
|
@@ -5700,6 +5807,7 @@ ${errors}`);
|
|
|
5700
5807
|
"sandbox",
|
|
5701
5808
|
"sandbox_defaults",
|
|
5702
5809
|
"policy",
|
|
5810
|
+
"task_live_updates",
|
|
5703
5811
|
// Workflow metadata fields used when configs are imported as reusable workflows
|
|
5704
5812
|
"id",
|
|
5705
5813
|
"name",
|
|
@@ -5940,4 +6048,4 @@ export {
|
|
|
5940
6048
|
config_exports,
|
|
5941
6049
|
init_config
|
|
5942
6050
|
};
|
|
5943
|
-
//# sourceMappingURL=chunk-
|
|
6051
|
+
//# sourceMappingURL=chunk-YBXNG75V.mjs.map
|