@minicor/mcp-server 2.0.8 → 3.1.0

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 (103) hide show
  1. package/README.md +29 -2
  2. package/dist/__tests__/state.test.d.ts +2 -0
  3. package/dist/__tests__/state.test.d.ts.map +1 -0
  4. package/dist/__tests__/state.test.js +116 -0
  5. package/dist/__tests__/state.test.js.map +1 -0
  6. package/dist/__tests__/vm-service-client.test.d.ts +2 -0
  7. package/dist/__tests__/vm-service-client.test.d.ts.map +1 -0
  8. package/dist/__tests__/vm-service-client.test.js +80 -0
  9. package/dist/__tests__/vm-service-client.test.js.map +1 -0
  10. package/dist/agent-service-client.d.ts +34 -0
  11. package/dist/agent-service-client.d.ts.map +1 -0
  12. package/dist/agent-service-client.js +64 -0
  13. package/dist/agent-service-client.js.map +1 -0
  14. package/dist/helpers.d.ts +1 -1
  15. package/dist/helpers.d.ts.map +1 -1
  16. package/dist/helpers.js +1 -1
  17. package/dist/helpers.js.map +1 -1
  18. package/dist/index.d.ts +5 -1
  19. package/dist/index.d.ts.map +1 -1
  20. package/dist/index.js +111 -44
  21. package/dist/index.js.map +1 -1
  22. package/dist/lib.d.ts +10 -2
  23. package/dist/lib.d.ts.map +1 -1
  24. package/dist/lib.js +55 -6
  25. package/dist/lib.js.map +1 -1
  26. package/dist/prompts/build-rpa.d.ts.map +1 -1
  27. package/dist/prompts/build-rpa.js +39 -5
  28. package/dist/prompts/build-rpa.js.map +1 -1
  29. package/dist/prompts/debug-execution.d.ts.map +1 -1
  30. package/dist/prompts/debug-execution.js +5 -3
  31. package/dist/prompts/debug-execution.js.map +1 -1
  32. package/dist/setup.js +86 -32
  33. package/dist/setup.js.map +1 -1
  34. package/dist/state.d.ts +14 -0
  35. package/dist/state.d.ts.map +1 -1
  36. package/dist/state.js +20 -0
  37. package/dist/state.js.map +1 -1
  38. package/dist/tools/{stats.d.ts → agents.d.ts} +1 -1
  39. package/dist/tools/agents.d.ts.map +1 -0
  40. package/dist/tools/agents.js +92 -0
  41. package/dist/tools/agents.js.map +1 -0
  42. package/dist/tools/config-stores.d.ts.map +1 -1
  43. package/dist/tools/config-stores.js +59 -11
  44. package/dist/tools/config-stores.js.map +1 -1
  45. package/dist/tools/core.d.ts.map +1 -1
  46. package/dist/tools/core.js +141 -33
  47. package/dist/tools/core.js.map +1 -1
  48. package/dist/tools/issues.d.ts.map +1 -1
  49. package/dist/tools/issues.js +51 -16
  50. package/dist/tools/issues.js.map +1 -1
  51. package/dist/tools/sync-tools.d.ts.map +1 -1
  52. package/dist/tools/sync-tools.js +29 -12
  53. package/dist/tools/sync-tools.js.map +1 -1
  54. package/dist/tools/tfa.d.ts.map +1 -1
  55. package/dist/tools/tfa.js +42 -22
  56. package/dist/tools/tfa.js.map +1 -1
  57. package/dist/tools/vm-rpa.d.ts.map +1 -1
  58. package/dist/tools/vm-rpa.js +15 -7
  59. package/dist/tools/vm-rpa.js.map +1 -1
  60. package/dist/tools/vm.d.ts.map +1 -1
  61. package/dist/tools/vm.js +380 -12
  62. package/dist/tools/vm.js.map +1 -1
  63. package/dist/tools/workflow-ops.d.ts.map +1 -1
  64. package/dist/tools/workflow-ops.js +46 -30
  65. package/dist/tools/workflow-ops.js.map +1 -1
  66. package/dist/types.d.ts +8 -2
  67. package/dist/types.d.ts.map +1 -1
  68. package/dist/vm-service-client.d.ts +24 -0
  69. package/dist/vm-service-client.d.ts.map +1 -0
  70. package/dist/vm-service-client.js +23 -0
  71. package/dist/vm-service-client.js.map +1 -0
  72. package/package.json +2 -2
  73. package/dist/browser-client.d.ts +0 -42
  74. package/dist/browser-client.d.ts.map +0 -1
  75. package/dist/browser-client.js +0 -66
  76. package/dist/browser-client.js.map +0 -1
  77. package/dist/prompts/build-browser-rpa.d.ts +0 -3
  78. package/dist/prompts/build-browser-rpa.d.ts.map +0 -1
  79. package/dist/prompts/build-browser-rpa.js +0 -90
  80. package/dist/prompts/build-browser-rpa.js.map +0 -1
  81. package/dist/prompts/build-nerve-rpa.d.ts +0 -3
  82. package/dist/prompts/build-nerve-rpa.d.ts.map +0 -1
  83. package/dist/prompts/build-nerve-rpa.js +0 -148
  84. package/dist/prompts/build-nerve-rpa.js.map +0 -1
  85. package/dist/services.d.ts +0 -61
  86. package/dist/services.d.ts.map +0 -1
  87. package/dist/services.js +0 -249
  88. package/dist/services.js.map +0 -1
  89. package/dist/tools/browser.d.ts +0 -3
  90. package/dist/tools/browser.d.ts.map +0 -1
  91. package/dist/tools/browser.js +0 -254
  92. package/dist/tools/browser.js.map +0 -1
  93. package/dist/tools/cron.d.ts +0 -3
  94. package/dist/tools/cron.d.ts.map +0 -1
  95. package/dist/tools/cron.js +0 -168
  96. package/dist/tools/cron.js.map +0 -1
  97. package/dist/tools/elasticsearch.d.ts +0 -3
  98. package/dist/tools/elasticsearch.d.ts.map +0 -1
  99. package/dist/tools/elasticsearch.js +0 -248
  100. package/dist/tools/elasticsearch.js.map +0 -1
  101. package/dist/tools/stats.d.ts.map +0 -1
  102. package/dist/tools/stats.js +0 -18
  103. package/dist/tools/stats.js.map +0 -1
@@ -1,148 +0,0 @@
1
- import { z } from "zod";
2
- export function register({ server }) {
3
- server.prompt("build-nerve-rpa-workflow", "Build an RPA workflow using NERVE's atomic operations: annotated screenshots, element clicking/typing, CDP browser control, OCR, and self-healing. Optimized for NERVE (not legacy LDS).", {
4
- workspaceId: z.string().describe("Laminar workspace ID"),
5
- task: z.string().describe("What to automate"),
6
- appName: z.string().describe("Target application name"),
7
- workflowId: z.string().optional().describe("Existing workflow ID to add steps to"),
8
- }, async ({ workspaceId, task, appName, workflowId }) => ({
9
- messages: [
10
- {
11
- role: "user",
12
- content: {
13
- type: "text",
14
- text: `You are building an RPA workflow using NERVE on the Laminar platform. NERVE gives you direct atomic control over the Windows desktop — you do NOT need to write Python scripts for simple interactions.
15
-
16
- ## Task
17
- ${task}
18
-
19
- ## Target Application
20
- ${appName}
21
-
22
- ## Workspace
23
- ID: ${workspaceId}${workflowId ? `\nExisting workflow ID: ${workflowId}` : "\nCreate a new workflow for this automation."}
24
-
25
- ## How NERVE Works
26
-
27
- NERVE runs on the VM and exposes the full OS via HTTP APIs. When you call \`vm_connect\`, check the \`capabilities\` array in the response to see what's available.
28
-
29
- Key capabilities:
30
- - \`annotated_screenshots\` — X-Ray Vision: screenshot with numbered element overlays
31
- - \`ui_tree_cache\` — Persistent accessibility tree
32
- - \`atomic_input\` — Click/type/invoke by element ID
33
- - \`script_execution\` — Run Python scripts
34
- - \`cdp\` — Chrome DevTools Protocol for browser control
35
- - \`ocr\` / \`template_matching\` — For Citrix/pixel-based apps
36
- - \`self_healing\` — Pause on error + intervention
37
-
38
- ## Step 1: Connect and Survey
39
-
40
- 1. \`vm_connect\` — connect to the VM
41
- 2. Check \`capabilities\` in the response
42
- 3. \`vm_annotated_screenshot\` — see the desktop with numbered elements
43
- 4. \`vm_system_info\` — get OS, RAM, CPU info
44
- 5. \`vm_processes\` — see what's running
45
-
46
- ## Step 2: Understand the UI
47
-
48
- Use the annotated screenshot to understand the screen. Each interactive element has a number:
49
- \`\`\`
50
- [1] Username field (Edit)
51
- [2] Password field (Edit)
52
- [3] OK button (Button)
53
- [4] Cancel button (Button)
54
- \`\`\`
55
-
56
- For deeper inspection:
57
- - \`vm_inspect_ui\` mode \`element_tree\` — full accessibility tree
58
- - \`vm_inspect_ui\` mode \`element_at_point\` — inspect specific coordinates
59
-
60
- ## Step 3: Interact with Atomic Operations
61
-
62
- **DO NOT write Python scripts for simple click/type operations.** Use atomic tools:
63
-
64
- - \`vm_click_element\` {element_id: 3} — click element #3 from annotated screenshot
65
- - \`vm_type_into_element\` {element_id: 1, text: "admin"} — type into element #1
66
- - \`vm_set_value\` {element_id: 2, value: "password"} — set value directly
67
- - \`vm_invoke_element\` {element_id: 3} — invoke button via accessibility pattern
68
- - \`vm_shell\` {command: "Start-Process notepad"} — run commands
69
-
70
- After each action, take another \`vm_annotated_screenshot\` to verify it worked.
71
-
72
- ## Step 4: For Web Apps — Use CDP
73
-
74
- If the target is a browser or Electron app:
75
-
76
- 1. \`cdp_connect\` — connect to Chrome/Edge DevTools
77
- 2. \`cdp_dom\` — get the full DOM tree
78
- 3. \`cdp_query\` {selector: "#username"} — find elements by CSS
79
- 4. \`cdp_click\` {selector: "#login-btn"} — click via DOM
80
- 5. \`cdp_type\` {selector: "#email", text: "user@example.com"} — type via DOM
81
- 6. \`cdp_js\` — execute arbitrary JavaScript
82
- 7. \`cdp_network\` — see API calls the app makes
83
-
84
- CDP is MORE RELIABLE than screen-based automation for web apps.
85
-
86
- ## Step 5: For Citrix / Legacy Apps — Use OCR + Template Matching
87
-
88
- When there's no accessibility tree (Citrix, RDP, custom-rendered apps):
89
-
90
- 1. \`vm_ocr\` {x, y, width, height} — read text from a screen region
91
- 2. \`vm_template_match\` {template_b64: "..."} — find a visual element
92
- 3. \`vm_wait_for_text\` {text: "Login", region: {...}} — wait for text to appear
93
- 4. \`vm_wait_for_change\` {region: {...}} — wait for visual change (replaces sleep)
94
- 5. \`vm_region_ocr\` {regions: [...]} — batch OCR multiple fields
95
- 6. Click by coordinates from template match results
96
-
97
- ## Step 6: Build Production Scripts
98
-
99
- Once you understand the UI and have tested atomic operations, consolidate into Python scripts for production:
100
-
101
- 1. Write a Python script that performs the full sequence
102
- 2. Test with \`debug_rpa_step\` — returns before/after screenshots + timeline
103
- 3. Save with \`create_rpa_flow\` — wraps Python in Laminar workflow format
104
-
105
- ## Step 7: Self-Healing Pattern
106
-
107
- For robust automations, enable self-healing:
108
-
109
- 1. Execute with \`on_error: "pause"\` — script pauses at failure instead of crashing
110
- 2. \`vm_failure_context\` — get screenshot, UI tree, error details at failure point
111
- 3. \`vm_annotated_screenshot\` — see current screen state
112
- 4. Fix with atomic operations (\`vm_click_element\`, etc.)
113
- 5. Resume execution
114
-
115
- ## Step 8: End-to-End Validation
116
-
117
- 1. \`execute_workflow\` to run the full sequence
118
- 2. \`vm_annotated_screenshot\` to verify final state
119
- 3. \`vm_execution_timeline\` to review frame-by-frame what happened
120
- 4. \`diagnose_execution\` if anything fails
121
-
122
- ## Data Extraction Priority
123
-
124
- When you need to READ data from the screen:
125
-
126
- 1. **Accessibility tree** — \`vm_inspect_ui\` with \`element_tree\` (most reliable)
127
- 2. **Focused element** — Tab through fields, read via \`vm_inspect_ui\` \`focused_element\`
128
- 3. **Clipboard** — Click field, Ctrl+A, Ctrl+C, then \`vm_read_clipboard\`
129
- 4. **OCR** — \`vm_ocr\` on a specific region
130
- 5. **CDP extraction** — \`cdp_js\` to read DOM values (for web apps)
131
- 6. **Region screenshot** — \`vm_screenshot\` of a specific area (last resort)
132
-
133
- ## Key Rules
134
-
135
- - **Annotated screenshots FIRST** — always start by seeing the screen with element IDs
136
- - **Atomic ops for exploration** — use click/type tools to test, scripts for production
137
- - **Verify after every action** — take another annotated screenshot
138
- - **Never hardcode coordinates** — use element IDs or accessibility patterns
139
- - **Use wait_for_text/wait_for_change** — never use time.sleep() for synchronization
140
- - **Use \`create_rpa_flow\`** to save steps — never construct JS wrappers manually
141
- - **Use \`{{config.variables}}\`** for secrets — never hardcode credentials
142
- `,
143
- },
144
- },
145
- ],
146
- }));
147
- }
148
- //# sourceMappingURL=build-nerve-rpa.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"build-nerve-rpa.js","sourceRoot":"","sources":["../../src/prompts/build-nerve-rpa.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,MAAM,UAAU,QAAQ,CAAC,EAAE,MAAM,EAAY;IAC3C,MAAM,CAAC,MAAM,CACX,0BAA0B,EAC1B,0LAA0L,EAC1L;QACE,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,sBAAsB,CAAC;QACxD,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;QAC7C,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,yBAAyB,CAAC;QACvD,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,sCAAsC,CAAC;KACnF,EACD,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAe;gBACrB,OAAO,EAAE;oBACP,IAAI,EAAE,MAAe;oBACrB,IAAI,EAAE;;;EAGhB,IAAI;;;EAGJ,OAAO;;;MAGH,WAAW,GAAG,UAAU,CAAC,CAAC,CAAC,2BAA2B,UAAU,EAAE,CAAC,CAAC,CAAC,8CAA8C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuHxH;iBACU;aACF;SACF;KACF,CAAC,CACH,CAAC;AACJ,CAAC"}
@@ -1,61 +0,0 @@
1
- /**
2
- * Optional service clients: Elasticsearch + CRON.
3
- * Only instantiated when configured — otherwise tools degrade gracefully.
4
- */
5
- import type { ElasticsearchConfig, CronConfig } from "./config.js";
6
- export interface ESSearchParams {
7
- workspaceId: string;
8
- workflowId?: string;
9
- workflowIds?: string[];
10
- query?: string;
11
- startDate?: string;
12
- endDate?: string;
13
- status?: string;
14
- includeGlobalObject?: boolean;
15
- rawQuery?: string;
16
- fuzzy?: boolean;
17
- size?: number;
18
- from?: number;
19
- }
20
- export declare class ElasticsearchService {
21
- private endpoint;
22
- private apiKey;
23
- private indexName;
24
- constructor(config: ElasticsearchConfig);
25
- private esRequest;
26
- search(params: ESSearchParams): Promise<{
27
- warning?: string | undefined;
28
- hits: any;
29
- total: any;
30
- took: any;
31
- }>;
32
- private formatResults;
33
- }
34
- export declare class CronService {
35
- private apiBase;
36
- private apiKey;
37
- constructor(config: CronConfig);
38
- private request;
39
- listJobs(workflowId?: string): Promise<any[]>;
40
- getJob(jobId: string): Promise<any>;
41
- createJob(job: {
42
- name: string;
43
- schedule: string;
44
- url: string;
45
- body?: Record<string, any>;
46
- enabled?: boolean;
47
- max_runs?: number | null;
48
- is_temporary?: boolean;
49
- }): Promise<any>;
50
- updateJob(jobId: string, updates: {
51
- name?: string;
52
- schedule?: string;
53
- url?: string;
54
- body?: Record<string, any>;
55
- enabled?: boolean;
56
- }): Promise<any>;
57
- toggleJob(jobId: string): Promise<any>;
58
- deleteJob(jobId: string): Promise<void>;
59
- triggerJob(jobId: string): Promise<void>;
60
- }
61
- //# sourceMappingURL=services.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"services.d.ts","sourceRoot":"","sources":["../src/services.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAOnE,MAAM,WAAW,cAAc;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,SAAS,CAAS;gBAEd,MAAM,EAAE,mBAAmB;YAMzB,SAAS;IAmBjB,MAAM,CAAC,MAAM,EAAE,cAAc;;;;;;IAmJnC,OAAO,CAAC,aAAa;CAyBtB;AAID,qBAAa,WAAW;IACtB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,MAAM,CAAS;gBAEX,MAAM,EAAE,UAAU;YAKhB,OAAO;IA+Bf,QAAQ,CAAC,UAAU,CAAC,EAAE,MAAM;IAY5B,MAAM,CAAC,KAAK,EAAE,MAAM;IAKpB,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QACzB,YAAY,CAAC,EAAE,OAAO,CAAC;KACxB;IASK,SAAS,CACb,KAAK,EAAE,MAAM,EACb,OAAO,EAAE;QACP,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB;IAUG,SAAS,CAAC,KAAK,EAAE,MAAM;IAKvB,SAAS,CAAC,KAAK,EAAE,MAAM;IAIvB,UAAU,CAAC,KAAK,EAAE,MAAM;CAG/B"}
package/dist/services.js DELETED
@@ -1,249 +0,0 @@
1
- /**
2
- * Optional service clients: Elasticsearch + CRON.
3
- * Only instantiated when configured — otherwise tools degrade gracefully.
4
- */
5
- const DEFAULT_ES_INDEX = "search-workflow-executions";
6
- const DEFAULT_CRON_BASE = "https://cron.laminar.run";
7
- export class ElasticsearchService {
8
- endpoint;
9
- apiKey;
10
- indexName;
11
- constructor(config) {
12
- this.endpoint = config.endpoint.replace(/\/$/, "");
13
- this.apiKey = config.apiKey;
14
- this.indexName = config.indexName || DEFAULT_ES_INDEX;
15
- }
16
- async esRequest(body) {
17
- const res = await fetch(`${this.endpoint}/${this.indexName}/_search`, {
18
- method: "POST",
19
- headers: {
20
- "Content-Type": "application/json",
21
- Authorization: `ApiKey ${this.apiKey}`,
22
- },
23
- body: JSON.stringify(body),
24
- });
25
- if (!res.ok) {
26
- const err = await res.text().catch(() => "");
27
- throw new Error(`Elasticsearch (${res.status}): ${err}`);
28
- }
29
- return res.json();
30
- }
31
- async search(params) {
32
- const { workspaceId, workflowId, workflowIds, query, startDate, endDate, status, includeGlobalObject = false, rawQuery, fuzzy = false, size = 20, from = 0, } = params;
33
- let searchBody;
34
- if (rawQuery) {
35
- const parsed = JSON.parse(rawQuery);
36
- if (!parsed.query)
37
- parsed.query = { bool: { must: [] } };
38
- if (!parsed.query.bool)
39
- parsed.query = { bool: { must: [parsed.query] } };
40
- if (!parsed.query.bool.must)
41
- parsed.query.bool.must = [];
42
- if (!JSON.stringify(parsed).includes(`"workspaceId":"${workspaceId}"`)) {
43
- parsed.query.bool.must.push({ term: { workspaceId } });
44
- }
45
- searchBody = { ...parsed, size, from };
46
- }
47
- else {
48
- const esQuery = {
49
- bool: { must: [{ term: { workspaceId } }], filter: [] },
50
- };
51
- if (workflowId) {
52
- esQuery.bool.must.push({ term: { workflowId } });
53
- }
54
- else if (workflowIds?.length) {
55
- esQuery.bool.must.push({ terms: { workflowId: workflowIds } });
56
- }
57
- if (status)
58
- esQuery.bool.must.push({ term: { status } });
59
- if (startDate || endDate) {
60
- const range = {};
61
- if (startDate)
62
- range.gte = startDate;
63
- if (endDate)
64
- range.lte = endDate;
65
- esQuery.bool.filter.push({ range: { startedAt: range } });
66
- }
67
- if (query?.trim()) {
68
- const q = query.trim();
69
- const nested = {
70
- nested: {
71
- path: "flows",
72
- query: {
73
- multi_match: {
74
- query: q,
75
- fields: [
76
- "flows.log^4",
77
- "flows.response^3",
78
- "flows.program^2",
79
- "flows.transformation^2",
80
- "flows.flowName^3",
81
- ],
82
- type: "best_fields",
83
- operator: fuzzy ? "OR" : "AND",
84
- ...(fuzzy ? { fuzziness: "AUTO" } : {}),
85
- },
86
- },
87
- inner_hits: {
88
- size: 10,
89
- highlight: {
90
- fields: {
91
- "flows.log": { fragment_size: 300, number_of_fragments: 3 },
92
- "flows.response": {
93
- fragment_size: 200,
94
- number_of_fragments: 2,
95
- },
96
- "flows.program": {
97
- fragment_size: 150,
98
- number_of_fragments: 1,
99
- },
100
- "flows.transformation": {
101
- fragment_size: 150,
102
- number_of_fragments: 1,
103
- },
104
- },
105
- pre_tags: [">>"],
106
- post_tags: ["<<"],
107
- },
108
- },
109
- },
110
- };
111
- if (includeGlobalObject) {
112
- esQuery.bool.must.push({
113
- bool: {
114
- should: [
115
- nested,
116
- {
117
- match: {
118
- globalJson: {
119
- query: q,
120
- operator: fuzzy ? "OR" : "AND",
121
- ...(fuzzy ? { fuzziness: "AUTO" } : {}),
122
- boost: 1,
123
- },
124
- },
125
- },
126
- ],
127
- minimum_should_match: 1,
128
- },
129
- });
130
- }
131
- else {
132
- esQuery.bool.must.push(nested);
133
- }
134
- }
135
- searchBody = {
136
- query: esQuery,
137
- sort: ["_score", { startedAt: { order: "desc" } }],
138
- size,
139
- from,
140
- };
141
- }
142
- const data = await this.esRequest(searchBody);
143
- // Retry without highlighting on shard failures
144
- if (data._shards?.failed > 0 &&
145
- !data.hits?.hits?.length &&
146
- (data.hits?.total?.value || 0) > 0) {
147
- try {
148
- const retry = await this.esRequest({
149
- ...searchBody,
150
- highlight: undefined,
151
- });
152
- if (retry.hits?.hits?.length) {
153
- return this.formatResults(retry, true);
154
- }
155
- }
156
- catch { }
157
- }
158
- return this.formatResults(data, false);
159
- }
160
- formatResults(data, noHighlight) {
161
- return {
162
- hits: (data.hits?.hits || []).map((hit) => ({
163
- id: hit._id,
164
- score: hit._score,
165
- workflowId: hit._source?.workflowId,
166
- workflowName: hit._source?.workflowName,
167
- executionId: hit._source?.executionId,
168
- status: hit._source?.status,
169
- startedAt: hit._source?.startedAt,
170
- endedAt: hit._source?.endedAt,
171
- highlight: hit.highlight || {},
172
- inner_hits: hit.inner_hits || {},
173
- })),
174
- total: data.hits?.total?.value || data.hits?.total || 0,
175
- took: data.took,
176
- ...(noHighlight && {
177
- warning: "Results loaded without highlighting due to large fields",
178
- }),
179
- ...(data._shards?.failed > 0 &&
180
- !noHighlight && {
181
- warning: "Some results may be missing due to large field values",
182
- }),
183
- };
184
- }
185
- }
186
- // ── CRON ──────────────────────────────────────────────────────
187
- export class CronService {
188
- apiBase;
189
- apiKey;
190
- constructor(config) {
191
- this.apiBase = (config.apiBase || DEFAULT_CRON_BASE).replace(/\/$/, "");
192
- this.apiKey = config.apiKey;
193
- }
194
- async request(method, endpoint, data) {
195
- const res = await fetch(`${this.apiBase}/${endpoint}`, {
196
- method,
197
- headers: {
198
- "Content-Type": "application/json",
199
- "X-API-Key": this.apiKey,
200
- },
201
- body: data ? JSON.stringify(data) : undefined,
202
- });
203
- if (!res.ok) {
204
- const errText = await res.text().catch(() => "");
205
- let msg;
206
- try {
207
- msg = JSON.parse(errText).error || errText;
208
- }
209
- catch {
210
- msg = errText;
211
- }
212
- throw new Error(msg || `CRON API ${method} ${endpoint} failed (${res.status})`);
213
- }
214
- if (method === "DELETE")
215
- return true;
216
- return res.json();
217
- }
218
- async listJobs(workflowId) {
219
- if (workflowId) {
220
- const d = await this.request("GET", `api/workflows/${workflowId}/jobs`);
221
- return d.jobs || [];
222
- }
223
- const d = await this.request("GET", "api/jobs");
224
- return d.jobs || [];
225
- }
226
- async getJob(jobId) {
227
- const d = await this.request("GET", `api/jobs/${jobId}`);
228
- return d.job;
229
- }
230
- async createJob(job) {
231
- const d = await this.request("POST", "api/jobs", job);
232
- return this.getJob(d.job_id);
233
- }
234
- async updateJob(jobId, updates) {
235
- const d = await this.request("PUT", `api/jobs/${jobId}`, updates);
236
- return d.job;
237
- }
238
- async toggleJob(jobId) {
239
- const cur = await this.getJob(jobId);
240
- return this.updateJob(jobId, { enabled: !cur.enabled });
241
- }
242
- async deleteJob(jobId) {
243
- await this.request("DELETE", `api/jobs/${jobId}`);
244
- }
245
- async triggerJob(jobId) {
246
- await this.request("POST", `api/jobs/${jobId}/trigger`);
247
- }
248
- }
249
- //# sourceMappingURL=services.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"services.js","sourceRoot":"","sources":["../src/services.ts"],"names":[],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- import type { ToolDeps } from "../types.js";
2
- export declare function register(deps: ToolDeps): void;
3
- //# sourceMappingURL=browser.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"browser.d.ts","sourceRoot":"","sources":["../../src/tools/browser.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAiC5C,wBAAgB,QAAQ,CAAC,IAAI,EAAE,QAAQ,QAyRtC"}