@probelabs/visor 0.1.173 → 0.1.174

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.
Files changed (97) hide show
  1. package/dist/docs/dashboards/README.md +73 -26
  2. package/dist/docs/dashboards/grafana-visor-overview.json +435 -15
  3. package/dist/docs/telemetry-reference.md +387 -0
  4. package/dist/docs/telemetry-setup.md +2 -0
  5. package/dist/generated/config-schema.d.ts +277 -7
  6. package/dist/generated/config-schema.d.ts.map +1 -1
  7. package/dist/generated/config-schema.json +3803 -0
  8. package/dist/index.js +364 -30
  9. package/dist/output/traces/{run-2026-03-09T15-21-25-122Z.ndjson → run-2026-03-09T15-44-30-340Z.ndjson} +84 -84
  10. package/dist/output/traces/{run-2026-03-09T15-22-05-255Z.ndjson → run-2026-03-09T15-45-10-778Z.ndjson} +1852 -1852
  11. package/dist/sdk/{a2a-frontend-VHOQ45CR.mjs → a2a-frontend-5L6H7ZVF.mjs} +3 -3
  12. package/dist/sdk/{a2a-frontend-7CYN3X7M.mjs → a2a-frontend-FUJRKHJB.mjs} +3 -3
  13. package/dist/sdk/{check-provider-registry-65GO3SCO.mjs → check-provider-registry-UM762L7S.mjs} +7 -7
  14. package/dist/sdk/{check-provider-registry-75O5XJMA.mjs → check-provider-registry-UPQNHHFF.mjs} +7 -7
  15. package/dist/sdk/{check-provider-registry-DBTS7OXY.mjs → check-provider-registry-YVQI4IOR.mjs} +7 -7
  16. package/dist/sdk/{chunk-Y5MEQW2W.mjs → chunk-2PL2YH3B.mjs} +19 -19
  17. package/dist/sdk/{chunk-4TV2CVVI.mjs → chunk-34QX63WK.mjs} +16 -14
  18. package/dist/sdk/chunk-34QX63WK.mjs.map +1 -0
  19. package/dist/sdk/{chunk-2HXOGRAS.mjs → chunk-65SHRIQF.mjs} +3 -3
  20. package/dist/sdk/{chunk-2HXOGRAS.mjs.map → chunk-65SHRIQF.mjs.map} +1 -1
  21. package/dist/sdk/{chunk-VVHALCWV.mjs → chunk-EFNNJIMY.mjs} +3 -3
  22. package/dist/sdk/{chunk-7CWJNSL2.mjs → chunk-EP7PQ4IX.mjs} +19 -19
  23. package/dist/sdk/{chunk-AV6KML52.mjs → chunk-I6GKXMQ5.mjs} +19 -19
  24. package/dist/sdk/{chunk-VK7FUBBU.mjs → chunk-UTBSBJFV.mjs} +3 -3
  25. package/dist/sdk/{chunk-HZEXCJGA.mjs → chunk-W4KCJM6J.mjs} +282 -8
  26. package/dist/sdk/chunk-W4KCJM6J.mjs.map +1 -0
  27. package/dist/sdk/{chunk-GVPMO6QD.mjs → chunk-WJIV7MKY.mjs} +3 -3
  28. package/dist/sdk/{chunk-WYFQQ445.mjs → chunk-YEARBXYT.mjs} +3 -3
  29. package/dist/sdk/{chunk-LTHHE6Z5.mjs → chunk-ZI3SEHWA.mjs} +4 -4
  30. package/dist/sdk/{chunk-LTHHE6Z5.mjs.map → chunk-ZI3SEHWA.mjs.map} +1 -1
  31. package/dist/sdk/{config-UXRHADSE.mjs → config-BVL3KFMB.mjs} +2 -2
  32. package/dist/sdk/{failure-condition-evaluator-Q4KNMX6F.mjs → failure-condition-evaluator-4O6BTC4Q.mjs} +4 -4
  33. package/dist/sdk/{failure-condition-evaluator-SNR5XLGN.mjs → failure-condition-evaluator-DL6H57NX.mjs} +4 -4
  34. package/dist/sdk/{github-frontend-56UQTA47.mjs → github-frontend-F2YCPK6H.mjs} +4 -4
  35. package/dist/sdk/{github-frontend-OOP26667.mjs → github-frontend-UXL73NKB.mjs} +4 -4
  36. package/dist/sdk/{host-QRGXXRDA.mjs → host-6TBS44ER.mjs} +3 -3
  37. package/dist/sdk/{host-VYPJ2UGQ.mjs → host-KJTXX76P.mjs} +3 -3
  38. package/dist/sdk/{metrics-FU2G5SZ2.mjs → metrics-JTOG2HNO.mjs} +2 -2
  39. package/dist/sdk/{routing-DBQHPP2O.mjs → routing-AWYB2YX3.mjs} +5 -5
  40. package/dist/sdk/{routing-ZAUCS3HJ.mjs → routing-GF2CF3JT.mjs} +5 -5
  41. package/dist/sdk/{schedule-tool-MHICRNCI.mjs → schedule-tool-IEY2CFLU.mjs} +7 -7
  42. package/dist/sdk/{schedule-tool-VRLX54J5.mjs → schedule-tool-SGCYDSHL.mjs} +7 -7
  43. package/dist/sdk/{schedule-tool-2FIVKPVJ.mjs → schedule-tool-UMDRCNO5.mjs} +7 -7
  44. package/dist/sdk/{schedule-tool-handler-3ES4WON7.mjs → schedule-tool-handler-5EPTHBLS.mjs} +7 -7
  45. package/dist/sdk/{schedule-tool-handler-FQGAWC5N.mjs → schedule-tool-handler-5QVUZ5EZ.mjs} +7 -7
  46. package/dist/sdk/{schedule-tool-handler-KYUHU4JR.mjs → schedule-tool-handler-HMEGLYJF.mjs} +7 -7
  47. package/dist/sdk/sdk.d.mts +137 -133
  48. package/dist/sdk/sdk.d.ts +137 -133
  49. package/dist/sdk/sdk.js +298 -22
  50. package/dist/sdk/sdk.js.map +1 -1
  51. package/dist/sdk/sdk.mjs +6 -6
  52. package/dist/sdk/{trace-helpers-UKMYHQIK.mjs → trace-helpers-6TEWG7RK.mjs} +3 -3
  53. package/dist/sdk/{trace-helpers-ZFDJ55SH.mjs → trace-helpers-FKM2MEDW.mjs} +3 -3
  54. package/dist/sdk/{workflow-check-provider-F5DTEX6E.mjs → workflow-check-provider-7VNIO6L5.mjs} +7 -7
  55. package/dist/sdk/{workflow-check-provider-VEOVTCVU.mjs → workflow-check-provider-EWMZEEES.mjs} +7 -7
  56. package/dist/sdk/{workflow-check-provider-5KQTXKWS.mjs → workflow-check-provider-VJ7VIMCQ.mjs} +7 -7
  57. package/dist/telemetry/metrics.d.ts.map +1 -1
  58. package/dist/traces/{run-2026-03-09T15-21-25-122Z.ndjson → run-2026-03-09T15-44-30-340Z.ndjson} +84 -84
  59. package/dist/traces/{run-2026-03-09T15-22-05-255Z.ndjson → run-2026-03-09T15-45-10-778Z.ndjson} +1852 -1852
  60. package/dist/types/config.d.ts +5 -4
  61. package/dist/types/config.d.ts.map +1 -1
  62. package/package.json +2 -2
  63. package/dist/sdk/chunk-4TV2CVVI.mjs.map +0 -1
  64. package/dist/sdk/chunk-HZEXCJGA.mjs.map +0 -1
  65. /package/dist/sdk/{a2a-frontend-7CYN3X7M.mjs.map → a2a-frontend-5L6H7ZVF.mjs.map} +0 -0
  66. /package/dist/sdk/{a2a-frontend-VHOQ45CR.mjs.map → a2a-frontend-FUJRKHJB.mjs.map} +0 -0
  67. /package/dist/sdk/{check-provider-registry-65GO3SCO.mjs.map → check-provider-registry-UM762L7S.mjs.map} +0 -0
  68. /package/dist/sdk/{check-provider-registry-75O5XJMA.mjs.map → check-provider-registry-UPQNHHFF.mjs.map} +0 -0
  69. /package/dist/sdk/{check-provider-registry-DBTS7OXY.mjs.map → check-provider-registry-YVQI4IOR.mjs.map} +0 -0
  70. /package/dist/sdk/{chunk-Y5MEQW2W.mjs.map → chunk-2PL2YH3B.mjs.map} +0 -0
  71. /package/dist/sdk/{chunk-VK7FUBBU.mjs.map → chunk-EFNNJIMY.mjs.map} +0 -0
  72. /package/dist/sdk/{chunk-7CWJNSL2.mjs.map → chunk-EP7PQ4IX.mjs.map} +0 -0
  73. /package/dist/sdk/{chunk-AV6KML52.mjs.map → chunk-I6GKXMQ5.mjs.map} +0 -0
  74. /package/dist/sdk/{chunk-VVHALCWV.mjs.map → chunk-UTBSBJFV.mjs.map} +0 -0
  75. /package/dist/sdk/{chunk-GVPMO6QD.mjs.map → chunk-WJIV7MKY.mjs.map} +0 -0
  76. /package/dist/sdk/{chunk-WYFQQ445.mjs.map → chunk-YEARBXYT.mjs.map} +0 -0
  77. /package/dist/sdk/{config-UXRHADSE.mjs.map → config-BVL3KFMB.mjs.map} +0 -0
  78. /package/dist/sdk/{failure-condition-evaluator-Q4KNMX6F.mjs.map → failure-condition-evaluator-4O6BTC4Q.mjs.map} +0 -0
  79. /package/dist/sdk/{failure-condition-evaluator-SNR5XLGN.mjs.map → failure-condition-evaluator-DL6H57NX.mjs.map} +0 -0
  80. /package/dist/sdk/{github-frontend-56UQTA47.mjs.map → github-frontend-F2YCPK6H.mjs.map} +0 -0
  81. /package/dist/sdk/{github-frontend-OOP26667.mjs.map → github-frontend-UXL73NKB.mjs.map} +0 -0
  82. /package/dist/sdk/{host-QRGXXRDA.mjs.map → host-6TBS44ER.mjs.map} +0 -0
  83. /package/dist/sdk/{host-VYPJ2UGQ.mjs.map → host-KJTXX76P.mjs.map} +0 -0
  84. /package/dist/sdk/{metrics-FU2G5SZ2.mjs.map → metrics-JTOG2HNO.mjs.map} +0 -0
  85. /package/dist/sdk/{routing-DBQHPP2O.mjs.map → routing-AWYB2YX3.mjs.map} +0 -0
  86. /package/dist/sdk/{routing-ZAUCS3HJ.mjs.map → routing-GF2CF3JT.mjs.map} +0 -0
  87. /package/dist/sdk/{schedule-tool-2FIVKPVJ.mjs.map → schedule-tool-IEY2CFLU.mjs.map} +0 -0
  88. /package/dist/sdk/{schedule-tool-MHICRNCI.mjs.map → schedule-tool-SGCYDSHL.mjs.map} +0 -0
  89. /package/dist/sdk/{schedule-tool-VRLX54J5.mjs.map → schedule-tool-UMDRCNO5.mjs.map} +0 -0
  90. /package/dist/sdk/{schedule-tool-handler-3ES4WON7.mjs.map → schedule-tool-handler-5EPTHBLS.mjs.map} +0 -0
  91. /package/dist/sdk/{schedule-tool-handler-FQGAWC5N.mjs.map → schedule-tool-handler-5QVUZ5EZ.mjs.map} +0 -0
  92. /package/dist/sdk/{schedule-tool-handler-KYUHU4JR.mjs.map → schedule-tool-handler-HMEGLYJF.mjs.map} +0 -0
  93. /package/dist/sdk/{trace-helpers-UKMYHQIK.mjs.map → trace-helpers-6TEWG7RK.mjs.map} +0 -0
  94. /package/dist/sdk/{trace-helpers-ZFDJ55SH.mjs.map → trace-helpers-FKM2MEDW.mjs.map} +0 -0
  95. /package/dist/sdk/{workflow-check-provider-5KQTXKWS.mjs.map → workflow-check-provider-7VNIO6L5.mjs.map} +0 -0
  96. /package/dist/sdk/{workflow-check-provider-F5DTEX6E.mjs.map → workflow-check-provider-EWMZEEES.mjs.map} +0 -0
  97. /package/dist/sdk/{workflow-check-provider-VEOVTCVU.mjs.map → workflow-check-provider-VJ7VIMCQ.mjs.map} +0 -0
@@ -43,7 +43,7 @@ import {
43
43
  import {
44
44
  config_exports,
45
45
  init_config
46
- } from "./chunk-HZEXCJGA.mjs";
46
+ } from "./chunk-W4KCJM6J.mjs";
47
47
  import {
48
48
  ExecutionJournal,
49
49
  checkLoopBudget,
@@ -52,11 +52,11 @@ import {
52
52
  init_routing,
53
53
  init_snapshot_store,
54
54
  snapshot_store_exports
55
- } from "./chunk-WYFQQ445.mjs";
55
+ } from "./chunk-YEARBXYT.mjs";
56
56
  import {
57
57
  FailureConditionEvaluator,
58
58
  init_failure_condition_evaluator
59
- } from "./chunk-VK7FUBBU.mjs";
59
+ } from "./chunk-UTBSBJFV.mjs";
60
60
  import {
61
61
  addEvent,
62
62
  emitNdjsonFallback,
@@ -67,7 +67,7 @@ import {
67
67
  setSpanAttributes,
68
68
  trace_helpers_exports,
69
69
  withActiveSpan
70
- } from "./chunk-2HXOGRAS.mjs";
70
+ } from "./chunk-ZI3SEHWA.mjs";
71
71
  import {
72
72
  generateHumanId,
73
73
  init_human_id
@@ -76,7 +76,7 @@ import {
76
76
  addDiagramBlock,
77
77
  init_metrics,
78
78
  metrics_exports
79
- } from "./chunk-4TV2CVVI.mjs";
79
+ } from "./chunk-34QX63WK.mjs";
80
80
  import {
81
81
  createExtendedLiquid,
82
82
  init_liquid_extensions
@@ -4006,7 +4006,7 @@ async function executeWorkflowAsTool(workflowId, args, context2, argsOverrides)
4006
4006
  ...args,
4007
4007
  ...argsOverrides
4008
4008
  };
4009
- const { WorkflowCheckProvider: WorkflowCheckProvider2 } = await import("./workflow-check-provider-F5DTEX6E.mjs");
4009
+ const { WorkflowCheckProvider: WorkflowCheckProvider2 } = await import("./workflow-check-provider-7VNIO6L5.mjs");
4010
4010
  const provider = new WorkflowCheckProvider2();
4011
4011
  const checkConfig = {
4012
4012
  type: "workflow",
@@ -9327,7 +9327,7 @@ async function executeCheckWithForEachItems2(checkId, forEachParent, forEachItem
9327
9327
  }
9328
9328
  }
9329
9329
  try {
9330
- const { evaluateTransitions } = await import("./routing-ZAUCS3HJ.mjs");
9330
+ const { evaluateTransitions } = await import("./routing-AWYB2YX3.mjs");
9331
9331
  const transTarget = await evaluateTransitions(
9332
9332
  onFinish.transitions,
9333
9333
  forEachParent,
@@ -9387,7 +9387,7 @@ async function executeCheckWithForEachItems2(checkId, forEachParent, forEachItem
9387
9387
  `[LevelDispatch] Error evaluating on_finish transitions for ${forEachParent}: ${e instanceof Error ? e.message : String(e)}`
9388
9388
  );
9389
9389
  }
9390
- const { evaluateGoto: evaluateGoto2 } = await import("./routing-ZAUCS3HJ.mjs");
9390
+ const { evaluateGoto: evaluateGoto2 } = await import("./routing-AWYB2YX3.mjs");
9391
9391
  if (context2.debug) {
9392
9392
  logger.info(
9393
9393
  `[LevelDispatch] Evaluating on_finish.goto_js for forEach parent: ${forEachParent}`
@@ -13348,7 +13348,7 @@ var init_state_machine_execution_engine = __esm({
13348
13348
  try {
13349
13349
  const map = options?.webhookContext?.webhookData;
13350
13350
  if (map) {
13351
- const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-DBTS7OXY.mjs");
13351
+ const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-UM762L7S.mjs");
13352
13352
  const reg = CheckProviderRegistry2.getInstance();
13353
13353
  const p = reg.getProvider("http_input");
13354
13354
  if (p && typeof p.setWebhookContext === "function") p.setWebhookContext(map);
@@ -13461,7 +13461,7 @@ var init_state_machine_execution_engine = __esm({
13461
13461
  logger.info("[StateMachine] Using state machine engine");
13462
13462
  }
13463
13463
  if (!config) {
13464
- const { ConfigManager } = await import("./config-UXRHADSE.mjs");
13464
+ const { ConfigManager } = await import("./config-BVL3KFMB.mjs");
13465
13465
  const configManager = new ConfigManager();
13466
13466
  config = await configManager.getDefaultConfig();
13467
13467
  logger.debug("[StateMachine] Using default configuration (no config provided)");
@@ -13471,7 +13471,7 @@ var init_state_machine_execution_engine = __esm({
13471
13471
  tag_filter: tagFilter
13472
13472
  } : config;
13473
13473
  try {
13474
- const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-DBTS7OXY.mjs");
13474
+ const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-UM762L7S.mjs");
13475
13475
  const registry = CheckProviderRegistry2.getInstance();
13476
13476
  registry.setCustomTools(configWithTagFilter.tools || {});
13477
13477
  } catch (error) {
@@ -13535,7 +13535,7 @@ var init_state_machine_execution_engine = __esm({
13535
13535
  try {
13536
13536
  const webhookData = this.executionContext?.webhookContext?.webhookData;
13537
13537
  if (webhookData instanceof Map) {
13538
- const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-3ES4WON7.mjs");
13538
+ const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-5QVUZ5EZ.mjs");
13539
13539
  const slackCtx = extractSlackContext2(webhookData);
13540
13540
  if (slackCtx) {
13541
13541
  const payload = Array.from(webhookData.values())[0];
@@ -13564,7 +13564,7 @@ var init_state_machine_execution_engine = __esm({
13564
13564
  if (Array.isArray(configWithTagFilter.frontends) && configWithTagFilter.frontends.length > 0) {
13565
13565
  try {
13566
13566
  const { EventBus } = await import("./event-bus-5K3Y2FCS.mjs");
13567
- const { FrontendsHost } = await import("./host-QRGXXRDA.mjs");
13567
+ const { FrontendsHost } = await import("./host-KJTXX76P.mjs");
13568
13568
  const bus = new EventBus();
13569
13569
  context2.eventBus = bus;
13570
13570
  frontendsHost = new FrontendsHost(bus, logger);
@@ -13916,10 +13916,10 @@ var init_state_machine_execution_engine = __esm({
13916
13916
  * @returns Array of failure condition evaluation results
13917
13917
  */
13918
13918
  async evaluateFailureConditions(checkName, reviewSummary, config, previousOutputs, authorAssociation) {
13919
- const { FailureConditionEvaluator: FailureConditionEvaluator2 } = await import("./failure-condition-evaluator-SNR5XLGN.mjs");
13919
+ const { FailureConditionEvaluator: FailureConditionEvaluator2 } = await import("./failure-condition-evaluator-4O6BTC4Q.mjs");
13920
13920
  const evaluator = new FailureConditionEvaluator2();
13921
- const { addEvent: addEvent3 } = await import("./trace-helpers-UKMYHQIK.mjs");
13922
- const { addFailIfTriggered } = await import("./metrics-FU2G5SZ2.mjs");
13921
+ const { addEvent: addEvent3 } = await import("./trace-helpers-6TEWG7RK.mjs");
13922
+ const { addFailIfTriggered } = await import("./metrics-JTOG2HNO.mjs");
13923
13923
  const checkConfig = config.checks?.[checkName];
13924
13924
  if (!checkConfig) {
13925
13925
  return [];
@@ -41415,8 +41415,8 @@ function buildBuiltinGlobals(opts) {
41415
41415
  const asyncFunctionNames = /* @__PURE__ */ new Set();
41416
41416
  const scheduleFn = async (args = {}) => {
41417
41417
  try {
41418
- const { handleScheduleAction: handleScheduleAction2, buildScheduleToolContext: buildScheduleToolContext2 } = await import("./schedule-tool-MHICRNCI.mjs");
41419
- const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-3ES4WON7.mjs");
41418
+ const { handleScheduleAction: handleScheduleAction2, buildScheduleToolContext: buildScheduleToolContext2 } = await import("./schedule-tool-SGCYDSHL.mjs");
41419
+ const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-5QVUZ5EZ.mjs");
41420
41420
  const parentCtx = opts.sessionInfo?._parentContext;
41421
41421
  const webhookData = parentCtx?.prInfo?.eventContext?.webhookData;
41422
41422
  const visorCfg = parentCtx?.config;
@@ -45013,4 +45013,4 @@ undici/lib/fetch/body.js:
45013
45013
  undici/lib/websocket/frame.js:
45014
45014
  (*! ws. MIT License. Einar Otto Stangvik <einaros@gmail.com> *)
45015
45015
  */
45016
- //# sourceMappingURL=chunk-7CWJNSL2.mjs.map
45016
+ //# sourceMappingURL=chunk-EP7PQ4IX.mjs.map
@@ -43,7 +43,7 @@ import {
43
43
  import {
44
44
  config_exports,
45
45
  init_config
46
- } from "./chunk-HZEXCJGA.mjs";
46
+ } from "./chunk-W4KCJM6J.mjs";
47
47
  import {
48
48
  ExecutionJournal,
49
49
  checkLoopBudget,
@@ -52,11 +52,11 @@ import {
52
52
  init_routing,
53
53
  init_snapshot_store,
54
54
  snapshot_store_exports
55
- } from "./chunk-GVPMO6QD.mjs";
55
+ } from "./chunk-WJIV7MKY.mjs";
56
56
  import {
57
57
  FailureConditionEvaluator,
58
58
  init_failure_condition_evaluator
59
- } from "./chunk-VVHALCWV.mjs";
59
+ } from "./chunk-EFNNJIMY.mjs";
60
60
  import {
61
61
  addEvent,
62
62
  emitNdjsonFallback,
@@ -67,7 +67,7 @@ import {
67
67
  setSpanAttributes,
68
68
  trace_helpers_exports,
69
69
  withActiveSpan
70
- } from "./chunk-LTHHE6Z5.mjs";
70
+ } from "./chunk-65SHRIQF.mjs";
71
71
  import {
72
72
  generateHumanId,
73
73
  init_human_id
@@ -76,7 +76,7 @@ import {
76
76
  addDiagramBlock,
77
77
  init_metrics,
78
78
  metrics_exports
79
- } from "./chunk-4TV2CVVI.mjs";
79
+ } from "./chunk-34QX63WK.mjs";
80
80
  import {
81
81
  createExtendedLiquid,
82
82
  init_liquid_extensions
@@ -4006,7 +4006,7 @@ async function executeWorkflowAsTool(workflowId, args, context2, argsOverrides)
4006
4006
  ...args,
4007
4007
  ...argsOverrides
4008
4008
  };
4009
- const { WorkflowCheckProvider: WorkflowCheckProvider2 } = await import("./workflow-check-provider-5KQTXKWS.mjs");
4009
+ const { WorkflowCheckProvider: WorkflowCheckProvider2 } = await import("./workflow-check-provider-VJ7VIMCQ.mjs");
4010
4010
  const provider = new WorkflowCheckProvider2();
4011
4011
  const checkConfig = {
4012
4012
  type: "workflow",
@@ -9327,7 +9327,7 @@ async function executeCheckWithForEachItems2(checkId, forEachParent, forEachItem
9327
9327
  }
9328
9328
  }
9329
9329
  try {
9330
- const { evaluateTransitions } = await import("./routing-DBQHPP2O.mjs");
9330
+ const { evaluateTransitions } = await import("./routing-GF2CF3JT.mjs");
9331
9331
  const transTarget = await evaluateTransitions(
9332
9332
  onFinish.transitions,
9333
9333
  forEachParent,
@@ -9387,7 +9387,7 @@ async function executeCheckWithForEachItems2(checkId, forEachParent, forEachItem
9387
9387
  `[LevelDispatch] Error evaluating on_finish transitions for ${forEachParent}: ${e instanceof Error ? e.message : String(e)}`
9388
9388
  );
9389
9389
  }
9390
- const { evaluateGoto: evaluateGoto2 } = await import("./routing-DBQHPP2O.mjs");
9390
+ const { evaluateGoto: evaluateGoto2 } = await import("./routing-GF2CF3JT.mjs");
9391
9391
  if (context2.debug) {
9392
9392
  logger.info(
9393
9393
  `[LevelDispatch] Evaluating on_finish.goto_js for forEach parent: ${forEachParent}`
@@ -13348,7 +13348,7 @@ var init_state_machine_execution_engine = __esm({
13348
13348
  try {
13349
13349
  const map = options?.webhookContext?.webhookData;
13350
13350
  if (map) {
13351
- const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-65GO3SCO.mjs");
13351
+ const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-YVQI4IOR.mjs");
13352
13352
  const reg = CheckProviderRegistry2.getInstance();
13353
13353
  const p = reg.getProvider("http_input");
13354
13354
  if (p && typeof p.setWebhookContext === "function") p.setWebhookContext(map);
@@ -13461,7 +13461,7 @@ var init_state_machine_execution_engine = __esm({
13461
13461
  logger.info("[StateMachine] Using state machine engine");
13462
13462
  }
13463
13463
  if (!config) {
13464
- const { ConfigManager } = await import("./config-UXRHADSE.mjs");
13464
+ const { ConfigManager } = await import("./config-BVL3KFMB.mjs");
13465
13465
  const configManager = new ConfigManager();
13466
13466
  config = await configManager.getDefaultConfig();
13467
13467
  logger.debug("[StateMachine] Using default configuration (no config provided)");
@@ -13471,7 +13471,7 @@ var init_state_machine_execution_engine = __esm({
13471
13471
  tag_filter: tagFilter
13472
13472
  } : config;
13473
13473
  try {
13474
- const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-65GO3SCO.mjs");
13474
+ const { CheckProviderRegistry: CheckProviderRegistry2 } = await import("./check-provider-registry-YVQI4IOR.mjs");
13475
13475
  const registry = CheckProviderRegistry2.getInstance();
13476
13476
  registry.setCustomTools(configWithTagFilter.tools || {});
13477
13477
  } catch (error) {
@@ -13535,7 +13535,7 @@ var init_state_machine_execution_engine = __esm({
13535
13535
  try {
13536
13536
  const webhookData = this.executionContext?.webhookContext?.webhookData;
13537
13537
  if (webhookData instanceof Map) {
13538
- const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-FQGAWC5N.mjs");
13538
+ const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-HMEGLYJF.mjs");
13539
13539
  const slackCtx = extractSlackContext2(webhookData);
13540
13540
  if (slackCtx) {
13541
13541
  const payload = Array.from(webhookData.values())[0];
@@ -13564,7 +13564,7 @@ var init_state_machine_execution_engine = __esm({
13564
13564
  if (Array.isArray(configWithTagFilter.frontends) && configWithTagFilter.frontends.length > 0) {
13565
13565
  try {
13566
13566
  const { EventBus } = await import("./event-bus-5K3Y2FCS.mjs");
13567
- const { FrontendsHost } = await import("./host-VYPJ2UGQ.mjs");
13567
+ const { FrontendsHost } = await import("./host-6TBS44ER.mjs");
13568
13568
  const bus = new EventBus();
13569
13569
  context2.eventBus = bus;
13570
13570
  frontendsHost = new FrontendsHost(bus, logger);
@@ -13916,10 +13916,10 @@ var init_state_machine_execution_engine = __esm({
13916
13916
  * @returns Array of failure condition evaluation results
13917
13917
  */
13918
13918
  async evaluateFailureConditions(checkName, reviewSummary, config, previousOutputs, authorAssociation) {
13919
- const { FailureConditionEvaluator: FailureConditionEvaluator2 } = await import("./failure-condition-evaluator-Q4KNMX6F.mjs");
13919
+ const { FailureConditionEvaluator: FailureConditionEvaluator2 } = await import("./failure-condition-evaluator-DL6H57NX.mjs");
13920
13920
  const evaluator = new FailureConditionEvaluator2();
13921
- const { addEvent: addEvent3 } = await import("./trace-helpers-ZFDJ55SH.mjs");
13922
- const { addFailIfTriggered } = await import("./metrics-FU2G5SZ2.mjs");
13921
+ const { addEvent: addEvent3 } = await import("./trace-helpers-FKM2MEDW.mjs");
13922
+ const { addFailIfTriggered } = await import("./metrics-JTOG2HNO.mjs");
13923
13923
  const checkConfig = config.checks?.[checkName];
13924
13924
  if (!checkConfig) {
13925
13925
  return [];
@@ -41415,8 +41415,8 @@ function buildBuiltinGlobals(opts) {
41415
41415
  const asyncFunctionNames = /* @__PURE__ */ new Set();
41416
41416
  const scheduleFn = async (args = {}) => {
41417
41417
  try {
41418
- const { handleScheduleAction: handleScheduleAction2, buildScheduleToolContext: buildScheduleToolContext2 } = await import("./schedule-tool-2FIVKPVJ.mjs");
41419
- const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-FQGAWC5N.mjs");
41418
+ const { handleScheduleAction: handleScheduleAction2, buildScheduleToolContext: buildScheduleToolContext2 } = await import("./schedule-tool-IEY2CFLU.mjs");
41419
+ const { extractSlackContext: extractSlackContext2 } = await import("./schedule-tool-handler-HMEGLYJF.mjs");
41420
41420
  const parentCtx = opts.sessionInfo?._parentContext;
41421
41421
  const webhookData = parentCtx?.prInfo?.eventContext?.webhookData;
41422
41422
  const visorCfg = parentCtx?.config;
@@ -45013,4 +45013,4 @@ undici/lib/fetch/body.js:
45013
45013
  undici/lib/websocket/frame.js:
45014
45014
  (*! ws. MIT License. Einar Otto Stangvik <einaros@gmail.com> *)
45015
45015
  */
45016
- //# sourceMappingURL=chunk-AV6KML52.mjs.map
45016
+ //# sourceMappingURL=chunk-I6GKXMQ5.mjs.map
@@ -3,11 +3,11 @@ import {
3
3
  fallback_ndjson_exports,
4
4
  init_fallback_ndjson,
5
5
  init_trace_helpers
6
- } from "./chunk-2HXOGRAS.mjs";
6
+ } from "./chunk-ZI3SEHWA.mjs";
7
7
  import {
8
8
  addFailIfTriggered,
9
9
  init_metrics
10
- } from "./chunk-4TV2CVVI.mjs";
10
+ } from "./chunk-34QX63WK.mjs";
11
11
  import {
12
12
  createPermissionHelpers,
13
13
  detectLocalMode,
@@ -736,4 +736,4 @@ export {
736
736
  failure_condition_evaluator_exports,
737
737
  init_failure_condition_evaluator
738
738
  };
739
- //# sourceMappingURL=chunk-VK7FUBBU.mjs.map
739
+ //# sourceMappingURL=chunk-UTBSBJFV.mjs.map
@@ -609,6 +609,22 @@ var init_config_schema = __esm({
609
609
  $ref: "#/definitions/SlackConfig",
610
610
  description: "Slack configuration"
611
611
  },
612
+ telegram: {
613
+ $ref: "#/definitions/TelegramConfig",
614
+ description: "Telegram bot configuration"
615
+ },
616
+ email: {
617
+ $ref: "#/definitions/EmailConfig",
618
+ description: "Email integration configuration"
619
+ },
620
+ whatsapp: {
621
+ $ref: "#/definitions/WhatsAppConfig",
622
+ description: "WhatsApp bot configuration"
623
+ },
624
+ teams: {
625
+ $ref: "#/definitions/TeamsConfig",
626
+ description: "Microsoft Teams bot configuration"
627
+ },
612
628
  scheduler: {
613
629
  $ref: "#/definitions/SchedulerConfig",
614
630
  description: "Scheduler configuration for scheduled workflow execution"
@@ -1382,7 +1398,7 @@ var init_config_schema = __esm({
1382
1398
  description: "Arguments/inputs for the workflow"
1383
1399
  },
1384
1400
  overrides: {
1385
- $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400%3E%3E",
1401
+ $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833%3E%3E",
1386
1402
  description: "Override specific step configurations in the workflow"
1387
1403
  },
1388
1404
  output_mapping: {
@@ -1398,7 +1414,7 @@ var init_config_schema = __esm({
1398
1414
  description: "Config file path - alternative to workflow ID (loads a Visor config file as workflow)"
1399
1415
  },
1400
1416
  workflow_overrides: {
1401
- $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400%3E%3E",
1417
+ $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833%3E%3E",
1402
1418
  description: "Alias for overrides - workflow step overrides (backward compatibility)"
1403
1419
  },
1404
1420
  ref: {
@@ -1582,7 +1598,11 @@ var init_config_schema = __esm({
1582
1598
  "manual",
1583
1599
  "schedule",
1584
1600
  "webhook_received",
1585
- "slack_message"
1601
+ "slack_message",
1602
+ "telegram_message",
1603
+ "email_message",
1604
+ "whatsapp_message",
1605
+ "teams_message"
1586
1606
  ],
1587
1607
  description: "Valid event triggers for checks"
1588
1608
  },
@@ -2096,7 +2116,7 @@ var init_config_schema = __esm({
2096
2116
  description: "Custom output name (defaults to workflow name)"
2097
2117
  },
2098
2118
  overrides: {
2099
- $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400%3E%3E",
2119
+ $ref: "#/definitions/Record%3Cstring%2CPartial%3Cinterface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833%3E%3E",
2100
2120
  description: "Step overrides"
2101
2121
  },
2102
2122
  output_mapping: {
@@ -2111,13 +2131,13 @@ var init_config_schema = __esm({
2111
2131
  "^x-": {}
2112
2132
  }
2113
2133
  },
2114
- "Record<string,Partial<interface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400>>": {
2134
+ "Record<string,Partial<interface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833>>": {
2115
2135
  type: "object",
2116
2136
  additionalProperties: {
2117
- $ref: "#/definitions/Partial%3Cinterface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400%3E"
2137
+ $ref: "#/definitions/Partial%3Cinterface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833%3E"
2118
2138
  }
2119
2139
  },
2120
- "Partial<interface-src_types_config.ts-13844-28438-src_types_config.ts-0-56400>": {
2140
+ "Partial<interface-src_types_config.ts-14017-28611-src_types_config.ts-0-56833>": {
2121
2141
  type: "object",
2122
2142
  additionalProperties: false
2123
2143
  },
@@ -2976,6 +2996,260 @@ var init_config_schema = __esm({
2976
2996
  "^x-": {}
2977
2997
  }
2978
2998
  },
2999
+ TelegramConfig: {
3000
+ type: "object",
3001
+ properties: {
3002
+ bot_token: {
3003
+ type: "string",
3004
+ description: "Bot token from"
3005
+ },
3006
+ polling_timeout: {
3007
+ type: "number",
3008
+ description: "Polling timeout in seconds for getUpdates (default: 30)"
3009
+ },
3010
+ chat_allowlist: {
3011
+ type: "array",
3012
+ items: {
3013
+ type: ["string", "number"]
3014
+ },
3015
+ description: "Chat/group allowlist - numeric chat IDs that the bot responds in"
3016
+ },
3017
+ require_mention: {
3018
+ type: "boolean",
3019
+ description: "In groups, only respond when"
3020
+ },
3021
+ workflow: {
3022
+ type: "string",
3023
+ description: "Workflow to run when a message is received"
3024
+ }
3025
+ },
3026
+ additionalProperties: false,
3027
+ patternProperties: {
3028
+ "^x-": {}
3029
+ }
3030
+ },
3031
+ EmailConfig: {
3032
+ type: "object",
3033
+ properties: {
3034
+ receive: {
3035
+ type: "object",
3036
+ properties: {
3037
+ type: {
3038
+ type: "string",
3039
+ enum: ["imap", "resend"],
3040
+ description: "Backend type: 'imap' (universal) or 'resend' (managed webhook)"
3041
+ },
3042
+ host: {
3043
+ type: "string",
3044
+ description: "IMAP server hostname"
3045
+ },
3046
+ port: {
3047
+ type: "number",
3048
+ description: "IMAP server port (default: 993)"
3049
+ },
3050
+ auth: {
3051
+ type: "object",
3052
+ properties: {
3053
+ user: {
3054
+ type: "string"
3055
+ },
3056
+ pass: {
3057
+ type: "string"
3058
+ }
3059
+ },
3060
+ additionalProperties: false,
3061
+ description: "IMAP auth credentials",
3062
+ patternProperties: {
3063
+ "^x-": {}
3064
+ }
3065
+ },
3066
+ secure: {
3067
+ type: "boolean",
3068
+ description: "Use TLS (default: true)"
3069
+ },
3070
+ poll_interval: {
3071
+ type: "number",
3072
+ description: "Polling interval in seconds when IDLE not available (default: 30)"
3073
+ },
3074
+ folder: {
3075
+ type: "string",
3076
+ description: "IMAP folder to monitor (default: 'INBOX')"
3077
+ },
3078
+ mark_read: {
3079
+ type: "boolean",
3080
+ description: "Mark processed messages as read (default: true)"
3081
+ },
3082
+ api_key: {
3083
+ type: "string",
3084
+ description: "Resend API key (for type: 'resend')"
3085
+ },
3086
+ webhook_secret: {
3087
+ type: "string",
3088
+ description: "Resend webhook secret for signature verification"
3089
+ }
3090
+ },
3091
+ additionalProperties: false,
3092
+ description: "Receive backend configuration",
3093
+ patternProperties: {
3094
+ "^x-": {}
3095
+ }
3096
+ },
3097
+ send: {
3098
+ type: "object",
3099
+ properties: {
3100
+ type: {
3101
+ type: "string",
3102
+ enum: ["smtp", "resend"],
3103
+ description: "Backend type: 'smtp' (universal) or 'resend' (managed API)"
3104
+ },
3105
+ host: {
3106
+ type: "string",
3107
+ description: "SMTP server hostname"
3108
+ },
3109
+ port: {
3110
+ type: "number",
3111
+ description: "SMTP server port (default: 587)"
3112
+ },
3113
+ auth: {
3114
+ type: "object",
3115
+ properties: {
3116
+ user: {
3117
+ type: "string"
3118
+ },
3119
+ pass: {
3120
+ type: "string"
3121
+ }
3122
+ },
3123
+ additionalProperties: false,
3124
+ description: "SMTP auth credentials",
3125
+ patternProperties: {
3126
+ "^x-": {}
3127
+ }
3128
+ },
3129
+ secure: {
3130
+ type: "boolean",
3131
+ description: "Use TLS (default: true)"
3132
+ },
3133
+ from: {
3134
+ type: "string",
3135
+ description: 'Default sender address (e.g., "Bot <bot@example.com>")'
3136
+ },
3137
+ api_key: {
3138
+ type: "string",
3139
+ description: "Resend API key (for type: 'resend')"
3140
+ }
3141
+ },
3142
+ additionalProperties: false,
3143
+ description: "Send backend configuration",
3144
+ patternProperties: {
3145
+ "^x-": {}
3146
+ }
3147
+ },
3148
+ allowlist: {
3149
+ type: "array",
3150
+ items: {
3151
+ type: "string"
3152
+ },
3153
+ description: "Only process emails from these senders"
3154
+ },
3155
+ workflow: {
3156
+ type: "string",
3157
+ description: "Workflow to run when an email is received"
3158
+ }
3159
+ },
3160
+ additionalProperties: false,
3161
+ patternProperties: {
3162
+ "^x-": {}
3163
+ }
3164
+ },
3165
+ WhatsAppConfig: {
3166
+ type: "object",
3167
+ properties: {
3168
+ access_token: {
3169
+ type: "string",
3170
+ description: "WhatsApp Cloud API access token (or WHATSAPP_ACCESS_TOKEN env var)"
3171
+ },
3172
+ phone_number_id: {
3173
+ type: "string",
3174
+ description: "Phone Number ID from Meta Business Suite (or WHATSAPP_PHONE_NUMBER_ID env var)"
3175
+ },
3176
+ app_secret: {
3177
+ type: "string",
3178
+ description: "Meta App Secret for webhook signature verification (or WHATSAPP_APP_SECRET env var)"
3179
+ },
3180
+ verify_token: {
3181
+ type: "string",
3182
+ description: "Verify token for webhook subscription challenge (or WHATSAPP_VERIFY_TOKEN env var)"
3183
+ },
3184
+ api_version: {
3185
+ type: "string",
3186
+ description: "Graph API version (default: 'v21.0')"
3187
+ },
3188
+ port: {
3189
+ type: "number",
3190
+ description: "Port for webhook HTTP server (default: 8443)"
3191
+ },
3192
+ host: {
3193
+ type: "string",
3194
+ description: "Host for webhook HTTP server (default: '0.0.0.0')"
3195
+ },
3196
+ phone_allowlist: {
3197
+ type: "array",
3198
+ items: {
3199
+ type: "string"
3200
+ },
3201
+ description: "Phone number allowlist \u2014 only respond to these numbers"
3202
+ },
3203
+ workflow: {
3204
+ type: "string",
3205
+ description: "Workflow to run when a message is received"
3206
+ }
3207
+ },
3208
+ additionalProperties: false,
3209
+ patternProperties: {
3210
+ "^x-": {}
3211
+ }
3212
+ },
3213
+ TeamsConfig: {
3214
+ type: "object",
3215
+ properties: {
3216
+ app_id: {
3217
+ type: "string",
3218
+ description: "Azure AD App (client) ID (or TEAMS_APP_ID env var)"
3219
+ },
3220
+ app_password: {
3221
+ type: "string",
3222
+ description: "Azure AD App client secret (or TEAMS_APP_PASSWORD env var)"
3223
+ },
3224
+ tenant_id: {
3225
+ type: "string",
3226
+ description: "Azure AD Tenant ID for single-tenant apps (or TEAMS_TENANT_ID env var)"
3227
+ },
3228
+ port: {
3229
+ type: "number",
3230
+ description: "Port for webhook HTTP server (default: 3978)"
3231
+ },
3232
+ host: {
3233
+ type: "string",
3234
+ description: "Host for webhook HTTP server (default: '0.0.0.0')"
3235
+ },
3236
+ user_allowlist: {
3237
+ type: "array",
3238
+ items: {
3239
+ type: "string"
3240
+ },
3241
+ description: "User ID allowlist \u2014 only respond to these AAD user IDs"
3242
+ },
3243
+ workflow: {
3244
+ type: "string",
3245
+ description: "Workflow to run when a message is received"
3246
+ }
3247
+ },
3248
+ additionalProperties: false,
3249
+ patternProperties: {
3250
+ "^x-": {}
3251
+ }
3252
+ },
2979
3253
  SchedulerConfig: {
2980
3254
  type: "object",
2981
3255
  properties: {
@@ -5453,4 +5727,4 @@ export {
5453
5727
  config_exports,
5454
5728
  init_config
5455
5729
  };
5456
- //# sourceMappingURL=chunk-HZEXCJGA.mjs.map
5730
+ //# sourceMappingURL=chunk-W4KCJM6J.mjs.map